1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.LegacyStackSynthesizer = void 0;
|
5 | const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const cxschema = require("@aws-cdk/cloud-assembly-schema");
|
8 | const cxapi = require("@aws-cdk/cx-api");
|
9 | const cfn_fn_1 = require("../cfn-fn");
|
10 | const construct_compat_1 = require("../construct-compat");
|
11 | const asset_parameters_1 = require("../private/asset-parameters");
|
12 | const _shared_1 = require("./_shared");
|
13 | const stack_synthesizer_1 = require("./stack-synthesizer");
|
14 | /**
|
15 | * The well-known name for the docker image asset ECR repository. All docker
|
16 | * image assets will be pushed into this repository with an image tag based on
|
17 | * the source hash.
|
18 | */
|
19 | const ASSETS_ECR_REPOSITORY_NAME = 'aws-cdk/assets';
|
20 | /**
|
21 | * This allows users to work around the fact that the ECR repository is
|
22 | * (currently) not configurable by setting this context key to their desired
|
23 | * repository name. The CLI will auto-create this ECR repository if it's not
|
24 | * already created.
|
25 | */
|
26 | const ASSETS_ECR_REPOSITORY_NAME_OVERRIDE_CONTEXT_KEY = 'assets-ecr-repository-name';
|
27 | /**
|
28 | * Use the CDK classic way of referencing assets
|
29 | *
|
30 | * This synthesizer will generate CloudFormation parameters for every referenced
|
31 | * asset, and use the CLI's current credentials to deploy the stack.
|
32 | *
|
33 | * - It does not support cross-account deployment (the CLI must have credentials
|
34 | * to the account you are trying to deploy to).
|
35 | * - It cannot be used with **CDK Pipelines**. To deploy using CDK Pipelines,
|
36 | * you must use the `DefaultStackSynthesizer`.
|
37 | * - Each asset will take up a CloudFormation Parameter in your template. Keep in
|
38 | * mind that there is a maximum of 200 parameters in a CloudFormation template.
|
39 | * To use determinstic asset locations instead, use `CliCredentialsStackSynthesizer`.
|
40 | *
|
41 | * Be aware that your CLI credentials must be valid for the duration of the
|
42 | * entire deployment. If you are using session credentials, make sure the
|
43 | * session lifetime is long enough.
|
44 | *
|
45 | * This is the only StackSynthesizer that supports customizing asset behavior
|
46 | * by overriding `Stack.addFileAsset()` and `Stack.addDockerImageAsset()`.
|
47 | */
|
48 | class LegacyStackSynthesizer extends stack_synthesizer_1.StackSynthesizer {
|
49 | constructor() {
|
50 | super(...arguments);
|
51 | this.cycle = false;
|
52 | /**
|
53 | * The image ID of all the docker image assets that were already added to this
|
54 | * stack (to avoid duplication).
|
55 | */
|
56 | this.addedImageAssets = new Set();
|
57 | }
|
58 | bind(stack) {
|
59 | try {
|
60 | jsiiDeprecationWarnings._aws_cdk_core_Stack(stack);
|
61 | }
|
62 | catch (error) {
|
63 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
64 | Error.captureStackTrace(error, this.bind);
|
65 | }
|
66 | throw error;
|
67 | }
|
68 | if (this.stack !== undefined) {
|
69 | throw new Error('A StackSynthesizer can only be used for one Stack: create a new instance to use with a different Stack');
|
70 | }
|
71 | this.stack = stack;
|
72 | }
|
73 | addFileAsset(asset) {
|
74 | try {
|
75 | jsiiDeprecationWarnings._aws_cdk_core_FileAssetSource(asset);
|
76 | }
|
77 | catch (error) {
|
78 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
79 | Error.captureStackTrace(error, this.addFileAsset);
|
80 | }
|
81 | throw error;
|
82 | }
|
83 | _shared_1.assertBound(this.stack);
|
84 | // Backwards compatibility hack. We have a number of conflicting goals here:
|
85 | //
|
86 | // - We want put the actual logic in this class
|
87 | // - We ALSO want to keep supporting people overriding Stack.addFileAsset (for backwards compatibility,
|
88 | // because that mechanism is currently used to make CI/CD scenarios work)
|
89 | // - We ALSO want to allow both entry points from user code (our own framework
|
90 | // code will always call stack.deploymentMechanism.addFileAsset() but existing users
|
91 | // may still be calling `stack.addFileAsset()` directly.
|
92 | //
|
93 | // Solution: delegate call to the stack, but if the stack delegates back to us again
|
94 | // then do the actual logic.
|
95 | //
|
96 | // @deprecated: this can be removed for v2
|
97 | if (this.cycle) {
|
98 | return this.doAddFileAsset(asset);
|
99 | }
|
100 | this.cycle = true;
|
101 | try {
|
102 | const stack = this.stack;
|
103 | return withoutDeprecationWarnings(() => stack.addFileAsset(asset));
|
104 | }
|
105 | finally {
|
106 | this.cycle = false;
|
107 | }
|
108 | }
|
109 | addDockerImageAsset(asset) {
|
110 | try {
|
111 | jsiiDeprecationWarnings._aws_cdk_core_DockerImageAssetSource(asset);
|
112 | }
|
113 | catch (error) {
|
114 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
115 | Error.captureStackTrace(error, this.addDockerImageAsset);
|
116 | }
|
117 | throw error;
|
118 | }
|
119 | _shared_1.assertBound(this.stack);
|
120 | // See `addFileAsset` for explanation.
|
121 | // @deprecated: this can be removed for v2
|
122 | if (this.cycle) {
|
123 | return this.doAddDockerImageAsset(asset);
|
124 | }
|
125 | this.cycle = true;
|
126 | try {
|
127 | const stack = this.stack;
|
128 | return withoutDeprecationWarnings(() => stack.addDockerImageAsset(asset));
|
129 | }
|
130 | finally {
|
131 | this.cycle = false;
|
132 | }
|
133 | }
|
134 | /**
|
135 | * Synthesize the associated stack to the session
|
136 | */
|
137 | synthesize(session) {
|
138 | try {
|
139 | jsiiDeprecationWarnings._aws_cdk_core_ISynthesisSession(session);
|
140 | }
|
141 | catch (error) {
|
142 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
143 | Error.captureStackTrace(error, this.synthesize);
|
144 | }
|
145 | throw error;
|
146 | }
|
147 | _shared_1.assertBound(this.stack);
|
148 | this.synthesizeStackTemplate(this.stack, session);
|
149 | // Just do the default stuff, nothing special
|
150 | this.emitStackArtifact(this.stack, session);
|
151 | }
|
152 | doAddDockerImageAsset(asset) {
|
153 | _shared_1.assertBound(this.stack);
|
154 | // check if we have an override from context
|
155 | const repositoryNameOverride = this.stack.node.tryGetContext(ASSETS_ECR_REPOSITORY_NAME_OVERRIDE_CONTEXT_KEY);
|
156 | const repositoryName = asset.repositoryName ?? repositoryNameOverride ?? ASSETS_ECR_REPOSITORY_NAME;
|
157 | const imageTag = asset.sourceHash;
|
158 | const assetId = asset.sourceHash;
|
159 | // only add every image (identified by source hash) once for each stack that uses it.
|
160 | if (!this.addedImageAssets.has(assetId)) {
|
161 | if (!asset.directoryName) {
|
162 | throw new Error(`LegacyStackSynthesizer does not support this type of file asset: ${JSON.stringify(asset)}`);
|
163 | }
|
164 | const metadata = {
|
165 | repositoryName,
|
166 | imageTag,
|
167 | id: assetId,
|
168 | packaging: 'container-image',
|
169 | path: asset.directoryName,
|
170 | sourceHash: asset.sourceHash,
|
171 | buildArgs: asset.dockerBuildArgs,
|
172 | target: asset.dockerBuildTarget,
|
173 | file: asset.dockerFile,
|
174 | networkMode: asset.networkMode,
|
175 | platform: asset.platform,
|
176 | };
|
177 | this.stack.node.addMetadata(cxschema.ArtifactMetadataEntryType.ASSET, metadata);
|
178 | this.addedImageAssets.add(assetId);
|
179 | }
|
180 | return {
|
181 | imageUri: `${this.stack.account}.dkr.ecr.${this.stack.region}.${this.stack.urlSuffix}/${repositoryName}:${imageTag}`,
|
182 | repositoryName,
|
183 | };
|
184 | }
|
185 | doAddFileAsset(asset) {
|
186 | _shared_1.assertBound(this.stack);
|
187 | let params = this.assetParameters.node.tryFindChild(asset.sourceHash);
|
188 | if (!params) {
|
189 | params = new asset_parameters_1.FileAssetParameters(this.assetParameters, asset.sourceHash);
|
190 | if (!asset.fileName || !asset.packaging) {
|
191 | throw new Error(`LegacyStackSynthesizer does not support this type of file asset: ${JSON.stringify(asset)}`);
|
192 | }
|
193 | const metadata = {
|
194 | path: asset.fileName,
|
195 | id: asset.sourceHash,
|
196 | packaging: asset.packaging,
|
197 | sourceHash: asset.sourceHash,
|
198 | s3BucketParameter: params.bucketNameParameter.logicalId,
|
199 | s3KeyParameter: params.objectKeyParameter.logicalId,
|
200 | artifactHashParameter: params.artifactHashParameter.logicalId,
|
201 | };
|
202 | this.stack.node.addMetadata(cxschema.ArtifactMetadataEntryType.ASSET, metadata);
|
203 | }
|
204 | const bucketName = params.bucketNameParameter.valueAsString;
|
205 | // key is prefix|postfix
|
206 | const encodedKey = params.objectKeyParameter.valueAsString;
|
207 | const s3Prefix = cfn_fn_1.Fn.select(0, cfn_fn_1.Fn.split(cxapi.ASSET_PREFIX_SEPARATOR, encodedKey));
|
208 | const s3Filename = cfn_fn_1.Fn.select(1, cfn_fn_1.Fn.split(cxapi.ASSET_PREFIX_SEPARATOR, encodedKey));
|
209 | const objectKey = `${s3Prefix}${s3Filename}`;
|
210 | const httpUrl = `https://s3.${this.stack.region}.${this.stack.urlSuffix}/${bucketName}/${objectKey}`;
|
211 | const s3ObjectUrl = `s3://${bucketName}/${objectKey}`;
|
212 | return { bucketName, objectKey, httpUrl, s3ObjectUrl, s3Url: httpUrl };
|
213 | }
|
214 | get assetParameters() {
|
215 | _shared_1.assertBound(this.stack);
|
216 | if (!this._assetParameters) {
|
217 | this._assetParameters = new construct_compat_1.Construct(this.stack, 'AssetParameters');
|
218 | }
|
219 | return this._assetParameters;
|
220 | }
|
221 | }
|
222 | exports.LegacyStackSynthesizer = LegacyStackSynthesizer;
|
223 | _a = JSII_RTTI_SYMBOL_1;
|
224 | LegacyStackSynthesizer[_a] = { fqn: "@aws-cdk/core.LegacyStackSynthesizer", version: "1.204.0" };
|
225 | function withoutDeprecationWarnings(block) {
|
226 | const orig = process.env.JSII_DEPRECATED;
|
227 | process.env.JSII_DEPRECATED = 'quiet';
|
228 | try {
|
229 | return block();
|
230 | }
|
231 | finally {
|
232 | process.env.JSII_DEPRECATED = orig;
|
233 | }
|
234 | }
|
235 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"legacy.js","sourceRoot":"","sources":["legacy.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { DockerImageAssetLocation, DockerImageAssetSource, FileAssetLocation, FileAssetSource } from '../assets';\nimport { Fn } from '../cfn-fn';\nimport { Construct, ISynthesisSession } from '../construct-compat';\nimport { FileAssetParameters } from '../private/asset-parameters';\nimport { Stack } from '../stack';\nimport { assertBound } from './_shared';\nimport { StackSynthesizer } from './stack-synthesizer';\n\n/**\n * The well-known name for the docker image asset ECR repository. All docker\n * image assets will be pushed into this repository with an image tag based on\n * the source hash.\n */\nconst ASSETS_ECR_REPOSITORY_NAME = 'aws-cdk/assets';\n\n/**\n * This allows users to work around the fact that the ECR repository is\n * (currently) not configurable by setting this context key to their desired\n * repository name. The CLI will auto-create this ECR repository if it's not\n * already created.\n */\nconst ASSETS_ECR_REPOSITORY_NAME_OVERRIDE_CONTEXT_KEY = 'assets-ecr-repository-name';\n\n/**\n * Use the CDK classic way of referencing assets\n *\n * This synthesizer will generate CloudFormation parameters for every referenced\n * asset, and use the CLI's current credentials to deploy the stack.\n *\n * - It does not support cross-account deployment (the CLI must have credentials\n *   to the account you are trying to deploy to).\n * - It cannot be used with **CDK Pipelines**. To deploy using CDK Pipelines,\n *   you must use the `DefaultStackSynthesizer`.\n * - Each asset will take up a CloudFormation Parameter in your template. Keep in\n *   mind that there is a maximum of 200 parameters in a CloudFormation template.\n *   To use determinstic asset locations instead, use `CliCredentialsStackSynthesizer`.\n *\n * Be aware that your CLI credentials must be valid for the duration of the\n * entire deployment. If you are using session credentials, make sure the\n * session lifetime is long enough.\n *\n * This is the only StackSynthesizer that supports customizing asset behavior\n * by overriding `Stack.addFileAsset()` and `Stack.addDockerImageAsset()`.\n */\nexport class LegacyStackSynthesizer extends StackSynthesizer {\n  private stack?: Stack;\n  private cycle = false;\n\n  /**\n   * Includes all parameters synthesized for assets (lazy).\n   */\n  private _assetParameters?: Construct;\n\n  /**\n   * The image ID of all the docker image assets that were already added to this\n   * stack (to avoid duplication).\n   */\n  private readonly addedImageAssets = new Set<string>();\n\n  public bind(stack: Stack): void {\n    if (this.stack !== undefined) {\n      throw new Error('A StackSynthesizer can only be used for one Stack: create a new instance to use with a different Stack');\n    }\n    this.stack = stack;\n  }\n\n  public addFileAsset(asset: FileAssetSource): FileAssetLocation {\n    assertBound(this.stack);\n\n    // Backwards compatibility hack. We have a number of conflicting goals here:\n    //\n    // - We want put the actual logic in this class\n    // - We ALSO want to keep supporting people overriding Stack.addFileAsset (for backwards compatibility,\n    // because that mechanism is currently used to make CI/CD scenarios work)\n    // - We ALSO want to allow both entry points from user code (our own framework\n    // code will always call stack.deploymentMechanism.addFileAsset() but existing users\n    // may still be calling `stack.addFileAsset()` directly.\n    //\n    // Solution: delegate call to the stack, but if the stack delegates back to us again\n    // then do the actual logic.\n    //\n    // @deprecated: this can be removed for v2\n    if (this.cycle) {\n      return this.doAddFileAsset(asset);\n    }\n    this.cycle = true;\n    try {\n      const stack = this.stack;\n      return withoutDeprecationWarnings(() => stack.addFileAsset(asset));\n    } finally {\n      this.cycle = false;\n    }\n  }\n\n  public addDockerImageAsset(asset: DockerImageAssetSource): DockerImageAssetLocation {\n    assertBound(this.stack);\n\n    // See `addFileAsset` for explanation.\n    // @deprecated: this can be removed for v2\n    if (this.cycle) {\n      return this.doAddDockerImageAsset(asset);\n    }\n    this.cycle = true;\n    try {\n      const stack = this.stack;\n      return withoutDeprecationWarnings(() => stack.addDockerImageAsset(asset));\n    } finally {\n      this.cycle = false;\n    }\n  }\n\n  /**\n   * Synthesize the associated stack to the session\n   */\n  public synthesize(session: ISynthesisSession): void {\n    assertBound(this.stack);\n\n    this.synthesizeStackTemplate(this.stack, session);\n\n    // Just do the default stuff, nothing special\n    this.emitStackArtifact(this.stack, session);\n  }\n\n  private doAddDockerImageAsset(asset: DockerImageAssetSource): DockerImageAssetLocation {\n    assertBound(this.stack);\n\n    // check if we have an override from context\n    const repositoryNameOverride = this.stack.node.tryGetContext(ASSETS_ECR_REPOSITORY_NAME_OVERRIDE_CONTEXT_KEY);\n    const repositoryName = asset.repositoryName ?? repositoryNameOverride ?? ASSETS_ECR_REPOSITORY_NAME;\n    const imageTag = asset.sourceHash;\n    const assetId = asset.sourceHash;\n\n    // only add every image (identified by source hash) once for each stack that uses it.\n    if (!this.addedImageAssets.has(assetId)) {\n      if (!asset.directoryName) {\n        throw new Error(`LegacyStackSynthesizer does not support this type of file asset: ${JSON.stringify(asset)}`);\n      }\n\n      const metadata: cxschema.ContainerImageAssetMetadataEntry = {\n        repositoryName,\n        imageTag,\n        id: assetId,\n        packaging: 'container-image',\n        path: asset.directoryName,\n        sourceHash: asset.sourceHash,\n        buildArgs: asset.dockerBuildArgs,\n        target: asset.dockerBuildTarget,\n        file: asset.dockerFile,\n        networkMode: asset.networkMode,\n        platform: asset.platform,\n      };\n\n      this.stack.node.addMetadata(cxschema.ArtifactMetadataEntryType.ASSET, metadata);\n      this.addedImageAssets.add(assetId);\n    }\n\n    return {\n      imageUri: `${this.stack.account}.dkr.ecr.${this.stack.region}.${this.stack.urlSuffix}/${repositoryName}:${imageTag}`,\n      repositoryName,\n    };\n  }\n\n  private doAddFileAsset(asset: FileAssetSource): FileAssetLocation {\n    assertBound(this.stack);\n\n    let params = this.assetParameters.node.tryFindChild(asset.sourceHash) as FileAssetParameters;\n    if (!params) {\n      params = new FileAssetParameters(this.assetParameters, asset.sourceHash);\n\n      if (!asset.fileName || !asset.packaging) {\n        throw new Error(`LegacyStackSynthesizer does not support this type of file asset: ${JSON.stringify(asset)}`);\n      }\n\n      const metadata: cxschema.FileAssetMetadataEntry = {\n        path: asset.fileName,\n        id: asset.sourceHash,\n        packaging: asset.packaging,\n        sourceHash: asset.sourceHash,\n\n        s3BucketParameter: params.bucketNameParameter.logicalId,\n        s3KeyParameter: params.objectKeyParameter.logicalId,\n        artifactHashParameter: params.artifactHashParameter.logicalId,\n      };\n\n      this.stack.node.addMetadata(cxschema.ArtifactMetadataEntryType.ASSET, metadata);\n    }\n\n    const bucketName = params.bucketNameParameter.valueAsString;\n\n    // key is prefix|postfix\n    const encodedKey = params.objectKeyParameter.valueAsString;\n\n    const s3Prefix = Fn.select(0, Fn.split(cxapi.ASSET_PREFIX_SEPARATOR, encodedKey));\n    const s3Filename = Fn.select(1, Fn.split(cxapi.ASSET_PREFIX_SEPARATOR, encodedKey));\n    const objectKey = `${s3Prefix}${s3Filename}`;\n\n    const httpUrl = `https://s3.${this.stack.region}.${this.stack.urlSuffix}/${bucketName}/${objectKey}`;\n    const s3ObjectUrl = `s3://${bucketName}/${objectKey}`;\n\n    return { bucketName, objectKey, httpUrl, s3ObjectUrl, s3Url: httpUrl };\n  }\n\n  private get assetParameters() {\n    assertBound(this.stack);\n\n    if (!this._assetParameters) {\n      this._assetParameters = new Construct(this.stack, 'AssetParameters');\n    }\n    return this._assetParameters;\n  }\n}\n\nfunction withoutDeprecationWarnings<A>(block: () => A): A {\n  const orig = process.env.JSII_DEPRECATED;\n  process.env.JSII_DEPRECATED = 'quiet';\n  try {\n    return block();\n  } finally {\n    process.env.JSII_DEPRECATED = orig;\n  }\n}\n"]} |
\ | No newline at end of file |