UNPKG

@aws-cdk/cx-api

Version:

Cloud executable protocol

117 lines 13.9 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.CloudArtifact = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const metadata_1 = require("./metadata"); const cxschema = require("@aws-cdk/cloud-assembly-schema"); const error_1 = require("./private/error"); /** * Represents an artifact within a cloud assembly. */ class CloudArtifact { /** * 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) { try { jsiiDeprecationWarnings._aws_cdk_cx_api_CloudAssembly(assembly); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromManifest); } throw error; } // 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; try { jsiiDeprecationWarnings._aws_cdk_cx_api_CloudAssembly(assembly); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, CloudArtifact); } throw error; } this.manifest = manifest; this.messages = this.renderMessages(); this._dependencyIDs = manifest.dependencies || []; } /** * 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 result = new Array(); for (const path of Object.keys(this.manifest.metadata || {})) { for (const entry of (this.manifest.metadata || {})[path]) { if (entry.type === type) { result.push({ path, ...entry }); } } } return result; } renderMessages() { const messages = new Array(); for (const [id, metadata] of Object.entries(this.manifest.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; _a = JSII_RTTI_SYMBOL_1; CloudArtifact[_a] = { fqn: "@aws-cdk/cx-api.CloudArtifact", version: "2.211.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-artifact.js","sourceRoot":"","sources":["cloud-artifact.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CloudAssembly } from './cloud-assembly';\nimport { MetadataEntryResult, SynthesisMessage, SynthesisMessageLevel } from './metadata';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\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   * 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 all the artifacts that this artifact depends on.\n   */\n  public get dependencies(): CloudArtifact[] {\n    if (this._deps) { return this._deps; }\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 result = new Array<MetadataEntryResult>();\n    for (const path of Object.keys(this.manifest.metadata || {})) {\n      for (const entry of (this.manifest.metadata || {})[path]) {\n        if (entry.type === type) {\n          result.push({ path, ...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.manifest.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"]}