@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.
- package/ambient.d.ts +0 -1
- package/build/__tests__/coerceType.test.js +165 -0
- package/build/__tests__/expressionToTs.test.js +693 -0
- package/build/__tests__/expressions.test.js +415 -0
- package/build/__tests__/findExpressionType.test.js +105 -0
- package/build/__tests__/functions.test.js +605 -0
- package/build/__tests__/generation.test.js +45 -0
- package/build/__tests__/jsii-rosetta-workarounds.test.js +86 -0
- package/build/__tests__/partialCode.test.js +390 -0
- package/build/__tests__/terraformSchema.test.js +105 -0
- package/build/__tests__/testHelpers.js +16 -0
- package/build/coerceType.js +240 -0
- package/build/dynamic-blocks.js +44 -0
- package/build/expressions.js +633 -0
- package/build/function-bindings/functions.generated.js +1142 -0
- package/build/function-bindings/functions.js +73 -0
- package/{lib → build}/generation.js +4 -4
- package/{lib → build}/index.d.ts +2 -2
- package/build/index.js +364 -0
- package/build/iteration.js +87 -0
- package/build/jsii-rosetta-workarounds.js +126 -0
- package/build/partialCode.js +116 -0
- package/build/provider.js +40 -0
- package/build/references.js +141 -0
- package/build/schema.js +81 -0
- package/build/telemetryAllowList.json +24 -0
- package/build/terraformSchema.js +136 -0
- package/build/types.js +3 -0
- package/build/utils.js +25 -0
- package/build/variables.js +172 -0
- package/package.json +13 -14
- package/tsconfig.json +4 -2
- package/lib/__tests__/coerceType.test.js +0 -165
- package/lib/__tests__/expressionToTs.test.js +0 -693
- package/lib/__tests__/expressions.test.js +0 -415
- package/lib/__tests__/findExpressionType.test.js +0 -105
- package/lib/__tests__/functions.test.js +0 -605
- package/lib/__tests__/generation.test.js +0 -45
- package/lib/__tests__/jsii-rosetta-workarounds.test.js +0 -86
- package/lib/__tests__/partialCode.test.js +0 -390
- package/lib/__tests__/terraformSchema.test.js +0 -105
- package/lib/__tests__/testHelpers.js +0 -16
- package/lib/coerceType.js +0 -240
- package/lib/dynamic-blocks.js +0 -44
- package/lib/expressions.js +0 -634
- package/lib/function-bindings/functions.generated.js +0 -1142
- package/lib/function-bindings/functions.js +0 -73
- package/lib/index.js +0 -364
- package/lib/iteration.js +0 -87
- package/lib/jsii-rosetta-workarounds.js +0 -126
- package/lib/partialCode.js +0 -116
- package/lib/provider.js +0 -40
- package/lib/references.js +0 -141
- package/lib/schema.js +0 -81
- package/lib/terraformSchema.js +0 -136
- package/lib/types.js +0 -3
- package/lib/utils.js +0 -25
- package/lib/variables.js +0 -172
- /package/{lib → build}/__tests__/coerceType.test.d.ts +0 -0
- /package/{lib → build}/__tests__/expressionToTs.test.d.ts +0 -0
- /package/{lib → build}/__tests__/expressions.test.d.ts +0 -0
- /package/{lib → build}/__tests__/findExpressionType.test.d.ts +0 -0
- /package/{lib → build}/__tests__/functions.test.d.ts +0 -0
- /package/{lib → build}/__tests__/generation.test.d.ts +0 -0
- /package/{lib → build}/__tests__/jsii-rosetta-workarounds.test.d.ts +0 -0
- /package/{lib → build}/__tests__/partialCode.test.d.ts +0 -0
- /package/{lib → build}/__tests__/terraformSchema.test.d.ts +0 -0
- /package/{lib → build}/__tests__/testHelpers.d.ts +0 -0
- /package/{lib → build}/coerceType.d.ts +0 -0
- /package/{lib → build}/dynamic-blocks.d.ts +0 -0
- /package/{lib → build}/expressions.d.ts +0 -0
- /package/{lib → build}/function-bindings/functions.d.ts +0 -0
- /package/{lib → build}/function-bindings/functions.generated.d.ts +0 -0
- /package/{lib → build}/generation.d.ts +0 -0
- /package/{lib → build}/iteration.d.ts +0 -0
- /package/{lib → build}/jsii-rosetta-workarounds.d.ts +0 -0
- /package/{lib → build}/partialCode.d.ts +0 -0
- /package/{lib → build}/provider.d.ts +0 -0
- /package/{lib → build}/references.d.ts +0 -0
- /package/{lib → build}/schema.d.ts +0 -0
- /package/{lib → build}/terraformSchema.d.ts +0 -0
- /package/{lib → build}/types.d.ts +0 -0
- /package/{lib → build}/utils.d.ts +0 -0
- /package/{lib → build}/variables.d.ts +0 -0
- /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":"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","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"]}
|
package/lib/partialCode.js
DELETED
|
@@ -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":";AAAA;;;GAGG;;;AAEH,8CAGyB;AACzB,mCAAmD;AAEnD,2CAA2C;AAE3C,SAAgB,uBAAuB,CACrC,KAAmB,EACnB,GAAc;IAEd,MAAM,KAAK,GAAG,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC3C,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC5E,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACvD,OAAO,IAAA,wBAAY,EAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;AAC7C,CAAC;AARD,0DAQC;AAED,SAAgB,iBAAiB,CAAC,UAA8B;IAC9D,IAAI,CAAC,iCAAG,CAAC,0BAA0B,CAAC,UAAU,CAAC,EAAE,CAAC;QAChD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,QAAQ,GAAG,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC;IAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IACxC,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC;IAElD,IACE,WAAW,KAAK,OAAO,IAAI,iBAAiB;QAC5C,WAAW,KAAK,MAAM,IAAI,gBAAgB;QAC1C,mGAAmG;QACnG,YAAY,CAAC,UAAU,CAAC,aAAa,CAAC;QACtC,YAAY,CAAC,UAAU,CAAC,WAAW,CAAC;QACpC,YAAY,CAAC,UAAU,CAAC,UAAU,CAAC;QACnC,YAAY,CAAC,UAAU,CAAC,qBAAqB,CAAC;QAC9C,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,oBAAoB;MACrD,CAAC;QACD,cAAM,CAAC,KAAK,CAAC,YAAY,YAAY,EAAE,CAAC,CAAC;QACzC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAxBD,8CAwBC;AAEM,KAAK,UAAU,+BAA+B,CACnD,KAAa,EACb,OAA0B,EAC1B,YAA+B,EAAE;IAEjC,cAAM,CAAC,KAAK,CAAC,mCAAmC,KAAK,GAAG,CAAC,CAAC;IAC1D,MAAM,qBAAqB,GAAG,MAAM,IAAA,oCAAyB,EAC3D,SAAS,EACT,KAAK,CACN,CAAC;IAEF,cAAM,CAAC,KAAK,CACV,kCAAkC,IAAI,CAAC,SAAS,CAAC,qBAAqB,CAAC,EAAE,CAC1E,CAAC;IAEF,OAAO,qBAAqB,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;QAClD,MAAM,EAAE,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC;QACnD,eAAe;QACf,IACE,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,iBAAiB;YACzC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,2BAA2B;YACpD,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,8BAA8B;YACvD,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,iBAAiB;YAC/C,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,gBAAgB;YAC7C,mGAAmG;YACnG,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC;YAC/B,KAAK,CAAC,UAAU,CAAC,WAAW,CAAC;YAC7B,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC;YAC5B,KAAK,CAAC,UAAU,CAAC,qBAAqB,CAAC;YACvC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,oBAAoB;UAC9C,CAAC;YACD,cAAM,CAAC,KAAK,CAAC,YAAY,KAAK,EAAE,CAAC,CAAC;YAClC,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,cAAc,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAExC,cAAM,CAAC,KAAK,CACV,0BAA0B,KAAK,QAAQ,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CACjE,CAAC;QACF,MAAM,kBAAkB,GAAG,CAAC,GAAG,OAAO,EAAE,GAAG,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE;YAChE,MAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC5B,MAAM,YAAY,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,cAAc,CAAC,CAAC,CAAC,CAAC;YACpD,MAAM,eAAe,GACnB,YAAY;gBACZ,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,cAAc,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;YAElE,OAAO,CACL,eAAe;gBACf,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAC9D,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,6DAA6D;YAC7D,6CAA6C;YAC7C,cAAM,CAAC,KAAK,CACV,sCAAsC,KAAK,mBAAmB,KAAK,6BAA6B,IAAI,CAAC,SAAS,CAC5G,OAAO,CACR,0BAA0B,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;EAC1D,wBAAgB,EAAE,CACb,CAAC;YACF,OAAO,KAAK,CAAC;QACf,CAAC;QAED,IAAI,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,CAAC;YAC3C,cAAM,CAAC,KAAK,CAAC,aAAa,KAAK,gCAAgC,CAAC,CAAC;YACjE,OAAO,KAAK,CAAC;QACf,CAAC;QACD,cAAM,CAAC,KAAK,CAAC,kBAAkB,kBAAkB,GAAG,CAAC,CAAC;QAEtD,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACnC,IAAI,uBAAuB,GAAG,KAAK,CAAC;QACpC,MAAM,kBAAkB,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YACnD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC;gBACtC,uBAAuB,GAAG,IAAI,CAAC;gBAC/B,OAAO,KAAK,CAAC;YACf,CAAC;YAED,OAAO,CAAC,uBAAuB,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,MAAM,aAAa,GAAG,uBAAuB;YAC3C,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;YAC1C,CAAC,CAAC,KAAK,CAAC;QAEV,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC5C,MAAM,MAAM;QACV,0BAA0B;QAC1B,CAAC,UAAU;YACX,4BAA4B;YAC5B,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC;YAC3B,gCAAgC;YAChC,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,GAAG,IAAI,qCAAqC;gBAChF,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,KAAK,GAAG,IAAI,oBAAoB;gBAC5D,uBAAuB,CAAC,CAAC,CAAC,mBAAmB;QAEjD,MAAM,GAAG,GAAc;YACrB,KAAK,EAAE,aAAa;YACpB,GAAG,EAAE,WAAW;YAChB,UAAU,EAAE;gBACV,EAAE,EAAE,kBAAkB;gBACtB,IAAI,EAAE,aAAa;aACpB;YACD,MAAM;YACN,UAAU;SACX,CAAC;QACF,cAAM,CAAC,KAAK,CAAC,mBAAmB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACvD,OAAO,CAAC,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC,EAAE,EAAiB,CAAC,CAAC;AACxB,CAAC;AA7GD,0EA6GC;AAEM,KAAK,UAAU,kBAAkB,CACtC,OAAiB,EACjB,IAA4B;IAE5B,cAAM,CAAC,KAAK,CAAC,sBAAsB,OAAO,KAAK,IAAI,GAAG,CAAC,CAAC;IACxD,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;QAC7B,OAAO,MAAM,+BAA+B,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;QACpE,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACxB,OAAO,CACL,MAAM,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,CACnE,CAAC,IAAI,EAAE,CAAC;IACX,CAAC;IAED,IAAI,IAAI,IAAI,SAAS,IAAI,IAAI,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAI,IAAY,CAAC,SAAS,CAAC,CAAC;QACrC,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,EAAE,GAAG,GAAG,CAAC;QACpC,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,OAAO,MAAM,kBAAkB,CAAC,CAAC,GAAG,OAAO,EAAE,UAAU,CAAC,EAAE,GAAG,CAAC,CAAC;IACjE,CAAC;IAED,OAAO,CACL,MAAM,OAAO,CAAC,GAAG,CACf,MAAM,CAAC,MAAM,CAAC,IAA2B,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CACnD,kBAAkB,CAAC,OAAO,EAAE,CAAC,CAAC,CAC/B,CACF,CACF,CAAC,IAAI,EAAE,CAAC;AACX,CAAC;AAjCD,gDAiCC","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"]}
|