@aws-cdk/toolkit-lib 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (102) hide show
  1. package/LICENSE +202 -0
  2. package/NOTICE +16 -0
  3. package/README.md +432 -0
  4. package/build-info.json +4 -0
  5. package/db.json.gz +0 -0
  6. package/lib/actions/deploy/index.d.ts +178 -0
  7. package/lib/actions/deploy/index.js +78 -0
  8. package/lib/actions/deploy/private/deploy-options.d.ts +78 -0
  9. package/lib/actions/deploy/private/deploy-options.js +3 -0
  10. package/lib/actions/deploy/private/helpers.d.ts +15 -0
  11. package/lib/actions/deploy/private/helpers.js +41 -0
  12. package/lib/actions/deploy/private/index.d.ts +2 -0
  13. package/lib/actions/deploy/private/index.js +19 -0
  14. package/lib/actions/destroy/index.d.ts +17 -0
  15. package/lib/actions/destroy/index.js +3 -0
  16. package/lib/actions/diff/index.d.ts +83 -0
  17. package/lib/actions/diff/index.js +45 -0
  18. package/lib/actions/diff/private/helpers.d.ts +7 -0
  19. package/lib/actions/diff/private/helpers.js +20 -0
  20. package/lib/actions/diff/private/index.d.ts +1 -0
  21. package/lib/actions/diff/private/index.js +18 -0
  22. package/lib/actions/import/index.d.ts +21 -0
  23. package/lib/actions/import/index.js +3 -0
  24. package/lib/actions/index.d.ts +6 -0
  25. package/lib/actions/index.js +23 -0
  26. package/lib/actions/list/index.d.ts +7 -0
  27. package/lib/actions/list/index.js +3 -0
  28. package/lib/actions/rollback/index.d.ts +39 -0
  29. package/lib/actions/rollback/index.js +3 -0
  30. package/lib/actions/synth/index.d.ts +12 -0
  31. package/lib/actions/synth/index.js +3 -0
  32. package/lib/actions/watch/index.d.ts +35 -0
  33. package/lib/actions/watch/index.js +3 -0
  34. package/lib/actions/watch/private/helpers.d.ts +4 -0
  35. package/lib/actions/watch/private/helpers.js +8 -0
  36. package/lib/actions/watch/private/index.d.ts +1 -0
  37. package/lib/actions/watch/private/index.js +18 -0
  38. package/lib/api/aws-auth/index.d.ts +1 -0
  39. package/lib/api/aws-auth/index.js +18 -0
  40. package/lib/api/aws-auth/types.d.ts +32 -0
  41. package/lib/api/aws-auth/types.js +3 -0
  42. package/lib/api/aws-cdk.d.ts +25 -0
  43. package/lib/api/aws-cdk.js +9329 -0
  44. package/lib/api/aws-cdk.js.map +7 -0
  45. package/lib/api/cloud-assembly/index.d.ts +3 -0
  46. package/lib/api/cloud-assembly/index.js +20 -0
  47. package/lib/api/cloud-assembly/private/cached-source.d.ts +15 -0
  48. package/lib/api/cloud-assembly/private/cached-source.js +25 -0
  49. package/lib/api/cloud-assembly/private/context-aware-source.d.ts +45 -0
  50. package/lib/api/cloud-assembly/private/context-aware-source.js +89 -0
  51. package/lib/api/cloud-assembly/private/exec.d.ts +13 -0
  52. package/lib/api/cloud-assembly/private/exec.js +56 -0
  53. package/lib/api/cloud-assembly/private/identity-source.d.ts +10 -0
  54. package/lib/api/cloud-assembly/private/identity-source.js +17 -0
  55. package/lib/api/cloud-assembly/private/index.d.ts +8 -0
  56. package/lib/api/cloud-assembly/private/index.js +25 -0
  57. package/lib/api/cloud-assembly/private/prepare-source.d.ts +52 -0
  58. package/lib/api/cloud-assembly/private/prepare-source.js +166 -0
  59. package/lib/api/cloud-assembly/private/source-builder.d.ts +29 -0
  60. package/lib/api/cloud-assembly/private/source-builder.js +121 -0
  61. package/lib/api/cloud-assembly/private/stack-assembly.d.ts +30 -0
  62. package/lib/api/cloud-assembly/private/stack-assembly.js +94 -0
  63. package/lib/api/cloud-assembly/private/stack-selectors.d.ts +2 -0
  64. package/lib/api/cloud-assembly/private/stack-selectors.js +8 -0
  65. package/lib/api/cloud-assembly/source-builder.d.ts +113 -0
  66. package/lib/api/cloud-assembly/source-builder.js +3 -0
  67. package/lib/api/cloud-assembly/stack-selector.d.ts +81 -0
  68. package/lib/api/cloud-assembly/stack-selector.js +64 -0
  69. package/lib/api/cloud-assembly/types.d.ts +7 -0
  70. package/lib/api/cloud-assembly/types.js +3 -0
  71. package/lib/api/errors.d.ts +44 -0
  72. package/lib/api/errors.js +82 -0
  73. package/lib/api/io/index.d.ts +2 -0
  74. package/lib/api/io/index.js +19 -0
  75. package/lib/api/io/io-host.d.ts +15 -0
  76. package/lib/api/io/io-host.js +3 -0
  77. package/lib/api/io/io-message.d.ts +59 -0
  78. package/lib/api/io/io-message.js +3 -0
  79. package/lib/api/io/private/codes.d.ts +37 -0
  80. package/lib/api/io/private/codes.js +48 -0
  81. package/lib/api/io/private/index.d.ts +6 -0
  82. package/lib/api/io/private/index.js +23 -0
  83. package/lib/api/io/private/level-priority.d.ts +11 -0
  84. package/lib/api/io/private/level-priority.js +33 -0
  85. package/lib/api/io/private/logger.d.ts +40 -0
  86. package/lib/api/io/private/logger.js +211 -0
  87. package/lib/api/io/private/messages.d.ts +64 -0
  88. package/lib/api/io/private/messages.js +159 -0
  89. package/lib/api/io/private/timer.d.ts +29 -0
  90. package/lib/api/io/private/timer.js +54 -0
  91. package/lib/api/io/private/types.d.ts +25 -0
  92. package/lib/api/io/private/types.js +3 -0
  93. package/lib/index.d.ts +6 -0
  94. package/lib/index.js +25 -0
  95. package/lib/index_bg.wasm +0 -0
  96. package/lib/toolkit/index.d.ts +1 -0
  97. package/lib/toolkit/index.js +18 -0
  98. package/lib/toolkit/private/index.d.ts +9 -0
  99. package/lib/toolkit/private/index.js +3 -0
  100. package/lib/toolkit/toolkit.d.ts +142 -0
  101. package/lib/toolkit/toolkit.js +644 -0
  102. package/package.json +147 -0
@@ -0,0 +1,3 @@
1
+ export * from './source-builder';
2
+ export * from './stack-selector';
3
+ export * from './types';
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./source-builder"), exports);
18
+ __exportStar(require("./stack-selector"), exports);
19
+ __exportStar(require("./types"), exports);
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsbURBQWlDO0FBQ2pDLG1EQUFpQztBQUNqQywwQ0FBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NvdXJjZS1idWlsZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vc3RhY2stc2VsZWN0b3InO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5cbiJdfQ==
@@ -0,0 +1,15 @@
1
+ import { CloudAssembly } from '@aws-cdk/cx-api';
2
+ import { ICloudAssemblySource } from '../types';
3
+ /**
4
+ * A CloudAssemblySource that is caching its result once produced.
5
+ *
6
+ * Most Toolkit interactions should use a cached source.
7
+ * Not caching is relevant when the source changes frequently
8
+ * and it is to expensive to predict if the source has changed.
9
+ */
10
+ export declare class CachedCloudAssemblySource implements ICloudAssemblySource {
11
+ private source;
12
+ private cloudAssembly;
13
+ constructor(source: ICloudAssemblySource);
14
+ produce(): Promise<CloudAssembly>;
15
+ }
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CachedCloudAssemblySource = void 0;
4
+ /**
5
+ * A CloudAssemblySource that is caching its result once produced.
6
+ *
7
+ * Most Toolkit interactions should use a cached source.
8
+ * Not caching is relevant when the source changes frequently
9
+ * and it is to expensive to predict if the source has changed.
10
+ */
11
+ class CachedCloudAssemblySource {
12
+ source;
13
+ cloudAssembly;
14
+ constructor(source) {
15
+ this.source = source;
16
+ }
17
+ async produce() {
18
+ if (!this.cloudAssembly) {
19
+ this.cloudAssembly = await this.source.produce();
20
+ }
21
+ return this.cloudAssembly;
22
+ }
23
+ }
24
+ exports.CachedCloudAssemblySource = CachedCloudAssemblySource;
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGVkLXNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNhY2hlZC1zb3VyY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBR0E7Ozs7OztHQU1HO0FBQ0gsTUFBYSx5QkFBeUI7SUFDNUIsTUFBTSxDQUF1QjtJQUM3QixhQUFhLENBQTRCO0lBRWpELFlBQW1CLE1BQTRCO1FBQzdDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxLQUFLLENBQUMsT0FBTztRQUNsQixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3hCLElBQUksQ0FBQyxhQUFhLEdBQUcsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ25ELENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDNUIsQ0FBQztDQUNGO0FBZEQsOERBY0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbG91ZEFzc2VtYmx5IH0gZnJvbSAnQGF3cy1jZGsvY3gtYXBpJztcbmltcG9ydCB7IElDbG91ZEFzc2VtYmx5U291cmNlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG4vKipcbiAqIEEgQ2xvdWRBc3NlbWJseVNvdXJjZSB0aGF0IGlzIGNhY2hpbmcgaXRzIHJlc3VsdCBvbmNlIHByb2R1Y2VkLlxuICpcbiAqIE1vc3QgVG9vbGtpdCBpbnRlcmFjdGlvbnMgc2hvdWxkIHVzZSBhIGNhY2hlZCBzb3VyY2UuXG4gKiBOb3QgY2FjaGluZyBpcyByZWxldmFudCB3aGVuIHRoZSBzb3VyY2UgY2hhbmdlcyBmcmVxdWVudGx5XG4gKiBhbmQgaXQgaXMgdG8gZXhwZW5zaXZlIHRvIHByZWRpY3QgaWYgdGhlIHNvdXJjZSBoYXMgY2hhbmdlZC5cbiAqL1xuZXhwb3J0IGNsYXNzIENhY2hlZENsb3VkQXNzZW1ibHlTb3VyY2UgaW1wbGVtZW50cyBJQ2xvdWRBc3NlbWJseVNvdXJjZSB7XG4gIHByaXZhdGUgc291cmNlOiBJQ2xvdWRBc3NlbWJseVNvdXJjZTtcbiAgcHJpdmF0ZSBjbG91ZEFzc2VtYmx5OiBDbG91ZEFzc2VtYmx5IHwgdW5kZWZpbmVkO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3Rvcihzb3VyY2U6IElDbG91ZEFzc2VtYmx5U291cmNlKSB7XG4gICAgdGhpcy5zb3VyY2UgPSBzb3VyY2U7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgcHJvZHVjZSgpOiBQcm9taXNlPENsb3VkQXNzZW1ibHk+IHtcbiAgICBpZiAoIXRoaXMuY2xvdWRBc3NlbWJseSkge1xuICAgICAgdGhpcy5jbG91ZEFzc2VtYmx5ID0gYXdhaXQgdGhpcy5zb3VyY2UucHJvZHVjZSgpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5jbG91ZEFzc2VtYmx5O1xuICB9XG59XG4iXX0=
@@ -0,0 +1,45 @@
1
+ import * as cxapi from '@aws-cdk/cx-api';
2
+ import { ToolkitServices } from '../../../toolkit/private';
3
+ import { type Context } from '../../aws-cdk';
4
+ import { ICloudAssemblySource } from '../types';
5
+ export interface ContextAwareCloudAssemblyProps {
6
+ /**
7
+ * AWS object (used by contextprovider)
8
+ * @deprecated context should be moved to the toolkit itself
9
+ */
10
+ readonly services: ToolkitServices;
11
+ /**
12
+ * Application context
13
+ */
14
+ readonly context: Context;
15
+ /**
16
+ * The file used to store application context in (relative to cwd).
17
+ *
18
+ * @default "cdk.context.json"
19
+ */
20
+ readonly contextFile?: string;
21
+ /**
22
+ * Enable context lookups.
23
+ *
24
+ * Producing a `cxapi.CloudAssembly` will fail if this is disabled and context lookups need to be performed.
25
+ *
26
+ * @default true
27
+ */
28
+ readonly lookups?: boolean;
29
+ }
30
+ /**
31
+ * Represent the Cloud Executable and the synthesis we can do on it
32
+ */
33
+ export declare class ContextAwareCloudAssembly implements ICloudAssemblySource {
34
+ private readonly source;
35
+ private readonly props;
36
+ private canLookup;
37
+ private context;
38
+ private contextFile;
39
+ private ioHost;
40
+ constructor(source: ICloudAssemblySource, props: ContextAwareCloudAssemblyProps);
41
+ /**
42
+ * Produce a Cloud Assembly, i.e. a set of stacks
43
+ */
44
+ produce(): Promise<cxapi.CloudAssembly>;
45
+ }
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ContextAwareCloudAssembly = void 0;
4
+ const aws_cdk_1 = require("../../aws-cdk");
5
+ const errors_1 = require("../../errors");
6
+ const private_1 = require("../../io/private");
7
+ /**
8
+ * Represent the Cloud Executable and the synthesis we can do on it
9
+ */
10
+ class ContextAwareCloudAssembly {
11
+ source;
12
+ props;
13
+ canLookup;
14
+ context;
15
+ contextFile;
16
+ ioHost;
17
+ constructor(source, props) {
18
+ this.source = source;
19
+ this.props = props;
20
+ this.canLookup = props.lookups ?? true;
21
+ this.context = props.context;
22
+ this.contextFile = props.contextFile ?? aws_cdk_1.PROJECT_CONTEXT; // @todo new feature not needed right now
23
+ this.ioHost = props.services.ioHost;
24
+ }
25
+ /**
26
+ * Produce a Cloud Assembly, i.e. a set of stacks
27
+ */
28
+ async produce() {
29
+ // We may need to run the cloud assembly source multiple times in order to satisfy all missing context
30
+ // (When the source producer runs, it will tell us about context it wants to use
31
+ // but it missing. We'll then look up the context and run the executable again, and
32
+ // again, until it doesn't complain anymore or we've stopped making progress).
33
+ let previouslyMissingKeys;
34
+ while (true) {
35
+ const assembly = await this.source.produce();
36
+ if (assembly.manifest.missing && assembly.manifest.missing.length > 0) {
37
+ const missingKeys = missingContextKeys(assembly.manifest.missing);
38
+ if (!this.canLookup) {
39
+ throw new errors_1.ToolkitError('Context lookups have been disabled. '
40
+ + 'Make sure all necessary context is already in \'cdk.context.json\' by running \'cdk synth\' on a machine with sufficient AWS credentials and committing the result. '
41
+ + `Missing context keys: '${Array.from(missingKeys).join(', ')}'`);
42
+ }
43
+ let tryLookup = true;
44
+ if (previouslyMissingKeys && equalSets(missingKeys, previouslyMissingKeys)) {
45
+ await this.ioHost.notify((0, private_1.debug)('Not making progress trying to resolve environmental context. Giving up.'));
46
+ tryLookup = false;
47
+ }
48
+ previouslyMissingKeys = missingKeys;
49
+ if (tryLookup) {
50
+ await this.ioHost.notify((0, private_1.debug)('Some context information is missing. Fetching...', 'CDK_ASSEMBLY_I0241', {
51
+ missingKeys: Array.from(missingKeys),
52
+ }));
53
+ await aws_cdk_1.contextproviders.provideContextValues(assembly.manifest.missing, this.context, this.props.services.sdkProvider);
54
+ // Cache the new context to disk
55
+ await this.ioHost.notify((0, private_1.debug)(`Writing updated context to ${this.contextFile}...`, 'CDK_ASSEMBLY_I0042', {
56
+ contextFile: this.contextFile,
57
+ context: this.context.all,
58
+ }));
59
+ await this.context.save(this.contextFile);
60
+ // Execute again
61
+ continue;
62
+ }
63
+ }
64
+ return assembly;
65
+ }
66
+ }
67
+ }
68
+ exports.ContextAwareCloudAssembly = ContextAwareCloudAssembly;
69
+ /**
70
+ * Return all keys of missing context items
71
+ */
72
+ function missingContextKeys(missing) {
73
+ return new Set((missing || []).map(m => m.key));
74
+ }
75
+ /**
76
+ * Are two sets equal to each other
77
+ */
78
+ function equalSets(a, b) {
79
+ if (a.size !== b.size) {
80
+ return false;
81
+ }
82
+ for (const x of a) {
83
+ if (!b.has(x)) {
84
+ return false;
85
+ }
86
+ }
87
+ return true;
88
+ }
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-aware-source.js","sourceRoot":"","sources":["context-aware-source.ts"],"names":[],"mappings":"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","sourcesContent":["import type { MissingContext } from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { ToolkitServices } from '../../../toolkit/private';\nimport { type Context, contextproviders, PROJECT_CONTEXT } from '../../aws-cdk';\nimport { ToolkitError } from '../../errors';\nimport { ActionAwareIoHost, debug } from '../../io/private';\nimport { ICloudAssemblySource } from '../types';\n\nexport interface ContextAwareCloudAssemblyProps {\n  /**\n   * AWS object (used by contextprovider)\n   * @deprecated context should be moved to the toolkit itself\n   */\n  readonly services: ToolkitServices;\n\n  /**\n   * Application context\n   */\n  readonly context: Context;\n\n  /**\n   * The file used to store application context in (relative to cwd).\n   *\n   * @default \"cdk.context.json\"\n   */\n  readonly contextFile?: string;\n\n  /**\n   * Enable context lookups.\n   *\n   * Producing a `cxapi.CloudAssembly` will fail if this is disabled and context lookups need to be performed.\n   *\n   * @default true\n   */\n  readonly lookups?: boolean;\n}\n\n/**\n * Represent the Cloud Executable and the synthesis we can do on it\n */\nexport class ContextAwareCloudAssembly implements ICloudAssemblySource {\n  private canLookup: boolean;\n  private context: Context;\n  private contextFile: string;\n  private ioHost: ActionAwareIoHost;\n\n  constructor(private readonly source: ICloudAssemblySource, private readonly props: ContextAwareCloudAssemblyProps) {\n    this.canLookup = props.lookups ?? true;\n    this.context = props.context;\n    this.contextFile = props.contextFile ?? PROJECT_CONTEXT; // @todo new feature not needed right now\n    this.ioHost = props.services.ioHost;\n  }\n\n  /**\n   * Produce a Cloud Assembly, i.e. a set of stacks\n   */\n  public async produce(): Promise<cxapi.CloudAssembly> {\n    // We may need to run the cloud assembly source multiple times in order to satisfy all missing context\n    // (When the source producer runs, it will tell us about context it wants to use\n    // but it missing. We'll then look up the context and run the executable again, and\n    // again, until it doesn't complain anymore or we've stopped making progress).\n    let previouslyMissingKeys: Set<string> | undefined;\n    while (true) {\n      const assembly = await this.source.produce();\n\n      if (assembly.manifest.missing && assembly.manifest.missing.length > 0) {\n        const missingKeys = missingContextKeys(assembly.manifest.missing);\n\n        if (!this.canLookup) {\n          throw new ToolkitError(\n            'Context lookups have been disabled. '\n            + 'Make sure all necessary context is already in \\'cdk.context.json\\' by running \\'cdk synth\\' on a machine with sufficient AWS credentials and committing the result. '\n            + `Missing context keys: '${Array.from(missingKeys).join(', ')}'`);\n        }\n\n        let tryLookup = true;\n        if (previouslyMissingKeys && equalSets(missingKeys, previouslyMissingKeys)) {\n          await this.ioHost.notify(debug('Not making progress trying to resolve environmental context. Giving up.'));\n          tryLookup = false;\n        }\n\n        previouslyMissingKeys = missingKeys;\n\n        if (tryLookup) {\n          await this.ioHost.notify(debug('Some context information is missing. Fetching...', 'CDK_ASSEMBLY_I0241', {\n            missingKeys: Array.from(missingKeys),\n          }));\n          await contextproviders.provideContextValues(\n            assembly.manifest.missing,\n            this.context,\n            this.props.services.sdkProvider,\n          );\n\n          // Cache the new context to disk\n          await this.ioHost.notify(debug(`Writing updated context to ${this.contextFile}...`, 'CDK_ASSEMBLY_I0042', {\n            contextFile: this.contextFile,\n            context: this.context.all,\n          }));\n          await this.context.save(this.contextFile);\n\n          // Execute again\n          continue;\n        }\n      }\n\n      return assembly;\n    }\n  }\n}\n\n/**\n * Return all keys of missing context items\n */\nfunction missingContextKeys(missing?: MissingContext[]): Set<string> {\n  return new Set((missing || []).map(m => m.key));\n}\n\n/**\n * Are two sets equal to each other\n */\nfunction equalSets<A>(a: Set<A>, b: Set<A>) {\n  if (a.size !== b.size) {\n    return false;\n  }\n  for (const x of a) {\n    if (!b.has(x)) {\n      return false;\n    }\n  }\n  return true;\n}\n"]}
@@ -0,0 +1,13 @@
1
+ type EventPublisher = (event: 'open' | 'data_stdout' | 'data_stderr' | 'close', line: string) => void;
2
+ interface ExecOptions {
3
+ eventPublisher?: EventPublisher;
4
+ extraEnv?: {
5
+ [key: string]: string | undefined;
6
+ };
7
+ cwd?: string;
8
+ }
9
+ /**
10
+ * Execute a command and args in a child process
11
+ */
12
+ export declare function execInChildProcess(commandAndArgs: string, options?: ExecOptions): Promise<void>;
13
+ export {};
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.execInChildProcess = execInChildProcess;
4
+ const child_process = require("node:child_process");
5
+ const split2 = require("split2");
6
+ const errors_1 = require("../../errors");
7
+ /**
8
+ * Execute a command and args in a child process
9
+ */
10
+ async function execInChildProcess(commandAndArgs, options = {}) {
11
+ return new Promise((ok, fail) => {
12
+ // We use a slightly lower-level interface to:
13
+ //
14
+ // - Pass arguments in an array instead of a string, to get around a
15
+ // number of quoting issues introduced by the intermediate shell layer
16
+ // (which would be different between Linux and Windows).
17
+ //
18
+ // - We have to capture any output to stdout and stderr sp we can pass it on to the IoHost
19
+ // To ensure messages get to the user fast, we will emit every full line we receive.
20
+ const proc = child_process.spawn(commandAndArgs, {
21
+ stdio: ['ignore', 'pipe', 'pipe'],
22
+ detached: false,
23
+ shell: true,
24
+ cwd: options.cwd,
25
+ env: {
26
+ ...process.env,
27
+ ...(options.extraEnv ?? {}),
28
+ },
29
+ });
30
+ const eventPublisher = options.eventPublisher ?? ((type, line) => {
31
+ switch (type) {
32
+ case 'data_stdout':
33
+ process.stdout.write(line);
34
+ return;
35
+ case 'data_stderr':
36
+ process.stderr.write(line);
37
+ return;
38
+ case 'open':
39
+ case 'close':
40
+ return;
41
+ }
42
+ });
43
+ proc.stdout.pipe(split2()).on('data', (line) => eventPublisher('data_stdout', line));
44
+ proc.stderr.pipe(split2()).on('data', (line) => eventPublisher('data_stderr', line));
45
+ proc.on('error', fail);
46
+ proc.on('exit', code => {
47
+ if (code === 0) {
48
+ return ok();
49
+ }
50
+ else {
51
+ return fail(new errors_1.ToolkitError(`Subprocess exited with error ${code}`));
52
+ }
53
+ });
54
+ });
55
+ }
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImV4ZWMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFlQSxnREErQ0M7QUE5REQsb0RBQW9EO0FBQ3BELGlDQUFpQztBQUNqQyx5Q0FBNEM7QUFVNUM7O0dBRUc7QUFDSSxLQUFLLFVBQVUsa0JBQWtCLENBQUMsY0FBc0IsRUFBRSxVQUF1QixFQUFFO0lBQ3hGLE9BQU8sSUFBSSxPQUFPLENBQU8sQ0FBQyxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUU7UUFDcEMsOENBQThDO1FBQzlDLEVBQUU7UUFDRixvRUFBb0U7UUFDcEUsd0VBQXdFO1FBQ3hFLDBEQUEwRDtRQUMxRCxFQUFFO1FBQ0YsMEZBQTBGO1FBQzFGLHNGQUFzRjtRQUN0RixNQUFNLElBQUksR0FBRyxhQUFhLENBQUMsS0FBSyxDQUFDLGNBQWMsRUFBRTtZQUMvQyxLQUFLLEVBQUUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQztZQUNqQyxRQUFRLEVBQUUsS0FBSztZQUNmLEtBQUssRUFBRSxJQUFJO1lBQ1gsR0FBRyxFQUFFLE9BQU8sQ0FBQyxHQUFHO1lBQ2hCLEdBQUcsRUFBRTtnQkFDSCxHQUFHLE9BQU8sQ0FBQyxHQUFHO2dCQUNkLEdBQUcsQ0FBQyxPQUFPLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQzthQUM1QjtTQUNGLENBQUMsQ0FBQztRQUVILE1BQU0sY0FBYyxHQUFtQixPQUFPLENBQUMsY0FBYyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLEVBQUU7WUFDL0UsUUFBUSxJQUFJLEVBQUUsQ0FBQztnQkFDYixLQUFLLGFBQWE7b0JBQ2hCLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO29CQUMzQixPQUFPO2dCQUNULEtBQUssYUFBYTtvQkFDaEIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7b0JBQzNCLE9BQU87Z0JBQ1QsS0FBSyxNQUFNLENBQUM7Z0JBQ1osS0FBSyxPQUFPO29CQUNWLE9BQU87WUFDWCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUNyRixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUVyRixJQUFJLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUV2QixJQUFJLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRTtZQUNyQixJQUFJLElBQUksS0FBSyxDQUFDLEVBQUUsQ0FBQztnQkFDZixPQUFPLEVBQUUsRUFBRSxDQUFDO1lBQ2QsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLE9BQU8sSUFBSSxDQUFDLElBQUkscUJBQVksQ0FBQyxnQ0FBZ0MsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ3hFLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNoaWxkX3Byb2Nlc3MgZnJvbSAnbm9kZTpjaGlsZF9wcm9jZXNzJztcbmltcG9ydCAqIGFzIHNwbGl0MiBmcm9tICdzcGxpdDInO1xuaW1wb3J0IHsgVG9vbGtpdEVycm9yIH0gZnJvbSAnLi4vLi4vZXJyb3JzJztcblxudHlwZSBFdmVudFB1Ymxpc2hlciA9IChldmVudDogJ29wZW4nIHwgJ2RhdGFfc3Rkb3V0JyB8ICdkYXRhX3N0ZGVycicgfCAnY2xvc2UnLCBsaW5lOiBzdHJpbmcpID0+IHZvaWQ7XG5cbmludGVyZmFjZSBFeGVjT3B0aW9ucyB7XG4gIGV2ZW50UHVibGlzaGVyPzogRXZlbnRQdWJsaXNoZXI7XG4gIGV4dHJhRW52PzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfCB1bmRlZmluZWQgfTtcbiAgY3dkPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEV4ZWN1dGUgYSBjb21tYW5kIGFuZCBhcmdzIGluIGEgY2hpbGQgcHJvY2Vzc1xuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZXhlY0luQ2hpbGRQcm9jZXNzKGNvbW1hbmRBbmRBcmdzOiBzdHJpbmcsIG9wdGlvbnM6IEV4ZWNPcHRpb25zID0ge30pIHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlPHZvaWQ+KChvaywgZmFpbCkgPT4ge1xuICAgIC8vIFdlIHVzZSBhIHNsaWdodGx5IGxvd2VyLWxldmVsIGludGVyZmFjZSB0bzpcbiAgICAvL1xuICAgIC8vIC0gUGFzcyBhcmd1bWVudHMgaW4gYW4gYXJyYXkgaW5zdGVhZCBvZiBhIHN0cmluZywgdG8gZ2V0IGFyb3VuZCBhXG4gICAgLy8gICBudW1iZXIgb2YgcXVvdGluZyBpc3N1ZXMgaW50cm9kdWNlZCBieSB0aGUgaW50ZXJtZWRpYXRlIHNoZWxsIGxheWVyXG4gICAgLy8gICAod2hpY2ggd291bGQgYmUgZGlmZmVyZW50IGJldHdlZW4gTGludXggYW5kIFdpbmRvd3MpLlxuICAgIC8vXG4gICAgLy8gLSBXZSBoYXZlIHRvIGNhcHR1cmUgYW55IG91dHB1dCB0byBzdGRvdXQgYW5kIHN0ZGVyciBzcCB3ZSBjYW4gcGFzcyBpdCBvbiB0byB0aGUgSW9Ib3N0XG4gICAgLy8gICBUbyBlbnN1cmUgbWVzc2FnZXMgZ2V0IHRvIHRoZSB1c2VyIGZhc3QsIHdlIHdpbGwgZW1pdCBldmVyeSBmdWxsIGxpbmUgd2UgcmVjZWl2ZS5cbiAgICBjb25zdCBwcm9jID0gY2hpbGRfcHJvY2Vzcy5zcGF3bihjb21tYW5kQW5kQXJncywge1xuICAgICAgc3RkaW86IFsnaWdub3JlJywgJ3BpcGUnLCAncGlwZSddLFxuICAgICAgZGV0YWNoZWQ6IGZhbHNlLFxuICAgICAgc2hlbGw6IHRydWUsXG4gICAgICBjd2Q6IG9wdGlvbnMuY3dkLFxuICAgICAgZW52OiB7XG4gICAgICAgIC4uLnByb2Nlc3MuZW52LFxuICAgICAgICAuLi4ob3B0aW9ucy5leHRyYUVudiA/PyB7fSksXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgY29uc3QgZXZlbnRQdWJsaXNoZXI6IEV2ZW50UHVibGlzaGVyID0gb3B0aW9ucy5ldmVudFB1Ymxpc2hlciA/PyAoKHR5cGUsIGxpbmUpID0+IHtcbiAgICAgIHN3aXRjaCAodHlwZSkge1xuICAgICAgICBjYXNlICdkYXRhX3N0ZG91dCc6XG4gICAgICAgICAgcHJvY2Vzcy5zdGRvdXQud3JpdGUobGluZSk7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICBjYXNlICdkYXRhX3N0ZGVycic6XG4gICAgICAgICAgcHJvY2Vzcy5zdGRlcnIud3JpdGUobGluZSk7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICBjYXNlICdvcGVuJzpcbiAgICAgICAgY2FzZSAnY2xvc2UnOlxuICAgICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICB9KTtcbiAgICBwcm9jLnN0ZG91dC5waXBlKHNwbGl0MigpKS5vbignZGF0YScsIChsaW5lKSA9PiBldmVudFB1Ymxpc2hlcignZGF0YV9zdGRvdXQnLCBsaW5lKSk7XG4gICAgcHJvYy5zdGRlcnIucGlwZShzcGxpdDIoKSkub24oJ2RhdGEnLCAobGluZSkgPT4gZXZlbnRQdWJsaXNoZXIoJ2RhdGFfc3RkZXJyJywgbGluZSkpO1xuXG4gICAgcHJvYy5vbignZXJyb3InLCBmYWlsKTtcblxuICAgIHByb2Mub24oJ2V4aXQnLCBjb2RlID0+IHtcbiAgICAgIGlmIChjb2RlID09PSAwKSB7XG4gICAgICAgIHJldHVybiBvaygpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIGZhaWwobmV3IFRvb2xraXRFcnJvcihgU3VicHJvY2VzcyBleGl0ZWQgd2l0aCBlcnJvciAke2NvZGV9YCkpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn1cbiJdfQ==
@@ -0,0 +1,10 @@
1
+ import type * as cxapi from '@aws-cdk/cx-api';
2
+ import { ICloudAssemblySource } from '../types';
3
+ /**
4
+ * A CloudAssemblySource that is representing a already existing and produced CloudAssembly.
5
+ */
6
+ export declare class IdentityCloudAssemblySource implements ICloudAssemblySource {
7
+ private readonly cloudAssembly;
8
+ constructor(cloudAssembly: cxapi.CloudAssembly);
9
+ produce(): Promise<cxapi.CloudAssembly>;
10
+ }
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.IdentityCloudAssemblySource = void 0;
4
+ /**
5
+ * A CloudAssemblySource that is representing a already existing and produced CloudAssembly.
6
+ */
7
+ class IdentityCloudAssemblySource {
8
+ cloudAssembly;
9
+ constructor(cloudAssembly) {
10
+ this.cloudAssembly = cloudAssembly;
11
+ }
12
+ async produce() {
13
+ return this.cloudAssembly;
14
+ }
15
+ }
16
+ exports.IdentityCloudAssemblySource = IdentityCloudAssemblySource;
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRlbnRpdHktc291cmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaWRlbnRpdHktc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdBOztHQUVHO0FBQ0gsTUFBYSwyQkFBMkI7SUFDRjtJQUFwQyxZQUFvQyxhQUFrQztRQUFsQyxrQkFBYSxHQUFiLGFBQWEsQ0FBcUI7SUFDdEUsQ0FBQztJQUVNLEtBQUssQ0FBQyxPQUFPO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM1QixDQUFDO0NBQ0Y7QUFQRCxrRUFPQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlICogYXMgY3hhcGkgZnJvbSAnQGF3cy1jZGsvY3gtYXBpJztcbmltcG9ydCB7IElDbG91ZEFzc2VtYmx5U291cmNlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG4vKipcbiAqIEEgQ2xvdWRBc3NlbWJseVNvdXJjZSB0aGF0IGlzIHJlcHJlc2VudGluZyBhIGFscmVhZHkgZXhpc3RpbmcgYW5kIHByb2R1Y2VkIENsb3VkQXNzZW1ibHkuXG4gKi9cbmV4cG9ydCBjbGFzcyBJZGVudGl0eUNsb3VkQXNzZW1ibHlTb3VyY2UgaW1wbGVtZW50cyBJQ2xvdWRBc3NlbWJseVNvdXJjZSB7XG4gIHB1YmxpYyBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGNsb3VkQXNzZW1ibHk6IGN4YXBpLkNsb3VkQXNzZW1ibHkpIHtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBwcm9kdWNlKCk6IFByb21pc2U8Y3hhcGkuQ2xvdWRBc3NlbWJseT4ge1xuICAgIHJldHVybiB0aGlzLmNsb3VkQXNzZW1ibHk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,8 @@
1
+ export * from './context-aware-source';
2
+ export * from './cached-source';
3
+ export * from './identity-source';
4
+ export * from './stack-assembly';
5
+ export * from './exec';
6
+ export * from './prepare-source';
7
+ export * from './source-builder';
8
+ export * from './stack-selectors';
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./context-aware-source"), exports);
18
+ __exportStar(require("./cached-source"), exports);
19
+ __exportStar(require("./identity-source"), exports);
20
+ __exportStar(require("./stack-assembly"), exports);
21
+ __exportStar(require("./exec"), exports);
22
+ __exportStar(require("./prepare-source"), exports);
23
+ __exportStar(require("./source-builder"), exports);
24
+ __exportStar(require("./stack-selectors"), exports);
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseURBQXVDO0FBQ3ZDLGtEQUFnQztBQUNoQyxvREFBa0M7QUFDbEMsbURBQWlDO0FBQ2pDLHlDQUF1QjtBQUN2QixtREFBaUM7QUFDakMsbURBQWlDO0FBQ2pDLG9EQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1hd2FyZS1zb3VyY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jYWNoZWQtc291cmNlJztcbmV4cG9ydCAqIGZyb20gJy4vaWRlbnRpdHktc291cmNlJztcbmV4cG9ydCAqIGZyb20gJy4vc3RhY2stYXNzZW1ibHknO1xuZXhwb3J0ICogZnJvbSAnLi9leGVjJztcbmV4cG9ydCAqIGZyb20gJy4vcHJlcGFyZS1zb3VyY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9zb3VyY2UtYnVpbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL3N0YWNrLXNlbGVjdG9ycyc7XG4iXX0=
@@ -0,0 +1,52 @@
1
+ import * as cxapi from '@aws-cdk/cx-api';
2
+ import { ToolkitServices } from '../../../toolkit/private';
3
+ import { ActionAwareIoHost } from '../../io/private';
4
+ import type { AppSynthOptions } from '../source-builder';
5
+ export { guessExecutable } from '../../../api/aws-cdk';
6
+ type Env = {
7
+ [key: string]: string;
8
+ };
9
+ type Context = {
10
+ [key: string]: any;
11
+ };
12
+ /**
13
+ * Turn the given optional output directory into a fixed output directory
14
+ */
15
+ export declare function determineOutputDirectory(outdir?: string): string;
16
+ /**
17
+ * If we don't have region/account defined in context, we fall back to the default SDK behavior
18
+ * where region is retrieved from ~/.aws/config and account is based on default credentials provider
19
+ * chain and then STS is queried.
20
+ *
21
+ * This is done opportunistically: for example, if we can't access STS for some reason or the region
22
+ * is not configured, the context value will be 'null' and there could failures down the line. In
23
+ * some cases, synthesis does not require region/account information at all, so that might be perfectly
24
+ * fine in certain scenarios.
25
+ *
26
+ * @param context The context key/value bash.
27
+ */
28
+ export declare function prepareDefaultEnvironment(services: ToolkitServices, props?: {
29
+ outdir?: string;
30
+ }): Promise<Env>;
31
+ /**
32
+ * Run code from a different working directory
33
+ */
34
+ export declare function changeDir<T>(block: () => Promise<T>, workingDir?: string): Promise<T>;
35
+ /**
36
+ * Run code with additional environment variables
37
+ */
38
+ export declare function withEnv<T>(env: Env | undefined, block: () => Promise<T>): Promise<T>;
39
+ /**
40
+ * Run code with context setup inside the environment
41
+ */
42
+ export declare function withContext<T>(inputContext: Context, env: Env, synthOpts: AppSynthOptions | undefined, block: (env: Env, context: Context) => Promise<T>): Promise<T>;
43
+ /**
44
+ * Checks if a given assembly supports context overflow, warn otherwise.
45
+ *
46
+ * @param assembly the assembly to check
47
+ */
48
+ export declare function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHost: ActionAwareIoHost): Promise<void>;
49
+ /**
50
+ * Safely create an assembly from a cloud assembly directory
51
+ */
52
+ export declare function assemblyFromDirectory(assemblyDir: string, ioHost: ActionAwareIoHost): Promise<cxapi.CloudAssembly>;
@@ -0,0 +1,166 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.guessExecutable = void 0;
4
+ exports.determineOutputDirectory = determineOutputDirectory;
5
+ exports.prepareDefaultEnvironment = prepareDefaultEnvironment;
6
+ exports.changeDir = changeDir;
7
+ exports.withEnv = withEnv;
8
+ exports.withContext = withContext;
9
+ exports.checkContextOverflowSupport = checkContextOverflowSupport;
10
+ exports.assemblyFromDirectory = assemblyFromDirectory;
11
+ const os = require("node:os");
12
+ const path = require("node:path");
13
+ const cxschema = require("@aws-cdk/cloud-assembly-schema");
14
+ const cxapi = require("@aws-cdk/cx-api");
15
+ const fs = require("fs-extra");
16
+ const semver_1 = require("semver");
17
+ const aws_cdk_1 = require("../../../api/aws-cdk");
18
+ const errors_1 = require("../../errors");
19
+ const private_1 = require("../../io/private");
20
+ var aws_cdk_2 = require("../../../api/aws-cdk");
21
+ Object.defineProperty(exports, "guessExecutable", { enumerable: true, get: function () { return aws_cdk_2.guessExecutable; } });
22
+ /**
23
+ * Turn the given optional output directory into a fixed output directory
24
+ */
25
+ function determineOutputDirectory(outdir) {
26
+ return outdir ?? fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));
27
+ }
28
+ /**
29
+ * If we don't have region/account defined in context, we fall back to the default SDK behavior
30
+ * where region is retrieved from ~/.aws/config and account is based on default credentials provider
31
+ * chain and then STS is queried.
32
+ *
33
+ * This is done opportunistically: for example, if we can't access STS for some reason or the region
34
+ * is not configured, the context value will be 'null' and there could failures down the line. In
35
+ * some cases, synthesis does not require region/account information at all, so that might be perfectly
36
+ * fine in certain scenarios.
37
+ *
38
+ * @param context The context key/value bash.
39
+ */
40
+ async function prepareDefaultEnvironment(services, props = {}) {
41
+ const logFn = (0, private_1.asLogger)(services.ioHost, 'ASSEMBLY').debug;
42
+ const env = await (0, aws_cdk_1.prepareDefaultEnvironment)(services.sdkProvider, logFn);
43
+ if (props.outdir) {
44
+ env[cxapi.OUTDIR_ENV] = props.outdir;
45
+ await logFn('outdir:', props.outdir);
46
+ }
47
+ // CLI version information
48
+ env[cxapi.CLI_ASM_VERSION_ENV] = cxschema.Manifest.version();
49
+ env[cxapi.CLI_VERSION_ENV] = (0, aws_cdk_1.versionNumber)();
50
+ await logFn('env:', env);
51
+ return env;
52
+ }
53
+ /**
54
+ * Run code from a different working directory
55
+ */
56
+ async function changeDir(block, workingDir) {
57
+ const originalWorkingDir = process.cwd();
58
+ try {
59
+ if (workingDir) {
60
+ process.chdir(workingDir);
61
+ }
62
+ return await block();
63
+ }
64
+ finally {
65
+ if (workingDir) {
66
+ process.chdir(originalWorkingDir);
67
+ }
68
+ }
69
+ }
70
+ /**
71
+ * Run code with additional environment variables
72
+ */
73
+ async function withEnv(env = {}, block) {
74
+ const originalEnv = process.env;
75
+ try {
76
+ process.env = {
77
+ ...originalEnv,
78
+ ...env,
79
+ };
80
+ return await block();
81
+ }
82
+ finally {
83
+ process.env = originalEnv;
84
+ }
85
+ }
86
+ /**
87
+ * Run code with context setup inside the environment
88
+ */
89
+ async function withContext(inputContext, env, synthOpts = {}, block) {
90
+ const context = await (0, aws_cdk_1.prepareContext)(synthOptsDefaults(synthOpts), inputContext, env);
91
+ let contextOverflowLocation = null;
92
+ try {
93
+ const envVariableSizeLimit = os.platform() === 'win32' ? 32760 : 131072;
94
+ const [smallContext, overflow] = (0, aws_cdk_1.splitBySize)(context, (0, aws_cdk_1.spaceAvailableForContext)(env, envVariableSizeLimit));
95
+ // Store the safe part in the environment variable
96
+ env[cxapi.CONTEXT_ENV] = JSON.stringify(smallContext);
97
+ // If there was any overflow, write it to a temporary file
98
+ if (Object.keys(overflow ?? {}).length > 0) {
99
+ const contextDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-context'));
100
+ contextOverflowLocation = path.join(contextDir, 'context-overflow.json');
101
+ fs.writeJSONSync(contextOverflowLocation, overflow);
102
+ env[cxapi.CONTEXT_OVERFLOW_LOCATION_ENV] = contextOverflowLocation;
103
+ }
104
+ // call the block code with new environment
105
+ return await block(env, context);
106
+ }
107
+ finally {
108
+ if (contextOverflowLocation) {
109
+ fs.removeSync(path.dirname(contextOverflowLocation));
110
+ }
111
+ }
112
+ }
113
+ /**
114
+ * Checks if a given assembly supports context overflow, warn otherwise.
115
+ *
116
+ * @param assembly the assembly to check
117
+ */
118
+ async function checkContextOverflowSupport(assembly, ioHost) {
119
+ const logFn = (0, private_1.asLogger)(ioHost, 'ASSEMBLY').warn;
120
+ const tree = (0, aws_cdk_1.loadTree)(assembly);
121
+ const frameworkDoesNotSupportContextOverflow = (0, aws_cdk_1.some)(tree, node => {
122
+ const fqn = node.constructInfo?.fqn;
123
+ const version = node.constructInfo?.version;
124
+ return (fqn === 'aws-cdk-lib.App' && version != null && (0, semver_1.lte)(version, '2.38.0')) // v2
125
+ || fqn === '@aws-cdk/core.App'; // v1
126
+ });
127
+ // We're dealing with an old version of the framework here. It is unaware of the temporary
128
+ // file, which means that it will ignore the context overflow.
129
+ if (frameworkDoesNotSupportContextOverflow) {
130
+ await logFn('Part of the context could not be sent to the application. Please update the AWS CDK library to the latest version.');
131
+ }
132
+ }
133
+ /**
134
+ * Safely create an assembly from a cloud assembly directory
135
+ */
136
+ async function assemblyFromDirectory(assemblyDir, ioHost) {
137
+ try {
138
+ const assembly = new cxapi.CloudAssembly(assemblyDir, {
139
+ // We sort as we deploy
140
+ topoSort: false,
141
+ });
142
+ await checkContextOverflowSupport(assembly, ioHost);
143
+ return assembly;
144
+ }
145
+ catch (err) {
146
+ if (err.message.includes(cxschema.VERSION_MISMATCH)) {
147
+ // this means the CLI version is too old.
148
+ // we instruct the user to upgrade.
149
+ const message = 'This AWS CDK Toolkit is not compatible with the AWS CDK library used by your application. Please upgrade to the latest version.';
150
+ await ioHost.notify((0, private_1.error)(message, 'CDK_ASSEMBLY_E1111', { error: err.message }));
151
+ throw new errors_1.ToolkitError(`${message}\n(${err.message}`);
152
+ }
153
+ throw err;
154
+ }
155
+ }
156
+ function synthOptsDefaults(synthOpts = {}) {
157
+ return new aws_cdk_1.Settings({
158
+ debug: false,
159
+ pathMetadata: true,
160
+ versionReporting: true,
161
+ assetMetadata: true,
162
+ assetStaging: true,
163
+ ...synthOpts,
164
+ }, true);
165
+ }
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prepare-source.js","sourceRoot":"","sources":["prepare-source.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'node:os';\nimport * as path from 'node:path';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { lte } from 'semver';\nimport { prepareDefaultEnvironment as oldPrepare, prepareContext, spaceAvailableForContext, Settings, loadTree, some, splitBySize, versionNumber } from '../../../api/aws-cdk';\nimport { ToolkitServices } from '../../../toolkit/private';\nimport { ToolkitError } from '../../errors';\nimport { ActionAwareIoHost, asLogger, error } from '../../io/private';\nimport type { AppSynthOptions } from '../source-builder';\n\nexport { guessExecutable } from '../../../api/aws-cdk';\n\ntype Env = { [key: string]: string };\ntype Context = { [key: string]: any };\n\n/**\n * Turn the given optional output directory into a fixed output directory\n */\nexport function determineOutputDirectory(outdir?: string) {\n  return outdir ?? fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));\n}\n\n/**\n * If we don't have region/account defined in context, we fall back to the default SDK behavior\n * where region is retrieved from ~/.aws/config and account is based on default credentials provider\n * chain and then STS is queried.\n *\n * This is done opportunistically: for example, if we can't access STS for some reason or the region\n * is not configured, the context value will be 'null' and there could failures down the line. In\n * some cases, synthesis does not require region/account information at all, so that might be perfectly\n * fine in certain scenarios.\n *\n * @param context The context key/value bash.\n */\nexport async function prepareDefaultEnvironment(services: ToolkitServices, props: { outdir?: string } = {}): Promise<Env> {\n  const logFn = asLogger(services.ioHost, 'ASSEMBLY').debug;\n  const env = await oldPrepare(services.sdkProvider, logFn);\n\n  if (props.outdir) {\n    env[cxapi.OUTDIR_ENV] = props.outdir;\n    await logFn('outdir:', props.outdir);\n  }\n\n  // CLI version information\n  env[cxapi.CLI_ASM_VERSION_ENV] = cxschema.Manifest.version();\n  env[cxapi.CLI_VERSION_ENV] = versionNumber();\n\n  await logFn('env:', env);\n  return env;\n}\n\n/**\n * Run code from a different working directory\n */\nexport async function changeDir<T>(block: () => Promise<T>, workingDir?: string) {\n  const originalWorkingDir = process.cwd();\n  try {\n    if (workingDir) {\n      process.chdir(workingDir);\n    }\n\n    return await block();\n  } finally {\n    if (workingDir) {\n      process.chdir(originalWorkingDir);\n    }\n  }\n}\n\n/**\n * Run code with additional environment variables\n */\nexport async function withEnv<T>(env: Env = {}, block: () => Promise<T>) {\n  const originalEnv = process.env;\n  try {\n    process.env = {\n      ...originalEnv,\n      ...env,\n    };\n\n    return await block();\n  } finally {\n    process.env = originalEnv;\n  }\n}\n\n/**\n * Run code with context setup inside the environment\n */\nexport async function withContext<T>(\n  inputContext: Context,\n  env: Env,\n  synthOpts: AppSynthOptions = {},\n  block: (env: Env, context: Context) => Promise<T>,\n) {\n  const context = await prepareContext(synthOptsDefaults(synthOpts), inputContext, env);\n  let contextOverflowLocation = null;\n\n  try {\n    const envVariableSizeLimit = os.platform() === 'win32' ? 32760 : 131072;\n    const [smallContext, overflow] = splitBySize(context, spaceAvailableForContext(env, envVariableSizeLimit));\n\n    // Store the safe part in the environment variable\n    env[cxapi.CONTEXT_ENV] = JSON.stringify(smallContext);\n\n    // If there was any overflow, write it to a temporary file\n    if (Object.keys(overflow ?? {}).length > 0) {\n      const contextDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-context'));\n      contextOverflowLocation = path.join(contextDir, 'context-overflow.json');\n      fs.writeJSONSync(contextOverflowLocation, overflow);\n      env[cxapi.CONTEXT_OVERFLOW_LOCATION_ENV] = contextOverflowLocation;\n    }\n\n    // call the block code with new environment\n    return await block(env, context);\n  } finally {\n    if (contextOverflowLocation) {\n      fs.removeSync(path.dirname(contextOverflowLocation));\n    }\n  }\n}\n\n/**\n * Checks if a given assembly supports context overflow, warn otherwise.\n *\n * @param assembly the assembly to check\n */\nexport async function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHost: ActionAwareIoHost): Promise<void> {\n  const logFn = asLogger(ioHost, 'ASSEMBLY').warn;\n  const tree = loadTree(assembly);\n  const frameworkDoesNotSupportContextOverflow = some(tree, node => {\n    const fqn = node.constructInfo?.fqn;\n    const version = node.constructInfo?.version;\n    return (fqn === 'aws-cdk-lib.App' && version != null && lte(version, '2.38.0')) // v2\n    || fqn === '@aws-cdk/core.App'; // v1\n  });\n\n  // We're dealing with an old version of the framework here. It is unaware of the temporary\n  // file, which means that it will ignore the context overflow.\n  if (frameworkDoesNotSupportContextOverflow) {\n    await logFn('Part of the context could not be sent to the application. Please update the AWS CDK library to the latest version.');\n  }\n}\n\n/**\n * Safely create an assembly from a cloud assembly directory\n */\nexport async function assemblyFromDirectory(assemblyDir: string, ioHost: ActionAwareIoHost) {\n  try {\n    const assembly = new cxapi.CloudAssembly(assemblyDir, {\n      // We sort as we deploy\n      topoSort: false,\n    });\n    await checkContextOverflowSupport(assembly, ioHost);\n    return assembly;\n  } catch (err: any) {\n    if (err.message.includes(cxschema.VERSION_MISMATCH)) {\n      // this means the CLI version is too old.\n      // we instruct the user to upgrade.\n      const message = 'This AWS CDK Toolkit is not compatible with the AWS CDK library used by your application. Please upgrade to the latest version.';\n      await ioHost.notify(error(message, 'CDK_ASSEMBLY_E1111', { error: err.message }));\n      throw new ToolkitError(`${message}\\n(${err.message}`);\n    }\n    throw err;\n  }\n}\n\nfunction synthOptsDefaults(synthOpts: AppSynthOptions = {}): Settings {\n  return new Settings({\n    debug: false,\n    pathMetadata: true,\n    versionReporting: true,\n    assetMetadata: true,\n    assetStaging: true,\n    ...synthOpts,\n  }, true);\n}\n"]}