UNPKG

@alicloud/ros-cdk-cxapi

Version:

Aliyun SDK Copyright (C) Alibaba Cloud Computing All rights reserved. http://www.aliyun.com

85 lines 11.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CloudArtifact = void 0; const cxschema = require("@alicloud/ros-cdk-assembly-schema"); const metadata_1 = require("./metadata"); /** * 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) { // Implementation is defined in a separate file to break cyclic dependencies void (assembly), void (id), void (artifact); throw new Error('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 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(`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. * @param type */ 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; } } exports.CloudArtifact = CloudArtifact; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-artifact.js","sourceRoot":"","sources":["cloud-artifact.ts"],"names":[],"mappings":";;;AAAA,8DAA8D;AAE9D,yCAIoB;AAuBpB;;GAEG;AACH,MAAa,aAAa;IACxB;;;;;;OAMG;IACI,MAAM,CAAC,YAAY,CACxB,QAAuB,EACvB,EAAU,EACV,QAAmC;QAEnC,4EAA4E;QAC5E,KAAI,CAAC,QAAQ,CAAC,EAAE,KAAI,CAAC,EAAE,CAAC,EAAE,KAAI,CAAC,QAAQ,CAAC,CAAC;QACzC,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;IACvD,CAAC;IAuBD,YACkB,QAAuB,EACvB,EAAU,EAC1B,QAAmC;QAFnB,aAAQ,GAAR,QAAQ,CAAe;QACvB,OAAE,GAAF,EAAE,CAAQ;QAG1B,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,YAAY;QACrB,oBAAoB;QACpB,uBAAuB;QACvB,IAAI;QAEJ,iDAAiD;QACjD,kDAAkD;QAClD,gBAAgB;QAChB,qFAAqF;QACrF,MAAM;QACN,gBAAgB;QAChB,MAAM;QAEN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;OAGG;IACI,kBAAkB,CAAC,IAAY;QACpC,MAAM,MAAM,GAAG,IAAI,KAAK,EAAuB,CAAC;QAChD,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,IAAI,EAAE,CAAC,EAAE;YAC5D,KAAK,MAAM,KAAK,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE;gBACxD,IAAI,KAAK,CAAC,IAAI,KAAK,IAAI,EAAE;oBACvB,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;iBACjC;aACF;SACF;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,CAAC,QAAQ,IAAI,EAAE,CAAC,EAAE;YACzE,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE;gBAC5B,IAAI,KAA4B,CAAC;gBACjC,QAAQ,KAAK,CAAC,IAAI,EAAE;oBAClB,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;iBACZ;gBAED,QAAQ,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;aACrC;SACF;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AA9GD,sCA8GC","sourcesContent":["import * as cxschema from \"@alicloud/ros-cdk-assembly-schema\";\nimport { CloudAssembly } from \"./cloud-assembly\";\nimport {\n  MetadataEntryResult,\n  SynthesisMessage,\n  SynthesisMessageLevel,\n} from \"./metadata\";\n\n/**\n * Artifact properties for ROS stacks.\n */\nexport interface AliyunRosStackProperties {\n  /**\n   * A file relative to the assembly root which contains the ROS template for this stack.\n   */\n  readonly templateFile: string;\n\n  /**\n   * Values for ROS 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 ROS stack.\n   * @default - name derived from artifact ID\n   */\n  readonly stackName?: string;\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   * @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(\n    assembly: CloudAssembly,\n    id: string,\n    artifact: cxschema.ArtifactManifest\n  ): CloudArtifact | undefined {\n    // Implementation is defined in a separate file to break cyclic dependencies\n    void(assembly), void(id), void(artifact);\n    throw new Error('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(\n    public readonly assembly: CloudAssembly,\n    public readonly id: string,\n    manifest: cxschema.ArtifactManifest\n  ) {\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[] | undefined {\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 Error(`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   * @param type\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"]}