aws-cdk 2.1005.0 → 2.1007.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.
- package/README.md +1 -1
- package/THIRD_PARTY_LICENSES +86 -86
- package/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/api/aws-auth/awscli-compatible.js +9 -10
- package/lib/api/aws-auth/credential-plugins.js +6 -7
- package/lib/api/aws-auth/sdk-logger.js +3 -4
- package/lib/api/aws-auth/sdk-provider.js +11 -13
- package/lib/api/aws-auth/sdk.js +8 -9
- package/lib/api/aws-auth/tracing.js +3 -4
- package/lib/api/aws-auth/user-agent.js +4 -5
- package/lib/api/bootstrap/bootstrap-environment.d.ts +1 -1
- package/lib/api/bootstrap/bootstrap-environment.js +42 -46
- package/lib/api/bootstrap/bootstrap-props.d.ts +1 -1
- package/lib/api/bootstrap/bootstrap-props.js +1 -1
- package/lib/api/bootstrap/deploy-bootstrap.d.ts +1 -1
- package/lib/api/bootstrap/deploy-bootstrap.js +11 -14
- package/lib/api/{evaluate-cloudformation-template.d.ts → cloudformation/evaluate-cloudformation-template.d.ts} +4 -8
- package/lib/api/{evaluate-cloudformation-template.js → cloudformation/evaluate-cloudformation-template.js} +16 -25
- package/lib/api/cloudformation/index.d.ts +4 -0
- package/lib/api/cloudformation/index.js +21 -0
- package/lib/api/{deployments → cloudformation}/nested-stack-helpers.d.ts +3 -9
- package/lib/api/cloudformation/nested-stack-helpers.js +86 -0
- package/lib/api/cloudformation/stack-helpers.d.ts +88 -0
- package/lib/api/cloudformation/stack-helpers.js +158 -0
- package/lib/api/{util → cloudformation}/template-body-parameter.d.ts +3 -2
- package/lib/api/cloudformation/template-body-parameter.js +104 -0
- package/lib/api/context.js +3 -3
- package/lib/api/cxapp/cloud-assembly.d.ts +6 -4
- package/lib/api/cxapp/cloud-assembly.js +25 -26
- package/lib/api/cxapp/cloud-executable.d.ts +5 -0
- package/lib/api/cxapp/cloud-executable.js +9 -10
- package/lib/api/cxapp/environments.js +4 -4
- package/lib/api/cxapp/exec.d.ts +5 -4
- package/lib/api/cxapp/exec.js +76 -72
- package/lib/api/deployments/asset-publishing.d.ts +0 -2
- package/lib/api/deployments/asset-publishing.js +24 -31
- package/lib/api/deployments/assets.d.ts +1 -1
- package/lib/api/deployments/assets.js +12 -13
- package/lib/api/deployments/{cloudformation.d.ts → cfn-api.d.ts} +5 -102
- package/lib/api/deployments/cfn-api.js +438 -0
- package/lib/api/deployments/checks.d.ts +1 -1
- package/lib/api/deployments/checks.js +12 -13
- package/lib/api/deployments/deploy-stack.d.ts +2 -3
- package/lib/api/deployments/deploy-stack.js +34 -45
- package/lib/api/deployments/deployment-result.js +3 -3
- package/lib/api/deployments/deployments.d.ts +3 -3
- package/lib/api/deployments/deployments.js +35 -42
- package/lib/api/deployments/hotswap-deployments.d.ts +2 -2
- package/lib/api/deployments/hotswap-deployments.js +122 -69
- package/lib/api/deployments/index.d.ts +1 -2
- package/lib/api/deployments/index.js +2 -3
- package/lib/api/environment/environment-access.d.ts +2 -2
- package/lib/api/environment/environment-access.js +18 -20
- package/lib/api/environment/environment-resources.d.ts +1 -1
- package/lib/api/environment/environment-resources.js +17 -19
- package/lib/api/environment/index.d.ts +1 -0
- package/lib/api/environment/index.js +2 -1
- package/lib/api/environment/placeholders.js +23 -0
- package/lib/api/garbage-collection/garbage-collector.d.ts +1 -1
- package/lib/api/garbage-collection/garbage-collector.js +56 -66
- package/lib/api/garbage-collection/progress-printer.d.ts +1 -1
- package/lib/api/garbage-collection/progress-printer.js +7 -7
- package/lib/api/garbage-collection/stack-refresh.d.ts +1 -1
- package/lib/api/garbage-collection/stack-refresh.js +12 -15
- package/lib/api/hotswap/appsync-mapping-templates.d.ts +3 -3
- package/lib/api/hotswap/appsync-mapping-templates.js +25 -22
- package/lib/api/hotswap/code-build-projects.d.ts +3 -3
- package/lib/api/hotswap/code-build-projects.js +12 -7
- package/lib/api/hotswap/common.d.ts +13 -61
- package/lib/api/hotswap/common.js +40 -70
- package/lib/api/hotswap/ecs-services.d.ts +4 -4
- package/lib/api/hotswap/ecs-services.js +38 -21
- package/lib/api/hotswap/lambda-functions.d.ts +3 -3
- package/lib/api/hotswap/lambda-functions.js +23 -19
- package/lib/api/hotswap/s3-bucket-deployments.d.ts +3 -3
- package/lib/api/hotswap/s3-bucket-deployments.js +11 -7
- package/lib/api/hotswap/stepfunctions-state-machines.d.ts +3 -3
- package/lib/api/hotswap/stepfunctions-state-machines.js +8 -4
- package/lib/api/logs/find-cloudwatch-logs.js +6 -7
- package/lib/api/logs/logs-monitor.js +5 -8
- package/lib/api/plugin/plugin.js +6 -10
- package/lib/api/resource-import/importer.d.ts +8 -8
- package/lib/api/resource-import/importer.js +27 -42
- package/lib/api/resource-import/migrator.d.ts +3 -3
- package/lib/api/resource-import/migrator.js +6 -6
- package/lib/api/settings.d.ts +0 -3
- package/lib/api/settings.js +4 -40
- package/lib/api/stack-events/stack-activity-monitor.d.ts +1 -1
- package/lib/api/stack-events/stack-activity-monitor.js +12 -15
- package/lib/api/stack-events/stack-event-poller.js +9 -10
- package/lib/api/toolkit-info.d.ts +2 -2
- package/lib/api/toolkit-info.js +20 -24
- package/lib/{tree.d.ts → api/tree.d.ts} +2 -2
- package/lib/api/tree.js +37 -0
- package/lib/api/util/rwlock.js +4 -4
- package/lib/api/work-graph/work-graph-builder.js +4 -4
- package/lib/api/work-graph/work-graph.d.ts +1 -1
- package/lib/api/work-graph/work-graph.js +13 -15
- package/lib/cli/activity-printer/base.d.ts +2 -2
- package/lib/cli/activity-printer/base.js +6 -8
- package/lib/cli/activity-printer/current.js +7 -11
- package/lib/cli/activity-printer/history.js +2 -3
- package/lib/cli/cdk-toolkit.d.ts +16 -19
- package/lib/cli/cdk-toolkit.js +118 -74
- package/lib/cli/ci-systems.js +2 -3
- package/lib/cli/cli-config.js +4 -4
- package/lib/cli/cli.js +49 -50
- package/lib/cli/convert-to-user-input.js +110 -111
- package/lib/{toolkit → cli/io-host}/cli-io-host.d.ts +6 -2
- package/lib/cli/io-host/cli-io-host.js +356 -0
- package/lib/cli/io-host/index.d.ts +1 -0
- package/lib/{toolkit/error.js → cli/io-host/index.js} +2 -2
- package/lib/cli/messages.d.ts +1 -1
- package/lib/cli/messages.js +2 -3
- package/lib/cli/pretty-print-error.d.ts +1 -0
- package/lib/cli/pretty-print-error.js +35 -0
- package/lib/cli/root-dir.js +4 -4
- package/lib/cli/user-configuration.js +57 -14
- package/lib/cli/util/npm.js +3 -3
- package/lib/cli/util/yargs-helpers.d.ts +1 -1
- package/lib/cli/util/yargs-helpers.js +3 -3
- package/lib/cli/version.js +4 -4
- package/lib/commands/context.js +7 -8
- package/lib/commands/diff.d.ts +1 -0
- package/lib/commands/diff.js +7 -0
- package/lib/commands/init/index.d.ts +1 -0
- package/lib/commands/init/index.js +18 -0
- package/lib/commands/init/init-hooks.js +63 -0
- package/lib/commands/init/init.js +435 -0
- package/lib/{os.js → commands/init/os.js} +4 -4
- package/lib/{list-stacks.d.ts → commands/list-stacks.d.ts} +1 -1
- package/lib/{list-stacks.js → commands/list-stacks.js} +2 -2
- package/lib/commands/migrate.js +29 -32
- package/lib/context-providers/ami.d.ts +3 -1
- package/lib/context-providers/ami.js +8 -8
- package/lib/context-providers/availability-zones.d.ts +3 -1
- package/lib/context-providers/availability-zones.js +4 -4
- package/lib/context-providers/cc-api-provider.d.ts +8 -12
- package/lib/context-providers/cc-api-provider.js +94 -66
- package/lib/context-providers/endpoint-service-availability-zones.d.ts +3 -1
- package/lib/context-providers/endpoint-service-availability-zones.js +6 -6
- package/lib/context-providers/hosted-zones.d.ts +3 -1
- package/lib/context-providers/hosted-zones.js +11 -11
- package/lib/context-providers/index.d.ts +19 -5
- package/lib/context-providers/index.js +35 -17
- package/lib/context-providers/keys.d.ts +3 -1
- package/lib/context-providers/keys.js +8 -8
- package/lib/context-providers/load-balancers.js +15 -18
- package/lib/context-providers/security-groups.js +10 -12
- package/lib/context-providers/ssm-parameters.d.ts +3 -1
- package/lib/context-providers/ssm-parameters.js +7 -7
- package/lib/context-providers/vpcs.d.ts +3 -1
- package/lib/context-providers/vpcs.js +14 -15
- package/lib/index.js +124098 -123198
- package/lib/init-templates/.init-version.json +1 -1
- package/lib/init-templates/.recommended-feature-flags.json +3 -1
- package/lib/legacy-exports-source.d.ts +4 -5
- package/lib/legacy-exports-source.js +6 -7
- package/lib/logging.js +2 -2
- package/lib/notices.d.ts +1 -1
- package/lib/notices.js +26 -32
- package/package.json +29 -29
- package/lib/api/deployments/cloudformation.js +0 -597
- package/lib/api/deployments/nested-stack-helpers.js +0 -88
- package/lib/api/util/placeholders.js +0 -24
- package/lib/api/util/template-body-parameter.js +0 -103
- package/lib/diff.d.ts +0 -28
- package/lib/diff.js +0 -165
- package/lib/init-hooks.js +0 -63
- package/lib/init.js +0 -437
- package/lib/toolkit/cli-io-host.js +0 -353
- package/lib/toolkit/error.d.ts +0 -1
- package/lib/tree.js +0 -40
- /package/lib/api/{util → environment}/placeholders.d.ts +0 -0
- /package/lib/{init-hooks.d.ts → commands/init/init-hooks.d.ts} +0 -0
- /package/lib/{init.d.ts → commands/init/init.d.ts} +0 -0
- /package/lib/{os.d.ts → commands/init/os.d.ts} +0 -0
|
@@ -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=
|
|
@@ -0,0 +1,435 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InitTemplate = void 0;
|
|
4
|
+
exports.cliInit = cliInit;
|
|
5
|
+
exports.expandPlaceholders = expandPlaceholders;
|
|
6
|
+
exports.availableInitTemplates = availableInitTemplates;
|
|
7
|
+
exports.availableInitLanguages = availableInitLanguages;
|
|
8
|
+
exports.printAvailableTemplates = printAvailableTemplates;
|
|
9
|
+
exports.currentlyRecommendedAwsCdkLibFlags = currentlyRecommendedAwsCdkLibFlags;
|
|
10
|
+
const childProcess = require("child_process");
|
|
11
|
+
const path = require("path");
|
|
12
|
+
const chalk = require("chalk");
|
|
13
|
+
const fs = require("fs-extra");
|
|
14
|
+
const init_hooks_1 = require("./init-hooks");
|
|
15
|
+
const api_1 = require("../../../../@aws-cdk/tmp-toolkit-helpers/src/api");
|
|
16
|
+
const root_dir_1 = require("../../cli/root-dir");
|
|
17
|
+
const version_1 = require("../../cli/version");
|
|
18
|
+
const logging_1 = require("../../logging");
|
|
19
|
+
const util_1 = require("../../util");
|
|
20
|
+
/* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module
|
|
21
|
+
// eslint-disable-next-line @typescript-eslint/no-require-imports
|
|
22
|
+
const camelCase = require('camelcase');
|
|
23
|
+
// eslint-disable-next-line @typescript-eslint/no-require-imports
|
|
24
|
+
const decamelize = require('decamelize');
|
|
25
|
+
/**
|
|
26
|
+
* Initialize a CDK package in the current directory
|
|
27
|
+
*/
|
|
28
|
+
async function cliInit(options) {
|
|
29
|
+
const canUseNetwork = options.canUseNetwork ?? true;
|
|
30
|
+
const generateOnly = options.generateOnly ?? false;
|
|
31
|
+
const workDir = options.workDir ?? process.cwd();
|
|
32
|
+
if (!options.type && !options.language) {
|
|
33
|
+
await printAvailableTemplates();
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const type = options.type || 'default'; // "default" is the default type (and maps to "app")
|
|
37
|
+
const template = (await availableInitTemplates()).find((t) => t.hasName(type));
|
|
38
|
+
if (!template) {
|
|
39
|
+
await printAvailableTemplates(options.language);
|
|
40
|
+
throw new api_1.ToolkitError(`Unknown init template: ${type}`);
|
|
41
|
+
}
|
|
42
|
+
if (!options.language && template.languages.length === 1) {
|
|
43
|
+
const language = template.languages[0];
|
|
44
|
+
(0, logging_1.warning)(`No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`);
|
|
45
|
+
}
|
|
46
|
+
if (!options.language) {
|
|
47
|
+
(0, logging_1.info)(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);
|
|
48
|
+
throw new api_1.ToolkitError('No language was selected');
|
|
49
|
+
}
|
|
50
|
+
await initializeProject(template, options.language, canUseNetwork, generateOnly, workDir, options.stackName, options.migrate, options.libVersion);
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Returns the name of the Python executable for this OS
|
|
54
|
+
*/
|
|
55
|
+
function pythonExecutable() {
|
|
56
|
+
let python = 'python3';
|
|
57
|
+
if (process.platform === 'win32') {
|
|
58
|
+
python = 'python';
|
|
59
|
+
}
|
|
60
|
+
return python;
|
|
61
|
+
}
|
|
62
|
+
const INFO_DOT_JSON = 'info.json';
|
|
63
|
+
class InitTemplate {
|
|
64
|
+
static async fromName(templatesDir, name) {
|
|
65
|
+
const basePath = path.join(templatesDir, name);
|
|
66
|
+
const languages = await listDirectory(basePath);
|
|
67
|
+
const initInfo = await fs.readJson(path.join(basePath, INFO_DOT_JSON));
|
|
68
|
+
return new InitTemplate(basePath, name, languages, initInfo);
|
|
69
|
+
}
|
|
70
|
+
constructor(basePath, name, languages, initInfo) {
|
|
71
|
+
this.basePath = basePath;
|
|
72
|
+
this.name = name;
|
|
73
|
+
this.languages = languages;
|
|
74
|
+
this.aliases = new Set();
|
|
75
|
+
this.description = initInfo.description;
|
|
76
|
+
for (const alias of initInfo.aliases || []) {
|
|
77
|
+
this.aliases.add(alias);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* @param name the name that is being checked
|
|
82
|
+
* @returns ``true`` if ``name`` is the name of this template or an alias of it.
|
|
83
|
+
*/
|
|
84
|
+
hasName(name) {
|
|
85
|
+
return name === this.name || this.aliases.has(name);
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Creates a new instance of this ``InitTemplate`` for a given language to a specified folder.
|
|
89
|
+
*
|
|
90
|
+
* @param language the language to instantiate this template with
|
|
91
|
+
* @param targetDirectory the directory where the template is to be instantiated into
|
|
92
|
+
*/
|
|
93
|
+
async install(language, targetDirectory, stackName, libVersion) {
|
|
94
|
+
if (this.languages.indexOf(language) === -1) {
|
|
95
|
+
(0, logging_1.error)(`The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` +
|
|
96
|
+
`(it supports: ${this.languages.map((l) => chalk.blue(l)).join(', ')})`);
|
|
97
|
+
throw new api_1.ToolkitError(`Unsupported language: ${language}`);
|
|
98
|
+
}
|
|
99
|
+
const projectInfo = {
|
|
100
|
+
name: decamelize(path.basename(path.resolve(targetDirectory))),
|
|
101
|
+
stackName,
|
|
102
|
+
versions: await loadInitVersions(),
|
|
103
|
+
};
|
|
104
|
+
if (libVersion) {
|
|
105
|
+
projectInfo.versions['aws-cdk-lib'] = libVersion;
|
|
106
|
+
}
|
|
107
|
+
const sourceDirectory = path.join(this.basePath, language);
|
|
108
|
+
await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);
|
|
109
|
+
await this.applyFutureFlags(targetDirectory);
|
|
110
|
+
await (0, init_hooks_1.invokeBuiltinHooks)({ targetDirectory, language, templateName: this.name }, {
|
|
111
|
+
substitutePlaceholdersIn: async (...fileNames) => {
|
|
112
|
+
for (const fileName of fileNames) {
|
|
113
|
+
const fullPath = path.join(targetDirectory, fileName);
|
|
114
|
+
const template = await fs.readFile(fullPath, { encoding: 'utf-8' });
|
|
115
|
+
await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo));
|
|
116
|
+
}
|
|
117
|
+
},
|
|
118
|
+
placeholder: (ph) => expandPlaceholders(`%${ph}%`, language, projectInfo),
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
async installFiles(sourceDirectory, targetDirectory, language, project) {
|
|
122
|
+
for (const file of await fs.readdir(sourceDirectory)) {
|
|
123
|
+
const fromFile = path.join(sourceDirectory, file);
|
|
124
|
+
const toFile = path.join(targetDirectory, expandPlaceholders(file, language, project));
|
|
125
|
+
if ((await fs.stat(fromFile)).isDirectory()) {
|
|
126
|
+
await fs.mkdir(toFile);
|
|
127
|
+
await this.installFiles(fromFile, toFile, language, project);
|
|
128
|
+
continue;
|
|
129
|
+
}
|
|
130
|
+
else if (file.match(/^.*\.template\.[^.]+$/)) {
|
|
131
|
+
await this.installProcessed(fromFile, toFile.replace(/\.template(\.[^.]+)$/, '$1'), language, project);
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
else if (file.match(/^.*\.hook\.(d.)?[^.]+$/)) {
|
|
135
|
+
// Ignore
|
|
136
|
+
continue;
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
await fs.copy(fromFile, toFile);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
async installProcessed(templatePath, toFile, language, project) {
|
|
144
|
+
const template = await fs.readFile(templatePath, { encoding: 'utf-8' });
|
|
145
|
+
await fs.writeFile(toFile, expandPlaceholders(template, language, project));
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Adds context variables to `cdk.json` in the generated project directory to
|
|
149
|
+
* enable future behavior for new projects.
|
|
150
|
+
*/
|
|
151
|
+
async applyFutureFlags(projectDir) {
|
|
152
|
+
const cdkJson = path.join(projectDir, 'cdk.json');
|
|
153
|
+
if (!(await fs.pathExists(cdkJson))) {
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
const config = await fs.readJson(cdkJson);
|
|
157
|
+
config.context = {
|
|
158
|
+
...config.context,
|
|
159
|
+
...await currentlyRecommendedAwsCdkLibFlags(),
|
|
160
|
+
};
|
|
161
|
+
await fs.writeJson(cdkJson, config, { spaces: 2 });
|
|
162
|
+
}
|
|
163
|
+
async addMigrateContext(projectDir) {
|
|
164
|
+
const cdkJson = path.join(projectDir, 'cdk.json');
|
|
165
|
+
if (!(await fs.pathExists(cdkJson))) {
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
const config = await fs.readJson(cdkJson);
|
|
169
|
+
config.context = {
|
|
170
|
+
...config.context,
|
|
171
|
+
'cdk-migrate': true,
|
|
172
|
+
};
|
|
173
|
+
await fs.writeJson(cdkJson, config, { spaces: 2 });
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
exports.InitTemplate = InitTemplate;
|
|
177
|
+
function expandPlaceholders(template, language, project) {
|
|
178
|
+
const cdkVersion = project.versions['aws-cdk-lib'];
|
|
179
|
+
const cdkCliVersion = project.versions['aws-cdk'];
|
|
180
|
+
let constructsVersion = project.versions.constructs;
|
|
181
|
+
switch (language) {
|
|
182
|
+
case 'java':
|
|
183
|
+
case 'csharp':
|
|
184
|
+
case 'fsharp':
|
|
185
|
+
constructsVersion = (0, util_1.rangeFromSemver)(constructsVersion, 'bracket');
|
|
186
|
+
break;
|
|
187
|
+
case 'python':
|
|
188
|
+
constructsVersion = (0, util_1.rangeFromSemver)(constructsVersion, 'pep');
|
|
189
|
+
break;
|
|
190
|
+
}
|
|
191
|
+
return template
|
|
192
|
+
.replace(/%name%/g, project.name)
|
|
193
|
+
.replace(/%stackname%/, project.stackName ?? '%name.PascalCased%Stack')
|
|
194
|
+
.replace(/%PascalNameSpace%/, project.stackName ? camelCase(project.stackName + 'Stack', { pascalCase: true }) : '%name.PascalCased%')
|
|
195
|
+
.replace(/%PascalStackProps%/, project.stackName ? camelCase(project.stackName, { pascalCase: true }) + 'StackProps' : 'StackProps')
|
|
196
|
+
.replace(/%name\.camelCased%/g, camelCase(project.name))
|
|
197
|
+
.replace(/%name\.PascalCased%/g, camelCase(project.name, { pascalCase: true }))
|
|
198
|
+
.replace(/%cdk-version%/g, cdkVersion)
|
|
199
|
+
.replace(/%cdk-cli-version%/g, cdkCliVersion)
|
|
200
|
+
.replace(/%constructs-version%/g, constructsVersion)
|
|
201
|
+
.replace(/%cdk-home%/g, (0, util_1.cdkHomeDir)())
|
|
202
|
+
.replace(/%name\.PythonModule%/g, project.name.replace(/-/g, '_'))
|
|
203
|
+
.replace(/%python-executable%/g, pythonExecutable())
|
|
204
|
+
.replace(/%name\.StackName%/g, project.name.replace(/[^A-Za-z0-9-]/g, '-'));
|
|
205
|
+
}
|
|
206
|
+
async function availableInitTemplates() {
|
|
207
|
+
return new Promise(async (resolve) => {
|
|
208
|
+
try {
|
|
209
|
+
const templatesDir = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates');
|
|
210
|
+
const templateNames = await listDirectory(templatesDir);
|
|
211
|
+
const templates = new Array();
|
|
212
|
+
for (const templateName of templateNames) {
|
|
213
|
+
templates.push(await InitTemplate.fromName(templatesDir, templateName));
|
|
214
|
+
}
|
|
215
|
+
resolve(templates);
|
|
216
|
+
}
|
|
217
|
+
catch {
|
|
218
|
+
resolve([]);
|
|
219
|
+
}
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
async function availableInitLanguages() {
|
|
223
|
+
return new Promise(async (resolve) => {
|
|
224
|
+
const templates = await availableInitTemplates();
|
|
225
|
+
const result = new Set();
|
|
226
|
+
for (const template of templates) {
|
|
227
|
+
for (const language of template.languages) {
|
|
228
|
+
result.add(language);
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
resolve([...result]);
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* @param dirPath is the directory to be listed.
|
|
236
|
+
* @returns the list of file or directory names contained in ``dirPath``, excluding any dot-file, and sorted.
|
|
237
|
+
*/
|
|
238
|
+
async function listDirectory(dirPath) {
|
|
239
|
+
return ((await fs.readdir(dirPath))
|
|
240
|
+
.filter((p) => !p.startsWith('.'))
|
|
241
|
+
.filter((p) => !(p === 'LICENSE'))
|
|
242
|
+
// if, for some reason, the temp folder for the hook doesn't get deleted we don't want to display it in this list
|
|
243
|
+
.filter((p) => !(p === INFO_DOT_JSON))
|
|
244
|
+
.sort());
|
|
245
|
+
}
|
|
246
|
+
async function printAvailableTemplates(language) {
|
|
247
|
+
(0, logging_1.info)('Available templates:');
|
|
248
|
+
for (const template of await availableInitTemplates()) {
|
|
249
|
+
if (language && template.languages.indexOf(language) === -1) {
|
|
250
|
+
continue;
|
|
251
|
+
}
|
|
252
|
+
(0, logging_1.info)(`* ${chalk.green(template.name)}: ${template.description}`);
|
|
253
|
+
const languageArg = language
|
|
254
|
+
? chalk.bold(language)
|
|
255
|
+
: template.languages.length > 1
|
|
256
|
+
? `[${template.languages.map((t) => chalk.bold(t)).join('|')}]`
|
|
257
|
+
: chalk.bold(template.languages[0]);
|
|
258
|
+
(0, logging_1.info)(` └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`);
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
async function initializeProject(template, language, canUseNetwork, generateOnly, workDir, stackName, migrate, cdkVersion) {
|
|
262
|
+
await assertIsEmptyDirectory(workDir);
|
|
263
|
+
(0, logging_1.info)(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`);
|
|
264
|
+
await template.install(language, workDir, stackName, cdkVersion);
|
|
265
|
+
if (migrate) {
|
|
266
|
+
await template.addMigrateContext(workDir);
|
|
267
|
+
}
|
|
268
|
+
if (await fs.pathExists(`${workDir}/README.md`)) {
|
|
269
|
+
const readme = await fs.readFile(`${workDir}/README.md`, { encoding: 'utf-8' });
|
|
270
|
+
(0, logging_1.info)(chalk.green(readme));
|
|
271
|
+
}
|
|
272
|
+
if (!generateOnly) {
|
|
273
|
+
await initializeGitRepository(workDir);
|
|
274
|
+
await postInstall(language, canUseNetwork, workDir);
|
|
275
|
+
}
|
|
276
|
+
(0, logging_1.info)('✅ All done!');
|
|
277
|
+
}
|
|
278
|
+
async function assertIsEmptyDirectory(workDir) {
|
|
279
|
+
const files = await fs.readdir(workDir);
|
|
280
|
+
if (files.filter((f) => !f.startsWith('.')).length !== 0) {
|
|
281
|
+
throw new api_1.ToolkitError('`cdk init` cannot be run in a non-empty directory!');
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
async function initializeGitRepository(workDir) {
|
|
285
|
+
if (await isInGitRepository(workDir)) {
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
(0, logging_1.info)('Initializing a new git repository...');
|
|
289
|
+
try {
|
|
290
|
+
await execute('git', ['init'], { cwd: workDir });
|
|
291
|
+
await execute('git', ['add', '.'], { cwd: workDir });
|
|
292
|
+
await execute('git', ['commit', '--message="Initial commit"', '--no-gpg-sign'], { cwd: workDir });
|
|
293
|
+
}
|
|
294
|
+
catch {
|
|
295
|
+
(0, logging_1.warning)('Unable to initialize git repository for your project.');
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
async function postInstall(language, canUseNetwork, workDir) {
|
|
299
|
+
switch (language) {
|
|
300
|
+
case 'javascript':
|
|
301
|
+
return postInstallJavascript(canUseNetwork, workDir);
|
|
302
|
+
case 'typescript':
|
|
303
|
+
return postInstallTypescript(canUseNetwork, workDir);
|
|
304
|
+
case 'java':
|
|
305
|
+
return postInstallJava(canUseNetwork, workDir);
|
|
306
|
+
case 'python':
|
|
307
|
+
return postInstallPython(workDir);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
async function postInstallJavascript(canUseNetwork, cwd) {
|
|
311
|
+
return postInstallTypescript(canUseNetwork, cwd);
|
|
312
|
+
}
|
|
313
|
+
async function postInstallTypescript(canUseNetwork, cwd) {
|
|
314
|
+
const command = 'npm';
|
|
315
|
+
if (!canUseNetwork) {
|
|
316
|
+
(0, logging_1.warning)(`Please run '${command} install'!`);
|
|
317
|
+
return;
|
|
318
|
+
}
|
|
319
|
+
(0, logging_1.info)(`Executing ${chalk.green(`${command} install`)}...`);
|
|
320
|
+
try {
|
|
321
|
+
await execute(command, ['install'], { cwd });
|
|
322
|
+
}
|
|
323
|
+
catch (e) {
|
|
324
|
+
(0, logging_1.warning)(`${command} install failed: ` + (0, util_1.formatErrorMessage)(e));
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
async function postInstallJava(canUseNetwork, cwd) {
|
|
328
|
+
const mvnPackageWarning = "Please run 'mvn package'!";
|
|
329
|
+
if (!canUseNetwork) {
|
|
330
|
+
(0, logging_1.warning)(mvnPackageWarning);
|
|
331
|
+
return;
|
|
332
|
+
}
|
|
333
|
+
(0, logging_1.info)("Executing 'mvn package'");
|
|
334
|
+
try {
|
|
335
|
+
await execute('mvn', ['package'], { cwd });
|
|
336
|
+
}
|
|
337
|
+
catch {
|
|
338
|
+
(0, logging_1.warning)('Unable to package compiled code as JAR');
|
|
339
|
+
(0, logging_1.warning)(mvnPackageWarning);
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
async function postInstallPython(cwd) {
|
|
343
|
+
const python = pythonExecutable();
|
|
344
|
+
(0, logging_1.warning)(`Please run '${python} -m venv .venv'!`);
|
|
345
|
+
(0, logging_1.info)(`Executing ${chalk.green('Creating virtualenv...')}`);
|
|
346
|
+
try {
|
|
347
|
+
await execute(python, ['-m venv', '.venv'], { cwd });
|
|
348
|
+
}
|
|
349
|
+
catch {
|
|
350
|
+
(0, logging_1.warning)('Unable to create virtualenv automatically');
|
|
351
|
+
(0, logging_1.warning)(`Please run '${python} -m venv .venv'!`);
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
/**
|
|
355
|
+
* @param dir a directory to be checked
|
|
356
|
+
* @returns true if ``dir`` is within a git repository.
|
|
357
|
+
*/
|
|
358
|
+
async function isInGitRepository(dir) {
|
|
359
|
+
while (true) {
|
|
360
|
+
if (await fs.pathExists(path.join(dir, '.git'))) {
|
|
361
|
+
return true;
|
|
362
|
+
}
|
|
363
|
+
if (isRoot(dir)) {
|
|
364
|
+
return false;
|
|
365
|
+
}
|
|
366
|
+
dir = path.dirname(dir);
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
/**
|
|
370
|
+
* @param dir a directory to be checked.
|
|
371
|
+
* @returns true if ``dir`` is the root of a filesystem.
|
|
372
|
+
*/
|
|
373
|
+
function isRoot(dir) {
|
|
374
|
+
return path.dirname(dir) === dir;
|
|
375
|
+
}
|
|
376
|
+
/**
|
|
377
|
+
* Executes `command`. STDERR is emitted in real-time.
|
|
378
|
+
*
|
|
379
|
+
* If command exits with non-zero exit code, an exceprion is thrown and includes
|
|
380
|
+
* the contents of STDOUT.
|
|
381
|
+
*
|
|
382
|
+
* @returns STDOUT (if successful).
|
|
383
|
+
*/
|
|
384
|
+
async function execute(cmd, args, { cwd }) {
|
|
385
|
+
const child = childProcess.spawn(cmd, args, {
|
|
386
|
+
cwd,
|
|
387
|
+
shell: true,
|
|
388
|
+
stdio: ['ignore', 'pipe', 'inherit'],
|
|
389
|
+
});
|
|
390
|
+
let stdout = '';
|
|
391
|
+
child.stdout.on('data', (chunk) => (stdout += chunk.toString()));
|
|
392
|
+
return new Promise((ok, fail) => {
|
|
393
|
+
child.once('error', (err) => fail(err));
|
|
394
|
+
child.once('exit', (status) => {
|
|
395
|
+
if (status === 0) {
|
|
396
|
+
return ok(stdout);
|
|
397
|
+
}
|
|
398
|
+
else {
|
|
399
|
+
(0, logging_1.error)(stdout);
|
|
400
|
+
return fail(new api_1.ToolkitError(`${cmd} exited with status ${status}`));
|
|
401
|
+
}
|
|
402
|
+
});
|
|
403
|
+
});
|
|
404
|
+
}
|
|
405
|
+
/**
|
|
406
|
+
* Return the 'aws-cdk-lib' version we will init
|
|
407
|
+
*
|
|
408
|
+
* This has been built into the CLI at build time.
|
|
409
|
+
*/
|
|
410
|
+
async function loadInitVersions() {
|
|
411
|
+
const initVersionFile = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates', '.init-version.json');
|
|
412
|
+
const contents = JSON.parse(await fs.readFile(initVersionFile, { encoding: 'utf-8' }));
|
|
413
|
+
const ret = {
|
|
414
|
+
'aws-cdk-lib': contents['aws-cdk-lib'],
|
|
415
|
+
'constructs': contents.constructs,
|
|
416
|
+
'aws-cdk': (0, version_1.versionNumber)(),
|
|
417
|
+
};
|
|
418
|
+
for (const [key, value] of Object.entries(ret)) {
|
|
419
|
+
/* istanbul ignore next */
|
|
420
|
+
if (!value) {
|
|
421
|
+
throw new api_1.ToolkitError(`Missing init version from ${initVersionFile}: ${key}`);
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
return ret;
|
|
425
|
+
}
|
|
426
|
+
/**
|
|
427
|
+
* Return the currently recommended flags for `aws-cdk-lib`.
|
|
428
|
+
*
|
|
429
|
+
* These have been built into the CLI at build time.
|
|
430
|
+
*/
|
|
431
|
+
async function currentlyRecommendedAwsCdkLibFlags() {
|
|
432
|
+
const recommendedFlagsFile = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates', '.recommended-feature-flags.json');
|
|
433
|
+
return JSON.parse(await fs.readFile(recommendedFlagsFile, { encoding: 'utf-8' }));
|
|
434
|
+
}
|
|
435
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"init.js","sourceRoot":"","sources":["init.ts"],"names":[],"mappings":"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","sourcesContent":["import * as childProcess from 'child_process';\nimport * as path from 'path';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport { invokeBuiltinHooks } from './init-hooks';\nimport { ToolkitError } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api';\nimport { cliRootDir } from '../../cli/root-dir';\nimport { versionNumber } from '../../cli/version';\nimport { error, info, warning } from '../../logging';\nimport { cdkHomeDir, formatErrorMessage, rangeFromSemver } from '../../util';\n\n/* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst camelCase = require('camelcase');\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst decamelize = require('decamelize');\n\nexport interface CliInitOptions {\n  readonly type?: string;\n  readonly language?: string;\n  readonly canUseNetwork?: boolean;\n  readonly generateOnly?: boolean;\n  readonly workDir?: string;\n  readonly stackName?: string;\n  readonly migrate?: boolean;\n\n  /**\n   * Override the built-in CDK version\n   */\n  readonly libVersion?: string;\n}\n\n/**\n * Initialize a CDK package in the current directory\n */\nexport async function cliInit(options: CliInitOptions) {\n  const canUseNetwork = options.canUseNetwork ?? true;\n  const generateOnly = options.generateOnly ?? false;\n  const workDir = options.workDir ?? process.cwd();\n  if (!options.type && !options.language) {\n    await printAvailableTemplates();\n    return;\n  }\n\n  const type = options.type || 'default'; // \"default\" is the default type (and maps to \"app\")\n\n  const template = (await availableInitTemplates()).find((t) => t.hasName(type!));\n  if (!template) {\n    await printAvailableTemplates(options.language);\n    throw new ToolkitError(`Unknown init template: ${type}`);\n  }\n  if (!options.language && template.languages.length === 1) {\n    const language = template.languages[0];\n    warning(\n      `No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`,\n    );\n  }\n  if (!options.language) {\n    info(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);\n    throw new ToolkitError('No language was selected');\n  }\n\n  await initializeProject(\n    template,\n    options.language,\n    canUseNetwork,\n    generateOnly,\n    workDir,\n    options.stackName,\n    options.migrate,\n    options.libVersion,\n  );\n}\n\n/**\n * Returns the name of the Python executable for this OS\n */\nfunction pythonExecutable() {\n  let python = 'python3';\n  if (process.platform === 'win32') {\n    python = 'python';\n  }\n  return python;\n}\nconst INFO_DOT_JSON = 'info.json';\n\nexport class InitTemplate {\n  public static async fromName(templatesDir: string, name: string) {\n    const basePath = path.join(templatesDir, name);\n    const languages = await listDirectory(basePath);\n    const initInfo = await fs.readJson(path.join(basePath, INFO_DOT_JSON));\n    return new InitTemplate(basePath, name, languages, initInfo);\n  }\n\n  public readonly description: string;\n  public readonly aliases = new Set<string>();\n\n  constructor(\n    private readonly basePath: string,\n    public readonly name: string,\n    public readonly languages: string[],\n    initInfo: any,\n  ) {\n    this.description = initInfo.description;\n    for (const alias of initInfo.aliases || []) {\n      this.aliases.add(alias);\n    }\n  }\n\n  /**\n   * @param name the name that is being checked\n   * @returns ``true`` if ``name`` is the name of this template or an alias of it.\n   */\n  public hasName(name: string): boolean {\n    return name === this.name || this.aliases.has(name);\n  }\n\n  /**\n   * Creates a new instance of this ``InitTemplate`` for a given language to a specified folder.\n   *\n   * @param language    the language to instantiate this template with\n   * @param targetDirectory the directory where the template is to be instantiated into\n   */\n  public async install(language: string, targetDirectory: string, stackName?: string, libVersion?: string) {\n    if (this.languages.indexOf(language) === -1) {\n      error(\n        `The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` +\n          `(it supports: ${this.languages.map((l) => chalk.blue(l)).join(', ')})`,\n      );\n      throw new ToolkitError(`Unsupported language: ${language}`);\n    }\n\n    const projectInfo: ProjectInfo = {\n      name: decamelize(path.basename(path.resolve(targetDirectory))),\n      stackName,\n      versions: await loadInitVersions(),\n    };\n\n    if (libVersion) {\n      projectInfo.versions['aws-cdk-lib'] = libVersion;\n    }\n\n    const sourceDirectory = path.join(this.basePath, language);\n\n    await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);\n    await this.applyFutureFlags(targetDirectory);\n    await invokeBuiltinHooks(\n      { targetDirectory, language, templateName: this.name },\n      {\n        substitutePlaceholdersIn: async (...fileNames: string[]) => {\n          for (const fileName of fileNames) {\n            const fullPath = path.join(targetDirectory, fileName);\n            const template = await fs.readFile(fullPath, { encoding: 'utf-8' });\n            await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo));\n          }\n        },\n        placeholder: (ph: string) => expandPlaceholders(`%${ph}%`, language, projectInfo),\n      },\n    );\n  }\n\n  private async installFiles(sourceDirectory: string, targetDirectory: string, language: string, project: ProjectInfo) {\n    for (const file of await fs.readdir(sourceDirectory)) {\n      const fromFile = path.join(sourceDirectory, file);\n      const toFile = path.join(targetDirectory, expandPlaceholders(file, language, project));\n      if ((await fs.stat(fromFile)).isDirectory()) {\n        await fs.mkdir(toFile);\n        await this.installFiles(fromFile, toFile, language, project);\n        continue;\n      } else if (file.match(/^.*\\.template\\.[^.]+$/)) {\n        await this.installProcessed(fromFile, toFile.replace(/\\.template(\\.[^.]+)$/, '$1'), language, project);\n        continue;\n      } else if (file.match(/^.*\\.hook\\.(d.)?[^.]+$/)) {\n        // Ignore\n        continue;\n      } else {\n        await fs.copy(fromFile, toFile);\n      }\n    }\n  }\n\n  private async installProcessed(templatePath: string, toFile: string, language: string, project: ProjectInfo) {\n    const template = await fs.readFile(templatePath, { encoding: 'utf-8' });\n    await fs.writeFile(toFile, expandPlaceholders(template, language, project));\n  }\n\n  /**\n   * Adds context variables to `cdk.json` in the generated project directory to\n   * enable future behavior for new projects.\n   */\n  private async applyFutureFlags(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      ...await currentlyRecommendedAwsCdkLibFlags(),\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n\n  public async addMigrateContext(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      'cdk-migrate': true,\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n}\n\nexport function expandPlaceholders(template: string, language: string, project: ProjectInfo) {\n  const cdkVersion = project.versions['aws-cdk-lib'];\n  const cdkCliVersion = project.versions['aws-cdk'];\n  let constructsVersion = project.versions.constructs;\n\n  switch (language) {\n    case 'java':\n    case 'csharp':\n    case 'fsharp':\n      constructsVersion = rangeFromSemver(constructsVersion, 'bracket');\n      break;\n    case 'python':\n      constructsVersion = rangeFromSemver(constructsVersion, 'pep');\n      break;\n  }\n  return template\n    .replace(/%name%/g, project.name)\n    .replace(/%stackname%/, project.stackName ?? '%name.PascalCased%Stack')\n    .replace(\n      /%PascalNameSpace%/,\n      project.stackName ? camelCase(project.stackName + 'Stack', { pascalCase: true }) : '%name.PascalCased%',\n    )\n    .replace(\n      /%PascalStackProps%/,\n      project.stackName ? camelCase(project.stackName, { pascalCase: true }) + 'StackProps' : 'StackProps',\n    )\n    .replace(/%name\\.camelCased%/g, camelCase(project.name))\n    .replace(/%name\\.PascalCased%/g, camelCase(project.name, { pascalCase: true }))\n    .replace(/%cdk-version%/g, cdkVersion)\n    .replace(/%cdk-cli-version%/g, cdkCliVersion)\n    .replace(/%constructs-version%/g, constructsVersion)\n    .replace(/%cdk-home%/g, cdkHomeDir())\n    .replace(/%name\\.PythonModule%/g, project.name.replace(/-/g, '_'))\n    .replace(/%python-executable%/g, pythonExecutable())\n    .replace(/%name\\.StackName%/g, project.name.replace(/[^A-Za-z0-9-]/g, '-'));\n}\n\ninterface ProjectInfo {\n  /** The value used for %name% */\n  readonly name: string;\n  readonly stackName?: string;\n\n  readonly versions: Versions;\n}\n\nexport async function availableInitTemplates(): Promise<InitTemplate[]> {\n  return new Promise(async (resolve) => {\n    try {\n      const templatesDir = path.join(cliRootDir(), 'lib', 'init-templates');\n      const templateNames = await listDirectory(templatesDir);\n      const templates = new Array<InitTemplate>();\n      for (const templateName of templateNames) {\n        templates.push(await InitTemplate.fromName(templatesDir, templateName));\n      }\n      resolve(templates);\n    } catch {\n      resolve([]);\n    }\n  });\n}\n\nexport async function availableInitLanguages(): Promise<string[]> {\n  return new Promise(async (resolve) => {\n    const templates = await availableInitTemplates();\n    const result = new Set<string>();\n    for (const template of templates) {\n      for (const language of template.languages) {\n        result.add(language);\n      }\n    }\n    resolve([...result]);\n  });\n}\n\n/**\n * @param dirPath is the directory to be listed.\n * @returns the list of file or directory names contained in ``dirPath``, excluding any dot-file, and sorted.\n */\nasync function listDirectory(dirPath: string) {\n  return (\n    (await fs.readdir(dirPath))\n      .filter((p) => !p.startsWith('.'))\n      .filter((p) => !(p === 'LICENSE'))\n      // if, for some reason, the temp folder for the hook doesn't get deleted we don't want to display it in this list\n      .filter((p) => !(p === INFO_DOT_JSON))\n      .sort()\n  );\n}\n\nexport async function printAvailableTemplates(language?: string) {\n  info('Available templates:');\n  for (const template of await availableInitTemplates()) {\n    if (language && template.languages.indexOf(language) === -1) {\n      continue;\n    }\n    info(`* ${chalk.green(template.name)}: ${template.description}`);\n    const languageArg = language\n      ? chalk.bold(language)\n      : template.languages.length > 1\n        ? `[${template.languages.map((t) => chalk.bold(t)).join('|')}]`\n        : chalk.bold(template.languages[0]);\n    info(`   └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`);\n  }\n}\n\nasync function initializeProject(\n  template: InitTemplate,\n  language: string,\n  canUseNetwork: boolean,\n  generateOnly: boolean,\n  workDir: string,\n  stackName?: string,\n  migrate?: boolean,\n  cdkVersion?: string,\n) {\n  await assertIsEmptyDirectory(workDir);\n  info(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`);\n  await template.install(language, workDir, stackName, cdkVersion);\n  if (migrate) {\n    await template.addMigrateContext(workDir);\n  }\n  if (await fs.pathExists(`${workDir}/README.md`)) {\n    const readme = await fs.readFile(`${workDir}/README.md`, { encoding: 'utf-8' });\n    info(chalk.green(readme));\n  }\n\n  if (!generateOnly) {\n    await initializeGitRepository(workDir);\n    await postInstall(language, canUseNetwork, workDir);\n  }\n\n  info('✅ All done!');\n}\n\nasync function assertIsEmptyDirectory(workDir: string) {\n  const files = await fs.readdir(workDir);\n  if (files.filter((f) => !f.startsWith('.')).length !== 0) {\n    throw new ToolkitError('`cdk init` cannot be run in a non-empty directory!');\n  }\n}\n\nasync function initializeGitRepository(workDir: string) {\n  if (await isInGitRepository(workDir)) {\n    return;\n  }\n  info('Initializing a new git repository...');\n  try {\n    await execute('git', ['init'], { cwd: workDir });\n    await execute('git', ['add', '.'], { cwd: workDir });\n    await execute('git', ['commit', '--message=\"Initial commit\"', '--no-gpg-sign'], { cwd: workDir });\n  } catch {\n    warning('Unable to initialize git repository for your project.');\n  }\n}\n\nasync function postInstall(language: string, canUseNetwork: boolean, workDir: string) {\n  switch (language) {\n    case 'javascript':\n      return postInstallJavascript(canUseNetwork, workDir);\n    case 'typescript':\n      return postInstallTypescript(canUseNetwork, workDir);\n    case 'java':\n      return postInstallJava(canUseNetwork, workDir);\n    case 'python':\n      return postInstallPython(workDir);\n  }\n}\n\nasync function postInstallJavascript(canUseNetwork: boolean, cwd: string) {\n  return postInstallTypescript(canUseNetwork, cwd);\n}\n\nasync function postInstallTypescript(canUseNetwork: boolean, cwd: string) {\n  const command = 'npm';\n\n  if (!canUseNetwork) {\n    warning(`Please run '${command} install'!`);\n    return;\n  }\n\n  info(`Executing ${chalk.green(`${command} install`)}...`);\n  try {\n    await execute(command, ['install'], { cwd });\n  } catch (e: any) {\n    warning(`${command} install failed: ` + formatErrorMessage(e));\n  }\n}\n\nasync function postInstallJava(canUseNetwork: boolean, cwd: string) {\n  const mvnPackageWarning = \"Please run 'mvn package'!\";\n  if (!canUseNetwork) {\n    warning(mvnPackageWarning);\n    return;\n  }\n\n  info(\"Executing 'mvn package'\");\n  try {\n    await execute('mvn', ['package'], { cwd });\n  } catch {\n    warning('Unable to package compiled code as JAR');\n    warning(mvnPackageWarning);\n  }\n}\n\nasync function postInstallPython(cwd: string) {\n  const python = pythonExecutable();\n  warning(`Please run '${python} -m venv .venv'!`);\n  info(`Executing ${chalk.green('Creating virtualenv...')}`);\n  try {\n    await execute(python, ['-m venv', '.venv'], { cwd });\n  } catch {\n    warning('Unable to create virtualenv automatically');\n    warning(`Please run '${python} -m venv .venv'!`);\n  }\n}\n\n/**\n * @param dir a directory to be checked\n * @returns true if ``dir`` is within a git repository.\n */\nasync function isInGitRepository(dir: string) {\n  while (true) {\n    if (await fs.pathExists(path.join(dir, '.git'))) {\n      return true;\n    }\n    if (isRoot(dir)) {\n      return false;\n    }\n    dir = path.dirname(dir);\n  }\n}\n\n/**\n * @param dir a directory to be checked.\n * @returns true if ``dir`` is the root of a filesystem.\n */\nfunction isRoot(dir: string) {\n  return path.dirname(dir) === dir;\n}\n\n/**\n * Executes `command`. STDERR is emitted in real-time.\n *\n * If command exits with non-zero exit code, an exceprion is thrown and includes\n * the contents of STDOUT.\n *\n * @returns STDOUT (if successful).\n */\nasync function execute(cmd: string, args: string[], { cwd }: { cwd: string }) {\n  const child = childProcess.spawn(cmd, args, {\n    cwd,\n    shell: true,\n    stdio: ['ignore', 'pipe', 'inherit'],\n  });\n  let stdout = '';\n  child.stdout.on('data', (chunk) => (stdout += chunk.toString()));\n  return new Promise<string>((ok, fail) => {\n    child.once('error', (err) => fail(err));\n    child.once('exit', (status) => {\n      if (status === 0) {\n        return ok(stdout);\n      } else {\n        error(stdout);\n        return fail(new ToolkitError(`${cmd} exited with status ${status}`));\n      }\n    });\n  });\n}\n\ninterface Versions {\n  ['aws-cdk']: string;\n  ['aws-cdk-lib']: string;\n  constructs: string;\n}\n\n/**\n * Return the 'aws-cdk-lib' version we will init\n *\n * This has been built into the CLI at build time.\n */\nasync function loadInitVersions(): Promise<Versions> {\n  const initVersionFile = path.join(cliRootDir(), 'lib', 'init-templates', '.init-version.json');\n  const contents = JSON.parse(await fs.readFile(initVersionFile, { encoding: 'utf-8' }));\n\n  const ret = {\n    'aws-cdk-lib': contents['aws-cdk-lib'],\n    'constructs': contents.constructs,\n    'aws-cdk': versionNumber(),\n  };\n  for (const [key, value] of Object.entries(ret)) {\n    /* istanbul ignore next */\n    if (!value) {\n      throw new ToolkitError(`Missing init version from ${initVersionFile}: ${key}`);\n    }\n  }\n\n  return ret;\n}\n\n/**\n * Return the currently recommended flags for `aws-cdk-lib`.\n *\n * These have been built into the CLI at build time.\n */\nexport async function currentlyRecommendedAwsCdkLibFlags() {\n  const recommendedFlagsFile = path.join(cliRootDir(), 'lib', 'init-templates', '.recommended-feature-flags.json');\n  return JSON.parse(await fs.readFile(recommendedFlagsFile, { encoding: 'utf-8' }));\n}\n"]}
|