projen-cdktf-hybrid-construct 0.1.1

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/lib/index.d.ts ADDED
@@ -0,0 +1,11 @@
1
+ import { ConstructLibrary, ConstructLibraryOptions } from "projen/lib/cdk";
2
+ declare type HybridModuleOptions = ConstructLibraryOptions & {
3
+ cdktfVersion?: string;
4
+ constructVersion?: string;
5
+ repository: string;
6
+ author: string;
7
+ };
8
+ export declare class HybridModule extends ConstructLibrary {
9
+ constructor(config: HybridModuleOptions);
10
+ }
11
+ export {};
package/lib/index.js ADDED
@@ -0,0 +1,153 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HybridModule = void 0;
4
+ const projen_1 = require("projen");
5
+ const cdk_1 = require("projen/lib/cdk");
6
+ const defaults = {
7
+ prettier: true,
8
+ defaultReleaseBranch: "main",
9
+ };
10
+ const constructSrcCode = `
11
+ import { Construct } from "constructs";
12
+
13
+ export interface MyConstructOptions {
14
+ readonly propertyA: string;
15
+ }
16
+
17
+ export class MyConstruct extends Construct {
18
+ constructor(scope: Construct, id: string, public config: MyConstructOptions) {
19
+ super(scope, id);
20
+ }
21
+ }
22
+ `;
23
+ const moduleSrcCode = `
24
+ import { App } from "cdktf";
25
+ import { Construct } from "constructs";
26
+ import { TFModuleStack } from "cdktf-tf-module-stack";
27
+ import { MyConstruct } from "./index";
28
+
29
+ class MyAwesomeModule extends TFModuleStack {
30
+ constructor(scope: Construct, id: string) {
31
+ super(scope, id);
32
+
33
+ new MyConstruct(this, "my-construct", {
34
+ propertyA: "valueA",
35
+ });
36
+ }
37
+ }
38
+
39
+ const app = new App();
40
+ // This is the name the module can be found under.
41
+ // We expect a "my-awesome-module.md" file in this directory.
42
+ // The README.md file will be generated from this file.
43
+ new MyAwesomeModule(app, "my-awesome-module");
44
+ app.synth();
45
+ `;
46
+ class ScriptFile extends projen_1.FileBase {
47
+ constructor(project, path, content) {
48
+ super(project, path, {
49
+ executable: true,
50
+ });
51
+ this.content = content;
52
+ }
53
+ synthesizeContent(_) {
54
+ return this.content;
55
+ }
56
+ }
57
+ class HybridModule extends cdk_1.ConstructLibrary {
58
+ constructor(config) {
59
+ var _a, _b;
60
+ super({ ...defaults, ...config, sampleCode: false });
61
+ const constructVersion = config.constructVersion || "^10.0.25";
62
+ const cdktfVersion = config.cdktfVersion || "^0.9.4";
63
+ this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);
64
+ this.addDevDeps(`cdktf-cli@${cdktfVersion}`, "ts-node");
65
+ this.addKeywords("cdktf", "cdktf-hybrid");
66
+ // Module Entrypoint
67
+ this.addDeps("cdktf-tf-module-stack");
68
+ const moduleDocs = `
69
+ # My Awesome Module
70
+
71
+ ## Usage
72
+
73
+ \`\`\`hcl
74
+ module "eks_managed_node_group" {
75
+ source = "${((_a = config.repository) === null || _a === void 0 ? void 0 : _a.replace("https://github.com/", "").replace("http://github.com/", "").replace("github.com/", "")) || "my-github-repo"}//modules/my-awesome-module"
76
+
77
+ }
78
+ \`\`\`
79
+ `;
80
+ new projen_1.SampleDir(this, this.srcdir, {
81
+ files: {
82
+ "index.ts": constructSrcCode.trim(),
83
+ "tfModules.ts": moduleSrcCode.trim(),
84
+ "my-awesome-module.md": moduleDocs.trim(),
85
+ "cdktf.json": JSON.stringify({
86
+ language: "typescript",
87
+ app: "npx ts-node tfModules.ts",
88
+ terraformProviders: ["hashicorp/null@3.1.1"],
89
+ terraformModules: [],
90
+ output: "modules",
91
+ }, null, 2),
92
+ },
93
+ });
94
+ this.gitignore.addPatterns("src/.gen", "src/cdktf.out", "src/modules");
95
+ this.compileTask.prependExec("cdktf get", {
96
+ cwd: this.srcdir,
97
+ });
98
+ this.compileTask.exec("cdktf synth", {
99
+ cwd: this.srcdir,
100
+ name: "Synthesize module HCL",
101
+ });
102
+ new ScriptFile(this, "scripts/copy-modules.sh", `
103
+ #!/bin/bash
104
+ # This script is created by projen, do not edit it directly.
105
+ set -e
106
+
107
+ SCRIPTPATH="$( cd -- "$(dirname "$0")" >/dev/null 2>&1 ; pwd -P )"
108
+
109
+ # check if the module folder has been generated as expected
110
+ MODULES_FOLDER=$( cd -- "$SCRIPTPATH/../src/modules/stacks" >/dev/null 2>&1 ; pwd -P )
111
+ SRC_FOLDER=$( cd -- "$SCRIPTPATH/../src/" >/dev/null 2>&1 ; pwd -P )
112
+ TARGET_FOLDER="$SCRIPTPATH/../modules"
113
+
114
+ if [ ! -d "$MODULES_FOLDER" ]; then
115
+ echo "Expected module folder to exist at $MODULES_FOLDER"
116
+ exit 1
117
+ fi
118
+
119
+ cd "$MODULES_FOLDER"
120
+ for d in */ ; do
121
+ [ -L "\${d%/}" ] && continue
122
+
123
+ dirname="\${d%/}"
124
+
125
+
126
+ # Check if everything is in place
127
+ if [ ! -f "$MODULES_FOLDER/$dirname/cdk.tf.json" ]; then
128
+ echo "Expected code for $dirname at cdk.tf.json to exist at $MODULES_FOLDER/$dirname"
129
+ exit 1
130
+ fi
131
+
132
+ if [ ! -f "$SRC_FOLDER/$dirname.md" ]; then
133
+ echo "Expected Documentation for $dirname at $dirname.md to exist at $SRC_FOLDER/$dirname.md"
134
+ exit 1
135
+ fi
136
+
137
+ # Copy module and readme together
138
+ echo "Copying Code and README for module $dirname"
139
+ mkdir -p "$TARGET_FOLDER"
140
+ mkdir -p "$TARGET_FOLDER/$dirname"
141
+ cp "$MODULES_FOLDER/$dirname/cdk.tf.json" "$TARGET_FOLDER/$dirname/cdk.tf.json"
142
+ cp "$SRC_FOLDER/$dirname.md" "$TARGET_FOLDER/$dirname/README.md"
143
+ done
144
+ `.trim());
145
+ this.compileTask.exec("./scripts/copy-modules.sh", {
146
+ name: "Copy HCL Modules",
147
+ });
148
+ // ignore dist in tests
149
+ (_b = this.jest) === null || _b === void 0 ? void 0 : _b.addIgnorePattern("dist");
150
+ }
151
+ }
152
+ exports.HybridModule = HybridModule;
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { FileBase, IResolver, Project, SampleDir } from \"projen\";\nimport { ConstructLibrary, ConstructLibraryOptions } from \"projen/lib/cdk\";\n\ntype HybridModuleOptions = ConstructLibraryOptions & {\n  cdktfVersion?: string;\n  constructVersion?: string;\n  repository: string;\n  author: string;\n};\n\nconst defaults = {\n  prettier: true,\n  defaultReleaseBranch: \"main\",\n};\n\nconst constructSrcCode = `\nimport { Construct } from \"constructs\";\n\nexport interface MyConstructOptions {\n  readonly propertyA: string;\n}\n\nexport class MyConstruct extends Construct {\n  constructor(scope: Construct, id: string, public config: MyConstructOptions) {\n    super(scope, id);\n  }\n}\n`;\n\nconst moduleSrcCode = `\nimport { App } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { TFModuleStack } from \"cdktf-tf-module-stack\";\nimport { MyConstruct } from \"./index\";\n\nclass MyAwesomeModule extends TFModuleStack {\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n\n    new MyConstruct(this, \"my-construct\", {\n      propertyA: \"valueA\",\n    });\n  }\n}\n\nconst app = new App();\n// This is the name the module can be found under. \n// We expect a \"my-awesome-module.md\" file in this directory.\n// The README.md file will be generated from this file.\nnew MyAwesomeModule(app, \"my-awesome-module\");\napp.synth();\n`;\n\nclass ScriptFile extends FileBase {\n  constructor(project: Project, path: string, private content: string) {\n    super(project, path, {\n      executable: true,\n    });\n  }\n\n  protected synthesizeContent(_: IResolver): string | undefined {\n    return this.content;\n  }\n}\n\nexport class HybridModule extends ConstructLibrary {\n  constructor(config: HybridModuleOptions) {\n    super({ ...defaults, ...config, sampleCode: false });\n    const constructVersion = config.constructVersion || \"^10.0.25\";\n    const cdktfVersion = config.cdktfVersion || \"^0.9.4\";\n\n    this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);\n    this.addDevDeps(`cdktf-cli@${cdktfVersion}`, \"ts-node\");\n    this.addKeywords(\"cdktf\", \"cdktf-hybrid\");\n\n    // Module Entrypoint\n    this.addDeps(\"cdktf-tf-module-stack\");\n    const moduleDocs = `\n# My Awesome Module\n\n## Usage\n\n\\`\\`\\`hcl\nmodule \"eks_managed_node_group\" {\n  source = \"${\n    config.repository\n      ?.replace(\"https://github.com/\", \"\")\n      .replace(\"http://github.com/\", \"\")\n      .replace(\"github.com/\", \"\") || \"my-github-repo\"\n  }//modules/my-awesome-module\"\n\n}\n\\`\\`\\`\n    `;\n\n    new SampleDir(this, this.srcdir, {\n      files: {\n        \"index.ts\": constructSrcCode.trim(),\n        \"tfModules.ts\": moduleSrcCode.trim(),\n        \"my-awesome-module.md\": moduleDocs.trim(),\n        \"cdktf.json\": JSON.stringify(\n          {\n            language: \"typescript\",\n            app: \"npx ts-node tfModules.ts\",\n            terraformProviders: [\"hashicorp/null@3.1.1\"], // We need at least a provider for get to succeed\n            terraformModules: [],\n            output: \"modules\",\n          },\n          null,\n          2\n        ),\n      },\n    });\n\n    this.gitignore.addPatterns(\"src/.gen\", \"src/cdktf.out\", \"src/modules\");\n    this.compileTask.prependExec(\"cdktf get\", {\n      cwd: this.srcdir,\n    });\n    this.compileTask.exec(\"cdktf synth\", {\n      cwd: this.srcdir,\n      name: \"Synthesize module HCL\",\n    });\n\n    new ScriptFile(\n      this,\n      \"scripts/copy-modules.sh\",\n      `\n#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nSCRIPTPATH=\"$( cd -- \"$(dirname \"$0\")\" >/dev/null 2>&1 ; pwd -P )\"\n\n# check if the module folder has been generated as expected\nMODULES_FOLDER=$( cd -- \"$SCRIPTPATH/../src/modules/stacks\" >/dev/null 2>&1 ; pwd -P )\nSRC_FOLDER=$( cd -- \"$SCRIPTPATH/../src/\" >/dev/null 2>&1 ; pwd -P )\nTARGET_FOLDER=\"$SCRIPTPATH/../modules\"\n\nif [ ! -d \"$MODULES_FOLDER\" ]; then\n  echo \"Expected module folder to exist at $MODULES_FOLDER\"\n  exit 1\nfi\n\ncd \"$MODULES_FOLDER\"\nfor d in */ ; do\n    [ -L \"\\${d%/}\" ] && continue\n\n    dirname=\"\\${d%/}\"\n\n\n    # Check if everything is in place\n    if [ ! -f \"$MODULES_FOLDER/$dirname/cdk.tf.json\" ]; then\n      echo \"Expected code for $dirname at cdk.tf.json to exist at $MODULES_FOLDER/$dirname\"\n      exit 1\n    fi\n\n    if [ ! -f \"$SRC_FOLDER/$dirname.md\" ]; then\n      echo \"Expected Documentation for $dirname at $dirname.md to exist at $SRC_FOLDER/$dirname.md\"\n      exit 1\n    fi\n\n    # Copy module and readme together\n    echo \"Copying Code and README for module $dirname\"\n    mkdir -p \"$TARGET_FOLDER\"\n    mkdir -p \"$TARGET_FOLDER/$dirname\"\n    cp \"$MODULES_FOLDER/$dirname/cdk.tf.json\" \"$TARGET_FOLDER/$dirname/cdk.tf.json\"\n    cp \"$SRC_FOLDER/$dirname.md\" \"$TARGET_FOLDER/$dirname/README.md\"\ndone\n`.trim()\n    );\n    this.compileTask.exec(\"./scripts/copy-modules.sh\", {\n      name: \"Copy HCL Modules\",\n    });\n\n    // ignore dist in tests\n    this.jest?.addIgnorePattern(\"dist\");\n  }\n}\n"]}
package/package.json ADDED
@@ -0,0 +1,100 @@
1
+ {
2
+ "name": "projen-cdktf-hybrid-construct",
3
+ "description": "Projen template for CDKTF Constructs that should also be used as Terraform Modules.",
4
+ "scripts": {
5
+ "build": "npx projen build",
6
+ "buildExample": "npx projen buildExample",
7
+ "bump": "npx projen bump",
8
+ "clobber": "npx projen clobber",
9
+ "compile": "npx projen compile",
10
+ "default": "npx projen default",
11
+ "eject": "npx projen eject",
12
+ "eslint": "npx projen eslint",
13
+ "package": "npx projen package",
14
+ "post-compile": "npx projen post-compile",
15
+ "post-upgrade": "npx projen post-upgrade",
16
+ "pre-compile": "npx projen pre-compile",
17
+ "release": "npx projen release",
18
+ "test": "npx projen test",
19
+ "test:update": "npx projen test:update",
20
+ "test:watch": "npx projen test:watch",
21
+ "unbump": "npx projen unbump",
22
+ "upgrade": "npx projen upgrade",
23
+ "upgrade-projen": "npx projen upgrade-projen",
24
+ "watch": "npx projen watch",
25
+ "projen": "npx projen"
26
+ },
27
+ "devDependencies": {
28
+ "@types/fs-extra": "^9.0.13",
29
+ "@types/glob": "^7.2.0",
30
+ "@types/jest": "^27.4.1",
31
+ "@types/node": "^12",
32
+ "@typescript-eslint/eslint-plugin": "^5",
33
+ "@typescript-eslint/parser": "^5",
34
+ "eslint": "^8",
35
+ "eslint-config-prettier": "^8.5.0",
36
+ "eslint-import-resolver-node": "^0.3.6",
37
+ "eslint-import-resolver-typescript": "^2.5.0",
38
+ "eslint-plugin-import": "^2.25.4",
39
+ "eslint-plugin-prettier": "^4.0.0",
40
+ "fs-extra": "^10.0.1",
41
+ "glob": "^7.2.0",
42
+ "jest": "^27.5.1",
43
+ "jest-junit": "^13",
44
+ "json-schema": "^0.4.0",
45
+ "npm-check-updates": "^12",
46
+ "prettier": "^2.6.0",
47
+ "projen": "^0.53.6",
48
+ "standard-version": "^9",
49
+ "ts-jest": "^27.1.3",
50
+ "typescript": "^4.6.2"
51
+ },
52
+ "dependencies": {
53
+ "projen": "^0.53.6"
54
+ },
55
+ "main": "lib/index.js",
56
+ "license": "MIT",
57
+ "version": "0.1.1",
58
+ "jest": {
59
+ "testMatch": [
60
+ "<rootDir>/src/**/__tests__/**/*.ts?(x)",
61
+ "<rootDir>/(test|src)/**/?(*.)+(spec|test).ts?(x)"
62
+ ],
63
+ "clearMocks": true,
64
+ "collectCoverage": true,
65
+ "coverageReporters": [
66
+ "json",
67
+ "lcov",
68
+ "clover",
69
+ "cobertura",
70
+ "text"
71
+ ],
72
+ "coverageDirectory": "coverage",
73
+ "coveragePathIgnorePatterns": [
74
+ "/node_modules/"
75
+ ],
76
+ "testPathIgnorePatterns": [
77
+ "/node_modules/"
78
+ ],
79
+ "watchPathIgnorePatterns": [
80
+ "/node_modules/"
81
+ ],
82
+ "reporters": [
83
+ "default",
84
+ [
85
+ "jest-junit",
86
+ {
87
+ "outputDirectory": "test-reports"
88
+ }
89
+ ]
90
+ ],
91
+ "preset": "ts-jest",
92
+ "globals": {
93
+ "ts-jest": {
94
+ "tsconfig": "tsconfig.dev.json"
95
+ }
96
+ }
97
+ },
98
+ "types": "lib/index.d.ts",
99
+ "//": "~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\"."
100
+ }