@cdktn/hcl2cdk 0.23.0-pre.8 → 0.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (85) hide show
  1. package/ambient.d.ts +0 -1
  2. package/build/__tests__/coerceType.test.js +165 -0
  3. package/build/__tests__/expressionToTs.test.js +693 -0
  4. package/build/__tests__/expressions.test.js +415 -0
  5. package/build/__tests__/findExpressionType.test.js +105 -0
  6. package/build/__tests__/functions.test.js +605 -0
  7. package/build/__tests__/generation.test.js +45 -0
  8. package/build/__tests__/jsii-rosetta-workarounds.test.js +86 -0
  9. package/build/__tests__/partialCode.test.js +390 -0
  10. package/build/__tests__/terraformSchema.test.js +105 -0
  11. package/build/__tests__/testHelpers.js +16 -0
  12. package/build/coerceType.js +240 -0
  13. package/build/dynamic-blocks.js +44 -0
  14. package/build/expressions.js +633 -0
  15. package/build/function-bindings/functions.generated.js +1142 -0
  16. package/build/function-bindings/functions.js +73 -0
  17. package/{lib → build}/generation.js +4 -4
  18. package/{lib → build}/index.d.ts +2 -2
  19. package/build/index.js +364 -0
  20. package/build/iteration.js +87 -0
  21. package/build/jsii-rosetta-workarounds.js +126 -0
  22. package/build/partialCode.js +116 -0
  23. package/build/provider.js +40 -0
  24. package/build/references.js +141 -0
  25. package/build/schema.js +81 -0
  26. package/build/telemetryAllowList.json +24 -0
  27. package/build/terraformSchema.js +136 -0
  28. package/build/types.js +3 -0
  29. package/build/utils.js +25 -0
  30. package/build/variables.js +172 -0
  31. package/package.json +13 -14
  32. package/tsconfig.json +4 -2
  33. package/lib/__tests__/coerceType.test.js +0 -165
  34. package/lib/__tests__/expressionToTs.test.js +0 -693
  35. package/lib/__tests__/expressions.test.js +0 -415
  36. package/lib/__tests__/findExpressionType.test.js +0 -105
  37. package/lib/__tests__/functions.test.js +0 -605
  38. package/lib/__tests__/generation.test.js +0 -45
  39. package/lib/__tests__/jsii-rosetta-workarounds.test.js +0 -86
  40. package/lib/__tests__/partialCode.test.js +0 -390
  41. package/lib/__tests__/terraformSchema.test.js +0 -105
  42. package/lib/__tests__/testHelpers.js +0 -16
  43. package/lib/coerceType.js +0 -240
  44. package/lib/dynamic-blocks.js +0 -44
  45. package/lib/expressions.js +0 -634
  46. package/lib/function-bindings/functions.generated.js +0 -1142
  47. package/lib/function-bindings/functions.js +0 -73
  48. package/lib/index.js +0 -364
  49. package/lib/iteration.js +0 -87
  50. package/lib/jsii-rosetta-workarounds.js +0 -126
  51. package/lib/partialCode.js +0 -116
  52. package/lib/provider.js +0 -40
  53. package/lib/references.js +0 -141
  54. package/lib/schema.js +0 -81
  55. package/lib/terraformSchema.js +0 -136
  56. package/lib/types.js +0 -3
  57. package/lib/utils.js +0 -25
  58. package/lib/variables.js +0 -172
  59. /package/{lib → build}/__tests__/coerceType.test.d.ts +0 -0
  60. /package/{lib → build}/__tests__/expressionToTs.test.d.ts +0 -0
  61. /package/{lib → build}/__tests__/expressions.test.d.ts +0 -0
  62. /package/{lib → build}/__tests__/findExpressionType.test.d.ts +0 -0
  63. /package/{lib → build}/__tests__/functions.test.d.ts +0 -0
  64. /package/{lib → build}/__tests__/generation.test.d.ts +0 -0
  65. /package/{lib → build}/__tests__/jsii-rosetta-workarounds.test.d.ts +0 -0
  66. /package/{lib → build}/__tests__/partialCode.test.d.ts +0 -0
  67. /package/{lib → build}/__tests__/terraformSchema.test.d.ts +0 -0
  68. /package/{lib → build}/__tests__/testHelpers.d.ts +0 -0
  69. /package/{lib → build}/coerceType.d.ts +0 -0
  70. /package/{lib → build}/dynamic-blocks.d.ts +0 -0
  71. /package/{lib → build}/expressions.d.ts +0 -0
  72. /package/{lib → build}/function-bindings/functions.d.ts +0 -0
  73. /package/{lib → build}/function-bindings/functions.generated.d.ts +0 -0
  74. /package/{lib → build}/generation.d.ts +0 -0
  75. /package/{lib → build}/iteration.d.ts +0 -0
  76. /package/{lib → build}/jsii-rosetta-workarounds.d.ts +0 -0
  77. /package/{lib → build}/partialCode.d.ts +0 -0
  78. /package/{lib → build}/provider.d.ts +0 -0
  79. /package/{lib → build}/references.d.ts +0 -0
  80. /package/{lib → build}/schema.d.ts +0 -0
  81. /package/{lib → build}/terraformSchema.d.ts +0 -0
  82. /package/{lib → build}/types.d.ts +0 -0
  83. /package/{lib → build}/utils.d.ts +0 -0
  84. /package/{lib → build}/variables.d.ts +0 -0
  85. /package/{lib → src}/telemetryAllowList.json +0 -0
package/lib/iteration.js DELETED
@@ -1,87 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.resourceStats = exports.forEachNamespaced = exports.forEachProvider = exports.forEachImport = exports.forEachGlobal = void 0;
4
- const telemetryAllowList_json_1 = require("./telemetryAllowList.json");
5
- // locals, variables, and outputs are global key value maps
6
- function forEachGlobal(scope, prefix, record, iterator) {
7
- return Object.entries(record || {}).reduce((carry, [key, item]) => {
8
- const id = `${prefix}.${key}`;
9
- return {
10
- ...carry,
11
- [id]: {
12
- code: async (graph) => await iterator(scope, key, id, item, graph),
13
- value: item,
14
- },
15
- };
16
- }, {});
17
- }
18
- exports.forEachGlobal = forEachGlobal;
19
- function forEachImport(scope, prefix, record, iterator) {
20
- return (record || []).reduce((carry, item) => {
21
- const target = item.to.startsWith("${") && item.to.endsWith("}")
22
- ? item.to.substring(2, item.to.length - 1)
23
- : item.to;
24
- const id = `${prefix}.${target}`;
25
- return {
26
- ...carry,
27
- [id]: {
28
- code: async (graph) => await iterator(scope, id, item, graph),
29
- value: item,
30
- },
31
- };
32
- }, {});
33
- }
34
- exports.forEachImport = forEachImport;
35
- function forEachProvider(scope, record, iterator) {
36
- return Object.entries(record || {}).reduce((carry, [key, items]) => {
37
- return {
38
- ...carry,
39
- ...items.reduce((innerCarry, item) => {
40
- const id = item.alias ? `${key}.${item.alias}` : `${key}`;
41
- return {
42
- ...innerCarry,
43
- [id]: {
44
- code: async (graph) => await iterator(scope, key, id, item, graph),
45
- value: item,
46
- },
47
- };
48
- }, {}),
49
- };
50
- }, {});
51
- }
52
- exports.forEachProvider = forEachProvider;
53
- // data and resource are namespaced key value maps
54
- function forEachNamespaced(scope, record, iterator, prefix) {
55
- return Object.entries(record || {}).reduce((outerCarry, [type, items]) => ({
56
- ...outerCarry,
57
- ...Object.entries(items).reduce((innerCarry, [key, item]) => {
58
- const prefixedType = prefix ? `${prefix}.${type}` : type;
59
- const id = prefix ? `${prefix}.${type}.${key}` : `${type}.${key}`;
60
- return {
61
- ...innerCarry,
62
- [id]: {
63
- code: async (graph) => await iterator(scope, prefixedType, key, id, item, graph),
64
- value: item,
65
- },
66
- };
67
- }, {}),
68
- }), {});
69
- }
70
- exports.forEachNamespaced = forEachNamespaced;
71
- function resourceStats(obj) {
72
- return Object.entries(obj).reduce((carry, [key, value]) => {
73
- const [provider, ...resourceParts] = key.split("_");
74
- const shouldBeTracked = telemetryAllowList_json_1.providers.includes(provider);
75
- const providerKey = shouldBeTracked ? provider : "other";
76
- const resourceName = shouldBeTracked ? resourceParts.join("_") : "other";
77
- return {
78
- ...carry,
79
- [providerKey]: {
80
- ...(carry[providerKey] || {}),
81
- [resourceName]: Object.keys(value).length,
82
- },
83
- };
84
- }, {});
85
- }
86
- exports.resourceStats = resourceStats;
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iteration.js","sourceRoot":"","sources":["iteration.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport { DirectedGraph } from \"graphology\";\nimport { providers as telemetryAllowedProviders } from \"./telemetryAllowList.json\";\nimport { ProgramScope } from \"./types\";\nimport { Import } from \"./schema\";\n\n// locals, variables, and outputs are global key value maps\nexport function forEachGlobal<T, R>(\n  scope: ProgramScope,\n  prefix: string,\n  record: Record<string, T> | undefined,\n  iterator: (\n    scope: ProgramScope,\n    key: string,\n    id: string,\n    value: T,\n    graph: DirectedGraph,\n  ) => Promise<R>,\n): Record<string, { code: (graph: DirectedGraph) => Promise<R>; value: T }> {\n  return Object.entries(record || {}).reduce((carry, [key, item]) => {\n    const id = `${prefix}.${key}`;\n    return {\n      ...carry,\n      [id]: {\n        code: async (graph: DirectedGraph) =>\n          await iterator(scope, key, id, item, graph),\n        value: item,\n      },\n    };\n  }, {});\n}\n\nexport function forEachImport<R>(\n  scope: ProgramScope,\n  prefix: string,\n  record: Import[] | undefined,\n  iterator: (\n    scope: ProgramScope,\n    id: string,\n    value: Import,\n    graph: DirectedGraph,\n  ) => Promise<R>,\n): Record<\n  string,\n  { code: (graph: DirectedGraph) => Promise<R>; value: Import }\n> {\n  return (record || []).reduce((carry, item) => {\n    const target =\n      item.to.startsWith(\"${\") && item.to.endsWith(\"}\")\n        ? item.to.substring(2, item.to.length - 1)\n        : item.to;\n\n    const id = `${prefix}.${target}`;\n    return {\n      ...carry,\n      [id]: {\n        code: async (graph: DirectedGraph) =>\n          await iterator(scope, id, item, graph),\n        value: item,\n      },\n    };\n  }, {});\n}\n\nexport function forEachProvider<T extends { alias?: string }, R>(\n  scope: ProgramScope,\n  record: Record<string, T[]> | undefined,\n  iterator: (\n    scope: ProgramScope,\n    key: string,\n    id: string,\n    value: T,\n    graph: DirectedGraph,\n  ) => Promise<R>,\n): Record<string, { code: (graph: DirectedGraph) => Promise<R>; value: T }> {\n  return Object.entries(record || {}).reduce((carry, [key, items]) => {\n    return {\n      ...carry,\n      ...items.reduce((innerCarry, item: T) => {\n        const id = item.alias ? `${key}.${item.alias}` : `${key}`;\n        return {\n          ...innerCarry,\n          [id]: {\n            code: async (graph: DirectedGraph) =>\n              await iterator(scope, key, id, item, graph),\n            value: item,\n          },\n        };\n      }, {}),\n    };\n  }, {});\n}\n\n// data and resource are namespaced key value maps\nexport function forEachNamespaced<T, R>(\n  scope: ProgramScope,\n  record: Record<string, Record<string, T>> | undefined,\n  iterator: (\n    scope: ProgramScope,\n    type: string,\n    key: string,\n    id: string,\n    value: T,\n    graph: DirectedGraph,\n  ) => Promise<R>,\n  prefix?: string,\n): Record<string, { code: (graph: DirectedGraph) => Promise<R>; value: T }> {\n  return Object.entries(record || {}).reduce(\n    (outerCarry, [type, items]) => ({\n      ...outerCarry,\n      ...Object.entries(items).reduce(\n        (innerCarry, [key, item]) => {\n          const prefixedType = prefix ? `${prefix}.${type}` : type;\n          const id = prefix ? `${prefix}.${type}.${key}` : `${type}.${key}`;\n          return {\n            ...innerCarry,\n            [id]: {\n              code: async (graph: DirectedGraph) =>\n                await iterator(scope, prefixedType, key, id, item, graph),\n              value: item,\n            },\n          };\n        },\n        {} as Record<\n          string,\n          { code: (graph: DirectedGraph) => Promise<R>; value: T }\n        >,\n      ),\n    }),\n    {} as Record<\n      string,\n      { code: (graph: DirectedGraph) => Promise<R>; value: T }\n    >,\n  );\n}\n\nexport function resourceStats(obj: Record<string, Record<string, unknown>>) {\n  return Object.entries(obj).reduce(\n    (carry, [key, value]) => {\n      const [provider, ...resourceParts] = key.split(\"_\");\n      const shouldBeTracked = telemetryAllowedProviders.includes(provider);\n      const providerKey = shouldBeTracked ? provider : \"other\";\n      const resourceName = shouldBeTracked ? resourceParts.join(\"_\") : \"other\";\n\n      return {\n        ...carry,\n        [providerKey]: {\n          ...(carry[providerKey] || {}),\n          [resourceName]: Object.keys(value).length,\n        },\n      };\n    },\n    {} as Record<string, Record<string, number>>,\n  );\n}\n"]}
@@ -1,126 +0,0 @@
1
- "use strict";
2
- // Copyright (c) HashiCorp, Inc
3
- // SPDX-License-Identifier: MPL-2.0
4
- Object.defineProperty(exports, "__esModule", { value: true });
5
- exports.replaceGoImports = exports.replaceCsharpImports = exports.replaceJavaImports = exports.replacePythonImports = void 0;
6
- function replacePythonImports(code) {
7
- return code
8
- .split("\n")
9
- .map((line) => {
10
- // Replace from-import lines with lib
11
- const fromImportLibRegex = /from \.\.\.gen\.providers\.([^.]+)(?:\.lib)?\.(.*) import/;
12
- if (fromImportLibRegex.test(line)) {
13
- return line.replace(fromImportLibRegex, "from imports.$1.$2 import");
14
- }
15
- // Replace import lines with lib
16
- const importLibRegex = /import \.\.\.gen\.providers\.([^.]+)(?:\.lib)?\.(.*) as (.*)/;
17
- if (importLibRegex.test(line)) {
18
- return line.replace(importLibRegex, "import imports.$1.$2 as $3");
19
- }
20
- // Replace from-import lines
21
- if (line.startsWith("from ...gen.providers.")) {
22
- return line.replace("from ...gen.providers.", "from imports.");
23
- }
24
- // Replace import lines
25
- if (line.startsWith("import ...gen.providers.")) {
26
- return line.replace("import ...gen.providers.", "import imports.");
27
- }
28
- // Replace modules
29
- if (line.startsWith("import ...gen.modules.")) {
30
- return line.replace("import ...gen.modules.", "import imports.");
31
- }
32
- return line;
33
- })
34
- .join("\n");
35
- }
36
- exports.replacePythonImports = replacePythonImports;
37
- function replaceJavaImports(code) {
38
- return code
39
- .split("\n")
40
- .map((line) => {
41
- // Replace using lines with lib and precices import
42
- const importWithLib = /import gen\.providers\.([^.]+)(?:\.lib)?\.([^.]+)\.(.*);/;
43
- const matchWithLib = line.match(importWithLib);
44
- if (matchWithLib) {
45
- const [, provider, resource, className] = matchWithLib;
46
- return `import imports.${provider}.${resource}.${className};`;
47
- }
48
- // Replace using lines
49
- const importWithoutLib = /import gen\.providers\.([^.]+)\.([^.]+)\.\*;/;
50
- const matchWithoutLib = line.match(importWithoutLib);
51
- if (matchWithoutLib) {
52
- const [, provider, resource] = matchWithoutLib;
53
- return `import imports.${provider}.${resource}.*;`;
54
- }
55
- // Replace using lines
56
- const importModules = /import gen\.modules\.(.+)\.\*;/;
57
- const importModulesMatch = line.match(importModules);
58
- if (importModulesMatch) {
59
- const [, module] = importModulesMatch;
60
- return `import imports.${module}.*;`;
61
- }
62
- return line;
63
- })
64
- .join("\n");
65
- }
66
- exports.replaceJavaImports = replaceJavaImports;
67
- function replaceCsharpImports(code) {
68
- return code
69
- .split("\n")
70
- .map((line) => {
71
- // Replace using lines with lib
72
- const fromImportLibRegex = /using Gen\.Providers\.([^.]*)(?:\.Lib)?\.(.*);/;
73
- const match = line.match(fromImportLibRegex);
74
- if (match) {
75
- const [, provider, resource] = match;
76
- return `using ${lowercaseFirstChar(provider)}.${resource};`;
77
- }
78
- // Replace using lines
79
- if (line.startsWith("using Gen.Providers.")) {
80
- const importLine = line.replace("using Gen.Providers.", "");
81
- return `using ${importLine
82
- .substring(0, 1)
83
- .toLocaleLowerCase()}${importLine.substring(1)}`;
84
- }
85
- if (line.startsWith("using Gen.Modules.")) {
86
- const importLine = line.replace("using Gen.Modules.", "");
87
- return `using ${importLine}`;
88
- }
89
- return line;
90
- })
91
- .join("\n");
92
- }
93
- exports.replaceCsharpImports = replaceCsharpImports;
94
- function replaceGoImports(code) {
95
- return code
96
- .split("\n")
97
- .map((line) => {
98
- // Replace using lines with lib
99
- const fromImportLibRegex = /import \"github.com\/aws-samples\/dummy\/gen\/providers\/([^\/]*)(?:\/lib)?\/(.*)\"/;
100
- const matchLib = line.match(fromImportLibRegex);
101
- if (matchLib) {
102
- const [, provider, resource] = matchLib;
103
- return `import "cdk.tf/go/stack/generated/${provider}/${resource}"`;
104
- }
105
- // Replace using lines
106
- const fromImportRegex = /import \"github.com\/aws-samples\/dummy\/gen\/providers\/([^\/]+)\/(.*)\"/;
107
- const match = line.match(fromImportRegex);
108
- if (match) {
109
- const [, provider, resource] = match;
110
- return `import "cdk.tf/go/stack/generated/${provider}/${resource}"`;
111
- }
112
- const importModulesRegex = /import (.*) \"github.com\/aws-samples\/dummy\/gen\/modules\/(.*)\"/;
113
- const matchModules = line.match(importModulesRegex);
114
- if (matchModules) {
115
- const [, name, module] = matchModules;
116
- return `import ${name} "cdk.tf/go/stack/generated/${module}"`;
117
- }
118
- return line;
119
- })
120
- .join("\n");
121
- }
122
- exports.replaceGoImports = replaceGoImports;
123
- function lowercaseFirstChar(str) {
124
- return str.substring(0, 1).toLocaleLowerCase() + str.substring(1);
125
- }
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsii-rosetta-workarounds.js","sourceRoot":"","sources":["jsii-rosetta-workarounds.ts"],"names":[],"mappings":";AAAA,+BAA+B;AAC/B,mCAAmC;;;AAEnC,SAAgB,oBAAoB,CAAC,IAAY;IAC/C,OAAO,IAAI;SACR,KAAK,CAAC,IAAI,CAAC;SACX,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACZ,qCAAqC;QACrC,MAAM,kBAAkB,GACtB,2DAA2D,CAAC;QAC9D,IAAI,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAClC,OAAO,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,2BAA2B,CAAC,CAAC;QACvE,CAAC;QAED,gCAAgC;QAChC,MAAM,cAAc,GAClB,8DAA8D,CAAC;QACjE,IAAI,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,4BAA4B,CAAC,CAAC;QACpE,CAAC;QAED,4BAA4B;QAC5B,IAAI,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,EAAE,CAAC;YAC9C,OAAO,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,eAAe,CAAC,CAAC;QACjE,CAAC;QACD,uBAAuB;QACvB,IAAI,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,EAAE,CAAC;YAChD,OAAO,IAAI,CAAC,OAAO,CAAC,0BAA0B,EAAE,iBAAiB,CAAC,CAAC;QACrE,CAAC;QAED,kBAAkB;QAClB,IAAI,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAC,EAAE,CAAC;YAC9C,OAAO,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,iBAAiB,CAAC,CAAC;QACnE,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;SACD,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC;AAnCD,oDAmCC;AAED,SAAgB,kBAAkB,CAAC,IAAY;IAC7C,OAAO,IAAI;SACR,KAAK,CAAC,IAAI,CAAC;SACX,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACZ,mDAAmD;QACnD,MAAM,aAAa,GACjB,0DAA0D,CAAC;QAC7D,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAC/C,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC,GAAG,YAAY,CAAC;YACvD,OAAO,kBAAkB,QAAQ,IAAI,QAAQ,IAAI,SAAS,GAAG,CAAC;QAChE,CAAC;QAED,sBAAsB;QACtB,MAAM,gBAAgB,GAAG,8CAA8C,CAAC;QACxE,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QACrD,IAAI,eAAe,EAAE,CAAC;YACpB,MAAM,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,eAAe,CAAC;YAC/C,OAAO,kBAAkB,QAAQ,IAAI,QAAQ,KAAK,CAAC;QACrD,CAAC;QAED,sBAAsB;QACtB,MAAM,aAAa,GAAG,gCAAgC,CAAC;QACvD,MAAM,kBAAkB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACrD,IAAI,kBAAkB,EAAE,CAAC;YACvB,MAAM,CAAC,EAAE,MAAM,CAAC,GAAG,kBAAkB,CAAC;YACtC,OAAO,kBAAkB,MAAM,KAAK,CAAC;QACvC,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;SACD,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC;AAhCD,gDAgCC;AAED,SAAgB,oBAAoB,CAAC,IAAY;IAC/C,OAAO,IAAI;SACR,KAAK,CAAC,IAAI,CAAC;SACX,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACZ,+BAA+B;QAC/B,MAAM,kBAAkB,GACtB,gDAAgD,CAAC;QACnD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAC7C,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC;YACrC,OAAO,SAAS,kBAAkB,CAAC,QAAQ,CAAC,IAAI,QAAQ,GAAG,CAAC;QAC9D,CAAC;QAED,sBAAsB;QACtB,IAAI,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC;YAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,sBAAsB,EAAE,EAAE,CAAC,CAAC;YAE5D,OAAO,SAAS,UAAU;iBACvB,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;iBACf,iBAAiB,EAAE,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QACrD,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,EAAE,CAAC;YAC1C,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB,EAAE,EAAE,CAAC,CAAC;YAE1D,OAAO,SAAS,UAAU,EAAE,CAAC;QAC/B,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;SACD,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC;AA/BD,oDA+BC;AAED,SAAgB,gBAAgB,CAAC,IAAY;IAC3C,OAAO,IAAI;SACR,KAAK,CAAC,IAAI,CAAC;SACX,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACZ,+BAA+B;QAC/B,MAAM,kBAAkB,GACtB,qFAAqF,CAAC;QACxF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAChD,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC;YACxC,OAAO,qCAAqC,QAAQ,IAAI,QAAQ,GAAG,CAAC;QACtE,CAAC;QAED,sBAAsB;QACtB,MAAM,eAAe,GACnB,2EAA2E,CAAC;QAC9E,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAC1C,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC;YACrC,OAAO,qCAAqC,QAAQ,IAAI,QAAQ,GAAG,CAAC;QACtE,CAAC;QAED,MAAM,kBAAkB,GACtB,oEAAoE,CAAC;QACvE,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;QACpD,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,GAAG,YAAY,CAAC;YACtC,OAAO,UAAU,IAAI,+BAA+B,MAAM,GAAG,CAAC;QAChE,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;SACD,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC;AAjCD,4CAiCC;AAED,SAAS,kBAAkB,CAAC,GAAW;IACrC,OAAO,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,iBAAiB,EAAE,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AACpE,CAAC","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\n\nexport function replacePythonImports(code: string) {\n  return code\n    .split(\"\\n\")\n    .map((line) => {\n      // Replace from-import lines with lib\n      const fromImportLibRegex =\n        /from \\.\\.\\.gen\\.providers\\.([^.]+)(?:\\.lib)?\\.(.*) import/;\n      if (fromImportLibRegex.test(line)) {\n        return line.replace(fromImportLibRegex, \"from imports.$1.$2 import\");\n      }\n\n      // Replace import lines with lib\n      const importLibRegex =\n        /import \\.\\.\\.gen\\.providers\\.([^.]+)(?:\\.lib)?\\.(.*) as (.*)/;\n      if (importLibRegex.test(line)) {\n        return line.replace(importLibRegex, \"import imports.$1.$2 as $3\");\n      }\n\n      // Replace from-import lines\n      if (line.startsWith(\"from ...gen.providers.\")) {\n        return line.replace(\"from ...gen.providers.\", \"from imports.\");\n      }\n      // Replace import lines\n      if (line.startsWith(\"import ...gen.providers.\")) {\n        return line.replace(\"import ...gen.providers.\", \"import imports.\");\n      }\n\n      // Replace modules\n      if (line.startsWith(\"import ...gen.modules.\")) {\n        return line.replace(\"import ...gen.modules.\", \"import imports.\");\n      }\n\n      return line;\n    })\n    .join(\"\\n\");\n}\n\nexport function replaceJavaImports(code: string) {\n  return code\n    .split(\"\\n\")\n    .map((line) => {\n      // Replace using lines with lib and precices import\n      const importWithLib =\n        /import gen\\.providers\\.([^.]+)(?:\\.lib)?\\.([^.]+)\\.(.*);/;\n      const matchWithLib = line.match(importWithLib);\n      if (matchWithLib) {\n        const [, provider, resource, className] = matchWithLib;\n        return `import imports.${provider}.${resource}.${className};`;\n      }\n\n      // Replace using lines\n      const importWithoutLib = /import gen\\.providers\\.([^.]+)\\.([^.]+)\\.\\*;/;\n      const matchWithoutLib = line.match(importWithoutLib);\n      if (matchWithoutLib) {\n        const [, provider, resource] = matchWithoutLib;\n        return `import imports.${provider}.${resource}.*;`;\n      }\n\n      // Replace using lines\n      const importModules = /import gen\\.modules\\.(.+)\\.\\*;/;\n      const importModulesMatch = line.match(importModules);\n      if (importModulesMatch) {\n        const [, module] = importModulesMatch;\n        return `import imports.${module}.*;`;\n      }\n\n      return line;\n    })\n    .join(\"\\n\");\n}\n\nexport function replaceCsharpImports(code: string) {\n  return code\n    .split(\"\\n\")\n    .map((line) => {\n      // Replace using lines with lib\n      const fromImportLibRegex =\n        /using Gen\\.Providers\\.([^.]*)(?:\\.Lib)?\\.(.*);/;\n      const match = line.match(fromImportLibRegex);\n      if (match) {\n        const [, provider, resource] = match;\n        return `using ${lowercaseFirstChar(provider)}.${resource};`;\n      }\n\n      // Replace using lines\n      if (line.startsWith(\"using Gen.Providers.\")) {\n        const importLine = line.replace(\"using Gen.Providers.\", \"\");\n\n        return `using ${importLine\n          .substring(0, 1)\n          .toLocaleLowerCase()}${importLine.substring(1)}`;\n      }\n\n      if (line.startsWith(\"using Gen.Modules.\")) {\n        const importLine = line.replace(\"using Gen.Modules.\", \"\");\n\n        return `using ${importLine}`;\n      }\n\n      return line;\n    })\n    .join(\"\\n\");\n}\n\nexport function replaceGoImports(code: string) {\n  return code\n    .split(\"\\n\")\n    .map((line) => {\n      // Replace using lines with lib\n      const fromImportLibRegex =\n        /import \\\"github.com\\/aws-samples\\/dummy\\/gen\\/providers\\/([^\\/]*)(?:\\/lib)?\\/(.*)\\\"/;\n      const matchLib = line.match(fromImportLibRegex);\n      if (matchLib) {\n        const [, provider, resource] = matchLib;\n        return `import \"cdk.tf/go/stack/generated/${provider}/${resource}\"`;\n      }\n\n      // Replace using lines\n      const fromImportRegex =\n        /import \\\"github.com\\/aws-samples\\/dummy\\/gen\\/providers\\/([^\\/]+)\\/(.*)\\\"/;\n      const match = line.match(fromImportRegex);\n      if (match) {\n        const [, provider, resource] = match;\n        return `import \"cdk.tf/go/stack/generated/${provider}/${resource}\"`;\n      }\n\n      const importModulesRegex =\n        /import (.*) \\\"github.com\\/aws-samples\\/dummy\\/gen\\/modules\\/(.*)\\\"/;\n      const matchModules = line.match(importModulesRegex);\n      if (matchModules) {\n        const [, name, module] = matchModules;\n        return `import ${name} \"cdk.tf/go/stack/generated/${module}\"`;\n      }\n\n      return line;\n    })\n    .join(\"\\n\");\n}\n\nfunction lowercaseFirstChar(str: string) {\n  return str.substring(0, 1).toLocaleLowerCase() + str.substring(1);\n}\n"]}
@@ -1,116 +0,0 @@
1
- "use strict";
2
- /**
3
- * Copyright (c) HashiCorp, Inc.
4
- * SPDX-License-Identifier: MPL-2.0
5
- */
6
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
- if (k2 === undefined) k2 = k;
8
- var desc = Object.getOwnPropertyDescriptor(m, k);
9
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
10
- desc = { enumerable: true, get: function() { return m[k]; } };
11
- }
12
- Object.defineProperty(o, k2, desc);
13
- }) : (function(o, m, k, k2) {
14
- if (k2 === undefined) k2 = k;
15
- o[k2] = m[k];
16
- }));
17
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
18
- Object.defineProperty(o, "default", { enumerable: true, value: v });
19
- }) : function(o, v) {
20
- o["default"] = v;
21
- });
22
- var __importStar = (this && this.__importStar) || function (mod) {
23
- if (mod && mod.__esModule) return mod;
24
- var result = {};
25
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
26
- __setModuleDefault(result, mod);
27
- return result;
28
- };
29
- Object.defineProperty(exports, "__esModule", { value: true });
30
- exports.getRequiredAttributes = exports.fillWithConfigAccessors = void 0;
31
- const terraformSchema_1 = require("./terraformSchema");
32
- const t = __importStar(require("@babel/types"));
33
- const utils_1 = require("./utils");
34
- function getConfigFieldName(topLevelConfig, name) {
35
- const sanitizedName = (0, utils_1.camelCase)(name);
36
- return deduplicateName(Object.keys(topLevelConfig), sanitizedName);
37
- }
38
- function deduplicateName(existingNames, name) {
39
- let newName = name;
40
- let i = 1;
41
- while (existingNames.includes(newName)) {
42
- newName = `${name}${i}`;
43
- i++;
44
- }
45
- return newName;
46
- }
47
- function fillWithConfigAccessors(scope, config, path) {
48
- if (Array.isArray(config)) {
49
- return config.map((c) => fillWithConfigAccessors(scope, c, `${path}.[]`));
50
- }
51
- if (typeof config === "object" && config !== null) {
52
- const mutated = Object.entries(config).reduce((acc, [key, value]) => ({
53
- ...acc,
54
- [key]: fillWithConfigAccessors(scope, value, `${path}.${key}`),
55
- }), {});
56
- // Get type of this part of the config
57
- const attributeType = (0, terraformSchema_1.getTypeAtPath)(scope.providerSchema, path);
58
- const requiredAttributes = getRequiredAttributes(attributeType);
59
- // Add accessors for all required attributes that are missing
60
- requiredAttributes.forEach((key) => {
61
- const value = mutated[key];
62
- const isNotDirectlyAccessible = value === undefined;
63
- const isReplacedByAst = (t.isNode(mutated) && t.isExpression(mutated)) ||
64
- t.isExpression(value);
65
- const isEmptyArray = Array.isArray(value) && value.length === 0;
66
- // If this was already replaced by an AST node, we don't need to do anything
67
- // We assume all fields are filled in by the AST
68
- if (isReplacedByAst) {
69
- return;
70
- }
71
- if (isNotDirectlyAccessible || isEmptyArray) {
72
- const fieldName = getConfigFieldName(scope.topLevelConfig, key);
73
- mutated[key] = t.memberExpression(t.identifier("config"), t.identifier(fieldName));
74
- scope.topLevelConfig[fieldName] = `${path}.${key}`;
75
- }
76
- });
77
- return mutated;
78
- }
79
- else {
80
- return config;
81
- }
82
- }
83
- exports.fillWithConfigAccessors = fillWithConfigAccessors;
84
- function getRequiredAttributes(attributeType) {
85
- if (!attributeType) {
86
- return [];
87
- }
88
- if (typeof attributeType !== "object" ||
89
- Array.isArray(attributeType) ||
90
- attributeType === null ||
91
- attributeType === undefined ||
92
- !("block" in attributeType)) {
93
- return [];
94
- }
95
- const requiredAttributes = Object.entries(attributeType.block.attributes || {}).reduce((acc, [key, value]) => (value.required ? [...acc, key] : acc), []);
96
- // Logic taken from (and should be shared with) provider generator resource parser: attributeForBlockType
97
- const requiredBlockTypes = Object.entries(attributeType.block.block_types || {}).reduce((acc, [key, value]) => {
98
- if (value.nesting_mode === "single" &&
99
- !Object.values(value.block.attributes || {}).some((x) => !x.required)) {
100
- return [...acc, key];
101
- }
102
- if (value.nesting_mode === "map") {
103
- return acc;
104
- }
105
- if ((value.nesting_mode === "list" || value.nesting_mode === "set") &&
106
- value.min_items === undefined
107
- ? false
108
- : value.min_items > 0) {
109
- return [...acc, key];
110
- }
111
- return acc;
112
- }, []);
113
- return [...requiredAttributes, ...requiredBlockTypes].sort();
114
- }
115
- exports.getRequiredAttributes = getRequiredAttributes;
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"partialCode.js","sourceRoot":"","sources":["partialCode.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) HashiCorp, Inc.\n * SPDX-License-Identifier: MPL-2.0\n */\n\nimport { getTypeAtPath } from \"./terraformSchema\";\nimport { ResourceScope, TerraformResourceBlock } from \"./types\";\nimport * as t from \"@babel/types\";\nimport { camelCase } from \"./utils\";\n\nfunction getConfigFieldName(\n  topLevelConfig: Record<string, unknown>,\n  name: string,\n) {\n  const sanitizedName = camelCase(name);\n  return deduplicateName(Object.keys(topLevelConfig), sanitizedName);\n}\n\nfunction deduplicateName(existingNames: string[], name: string) {\n  let newName = name;\n  let i = 1;\n  while (existingNames.includes(newName)) {\n    newName = `${name}${i}`;\n    i++;\n  }\n  return newName;\n}\n\nexport function fillWithConfigAccessors(\n  scope: ResourceScope,\n  config: TerraformResourceBlock,\n  path: string,\n): any {\n  if (Array.isArray(config)) {\n    return config.map((c) => fillWithConfigAccessors(scope, c, `${path}.[]`));\n  }\n\n  if (typeof config === \"object\" && config !== null) {\n    const mutated = Object.entries(config).reduce(\n      (acc, [key, value]) => ({\n        ...acc,\n        [key]: fillWithConfigAccessors(scope, value, `${path}.${key}`),\n      }),\n      {} as Record<string, TerraformResourceBlock>,\n    );\n\n    // Get type of this part of the config\n    const attributeType = getTypeAtPath(scope.providerSchema, path);\n    const requiredAttributes = getRequiredAttributes(attributeType);\n\n    // Add accessors for all required attributes that are missing\n    requiredAttributes.forEach((key) => {\n      const value = mutated[key];\n      const isNotDirectlyAccessible = value === undefined;\n      const isReplacedByAst =\n        (t.isNode(mutated) && t.isExpression(mutated)) ||\n        t.isExpression(value as any);\n      const isEmptyArray = Array.isArray(value) && value.length === 0;\n\n      // If this was already replaced by an AST node, we don't need to do anything\n      // We assume all fields are filled in by the AST\n      if (isReplacedByAst) {\n        return;\n      }\n\n      if (isNotDirectlyAccessible || isEmptyArray) {\n        const fieldName = getConfigFieldName(scope.topLevelConfig, key);\n        mutated[key] = t.memberExpression(\n          t.identifier(\"config\"),\n          t.identifier(fieldName),\n        );\n        scope.topLevelConfig[fieldName] = `${path}.${key}`;\n      }\n    });\n\n    return mutated;\n  } else {\n    return config;\n  }\n}\n\ntype Key = string;\nexport function getRequiredAttributes(\n  attributeType: ReturnType<typeof getTypeAtPath>,\n): Key[] {\n  if (!attributeType) {\n    return [];\n  }\n  if (\n    typeof attributeType !== \"object\" ||\n    Array.isArray(attributeType) ||\n    attributeType === null ||\n    attributeType === undefined ||\n    !(\"block\" in attributeType)\n  ) {\n    return [];\n  }\n\n  const requiredAttributes = Object.entries(\n    attributeType.block.attributes || {},\n  ).reduce(\n    (acc, [key, value]) => (value.required ? [...acc, key] : acc),\n    [] as string[],\n  );\n\n  // Logic taken from (and should be shared with) provider generator resource parser: attributeForBlockType\n  const requiredBlockTypes = Object.entries(\n    attributeType.block.block_types || {},\n  ).reduce((acc, [key, value]) => {\n    if (\n      value.nesting_mode === \"single\" &&\n      !Object.values(value.block.attributes || {}).some((x) => !x.required)\n    ) {\n      return [...acc, key];\n    }\n    if (value.nesting_mode === \"map\") {\n      return acc;\n    }\n\n    if (\n      (value.nesting_mode === \"list\" || value.nesting_mode === \"set\") &&\n      value.min_items === undefined\n        ? false\n        : (value as any).min_items > 0\n    ) {\n      return [...acc, key];\n    }\n\n    return acc;\n  }, [] as string[]);\n  return [...requiredAttributes, ...requiredBlockTypes].sort();\n}\n"]}
package/lib/provider.js DELETED
@@ -1,40 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getProviderRequirements = exports.getFullProviderName = void 0;
4
- function getFullProviderName(schema, providerName) {
5
- return Object.keys(schema.provider_schemas || {}).find((name) => name.endsWith(providerName));
6
- }
7
- exports.getFullProviderName = getFullProviderName;
8
- function getProviderRequirements(plan) {
9
- var _a;
10
- // In Terraform one can implicitly define the provider by using resources of that type
11
- const explicitProviders = Object.keys(plan.provider || {});
12
- const implicitProviders = Object.keys({ ...plan.resource, ...plan.data })
13
- .filter((type) => type !== "terraform_remote_state")
14
- .filter((type) => type !== "terraform_data")
15
- .map((type) => type.split("_")[0]);
16
- const providerRequirements = Array.from(new Set([...explicitProviders, ...implicitProviders])).reduce((carry, req) => ({ ...carry, [req]: "*" }), {});
17
- (_a = plan.terraform) === null || _a === void 0 ? void 0 : _a.forEach(({ required_providers }) => (required_providers || []).forEach((providerBlock) => Object.entries(providerBlock).forEach(([key, value]) => {
18
- let name, version;
19
- if (typeof value === "string") {
20
- name = key;
21
- version = value;
22
- }
23
- else {
24
- name = value.source;
25
- version = value.version;
26
- }
27
- if (!name) {
28
- return;
29
- }
30
- // implicitly only the last part of the path is used (e.g. docker for kreuzwerker/docker)
31
- const parts = name.split("/");
32
- if (parts.length > 1) {
33
- delete providerRequirements[parts.pop() || ""];
34
- }
35
- providerRequirements[name] = version || "*";
36
- })));
37
- return providerRequirements;
38
- }
39
- exports.getProviderRequirements = getProviderRequirements;
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJwcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFRQSxTQUFnQixtQkFBbUIsQ0FDakMsTUFBc0IsRUFDdEIsWUFBb0I7SUFFcEIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUM5RCxJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUM1QixDQUFDO0FBQ0osQ0FBQztBQVBELGtEQU9DO0FBR0QsU0FBZ0IsdUJBQXVCLENBQUMsSUFBVTs7SUFDaEQsc0ZBQXNGO0lBQ3RGLE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQzNELE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUN0RSxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksS0FBSyx3QkFBd0IsQ0FBQztTQUNuRCxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksS0FBSyxnQkFBZ0IsQ0FBQztTQUMzQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUVyQyxNQUFNLG9CQUFvQixHQUFHLEtBQUssQ0FBQyxJQUFJLENBQ3JDLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxpQkFBaUIsRUFBRSxHQUFHLGlCQUFpQixDQUFDLENBQUMsQ0FDdEQsQ0FBQyxNQUFNLENBQ04sQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxLQUFLLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUMxQyxFQUE0QixDQUM3QixDQUFDO0lBRUYsTUFBQSxJQUFJLENBQUMsU0FBUywwQ0FBRSxPQUFPLENBQUMsQ0FBQyxFQUFFLGtCQUFrQixFQUFFLEVBQUUsRUFBRSxDQUNqRCxDQUFDLGtCQUFrQixJQUFJLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQ25ELE1BQU0sQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRTtRQUNyRCxJQUFJLElBQUksRUFBRSxPQUFPLENBQUM7UUFDbEIsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUM5QixJQUFJLEdBQUcsR0FBRyxDQUFDO1lBQ1gsT0FBTyxHQUFHLEtBQUssQ0FBQztRQUNsQixDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDO1lBQ3BCLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQzFCLENBQUM7UUFFRCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDVixPQUFPO1FBQ1QsQ0FBQztRQUNELHlGQUF5RjtRQUN6RixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzlCLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUNyQixPQUFPLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNqRCxDQUFDO1FBQ0Qsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEdBQUcsT0FBTyxJQUFJLEdBQUcsQ0FBQztJQUM5QyxDQUFDLENBQUMsQ0FDSCxDQUNGLENBQUM7SUFFRixPQUFPLG9CQUFvQixDQUFDO0FBQzlCLENBQUM7QUF6Q0QsMERBeUNDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IChjKSBIYXNoaUNvcnAsIEluY1xuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IE1QTC0yLjBcbmltcG9ydCAqIGFzIHogZnJvbSBcInpvZFwiO1xuaW1wb3J0IHsgUHJvdmlkZXJTY2hlbWEsIEJsb2NrVHlwZSwgQXR0cmlidXRlIH0gZnJvbSBcIkBjZGt0bi9jb21tb25zXCI7XG5pbXBvcnQgeyBzY2hlbWEgfSBmcm9tIFwiLi9zY2hlbWFcIjtcblxuZXhwb3J0IHsgQmxvY2tUeXBlLCBBdHRyaWJ1dGUgfTtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEZ1bGxQcm92aWRlck5hbWUoXG4gIHNjaGVtYTogUHJvdmlkZXJTY2hlbWEsXG4gIHByb3ZpZGVyTmFtZTogc3RyaW5nLFxuKSB7XG4gIHJldHVybiBPYmplY3Qua2V5cyhzY2hlbWEucHJvdmlkZXJfc2NoZW1hcyB8fCB7fSkuZmluZCgobmFtZSkgPT5cbiAgICBuYW1lLmVuZHNXaXRoKHByb3ZpZGVyTmFtZSksXG4gICk7XG59XG5cbnR5cGUgUGxhbiA9IHouaW5mZXI8dHlwZW9mIHNjaGVtYT47XG5leHBvcnQgZnVuY3Rpb24gZ2V0UHJvdmlkZXJSZXF1aXJlbWVudHMocGxhbjogUGxhbikge1xuICAvLyBJbiBUZXJyYWZvcm0gb25lIGNhbiBpbXBsaWNpdGx5IGRlZmluZSB0aGUgcHJvdmlkZXIgYnkgdXNpbmcgcmVzb3VyY2VzIG9mIHRoYXQgdHlwZVxuICBjb25zdCBleHBsaWNpdFByb3ZpZGVycyA9IE9iamVjdC5rZXlzKHBsYW4ucHJvdmlkZXIgfHwge30pO1xuICBjb25zdCBpbXBsaWNpdFByb3ZpZGVycyA9IE9iamVjdC5rZXlzKHsgLi4ucGxhbi5yZXNvdXJjZSwgLi4ucGxhbi5kYXRhIH0pXG4gICAgLmZpbHRlcigodHlwZSkgPT4gdHlwZSAhPT0gXCJ0ZXJyYWZvcm1fcmVtb3RlX3N0YXRlXCIpXG4gICAgLmZpbHRlcigodHlwZSkgPT4gdHlwZSAhPT0gXCJ0ZXJyYWZvcm1fZGF0YVwiKVxuICAgIC5tYXAoKHR5cGUpID0+IHR5cGUuc3BsaXQoXCJfXCIpWzBdKTtcblxuICBjb25zdCBwcm92aWRlclJlcXVpcmVtZW50cyA9IEFycmF5LmZyb20oXG4gICAgbmV3IFNldChbLi4uZXhwbGljaXRQcm92aWRlcnMsIC4uLmltcGxpY2l0UHJvdmlkZXJzXSksXG4gICkucmVkdWNlKFxuICAgIChjYXJyeSwgcmVxKSA9PiAoeyAuLi5jYXJyeSwgW3JlcV06IFwiKlwiIH0pLFxuICAgIHt9IGFzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4sXG4gICk7XG5cbiAgcGxhbi50ZXJyYWZvcm0/LmZvckVhY2goKHsgcmVxdWlyZWRfcHJvdmlkZXJzIH0pID0+XG4gICAgKHJlcXVpcmVkX3Byb3ZpZGVycyB8fCBbXSkuZm9yRWFjaCgocHJvdmlkZXJCbG9jaykgPT5cbiAgICAgIE9iamVjdC5lbnRyaWVzKHByb3ZpZGVyQmxvY2spLmZvckVhY2goKFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgICBsZXQgbmFtZSwgdmVyc2lvbjtcbiAgICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gXCJzdHJpbmdcIikge1xuICAgICAgICAgIG5hbWUgPSBrZXk7XG4gICAgICAgICAgdmVyc2lvbiA9IHZhbHVlO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIG5hbWUgPSB2YWx1ZS5zb3VyY2U7XG4gICAgICAgICAgdmVyc2lvbiA9IHZhbHVlLnZlcnNpb247XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoIW5hbWUpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgLy8gaW1wbGljaXRseSBvbmx5IHRoZSBsYXN0IHBhcnQgb2YgdGhlIHBhdGggaXMgdXNlZCAoZS5nLiBkb2NrZXIgZm9yIGtyZXV6d2Vya2VyL2RvY2tlcilcbiAgICAgICAgY29uc3QgcGFydHMgPSBuYW1lLnNwbGl0KFwiL1wiKTtcbiAgICAgICAgaWYgKHBhcnRzLmxlbmd0aCA+IDEpIHtcbiAgICAgICAgICBkZWxldGUgcHJvdmlkZXJSZXF1aXJlbWVudHNbcGFydHMucG9wKCkgfHwgXCJcIl07XG4gICAgICAgIH1cbiAgICAgICAgcHJvdmlkZXJSZXF1aXJlbWVudHNbbmFtZV0gPSB2ZXJzaW9uIHx8IFwiKlwiO1xuICAgICAgfSksXG4gICAgKSxcbiAgKTtcblxuICByZXR1cm4gcHJvdmlkZXJSZXF1aXJlbWVudHM7XG59XG4iXX0=
package/lib/references.js DELETED
@@ -1,141 +0,0 @@
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.findUsedReferences = exports.extractReferencesFromExpression = exports.containsReference = exports.referenceToVariableName = void 0;
8
- const hcl2json_1 = require("@cdktn/hcl2json");
9
- const utils_1 = require("./utils");
10
- const variables_1 = require("./variables");
11
- function referenceToVariableName(scope, ref) {
12
- const parts = ref.referencee.id.split(".");
13
- const resource = parts[0] === "data" ? `${parts[0]}.${parts[1]}` : parts[0];
14
- const name = parts[0] === "data" ? parts[2] : parts[1];
15
- return (0, variables_1.variableName)(scope, resource, name);
16
- }
17
- exports.referenceToVariableName = referenceToVariableName;
18
- function containsReference(expression) {
19
- if (!hcl2json_1.TFExpressionSyntaxTree.isScopeTraversalExpression(expression)) {
20
- return false;
21
- }
22
- const segments = expression.meta.traversal;
23
- const rootSegment = segments[0].segment;
24
- const fullAccessor = expression.meta.fullAccessor;
25
- if (rootSegment === "count" || // count variable
26
- rootSegment === "each" || // each variable
27
- // https://www.terraform.io/docs/language/expressions/references.html#filesystem-and-workspace-info
28
- fullAccessor.startsWith("path.module") ||
29
- fullAccessor.startsWith("path.root") ||
30
- fullAccessor.startsWith("path.cwd") ||
31
- fullAccessor.startsWith("terraform.workspace") ||
32
- fullAccessor.startsWith("self.") // block local value
33
- ) {
34
- utils_1.logger.debug(`skipping ${fullAccessor}`);
35
- return false;
36
- }
37
- return true;
38
- }
39
- exports.containsReference = containsReference;
40
- async function extractReferencesFromExpression(input, nodeIds, scopedIds = []) {
41
- utils_1.logger.debug(`extractReferencesFromExpression(${input})`);
42
- const possibleVariableSpots = await (0, hcl2json_1.getReferencesInExpression)("main.tf", input);
43
- utils_1.logger.debug(`found possible variable spots: ${JSON.stringify(possibleVariableSpots)}`);
44
- return possibleVariableSpots.reduce((carry, spot) => {
45
- const { value, startPosition, endPosition } = spot;
46
- // no reference
47
- if (!value.includes(".") || // just a literal
48
- value.startsWith(".") || // dangling property access
49
- value.endsWith("...") || // spread (likely in for loop)
50
- value.startsWith("count.") || // count variable
51
- value.startsWith("each.") || // each variable
52
- // https://www.terraform.io/docs/language/expressions/references.html#filesystem-and-workspace-info
53
- value.startsWith("path.module") ||
54
- value.startsWith("path.root") ||
55
- value.startsWith("path.cwd") ||
56
- value.startsWith("terraform.workspace") ||
57
- value.startsWith("self.") // block local value
58
- ) {
59
- utils_1.logger.debug(`skipping ${value}`);
60
- return carry;
61
- }
62
- const referenceParts = value.split(".");
63
- utils_1.logger.debug(`Searching for node id '${value}' in ${JSON.stringify(nodeIds)}`);
64
- const corespondingNodeId = [...nodeIds, ...scopedIds].find((id) => {
65
- const parts = id.split(".");
66
- const matchesFirst = parts[0] === referenceParts[0];
67
- const matchesFirstTwo = matchesFirst &&
68
- (parts[1] === referenceParts[1] || referenceParts.length === 1);
69
- return (matchesFirstTwo &&
70
- (parts[0] === "data" ? parts[2] === referenceParts[2] : true));
71
- });
72
- if (!corespondingNodeId) {
73
- // This is most likely a false positive, so we just ignore it
74
- // We include the log below to help debugging
75
- utils_1.logger.error(`Found a reference that is unknown: ${input} has reference "${value}".The id was not found in ${JSON.stringify(nodeIds)} with temporary values ${JSON.stringify(scopedIds)}.
76
- ${utils_1.leaveCommentText}`);
77
- return carry;
78
- }
79
- if (scopedIds.includes(corespondingNodeId)) {
80
- utils_1.logger.debug(`skipping '${value}' since it's a scoped variable`);
81
- return carry;
82
- }
83
- utils_1.logger.debug(`Found node id '${corespondingNodeId}'`);
84
- const spotParts = value.split(".");
85
- let isThereANumericAccessor = false;
86
- const referenceSpotParts = spotParts.filter((part) => {
87
- if (!Number.isNaN(parseInt(part, 10))) {
88
- isThereANumericAccessor = true;
89
- return false;
90
- }
91
- return !isThereANumericAccessor;
92
- });
93
- const fullReference = isThereANumericAccessor
94
- ? referenceSpotParts.slice(0, 2).join(".")
95
- : value;
96
- const isVariable = value.startsWith("var.");
97
- const useFqn =
98
- // Can not use FQN on vars
99
- !isVariable &&
100
- // Can not use FQN on locals
101
- !value.startsWith("local.") &&
102
- // If the following character is
103
- (input.substr(endPosition + 1, 1) === "*" || // a * (splat) we need to use the FQN
104
- input.substr(endPosition, 1) === "[" || // a property access
105
- isThereANumericAccessor); // a numeric access
106
- const ref = {
107
- start: startPosition,
108
- end: endPosition,
109
- referencee: {
110
- id: corespondingNodeId,
111
- full: fullReference,
112
- },
113
- useFqn,
114
- isVariable,
115
- };
116
- utils_1.logger.debug(`Found reference ${JSON.stringify(ref)}`);
117
- return [...carry, ref];
118
- }, []);
119
- }
120
- exports.extractReferencesFromExpression = extractReferencesFromExpression;
121
- async function findUsedReferences(nodeIds, item) {
122
- utils_1.logger.debug(`findUsedReferences(${nodeIds}, ${item})`);
123
- if (typeof item === "string") {
124
- return await extractReferencesFromExpression(item, nodeIds, []);
125
- }
126
- if (typeof item !== "object" || item === null || item === undefined) {
127
- return [];
128
- }
129
- if (Array.isArray(item)) {
130
- return (await Promise.all(item.map((i) => findUsedReferences(nodeIds, i)))).flat();
131
- }
132
- if (item && "dynamic" in item) {
133
- const dyn = item["dynamic"];
134
- const { for_each, ...others } = dyn;
135
- const dynamicRef = Object.keys(others)[0];
136
- return await findUsedReferences([...nodeIds, dynamicRef], dyn);
137
- }
138
- return (await Promise.all(Object.values(item).map((i) => findUsedReferences(nodeIds, i)))).flat();
139
- }
140
- exports.findUsedReferences = findUsedReferences;
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"references.js","sourceRoot":"","sources":["references.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) HashiCorp, Inc.\n * SPDX-License-Identifier: MPL-2.0\n */\n\nimport {\n  getReferencesInExpression,\n  TFExpressionSyntaxTree as tex,\n} from \"@cdktn/hcl2json\";\nimport { leaveCommentText, logger } from \"./utils\";\nimport { ProgramScope, Reference, TerraformResourceBlock } from \"./types\";\nimport { variableName } from \"./variables\";\n\nexport function referenceToVariableName(\n  scope: ProgramScope,\n  ref: Reference,\n): string {\n  const parts = ref.referencee.id.split(\".\");\n  const resource = parts[0] === \"data\" ? `${parts[0]}.${parts[1]}` : parts[0];\n  const name = parts[0] === \"data\" ? parts[2] : parts[1];\n  return variableName(scope, resource, name);\n}\n\nexport function containsReference(expression: tex.ExpressionType) {\n  if (!tex.isScopeTraversalExpression(expression)) {\n    return false;\n  }\n\n  const segments = expression.meta.traversal;\n  const rootSegment = segments[0].segment;\n  const fullAccessor = expression.meta.fullAccessor;\n\n  if (\n    rootSegment === \"count\" || // count variable\n    rootSegment === \"each\" || // each variable\n    // https://www.terraform.io/docs/language/expressions/references.html#filesystem-and-workspace-info\n    fullAccessor.startsWith(\"path.module\") ||\n    fullAccessor.startsWith(\"path.root\") ||\n    fullAccessor.startsWith(\"path.cwd\") ||\n    fullAccessor.startsWith(\"terraform.workspace\") ||\n    fullAccessor.startsWith(\"self.\") // block local value\n  ) {\n    logger.debug(`skipping ${fullAccessor}`);\n    return false;\n  }\n\n  return true;\n}\n\nexport async function extractReferencesFromExpression(\n  input: string,\n  nodeIds: readonly string[],\n  scopedIds: readonly string[] = [], // dynamics introduce new scoped variables that are not the globally accessible ids\n): Promise<Reference[]> {\n  logger.debug(`extractReferencesFromExpression(${input})`);\n  const possibleVariableSpots = await getReferencesInExpression(\n    \"main.tf\",\n    input,\n  );\n\n  logger.debug(\n    `found possible variable spots: ${JSON.stringify(possibleVariableSpots)}`,\n  );\n\n  return possibleVariableSpots.reduce((carry, spot) => {\n    const { value, startPosition, endPosition } = spot;\n    // no reference\n    if (\n      !value.includes(\".\") || // just a literal\n      value.startsWith(\".\") || // dangling property access\n      value.endsWith(\"...\") || // spread (likely in for loop)\n      value.startsWith(\"count.\") || // count variable\n      value.startsWith(\"each.\") || // each variable\n      // https://www.terraform.io/docs/language/expressions/references.html#filesystem-and-workspace-info\n      value.startsWith(\"path.module\") ||\n      value.startsWith(\"path.root\") ||\n      value.startsWith(\"path.cwd\") ||\n      value.startsWith(\"terraform.workspace\") ||\n      value.startsWith(\"self.\") // block local value\n    ) {\n      logger.debug(`skipping ${value}`);\n      return carry;\n    }\n\n    const referenceParts = value.split(\".\");\n\n    logger.debug(\n      `Searching for node id '${value}' in ${JSON.stringify(nodeIds)}`,\n    );\n    const corespondingNodeId = [...nodeIds, ...scopedIds].find((id) => {\n      const parts = id.split(\".\");\n      const matchesFirst = parts[0] === referenceParts[0];\n      const matchesFirstTwo =\n        matchesFirst &&\n        (parts[1] === referenceParts[1] || referenceParts.length === 1);\n\n      return (\n        matchesFirstTwo &&\n        (parts[0] === \"data\" ? parts[2] === referenceParts[2] : true)\n      );\n    });\n\n    if (!corespondingNodeId) {\n      // This is most likely a false positive, so we just ignore it\n      // We include the log below to help debugging\n      logger.error(\n        `Found a reference that is unknown: ${input} has reference \"${value}\".The id was not found in ${JSON.stringify(\n          nodeIds,\n        )} with temporary values ${JSON.stringify(scopedIds)}.\n${leaveCommentText}`,\n      );\n      return carry;\n    }\n\n    if (scopedIds.includes(corespondingNodeId)) {\n      logger.debug(`skipping '${value}' since it's a scoped variable`);\n      return carry;\n    }\n    logger.debug(`Found node id '${corespondingNodeId}'`);\n\n    const spotParts = value.split(\".\");\n    let isThereANumericAccessor = false;\n    const referenceSpotParts = spotParts.filter((part) => {\n      if (!Number.isNaN(parseInt(part, 10))) {\n        isThereANumericAccessor = true;\n        return false;\n      }\n\n      return !isThereANumericAccessor;\n    });\n    const fullReference = isThereANumericAccessor\n      ? referenceSpotParts.slice(0, 2).join(\".\")\n      : value;\n\n    const isVariable = value.startsWith(\"var.\");\n    const useFqn =\n      // Can not use FQN on vars\n      !isVariable &&\n      // Can not use FQN on locals\n      !value.startsWith(\"local.\") &&\n      // If the following character is\n      (input.substr(endPosition + 1, 1) === \"*\" || // a * (splat) we need to use the FQN\n        input.substr(endPosition, 1) === \"[\" || // a property access\n        isThereANumericAccessor); // a numeric access\n\n    const ref: Reference = {\n      start: startPosition,\n      end: endPosition,\n      referencee: {\n        id: corespondingNodeId,\n        full: fullReference,\n      },\n      useFqn,\n      isVariable,\n    };\n    logger.debug(`Found reference ${JSON.stringify(ref)}`);\n    return [...carry, ref];\n  }, [] as Reference[]);\n}\n\nexport async function findUsedReferences(\n  nodeIds: string[],\n  item: TerraformResourceBlock,\n): Promise<Reference[]> {\n  logger.debug(`findUsedReferences(${nodeIds}, ${item})`);\n  if (typeof item === \"string\") {\n    return await extractReferencesFromExpression(item, nodeIds, []);\n  }\n\n  if (typeof item !== \"object\" || item === null || item === undefined) {\n    return [];\n  }\n\n  if (Array.isArray(item)) {\n    return (\n      await Promise.all(item.map((i) => findUsedReferences(nodeIds, i)))\n    ).flat();\n  }\n\n  if (item && \"dynamic\" in item) {\n    const dyn = (item as any)[\"dynamic\"];\n    const { for_each, ...others } = dyn;\n    const dynamicRef = Object.keys(others)[0];\n    return await findUsedReferences([...nodeIds, dynamicRef], dyn);\n  }\n\n  return (\n    await Promise.all(\n      Object.values(item as Record<string, any>).map((i) =>\n        findUsedReferences(nodeIds, i),\n      ),\n    )\n  ).flat();\n}\n"]}