UNPKG

20.4 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.CliCredentialsStackSynthesizer = void 0;
5const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const cxapi = require("@aws-cdk/cx-api");
8const token_1 = require("../token");
9const _asset_manifest_builder_1 = require("./_asset-manifest-builder");
10const _shared_1 = require("./_shared");
11const default_synthesizer_1 = require("./default-synthesizer");
12const stack_synthesizer_1 = require("./stack-synthesizer");
13/**
14 * A synthesizer that uses conventional asset locations, but not conventional deployment roles
15 *
16 * Instead of assuming the bootstrapped deployment roles, all stack operations will be performed
17 * using the CLI's current credentials.
18 *
19 * - This synthesizer does not support deploying to accounts to which the CLI does not have
20 * credentials. It also does not support deploying using **CDK Pipelines**. For either of those
21 * features, use `DefaultStackSynthesizer`.
22 * - This synthesizer requires an S3 bucket and ECR repository with well-known names. To
23 * not depend on those, use `LegacyStackSynthesizer`.
24 *
25 * Be aware that your CLI credentials must be valid for the duration of the
26 * entire deployment. If you are using session credentials, make sure the
27 * session lifetime is long enough.
28 *
29 * By default, expects the environment to have been bootstrapped with just the staging resources
30 * of the Bootstrap Stack V2 (also known as "modern bootstrap stack"). You can override
31 * the default names using the synthesizer's construction properties.
32 */
33class CliCredentialsStackSynthesizer extends stack_synthesizer_1.StackSynthesizer {
34 constructor(props = {}) {
35 super();
36 this.props = props;
37 this.assetManifest = new _asset_manifest_builder_1.AssetManifestBuilder();
38 try {
39 jsiiDeprecationWarnings._aws_cdk_core_CliCredentialsStackSynthesizerProps(props);
40 }
41 catch (error) {
42 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
43 Error.captureStackTrace(error, CliCredentialsStackSynthesizer);
44 }
45 throw error;
46 }
47 for (const key in props) {
48 if (props.hasOwnProperty(key)) {
49 validateNoToken(key);
50 }
51 }
52 function validateNoToken(key) {
53 const prop = props[key];
54 if (typeof prop === 'string' && token_1.Token.isUnresolved(prop)) {
55 throw new Error(`DefaultSynthesizer property '${key}' cannot contain tokens; only the following placeholder strings are allowed: ` + [
56 '${Qualifier}',
57 cxapi.EnvironmentPlaceholders.CURRENT_REGION,
58 cxapi.EnvironmentPlaceholders.CURRENT_ACCOUNT,
59 cxapi.EnvironmentPlaceholders.CURRENT_PARTITION,
60 ].join(', '));
61 }
62 }
63 }
64 bind(stack) {
65 try {
66 jsiiDeprecationWarnings._aws_cdk_core_Stack(stack);
67 }
68 catch (error) {
69 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
70 Error.captureStackTrace(error, this.bind);
71 }
72 throw error;
73 }
74 if (this.stack !== undefined) {
75 throw new Error('A StackSynthesizer can only be used for one Stack: create a new instance to use with a different Stack');
76 }
77 this.stack = stack;
78 const qualifier = this.props.qualifier ?? stack.node.tryGetContext(default_synthesizer_1.BOOTSTRAP_QUALIFIER_CONTEXT) ?? default_synthesizer_1.DefaultStackSynthesizer.DEFAULT_QUALIFIER;
79 this.qualifier = qualifier;
80 const spec = new _shared_1.StringSpecializer(stack, qualifier);
81 /* eslint-disable max-len */
82 this.bucketName = spec.specialize(this.props.fileAssetsBucketName ?? default_synthesizer_1.DefaultStackSynthesizer.DEFAULT_FILE_ASSETS_BUCKET_NAME);
83 this.repositoryName = spec.specialize(this.props.imageAssetsRepositoryName ?? default_synthesizer_1.DefaultStackSynthesizer.DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME);
84 this.bucketPrefix = spec.specialize(this.props.bucketPrefix ?? default_synthesizer_1.DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PREFIX);
85 this.dockerTagPrefix = spec.specialize(this.props.dockerTagPrefix ?? default_synthesizer_1.DefaultStackSynthesizer.DEFAULT_DOCKER_ASSET_PREFIX);
86 }
87 addFileAsset(asset) {
88 try {
89 jsiiDeprecationWarnings._aws_cdk_core_FileAssetSource(asset);
90 }
91 catch (error) {
92 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
93 Error.captureStackTrace(error, this.addFileAsset);
94 }
95 throw error;
96 }
97 _shared_1.assertBound(this.stack);
98 _shared_1.assertBound(this.bucketName);
99 _shared_1.assertBound(this.bucketPrefix);
100 return this.assetManifest.addFileAssetDefault(asset, this.stack, this.bucketName, this.bucketPrefix);
101 }
102 addDockerImageAsset(asset) {
103 try {
104 jsiiDeprecationWarnings._aws_cdk_core_DockerImageAssetSource(asset);
105 }
106 catch (error) {
107 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
108 Error.captureStackTrace(error, this.addDockerImageAsset);
109 }
110 throw error;
111 }
112 _shared_1.assertBound(this.stack);
113 _shared_1.assertBound(this.repositoryName);
114 _shared_1.assertBound(this.dockerTagPrefix);
115 return this.assetManifest.addDockerImageAssetDefault(asset, this.stack, this.repositoryName, this.dockerTagPrefix);
116 }
117 /**
118 * Synthesize the associated stack to the session
119 */
120 synthesize(session) {
121 try {
122 jsiiDeprecationWarnings._aws_cdk_core_ISynthesisSession(session);
123 }
124 catch (error) {
125 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
126 Error.captureStackTrace(error, this.synthesize);
127 }
128 throw error;
129 }
130 _shared_1.assertBound(this.stack);
131 _shared_1.assertBound(this.qualifier);
132 this.synthesizeStackTemplate(this.stack, session);
133 const templateAsset = this.addFileAsset(_shared_1.stackTemplateFileAsset(this.stack, session));
134 const assetManifestId = this.assetManifest.writeManifest(this.stack, session);
135 this.emitStackArtifact(this.stack, session, {
136 stackTemplateAssetObjectUrl: templateAsset.s3ObjectUrlWithPlaceholders,
137 additionalDependencies: [assetManifestId],
138 });
139 }
140}
141exports.CliCredentialsStackSynthesizer = CliCredentialsStackSynthesizer;
142_a = JSII_RTTI_SYMBOL_1;
143CliCredentialsStackSynthesizer[_a] = { fqn: "@aws-cdk/core.CliCredentialsStackSynthesizer", version: "1.204.0" };
144//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-credentials-synthesizer.js","sourceRoot":"","sources":["cli-credentials-synthesizer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cxapi from '@aws-cdk/cx-api';\nimport { DockerImageAssetLocation, DockerImageAssetSource, FileAssetLocation, FileAssetSource } from '../assets';\nimport { ISynthesisSession } from '../construct-compat';\nimport { Stack } from '../stack';\nimport { Token } from '../token';\nimport { AssetManifestBuilder } from './_asset-manifest-builder';\nimport { assertBound, StringSpecializer, stackTemplateFileAsset } from './_shared';\nimport { BOOTSTRAP_QUALIFIER_CONTEXT, DefaultStackSynthesizer } from './default-synthesizer';\nimport { StackSynthesizer } from './stack-synthesizer';\n\n/**\n * Properties for the CliCredentialsStackSynthesizer\n */\nexport interface CliCredentialsStackSynthesizerProps {\n  /**\n   * Name of the S3 bucket to hold file assets\n   *\n   * You must supply this if you have given a non-standard name to the staging bucket.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_FILE_ASSETS_BUCKET_NAME\n   */\n  readonly fileAssetsBucketName?: string;\n\n  /**\n   * Name of the ECR repository to hold Docker Image assets\n   *\n   * You must supply this if you have given a non-standard name to the ECR repository.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME\n   */\n  readonly imageAssetsRepositoryName?: string;\n\n  /**\n   * Qualifier to disambiguate multiple environments in the same account\n   *\n   * You can use this and leave the other naming properties empty if you have deployed\n   * the bootstrap environment with standard names but only differnet qualifiers.\n   *\n   * @default - Value of context key '@aws-cdk/core:bootstrapQualifier' if set, otherwise `DefaultStackSynthesizer.DEFAULT_QUALIFIER`\n   */\n  readonly qualifier?: string;\n\n  /**\n   * bucketPrefix to use while storing S3 Assets\n   *\n   * @default - DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PREFIX\n   */\n  readonly bucketPrefix?: string;\n\n  /**\n   * A prefix to use while tagging and uploading Docker images to ECR.\n   *\n   * This does not add any separators - the source hash will be appended to\n   * this string directly.\n   *\n   * @default - DefaultStackSynthesizer.DEFAULT_DOCKER_ASSET_PREFIX\n   */\n  readonly dockerTagPrefix?: string;\n}\n\n/**\n * A synthesizer that uses conventional asset locations, but not conventional deployment roles\n *\n * Instead of assuming the bootstrapped deployment roles, all stack operations will be performed\n * using the CLI's current credentials.\n *\n * - This synthesizer does not support deploying to accounts to which the CLI does not have\n *   credentials. It also does not support deploying using **CDK Pipelines**. For either of those\n *   features, use `DefaultStackSynthesizer`.\n * - This synthesizer requires an S3 bucket and ECR repository with well-known names. To\n *   not depend on those, use `LegacyStackSynthesizer`.\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 * By default, expects the environment to have been bootstrapped with just the staging resources\n * of the Bootstrap Stack V2 (also known as \"modern bootstrap stack\"). You can override\n * the default names using the synthesizer's construction properties.\n */\nexport class CliCredentialsStackSynthesizer extends StackSynthesizer {\n  private stack?: Stack;\n  private qualifier?: string;\n  private bucketName?: string;\n  private repositoryName?: string;\n  private bucketPrefix?: string;\n  private dockerTagPrefix?: string;\n\n  private readonly assetManifest = new AssetManifestBuilder();\n\n  constructor(private readonly props: CliCredentialsStackSynthesizerProps = {}) {\n    super();\n\n    for (const key in props) {\n      if (props.hasOwnProperty(key)) {\n        validateNoToken(key as keyof CliCredentialsStackSynthesizerProps);\n      }\n    }\n\n    function validateNoToken<A extends keyof CliCredentialsStackSynthesizerProps>(key: A) {\n      const prop = props[key];\n      if (typeof prop === 'string' && Token.isUnresolved(prop)) {\n        throw new Error(`DefaultSynthesizer property '${key}' cannot contain tokens; only the following placeholder strings are allowed: ` + [\n          '${Qualifier}',\n          cxapi.EnvironmentPlaceholders.CURRENT_REGION,\n          cxapi.EnvironmentPlaceholders.CURRENT_ACCOUNT,\n          cxapi.EnvironmentPlaceholders.CURRENT_PARTITION,\n        ].join(', '));\n      }\n    }\n  }\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\n    this.stack = stack;\n\n    const qualifier = this.props.qualifier ?? stack.node.tryGetContext(BOOTSTRAP_QUALIFIER_CONTEXT) ?? DefaultStackSynthesizer.DEFAULT_QUALIFIER;\n    this.qualifier = qualifier;\n\n    const spec = new StringSpecializer(stack, qualifier);\n\n    /* eslint-disable max-len */\n    this.bucketName = spec.specialize(this.props.fileAssetsBucketName ?? DefaultStackSynthesizer.DEFAULT_FILE_ASSETS_BUCKET_NAME);\n    this.repositoryName = spec.specialize(this.props.imageAssetsRepositoryName ?? DefaultStackSynthesizer.DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME);\n    this.bucketPrefix = spec.specialize(this.props.bucketPrefix ?? DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PREFIX);\n    this.dockerTagPrefix = spec.specialize(this.props.dockerTagPrefix ?? DefaultStackSynthesizer.DEFAULT_DOCKER_ASSET_PREFIX);\n    /* eslint-enable max-len */\n  }\n\n  public addFileAsset(asset: FileAssetSource): FileAssetLocation {\n    assertBound(this.stack);\n    assertBound(this.bucketName);\n    assertBound(this.bucketPrefix);\n\n    return this.assetManifest.addFileAssetDefault(asset, this.stack, this.bucketName, this.bucketPrefix);\n  }\n\n  public addDockerImageAsset(asset: DockerImageAssetSource): DockerImageAssetLocation {\n    assertBound(this.stack);\n    assertBound(this.repositoryName);\n    assertBound(this.dockerTagPrefix);\n\n    return this.assetManifest.addDockerImageAssetDefault(asset, this.stack, this.repositoryName, this.dockerTagPrefix);\n  }\n\n  /**\n   * Synthesize the associated stack to the session\n   */\n  public synthesize(session: ISynthesisSession): void {\n    assertBound(this.stack);\n    assertBound(this.qualifier);\n\n    this.synthesizeStackTemplate(this.stack, session);\n\n    const templateAsset = this.addFileAsset(stackTemplateFileAsset(this.stack, session));\n    const assetManifestId = this.assetManifest.writeManifest(this.stack, session);\n\n    this.emitStackArtifact(this.stack, session, {\n      stackTemplateAssetObjectUrl: templateAsset.s3ObjectUrlWithPlaceholders,\n      additionalDependencies: [assetManifestId],\n    });\n  }\n}"]}
\No newline at end of file