aws-cdk 2.1005.0 → 2.1006.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 (174) hide show
  1. package/THIRD_PARTY_LICENSES +31 -31
  2. package/build-info.json +2 -2
  3. package/db.json.gz +0 -0
  4. package/lib/api/aws-auth/awscli-compatible.js +9 -10
  5. package/lib/api/aws-auth/credential-plugins.js +6 -7
  6. package/lib/api/aws-auth/sdk-logger.js +3 -4
  7. package/lib/api/aws-auth/sdk-provider.js +11 -13
  8. package/lib/api/aws-auth/sdk.js +8 -9
  9. package/lib/api/aws-auth/tracing.js +3 -4
  10. package/lib/api/aws-auth/user-agent.js +4 -5
  11. package/lib/api/bootstrap/bootstrap-environment.d.ts +1 -1
  12. package/lib/api/bootstrap/bootstrap-environment.js +42 -46
  13. package/lib/api/bootstrap/bootstrap-props.d.ts +1 -1
  14. package/lib/api/bootstrap/bootstrap-props.js +1 -1
  15. package/lib/api/bootstrap/deploy-bootstrap.d.ts +1 -1
  16. package/lib/api/bootstrap/deploy-bootstrap.js +11 -14
  17. package/lib/api/{evaluate-cloudformation-template.d.ts → cloudformation/evaluate-cloudformation-template.d.ts} +4 -8
  18. package/lib/api/{evaluate-cloudformation-template.js → cloudformation/evaluate-cloudformation-template.js} +16 -25
  19. package/lib/api/cloudformation/index.d.ts +4 -0
  20. package/lib/api/cloudformation/index.js +21 -0
  21. package/lib/api/{deployments → cloudformation}/nested-stack-helpers.d.ts +1 -1
  22. package/lib/api/cloudformation/nested-stack-helpers.js +86 -0
  23. package/lib/api/cloudformation/stack-helpers.d.ts +96 -0
  24. package/lib/api/cloudformation/stack-helpers.js +158 -0
  25. package/lib/api/{util → cloudformation}/template-body-parameter.d.ts +3 -2
  26. package/lib/api/cloudformation/template-body-parameter.js +104 -0
  27. package/lib/api/context.js +3 -3
  28. package/lib/api/cxapp/cloud-assembly.js +13 -15
  29. package/lib/api/cxapp/cloud-executable.js +4 -5
  30. package/lib/api/cxapp/environments.js +4 -4
  31. package/lib/api/cxapp/exec.js +20 -23
  32. package/lib/api/deployments/asset-publishing.d.ts +0 -2
  33. package/lib/api/deployments/asset-publishing.js +24 -31
  34. package/lib/api/deployments/assets.d.ts +1 -1
  35. package/lib/api/deployments/assets.js +12 -13
  36. package/lib/api/deployments/{cloudformation.d.ts → cfn-api.d.ts} +5 -102
  37. package/lib/api/deployments/cfn-api.js +438 -0
  38. package/lib/api/deployments/checks.d.ts +1 -1
  39. package/lib/api/deployments/checks.js +12 -13
  40. package/lib/api/deployments/deploy-stack.d.ts +2 -3
  41. package/lib/api/deployments/deploy-stack.js +34 -45
  42. package/lib/api/deployments/deployment-result.js +3 -3
  43. package/lib/api/deployments/deployments.d.ts +3 -3
  44. package/lib/api/deployments/deployments.js +35 -42
  45. package/lib/api/deployments/hotswap-deployments.d.ts +2 -2
  46. package/lib/api/deployments/hotswap-deployments.js +122 -69
  47. package/lib/api/deployments/index.d.ts +0 -2
  48. package/lib/api/deployments/index.js +1 -3
  49. package/lib/api/environment/environment-access.d.ts +2 -2
  50. package/lib/api/environment/environment-access.js +18 -20
  51. package/lib/api/environment/environment-resources.d.ts +1 -1
  52. package/lib/api/environment/environment-resources.js +17 -19
  53. package/lib/api/environment/index.d.ts +1 -0
  54. package/lib/api/environment/index.js +2 -1
  55. package/lib/api/environment/placeholders.js +23 -0
  56. package/lib/api/garbage-collection/garbage-collector.d.ts +1 -1
  57. package/lib/api/garbage-collection/garbage-collector.js +56 -66
  58. package/lib/api/garbage-collection/progress-printer.d.ts +1 -1
  59. package/lib/api/garbage-collection/progress-printer.js +7 -7
  60. package/lib/api/garbage-collection/stack-refresh.d.ts +1 -1
  61. package/lib/api/garbage-collection/stack-refresh.js +12 -15
  62. package/lib/api/hotswap/appsync-mapping-templates.d.ts +3 -3
  63. package/lib/api/hotswap/appsync-mapping-templates.js +25 -22
  64. package/lib/api/hotswap/code-build-projects.d.ts +3 -3
  65. package/lib/api/hotswap/code-build-projects.js +12 -7
  66. package/lib/api/hotswap/common.d.ts +13 -61
  67. package/lib/api/hotswap/common.js +40 -70
  68. package/lib/api/hotswap/ecs-services.d.ts +4 -4
  69. package/lib/api/hotswap/ecs-services.js +38 -21
  70. package/lib/api/hotswap/lambda-functions.d.ts +3 -3
  71. package/lib/api/hotswap/lambda-functions.js +23 -19
  72. package/lib/api/hotswap/s3-bucket-deployments.d.ts +3 -3
  73. package/lib/api/hotswap/s3-bucket-deployments.js +11 -7
  74. package/lib/api/hotswap/stepfunctions-state-machines.d.ts +3 -3
  75. package/lib/api/hotswap/stepfunctions-state-machines.js +8 -4
  76. package/lib/api/logs/find-cloudwatch-logs.js +6 -7
  77. package/lib/api/logs/logs-monitor.js +5 -8
  78. package/lib/api/plugin/plugin.js +6 -10
  79. package/lib/api/resource-import/importer.d.ts +8 -3
  80. package/lib/api/resource-import/importer.js +23 -29
  81. package/lib/api/resource-import/migrator.d.ts +3 -3
  82. package/lib/api/resource-import/migrator.js +6 -6
  83. package/lib/api/settings.d.ts +0 -3
  84. package/lib/api/settings.js +4 -40
  85. package/lib/api/stack-events/stack-activity-monitor.d.ts +1 -1
  86. package/lib/api/stack-events/stack-activity-monitor.js +12 -15
  87. package/lib/api/stack-events/stack-event-poller.js +9 -10
  88. package/lib/api/toolkit-info.d.ts +2 -2
  89. package/lib/api/toolkit-info.js +20 -24
  90. package/lib/{tree.d.ts → api/tree.d.ts} +2 -2
  91. package/lib/api/tree.js +37 -0
  92. package/lib/api/util/rwlock.js +4 -4
  93. package/lib/api/work-graph/work-graph-builder.js +4 -4
  94. package/lib/api/work-graph/work-graph.d.ts +1 -1
  95. package/lib/api/work-graph/work-graph.js +13 -15
  96. package/lib/cli/activity-printer/base.d.ts +2 -2
  97. package/lib/cli/activity-printer/base.js +6 -8
  98. package/lib/cli/activity-printer/current.js +7 -11
  99. package/lib/cli/activity-printer/history.js +2 -3
  100. package/lib/cli/cdk-toolkit.d.ts +2 -8
  101. package/lib/cli/cdk-toolkit.js +81 -72
  102. package/lib/cli/ci-systems.js +2 -3
  103. package/lib/cli/cli-config.js +3 -3
  104. package/lib/cli/cli.js +48 -50
  105. package/lib/cli/convert-to-user-input.js +110 -111
  106. package/lib/{toolkit → cli/io-host}/cli-io-host.d.ts +6 -2
  107. package/lib/cli/io-host/cli-io-host.js +356 -0
  108. package/lib/cli/io-host/index.d.ts +1 -0
  109. package/lib/{toolkit/error.js → cli/io-host/index.js} +2 -2
  110. package/lib/cli/messages.d.ts +1 -1
  111. package/lib/cli/messages.js +2 -3
  112. package/lib/cli/pretty-print-error.d.ts +1 -0
  113. package/lib/cli/pretty-print-error.js +35 -0
  114. package/lib/cli/root-dir.js +4 -4
  115. package/lib/cli/user-configuration.js +57 -14
  116. package/lib/cli/util/npm.js +3 -3
  117. package/lib/cli/util/yargs-helpers.d.ts +1 -1
  118. package/lib/cli/util/yargs-helpers.js +3 -3
  119. package/lib/cli/version.js +4 -4
  120. package/lib/commands/context.js +7 -8
  121. package/lib/commands/diff.d.ts +50 -0
  122. package/lib/commands/diff.js +215 -0
  123. package/lib/commands/init/index.d.ts +1 -0
  124. package/lib/commands/init/index.js +18 -0
  125. package/lib/commands/init/init-hooks.js +63 -0
  126. package/lib/commands/init/init.js +435 -0
  127. package/lib/{os.js → commands/init/os.js} +4 -4
  128. package/lib/{list-stacks.d.ts → commands/list-stacks.d.ts} +1 -1
  129. package/lib/{list-stacks.js → commands/list-stacks.js} +2 -2
  130. package/lib/commands/migrate.js +29 -32
  131. package/lib/context-providers/ami.d.ts +3 -1
  132. package/lib/context-providers/ami.js +8 -8
  133. package/lib/context-providers/availability-zones.d.ts +3 -1
  134. package/lib/context-providers/availability-zones.js +4 -4
  135. package/lib/context-providers/cc-api-provider.d.ts +8 -12
  136. package/lib/context-providers/cc-api-provider.js +88 -66
  137. package/lib/context-providers/endpoint-service-availability-zones.d.ts +3 -1
  138. package/lib/context-providers/endpoint-service-availability-zones.js +6 -6
  139. package/lib/context-providers/hosted-zones.d.ts +3 -1
  140. package/lib/context-providers/hosted-zones.js +11 -11
  141. package/lib/context-providers/index.d.ts +19 -5
  142. package/lib/context-providers/index.js +35 -17
  143. package/lib/context-providers/keys.d.ts +3 -1
  144. package/lib/context-providers/keys.js +8 -8
  145. package/lib/context-providers/load-balancers.js +15 -18
  146. package/lib/context-providers/security-groups.js +10 -12
  147. package/lib/context-providers/ssm-parameters.d.ts +3 -1
  148. package/lib/context-providers/ssm-parameters.js +7 -7
  149. package/lib/context-providers/vpcs.d.ts +3 -1
  150. package/lib/context-providers/vpcs.js +14 -15
  151. package/lib/index.js +113386 -112712
  152. package/lib/init-templates/.init-version.json +1 -1
  153. package/lib/init-templates/.recommended-feature-flags.json +2 -1
  154. package/lib/legacy-exports-source.d.ts +4 -5
  155. package/lib/legacy-exports-source.js +6 -7
  156. package/lib/logging.js +2 -2
  157. package/lib/notices.d.ts +1 -1
  158. package/lib/notices.js +26 -32
  159. package/package.json +18 -18
  160. package/lib/api/deployments/cloudformation.js +0 -597
  161. package/lib/api/deployments/nested-stack-helpers.js +0 -88
  162. package/lib/api/util/placeholders.js +0 -24
  163. package/lib/api/util/template-body-parameter.js +0 -103
  164. package/lib/diff.d.ts +0 -28
  165. package/lib/diff.js +0 -165
  166. package/lib/init-hooks.js +0 -63
  167. package/lib/init.js +0 -437
  168. package/lib/toolkit/cli-io-host.js +0 -353
  169. package/lib/toolkit/error.d.ts +0 -1
  170. package/lib/tree.js +0 -40
  171. /package/lib/api/{util → environment}/placeholders.d.ts +0 -0
  172. /package/lib/{init-hooks.d.ts → commands/init/init-hooks.d.ts} +0 -0
  173. /package/lib/{init.d.ts → commands/init/init.d.ts} +0 -0
  174. /package/lib/{os.d.ts → commands/init/os.d.ts} +0 -0
@@ -0,0 +1,215 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RequireApproval = void 0;
4
+ exports.formatStackDiff = formatStackDiff;
5
+ exports.formatSecurityDiff = formatSecurityDiff;
6
+ const stream_1 = require("stream");
7
+ const util_1 = require("util");
8
+ const cxschema = require("@aws-cdk/cloud-assembly-schema");
9
+ const cloudformation_diff_1 = require("@aws-cdk/cloudformation-diff");
10
+ const chalk = require("chalk");
11
+ const api_1 = require("../../../@aws-cdk/tmp-toolkit-helpers/src/api");
12
+ const logging_1 = require("../logging");
13
+ /*
14
+ * Custom writable stream that collects text into a string buffer.
15
+ * Used on classes that take in and directly write to a stream, but
16
+ * we intend to capture the output rather than print.
17
+ */
18
+ class StringWriteStream extends stream_1.Writable {
19
+ constructor() {
20
+ super();
21
+ this.buffer = [];
22
+ }
23
+ _write(chunk, _encoding, callback) {
24
+ this.buffer.push(chunk.toString());
25
+ callback();
26
+ }
27
+ toString() {
28
+ return this.buffer.join('');
29
+ }
30
+ }
31
+ /**
32
+ * Formats the differences between two template states and returns it as a string.
33
+ *
34
+ * @param oldTemplate the old/current state of the stack.
35
+ * @param newTemplate the new/target state of the stack.
36
+ * @param strict do not filter out AWS::CDK::Metadata or Rules
37
+ * @param context lines of context to use in arbitrary JSON diff
38
+ * @param quiet silences \'There were no differences\' messages
39
+ *
40
+ * @returns the formatted diff, and the number of stacks in this stack tree that have differences, including the top-level root stack
41
+ */
42
+ function formatStackDiff(oldTemplate, newTemplate, strict, context, quiet, stackName, changeSet, isImport, nestedStackTemplates) {
43
+ let diff = (0, cloudformation_diff_1.fullDiff)(oldTemplate, newTemplate.template, changeSet, isImport);
44
+ // The stack diff is formatted via `Formatter`, which takes in a stream
45
+ // and sends its output directly to that stream. To faciliate use of the
46
+ // global CliIoHost, we create our own stream to capture the output of
47
+ // `Formatter` and return the output as a string for the consumer of
48
+ // `formatStackDiff` to decide what to do with it.
49
+ const stream = new StringWriteStream();
50
+ let numStacksWithChanges = 0;
51
+ let formattedDiff = '';
52
+ let filteredChangesCount = 0;
53
+ try {
54
+ // must output the stack name if there are differences, even if quiet
55
+ if (stackName && (!quiet || !diff.isEmpty)) {
56
+ stream.write((0, util_1.format)('Stack %s\n', chalk.bold(stackName)));
57
+ }
58
+ if (!quiet && isImport) {
59
+ stream.write('Parameters and rules created during migration do not affect resource configuration.\n');
60
+ }
61
+ // detect and filter out mangled characters from the diff
62
+ if (diff.differenceCount && !strict) {
63
+ const mangledNewTemplate = JSON.parse((0, cloudformation_diff_1.mangleLikeCloudFormation)(JSON.stringify(newTemplate.template)));
64
+ const mangledDiff = (0, cloudformation_diff_1.fullDiff)(oldTemplate, mangledNewTemplate, changeSet);
65
+ filteredChangesCount = Math.max(0, diff.differenceCount - mangledDiff.differenceCount);
66
+ if (filteredChangesCount > 0) {
67
+ diff = mangledDiff;
68
+ }
69
+ }
70
+ // filter out 'AWS::CDK::Metadata' resources from the template
71
+ // filter out 'CheckBootstrapVersion' rules from the template
72
+ if (!strict) {
73
+ obscureDiff(diff);
74
+ }
75
+ if (!diff.isEmpty) {
76
+ numStacksWithChanges++;
77
+ // formatDifferences updates the stream with the formatted stack diff
78
+ (0, cloudformation_diff_1.formatDifferences)(stream, diff, {
79
+ ...logicalIdMapFromTemplate(oldTemplate),
80
+ ...buildLogicalToPathMap(newTemplate),
81
+ }, context);
82
+ // store the stream containing a formatted stack diff
83
+ formattedDiff = stream.toString();
84
+ }
85
+ else if (!quiet) {
86
+ (0, logging_1.info)(chalk.green('There were no differences'));
87
+ }
88
+ }
89
+ finally {
90
+ stream.end();
91
+ }
92
+ if (filteredChangesCount > 0) {
93
+ (0, logging_1.info)(chalk.yellow(`Omitted ${filteredChangesCount} changes because they are likely mangled non-ASCII characters. Use --strict to print them.`));
94
+ }
95
+ for (const nestedStackLogicalId of Object.keys(nestedStackTemplates ?? {})) {
96
+ if (!nestedStackTemplates) {
97
+ break;
98
+ }
99
+ const nestedStack = nestedStackTemplates[nestedStackLogicalId];
100
+ newTemplate._template = nestedStack.generatedTemplate;
101
+ const nextDiff = formatStackDiff(nestedStack.deployedTemplate, newTemplate, strict, context, quiet, nestedStack.physicalName ?? nestedStackLogicalId, undefined, isImport, nestedStack.nestedStackTemplates);
102
+ numStacksWithChanges += nextDiff.numStacksWithChanges;
103
+ formattedDiff += nextDiff.formattedDiff;
104
+ }
105
+ return {
106
+ numStacksWithChanges,
107
+ formattedDiff,
108
+ };
109
+ }
110
+ var RequireApproval;
111
+ (function (RequireApproval) {
112
+ RequireApproval["Never"] = "never";
113
+ RequireApproval["AnyChange"] = "any-change";
114
+ RequireApproval["Broadening"] = "broadening";
115
+ })(RequireApproval || (exports.RequireApproval = RequireApproval = {}));
116
+ /**
117
+ * Formats the security changes of this diff, if the change is impactful enough according to the approval level
118
+ *
119
+ * Returns the diff if the changes are prompt-worthy, an empty object otherwise.
120
+ */
121
+ function formatSecurityDiff(oldTemplate, newTemplate, requireApproval, stackName, changeSet) {
122
+ const diff = (0, cloudformation_diff_1.fullDiff)(oldTemplate, newTemplate.template, changeSet);
123
+ if (diffRequiresApproval(diff, requireApproval)) {
124
+ (0, logging_1.info)((0, util_1.format)('Stack %s\n', chalk.bold(stackName)));
125
+ // eslint-disable-next-line max-len
126
+ (0, logging_1.warning)(`This deployment will make potentially sensitive changes according to your current security approval level (--require-approval ${requireApproval}).`);
127
+ (0, logging_1.warning)('Please confirm you intend to make the following modifications:\n');
128
+ // The security diff is formatted via `Formatter`, which takes in a stream
129
+ // and sends its output directly to that stream. To faciliate use of the
130
+ // global CliIoHost, we create our own stream to capture the output of
131
+ // `Formatter` and return the output as a string for the consumer of
132
+ // `formatSecurityDiff` to decide what to do with it.
133
+ const stream = new StringWriteStream();
134
+ try {
135
+ // formatSecurityChanges updates the stream with the formatted security diff
136
+ (0, cloudformation_diff_1.formatSecurityChanges)(stream, diff, buildLogicalToPathMap(newTemplate));
137
+ }
138
+ finally {
139
+ stream.end();
140
+ }
141
+ // store the stream containing a formatted stack diff
142
+ const formattedDiff = stream.toString();
143
+ return { formattedDiff };
144
+ }
145
+ return {};
146
+ }
147
+ /**
148
+ * Return whether the diff has security-impacting changes that need confirmation
149
+ *
150
+ * TODO: Filter the security impact determination based off of an enum that allows
151
+ * us to pick minimum "severities" to alert on.
152
+ */
153
+ function diffRequiresApproval(diff, requireApproval) {
154
+ switch (requireApproval) {
155
+ case RequireApproval.Never: return false;
156
+ case RequireApproval.AnyChange: return diff.permissionsAnyChanges;
157
+ case RequireApproval.Broadening: return diff.permissionsBroadened;
158
+ default: throw new api_1.ToolkitError(`Unrecognized approval level: ${requireApproval}`);
159
+ }
160
+ }
161
+ function buildLogicalToPathMap(stack) {
162
+ const map = {};
163
+ for (const md of stack.findMetadataByType(cxschema.ArtifactMetadataEntryType.LOGICAL_ID)) {
164
+ map[md.data] = md.path;
165
+ }
166
+ return map;
167
+ }
168
+ function logicalIdMapFromTemplate(template) {
169
+ const ret = {};
170
+ for (const [logicalId, resource] of Object.entries(template.Resources ?? {})) {
171
+ const path = resource?.Metadata?.['aws:cdk:path'];
172
+ if (path) {
173
+ ret[logicalId] = path;
174
+ }
175
+ }
176
+ return ret;
177
+ }
178
+ /**
179
+ * Remove any template elements that we don't want to show users.
180
+ * This is currently:
181
+ * - AWS::CDK::Metadata resource
182
+ * - CheckBootstrapVersion Rule
183
+ */
184
+ function obscureDiff(diff) {
185
+ if (diff.unknown) {
186
+ // see https://github.com/aws/aws-cdk/issues/17942
187
+ diff.unknown = diff.unknown.filter(change => {
188
+ if (!change) {
189
+ return true;
190
+ }
191
+ if (change.newValue?.CheckBootstrapVersion) {
192
+ return false;
193
+ }
194
+ if (change.oldValue?.CheckBootstrapVersion) {
195
+ return false;
196
+ }
197
+ return true;
198
+ });
199
+ }
200
+ if (diff.resources) {
201
+ diff.resources = diff.resources.filter(change => {
202
+ if (!change) {
203
+ return true;
204
+ }
205
+ if (change.newResourceType === 'AWS::CDK::Metadata') {
206
+ return false;
207
+ }
208
+ if (change.oldResourceType === 'AWS::CDK::Metadata') {
209
+ return false;
210
+ }
211
+ return true;
212
+ });
213
+ }
214
+ }
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"diff.js","sourceRoot":"","sources":["diff.ts"],"names":[],"mappings":"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","sourcesContent":["import { Writable } from 'stream';\nimport { format } from 'util';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport {\n  type DescribeChangeSetOutput,\n  type TemplateDiff,\n  formatDifferences,\n  formatSecurityChanges,\n  fullDiff,\n  mangleLikeCloudFormation,\n} from '@aws-cdk/cloudformation-diff';\nimport type * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport { ToolkitError } from '../../../@aws-cdk/tmp-toolkit-helpers/src/api';\nimport type { NestedStackTemplates } from '../api/cloudformation';\nimport { info, warning } from '../logging';\n\n/*\n * Custom writable stream that collects text into a string buffer.\n * Used on classes that take in and directly write to a stream, but\n * we intend to capture the output rather than print.\n */\nclass StringWriteStream extends Writable {\n  private buffer: string[] = [];\n\n  constructor() {\n    super();\n  }\n\n  _write(chunk: any, _encoding: string, callback: (error?: Error | null) => void): void {\n    this.buffer.push(chunk.toString());\n    callback();\n  }\n\n  toString(): string {\n    return this.buffer.join('');\n  }\n}\n\n/**\n * Output of formatStackDiff\n */\nexport interface FormatStackDiffOutput {\n  /**\n   * Number of stacks with diff changes\n   */\n  readonly numStacksWithChanges: number;\n\n  /**\n   * Complete formatted diff\n   */\n  readonly formattedDiff: string;\n}\n\n/**\n * Formats the differences between two template states and returns it as a string.\n *\n * @param oldTemplate the old/current state of the stack.\n * @param newTemplate the new/target state of the stack.\n * @param strict      do not filter out AWS::CDK::Metadata or Rules\n * @param context     lines of context to use in arbitrary JSON diff\n * @param quiet       silences \\'There were no differences\\' messages\n *\n * @returns the formatted diff, and the number of stacks in this stack tree that have differences, including the top-level root stack\n */\nexport function formatStackDiff(\n  oldTemplate: any,\n  newTemplate: cxapi.CloudFormationStackArtifact,\n  strict: boolean,\n  context: number,\n  quiet: boolean,\n  stackName?: string,\n  changeSet?: DescribeChangeSetOutput,\n  isImport?: boolean,\n  nestedStackTemplates?: { [nestedStackLogicalId: string]: NestedStackTemplates }): FormatStackDiffOutput {\n  let diff = fullDiff(oldTemplate, newTemplate.template, changeSet, isImport);\n\n  // The stack diff is formatted via `Formatter`, which takes in a stream\n  // and sends its output directly to that stream. To faciliate use of the\n  // global CliIoHost, we create our own stream to capture the output of\n  // `Formatter` and return the output as a string for the consumer of\n  // `formatStackDiff` to decide what to do with it.\n  const stream = new StringWriteStream();\n\n  let numStacksWithChanges = 0;\n  let formattedDiff = '';\n  let filteredChangesCount = 0;\n  try {\n    // must output the stack name if there are differences, even if quiet\n    if (stackName && (!quiet || !diff.isEmpty)) {\n      stream.write(format('Stack %s\\n', chalk.bold(stackName)));\n    }\n\n    if (!quiet && isImport) {\n      stream.write('Parameters and rules created during migration do not affect resource configuration.\\n');\n    }\n\n    // detect and filter out mangled characters from the diff\n    if (diff.differenceCount && !strict) {\n      const mangledNewTemplate = JSON.parse(mangleLikeCloudFormation(JSON.stringify(newTemplate.template)));\n      const mangledDiff = fullDiff(oldTemplate, mangledNewTemplate, changeSet);\n      filteredChangesCount = Math.max(0, diff.differenceCount - mangledDiff.differenceCount);\n      if (filteredChangesCount > 0) {\n        diff = mangledDiff;\n      }\n    }\n\n    // filter out 'AWS::CDK::Metadata' resources from the template\n    // filter out 'CheckBootstrapVersion' rules from the template\n    if (!strict) {\n      obscureDiff(diff);\n    }\n\n    if (!diff.isEmpty) {\n      numStacksWithChanges++;\n\n      // formatDifferences updates the stream with the formatted stack diff\n      formatDifferences(stream, diff, {\n        ...logicalIdMapFromTemplate(oldTemplate),\n        ...buildLogicalToPathMap(newTemplate),\n      }, context);\n\n      // store the stream containing a formatted stack diff\n      formattedDiff = stream.toString();\n    } else if (!quiet) {\n      info(chalk.green('There were no differences'));\n    }\n  } finally {\n    stream.end();\n  }\n\n  if (filteredChangesCount > 0) {\n    info(chalk.yellow(`Omitted ${filteredChangesCount} changes because they are likely mangled non-ASCII characters. Use --strict to print them.`));\n  }\n\n  for (const nestedStackLogicalId of Object.keys(nestedStackTemplates ?? {})) {\n    if (!nestedStackTemplates) {\n      break;\n    }\n    const nestedStack = nestedStackTemplates[nestedStackLogicalId];\n\n    (newTemplate as any)._template = nestedStack.generatedTemplate;\n    const nextDiff = formatStackDiff(\n      nestedStack.deployedTemplate,\n      newTemplate,\n      strict,\n      context,\n      quiet,\n      nestedStack.physicalName ?? nestedStackLogicalId,\n      undefined,\n      isImport,\n      nestedStack.nestedStackTemplates,\n    );\n    numStacksWithChanges += nextDiff.numStacksWithChanges;\n    formattedDiff += nextDiff.formattedDiff;\n  }\n\n  return {\n    numStacksWithChanges,\n    formattedDiff,\n  };\n}\n\nexport enum RequireApproval {\n  Never = 'never',\n\n  AnyChange = 'any-change',\n\n  Broadening = 'broadening',\n}\n\n/**\n * Output of formatSecurityDiff\n */\nexport interface FormatSecurityDiffOutput {\n  /**\n   * Complete formatted security diff, if it is prompt-worthy\n   */\n  readonly formattedDiff?: string;\n}\n\n/**\n * Formats the security changes of this diff, if the change is impactful enough according to the approval level\n *\n * Returns the diff if the changes are prompt-worthy, an empty object otherwise.\n */\nexport function formatSecurityDiff(\n  oldTemplate: any,\n  newTemplate: cxapi.CloudFormationStackArtifact,\n  requireApproval: RequireApproval,\n  stackName?: string,\n  changeSet?: DescribeChangeSetOutput,\n): FormatSecurityDiffOutput {\n  const diff = fullDiff(oldTemplate, newTemplate.template, changeSet);\n\n  if (diffRequiresApproval(diff, requireApproval)) {\n    info(format('Stack %s\\n', chalk.bold(stackName)));\n\n    // eslint-disable-next-line max-len\n    warning(`This deployment will make potentially sensitive changes according to your current security approval level (--require-approval ${requireApproval}).`);\n    warning('Please confirm you intend to make the following modifications:\\n');\n\n    // The security diff is formatted via `Formatter`, which takes in a stream\n    // and sends its output directly to that stream. To faciliate use of the\n    // global CliIoHost, we create our own stream to capture the output of\n    // `Formatter` and return the output as a string for the consumer of\n    // `formatSecurityDiff` to decide what to do with it.\n    const stream = new StringWriteStream();\n    try {\n      // formatSecurityChanges updates the stream with the formatted security diff\n      formatSecurityChanges(stream, diff, buildLogicalToPathMap(newTemplate));\n    } finally {\n      stream.end();\n    }\n    // store the stream containing a formatted stack diff\n    const formattedDiff = stream.toString();\n    return { formattedDiff };\n  }\n  return {};\n}\n\n/**\n * Return whether the diff has security-impacting changes that need confirmation\n *\n * TODO: Filter the security impact determination based off of an enum that allows\n * us to pick minimum \"severities\" to alert on.\n */\nfunction diffRequiresApproval(diff: TemplateDiff, requireApproval: RequireApproval) {\n  switch (requireApproval) {\n    case RequireApproval.Never: return false;\n    case RequireApproval.AnyChange: return diff.permissionsAnyChanges;\n    case RequireApproval.Broadening: return diff.permissionsBroadened;\n    default: throw new ToolkitError(`Unrecognized approval level: ${requireApproval}`);\n  }\n}\n\nfunction buildLogicalToPathMap(stack: cxapi.CloudFormationStackArtifact) {\n  const map: { [id: string]: string } = {};\n  for (const md of stack.findMetadataByType(cxschema.ArtifactMetadataEntryType.LOGICAL_ID)) {\n    map[md.data as string] = md.path;\n  }\n  return map;\n}\n\nfunction logicalIdMapFromTemplate(template: any) {\n  const ret: Record<string, string> = {};\n\n  for (const [logicalId, resource] of Object.entries(template.Resources ?? {})) {\n    const path = (resource as any)?.Metadata?.['aws:cdk:path'];\n    if (path) {\n      ret[logicalId] = path;\n    }\n  }\n  return ret;\n}\n\n/**\n * Remove any template elements that we don't want to show users.\n * This is currently:\n * - AWS::CDK::Metadata resource\n * - CheckBootstrapVersion Rule\n */\nfunction obscureDiff(diff: TemplateDiff) {\n  if (diff.unknown) {\n    // see https://github.com/aws/aws-cdk/issues/17942\n    diff.unknown = diff.unknown.filter(change => {\n      if (!change) {\n        return true;\n      }\n      if (change.newValue?.CheckBootstrapVersion) {\n        return false;\n      }\n      if (change.oldValue?.CheckBootstrapVersion) {\n        return false;\n      }\n      return true;\n    });\n  }\n\n  if (diff.resources) {\n    diff.resources = diff.resources.filter(change => {\n      if (!change) {\n        return true;\n      }\n      if (change.newResourceType === 'AWS::CDK::Metadata') {\n        return false;\n      }\n      if (change.oldResourceType === 'AWS::CDK::Metadata') {\n        return false;\n      }\n      return true;\n    });\n  }\n}\n"]}
@@ -0,0 +1 @@
1
+ export * from './init';
@@ -0,0 +1,18 @@
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("./init"), exports);
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9pbml0JztcbiJdfQ==
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.invokeBuiltinHooks = invokeBuiltinHooks;
4
+ const path = require("path");
5
+ const os_1 = require("./os");
6
+ const api_1 = require("../../../../@aws-cdk/tmp-toolkit-helpers/src/api");
7
+ const util_1 = require("../../util");
8
+ /**
9
+ * Invoke hooks for the given init template
10
+ *
11
+ * Sometimes templates need more complex logic than just replacing tokens. A 'hook' can be
12
+ * used to do additional processing other than copying files.
13
+ *
14
+ * Hooks used to be defined externally to the CLI, by running arbitrarily
15
+ * substituted shell scripts in the target directory.
16
+ *
17
+ * In practice, they're all TypeScript files and all the same, and the dynamism
18
+ * that the original solution allowed wasn't used at all. Worse, since the CLI
19
+ * is now bundled the hooks can't even reuse code from the CLI libraries at all
20
+ * anymore, so all shared code would have to be copy/pasted.
21
+ *
22
+ * Bundle hooks as built-ins into the CLI, so they get bundled and can take advantage
23
+ * of all shared code.
24
+ */
25
+ async function invokeBuiltinHooks(target, context) {
26
+ switch (target.language) {
27
+ case 'csharp':
28
+ if (['app', 'sample-app'].includes(target.templateName)) {
29
+ return dotnetAddProject(target.targetDirectory, context);
30
+ }
31
+ break;
32
+ case 'fsharp':
33
+ if (['app', 'sample-app'].includes(target.templateName)) {
34
+ return dotnetAddProject(target.targetDirectory, context, 'fsproj');
35
+ }
36
+ break;
37
+ case 'python':
38
+ // We can't call this file 'requirements.template.txt' because Dependabot needs to be able to find it.
39
+ // Therefore, keep the in-repo name but still substitute placeholders.
40
+ await context.substitutePlaceholdersIn('requirements.txt');
41
+ break;
42
+ case 'java':
43
+ // We can't call this file 'pom.template.xml'... for the same reason as Python above.
44
+ await context.substitutePlaceholdersIn('pom.xml');
45
+ break;
46
+ case 'javascript':
47
+ case 'typescript':
48
+ // See above, but for 'package.json'.
49
+ await context.substitutePlaceholdersIn('package.json');
50
+ }
51
+ }
52
+ async function dotnetAddProject(targetDirectory, context, ext = 'csproj') {
53
+ const pname = context.placeholder('name.PascalCased');
54
+ const slnPath = path.join(targetDirectory, 'src', `${pname}.sln`);
55
+ const csprojPath = path.join(targetDirectory, 'src', pname, `${pname}.${ext}`);
56
+ try {
57
+ await (0, os_1.shell)(['dotnet', 'sln', slnPath, 'add', csprojPath]);
58
+ }
59
+ catch (e) {
60
+ throw new api_1.ToolkitError(`Could not add project ${pname}.${ext} to solution ${pname}.sln. ${(0, util_1.formatErrorMessage)(e)}`);
61
+ }
62
+ }
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5pdC1ob29rcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImluaXQtaG9va3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFpREEsZ0RBOEJDO0FBL0VELDZCQUE2QjtBQUM3Qiw2QkFBNkI7QUFDN0IsMEVBQWdGO0FBQ2hGLHFDQUFnRDtBQTZCaEQ7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnQkc7QUFDSSxLQUFLLFVBQVUsa0JBQWtCLENBQUMsTUFBa0IsRUFBRSxPQUFvQjtJQUMvRSxRQUFRLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN4QixLQUFLLFFBQVE7WUFDWCxJQUFJLENBQUMsS0FBSyxFQUFFLFlBQVksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQztnQkFDeEQsT0FBTyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsZUFBZSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQzNELENBQUM7WUFDRCxNQUFNO1FBRVIsS0FBSyxRQUFRO1lBQ1gsSUFBSSxDQUFDLEtBQUssRUFBRSxZQUFZLENBQUMsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxFQUFFLENBQUM7Z0JBQ3hELE9BQU8sZ0JBQWdCLENBQUMsTUFBTSxDQUFDLGVBQWUsRUFBRSxPQUFPLEVBQUUsUUFBUSxDQUFDLENBQUM7WUFDckUsQ0FBQztZQUNELE1BQU07UUFFUixLQUFLLFFBQVE7WUFDWCxzR0FBc0c7WUFDdEcsc0VBQXNFO1lBQ3RFLE1BQU0sT0FBTyxDQUFDLHdCQUF3QixDQUFDLGtCQUFrQixDQUFDLENBQUM7WUFDM0QsTUFBTTtRQUVSLEtBQUssTUFBTTtZQUNULHFGQUFxRjtZQUNyRixNQUFNLE9BQU8sQ0FBQyx3QkFBd0IsQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUNsRCxNQUFNO1FBRVIsS0FBSyxZQUFZLENBQUM7UUFDbEIsS0FBSyxZQUFZO1lBQ2YscUNBQXFDO1lBQ3JDLE1BQU0sT0FBTyxDQUFDLHdCQUF3QixDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDO0FBRUQsS0FBSyxVQUFVLGdCQUFnQixDQUFDLGVBQXVCLEVBQUUsT0FBb0IsRUFBRSxHQUFHLEdBQUcsUUFBUTtJQUMzRixNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDdEQsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsS0FBSyxFQUFFLEdBQUcsS0FBSyxNQUFNLENBQUMsQ0FBQztJQUNsRSxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEdBQUcsS0FBSyxJQUFJLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDL0UsSUFBSSxDQUFDO1FBQ0gsTUFBTSxJQUFBLFVBQUssRUFBQyxDQUFDLFFBQVEsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFBQyxPQUFPLENBQU0sRUFBRSxDQUFDO1FBQ2hCLE1BQU0sSUFBSSxrQkFBWSxDQUFDLHlCQUF5QixLQUFLLElBQUksR0FBRyxnQkFBZ0IsS0FBSyxTQUFTLElBQUEseUJBQWtCLEVBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3JILENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IHNoZWxsIH0gZnJvbSAnLi9vcyc7XG5pbXBvcnQgeyBUb29sa2l0RXJyb3IgfSBmcm9tICcuLi8uLi8uLi8uLi9AYXdzLWNkay90bXAtdG9vbGtpdC1oZWxwZXJzL3NyYy9hcGknO1xuaW1wb3J0IHsgZm9ybWF0RXJyb3JNZXNzYWdlIH0gZnJvbSAnLi4vLi4vdXRpbCc7XG5cbmV4cG9ydCB0eXBlIFN1YnN0aXR1dGVQbGFjZWhvbGRlcnMgPSAoLi4uZmlsZU5hbWVzOiBzdHJpbmdbXSkgPT4gUHJvbWlzZTx2b2lkPjtcblxuLyoqXG4gKiBIZWxwZXJzIHBhc3NlZCB0byBob29rIGZ1bmN0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEhvb2tDb250ZXh0IHtcbiAgLyoqXG4gICAqIENhbGxiYWNrIGZ1bmN0aW9uIHRvIHJlcGxhY2UgcGxhY2Vob2xkZXJzIG9uIGFyYml0cmFyeSBmaWxlc1xuICAgKlxuICAgKiBUaGlzIG1ha2VzIHRva2VuIHN1YnN0aXR1dGlvbiBhdmFpbGFibGUgdG8gbm9uLWAudGVtcGxhdGVgIGZpbGVzLlxuICAgKi9cbiAgcmVhZG9ubHkgc3Vic3RpdHV0ZVBsYWNlaG9sZGVyc0luOiBTdWJzdGl0dXRlUGxhY2Vob2xkZXJzO1xuXG4gIC8qKlxuICAgKiBSZXR1cm4gYSBzaW5nbGUgcGxhY2Vob2xkZXJcbiAgICovXG4gIHBsYWNlaG9sZGVyKG5hbWU6IHN0cmluZyk6IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgSW52b2tlSG9vayA9ICh0YXJnZXREaXJlY3Rvcnk6IHN0cmluZywgY29udGV4dDogSG9va0NvbnRleHQpID0+IFByb21pc2U8dm9pZD47XG5cbmV4cG9ydCBpbnRlcmZhY2UgSG9va1RhcmdldCB7XG4gIHJlYWRvbmx5IHRhcmdldERpcmVjdG9yeTogc3RyaW5nO1xuICByZWFkb25seSB0ZW1wbGF0ZU5hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgbGFuZ3VhZ2U6IHN0cmluZztcbn1cblxuLyoqXG4gKiBJbnZva2UgaG9va3MgZm9yIHRoZSBnaXZlbiBpbml0IHRlbXBsYXRlXG4gKlxuICogU29tZXRpbWVzIHRlbXBsYXRlcyBuZWVkIG1vcmUgY29tcGxleCBsb2dpYyB0aGFuIGp1c3QgcmVwbGFjaW5nIHRva2Vucy4gQSAnaG9vaycgY2FuIGJlXG4gKiB1c2VkIHRvIGRvIGFkZGl0aW9uYWwgcHJvY2Vzc2luZyBvdGhlciB0aGFuIGNvcHlpbmcgZmlsZXMuXG4gKlxuICogSG9va3MgdXNlZCB0byBiZSBkZWZpbmVkIGV4dGVybmFsbHkgdG8gdGhlIENMSSwgYnkgcnVubmluZyBhcmJpdHJhcmlseVxuICogc3Vic3RpdHV0ZWQgc2hlbGwgc2NyaXB0cyBpbiB0aGUgdGFyZ2V0IGRpcmVjdG9yeS5cbiAqXG4gKiBJbiBwcmFjdGljZSwgdGhleSdyZSBhbGwgVHlwZVNjcmlwdCBmaWxlcyBhbmQgYWxsIHRoZSBzYW1lLCBhbmQgdGhlIGR5bmFtaXNtXG4gKiB0aGF0IHRoZSBvcmlnaW5hbCBzb2x1dGlvbiBhbGxvd2VkIHdhc24ndCB1c2VkIGF0IGFsbC4gV29yc2UsIHNpbmNlIHRoZSBDTElcbiAqIGlzIG5vdyBidW5kbGVkIHRoZSBob29rcyBjYW4ndCBldmVuIHJldXNlIGNvZGUgZnJvbSB0aGUgQ0xJIGxpYnJhcmllcyBhdCBhbGxcbiAqIGFueW1vcmUsIHNvIGFsbCBzaGFyZWQgY29kZSB3b3VsZCBoYXZlIHRvIGJlIGNvcHkvcGFzdGVkLlxuICpcbiAqIEJ1bmRsZSBob29rcyBhcyBidWlsdC1pbnMgaW50byB0aGUgQ0xJLCBzbyB0aGV5IGdldCBidW5kbGVkIGFuZCBjYW4gdGFrZSBhZHZhbnRhZ2VcbiAqIG9mIGFsbCBzaGFyZWQgY29kZS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGludm9rZUJ1aWx0aW5Ib29rcyh0YXJnZXQ6IEhvb2tUYXJnZXQsIGNvbnRleHQ6IEhvb2tDb250ZXh0KSB7XG4gIHN3aXRjaCAodGFyZ2V0Lmxhbmd1YWdlKSB7XG4gICAgY2FzZSAnY3NoYXJwJzpcbiAgICAgIGlmIChbJ2FwcCcsICdzYW1wbGUtYXBwJ10uaW5jbHVkZXModGFyZ2V0LnRlbXBsYXRlTmFtZSkpIHtcbiAgICAgICAgcmV0dXJuIGRvdG5ldEFkZFByb2plY3QodGFyZ2V0LnRhcmdldERpcmVjdG9yeSwgY29udGV4dCk7XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2ZzaGFycCc6XG4gICAgICBpZiAoWydhcHAnLCAnc2FtcGxlLWFwcCddLmluY2x1ZGVzKHRhcmdldC50ZW1wbGF0ZU5hbWUpKSB7XG4gICAgICAgIHJldHVybiBkb3RuZXRBZGRQcm9qZWN0KHRhcmdldC50YXJnZXREaXJlY3RvcnksIGNvbnRleHQsICdmc3Byb2onKTtcbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAncHl0aG9uJzpcbiAgICAgIC8vIFdlIGNhbid0IGNhbGwgdGhpcyBmaWxlICdyZXF1aXJlbWVudHMudGVtcGxhdGUudHh0JyBiZWNhdXNlIERlcGVuZGFib3QgbmVlZHMgdG8gYmUgYWJsZSB0byBmaW5kIGl0LlxuICAgICAgLy8gVGhlcmVmb3JlLCBrZWVwIHRoZSBpbi1yZXBvIG5hbWUgYnV0IHN0aWxsIHN1YnN0aXR1dGUgcGxhY2Vob2xkZXJzLlxuICAgICAgYXdhaXQgY29udGV4dC5zdWJzdGl0dXRlUGxhY2Vob2xkZXJzSW4oJ3JlcXVpcmVtZW50cy50eHQnKTtcbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnamF2YSc6XG4gICAgICAvLyBXZSBjYW4ndCBjYWxsIHRoaXMgZmlsZSAncG9tLnRlbXBsYXRlLnhtbCcuLi4gZm9yIHRoZSBzYW1lIHJlYXNvbiBhcyBQeXRob24gYWJvdmUuXG4gICAgICBhd2FpdCBjb250ZXh0LnN1YnN0aXR1dGVQbGFjZWhvbGRlcnNJbigncG9tLnhtbCcpO1xuICAgICAgYnJlYWs7XG5cbiAgICBjYXNlICdqYXZhc2NyaXB0JzpcbiAgICBjYXNlICd0eXBlc2NyaXB0JzpcbiAgICAgIC8vIFNlZSBhYm92ZSwgYnV0IGZvciAncGFja2FnZS5qc29uJy5cbiAgICAgIGF3YWl0IGNvbnRleHQuc3Vic3RpdHV0ZVBsYWNlaG9sZGVyc0luKCdwYWNrYWdlLmpzb24nKTtcbiAgfVxufVxuXG5hc3luYyBmdW5jdGlvbiBkb3RuZXRBZGRQcm9qZWN0KHRhcmdldERpcmVjdG9yeTogc3RyaW5nLCBjb250ZXh0OiBIb29rQ29udGV4dCwgZXh0ID0gJ2NzcHJvaicpIHtcbiAgY29uc3QgcG5hbWUgPSBjb250ZXh0LnBsYWNlaG9sZGVyKCduYW1lLlBhc2NhbENhc2VkJyk7XG4gIGNvbnN0IHNsblBhdGggPSBwYXRoLmpvaW4odGFyZ2V0RGlyZWN0b3J5LCAnc3JjJywgYCR7cG5hbWV9LnNsbmApO1xuICBjb25zdCBjc3Byb2pQYXRoID0gcGF0aC5qb2luKHRhcmdldERpcmVjdG9yeSwgJ3NyYycsIHBuYW1lLCBgJHtwbmFtZX0uJHtleHR9YCk7XG4gIHRyeSB7XG4gICAgYXdhaXQgc2hlbGwoWydkb3RuZXQnLCAnc2xuJywgc2xuUGF0aCwgJ2FkZCcsIGNzcHJvalBhdGhdKTtcbiAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgdGhyb3cgbmV3IFRvb2xraXRFcnJvcihgQ291bGQgbm90IGFkZCBwcm9qZWN0ICR7cG5hbWV9LiR7ZXh0fSB0byBzb2x1dGlvbiAke3BuYW1lfS5zbG4uICR7Zm9ybWF0RXJyb3JNZXNzYWdlKGUpfWApO1xuICB9XG59XG4iXX0=