@cdktn/provider-generator 0.23.0-pre.36 → 0.23.0-pre.39

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 (179) hide show
  1. package/build/__tests__/edge-provider-schema/builder.js +106 -0
  2. package/build/__tests__/edge-provider-schema/cli.js +67 -0
  3. package/build/__tests__/edge-provider-schema/index.js +154 -0
  4. package/build/__tests__/edge-provider-schema.test.js +46 -0
  5. package/build/__tests__/provider.test.js +158 -0
  6. package/build/get/__tests__/constructs-maker.test.js +113 -0
  7. package/build/get/__tests__/generator/complex-computed-types.test.js +42 -0
  8. package/build/get/__tests__/generator/deep-nested-attributes.test.js +50 -0
  9. package/build/get/__tests__/generator/description-escaping.test.js +65 -0
  10. package/build/get/__tests__/generator/empty-provider-resources.test.js +40 -0
  11. package/build/get/__tests__/generator/export-sharding.test.js +82 -0
  12. package/build/get/__tests__/generator/module-generator.test.js +476 -0
  13. package/build/get/__tests__/generator/nested-types.test.js +51 -0
  14. package/build/get/__tests__/generator/provider.test.js +51 -0
  15. package/build/get/__tests__/generator/resource-types.test.js +78 -0
  16. package/build/get/__tests__/generator/skipped-attributes.test.js +55 -0
  17. package/build/get/__tests__/generator/types.test.js +289 -0
  18. package/build/get/__tests__/generator/versions-file.test.js +74 -0
  19. package/build/get/__tests__/util.js +59 -0
  20. package/{lib → build}/get/constructs-maker.d.ts +1 -1
  21. package/build/get/constructs-maker.js +530 -0
  22. package/build/get/generator/custom-defaults.js +403 -0
  23. package/build/get/generator/emitter/attributes-emitter.js +161 -0
  24. package/{lib → build}/get/generator/emitter/index.js +1 -1
  25. package/build/get/generator/emitter/resource-emitter.js +144 -0
  26. package/build/get/generator/emitter/struct-emitter.js +500 -0
  27. package/build/get/generator/loop-detection.js +56 -0
  28. package/build/get/generator/models/attribute-model.js +160 -0
  29. package/build/get/generator/models/attribute-type-model.js +376 -0
  30. package/{lib → build}/get/generator/models/index.js +1 -1
  31. package/build/get/generator/models/resource-model.js +106 -0
  32. package/build/get/generator/models/scope.js +36 -0
  33. package/build/get/generator/models/struct.js +90 -0
  34. package/build/get/generator/module-generator.js +184 -0
  35. package/build/get/generator/provider-generator.js +225 -0
  36. package/build/get/generator/resource-parser.js +497 -0
  37. package/build/get/generator/sanitized-comments.js +44 -0
  38. package/build/get/generator/skipped-attributes.js +29 -0
  39. package/{lib → build}/index.js +1 -1
  40. package/build/util.js +30 -0
  41. package/package.json +6 -6
  42. package/tsconfig.json +5 -3
  43. package/lib/__tests__/edge-provider-schema/builder.js +0 -106
  44. package/lib/__tests__/edge-provider-schema/cli.js +0 -67
  45. package/lib/__tests__/edge-provider-schema/index.js +0 -154
  46. package/lib/__tests__/edge-provider-schema.test.js +0 -46
  47. package/lib/__tests__/provider.test.js +0 -158
  48. package/lib/get/__tests__/constructs-maker.test.js +0 -113
  49. package/lib/get/__tests__/generator/complex-computed-types.test.js +0 -42
  50. package/lib/get/__tests__/generator/deep-nested-attributes.test.js +0 -50
  51. package/lib/get/__tests__/generator/description-escaping.test.js +0 -65
  52. package/lib/get/__tests__/generator/empty-provider-resources.test.js +0 -40
  53. package/lib/get/__tests__/generator/export-sharding.test.js +0 -82
  54. package/lib/get/__tests__/generator/module-generator.test.js +0 -476
  55. package/lib/get/__tests__/generator/nested-types.test.js +0 -51
  56. package/lib/get/__tests__/generator/provider.test.js +0 -51
  57. package/lib/get/__tests__/generator/resource-types.test.js +0 -78
  58. package/lib/get/__tests__/generator/skipped-attributes.test.js +0 -55
  59. package/lib/get/__tests__/generator/types.test.js +0 -289
  60. package/lib/get/__tests__/generator/versions-file.test.js +0 -74
  61. package/lib/get/__tests__/util.js +0 -59
  62. package/lib/get/constructs-maker.js +0 -530
  63. package/lib/get/generator/custom-defaults.js +0 -403
  64. package/lib/get/generator/emitter/attributes-emitter.js +0 -161
  65. package/lib/get/generator/emitter/resource-emitter.js +0 -144
  66. package/lib/get/generator/emitter/struct-emitter.js +0 -500
  67. package/lib/get/generator/loop-detection.js +0 -56
  68. package/lib/get/generator/models/attribute-model.js +0 -160
  69. package/lib/get/generator/models/attribute-type-model.js +0 -376
  70. package/lib/get/generator/models/resource-model.js +0 -106
  71. package/lib/get/generator/models/scope.js +0 -36
  72. package/lib/get/generator/models/struct.js +0 -90
  73. package/lib/get/generator/module-generator.js +0 -184
  74. package/lib/get/generator/provider-generator.js +0 -225
  75. package/lib/get/generator/resource-parser.js +0 -497
  76. package/lib/get/generator/sanitized-comments.js +0 -44
  77. package/lib/get/generator/skipped-attributes.js +0 -29
  78. package/lib/util.js +0 -30
  79. /package/{lib → build}/__tests__/edge-provider-schema/builder.d.ts +0 -0
  80. /package/{lib → build}/__tests__/edge-provider-schema/cli.d.ts +0 -0
  81. /package/{lib → build}/__tests__/edge-provider-schema/index.d.ts +0 -0
  82. /package/{lib → build}/__tests__/edge-provider-schema.test.d.ts +0 -0
  83. /package/{lib → build}/__tests__/provider.test.d.ts +0 -0
  84. /package/{lib → build}/get/__tests__/constructs-maker.test.d.ts +0 -0
  85. /package/{lib → build}/get/__tests__/generator/complex-computed-types.test.d.ts +0 -0
  86. /package/{lib → build}/get/__tests__/generator/deep-nested-attributes.test.d.ts +0 -0
  87. /package/{lib → build}/get/__tests__/generator/description-escaping.test.d.ts +0 -0
  88. /package/{lib → build}/get/__tests__/generator/empty-provider-resources.test.d.ts +0 -0
  89. /package/{lib → build}/get/__tests__/generator/export-sharding.test.d.ts +0 -0
  90. /package/{lib → build}/get/__tests__/generator/module-generator.test.d.ts +0 -0
  91. /package/{lib → build}/get/__tests__/generator/nested-types.test.d.ts +0 -0
  92. /package/{lib → build}/get/__tests__/generator/provider.test.d.ts +0 -0
  93. /package/{lib → build}/get/__tests__/generator/resource-types.test.d.ts +0 -0
  94. /package/{lib → build}/get/__tests__/generator/skipped-attributes.test.d.ts +0 -0
  95. /package/{lib → build}/get/__tests__/generator/types.test.d.ts +0 -0
  96. /package/{lib → build}/get/__tests__/generator/versions-file.test.d.ts +0 -0
  97. /package/{lib → build}/get/__tests__/util.d.ts +0 -0
  98. /package/{lib → build}/get/generator/custom-defaults.d.ts +0 -0
  99. /package/{lib → build}/get/generator/emitter/attributes-emitter.d.ts +0 -0
  100. /package/{lib → build}/get/generator/emitter/index.d.ts +0 -0
  101. /package/{lib → build}/get/generator/emitter/resource-emitter.d.ts +0 -0
  102. /package/{lib → build}/get/generator/emitter/struct-emitter.d.ts +0 -0
  103. /package/{lib → build}/get/generator/loop-detection.d.ts +0 -0
  104. /package/{lib → build}/get/generator/models/attribute-model.d.ts +0 -0
  105. /package/{lib → build}/get/generator/models/attribute-type-model.d.ts +0 -0
  106. /package/{lib → build}/get/generator/models/index.d.ts +0 -0
  107. /package/{lib → build}/get/generator/models/resource-model.d.ts +0 -0
  108. /package/{lib → build}/get/generator/models/scope.d.ts +0 -0
  109. /package/{lib → build}/get/generator/models/struct.d.ts +0 -0
  110. /package/{lib → build}/get/generator/module-generator.d.ts +0 -0
  111. /package/{lib → build}/get/generator/provider-generator.d.ts +0 -0
  112. /package/{lib → build}/get/generator/resource-parser.d.ts +0 -0
  113. /package/{lib → build}/get/generator/sanitized-comments.d.ts +0 -0
  114. /package/{lib → build}/get/generator/skipped-attributes.d.ts +0 -0
  115. /package/{lib → build}/index.d.ts +0 -0
  116. /package/{lib → build}/util.d.ts +0 -0
  117. /package/{lib → src}/__tests__/__snapshots__/edge-provider-schema.test.ts.snap +0 -0
  118. /package/{lib → src}/__tests__/__snapshots__/provider.test.ts.snap +0 -0
  119. /package/{lib → src}/get/__tests__/generator/__snapshots__/complex-computed-types.test.ts.snap +0 -0
  120. /package/{lib → src}/get/__tests__/generator/__snapshots__/description-escaping.test.ts.snap +0 -0
  121. /package/{lib → src}/get/__tests__/generator/__snapshots__/export-sharding.test.ts.snap +0 -0
  122. /package/{lib → src}/get/__tests__/generator/__snapshots__/module-generator.test.ts.snap +0 -0
  123. /package/{lib → src}/get/__tests__/generator/__snapshots__/nested-types.test.ts.snap +0 -0
  124. /package/{lib → src}/get/__tests__/generator/__snapshots__/provider.test.ts.snap +0 -0
  125. /package/{lib → src}/get/__tests__/generator/__snapshots__/resource-types.test.ts.snap +0 -0
  126. /package/{lib → src}/get/__tests__/generator/__snapshots__/skipped-attributes.test.ts.snap +0 -0
  127. /package/{lib → src}/get/__tests__/generator/__snapshots__/types.test.ts.snap +0 -0
  128. /package/{lib → src}/get/__tests__/generator/fixtures/aws-provider.test.fixture.json +0 -0
  129. /package/{lib → src}/get/__tests__/generator/fixtures/aws_acm_certificate.test.fixture.json +0 -0
  130. /package/{lib → src}/get/__tests__/generator/fixtures/aws_cloudfront_distribution.test.fixture.json +0 -0
  131. /package/{lib → src}/get/__tests__/generator/fixtures/aws_fms_admin_account.test.fixture.json +0 -0
  132. /package/{lib → src}/get/__tests__/generator/fixtures/aws_quicksight_template.test.fixture.json +0 -0
  133. /package/{lib → src}/get/__tests__/generator/fixtures/aws_s3_bucket.test.fixture.json +0 -0
  134. /package/{lib → src}/get/__tests__/generator/fixtures/aws_security_group.test.fixture.json +0 -0
  135. /package/{lib → src}/get/__tests__/generator/fixtures/aws_wafv2_web_acl.test.fixture.json +0 -0
  136. /package/{lib → src}/get/__tests__/generator/fixtures/block-type-nested-computed-list.test.fixture.json +0 -0
  137. /package/{lib → src}/get/__tests__/generator/fixtures/block-type-set-list.test.fixture.json +0 -0
  138. /package/{lib → src}/get/__tests__/generator/fixtures/boolean-list.test.fixture.json +0 -0
  139. /package/{lib → src}/get/__tests__/generator/fixtures/boolean-map.test.fixture.json +0 -0
  140. /package/{lib → src}/get/__tests__/generator/fixtures/comment-ending-sequence.test.fixture.json +0 -0
  141. /package/{lib → src}/get/__tests__/generator/fixtures/computed-complex-nested.test.fixture.json +0 -0
  142. /package/{lib → src}/get/__tests__/generator/fixtures/computed-complex.test.fixture.json +0 -0
  143. /package/{lib → src}/get/__tests__/generator/fixtures/computed-optional-complex.test.fixture.json +0 -0
  144. /package/{lib → src}/get/__tests__/generator/fixtures/data_aws_quicksight_analysis.fixture.json +0 -0
  145. /package/{lib → src}/get/__tests__/generator/fixtures/datadog_dashboard.test.fixture.json +0 -0
  146. /package/{lib → src}/get/__tests__/generator/fixtures/datadog_spans_metric.test.fixture.json +0 -0
  147. /package/{lib → src}/get/__tests__/generator/fixtures/deep-attributes.test.fixture.json +0 -0
  148. /package/{lib → src}/get/__tests__/generator/fixtures/deeply-nested-block-types.test.fixture.json +0 -0
  149. /package/{lib → src}/get/__tests__/generator/fixtures/description-escaping.test.fixture.json +0 -0
  150. /package/{lib → src}/get/__tests__/generator/fixtures/elasticstack-provider.test.fixture.json +0 -0
  151. /package/{lib → src}/get/__tests__/generator/fixtures/empty-provider-resources.test.fixture.json +0 -0
  152. /package/{lib → src}/get/__tests__/generator/fixtures/ignored-attributes.test.fixture.json +0 -0
  153. /package/{lib → src}/get/__tests__/generator/fixtures/incompatible-attribute-names.test.fixture.json +0 -0
  154. /package/{lib → src}/get/__tests__/generator/fixtures/incompatible-resource-names.test.fixture.json +0 -0
  155. /package/{lib → src}/get/__tests__/generator/fixtures/list-list-object.test.fixture.json +0 -0
  156. /package/{lib → src}/get/__tests__/generator/fixtures/list-list-string.test.fixture.json +0 -0
  157. /package/{lib → src}/get/__tests__/generator/fixtures/list-of-string-map.test.fixture.json +0 -0
  158. /package/{lib → src}/get/__tests__/generator/fixtures/map-of-map-of-string.test.fixture.json +0 -0
  159. /package/{lib → src}/get/__tests__/generator/fixtures/map-of-string-list.test.fixture.json +0 -0
  160. /package/{lib → src}/get/__tests__/generator/fixtures/markdown-description-with-code-blocks.test.fixture.json +0 -0
  161. /package/{lib → src}/get/__tests__/generator/fixtures/module-get-x.test.fixture.tf +0 -0
  162. /package/{lib → src}/get/__tests__/generator/fixtures/module-no-newline-1.test.fixture.tf +0 -0
  163. /package/{lib → src}/get/__tests__/generator/fixtures/module-no-newline-2.test.fixture.tf +0 -0
  164. /package/{lib → src}/get/__tests__/generator/fixtures/module-no-outputs.test.fixture.tf +0 -0
  165. /package/{lib → src}/get/__tests__/generator/fixtures/module-no-variable-type.test.fixture.tf +0 -0
  166. /package/{lib → src}/get/__tests__/generator/fixtures/module-with-star-default.test.fixture.tf +0 -0
  167. /package/{lib → src}/get/__tests__/generator/fixtures/name-conflict.test.fixture.json +0 -0
  168. /package/{lib → src}/get/__tests__/generator/fixtures/nested-type-without-attributes.test.fixture.json +0 -0
  169. /package/{lib → src}/get/__tests__/generator/fixtures/nested-types.test.fixture.json +0 -0
  170. /package/{lib → src}/get/__tests__/generator/fixtures/number-list.test.fixture.json +0 -0
  171. /package/{lib → src}/get/__tests__/generator/fixtures/number-map.test.fixture.json +0 -0
  172. /package/{lib → src}/get/__tests__/generator/fixtures/primitive-boolean.test.fixture.json +0 -0
  173. /package/{lib → src}/get/__tests__/generator/fixtures/primitive-dynamic.test.fixture.json +0 -0
  174. /package/{lib → src}/get/__tests__/generator/fixtures/primitive-number.test.fixture.json +0 -0
  175. /package/{lib → src}/get/__tests__/generator/fixtures/primitive-string.test.fixture.json +0 -0
  176. /package/{lib → src}/get/__tests__/generator/fixtures/single-block-type.test.fixture.json +0 -0
  177. /package/{lib → src}/get/__tests__/generator/fixtures/string-list.test.fixture.json +0 -0
  178. /package/{lib → src}/get/__tests__/generator/fixtures/string-map.test.fixture.json +0 -0
  179. /package/{lib → src}/get/__tests__/generator/fixtures/stripe-schema.test.fixture.json +0 -0
@@ -1,530 +0,0 @@
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.determineGoModuleName = exports.ConstructsMaker = exports.generateJsiiLanguage = void 0;
27
- // Copyright (c) HashiCorp, Inc
28
- // SPDX-License-Identifier: MPL-2.0
29
- const fs = __importStar(require("fs-extra"));
30
- const path = __importStar(require("path"));
31
- const codemaker_1 = require("codemaker");
32
- const commons_1 = require("@cdktn/commons");
33
- const commons_2 = require("@cdktn/commons");
34
- const commons_3 = require("@cdktn/commons");
35
- const provider_generator_1 = require("./generator/provider-generator");
36
- const module_generator_1 = require("./generator/module-generator");
37
- const glob_1 = require("glob");
38
- const provider_schema_1 = require("@cdktn/provider-schema");
39
- const pacmakModule = require.resolve("jsii-pacmak/bin/jsii-pacmak");
40
- const jsiiModule = require.resolve("jsii/bin/jsii");
41
- async function generateJsiiLanguage(code, opts, outputPath, disallowedFileGlobs = []) {
42
- await (0, commons_1.mkdtemp)(async (staging) => {
43
- // this is not typescript, so we generate in a staging directory and
44
- // use jsii-srcmak to compile and extract the language-specific source
45
- // into our project.
46
- await code.save(staging);
47
- // as the above generated the Typescript code for all providers and modules,
48
- // we need to filter out the ones we don't need so they don't end up in the JSII bundle over and over again.
49
- const filesToDelete = disallowedFileGlobs.flatMap((pattern) => glob_1.glob.sync(pattern, { cwd: staging }));
50
- await Promise.all(filesToDelete.map((file) => fs.remove(path.join(staging, file))));
51
- // Compile with JSII
52
- const jsiiArgs = ["--silence-warnings", "reserved-word"];
53
- const jsiiEntrypoint = opts.entrypoint;
54
- const basepath = path.join(path.dirname(jsiiEntrypoint), path.basename(jsiiEntrypoint, ".ts"));
55
- const moduleKey = opts.moduleKey.replace(/\./g, "").replace(/\//g, "");
56
- const moduleDirs = opts.deps;
57
- const targets = {};
58
- const deps = {};
59
- for (const dir of moduleDirs) {
60
- // read module metadata
61
- const metadata = await fs.readJson(path.join(dir, "package.json"));
62
- const moduleName = metadata.name;
63
- const moduleVersion = metadata.version;
64
- const targetdir = path.join(path.join(staging, "node_modules"), moduleName);
65
- await fs.mkdirp(path.dirname(targetdir));
66
- await fs.copy(dir, targetdir);
67
- // add to "deps" and "peer deps"
68
- if (!moduleName.startsWith("@types/")) {
69
- deps[moduleName] = moduleVersion;
70
- }
71
- }
72
- const pkg = {
73
- name: moduleKey,
74
- version: "0.0.0",
75
- author: "generated@generated.com",
76
- main: `${basepath}.js`,
77
- types: `${basepath}.d.ts`,
78
- license: "UNLICENSED",
79
- repository: { url: "http://generated", type: "git" },
80
- jsii: {
81
- outdir: "dist",
82
- targets: targets,
83
- },
84
- dependencies: deps,
85
- peerDependencies: deps,
86
- };
87
- if (opts.exports) {
88
- pkg.exports = opts.exports;
89
- }
90
- if (opts.python) {
91
- targets.python = {
92
- distName: "generated",
93
- module: opts.python.moduleName,
94
- };
95
- }
96
- if (opts.java) {
97
- targets.java = {
98
- package: opts.java.package,
99
- maven: {
100
- groupId: "generated",
101
- artifactId: "generated",
102
- },
103
- };
104
- }
105
- if (opts.csharp) {
106
- targets.dotnet = {
107
- namespace: opts.csharp.namespace,
108
- packageId: opts.csharp.namespace,
109
- };
110
- }
111
- if (opts.golang) {
112
- targets.go = {
113
- moduleName: opts.golang.moduleName,
114
- packageName: opts.golang.packageName,
115
- };
116
- }
117
- await fs.writeFile(path.join(staging, "package.json"), JSON.stringify(pkg, undefined, 2));
118
- const endJsiiTimer = (0, commons_2.logTimespan)("jsii");
119
- await (0, commons_1.exec)(jsiiModule, jsiiArgs, {
120
- cwd: staging,
121
- });
122
- endJsiiTimer();
123
- // extract .jsii if requested
124
- if (opts.jsii) {
125
- await fs.copy(path.join(staging, ".jsii"), opts.jsii.path);
126
- }
127
- // run pacmak to generate code
128
- const endJsiiPacmakTimer = (0, commons_2.logTimespan)("jsii-pacmak");
129
- await (0, commons_1.exec)(pacmakModule, ["--code-only"], { cwd: staging });
130
- endJsiiPacmakTimer();
131
- if (opts.python) {
132
- const reldir = opts.python.moduleName.replace(/\./g, "/"); // jsii replaces "." with "/"
133
- const source = path.resolve(path.join(staging, "dist/python/src", reldir));
134
- const target = path.join(opts.python.outdir, reldir);
135
- await fs.move(source, target, { overwrite: true });
136
- }
137
- if (opts.java) {
138
- const source = path.resolve(path.join(staging, "dist/java/src/"));
139
- const target = path.join(opts.java.outdir, "src/");
140
- await fs.mkdirp(target); // make sure target directory exists
141
- await fs.copy(source, target, { recursive: true, overwrite: false });
142
- }
143
- if (opts.csharp) {
144
- const reldir = opts.csharp.namespace;
145
- const source = path.resolve(path.join(staging, "dist/dotnet/", reldir));
146
- const target = path.join(opts.csharp.outdir, reldir);
147
- await fs.move(source, target, { overwrite: true });
148
- }
149
- if (opts.golang) {
150
- const reldir = opts.golang.packageName;
151
- const source = path.resolve(path.join(staging, "dist/go/", reldir));
152
- const target = path.join(opts.golang.outdir, reldir);
153
- await fs.move(source, target, { overwrite: true });
154
- // remove go.mod as this would make it a submodule
155
- await fs.remove(path.join(target, "go.mod"));
156
- }
157
- ["versions.json", "constraints.json"].forEach((file) => {
158
- try {
159
- fs.copySync(path.resolve(staging, file), path.resolve(outputPath, file));
160
- }
161
- catch (e) {
162
- commons_2.logger.debug(`Failed to copy ${file}: ${e}`);
163
- }
164
- });
165
- });
166
- }
167
- exports.generateJsiiLanguage = generateJsiiLanguage;
168
- class ConstructsMaker {
169
- constructor(options, schemaCachePath, reportTelemetry = async () => { }) {
170
- this.options = options;
171
- this.schemaCachePath = schemaCachePath;
172
- this.reportTelemetry = reportTelemetry;
173
- this.codeMakerOutdir = path.resolve(this.options.codeMakerOutput);
174
- fs.mkdirpSync(this.codeMakerOutdir);
175
- this.code = new codemaker_1.CodeMaker();
176
- this.versions = {};
177
- }
178
- async generateTypescriptProvider(target, schema) {
179
- const endTSTimer = (0, commons_2.logTimespan)(`Generate Typescript for ${target.name}`);
180
- const generator = new provider_generator_1.TerraformProviderGenerator(this.code, schema);
181
- generator.generate(target);
182
- this.versions = { ...this.versions, ...generator.versions };
183
- endTSTimer();
184
- }
185
- async filterAlreadyGenerated(constraints) {
186
- let constraintsFile = "{}";
187
- try {
188
- constraintsFile = await fs.readFile(path.join(this.codeMakerOutdir, "constraints.json"), "utf8");
189
- }
190
- catch (e) {
191
- commons_2.logger.debug(`Could not find constraints.json file while filtering: ${e}. This means no providers were generated, so all constraints need to be generated.`);
192
- return constraints;
193
- }
194
- commons_2.logger.debug(`Found constraints.json file: ${constraintsFile}`);
195
- let previousConstraints = {};
196
- try {
197
- previousConstraints = JSON.parse(constraintsFile);
198
- }
199
- catch (e) {
200
- commons_2.logger.info(`Could not parse constraints.json file while filtering: ${e}. Generating all constraints.`);
201
- return constraints;
202
- }
203
- commons_2.logger.debug(`Found previous constraints: ${JSON.stringify(previousConstraints, null, 2)}`);
204
- if (!previousConstraints.providers ||
205
- typeof previousConstraints.providers !== "object") {
206
- commons_2.logger.info(`Could not find providers in constraints.json file, generating all constraints. The constraints file was ${JSON.stringify(previousConstraints, null, 2)}`);
207
- return constraints;
208
- }
209
- if (previousConstraints.cdktf !== commons_3.DISPLAY_VERSION) {
210
- commons_2.logger.info(`The CDKTN version has changed, generating all constraints. The previous version was ${previousConstraints.cdktf}, the current version is ${commons_3.DISPLAY_VERSION}`);
211
- return constraints;
212
- }
213
- const constraintsToGenerate = constraints.filter((constraint) => {
214
- const constraintMatches = previousConstraints.providers[constraint.fqn] === constraint.version;
215
- let providerFolderExists = false;
216
- switch (this.options.targetLanguage) {
217
- case commons_3.Language.TYPESCRIPT:
218
- providerFolderExists = fs.existsSync(path.join(this.codeMakerOutdir, "providers", constraint.name));
219
- break;
220
- case commons_3.Language.PYTHON:
221
- case commons_3.Language.JAVA:
222
- case commons_3.Language.CSHARP:
223
- providerFolderExists = fs.existsSync(path.join(this.codeMakerOutdir, constraint.name));
224
- break;
225
- case commons_3.Language.GO:
226
- providerFolderExists = fs.existsSync(path.join(this.codeMakerOutdir, constraint.namespace || "hashicorp", constraint.name));
227
- break;
228
- }
229
- const providerExists = constraintMatches && providerFolderExists;
230
- return !providerExists;
231
- });
232
- commons_2.logger.debug(`Constraints to generate: ${JSON.stringify(constraintsToGenerate, null, 2)}`);
233
- return constraintsToGenerate;
234
- }
235
- async generateTypescriptModule(target, schema) {
236
- const endTSTimer = (0, commons_2.logTimespan)(`Generate Typescript for ${target.name}`);
237
- target.spec = schema;
238
- new module_generator_1.ModuleGenerator(this.code, [target]);
239
- endTSTimer();
240
- }
241
- async generateTypescript(target, schemas) {
242
- var _a;
243
- if (target.isModule) {
244
- const schema = (_a = schemas.moduleSchema) === null || _a === void 0 ? void 0 : _a[target.moduleKey];
245
- if (!schema) {
246
- throw commons_2.Errors.Internal(`Could not generate schema for module ${target.moduleKey}`);
247
- }
248
- await this.generateTypescriptModule(target, schema);
249
- }
250
- else if (target.isProvider) {
251
- if (!schemas.providerSchema) {
252
- throw commons_2.Errors.Internal(`Could not generate schema for providers`);
253
- }
254
- await this.generateTypescriptProvider(target, schemas.providerSchema);
255
- }
256
- else {
257
- throw new Error(`Unknown target type used to generate bindings: ${target.name}`);
258
- }
259
- }
260
- // emits a versions.json file with a map of the used version for each provider fqpn
261
- updateVersionsFile(allowedConstraints) {
262
- commons_2.logger.debug(`Updating versions file with generated versions ${JSON.stringify(this.versions, null, 2)} with allowed constraints ${JSON.stringify(allowedConstraints, null, 2)}`);
263
- const filePath = "versions.json";
264
- let previousVersions = {};
265
- try {
266
- previousVersions = JSON.parse(fs.readFileSync(path.resolve(this.codeMakerOutdir, filePath), "utf8"));
267
- commons_2.logger.debug(`Read existing versions file: ${JSON.stringify(previousVersions, null, 2)}`);
268
- }
269
- catch (e) {
270
- // ignore
271
- commons_2.logger.debug(`Could not read versions file, this is expected if there are no pre-existing local providers: ${e}`);
272
- }
273
- const versions = allowedConstraints.reduce((acc, constraint) => {
274
- const provider = Object.entries(previousVersions).find(([name]) =>
275
- // This could be more refined, but it's good enough for now
276
- name.endsWith(constraint.fqn));
277
- if (provider) {
278
- const [name, version] = provider;
279
- return { ...acc, [name]: version };
280
- }
281
- return acc;
282
- }, {});
283
- commons_2.logger.debug(`Writing versions file (${filePath}): ${JSON.stringify(versions, null, 2)}`);
284
- this.code.openFile(filePath);
285
- this.code.line(JSON.stringify({ ...versions, ...this.versions }, null, 2));
286
- this.code.closeFile(filePath);
287
- return filePath;
288
- }
289
- async removeFoldersThatShouldNotExist(constraintsThatShouldExist) {
290
- commons_2.logger.debug(`Removing providers except for ${JSON.stringify(constraintsThatShouldExist, null, 2)}`);
291
- // All languages besides TS keep their providers in the same folders as modules
292
- // this makes it impossible for us to distinguish a no longer required provider
293
- // from a manually written construct or a module
294
- if (!this.isJavascriptTarget) {
295
- return;
296
- }
297
- let filesInProviders = [];
298
- const providersFolder = path.resolve(this.codeMakerOutdir, "providers");
299
- try {
300
- filesInProviders = await fs.readdir(providersFolder);
301
- }
302
- catch (e) {
303
- commons_2.logger.debug(`Error listing files in providers folder '${providersFolder}': ${e}`);
304
- }
305
- const folders = filesInProviders.filter((file) => fs
306
- .statSync(path.resolve(this.codeMakerOutdir, "providers", file))
307
- .isDirectory());
308
- return folders.forEach((folder) => {
309
- const shouldExist = constraintsThatShouldExist.some((constraint) => constraint.name === folder);
310
- if (!shouldExist) {
311
- commons_2.logger.debug(`Removing folder ${folder} from providers`);
312
- fs.removeSync(path.resolve(this.codeMakerOutdir, "providers", folder));
313
- }
314
- });
315
- }
316
- // emits a constraints.json file with a map of the used provider fqpns and version constraints
317
- // this is used for caching purposes
318
- emitConstraintsFile(allowedConstraints) {
319
- const filePath = "constraints.json";
320
- const content = {
321
- cdktf: commons_3.DISPLAY_VERSION,
322
- providers: allowedConstraints
323
- .sort((a, b) => a.fqn.localeCompare(b.fqn))
324
- .reduce((carry, item) => ({
325
- ...carry,
326
- [item.fqn]: item.version,
327
- }), {}),
328
- };
329
- this.code.openFile(filePath);
330
- this.code.line(JSON.stringify(content, null, 2));
331
- this.code.closeFile(filePath);
332
- return filePath;
333
- }
334
- async generateJsiiLanguage(target) {
335
- var _a;
336
- // these are the module dependencies we compile against
337
- const deps = ["@types/node", "constructs", "cdktn"];
338
- const opts = {
339
- entrypoint: target.fileName,
340
- deps: deps.map((dep) => path.dirname(require.resolve(`${dep}/package.json`))),
341
- moduleKey: target.moduleKey,
342
- exports: target.isProvider // Modules are small enough that we don't need this optimization
343
- ? {
344
- ".": {
345
- import: `./providers/${target.name}/index.js`,
346
- require: `./providers/${target.name}/lazy-index.js`,
347
- },
348
- }
349
- : undefined,
350
- };
351
- // used for testing.
352
- if (this.options.outputJsii) {
353
- opts.jsii = { path: this.options.outputJsii };
354
- }
355
- if (this.isPythonTarget) {
356
- opts.python = {
357
- outdir: this.codeMakerOutdir,
358
- moduleName: target.srcMakName,
359
- };
360
- }
361
- if (this.isJavaTarget) {
362
- if (this.options.codeMakerOutput.includes("/") ||
363
- this.options.codeMakerOutput.includes("\\")) {
364
- throw commons_2.Errors.Usage(`When using Java the "codeMakerOutput" option in the cdktf.json must be the organization identifier for your project (e.g. com.my-company), not a path. The generated Java code will be placed in a subdirectory of the given directory. If you are migrating from a < 0.19 version of cdktf you want to change the codemakerOutput to "imports".`);
365
- }
366
- opts.java = {
367
- outdir: ".", // generated java files aren't packaged, so just include directly in app
368
- package: `${this.options.codeMakerOutput}.${target.srcMakName}`,
369
- };
370
- }
371
- if (this.isCsharpTarget) {
372
- opts.csharp = {
373
- outdir: this.codeMakerOutdir,
374
- namespace: target.srcMakName,
375
- };
376
- }
377
- if (this.isGoTarget) {
378
- // TODO: check if needed for modules somehow
379
- // const targetType = target.isProvider ? 'provider' : 'module';
380
- // jsii-srcmac will produce a folder inside this dir named after "packageName"
381
- // so this results in e.g. .gen/hashicorp/random
382
- const outdir = path.join(this.codeMakerOutdir, (_a = target.namespace) !== null && _a !== void 0 ? _a : "");
383
- opts.golang = {
384
- outdir,
385
- moduleName: await (0, exports.determineGoModuleName)(outdir), // e.g. `github.com/org/userproject/.gen/hashicorp`
386
- packageName: target.srcMakName, // package will be named e.g. random for hashicorp/random
387
- };
388
- }
389
- if (process.env.NODE_OPTIONS &&
390
- !process.env.NODE_OPTIONS.includes(`--max-old-space-size`)) {
391
- commons_2.logger.warn(`found NODE_OPTIONS environment variable without a setting for --max-old-space-size.
392
- The provider generation needs a substantial amount of memory (~13GB) for some providers and languages.
393
- So cdktn-cli sets it to NODE_OPTIONS="--max-old-space-size=16384" by default. As your environment already contains
394
- a NODE_OPTIONS variable, we won't override it. Hence, the provider generation might fail with an out of memory error.`);
395
- }
396
- else {
397
- // increase memory to allow generating large providers (i.e. aws or azurerm for Go)
398
- // srcmak is going to spawn a childprocess (for jsii-pacmak) which is going to be affected by this env var
399
- process.env.NODE_OPTIONS = "--max-old-space-size=16384";
400
- }
401
- const jsiiTimer = (0, commons_2.logTimespan)("JSII");
402
- await generateJsiiLanguage(this.code, opts, this.codeMakerOutdir, [
403
- target.isModule ? "providers/**" : "modules/**",
404
- ]);
405
- jsiiTimer();
406
- }
407
- async getSchemas(targets) {
408
- return await (0, provider_schema_1.readSchema)(targets, this.schemaCachePath);
409
- }
410
- async generate(allConstraints, constraintsToGenerate = allConstraints) {
411
- const targets = constraintsToGenerate.map((constraint) => commons_2.ConstructsMakerTarget.from(constraint, this.options.targetLanguage));
412
- const endSchemaTimer = (0, commons_2.logTimespan)("Gathering schema");
413
- const schemas = await this.getSchemas(constraintsToGenerate);
414
- endSchemaTimer();
415
- const endGenerateTimer = (0, commons_2.logTimespan)("Generate TS");
416
- await Promise.all(targets.map((target) => this.generateTypescript(target, schemas)));
417
- endGenerateTimer();
418
- this.updateVersionsFile(allConstraints);
419
- this.emitConstraintsFile(allConstraints);
420
- if (this.isJavascriptTarget) {
421
- await this.save();
422
- }
423
- if (!this.isJavascriptTarget || this.options.outputJsii) {
424
- const numberOfWorkers = Math.max(1, this.options.jsiiParallelism === -1
425
- ? targets.length
426
- : this.options.jsiiParallelism || 1);
427
- const work = [...targets];
428
- const workers = new Array(numberOfWorkers).fill(async () => {
429
- let target;
430
- while ((target = work.pop())) {
431
- const endJsiiTarget = (0, commons_2.logTimespan)(`Generating JSII bindings for ${target.name}`);
432
- await this.generateJsiiLanguage(target);
433
- endJsiiTarget();
434
- }
435
- });
436
- await Promise.all(workers.map((fn) => fn()));
437
- }
438
- for (const target of targets) {
439
- await this.reportTelemetry({
440
- trackingPayload: target.trackingPayload,
441
- targetLanguage: target.targetLanguage,
442
- });
443
- }
444
- if (this.isPythonTarget) {
445
- const endPythonTimer = (0, commons_2.logTimespan)("Python post-processing");
446
- // Remove from . import ... statements from root level __init__.py
447
- // This removes root-level imports of namespaces, but saves 25s synth time for the aws provider alone
448
- const allInitPyPaths = glob_1.glob
449
- .sync("**/__init__.py", {
450
- cwd: this.codeMakerOutdir,
451
- })
452
- // sort by depth, so we start with the shallowest files
453
- .sort((a, b) => a.split("/").length - b.split("/").length);
454
- const visitedDirectories = [];
455
- for (const initPyPath of allInitPyPaths) {
456
- const directoryPath = path.dirname(initPyPath);
457
- if (visitedDirectories.some((dir) => directoryPath.startsWith(dir))) {
458
- // we already processed this directory
459
- continue;
460
- }
461
- visitedDirectories.push(directoryPath);
462
- const absoluteInitPyPath = path.join(this.codeMakerOutdir, initPyPath);
463
- const initPy = await fs.readFile(absoluteInitPyPath, "utf8");
464
- const initPyWithoutImports = initPy.replace(/from \. import .*\n/g, "");
465
- await fs.writeFile(absoluteInitPyPath, initPyWithoutImports);
466
- }
467
- endPythonTimer();
468
- }
469
- }
470
- async save(outdir = this.codeMakerOutdir) {
471
- await this.code.save(outdir);
472
- }
473
- get isJavascriptTarget() {
474
- return this.options.targetLanguage === commons_3.Language.TYPESCRIPT;
475
- }
476
- get isPythonTarget() {
477
- return this.options.targetLanguage === commons_3.Language.PYTHON;
478
- }
479
- get isJavaTarget() {
480
- return this.options.targetLanguage === commons_3.Language.JAVA;
481
- }
482
- get isCsharpTarget() {
483
- return this.options.targetLanguage === commons_3.Language.CSHARP;
484
- }
485
- get isGoTarget() {
486
- return this.options.targetLanguage === commons_3.Language.GO;
487
- }
488
- }
489
- exports.ConstructsMaker = ConstructsMaker;
490
- /**
491
- * searches for the closest `go.mod` file and returns the nested go module name for `dir`
492
- * e.g. (/dir/.gen/) => cdk.tf/stack/.gen if the parent dir of .gen has a go.mod for "module cdk.tf/stack"
493
- *
494
- * @param dir the directory to start the search from (searches upwards)
495
- * @returns the package name for `dir`
496
- * @throws an Error if no go.mod was found
497
- */
498
- const determineGoModuleName = async (dir) => {
499
- let previousDir;
500
- let currentDir = path.resolve(dir);
501
- do {
502
- let files = [];
503
- try {
504
- files = await fs.readdir(currentDir);
505
- }
506
- catch (e) {
507
- // directory might not exist yet, but we still walk upwards from there, so ignore 'ENOENT'
508
- if (e.code !== "ENOENT") {
509
- throw e;
510
- }
511
- }
512
- if (files.includes("go.mod")) {
513
- const file = path.resolve(currentDir, "go.mod");
514
- const gomod = await fs.readFile(file);
515
- const match = /^module\s*(\S*)\s*$/m.exec(gomod.toString());
516
- if (match && match[1]) {
517
- const childdir = path.relative(currentDir, dir).replace(/\\/g, "/"); // replace '\' with '/' for windows paths
518
- return childdir.length > 0 ? `${match[1]}/${childdir}` : match[1];
519
- }
520
- throw new Error(`Could not determine the root Go module name. Found ${file} but failed to regex match the module name directive`);
521
- }
522
- // go up one directory. As dirname('/') will return '/' we cancel the loop
523
- // as soon as the dir does not change anymore.
524
- previousDir = currentDir;
525
- currentDir = path.dirname(currentDir);
526
- } while (currentDir !== previousDir);
527
- throw new Error(`Could not determine the root Go module name. No go.mod found in ${dir} and any parent directories`);
528
- };
529
- exports.determineGoModuleName = determineGoModuleName;
530
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructs-maker.js","sourceRoot":"","sources":["constructs-maker.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport * as fs from \"fs-extra\";\nimport * as path from \"path\";\nimport { CodeMaker } from \"codemaker\";\nimport { exec, mkdtemp } from \"@cdktn/commons\";\nimport {\n  TerraformDependencyConstraint,\n  logger,\n  logTimespan,\n  ConstructsMakerProviderTarget,\n  ConstructsMakerModuleTarget,\n  ConstructsMakerTarget,\n  ProviderSchema,\n  ModuleSchema,\n  Errors,\n} from \"@cdktn/commons\";\nimport { DISPLAY_VERSION, Language } from \"@cdktn/commons\";\nimport { TerraformProviderGenerator } from \"./generator/provider-generator\";\nimport { ModuleGenerator } from \"./generator/module-generator\";\nimport { glob } from \"glob\";\nimport { readSchema } from \"@cdktn/provider-schema\";\n\nconst pacmakModule = require.resolve(\"jsii-pacmak/bin/jsii-pacmak\");\nconst jsiiModule = require.resolve(\"jsii/bin/jsii\");\n\nexport interface GenerateJSIIOptions {\n  entrypoint: string;\n  deps: string[];\n  moduleKey: string;\n  exports?: Record<string, ExportDefinition | string>;\n  jsii?: JsiiOutputOptions;\n  python?: PythonOutputOptions;\n  java?: JavaOutputOptions;\n  csharp?: CSharpOutputOptions;\n  golang?: GoLangOutputOptions;\n}\n\nexport interface JsiiOutputOptions {\n  path: string;\n}\n\nexport interface PythonOutputOptions {\n  outdir: string;\n  moduleName: string;\n}\n\nexport interface JavaOutputOptions {\n  outdir: string;\n  package: string;\n}\n\nexport interface CSharpOutputOptions {\n  outdir: string;\n  namespace: string;\n}\n\nexport interface GoLangOutputOptions {\n  outdir: string;\n  moduleName: string;\n  packageName: string;\n}\n\n/**\n * See https://nodejs.org/api/packages.html#conditional-exports for more information\n */\nexport interface ExportDefinition {\n  node?: string;\n  import?: string;\n  require?: string;\n  default?: string;\n}\n\nexport async function generateJsiiLanguage(\n  code: CodeMaker,\n  opts: GenerateJSIIOptions,\n  outputPath: string,\n  disallowedFileGlobs: string[] = [],\n) {\n  await mkdtemp(async (staging) => {\n    // this is not typescript, so we generate in a staging directory and\n    // use jsii-srcmak to compile and extract the language-specific source\n    // into our project.\n    await code.save(staging);\n\n    // as the above generated the Typescript code for all providers and modules,\n    // we need to filter out the ones we don't need so they don't end up in the JSII bundle over and over again.\n    const filesToDelete = disallowedFileGlobs.flatMap((pattern) =>\n      glob.sync(pattern, { cwd: staging }),\n    );\n    await Promise.all(\n      filesToDelete.map((file) => fs.remove(path.join(staging, file))),\n    );\n\n    // Compile with JSII\n    const jsiiArgs = [\"--silence-warnings\", \"reserved-word\"];\n    const jsiiEntrypoint = opts.entrypoint;\n    const basepath = path.join(\n      path.dirname(jsiiEntrypoint),\n      path.basename(jsiiEntrypoint, \".ts\"),\n    );\n\n    const moduleKey = opts.moduleKey.replace(/\\./g, \"\").replace(/\\//g, \"\");\n    const moduleDirs = opts.deps;\n    const targets: Record<string, any> = {};\n    const deps: Record<string, string> = {};\n    for (const dir of moduleDirs) {\n      // read module metadata\n      const metadata = await fs.readJson(path.join(dir, \"package.json\"));\n      const moduleName: string = metadata.name;\n      const moduleVersion: string = metadata.version;\n\n      const targetdir = path.join(\n        path.join(staging, \"node_modules\"),\n        moduleName,\n      );\n      await fs.mkdirp(path.dirname(targetdir));\n      await fs.copy(dir, targetdir);\n\n      // add to \"deps\" and \"peer deps\"\n      if (!moduleName.startsWith(\"@types/\")) {\n        deps[moduleName] = moduleVersion;\n      }\n    }\n    const pkg = {\n      name: moduleKey,\n      version: \"0.0.0\",\n      author: \"generated@generated.com\",\n      main: `${basepath}.js`,\n      types: `${basepath}.d.ts`,\n      license: \"UNLICENSED\",\n      repository: { url: \"http://generated\", type: \"git\" },\n      jsii: {\n        outdir: \"dist\",\n        targets: targets,\n      },\n      dependencies: deps,\n      peerDependencies: deps,\n    };\n\n    if (opts.exports) {\n      (pkg as Record<string, any>).exports = opts.exports;\n    }\n    if (opts.python) {\n      targets.python = {\n        distName: \"generated\",\n        module: opts.python.moduleName,\n      };\n    }\n\n    if (opts.java) {\n      targets.java = {\n        package: opts.java.package,\n        maven: {\n          groupId: \"generated\",\n          artifactId: \"generated\",\n        },\n      };\n    }\n\n    if (opts.csharp) {\n      targets.dotnet = {\n        namespace: opts.csharp.namespace,\n        packageId: opts.csharp.namespace,\n      };\n    }\n\n    if (opts.golang) {\n      targets.go = {\n        moduleName: opts.golang.moduleName,\n        packageName: opts.golang.packageName,\n      };\n    }\n\n    await fs.writeFile(\n      path.join(staging, \"package.json\"),\n      JSON.stringify(pkg, undefined, 2),\n    );\n\n    const endJsiiTimer = logTimespan(\"jsii\");\n    await exec(jsiiModule, jsiiArgs, {\n      cwd: staging,\n    });\n    endJsiiTimer();\n\n    // extract .jsii if requested\n    if (opts.jsii) {\n      await fs.copy(path.join(staging, \".jsii\"), opts.jsii.path);\n    }\n\n    // run pacmak to generate code\n    const endJsiiPacmakTimer = logTimespan(\"jsii-pacmak\");\n    await exec(pacmakModule, [\"--code-only\"], { cwd: staging });\n    endJsiiPacmakTimer();\n\n    if (opts.python) {\n      const reldir = opts.python.moduleName.replace(/\\./g, \"/\"); // jsii replaces \".\" with \"/\"\n      const source = path.resolve(\n        path.join(staging, \"dist/python/src\", reldir),\n      );\n      const target = path.join(opts.python.outdir, reldir);\n      await fs.move(source, target, { overwrite: true });\n    }\n\n    if (opts.java) {\n      const source = path.resolve(path.join(staging, \"dist/java/src/\"));\n      const target = path.join(opts.java.outdir, \"src/\");\n      await fs.mkdirp(target); // make sure target directory exists\n      await fs.copy(source, target, { recursive: true, overwrite: false });\n    }\n\n    if (opts.csharp) {\n      const reldir = opts.csharp.namespace;\n      const source = path.resolve(path.join(staging, \"dist/dotnet/\", reldir));\n      const target = path.join(opts.csharp.outdir, reldir);\n      await fs.move(source, target, { overwrite: true });\n    }\n\n    if (opts.golang) {\n      const reldir = opts.golang.packageName;\n      const source = path.resolve(path.join(staging, \"dist/go/\", reldir));\n      const target = path.join(opts.golang.outdir, reldir);\n      await fs.move(source, target, { overwrite: true });\n      // remove go.mod as this would make it a submodule\n      await fs.remove(path.join(target, \"go.mod\"));\n    }\n\n    [\"versions.json\", \"constraints.json\"].forEach((file) => {\n      try {\n        fs.copySync(\n          path.resolve(staging, file),\n          path.resolve(outputPath, file),\n        );\n      } catch (e) {\n        logger.debug(`Failed to copy ${file}: ${e}`);\n      }\n    });\n  });\n}\n\ntype ConstraintFile = { providers: Record<string, string>; cdktf: string };\n\nexport interface GetOptions {\n  readonly targetLanguage: Language;\n  readonly codeMakerOutput: string;\n  readonly jsiiParallelism?: number;\n  /**\n   * Path to copy the output .jsii file.\n   * @default - jsii file is not emitted\n   */\n  readonly outputJsii?: string;\n}\n\nexport class ConstructsMaker {\n  private readonly codeMakerOutdir: string;\n  private readonly code: CodeMaker;\n  private versions: { [providerName: string]: string | undefined };\n\n  constructor(\n    private readonly options: GetOptions,\n    private readonly schemaCachePath?: string,\n    private readonly reportTelemetry: (payload: {\n      targetLanguage: string;\n      trackingPayload: Record<string, any>;\n    }) => Promise<void> = async () => {},\n  ) {\n    this.codeMakerOutdir = path.resolve(this.options.codeMakerOutput);\n    fs.mkdirpSync(this.codeMakerOutdir);\n    this.code = new CodeMaker();\n    this.versions = {};\n  }\n  private async generateTypescriptProvider(\n    target: ConstructsMakerProviderTarget,\n    schema: ProviderSchema,\n  ) {\n    const endTSTimer = logTimespan(`Generate Typescript for ${target.name}`);\n    const generator = new TerraformProviderGenerator(this.code, schema);\n    generator.generate(target);\n\n    this.versions = { ...this.versions, ...generator.versions };\n    endTSTimer();\n  }\n\n  public async filterAlreadyGenerated(\n    constraints: TerraformDependencyConstraint[],\n  ) {\n    let constraintsFile = \"{}\";\n    try {\n      constraintsFile = await fs.readFile(\n        path.join(this.codeMakerOutdir, \"constraints.json\"),\n        \"utf8\",\n      );\n    } catch (e) {\n      logger.debug(\n        `Could not find constraints.json file while filtering: ${e}. This means no providers were generated, so all constraints need to be generated.`,\n      );\n      return constraints;\n    }\n    logger.debug(`Found constraints.json file: ${constraintsFile}`);\n\n    let previousConstraints: Partial<ConstraintFile> = {};\n    try {\n      previousConstraints = JSON.parse(constraintsFile);\n    } catch (e) {\n      logger.info(\n        `Could not parse constraints.json file while filtering: ${e}. Generating all constraints.`,\n      );\n      return constraints;\n    }\n\n    logger.debug(\n      `Found previous constraints: ${JSON.stringify(\n        previousConstraints,\n        null,\n        2,\n      )}`,\n    );\n\n    if (\n      !previousConstraints.providers ||\n      typeof previousConstraints.providers !== \"object\"\n    ) {\n      logger.info(\n        `Could not find providers in constraints.json file, generating all constraints. The constraints file was ${JSON.stringify(\n          previousConstraints,\n          null,\n          2,\n        )}`,\n      );\n      return constraints;\n    }\n\n    if (previousConstraints.cdktf !== DISPLAY_VERSION) {\n      logger.info(\n        `The CDKTN version has changed, generating all constraints. The previous version was ${previousConstraints.cdktf}, the current version is ${DISPLAY_VERSION}`,\n      );\n      return constraints;\n    }\n\n    const constraintsToGenerate = constraints.filter((constraint) => {\n      const constraintMatches =\n        previousConstraints.providers![constraint.fqn] === constraint.version;\n      let providerFolderExists = false;\n\n      switch (this.options.targetLanguage) {\n        case Language.TYPESCRIPT:\n          providerFolderExists = fs.existsSync(\n            path.join(this.codeMakerOutdir, \"providers\", constraint.name),\n          );\n          break;\n        case Language.PYTHON:\n        case Language.JAVA:\n        case Language.CSHARP:\n          providerFolderExists = fs.existsSync(\n            path.join(this.codeMakerOutdir, constraint.name),\n          );\n          break;\n        case Language.GO:\n          providerFolderExists = fs.existsSync(\n            path.join(\n              this.codeMakerOutdir,\n              constraint.namespace || \"hashicorp\",\n              constraint.name,\n            ),\n          );\n          break;\n      }\n\n      const providerExists = constraintMatches && providerFolderExists;\n      return !providerExists;\n    });\n\n    logger.debug(\n      `Constraints to generate: ${JSON.stringify(\n        constraintsToGenerate,\n        null,\n        2,\n      )}`,\n    );\n\n    return constraintsToGenerate;\n  }\n\n  private async generateTypescriptModule(\n    target: ConstructsMakerModuleTarget,\n    schema: ModuleSchema,\n  ) {\n    const endTSTimer = logTimespan(`Generate Typescript for ${target.name}`);\n    target.spec = schema;\n    new ModuleGenerator(this.code, [target]);\n    endTSTimer();\n  }\n\n  private async generateTypescript(\n    target: ConstructsMakerTarget,\n    schemas: Awaited<ReturnType<typeof readSchema>>,\n  ) {\n    if (target.isModule) {\n      const schema = schemas.moduleSchema?.[target.moduleKey];\n      if (!schema) {\n        throw Errors.Internal(\n          `Could not generate schema for module ${target.moduleKey}`,\n        );\n      }\n\n      await this.generateTypescriptModule(\n        target as ConstructsMakerModuleTarget,\n        schema,\n      );\n    } else if (target.isProvider) {\n      if (!schemas.providerSchema) {\n        throw Errors.Internal(`Could not generate schema for providers`);\n      }\n\n      await this.generateTypescriptProvider(\n        target as ConstructsMakerProviderTarget,\n        schemas.providerSchema,\n      );\n    } else {\n      throw new Error(\n        `Unknown target type used to generate bindings: ${target.name}`,\n      );\n    }\n  }\n\n  // emits a versions.json file with a map of the used version for each provider fqpn\n  private updateVersionsFile(\n    allowedConstraints: TerraformDependencyConstraint[],\n  ) {\n    logger.debug(\n      `Updating versions file with generated versions ${JSON.stringify(\n        this.versions,\n        null,\n        2,\n      )} with allowed constraints ${JSON.stringify(\n        allowedConstraints,\n        null,\n        2,\n      )}`,\n    );\n    const filePath = \"versions.json\";\n    let previousVersions: Record<string, string> = {};\n    try {\n      previousVersions = JSON.parse(\n        fs.readFileSync(path.resolve(this.codeMakerOutdir, filePath), \"utf8\"),\n      );\n\n      logger.debug(\n        `Read existing versions file: ${JSON.stringify(\n          previousVersions,\n          null,\n          2,\n        )}`,\n      );\n    } catch (e) {\n      // ignore\n      logger.debug(\n        `Could not read versions file, this is expected if there are no pre-existing local providers: ${e}`,\n      );\n    }\n\n    const versions = allowedConstraints.reduce((acc, constraint) => {\n      const provider = Object.entries(previousVersions).find(([name]) =>\n        // This could be more refined, but it's good enough for now\n        name.endsWith(constraint.fqn),\n      );\n\n      if (provider) {\n        const [name, version] = provider;\n        return { ...acc, [name]: version };\n      }\n\n      return acc;\n    }, {});\n\n    logger.debug(\n      `Writing versions file (${filePath}): ${JSON.stringify(\n        versions,\n        null,\n        2,\n      )}`,\n    );\n\n    this.code.openFile(filePath);\n    this.code.line(JSON.stringify({ ...versions, ...this.versions }, null, 2));\n    this.code.closeFile(filePath);\n    return filePath;\n  }\n\n  public async removeFoldersThatShouldNotExist(\n    constraintsThatShouldExist: TerraformDependencyConstraint[],\n  ) {\n    logger.debug(\n      `Removing providers except for ${JSON.stringify(\n        constraintsThatShouldExist,\n        null,\n        2,\n      )}`,\n    );\n\n    // All languages besides TS keep their providers in the same folders as modules\n    // this makes it impossible for us to distinguish a no longer required provider\n    // from a manually written construct or a module\n    if (!this.isJavascriptTarget) {\n      return;\n    }\n\n    let filesInProviders: string[] = [];\n    const providersFolder = path.resolve(this.codeMakerOutdir, \"providers\");\n    try {\n      filesInProviders = await fs.readdir(providersFolder);\n    } catch (e) {\n      logger.debug(\n        `Error listing files in providers folder '${providersFolder}': ${e}`,\n      );\n    }\n\n    const folders = filesInProviders.filter((file) =>\n      fs\n        .statSync(path.resolve(this.codeMakerOutdir, \"providers\", file))\n        .isDirectory(),\n    );\n\n    return folders.forEach((folder) => {\n      const shouldExist = constraintsThatShouldExist.some(\n        (constraint) => constraint.name === folder,\n      );\n\n      if (!shouldExist) {\n        logger.debug(`Removing folder ${folder} from providers`);\n        fs.removeSync(path.resolve(this.codeMakerOutdir, \"providers\", folder));\n      }\n    });\n  }\n\n  // emits a constraints.json file with a map of the used provider fqpns and version constraints\n  // this is used for caching purposes\n  private emitConstraintsFile(\n    allowedConstraints: TerraformDependencyConstraint[],\n  ) {\n    const filePath = \"constraints.json\";\n\n    const content: ConstraintFile = {\n      cdktf: DISPLAY_VERSION,\n      providers: allowedConstraints\n        .sort((a, b) => a.fqn.localeCompare(b.fqn))\n        .reduce(\n          (carry, item) => ({\n            ...carry,\n            [item.fqn]: item.version,\n          }),\n          {},\n        ),\n    };\n\n    this.code.openFile(filePath);\n    this.code.line(JSON.stringify(content, null, 2));\n    this.code.closeFile(filePath);\n    return filePath;\n  }\n\n  private async generateJsiiLanguage(target: ConstructsMakerTarget) {\n    // these are the module dependencies we compile against\n    const deps = [\"@types/node\", \"constructs\", \"cdktn\"];\n    const opts: GenerateJSIIOptions = {\n      entrypoint: target.fileName,\n      deps: deps.map((dep) =>\n        path.dirname(require.resolve(`${dep}/package.json`)),\n      ),\n      moduleKey: target.moduleKey,\n      exports: target.isProvider // Modules are small enough that we don't need this optimization\n        ? {\n            \".\": {\n              import: `./providers/${target.name}/index.js`,\n              require: `./providers/${target.name}/lazy-index.js`,\n            },\n          }\n        : undefined,\n    };\n\n    // used for testing.\n    if (this.options.outputJsii) {\n      opts.jsii = { path: this.options.outputJsii };\n    }\n\n    if (this.isPythonTarget) {\n      opts.python = {\n        outdir: this.codeMakerOutdir,\n        moduleName: target.srcMakName,\n      };\n    }\n\n    if (this.isJavaTarget) {\n      if (\n        this.options.codeMakerOutput.includes(\"/\") ||\n        this.options.codeMakerOutput.includes(\"\\\\\")\n      ) {\n        throw Errors.Usage(\n          `When using Java the \"codeMakerOutput\" option in the cdktf.json must be the organization identifier for your project (e.g. com.my-company), not a path. The generated Java code will be placed in a subdirectory of the given directory. If you are migrating from a < 0.19 version of cdktf you want to change the codemakerOutput to \"imports\".`,\n        );\n      }\n\n      opts.java = {\n        outdir: \".\", // generated java files aren't packaged, so just include directly in app\n        package: `${this.options.codeMakerOutput}.${target.srcMakName}`,\n      };\n    }\n\n    if (this.isCsharpTarget) {\n      opts.csharp = {\n        outdir: this.codeMakerOutdir,\n        namespace: target.srcMakName,\n      };\n    }\n\n    if (this.isGoTarget) {\n      // TODO: check if needed for modules somehow\n      // const targetType = target.isProvider ? 'provider' : 'module';\n\n      // jsii-srcmac will produce a folder inside this dir named after \"packageName\"\n      // so this results in e.g. .gen/hashicorp/random\n      const outdir = path.join(this.codeMakerOutdir, target.namespace ?? \"\");\n\n      opts.golang = {\n        outdir,\n        moduleName: await determineGoModuleName(outdir), // e.g. `github.com/org/userproject/.gen/hashicorp`\n        packageName: target.srcMakName, // package will be named e.g. random for hashicorp/random\n      };\n    }\n\n    if (\n      process.env.NODE_OPTIONS &&\n      !process.env.NODE_OPTIONS.includes(`--max-old-space-size`)\n    ) {\n      logger.warn(`found NODE_OPTIONS environment variable without a setting for --max-old-space-size.\nThe provider generation needs a substantial amount of memory (~13GB) for some providers and languages.\nSo cdktn-cli sets it to NODE_OPTIONS=\"--max-old-space-size=16384\" by default. As your environment already contains\na NODE_OPTIONS variable, we won't override it. Hence, the provider generation might fail with an out of memory error.`);\n    } else {\n      // increase memory to allow generating large providers (i.e. aws or azurerm for Go)\n      // srcmak is going to spawn a childprocess (for jsii-pacmak) which is going to be affected by this env var\n      process.env.NODE_OPTIONS = \"--max-old-space-size=16384\";\n    }\n\n    const jsiiTimer = logTimespan(\"JSII\");\n    await generateJsiiLanguage(this.code, opts, this.codeMakerOutdir, [\n      target.isModule ? \"providers/**\" : \"modules/**\",\n    ]);\n    jsiiTimer();\n  }\n\n  public async getSchemas(targets: TerraformDependencyConstraint[]) {\n    return await readSchema(targets, this.schemaCachePath);\n  }\n\n  public async generate(\n    allConstraints: TerraformDependencyConstraint[],\n    constraintsToGenerate = allConstraints,\n  ) {\n    const targets = constraintsToGenerate.map((constraint) =>\n      ConstructsMakerTarget.from(constraint, this.options.targetLanguage),\n    );\n\n    const endSchemaTimer = logTimespan(\"Gathering schema\");\n    const schemas = await this.getSchemas(constraintsToGenerate);\n    endSchemaTimer();\n\n    const endGenerateTimer = logTimespan(\"Generate TS\");\n    await Promise.all(\n      targets.map((target) => this.generateTypescript(target, schemas)),\n    );\n    endGenerateTimer();\n\n    this.updateVersionsFile(allConstraints);\n    this.emitConstraintsFile(allConstraints);\n\n    if (this.isJavascriptTarget) {\n      await this.save();\n    }\n\n    if (!this.isJavascriptTarget || this.options.outputJsii) {\n      const numberOfWorkers = Math.max(\n        1,\n        this.options.jsiiParallelism === -1\n          ? targets.length\n          : this.options.jsiiParallelism || 1,\n      );\n\n      const work = [...targets];\n      const workers = new Array(numberOfWorkers).fill(async () => {\n        let target: ConstructsMakerTarget | undefined;\n        while ((target = work.pop())) {\n          const endJsiiTarget = logTimespan(\n            `Generating JSII bindings for ${target.name}`,\n          );\n          await this.generateJsiiLanguage(target);\n          endJsiiTarget();\n        }\n      });\n\n      await Promise.all(workers.map((fn) => fn()));\n    }\n\n    for (const target of targets) {\n      await this.reportTelemetry({\n        trackingPayload: target.trackingPayload,\n        targetLanguage: target.targetLanguage,\n      });\n    }\n\n    if (this.isPythonTarget) {\n      const endPythonTimer = logTimespan(\"Python post-processing\");\n      // Remove from . import ... statements from root level __init__.py\n      // This removes root-level imports of namespaces, but saves 25s synth time for the aws provider alone\n      const allInitPyPaths = glob\n        .sync(\"**/__init__.py\", {\n          cwd: this.codeMakerOutdir,\n        })\n        // sort by depth, so we start with the shallowest files\n        .sort((a, b) => a.split(\"/\").length - b.split(\"/\").length);\n\n      const visitedDirectories: string[] = [];\n      for (const initPyPath of allInitPyPaths) {\n        const directoryPath = path.dirname(initPyPath);\n        if (visitedDirectories.some((dir) => directoryPath.startsWith(dir))) {\n          // we already processed this directory\n          continue;\n        }\n        visitedDirectories.push(directoryPath);\n\n        const absoluteInitPyPath = path.join(this.codeMakerOutdir, initPyPath);\n        const initPy = await fs.readFile(absoluteInitPyPath, \"utf8\");\n        const initPyWithoutImports = initPy.replace(/from \\. import .*\\n/g, \"\");\n        await fs.writeFile(absoluteInitPyPath, initPyWithoutImports);\n      }\n\n      endPythonTimer();\n    }\n  }\n\n  private async save(outdir = this.codeMakerOutdir) {\n    await this.code.save(outdir);\n  }\n\n  private get isJavascriptTarget() {\n    return this.options.targetLanguage === Language.TYPESCRIPT;\n  }\n\n  private get isPythonTarget() {\n    return this.options.targetLanguage === Language.PYTHON;\n  }\n\n  private get isJavaTarget() {\n    return this.options.targetLanguage === Language.JAVA;\n  }\n\n  private get isCsharpTarget() {\n    return this.options.targetLanguage === Language.CSHARP;\n  }\n\n  private get isGoTarget() {\n    return this.options.targetLanguage === Language.GO;\n  }\n}\n\n/**\n * searches for the closest `go.mod` file and returns the nested go module name for `dir`\n * e.g. (/dir/.gen/) => cdk.tf/stack/.gen if the parent dir of .gen has a go.mod for \"module cdk.tf/stack\"\n *\n * @param dir the directory to start the search from (searches upwards)\n * @returns the package name for `dir`\n * @throws an Error if no go.mod was found\n */\nexport const determineGoModuleName = async (dir: string): Promise<string> => {\n  let previousDir;\n  let currentDir = path.resolve(dir);\n\n  do {\n    let files: string[] = [];\n    try {\n      files = await fs.readdir(currentDir);\n    } catch (e: any) {\n      // directory might not exist yet, but we still walk upwards from there, so ignore 'ENOENT'\n      if (e.code !== \"ENOENT\") {\n        throw e;\n      }\n    }\n    if (files.includes(\"go.mod\")) {\n      const file = path.resolve(currentDir, \"go.mod\");\n      const gomod = await fs.readFile(file);\n      const match = /^module\\s*(\\S*)\\s*$/m.exec(gomod.toString());\n      if (match && match[1]) {\n        const childdir = path.relative(currentDir, dir).replace(/\\\\/g, \"/\"); // replace '\\' with '/' for windows paths\n        return childdir.length > 0 ? `${match[1]}/${childdir}` : match[1];\n      }\n      throw new Error(\n        `Could not determine the root Go module name. Found ${file} but failed to regex match the module name directive`,\n      );\n    }\n    // go up one directory. As dirname('/') will return '/' we cancel the loop\n    // as soon as the dir does not change anymore.\n    previousDir = currentDir;\n    currentDir = path.dirname(currentDir);\n  } while (currentDir !== previousDir);\n\n  throw new Error(\n    `Could not determine the root Go module name. No go.mod found in ${dir} and any parent directories`,\n  );\n};\n"]}