aws-cdk-lib
Version:
Version 2 of the AWS Cloud Development Kit library
129 lines • 16.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.CloudArtifact = void 0;
const fs = require("fs");
const path = require("path");
const cxschema = require("@aws-cdk/cloud-assembly-schema");
const metadata_1 = require("./metadata");
const error_1 = require("./private/error");
/**
* Represents an artifact within a cloud assembly.
*/
class CloudArtifact {
/**
* Read the metadata for the given artifact
*
* HISTORICAL OR PRIVATE USE ONLY
*
* This is publicly exposed as a static function for downstream libraries that
* don't use the `CloudAssembly`/`CloudArtifact` API, yet still need to read
* an artifact's metadata.
*
* 99% of consumers should just access `artifact.metadata`.
*/
static readMetadata(assemblyDirectory, x) {
const ret = {};
if (x.additionalMetadataFile) {
Object.assign(ret, JSON.parse(fs.readFileSync(path.join(assemblyDirectory, x.additionalMetadataFile), 'utf-8')));
}
for (const [p, entries] of Object.entries(x.metadata ?? {})) {
if (ret[p]) {
ret[p].push(...entries);
}
else {
ret[p] = entries;
}
}
return ret;
}
/**
* Returns a subclass of `CloudArtifact` based on the artifact type defined in the artifact manifest.
*
* @param assembly - The cloud assembly from which to load the artifact
* @param id - The artifact ID
* @param artifact - The artifact manifest
* @returns the `CloudArtifact` that matches the artifact type or `undefined` if it's an artifact type that is unrecognized by this module.
*/
static fromManifest(assembly, id, artifact) {
// Implementation is defined in a separate file to break cyclic dependencies
void (assembly), void (id), void (artifact);
throw new error_1.CloudAssemblyError('Implementation not overridden yet');
}
constructor(assembly, id, manifest) {
this.assembly = assembly;
this.id = id;
this.manifest = manifest;
this.messages = this.renderMessages();
this._dependencyIDs = manifest.dependencies || [];
}
/**
* Returns the metadata associated with this Cloud Artifact
*/
get metadata() {
return CloudArtifact.readMetadata(this.assembly.directory, this.manifest);
}
/**
* Returns all the artifacts that this artifact depends on.
*/
get dependencies() {
if (this._deps) {
return this._deps;
}
this._deps = this._dependencyIDs.map(id => {
const dep = this.assembly.tryGetArtifact(id);
if (!dep) {
throw new error_1.CloudAssemblyError(`Artifact ${this.id} depends on non-existing artifact ${id}`);
}
return dep;
});
return this._deps;
}
/**
* @returns all the metadata entries of a specific type in this artifact.
*/
findMetadataByType(type) {
const metadata = this.metadata;
const result = new Array();
for (const p of Object.keys(metadata || {})) {
for (const entry of (metadata || {})[p]) {
if (entry.type === type) {
result.push({ path: p, ...entry });
}
}
}
return result;
}
renderMessages() {
const messages = new Array();
for (const [id, metadata] of Object.entries(this.metadata || {})) {
for (const entry of metadata) {
let level;
switch (entry.type) {
case cxschema.ArtifactMetadataEntryType.WARN:
level = metadata_1.SynthesisMessageLevel.WARNING;
break;
case cxschema.ArtifactMetadataEntryType.ERROR:
level = metadata_1.SynthesisMessageLevel.ERROR;
break;
case cxschema.ArtifactMetadataEntryType.INFO:
level = metadata_1.SynthesisMessageLevel.INFO;
break;
default:
continue;
}
messages.push({ level, entry, id });
}
}
return messages;
}
/**
* An identifier that shows where this artifact is located in the tree
* of nested assemblies, based on their manifests. Defaults to the normal
* id. Should only be used in user interfaces.
*/
get hierarchicalId() {
return this.manifest.displayName ?? this.id;
}
}
exports.CloudArtifact = CloudArtifact;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-artifact.js","sourceRoot":"","sources":["cloud-artifact.ts"],"names":[],"mappings":";;;AAAA,yBAAyB;AACzB,6BAA6B;AAC7B,2DAA2D;AAG3D,yCAAmD;AACnD,2CAAqD;AA8BrD;;GAEG;AACH,MAAa,aAAa;IACxB;;;;;;;;;;OAUG;IACI,MAAM,CAAC,YAAY,CAAC,iBAAyB,EAAE,CAA4B;QAChF,MAAM,GAAG,GAA6C,EAAE,CAAC;QACzD,IAAI,CAAC,CAAC,sBAAsB,EAAE,CAAC;YAC7B,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,sBAAsB,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;QACnH,CAAC;QAED,KAAK,MAAM,CAAC,CAAC,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,IAAI,EAAE,CAAC,EAAE,CAAC;YAC5D,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;gBACX,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;YAC1B,CAAC;iBAAM,CAAC;gBACN,GAAG,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;YACnB,CAAC;QACH,CAAC;QAED,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;;;;;;OAOG;IACI,MAAM,CAAC,YAAY,CAAC,QAAuB,EAAE,EAAU,EAAE,QAAmC;QACjG,4EAA4E;QAC5E,KAAI,CAAC,QAAQ,CAAC,EAAE,KAAI,CAAC,EAAE,CAAC,EAAE,KAAI,CAAC,QAAQ,CAAC,CAAC;QACzC,MAAM,IAAI,0BAAkB,CAAC,mCAAmC,CAAC,CAAC;IACpE,CAAC;IAuBD,YAAsC,QAAuB,EAAkB,EAAU,EAAE,QAAmC;QAAxF,aAAQ,GAAR,QAAQ,CAAe;QAAkB,OAAE,GAAF,EAAE,CAAQ;QACvF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACtC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,YAAY,IAAI,EAAE,CAAC;IACpD,CAAC;IAED;;OAEG;IACH,IAAW,QAAQ;QACjB,OAAO,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACH,IAAW,YAAY;QACrB,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;QAED,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;YACxC,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;YAC7C,IAAI,CAAC,GAAG,EAAE,CAAC;gBACT,MAAM,IAAI,0BAAkB,CAAC,YAAY,IAAI,CAAC,EAAE,qCAAqC,EAAE,EAAE,CAAC,CAAC;YAC7F,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;OAEG;IACI,kBAAkB,CAAC,IAAY;QACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE/B,MAAM,MAAM,GAAG,IAAI,KAAK,EAAuB,CAAC;QAChD,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC,EAAE,CAAC;YAC5C,KAAK,MAAM,KAAK,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBACxC,IAAI,KAAK,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;oBACxB,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;gBACrC,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,cAAc;QACpB,MAAM,QAAQ,GAAG,IAAI,KAAK,EAAoB,CAAC;QAE/C,KAAK,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAG,CAAC,EAAE,CAAC;YAClE,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;gBAC7B,IAAI,KAA4B,CAAC;gBACjC,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;oBACnB,KAAK,QAAQ,CAAC,yBAAyB,CAAC,IAAI;wBAC1C,KAAK,GAAG,gCAAqB,CAAC,OAAO,CAAC;wBACtC,MAAM;oBACR,KAAK,QAAQ,CAAC,yBAAyB,CAAC,KAAK;wBAC3C,KAAK,GAAG,gCAAqB,CAAC,KAAK,CAAC;wBACpC,MAAM;oBACR,KAAK,QAAQ,CAAC,yBAAyB,CAAC,IAAI;wBAC1C,KAAK,GAAG,gCAAqB,CAAC,IAAI,CAAC;wBACnC,MAAM;oBACR;wBACE,SAAS;gBACb,CAAC;gBAED,QAAQ,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;YACtC,CAAC;QACH,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;;OAIG;IACH,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC,WAAW,IAAI,IAAI,CAAC,EAAE,CAAC;IAC9C,CAAC;CACF;AApJD,sCAoJC","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport type { CloudAssembly } from './cloud-assembly';\nimport type { MetadataEntryResult, SynthesisMessage } from './metadata';\nimport { SynthesisMessageLevel } from './metadata';\nimport { CloudAssemblyError } from './private/error';\n\n/**\n * Artifact properties for CloudFormation stacks.\n */\nexport interface AwsCloudFormationStackProperties {\n  /**\n   * A file relative to the assembly root which contains the CloudFormation template for this stack.\n   */\n  readonly templateFile: string;\n\n  /**\n   * Values for CloudFormation stack parameters that should be passed when the stack is deployed.\n   */\n  readonly parameters?: { [id: string]: string };\n\n  /**\n   * The name to use for the CloudFormation stack.\n   * @default - name derived from artifact ID\n   */\n  readonly stackName?: string;\n\n  /**\n   * Whether to enable termination protection for this stack.\n   *\n   * @default false\n   */\n  readonly terminationProtection?: boolean;\n}\n\n/**\n * Represents an artifact within a cloud assembly.\n */\nexport class CloudArtifact {\n  /**\n   * Read the metadata for the given artifact\n   *\n   * HISTORICAL OR PRIVATE USE ONLY\n   *\n   * This is publicly exposed as a static function for downstream libraries that\n   * don't use the `CloudAssembly`/`CloudArtifact` API, yet still need to read\n   * an artifact's metadata.\n   *\n   * 99% of consumers should just access `artifact.metadata`.\n   */\n  public static readMetadata(assemblyDirectory: string, x: cxschema.ArtifactManifest): Record<string, cxschema.MetadataEntry[]> {\n    const ret: Record<string, cxschema.MetadataEntry[]> = {};\n    if (x.additionalMetadataFile) {\n      Object.assign(ret, JSON.parse(fs.readFileSync(path.join(assemblyDirectory, x.additionalMetadataFile), 'utf-8')));\n    }\n\n    for (const [p, entries] of Object.entries(x.metadata ?? {})) {\n      if (ret[p]) {\n        ret[p].push(...entries);\n      } else {\n        ret[p] = entries;\n      }\n    }\n\n    return ret;\n  }\n\n  /**\n   * Returns a subclass of `CloudArtifact` based on the artifact type defined in the artifact manifest.\n   *\n   * @param assembly - The cloud assembly from which to load the artifact\n   * @param id - The artifact ID\n   * @param artifact - The artifact manifest\n   * @returns the `CloudArtifact` that matches the artifact type or `undefined` if it's an artifact type that is unrecognized by this module.\n   */\n  public static fromManifest(assembly: CloudAssembly, id: string, artifact: cxschema.ArtifactManifest): CloudArtifact | undefined {\n    // Implementation is defined in a separate file to break cyclic dependencies\n    void(assembly), void(id), void(artifact);\n    throw new CloudAssemblyError('Implementation not overridden yet');\n  }\n\n  /**\n   * The artifact's manifest\n   */\n  public readonly manifest: cxschema.ArtifactManifest;\n\n  /**\n   * The set of messages extracted from the artifact's metadata.\n   */\n  public readonly messages: SynthesisMessage[];\n\n  /**\n   * IDs of all dependencies. Used when topologically sorting the artifacts within the cloud assembly.\n   * @internal\n   */\n  public readonly _dependencyIDs: string[];\n\n  /**\n   * Cache of resolved dependencies.\n   */\n  private _deps?: CloudArtifact[];\n\n  protected constructor(public readonly assembly: CloudAssembly, public readonly id: string, manifest: cxschema.ArtifactManifest) {\n    this.manifest = manifest;\n    this.messages = this.renderMessages();\n    this._dependencyIDs = manifest.dependencies || [];\n  }\n\n  /**\n   * Returns the metadata associated with this Cloud Artifact\n   */\n  public get metadata() {\n    return CloudArtifact.readMetadata(this.assembly.directory, this.manifest);\n  }\n\n  /**\n   * Returns all the artifacts that this artifact depends on.\n   */\n  public get dependencies(): CloudArtifact[] {\n    if (this._deps) {\n      return this._deps;\n    }\n\n    this._deps = this._dependencyIDs.map(id => {\n      const dep = this.assembly.tryGetArtifact(id);\n      if (!dep) {\n        throw new CloudAssemblyError(`Artifact ${this.id} depends on non-existing artifact ${id}`);\n      }\n      return dep;\n    });\n\n    return this._deps;\n  }\n\n  /**\n   * @returns all the metadata entries of a specific type in this artifact.\n   */\n  public findMetadataByType(type: string): MetadataEntryResult[] {\n    const metadata = this.metadata;\n\n    const result = new Array<MetadataEntryResult>();\n    for (const p of Object.keys(metadata || {})) {\n      for (const entry of (metadata || {})[p]) {\n        if (entry.type === type) {\n          result.push({ path: p, ...entry });\n        }\n      }\n    }\n    return result;\n  }\n\n  private renderMessages() {\n    const messages = new Array<SynthesisMessage>();\n\n    for (const [id, metadata] of Object.entries(this.metadata || { })) {\n      for (const entry of metadata) {\n        let level: SynthesisMessageLevel;\n        switch (entry.type) {\n          case cxschema.ArtifactMetadataEntryType.WARN:\n            level = SynthesisMessageLevel.WARNING;\n            break;\n          case cxschema.ArtifactMetadataEntryType.ERROR:\n            level = SynthesisMessageLevel.ERROR;\n            break;\n          case cxschema.ArtifactMetadataEntryType.INFO:\n            level = SynthesisMessageLevel.INFO;\n            break;\n          default:\n            continue;\n        }\n\n        messages.push({ level, entry, id });\n      }\n    }\n\n    return messages;\n  }\n\n  /**\n   * An identifier that shows where this artifact is located in the tree\n   * of nested assemblies, based on their manifests. Defaults to the normal\n   * id. Should only be used in user interfaces.\n   */\n  public get hierarchicalId(): string {\n    return this.manifest.displayName ?? this.id;\n  }\n}\n"]}