@cdktn/cli-core 0.22.0-pre.2

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 (154) hide show
  1. package/README.md +3 -0
  2. package/ambient.d.ts +13 -0
  3. package/eslint.config.mjs +82 -0
  4. package/jest.config.js +20 -0
  5. package/package.json +139 -0
  6. package/src/lib/cdktf-config.d.ts +16 -0
  7. package/src/lib/cdktf-config.d.ts.map +1 -0
  8. package/src/lib/cdktf-config.js +108 -0
  9. package/src/lib/cdktf-project-io-handler.d.ts +20 -0
  10. package/src/lib/cdktf-project-io-handler.d.ts.map +1 -0
  11. package/src/lib/cdktf-project-io-handler.js +84 -0
  12. package/src/lib/cdktf-project.d.ts +111 -0
  13. package/src/lib/cdktf-project.d.ts.map +1 -0
  14. package/src/lib/cdktf-project.js +371 -0
  15. package/src/lib/cdktf-stack.d.ts +134 -0
  16. package/src/lib/cdktf-stack.d.ts.map +1 -0
  17. package/src/lib/cdktf-stack.js +386 -0
  18. package/src/lib/convert.d.ts +6 -0
  19. package/src/lib/convert.d.ts.map +1 -0
  20. package/src/lib/convert.js +51 -0
  21. package/src/lib/dependencies/cdktf-config-manager.d.ts +12 -0
  22. package/src/lib/dependencies/cdktf-config-manager.d.ts.map +1 -0
  23. package/src/lib/dependencies/cdktf-config-manager.js +36 -0
  24. package/src/lib/dependencies/dependency-manager.d.ts +84 -0
  25. package/src/lib/dependencies/dependency-manager.d.ts.map +1 -0
  26. package/src/lib/dependencies/dependency-manager.js +365 -0
  27. package/src/lib/dependencies/package-manager.d.ts +18 -0
  28. package/src/lib/dependencies/package-manager.d.ts.map +1 -0
  29. package/src/lib/dependencies/package-manager.js +574 -0
  30. package/src/lib/dependencies/prebuilt-providers.d.ts +18 -0
  31. package/src/lib/dependencies/prebuilt-providers.d.ts.map +1 -0
  32. package/src/lib/dependencies/prebuilt-providers.js +204 -0
  33. package/src/lib/dependencies/registry-api.d.ts +8 -0
  34. package/src/lib/dependencies/registry-api.d.ts.map +1 -0
  35. package/src/lib/dependencies/registry-api.js +77 -0
  36. package/src/lib/dependencies/version-constraints.d.ts +8 -0
  37. package/src/lib/dependencies/version-constraints.d.ts.map +1 -0
  38. package/src/lib/dependencies/version-constraints.js +95 -0
  39. package/src/lib/error-reporting.d.ts +10 -0
  40. package/src/lib/error-reporting.d.ts.map +1 -0
  41. package/src/lib/error-reporting.js +133 -0
  42. package/src/lib/errors.d.ts +6 -0
  43. package/src/lib/errors.d.ts.map +1 -0
  44. package/src/lib/errors.js +10 -0
  45. package/src/lib/execution-logs.d.ts +3 -0
  46. package/src/lib/execution-logs.d.ts.map +1 -0
  47. package/src/lib/execution-logs.js +47 -0
  48. package/src/lib/get.d.ts +25 -0
  49. package/src/lib/get.d.ts.map +1 -0
  50. package/src/lib/get.js +90 -0
  51. package/src/lib/helpers/stack-helpers.d.ts +16 -0
  52. package/src/lib/helpers/stack-helpers.d.ts.map +1 -0
  53. package/src/lib/helpers/stack-helpers.js +155 -0
  54. package/src/lib/index.d.ts +15 -0
  55. package/src/lib/index.d.ts.map +1 -0
  56. package/src/lib/index.js +44 -0
  57. package/src/lib/init.d.ts +37 -0
  58. package/src/lib/init.d.ts.map +1 -0
  59. package/src/lib/init.js +131 -0
  60. package/src/lib/local-provider-constraints.d.ts +28 -0
  61. package/src/lib/local-provider-constraints.d.ts.map +1 -0
  62. package/src/lib/local-provider-constraints.js +95 -0
  63. package/src/lib/local-provider-versions.d.ts +12 -0
  64. package/src/lib/local-provider-versions.d.ts.map +1 -0
  65. package/src/lib/local-provider-versions.js +73 -0
  66. package/src/lib/models/deploy-machine.d.ts +128 -0
  67. package/src/lib/models/deploy-machine.d.ts.map +1 -0
  68. package/src/lib/models/deploy-machine.js +280 -0
  69. package/src/lib/models/pty-process.d.ts +29 -0
  70. package/src/lib/models/pty-process.d.ts.map +1 -0
  71. package/src/lib/models/pty-process.js +132 -0
  72. package/src/lib/models/schema.d.ts +2307 -0
  73. package/src/lib/models/schema.d.ts.map +1 -0
  74. package/src/lib/models/schema.js +181 -0
  75. package/src/lib/models/terraform-cli.d.ts +72 -0
  76. package/src/lib/models/terraform-cli.d.ts.map +1 -0
  77. package/src/lib/models/terraform-cli.js +357 -0
  78. package/src/lib/models/terraform.d.ts +125 -0
  79. package/src/lib/models/terraform.d.ts.map +1 -0
  80. package/src/lib/models/terraform.js +72 -0
  81. package/src/lib/output.d.ts +23 -0
  82. package/src/lib/output.d.ts.map +1 -0
  83. package/src/lib/output.js +211 -0
  84. package/src/lib/provider-add.d.ts +15 -0
  85. package/src/lib/provider-add.d.ts.map +1 -0
  86. package/src/lib/provider-add.js +30 -0
  87. package/src/lib/server/terraform-logs.d.ts +2 -0
  88. package/src/lib/server/terraform-logs.d.ts.map +1 -0
  89. package/src/lib/server/terraform-logs.js +19 -0
  90. package/src/lib/synth-stack.d.ts +29 -0
  91. package/src/lib/synth-stack.d.ts.map +1 -0
  92. package/src/lib/synth-stack.js +251 -0
  93. package/src/lib/synth.d.ts +7 -0
  94. package/src/lib/synth.d.ts.map +1 -0
  95. package/src/lib/synth.js +67 -0
  96. package/src/lib/terraform-json.d.ts +1015 -0
  97. package/src/lib/terraform-json.d.ts.map +1 -0
  98. package/src/lib/terraform-json.js +82 -0
  99. package/src/lib/terraform-provider-lock.d.ts +25 -0
  100. package/src/lib/terraform-provider-lock.d.ts.map +1 -0
  101. package/src/lib/terraform-provider-lock.js +95 -0
  102. package/src/lib/watch.d.ts +16 -0
  103. package/src/lib/watch.d.ts.map +1 -0
  104. package/src/lib/watch.js +155 -0
  105. package/templates/csharp/.hooks.sscaff.js +63 -0
  106. package/templates/csharp/MainStack.cs +15 -0
  107. package/templates/csharp/MyTerraformStack.csproj +13 -0
  108. package/templates/csharp/Program.cs +17 -0
  109. package/templates/csharp/TestProgram.cs +42 -0
  110. package/templates/csharp/cdktf.json +11 -0
  111. package/templates/csharp/help +42 -0
  112. package/templates/csharp/{{}}.gitignore +345 -0
  113. package/templates/go/.hooks.sscaff.js +70 -0
  114. package/templates/go/cdktf.json +12 -0
  115. package/templates/go/go.mod +8 -0
  116. package/templates/go/help +32 -0
  117. package/templates/go/main.go +22 -0
  118. package/templates/go/main_test.go +42 -0
  119. package/templates/go/{{}}.gitignore +21 -0
  120. package/templates/java/.hooks.sscaff.js +64 -0
  121. package/templates/java/build.gradle +55 -0
  122. package/templates/java/cdktf.json +12 -0
  123. package/templates/java/gradle.properties +1 -0
  124. package/templates/java/gradlew +248 -0
  125. package/templates/java/gradlew.bat +92 -0
  126. package/templates/java/help +35 -0
  127. package/templates/java/settings.gradle +5 -0
  128. package/templates/java/src/main/java/com/mycompany/app/Main.java +16 -0
  129. package/templates/java/src/main/java/com/mycompany/app/MainStack.java +14 -0
  130. package/templates/java/src/test/java/com/company/app/MainTest.java +38 -0
  131. package/templates/java/{{}}.gitignore +14 -0
  132. package/templates/python/.hooks.sscaff.js +59 -0
  133. package/templates/python/Pipfile +7 -0
  134. package/templates/python/cdktf.json +12 -0
  135. package/templates/python/help +42 -0
  136. package/templates/python/main-test.py +26 -0
  137. package/templates/python/main.py +16 -0
  138. package/templates/python/{{}}.gitignore +7 -0
  139. package/templates/python-pip/.hooks.sscaff.js +63 -0
  140. package/templates/python-pip/cdktf.json +12 -0
  141. package/templates/python-pip/help +35 -0
  142. package/templates/python-pip/main-test.py +23 -0
  143. package/templates/python-pip/main.py +16 -0
  144. package/templates/python-pip/{{}}.gitignore +7 -0
  145. package/templates/typescript/.hooks.sscaff.js +78 -0
  146. package/templates/typescript/__tests__/main-test.ts +89 -0
  147. package/templates/typescript/cdktf.json +11 -0
  148. package/templates/typescript/help +51 -0
  149. package/templates/typescript/jest.config.js +187 -0
  150. package/templates/typescript/main.ts +14 -0
  151. package/templates/typescript/package.json +22 -0
  152. package/templates/typescript/setup.js +2 -0
  153. package/templates/typescript/tsconfig.json +35 -0
  154. package/templates/typescript/{{}}.gitignore +11 -0
@@ -0,0 +1,133 @@
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.captureException = exports.initializErrorReporting = exports.persistReportCrashReportDecision = exports.shouldReportCrash = void 0;
30
+ // Copyright (c) HashiCorp, Inc
31
+ // SPDX-License-Identifier: MPL-2.0
32
+ const Sentry = __importStar(require("@sentry/node"));
33
+ const commons_1 = require("@cdktn/commons");
34
+ const commons_2 = require("@cdktn/commons");
35
+ const path = __importStar(require("path"));
36
+ const fs = __importStar(require("fs-extra"));
37
+ const ci_info_1 = __importDefault(require("ci-info"));
38
+ function shouldReportCrash(projectPath = process.cwd()) {
39
+ try {
40
+ const cdktfJson = JSON.parse(fs.readFileSync(path.resolve(projectPath, "cdktf.json"), "utf8"));
41
+ return typeof cdktfJson.sendCrashReports === "boolean"
42
+ ? cdktfJson.sendCrashReports
43
+ : cdktfJson.sendCrashReports === "true";
44
+ }
45
+ catch (e) {
46
+ commons_2.logger.debug(`Error determining if crash reporting should be enabled, defaulting to false: ${e}`);
47
+ return false;
48
+ }
49
+ }
50
+ exports.shouldReportCrash = shouldReportCrash;
51
+ function persistReportCrashReportDecision(decision, projectPath = process.cwd()) {
52
+ const cdktfJson = JSON.parse(fs.readFileSync(path.resolve(projectPath, "cdktf.json"), "utf8"));
53
+ cdktfJson.sendCrashReports = decision;
54
+ fs.writeFileSync(path.resolve(projectPath, "cdktf.json"), JSON.stringify(cdktfJson, null, 2));
55
+ }
56
+ exports.persistReportCrashReportDecision = persistReportCrashReportDecision;
57
+ function isPromise(p) {
58
+ return (typeof p === "object" &&
59
+ typeof p.then === "function" &&
60
+ typeof p.catch === "function");
61
+ }
62
+ async function initializErrorReporting(runConsentPrompt) {
63
+ let shouldReport = shouldReportCrash();
64
+ const ci = ci_info_1.default.isCI ? ci_info_1.default.name || "unknown" : false;
65
+ // We have no info yet, so we need to ask the user
66
+ if (shouldReport === undefined && runConsentPrompt) {
67
+ // But only if it's a user
68
+ if (ci) {
69
+ return;
70
+ }
71
+ shouldReport = await runConsentPrompt();
72
+ persistReportCrashReportDecision(shouldReport);
73
+ }
74
+ if (!shouldReport) {
75
+ commons_2.logger.debug("Error reporting disabled");
76
+ return;
77
+ }
78
+ if (!process.env.SENTRY_DSN) {
79
+ commons_2.logger.info("Error reporting disabled: SENTRY_DSN not set");
80
+ return;
81
+ }
82
+ commons_2.logger.debug("Initializing error reporting");
83
+ Sentry.init({
84
+ autoSessionTracking: true,
85
+ dsn: process.env.SENTRY_DSN,
86
+ release: `cdktn-cli-${commons_1.DISPLAY_VERSION}`,
87
+ async beforeSend(event, hint) {
88
+ if (!hint) {
89
+ return event;
90
+ }
91
+ // The promise character is not documented, but it happens
92
+ const originalException = hint.originalException;
93
+ let error;
94
+ if (isPromise(originalException)) {
95
+ originalException.catch((e) => (error = e));
96
+ await Promise.allSettled([originalException]);
97
+ }
98
+ else {
99
+ error = originalException;
100
+ }
101
+ const errorMessage = (error === null || error === void 0 ? void 0 : error.toString()) || "";
102
+ if (errorMessage.includes("Usage Error")) {
103
+ // This is a usage error, so we don't want to report it
104
+ return null;
105
+ }
106
+ return event;
107
+ },
108
+ });
109
+ Sentry.configureScope(function (scope) {
110
+ scope.setUser({
111
+ id: (0, commons_1.getUserId)(),
112
+ });
113
+ scope.setTag("projectId", (0, commons_1.getProjectId)());
114
+ });
115
+ commons_2.logger.debug("Collecting environment information for error reporting");
116
+ (0, commons_1.collectDebugInformation)().then((debugOutput) => {
117
+ Sentry.setContext("environment", debugOutput);
118
+ });
119
+ }
120
+ exports.initializErrorReporting = initializErrorReporting;
121
+ function captureException({ message, type, command, context, }) {
122
+ if (process.env.SENTRY_DSN && shouldReportCrash()) {
123
+ Sentry.captureException(new Error(message), {
124
+ tags: {
125
+ context: JSON.stringify(context),
126
+ type,
127
+ command,
128
+ },
129
+ });
130
+ }
131
+ }
132
+ exports.captureException = captureException;
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error-reporting.js","sourceRoot":"","sources":["error-reporting.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport * as Sentry from \"@sentry/node\";\nimport {\n  getProjectId,\n  getUserId,\n  collectDebugInformation,\n  DISPLAY_VERSION,\n} from \"@cdktn/commons\";\nimport { logger } from \"@cdktn/commons\";\nimport * as path from \"path\";\nimport * as fs from \"fs-extra\";\nimport ciInfo from \"ci-info\";\n\nexport function shouldReportCrash(\n  projectPath = process.cwd(),\n): boolean | undefined {\n  try {\n    const cdktfJson = JSON.parse(\n      fs.readFileSync(path.resolve(projectPath, \"cdktf.json\"), \"utf8\"),\n    );\n\n    return typeof cdktfJson.sendCrashReports === \"boolean\"\n      ? cdktfJson.sendCrashReports\n      : cdktfJson.sendCrashReports === \"true\";\n  } catch (e) {\n    logger.debug(\n      `Error determining if crash reporting should be enabled, defaulting to false: ${e}`,\n    );\n    return false;\n  }\n}\n\nexport function persistReportCrashReportDecision(\n  decision: boolean,\n  projectPath = process.cwd(),\n) {\n  const cdktfJson = JSON.parse(\n    fs.readFileSync(path.resolve(projectPath, \"cdktf.json\"), \"utf8\"),\n  );\n  cdktfJson.sendCrashReports = decision;\n  fs.writeFileSync(\n    path.resolve(projectPath, \"cdktf.json\"),\n    JSON.stringify(cdktfJson, null, 2),\n  );\n}\n\nfunction isPromise(p: any): p is Promise<any> {\n  return (\n    typeof p === \"object\" &&\n    typeof p.then === \"function\" &&\n    typeof p.catch === \"function\"\n  );\n}\n\nexport async function initializErrorReporting(\n  runConsentPrompt?: () => Promise<boolean>,\n) {\n  let shouldReport = shouldReportCrash();\n  const ci: string | false = ciInfo.isCI ? ciInfo.name || \"unknown\" : false;\n\n  // We have no info yet, so we need to ask the user\n  if (shouldReport === undefined && runConsentPrompt) {\n    // But only if it's a user\n    if (ci) {\n      return;\n    }\n\n    shouldReport = await runConsentPrompt();\n    persistReportCrashReportDecision(shouldReport);\n  }\n\n  if (!shouldReport) {\n    logger.debug(\"Error reporting disabled\");\n    return;\n  }\n  if (!process.env.SENTRY_DSN) {\n    logger.info(\"Error reporting disabled: SENTRY_DSN not set\");\n    return;\n  }\n\n  logger.debug(\"Initializing error reporting\");\n\n  Sentry.init({\n    autoSessionTracking: true,\n    dsn: process.env.SENTRY_DSN,\n    release: `cdktn-cli-${DISPLAY_VERSION}`,\n    async beforeSend(event, hint) {\n      if (!hint) {\n        return event;\n      }\n\n      // The promise character is not documented, but it happens\n      const originalException:\n        | Promise<Error>\n        | Error\n        | string\n        | null\n        | undefined\n        | unknown = hint.originalException;\n      let error: Error | string | null | undefined | unknown;\n      if (isPromise(originalException)) {\n        (originalException as unknown as Promise<Error>).catch(\n          (e) => (error = e),\n        );\n        await Promise.allSettled([originalException]);\n      } else {\n        error = originalException;\n      }\n\n      const errorMessage = error?.toString() || \"\";\n      if (errorMessage.includes(\"Usage Error\")) {\n        // This is a usage error, so we don't want to report it\n        return null;\n      }\n      return event;\n    },\n  });\n\n  Sentry.configureScope(function (scope) {\n    scope.setUser({\n      id: getUserId(),\n    });\n    scope.setTag(\"projectId\", getProjectId());\n  });\n\n  logger.debug(\"Collecting environment information for error reporting\");\n  collectDebugInformation().then((debugOutput) => {\n    Sentry.setContext(\"environment\", debugOutput);\n  });\n}\n\nexport function captureException({\n  message,\n  type,\n  command,\n  context,\n}: {\n  message: string;\n  type: string;\n  command: string;\n  context?: Record<string, any>;\n}) {\n  if (process.env.SENTRY_DSN && shouldReportCrash()) {\n    Sentry.captureException(new Error(message), {\n      tags: {\n        context: JSON.stringify(context),\n        type,\n        command,\n      },\n    });\n  }\n}\n"]}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Copyright (c) HashiCorp, Inc.
3
+ * SPDX-License-Identifier: MPL-2.0
4
+ */
5
+ export declare const missingVariable: (variableName: string) => string;
6
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["errors.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,eAAO,MAAM,eAAe,iBAAkB,MAAM,WACgE,CAAC"}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) HashiCorp, Inc.
4
+ * SPDX-License-Identifier: MPL-2.0
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.missingVariable = void 0;
8
+ const missingVariable = (variableName) => `Missing variable: '${variableName}'. You can provide it using the 'TF_VAR_${variableName}' environment variable.`;
9
+ exports.missingVariable = missingVariable;
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXJyb3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0c7OztBQUVJLE1BQU0sZUFBZSxHQUFHLENBQUMsWUFBb0IsRUFBRSxFQUFFLENBQ3RELHNCQUFzQixZQUFZLDJDQUEyQyxZQUFZLHlCQUF5QixDQUFDO0FBRHhHLFFBQUEsZUFBZSxtQkFDeUYiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgSGFzaGlDb3JwLCBJbmMuXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTVBMLTIuMFxuICovXG5cbmV4cG9ydCBjb25zdCBtaXNzaW5nVmFyaWFibGUgPSAodmFyaWFibGVOYW1lOiBzdHJpbmcpID0+XG4gIGBNaXNzaW5nIHZhcmlhYmxlOiAnJHt2YXJpYWJsZU5hbWV9Jy4gWW91IGNhbiBwcm92aWRlIGl0IHVzaW5nIHRoZSAnVEZfVkFSXyR7dmFyaWFibGVOYW1lfScgZW52aXJvbm1lbnQgdmFyaWFibGUuYDtcbiJdfQ==
@@ -0,0 +1,3 @@
1
+ import { SynthesizedStack } from "./synth-stack";
2
+ export declare function createEnhanceLogMessage(stack: SynthesizedStack): (message: string) => string | undefined;
3
+ //# sourceMappingURL=execution-logs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execution-logs.d.ts","sourceRoot":"","sources":["execution-logs.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AA2BjD,wBAAgB,uBAAuB,CACrC,KAAK,EAAE,gBAAgB,GACtB,CAAC,OAAO,EAAE,MAAM,KAAK,MAAM,GAAG,SAAS,CA6CzC"}
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createEnhanceLogMessage = void 0;
4
+ // Copyright (c) HashiCorp, Inc
5
+ // SPDX-License-Identifier: MPL-2.0
6
+ const commons_1 = require("@cdktn/commons");
7
+ // escapes any special charaters used in regex
8
+ const escapeRegexSpecialChars = (str) => str.replace(/[-/\\^$*+?.()|[\]{}]/g, "\\$&");
9
+ // uses word boundary to match the whole of the tfIdentifer
10
+ const lineHasExactMatch = (line, tfIdentifier) => new RegExp(`\\b${escapeRegexSpecialChars(tfIdentifier)}\\b`).test(line);
11
+ function createEnhanceLogMessage(stack) {
12
+ // we never want to throw, if it does not work we just do as if it did not happen
13
+ const pathMapping = {};
14
+ try {
15
+ const json = JSON.parse(stack.content);
16
+ ["data", "resource"].forEach((type) => {
17
+ Object.entries(json[type] || {}).forEach(([resourceType, resourceInstances]) => {
18
+ Object.entries(resourceInstances || {}).forEach(([resourceName, resource]) => {
19
+ // Some constructs don't have this metadata
20
+ if (resource["//"] &&
21
+ resource["//"].metadata &&
22
+ resource["//"].metadata.path) {
23
+ pathMapping[`${resourceType}.${resourceName}`] = resource["//"].metadata.path.replace(`${stack.name}/`, "");
24
+ }
25
+ });
26
+ });
27
+ });
28
+ }
29
+ catch (e) {
30
+ commons_1.logger.debug(`Could not enhance log message: ${e}`);
31
+ }
32
+ return (message) => {
33
+ return message
34
+ .split("\n")
35
+ .map((line) => {
36
+ const matchingEntry = Object.entries(pathMapping).find(([tfIdentifier]) => lineHasExactMatch(line, tfIdentifier));
37
+ if (!matchingEntry) {
38
+ return line;
39
+ }
40
+ const [id, cdkPath] = matchingEntry;
41
+ return line.replace(id, `${id} (${cdkPath})`);
42
+ })
43
+ .join("\n");
44
+ };
45
+ }
46
+ exports.createEnhanceLogMessage = createEnhanceLogMessage;
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWxvZ3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJleGVjdXRpb24tbG9ncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrQkFBK0I7QUFDL0IsbUNBQW1DO0FBQ25DLDRDQUF3QztBQW9CeEMsOENBQThDO0FBQzlDLE1BQU0sdUJBQXVCLEdBQUcsQ0FBQyxHQUFXLEVBQUUsRUFBRSxDQUM5QyxHQUFHLENBQUMsT0FBTyxDQUFDLHVCQUF1QixFQUFFLE1BQU0sQ0FBQyxDQUFDO0FBRS9DLDJEQUEyRDtBQUMzRCxNQUFNLGlCQUFpQixHQUFHLENBQUMsSUFBWSxFQUFFLFlBQW9CLEVBQUUsRUFBRSxDQUMvRCxJQUFJLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7QUFFMUUsU0FBZ0IsdUJBQXVCLENBQ3JDLEtBQXVCO0lBRXZCLGlGQUFpRjtJQUNqRixNQUFNLFdBQVcsR0FBNEMsRUFBRSxDQUFDO0lBQ2hFLElBQUksQ0FBQztRQUNILE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBVyxDQUFDO1FBRWpELENBQUMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ3BDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQTJCLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQzdELENBQUMsQ0FBQyxZQUFZLEVBQUUsaUJBQWlCLENBQUMsRUFBRSxFQUFFO2dCQUNwQyxNQUFNLENBQUMsT0FBTyxDQUFDLGlCQUFpQixJQUFJLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FDN0MsQ0FBQyxDQUFDLFlBQVksRUFBRSxRQUFRLENBQUMsRUFBRSxFQUFFO29CQUMzQiwyQ0FBMkM7b0JBQzNDLElBQ0UsUUFBUSxDQUFDLElBQUksQ0FBQzt3QkFDZCxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUTt3QkFDdkIsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQzVCLENBQUM7d0JBQ0QsV0FBVyxDQUFDLEdBQUcsWUFBWSxJQUFJLFlBQVksRUFBRSxDQUFDLEdBQUcsUUFBUSxDQUN2RCxJQUFJLENBQ0wsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEtBQUssQ0FBQyxJQUFJLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztvQkFDaEQsQ0FBQztnQkFDSCxDQUFDLENBQ0YsQ0FBQztZQUNKLENBQUMsQ0FDRixDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUNYLGdCQUFNLENBQUMsS0FBSyxDQUFDLGtDQUFrQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxPQUFPLENBQUMsT0FBZSxFQUFFLEVBQUU7UUFDekIsT0FBTyxPQUFPO2FBQ1gsS0FBSyxDQUFDLElBQUksQ0FBQzthQUNYLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ1osTUFBTSxhQUFhLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxJQUFJLENBQ3BELENBQUMsQ0FBQyxZQUFZLENBQUMsRUFBRSxFQUFFLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLFlBQVksQ0FBQyxDQUMxRCxDQUFDO1lBQ0YsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUNuQixPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7WUFDRCxNQUFNLENBQUMsRUFBRSxFQUFFLE9BQU8sQ0FBQyxHQUFHLGFBQWEsQ0FBQztZQUNwQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRSxFQUFFLEdBQUcsRUFBRSxLQUFLLE9BQU8sR0FBRyxDQUFDLENBQUM7UUFDaEQsQ0FBQyxDQUFDO2FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hCLENBQUMsQ0FBQztBQUNKLENBQUM7QUEvQ0QsMERBK0NDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IChjKSBIYXNoaUNvcnAsIEluY1xuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IE1QTC0yLjBcbmltcG9ydCB7IGxvZ2dlciB9IGZyb20gXCJAY2RrdG4vY29tbW9uc1wiO1xuaW1wb3J0IHsgU3ludGhlc2l6ZWRTdGFjayB9IGZyb20gXCIuL3N5bnRoLXN0YWNrXCI7XG50eXBlIFRGSWRlbnRpZmllciA9IHN0cmluZztcbnR5cGUgQ0RLVEZSZXNvdXJjZVBhdGggPSBzdHJpbmc7XG50eXBlIFRmUmVzb3VyY2UgPSBSZWNvcmQ8XG4gIHN0cmluZyxcbiAge1xuICAgIFtcIi8vXCJdPzoge1xuICAgICAgbWV0YWRhdGE/OiB7XG4gICAgICAgIHBhdGg/OiBzdHJpbmc7XG4gICAgICB9O1xuICAgIH07XG4gIH1cbj47XG50eXBlIFRmUmVzb3VyY2VUeXBlID0gUmVjb3JkPHN0cmluZywgVGZSZXNvdXJjZT47XG50eXBlIFRGSnNvbiA9IHtcbiAgZGF0YTogVGZSZXNvdXJjZVR5cGU7XG4gIHJlc291cmNlOiBUZlJlc291cmNlVHlwZTtcbn07XG5cbi8vIGVzY2FwZXMgYW55IHNwZWNpYWwgY2hhcmF0ZXJzIHVzZWQgaW4gcmVnZXhcbmNvbnN0IGVzY2FwZVJlZ2V4U3BlY2lhbENoYXJzID0gKHN0cjogc3RyaW5nKSA9PlxuICBzdHIucmVwbGFjZSgvWy0vXFxcXF4kKis/LigpfFtcXF17fV0vZywgXCJcXFxcJCZcIik7XG5cbi8vIHVzZXMgd29yZCBib3VuZGFyeSB0byBtYXRjaCB0aGUgd2hvbGUgb2YgdGhlIHRmSWRlbnRpZmVyXG5jb25zdCBsaW5lSGFzRXhhY3RNYXRjaCA9IChsaW5lOiBzdHJpbmcsIHRmSWRlbnRpZmllcjogc3RyaW5nKSA9PlxuICBuZXcgUmVnRXhwKGBcXFxcYiR7ZXNjYXBlUmVnZXhTcGVjaWFsQ2hhcnModGZJZGVudGlmaWVyKX1cXFxcYmApLnRlc3QobGluZSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFbmhhbmNlTG9nTWVzc2FnZShcbiAgc3RhY2s6IFN5bnRoZXNpemVkU3RhY2ssXG4pOiAobWVzc2FnZTogc3RyaW5nKSA9PiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAvLyB3ZSBuZXZlciB3YW50IHRvIHRocm93LCBpZiBpdCBkb2VzIG5vdCB3b3JrIHdlIGp1c3QgZG8gYXMgaWYgaXQgZGlkIG5vdCBoYXBwZW5cbiAgY29uc3QgcGF0aE1hcHBpbmc6IFJlY29yZDxURklkZW50aWZpZXIsIENES1RGUmVzb3VyY2VQYXRoPiA9IHt9O1xuICB0cnkge1xuICAgIGNvbnN0IGpzb24gPSBKU09OLnBhcnNlKHN0YWNrLmNvbnRlbnQpIGFzIFRGSnNvbjtcblxuICAgIFtcImRhdGFcIiwgXCJyZXNvdXJjZVwiXS5mb3JFYWNoKCh0eXBlKSA9PiB7XG4gICAgICBPYmplY3QuZW50cmllcyhqc29uW3R5cGUgYXMgXCJkYXRhXCIgfCBcInJlc291cmNlXCJdIHx8IHt9KS5mb3JFYWNoKFxuICAgICAgICAoW3Jlc291cmNlVHlwZSwgcmVzb3VyY2VJbnN0YW5jZXNdKSA9PiB7XG4gICAgICAgICAgT2JqZWN0LmVudHJpZXMocmVzb3VyY2VJbnN0YW5jZXMgfHwge30pLmZvckVhY2goXG4gICAgICAgICAgICAoW3Jlc291cmNlTmFtZSwgcmVzb3VyY2VdKSA9PiB7XG4gICAgICAgICAgICAgIC8vIFNvbWUgY29uc3RydWN0cyBkb24ndCBoYXZlIHRoaXMgbWV0YWRhdGFcbiAgICAgICAgICAgICAgaWYgKFxuICAgICAgICAgICAgICAgIHJlc291cmNlW1wiLy9cIl0gJiZcbiAgICAgICAgICAgICAgICByZXNvdXJjZVtcIi8vXCJdLm1ldGFkYXRhICYmXG4gICAgICAgICAgICAgICAgcmVzb3VyY2VbXCIvL1wiXS5tZXRhZGF0YS5wYXRoXG4gICAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICAgIHBhdGhNYXBwaW5nW2Ake3Jlc291cmNlVHlwZX0uJHtyZXNvdXJjZU5hbWV9YF0gPSByZXNvdXJjZVtcbiAgICAgICAgICAgICAgICAgIFwiLy9cIlxuICAgICAgICAgICAgICAgIF0ubWV0YWRhdGEucGF0aC5yZXBsYWNlKGAke3N0YWNrLm5hbWV9L2AsIFwiXCIpO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9LFxuICAgICAgICAgICk7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH0pO1xuICB9IGNhdGNoIChlKSB7XG4gICAgbG9nZ2VyLmRlYnVnKGBDb3VsZCBub3QgZW5oYW5jZSBsb2cgbWVzc2FnZTogJHtlfWApO1xuICB9XG5cbiAgcmV0dXJuIChtZXNzYWdlOiBzdHJpbmcpID0+IHtcbiAgICByZXR1cm4gbWVzc2FnZVxuICAgICAgLnNwbGl0KFwiXFxuXCIpXG4gICAgICAubWFwKChsaW5lKSA9PiB7XG4gICAgICAgIGNvbnN0IG1hdGNoaW5nRW50cnkgPSBPYmplY3QuZW50cmllcyhwYXRoTWFwcGluZykuZmluZChcbiAgICAgICAgICAoW3RmSWRlbnRpZmllcl0pID0+IGxpbmVIYXNFeGFjdE1hdGNoKGxpbmUsIHRmSWRlbnRpZmllciksXG4gICAgICAgICk7XG4gICAgICAgIGlmICghbWF0Y2hpbmdFbnRyeSkge1xuICAgICAgICAgIHJldHVybiBsaW5lO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IFtpZCwgY2RrUGF0aF0gPSBtYXRjaGluZ0VudHJ5O1xuICAgICAgICByZXR1cm4gbGluZS5yZXBsYWNlKGlkLCBgJHtpZH0gKCR7Y2RrUGF0aH0pYCk7XG4gICAgICB9KVxuICAgICAgLmpvaW4oXCJcXG5cIik7XG4gIH07XG59XG4iXX0=
@@ -0,0 +1,25 @@
1
+ import { GetOptions } from "@cdktn/provider-generator";
2
+ import { TerraformModuleConstraint, TerraformProviderConstraint, TerraformDependencyConstraint } from "@cdktn/commons";
3
+ export declare enum GetStatus {
4
+ STARTING = "starting",
5
+ DOWNLOADING = "downloading and generating modules and providers",
6
+ DONE = "done",
7
+ ERROR = "error"
8
+ }
9
+ type ParsedDependencyConstraint = TerraformModuleConstraint | TerraformProviderConstraint | TerraformDependencyConstraint;
10
+ interface GetConfig {
11
+ constraints: ParsedDependencyConstraint[];
12
+ constraintsToGenerate?: ParsedDependencyConstraint[];
13
+ constructsOptions: GetOptions;
14
+ cleanDirectory?: boolean;
15
+ providerSchemaCachePath?: string;
16
+ onUpdate?: (payload: GetStatus) => void;
17
+ reportTelemetry?: (telemetry: {
18
+ targetLanguage: string;
19
+ trackingPayload: Record<string, any>;
20
+ }) => Promise<void>;
21
+ }
22
+ export declare function get({ constructsOptions, constraints, constraintsToGenerate, cleanDirectory, providerSchemaCachePath, onUpdate, reportTelemetry, }: GetConfig): Promise<void>;
23
+ export declare function runGetInDir(dir: string, clean?: boolean): Promise<void>;
24
+ export {};
25
+ //# sourceMappingURL=get.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get.d.ts","sourceRoot":"","sources":["get.ts"],"names":[],"mappings":"AAEA,OAAO,EAAmB,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACxE,OAAO,EAEL,yBAAyB,EACzB,2BAA2B,EAC3B,6BAA6B,EAC9B,MAAM,gBAAgB,CAAC;AAMxB,oBAAY,SAAS;IACnB,QAAQ,aAAa;IACrB,WAAW,qDAAqD;IAChE,IAAI,SAAS;IACb,KAAK,UAAU;CAChB;AAED,KAAK,0BAA0B,GAC3B,yBAAyB,GACzB,2BAA2B,GAC3B,6BAA6B,CAAC;AAElC,UAAU,SAAS;IAEjB,WAAW,EAAE,0BAA0B,EAAE,CAAC;IAE1C,qBAAqB,CAAC,EAAE,0BAA0B,EAAE,CAAC;IACrD,iBAAiB,EAAE,UAAU,CAAC;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,SAAS,KAAK,IAAI,CAAC;IACxC,eAAe,CAAC,EAAE,CAAC,SAAS,EAAE;QAC5B,cAAc,EAAE,MAAM,CAAC;QACvB,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;KACtC,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CACrB;AAED,wBAAsB,GAAG,CAAC,EACxB,iBAAiB,EACjB,WAAW,EACX,qBAAqB,EACrB,cAAc,EACd,uBAAuB,EACvB,QAA0B,EAC1B,eAAuC,GACxC,EAAE,SAAS,iBAsCX;AAED,wBAAsB,WAAW,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,UAAO,iBAiB1D"}
package/src/lib/get.js ADDED
@@ -0,0 +1,90 @@
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.runGetInDir = exports.get = exports.GetStatus = void 0;
27
+ // Copyright (c) HashiCorp, Inc
28
+ // SPDX-License-Identifier: MPL-2.0
29
+ const provider_generator_1 = require("@cdktn/provider-generator");
30
+ const commons_1 = require("@cdktn/commons");
31
+ const fs = __importStar(require("fs-extra"));
32
+ const commons_2 = require("@cdktn/commons");
33
+ const path = __importStar(require("path"));
34
+ const cdktf_config_1 = require("./cdktf-config");
35
+ var GetStatus;
36
+ (function (GetStatus) {
37
+ GetStatus["STARTING"] = "starting";
38
+ GetStatus["DOWNLOADING"] = "downloading and generating modules and providers";
39
+ GetStatus["DONE"] = "done";
40
+ GetStatus["ERROR"] = "error";
41
+ })(GetStatus || (exports.GetStatus = GetStatus = {}));
42
+ async function get({ constructsOptions, constraints, constraintsToGenerate, cleanDirectory, providerSchemaCachePath, onUpdate = () => undefined, reportTelemetry = async () => undefined, }) {
43
+ commons_2.logger.debug(`Starting get with outdir ${constructsOptions.codeMakerOutput}`);
44
+ const constructsMaker = new provider_generator_1.ConstructsMaker(constructsOptions, providerSchemaCachePath, reportTelemetry);
45
+ if (cleanDirectory) {
46
+ await fs.remove(constructsOptions.codeMakerOutput);
47
+ }
48
+ else {
49
+ // Remove all providers that are not in the new list
50
+ await constructsMaker.removeFoldersThatShouldNotExist(constraints);
51
+ if (constructsOptions.targetLanguage === commons_1.Language.TYPESCRIPT) {
52
+ // Remove all modules
53
+ await fs.remove(path.resolve(constructsOptions.codeMakerOutput, "modules"));
54
+ }
55
+ }
56
+ // Filter constraints to generate
57
+ const toGenerate = constraintsToGenerate ||
58
+ (await constructsMaker.filterAlreadyGenerated(constraints));
59
+ onUpdate(GetStatus.DOWNLOADING);
60
+ commons_2.logger.debug("Generating provider bindings");
61
+ await constructsMaker.generate(constraints, toGenerate);
62
+ commons_2.logger.debug("Provider bindings generated");
63
+ if (!(await fs.pathExists(constructsOptions.codeMakerOutput))) {
64
+ onUpdate(GetStatus.ERROR);
65
+ commons_2.logger.debug("Failed to generate provider bindings");
66
+ }
67
+ else {
68
+ onUpdate(GetStatus.DONE);
69
+ commons_2.logger.debug("Provider bindings generated");
70
+ }
71
+ }
72
+ exports.get = get;
73
+ async function runGetInDir(dir, clean = true) {
74
+ const config = cdktf_config_1.CdktfConfig.read(dir);
75
+ const constraints = [
76
+ ...config.terraformProviders.map((c) => new commons_1.TerraformProviderConstraint(c)),
77
+ ...config.terraformModules.map((c) => new commons_1.TerraformModuleConstraint(c)),
78
+ ];
79
+ await get({
80
+ constraints,
81
+ constructsOptions: {
82
+ codeMakerOutput: path.resolve(dir, config.codeMakerOutput),
83
+ targetLanguage: config.language,
84
+ jsiiParallelism: 1,
85
+ },
86
+ cleanDirectory: clean,
87
+ });
88
+ }
89
+ exports.runGetInDir = runGetInDir;
90
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZ2V0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0JBQStCO0FBQy9CLG1DQUFtQztBQUNuQyxrRUFBd0U7QUFDeEUsNENBS3dCO0FBQ3hCLDZDQUErQjtBQUMvQiw0Q0FBd0M7QUFDeEMsMkNBQTZCO0FBQzdCLGlEQUE2QztBQUU3QyxJQUFZLFNBS1g7QUFMRCxXQUFZLFNBQVM7SUFDbkIsa0NBQXFCLENBQUE7SUFDckIsNkVBQWdFLENBQUE7SUFDaEUsMEJBQWEsQ0FBQTtJQUNiLDRCQUFlLENBQUE7QUFDakIsQ0FBQyxFQUxXLFNBQVMseUJBQVQsU0FBUyxRQUtwQjtBQXNCTSxLQUFLLFVBQVUsR0FBRyxDQUFDLEVBQ3hCLGlCQUFpQixFQUNqQixXQUFXLEVBQ1gscUJBQXFCLEVBQ3JCLGNBQWMsRUFDZCx1QkFBdUIsRUFDdkIsUUFBUSxHQUFHLEdBQUcsRUFBRSxDQUFDLFNBQVMsRUFDMUIsZUFBZSxHQUFHLEtBQUssSUFBSSxFQUFFLENBQUMsU0FBUyxHQUM3QjtJQUNWLGdCQUFNLENBQUMsS0FBSyxDQUFDLDRCQUE0QixpQkFBaUIsQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDO0lBQzlFLE1BQU0sZUFBZSxHQUFHLElBQUksb0NBQWUsQ0FDekMsaUJBQWlCLEVBQ2pCLHVCQUF1QixFQUN2QixlQUFlLENBQ2hCLENBQUM7SUFFRixJQUFJLGNBQWMsRUFBRSxDQUFDO1FBQ25CLE1BQU0sRUFBRSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNyRCxDQUFDO1NBQU0sQ0FBQztRQUNOLG9EQUFvRDtRQUNwRCxNQUFNLGVBQWUsQ0FBQywrQkFBK0IsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNuRSxJQUFJLGlCQUFpQixDQUFDLGNBQWMsS0FBSyxrQkFBUSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQzdELHFCQUFxQjtZQUNyQixNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQ2IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLEVBQUUsU0FBUyxDQUFDLENBQzNELENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQztJQUVELGlDQUFpQztJQUNqQyxNQUFNLFVBQVUsR0FDZCxxQkFBcUI7UUFDckIsQ0FBQyxNQUFNLGVBQWUsQ0FBQyxzQkFBc0IsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO0lBRTlELFFBQVEsQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDaEMsZ0JBQU0sQ0FBQyxLQUFLLENBQUMsOEJBQThCLENBQUMsQ0FBQztJQUM3QyxNQUFNLGVBQWUsQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQ3hELGdCQUFNLENBQUMsS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7SUFFNUMsSUFBSSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsVUFBVSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUM5RCxRQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzFCLGdCQUFNLENBQUMsS0FBSyxDQUFDLHNDQUFzQyxDQUFDLENBQUM7SUFDdkQsQ0FBQztTQUFNLENBQUM7UUFDTixRQUFRLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pCLGdCQUFNLENBQUMsS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7SUFDOUMsQ0FBQztBQUNILENBQUM7QUE5Q0Qsa0JBOENDO0FBRU0sS0FBSyxVQUFVLFdBQVcsQ0FBQyxHQUFXLEVBQUUsS0FBSyxHQUFHLElBQUk7SUFDekQsTUFBTSxNQUFNLEdBQUcsMEJBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFckMsTUFBTSxXQUFXLEdBQUc7UUFDbEIsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLHFDQUEyQixDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNFLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxtQ0FBeUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztLQUN4RSxDQUFDO0lBRUYsTUFBTSxHQUFHLENBQUM7UUFDUixXQUFXO1FBQ1gsaUJBQWlCLEVBQUU7WUFDakIsZUFBZSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxlQUFlLENBQUM7WUFDMUQsY0FBYyxFQUFFLE1BQU0sQ0FBQyxRQUFRO1lBQy9CLGVBQWUsRUFBRSxDQUFDO1NBQ25CO1FBQ0QsY0FBYyxFQUFFLEtBQUs7S0FDdEIsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQWpCRCxrQ0FpQkMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIEhhc2hpQ29ycCwgSW5jXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTVBMLTIuMFxuaW1wb3J0IHsgQ29uc3RydWN0c01ha2VyLCBHZXRPcHRpb25zIH0gZnJvbSBcIkBjZGt0bi9wcm92aWRlci1nZW5lcmF0b3JcIjtcbmltcG9ydCB7XG4gIExhbmd1YWdlLFxuICBUZXJyYWZvcm1Nb2R1bGVDb25zdHJhaW50LFxuICBUZXJyYWZvcm1Qcm92aWRlckNvbnN0cmFpbnQsXG4gIFRlcnJhZm9ybURlcGVuZGVuY3lDb25zdHJhaW50LFxufSBmcm9tIFwiQGNka3RuL2NvbW1vbnNcIjtcbmltcG9ydCAqIGFzIGZzIGZyb20gXCJmcy1leHRyYVwiO1xuaW1wb3J0IHsgbG9nZ2VyIH0gZnJvbSBcIkBjZGt0bi9jb21tb25zXCI7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gXCJwYXRoXCI7XG5pbXBvcnQgeyBDZGt0ZkNvbmZpZyB9IGZyb20gXCIuL2Nka3RmLWNvbmZpZ1wiO1xuXG5leHBvcnQgZW51bSBHZXRTdGF0dXMge1xuICBTVEFSVElORyA9IFwic3RhcnRpbmdcIixcbiAgRE9XTkxPQURJTkcgPSBcImRvd25sb2FkaW5nIGFuZCBnZW5lcmF0aW5nIG1vZHVsZXMgYW5kIHByb3ZpZGVyc1wiLFxuICBET05FID0gXCJkb25lXCIsXG4gIEVSUk9SID0gXCJlcnJvclwiLFxufVxuXG50eXBlIFBhcnNlZERlcGVuZGVuY3lDb25zdHJhaW50ID1cbiAgfCBUZXJyYWZvcm1Nb2R1bGVDb25zdHJhaW50XG4gIHwgVGVycmFmb3JtUHJvdmlkZXJDb25zdHJhaW50XG4gIHwgVGVycmFmb3JtRGVwZW5kZW5jeUNvbnN0cmFpbnQ7XG5cbmludGVyZmFjZSBHZXRDb25maWcge1xuICAvLyBBbGwgZXhpc3RpbmcgY29uc3RyYWludHMgKHRvIGJlIGFibGUgdG8gcmVtb3ZlIG5vIGxvbmdlciB1c2VkIG9uZXMpXG4gIGNvbnN0cmFpbnRzOiBQYXJzZWREZXBlbmRlbmN5Q29uc3RyYWludFtdO1xuICAvLyBUaGUgY29uc3RyYWludHMgdGhhdCBzaG91bGQgYmUgZ2VuZXJhdGVkXG4gIGNvbnN0cmFpbnRzVG9HZW5lcmF0ZT86IFBhcnNlZERlcGVuZGVuY3lDb25zdHJhaW50W107XG4gIGNvbnN0cnVjdHNPcHRpb25zOiBHZXRPcHRpb25zO1xuICBjbGVhbkRpcmVjdG9yeT86IGJvb2xlYW47XG4gIHByb3ZpZGVyU2NoZW1hQ2FjaGVQYXRoPzogc3RyaW5nO1xuICBvblVwZGF0ZT86IChwYXlsb2FkOiBHZXRTdGF0dXMpID0+IHZvaWQ7XG4gIHJlcG9ydFRlbGVtZXRyeT86ICh0ZWxlbWV0cnk6IHtcbiAgICB0YXJnZXRMYW5ndWFnZTogc3RyaW5nO1xuICAgIHRyYWNraW5nUGF5bG9hZDogUmVjb3JkPHN0cmluZywgYW55PjtcbiAgfSkgPT4gUHJvbWlzZTx2b2lkPjtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldCh7XG4gIGNvbnN0cnVjdHNPcHRpb25zLFxuICBjb25zdHJhaW50cyxcbiAgY29uc3RyYWludHNUb0dlbmVyYXRlLFxuICBjbGVhbkRpcmVjdG9yeSxcbiAgcHJvdmlkZXJTY2hlbWFDYWNoZVBhdGgsXG4gIG9uVXBkYXRlID0gKCkgPT4gdW5kZWZpbmVkLFxuICByZXBvcnRUZWxlbWV0cnkgPSBhc3luYyAoKSA9PiB1bmRlZmluZWQsXG59OiBHZXRDb25maWcpIHtcbiAgbG9nZ2VyLmRlYnVnKGBTdGFydGluZyBnZXQgd2l0aCBvdXRkaXIgJHtjb25zdHJ1Y3RzT3B0aW9ucy5jb2RlTWFrZXJPdXRwdXR9YCk7XG4gIGNvbnN0IGNvbnN0cnVjdHNNYWtlciA9IG5ldyBDb25zdHJ1Y3RzTWFrZXIoXG4gICAgY29uc3RydWN0c09wdGlvbnMsXG4gICAgcHJvdmlkZXJTY2hlbWFDYWNoZVBhdGgsXG4gICAgcmVwb3J0VGVsZW1ldHJ5LFxuICApO1xuXG4gIGlmIChjbGVhbkRpcmVjdG9yeSkge1xuICAgIGF3YWl0IGZzLnJlbW92ZShjb25zdHJ1Y3RzT3B0aW9ucy5jb2RlTWFrZXJPdXRwdXQpO1xuICB9IGVsc2Uge1xuICAgIC8vIFJlbW92ZSBhbGwgcHJvdmlkZXJzIHRoYXQgYXJlIG5vdCBpbiB0aGUgbmV3IGxpc3RcbiAgICBhd2FpdCBjb25zdHJ1Y3RzTWFrZXIucmVtb3ZlRm9sZGVyc1RoYXRTaG91bGROb3RFeGlzdChjb25zdHJhaW50cyk7XG4gICAgaWYgKGNvbnN0cnVjdHNPcHRpb25zLnRhcmdldExhbmd1YWdlID09PSBMYW5ndWFnZS5UWVBFU0NSSVBUKSB7XG4gICAgICAvLyBSZW1vdmUgYWxsIG1vZHVsZXNcbiAgICAgIGF3YWl0IGZzLnJlbW92ZShcbiAgICAgICAgcGF0aC5yZXNvbHZlKGNvbnN0cnVjdHNPcHRpb25zLmNvZGVNYWtlck91dHB1dCwgXCJtb2R1bGVzXCIpLFxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICAvLyBGaWx0ZXIgY29uc3RyYWludHMgdG8gZ2VuZXJhdGVcbiAgY29uc3QgdG9HZW5lcmF0ZSA9XG4gICAgY29uc3RyYWludHNUb0dlbmVyYXRlIHx8XG4gICAgKGF3YWl0IGNvbnN0cnVjdHNNYWtlci5maWx0ZXJBbHJlYWR5R2VuZXJhdGVkKGNvbnN0cmFpbnRzKSk7XG5cbiAgb25VcGRhdGUoR2V0U3RhdHVzLkRPV05MT0FESU5HKTtcbiAgbG9nZ2VyLmRlYnVnKFwiR2VuZXJhdGluZyBwcm92aWRlciBiaW5kaW5nc1wiKTtcbiAgYXdhaXQgY29uc3RydWN0c01ha2VyLmdlbmVyYXRlKGNvbnN0cmFpbnRzLCB0b0dlbmVyYXRlKTtcbiAgbG9nZ2VyLmRlYnVnKFwiUHJvdmlkZXIgYmluZGluZ3MgZ2VuZXJhdGVkXCIpO1xuXG4gIGlmICghKGF3YWl0IGZzLnBhdGhFeGlzdHMoY29uc3RydWN0c09wdGlvbnMuY29kZU1ha2VyT3V0cHV0KSkpIHtcbiAgICBvblVwZGF0ZShHZXRTdGF0dXMuRVJST1IpO1xuICAgIGxvZ2dlci5kZWJ1ZyhcIkZhaWxlZCB0byBnZW5lcmF0ZSBwcm92aWRlciBiaW5kaW5nc1wiKTtcbiAgfSBlbHNlIHtcbiAgICBvblVwZGF0ZShHZXRTdGF0dXMuRE9ORSk7XG4gICAgbG9nZ2VyLmRlYnVnKFwiUHJvdmlkZXIgYmluZGluZ3MgZ2VuZXJhdGVkXCIpO1xuICB9XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBydW5HZXRJbkRpcihkaXI6IHN0cmluZywgY2xlYW4gPSB0cnVlKSB7XG4gIGNvbnN0IGNvbmZpZyA9IENka3RmQ29uZmlnLnJlYWQoZGlyKTtcblxuICBjb25zdCBjb25zdHJhaW50cyA9IFtcbiAgICAuLi5jb25maWcudGVycmFmb3JtUHJvdmlkZXJzLm1hcCgoYykgPT4gbmV3IFRlcnJhZm9ybVByb3ZpZGVyQ29uc3RyYWludChjKSksXG4gICAgLi4uY29uZmlnLnRlcnJhZm9ybU1vZHVsZXMubWFwKChjKSA9PiBuZXcgVGVycmFmb3JtTW9kdWxlQ29uc3RyYWludChjKSksXG4gIF07XG5cbiAgYXdhaXQgZ2V0KHtcbiAgICBjb25zdHJhaW50cyxcbiAgICBjb25zdHJ1Y3RzT3B0aW9uczoge1xuICAgICAgY29kZU1ha2VyT3V0cHV0OiBwYXRoLnJlc29sdmUoZGlyLCBjb25maWcuY29kZU1ha2VyT3V0cHV0KSxcbiAgICAgIHRhcmdldExhbmd1YWdlOiBjb25maWcubGFuZ3VhZ2UsXG4gICAgICBqc2lpUGFyYWxsZWxpc206IDEsXG4gICAgfSxcbiAgICBjbGVhbkRpcmVjdG9yeTogY2xlYW4sXG4gIH0pO1xufVxuIl19
@@ -0,0 +1,16 @@
1
+ import { CdktfStack } from "../cdktf-stack";
2
+ import { SynthesizedStack } from "../synth-stack";
3
+ export declare function getSingleStack(stacks: SynthesizedStack[], stackName?: string, targetAction?: string): SynthesizedStack;
4
+ export declare function getMultipleStacks(stacks: SynthesizedStack[], patterns?: string[], targetAction?: string): SynthesizedStack[];
5
+ export declare function getStackWithNoUnmetDependencies(stackExecutors: CdktfStack[]): Promise<CdktfStack | undefined>;
6
+ export declare function findAllNestedDependantStacks(stackExecutors: CdktfStack[], stackName: string, knownDependantStackNames?: Set<string>): CdktfStack[];
7
+ export declare function getStackWithNoUnmetDependants(stackExecutors: CdktfStack[]): Promise<CdktfStack | undefined>;
8
+ export declare function checkIfAllDependantsAreIncluded(stacksToRun: SynthesizedStack[], allStacks: SynthesizedStack[]): void;
9
+ /**
10
+ Throws an error if there is a dependency that is not included
11
+ Cycles are detected on dependency creation at synthesis time
12
+ Running this prevents us from being in a situation where we
13
+ have to wait for a stack to be deployed that is not included to be run
14
+ */
15
+ export declare function checkIfAllDependenciesAreIncluded(stacksToRun: SynthesizedStack[]): void;
16
+ //# sourceMappingURL=stack-helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stack-helpers.d.ts","sourceRoot":"","sources":["stack-helpers.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,wBAAgB,cAAc,CAC5B,MAAM,EAAE,gBAAgB,EAAE,EAC1B,SAAS,CAAC,EAAE,MAAM,EAClB,YAAY,CAAC,EAAE,MAAM,oBA4BtB;AAED,wBAAgB,iBAAiB,CAC/B,MAAM,EAAE,gBAAgB,EAAE,EAC1B,QAAQ,CAAC,EAAE,MAAM,EAAE,EACnB,YAAY,CAAC,EAAE,MAAM,sBA0BtB;AAMD,wBAAsB,+BAA+B,CACnD,cAAc,EAAE,UAAU,EAAE,GAC3B,OAAO,CAAC,UAAU,GAAG,SAAS,CAAC,CAyCjC;AAWD,wBAAgB,4BAA4B,CAC1C,cAAc,EAAE,UAAU,EAAE,EAC5B,SAAS,EAAE,MAAM,EACjB,wBAAwB,GAAE,GAAG,CAAC,MAAM,CAAa,GAChD,UAAU,EAAE,CAkBd;AAGD,wBAAsB,6BAA6B,CACjD,cAAc,EAAE,UAAU,EAAE,GAC3B,OAAO,CAAC,UAAU,GAAG,SAAS,CAAC,CAmCjC;AAGD,wBAAgB,+BAA+B,CAC7C,WAAW,EAAE,gBAAgB,EAAE,EAC/B,SAAS,EAAE,gBAAgB,EAAE,QAsB9B;AAED;;;;;EAKE;AACF,wBAAgB,iCAAiC,CAC/C,WAAW,EAAE,gBAAgB,EAAE,QAoBhC"}
@@ -0,0 +1,155 @@
1
+ "use strict";
2
+ // Copyright (c) HashiCorp, Inc
3
+ // SPDX-License-Identifier: MPL-2.0
4
+ var __importDefault = (this && this.__importDefault) || function (mod) {
5
+ return (mod && mod.__esModule) ? mod : { "default": mod };
6
+ };
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.checkIfAllDependenciesAreIncluded = exports.checkIfAllDependantsAreIncluded = exports.getStackWithNoUnmetDependants = exports.findAllNestedDependantStacks = exports.getStackWithNoUnmetDependencies = exports.getMultipleStacks = exports.getSingleStack = void 0;
9
+ const commons_1 = require("@cdktn/commons");
10
+ const minimatch_1 = __importDefault(require("minimatch"));
11
+ function getSingleStack(stacks, stackName, targetAction) {
12
+ if (!stacks) {
13
+ throw commons_1.Errors.Internal("Trying to access a stack before it has been synthesized");
14
+ }
15
+ if (stackName) {
16
+ const stack = stacks.find((s) => s.name === stackName);
17
+ if (!stack) {
18
+ throw commons_1.Errors.Usage("Could not find stack: " + stackName);
19
+ }
20
+ return stack;
21
+ }
22
+ if (stacks.length === 1) {
23
+ return stacks[0];
24
+ }
25
+ throw commons_1.Errors.Usage(`Found more than one stack, please specify a target stack. Run cdktn ${targetAction || "<verb>"} <stack> with one of these stacks: ${stacks
26
+ .map((s) => s.name)
27
+ .join(", ")} `);
28
+ }
29
+ exports.getSingleStack = getSingleStack;
30
+ function getMultipleStacks(stacks, patterns, targetAction) {
31
+ if (!patterns || !patterns.length) {
32
+ if (stacks.length === 1) {
33
+ return [stacks[0]];
34
+ }
35
+ throw commons_1.Errors.Usage(`Found more than one stack, please specify a target stack. Run cdktn ${targetAction || "<verb>"} <stack> with one of these stacks: ${stacks
36
+ .map((s) => s.name)
37
+ .join(", ")} `);
38
+ }
39
+ return patterns.flatMap((pattern) => {
40
+ const matchingStacks = stacks.filter((stack) => (0, minimatch_1.default)(stack.name, pattern));
41
+ if (matchingStacks.length === 0) {
42
+ throw commons_1.Errors.Usage(`Could not find stack for pattern '${pattern}'`);
43
+ }
44
+ return matchingStacks;
45
+ });
46
+ }
47
+ exports.getMultipleStacks = getMultipleStacks;
48
+ // Returns the first stack that has no unmet dependencies
49
+ // An unmet dependency is a dependency that has not been deployed yet
50
+ // If there is no unfinished stack, returns undefined
51
+ // If there is no stack ready to be worked on, it returns a promise that will resolve as soon as there is a follow-up stack available
52
+ async function getStackWithNoUnmetDependencies(stackExecutors) {
53
+ commons_1.logger.debug("Checking for stacks with unmet dependencies");
54
+ commons_1.logger.debug("stack executors:", stackExecutors);
55
+ const pendingStacks = stackExecutors.filter((executor) => executor.isPending);
56
+ commons_1.logger.debug("pending stacks:", stackExecutors);
57
+ if (pendingStacks.length === 0) {
58
+ return undefined;
59
+ }
60
+ const currentlyReadyStack = pendingStacks.find((executor) => executor.stack.dependencies.every((dependency) => {
61
+ var _a;
62
+ return ((_a = stackExecutors.find((executor) => executor.stack.name === dependency)) === null || _a === void 0 ? void 0 : _a.currentState) === "done";
63
+ }));
64
+ if (currentlyReadyStack) {
65
+ commons_1.logger.debug("Found a stack with no unmet dependencies");
66
+ return currentlyReadyStack;
67
+ }
68
+ const stackExecutionPromises = stackExecutors
69
+ .filter((ex) => ex.currentWorkPromise)
70
+ .map((ex) => ex.currentWorkPromise);
71
+ commons_1.logger.debug(`${stackExecutionPromises.length} stacks are currently busy, waiting for one to finish`);
72
+ if (!stackExecutionPromises.length) {
73
+ return undefined;
74
+ }
75
+ await (0, commons_1.ensureAllSettledBeforeThrowing)(Promise.race(stackExecutionPromises), stackExecutionPromises);
76
+ return await getStackWithNoUnmetDependencies(stackExecutors);
77
+ }
78
+ exports.getStackWithNoUnmetDependencies = getStackWithNoUnmetDependencies;
79
+ function findAllDependantStacks(stackExecutors, stackName) {
80
+ return stackExecutors.filter((innerExecutor) => innerExecutor.stack.dependencies.includes(stackName));
81
+ }
82
+ function findAllNestedDependantStacks(stackExecutors, stackName, knownDependantStackNames = new Set()) {
83
+ const dependantStacks = findAllDependantStacks(stackExecutors, stackName);
84
+ dependantStacks.forEach((stack) => {
85
+ if (knownDependantStackNames.has(stack.stack.name)) {
86
+ return;
87
+ }
88
+ knownDependantStackNames.add(stack.stack.name);
89
+ findAllNestedDependantStacks(stackExecutors, stack.stack.name, knownDependantStackNames);
90
+ });
91
+ return stackExecutors.filter((executor) => knownDependantStackNames.has(executor.stack.name));
92
+ }
93
+ exports.findAllNestedDependantStacks = findAllNestedDependantStacks;
94
+ // Returns the first stack that has no dependents that need to be destroyed first
95
+ async function getStackWithNoUnmetDependants(stackExecutors) {
96
+ commons_1.logger.debug("Checking for stacks with unmet dependants");
97
+ commons_1.logger.debug("stack executors:", stackExecutors);
98
+ const pendingStacks = stackExecutors.filter((executor) => executor.isPending);
99
+ commons_1.logger.debug("pending stacks:", stackExecutors);
100
+ if (pendingStacks.length === 0) {
101
+ return undefined;
102
+ }
103
+ const currentlyReadyStack = pendingStacks.find((executor) => {
104
+ const dependantStacks = findAllDependantStacks(stackExecutors, executor.stack.name);
105
+ return dependantStacks.every((stack) => stack.currentState === "done");
106
+ });
107
+ if (currentlyReadyStack) {
108
+ commons_1.logger.debug("Found a stack with no unmet dependants");
109
+ return currentlyReadyStack;
110
+ }
111
+ const stackExecutionPromises = stackExecutors
112
+ .filter((ex) => ex.currentWorkPromise)
113
+ .map((ex) => ex.currentWorkPromise);
114
+ commons_1.logger.debug(`${stackExecutionPromises.length} stacks are currently busy, waiting for one to finish`);
115
+ if (!stackExecutionPromises.length) {
116
+ return undefined;
117
+ }
118
+ await Promise.race(stackExecutionPromises);
119
+ return await getStackWithNoUnmetDependants(stackExecutors);
120
+ }
121
+ exports.getStackWithNoUnmetDependants = getStackWithNoUnmetDependants;
122
+ // Throws an error if there is a dependant stack that is not included
123
+ function checkIfAllDependantsAreIncluded(stacksToRun, allStacks) {
124
+ const allDependants = new Set();
125
+ stacksToRun
126
+ .map((stack) => allStacks.filter((s) => s.dependencies.includes(stack.name)))
127
+ .flat()
128
+ .forEach((dependant) => allDependants.add(dependant.name));
129
+ const stackNames = stacksToRun.map((stack) => stack.name);
130
+ const missingDependants = [...allDependants].filter((dependant) => !stackNames.includes(dependant));
131
+ if (missingDependants.length > 0) {
132
+ throw commons_1.Errors.Usage(`The following dependant stacks are not included in the stacks to run: ${missingDependants.join(", ")}. Either add them or add the --ignore-missing-stack-dependencies flag.`);
133
+ }
134
+ }
135
+ exports.checkIfAllDependantsAreIncluded = checkIfAllDependantsAreIncluded;
136
+ /**
137
+ Throws an error if there is a dependency that is not included
138
+ Cycles are detected on dependency creation at synthesis time
139
+ Running this prevents us from being in a situation where we
140
+ have to wait for a stack to be deployed that is not included to be run
141
+ */
142
+ function checkIfAllDependenciesAreIncluded(stacksToRun) {
143
+ const allDependencies = new Set();
144
+ stacksToRun
145
+ .map((stack) => stack.dependencies)
146
+ .flat()
147
+ .forEach((dependency) => allDependencies.add(dependency));
148
+ const stackNames = stacksToRun.map((stack) => stack.name);
149
+ const missingDependencies = [...allDependencies].filter((dependency) => !stackNames.includes(dependency));
150
+ if (missingDependencies.length > 0) {
151
+ throw commons_1.Errors.Usage(`The following dependencies are not included in the stacks to run: ${missingDependencies.join(", ")}. Either add them or add the --ignore-missing-stack-dependencies flag.`);
152
+ }
153
+ }
154
+ exports.checkIfAllDependenciesAreIncluded = checkIfAllDependenciesAreIncluded;
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-helpers.js","sourceRoot":"","sources":["stack-helpers.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\n\nimport { ensureAllSettledBeforeThrowing, Errors, logger } from \"@cdktn/commons\";\nimport minimatch from \"minimatch\";\nimport { CdktfStack } from \"../cdktf-stack\";\nimport { SynthesizedStack } from \"../synth-stack\";\n\nexport function getSingleStack(\n  stacks: SynthesizedStack[],\n  stackName?: string,\n  targetAction?: string,\n) {\n  if (!stacks) {\n    throw Errors.Internal(\n      \"Trying to access a stack before it has been synthesized\",\n    );\n  }\n\n  if (stackName) {\n    const stack = stacks.find((s) => s.name === stackName);\n    if (!stack) {\n      throw Errors.Usage(\"Could not find stack: \" + stackName);\n    }\n\n    return stack;\n  }\n\n  if (stacks.length === 1) {\n    return stacks[0];\n  }\n\n  throw Errors.Usage(\n    `Found more than one stack, please specify a target stack. Run cdktn ${\n      targetAction || \"<verb>\"\n    } <stack> with one of these stacks: ${stacks\n      .map((s) => s.name)\n      .join(\", \")} `,\n  );\n}\n\nexport function getMultipleStacks(\n  stacks: SynthesizedStack[],\n  patterns?: string[],\n  targetAction?: string,\n) {\n  if (!patterns || !patterns.length) {\n    if (stacks.length === 1) {\n      return [stacks[0]];\n    }\n    throw Errors.Usage(\n      `Found more than one stack, please specify a target stack. Run cdktn ${\n        targetAction || \"<verb>\"\n      } <stack> with one of these stacks: ${stacks\n        .map((s) => s.name)\n        .join(\", \")} `,\n    );\n  }\n\n  return patterns.flatMap((pattern) => {\n    const matchingStacks = stacks.filter((stack) =>\n      minimatch(stack.name, pattern),\n    );\n\n    if (matchingStacks.length === 0) {\n      throw Errors.Usage(`Could not find stack for pattern '${pattern}'`);\n    }\n\n    return matchingStacks;\n  });\n}\n\n// Returns the first stack that has no unmet dependencies\n// An unmet dependency is a dependency that has not been deployed yet\n// If there is no unfinished stack, returns undefined\n// If there is no stack ready to be worked on, it returns a promise that will resolve as soon as there is a follow-up stack available\nexport async function getStackWithNoUnmetDependencies(\n  stackExecutors: CdktfStack[],\n): Promise<CdktfStack | undefined> {\n  logger.debug(\"Checking for stacks with unmet dependencies\");\n  logger.debug(\"stack executors:\", stackExecutors);\n  const pendingStacks = stackExecutors.filter((executor) => executor.isPending);\n  logger.debug(\"pending stacks:\", stackExecutors);\n\n  if (pendingStacks.length === 0) {\n    return undefined;\n  }\n\n  const currentlyReadyStack = pendingStacks.find((executor) =>\n    executor.stack.dependencies.every(\n      (dependency) =>\n        stackExecutors.find((executor) => executor.stack.name === dependency)\n          ?.currentState === \"done\",\n    ),\n  );\n\n  if (currentlyReadyStack) {\n    logger.debug(\"Found a stack with no unmet dependencies\");\n    return currentlyReadyStack;\n  }\n\n  const stackExecutionPromises = stackExecutors\n    .filter((ex) => ex.currentWorkPromise)\n    .map((ex) => ex.currentWorkPromise);\n\n  logger.debug(\n    `${stackExecutionPromises.length} stacks are currently busy, waiting for one to finish`,\n  );\n\n  if (!stackExecutionPromises.length) {\n    return undefined;\n  }\n\n  await ensureAllSettledBeforeThrowing(\n    Promise.race(stackExecutionPromises),\n    stackExecutionPromises,\n  );\n\n  return await getStackWithNoUnmetDependencies(stackExecutors);\n}\n\nfunction findAllDependantStacks(\n  stackExecutors: CdktfStack[],\n  stackName: string,\n): CdktfStack[] {\n  return stackExecutors.filter((innerExecutor) =>\n    innerExecutor.stack.dependencies.includes(stackName),\n  );\n}\n\nexport function findAllNestedDependantStacks(\n  stackExecutors: CdktfStack[],\n  stackName: string,\n  knownDependantStackNames: Set<string> = new Set(),\n): CdktfStack[] {\n  const dependantStacks = findAllDependantStacks(stackExecutors, stackName);\n  dependantStacks.forEach((stack) => {\n    if (knownDependantStackNames.has(stack.stack.name)) {\n      return;\n    }\n\n    knownDependantStackNames.add(stack.stack.name);\n    findAllNestedDependantStacks(\n      stackExecutors,\n      stack.stack.name,\n      knownDependantStackNames,\n    );\n  });\n\n  return stackExecutors.filter((executor) =>\n    knownDependantStackNames.has(executor.stack.name),\n  );\n}\n\n// Returns the first stack that has no dependents that need to be destroyed first\nexport async function getStackWithNoUnmetDependants(\n  stackExecutors: CdktfStack[],\n): Promise<CdktfStack | undefined> {\n  logger.debug(\"Checking for stacks with unmet dependants\");\n  logger.debug(\"stack executors:\", stackExecutors);\n  const pendingStacks = stackExecutors.filter((executor) => executor.isPending);\n  logger.debug(\"pending stacks:\", stackExecutors);\n\n  if (pendingStacks.length === 0) {\n    return undefined;\n  }\n\n  const currentlyReadyStack = pendingStacks.find((executor) => {\n    const dependantStacks = findAllDependantStacks(\n      stackExecutors,\n      executor.stack.name,\n    );\n    return dependantStacks.every((stack) => stack.currentState === \"done\");\n  });\n\n  if (currentlyReadyStack) {\n    logger.debug(\"Found a stack with no unmet dependants\");\n    return currentlyReadyStack;\n  }\n  const stackExecutionPromises = stackExecutors\n    .filter((ex) => ex.currentWorkPromise)\n    .map((ex) => ex.currentWorkPromise);\n\n  logger.debug(\n    `${stackExecutionPromises.length} stacks are currently busy, waiting for one to finish`,\n  );\n  if (!stackExecutionPromises.length) {\n    return undefined;\n  }\n\n  await Promise.race(stackExecutionPromises);\n  return await getStackWithNoUnmetDependants(stackExecutors);\n}\n\n// Throws an error if there is a dependant stack that is not included\nexport function checkIfAllDependantsAreIncluded(\n  stacksToRun: SynthesizedStack[],\n  allStacks: SynthesizedStack[],\n) {\n  const allDependants = new Set<string>();\n  stacksToRun\n    .map((stack) =>\n      allStacks.filter((s) => s.dependencies.includes(stack.name)),\n    )\n    .flat()\n    .forEach((dependant) => allDependants.add(dependant.name));\n\n  const stackNames = stacksToRun.map((stack) => stack.name);\n  const missingDependants = [...allDependants].filter(\n    (dependant) => !stackNames.includes(dependant),\n  );\n\n  if (missingDependants.length > 0) {\n    throw Errors.Usage(\n      `The following dependant stacks are not included in the stacks to run: ${missingDependants.join(\n        \", \",\n      )}. Either add them or add the --ignore-missing-stack-dependencies flag.`,\n    );\n  }\n}\n\n/** \n  Throws an error if there is a dependency that is not included\n  Cycles are detected on dependency creation at synthesis time\n  Running this prevents us from being in a situation where we \n  have to wait for a stack to be deployed that is not included to be run\n*/\nexport function checkIfAllDependenciesAreIncluded(\n  stacksToRun: SynthesizedStack[],\n) {\n  const allDependencies = new Set<string>();\n  stacksToRun\n    .map((stack) => stack.dependencies)\n    .flat()\n    .forEach((dependency) => allDependencies.add(dependency));\n\n  const stackNames = stacksToRun.map((stack) => stack.name);\n  const missingDependencies = [...allDependencies].filter(\n    (dependency) => !stackNames.includes(dependency),\n  );\n\n  if (missingDependencies.length > 0) {\n    throw Errors.Usage(\n      `The following dependencies are not included in the stacks to run: ${missingDependencies.join(\n        \", \",\n      )}. Either add them or add the --ignore-missing-stack-dependencies flag.`,\n    );\n  }\n}\n"]}
@@ -0,0 +1,15 @@
1
+ export { DependencyManager, ProviderConstraint, } from "./dependencies/dependency-manager";
2
+ export { getAllPrebuiltProviders } from "./dependencies/prebuilt-providers";
3
+ export { providerAdd } from "./provider-add";
4
+ export { TerraformCli } from "./models/terraform-cli";
5
+ export { CdktfConfig } from "./cdktf-config";
6
+ export { initializErrorReporting } from "./error-reporting";
7
+ export { CdktfStack } from "./cdktf-stack";
8
+ export { init, Project, InitArgs, templates, templatesDir } from "./init";
9
+ export { get, GetStatus, runGetInDir } from "./get";
10
+ export { SynthesizedStack } from "./synth-stack";
11
+ export { CdktfProject, ProjectUpdate } from "./cdktf-project";
12
+ export { watch, State as WatchState } from "./watch";
13
+ export { NestedTerraformOutputs, saveOutputs, normalizeOutputPath, } from "./output";
14
+ export { DeployingResource, DeployingResourceApplyState, isTerraformOutput, PlannedResourceAction, TerraformOutput, } from "./models/terraform";
15
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAOA,OAAO,EACL,iBAAiB,EACjB,kBAAkB,GACnB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAC1E,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,KAAK,EAAE,KAAK,IAAI,UAAU,EAAE,MAAM,SAAS,CAAC;AACrD,OAAO,EACL,sBAAsB,EACtB,WAAW,EACX,mBAAmB,GACpB,MAAM,UAAU,CAAC;AAClB,OAAO,EACL,iBAAiB,EACjB,2BAA2B,EAC3B,iBAAiB,EACjB,qBAAqB,EACrB,eAAe,GAChB,MAAM,oBAAoB,CAAC"}