projen-cdktf-hybrid-construct 0.5.0 → 0.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -59,7 +59,7 @@
59
59
  "stability": "stable"
60
60
  },
61
61
  "homepage": "https://github.com/cdktf/projen-cdktf-hybrid-construct.git",
62
- "jsiiVersion": "5.2.14 (build 3ac02dc)",
62
+ "jsiiVersion": "5.2.21 (build 8d5c5fe)",
63
63
  "license": "MPL-2.0",
64
64
  "metadata": {
65
65
  "jsii": {
@@ -603,6 +603,6 @@
603
603
  "symbolId": "src/terraform-module:TerraformVersionConstraint"
604
604
  }
605
605
  },
606
- "version": "0.5.0",
607
- "fingerprint": "RORSjq50iegKi7/N8/bd3sT92bLF3HHDuHGrZf5B0+k="
606
+ "version": "0.5.2",
607
+ "fingerprint": "7P1m3npLLVefl22XtnfEXvKcvFB/6OhHhONJhE3Nc9Q="
608
608
  }
@@ -325,5 +325,5 @@ done
325
325
  }
326
326
  exports.HybridModule = HybridModule;
327
327
  _a = JSII_RTTI_SYMBOL_1;
328
- HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.5.0" };
328
+ HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.5.2" };
329
329
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hybrid-module.js","sourceRoot":"","sources":["../src/hybrid-module.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) HashiCorp, Inc.\n * SPDX-License-Identifier: MPL-2.0\n */\n\nimport * as path from \"path\";\nimport { FileBase, IResolver, Project, SampleDir } from \"projen\";\nimport { JsiiProject, ConstructLibraryOptions } from \"projen/lib/cdk\";\nimport { defaults } from \"./defaults\";\n\nexport interface ConstructExamplesOption {\n  // If set construct examples will be rendered\n  readonly enabled: boolean;\n  // Path for the construct examples\n  readonly folder?: string;\n}\n\nexport interface TerraformExamplesOption {\n  // If set terraform examples will be rendered\n  readonly enabled: boolean;\n  // Path for the terraform examples\n  readonly folder?: string;\n  // The HCL config file to use for the terraform provider\n  readonly providerConfig?: string;\n  // HCL example config\n  readonly exampleCode?: string;\n}\n\nexport interface HybridModuleOptions extends ConstructLibraryOptions {\n  /**\n   * Minimum target version of this library.\n   * @default \"0.19.0\"\n   * @featured\n   */\n  readonly cdktfVersion?: string;\n\n  /**\n   * Construct version to use\n   * @default \"^10.0.107\"\n   */\n  readonly constructVersion?: string;\n\n  /**\n   * If set a terraform examples folder will be created\n   * @default undefined\n   * @featured\n   */\n  readonly terraformExamples?: TerraformExamplesOption;\n\n  /**\n   * If set a construct examples folder will be created\n   * @default undefined\n   * @featured\n   */\n  readonly constructExamples?: ConstructExamplesOption;\n\n  /**\n   * If set a terraform examples folder will be created\n   *Defaults to a uuid string as cdktf would\n   * Mostly used for testing to have a predictable result\n   */\n  readonly projectId?: string;\n\n  /**\n   * If set a terraform plan is being run as part of the tests\n   */\n  readonly runPlan?: boolean;\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 constructTestCode = `\nimport { Testing } from \"cdktf\";\nimport \"cdktf/lib/testing/adapters/jest\";\nimport { MyConstruct } from \"../\";\n\n// To learn more about testing see cdk.tf/testing\ndescribe(\"MyConstruct\", () => {\n  it(\"should synthesize\", () => {\n    expect(\n      Testing.synthScope((scope) => {\n        new MyConstruct(scope, \"my-construct\", {\n          propertyA: \"valueA\",\n        });\n      })\n    ).toMatchSnapshot();\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\nconst terraformReadmeDocs = `\n# Please add here some pure HCL tests for your modules in order to test HCL Interoperability\n\nExamples:\n\nmodule \"my_awesome_test\" {\n  source = \"../modules/my-awesome-modules\"\n  ...variables...\n}\n    `;\n\nclass ScriptFile extends FileBase {\n  constructor(project: Project, filePath: string, private content: string) {\n    super(project, filePath, {\n      executable: true,\n    });\n  }\n\n  protected synthesizeContent(_: IResolver): string | undefined {\n    return this.content;\n  }\n}\n\nclass HCLFile extends FileBase {\n  constructor(project: Project, filePath: string, private content: string) {\n    super(project, filePath, {\n      executable: false,\n      committed: true,\n      readonly: false, // terraform fmt might want to overwrite it\n    });\n  }\n\n  protected synthesizeContent(_: IResolver): string | undefined {\n    return `# This file is managed by projen. Do not edit, change the .projenrc file instead.\n${this.content}`;\n  }\n}\n\n/**\n * Hybrid CDKTF Construct / Terraform Module\n *\n * @pjid hybrid-module\n */\nexport class HybridModule extends JsiiProject {\n  constructor(options: HybridModuleOptions) {\n    super({\n      ...defaults,\n      ...options,\n      eslintOptions: Object.assign({}, options.eslintOptions, {\n        lintProjenRc: false,\n      }),\n      postBuildSteps: [],\n    });\n    const constructVersion = options.constructVersion || \"10.0.107\";\n    const cdktfVersion = options.cdktfVersion || \"0.19.0\";\n\n    console.log({ cdktfVersion, constructVersion });\n    this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);\n    this.addDevDeps(\n      `cdktf-cli@${cdktfVersion}`,\n      \"ts-node@>=10.9.1\",\n      \"jsii-docgen@^9.0.0\"\n    );\n    this.addKeywords(\"cdk\", \"cdktf\", \"cdktf-hybrid\", \"terraform\");\n    this.setScript(\"terraform:test\", \"./scripts/tf-module-test.sh\");\n\n    // Module Entrypoint\n    this.addDeps(\"@cdktf/tf-module-stack@>=4.0.0\");\n    const moduleDocs = `\n# My Awesome Module\n\n## Usage\n\n\\`\\`\\`hcl\nmodule \"eks_managed_node_group\" {\n  source = \"${\n    options.repositoryUrl\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            projectId:\n              options.projectId ||\n              \"hybrid-module-fb734dba-eac9-466c-96bb-7eb9c406c28a\",\n          },\n          null,\n          2\n        ),\n        \"__tests__/index-test.ts\": constructTestCode.trim(),\n      },\n    });\n\n    if (options.terraformExamples && options.terraformExamples.enabled) {\n      const providerConfig =\n        options.terraformExamples.providerConfig ||\n        `\nterraform {\n  # Terraform binary version constraint\n  required_version = \">= 1.2.0\"\n\n  # Define all needed providers here, you can find all available providers here:\n  # https://registry.terraform.io/\n  required_providers {}\n}\n\n# Initialize your provider here\n\n`.trim();\n      const examplesFolder =\n        options.terraformExamples.folder || \"terraform-examples\";\n\n      new SampleDir(this, examplesFolder, {\n        files: {\n          \"main.tf\":\n            options.terraformExamples.exampleCode ||\n            `# Configure you module here`,\n          \"README.md\": terraformReadmeDocs.trim(),\n        },\n      });\n\n      new HCLFile(\n        this,\n        path.join(examplesFolder, \"provider.tf\"),\n        providerConfig\n      );\n\n      this.gitignore.addPatterns(\n        `${examplesFolder}/.terraform`,\n        `${examplesFolder}/.terraform.lock.hcl`\n      );\n\n      new ScriptFile(\n        this,\n        \"./scripts/tf-module-test.sh\",\n        `#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nterraform -chdir=${examplesFolder} init --upgrade\nterraform -chdir=${examplesFolder} fmt\nterraform -chdir=${examplesFolder} validate\n${options.runPlan ? `terraform -chdir=${examplesFolder} plan` : \"\"}\n          `\n      );\n\n      this.testTask.exec(\"./scripts/tf-module-test.sh\");\n      this.jest?.addIgnorePattern(`<rootDir>/${examplesFolder}`);\n    }\n\n    if (options.constructExamples && options.constructExamples.enabled) {\n      const constructExampleFolder =\n        options.constructExamples.folder || \"construct-examples\";\n\n      const levels = constructExampleFolder\n        .split(\"/\")\n        .splice(0, 1)\n        .map(() => \"..\")\n        .join(\"/\");\n\n      const constructReadmeDocs = `\n# Construct Examples\n\nExample use-cases for the Construct library.\n\n- [Basic Usage](./basic.ts)\n\nTo ensure all examples are working, please make sure the [index.ts](./index.ts) file is importing all of them.\n`;\n\n      const constructExampleCode = `\nimport { TerraformStack } from \"cdktf\";\nimport { Construct } from \"constructs\";\n\nimport { MyConstruct } from \"${levels}/src/\";\n\nexport class BasicExample extends TerraformStack {\n  constructor(scope: Construct, name: string) {\n    super(scope, name);\n\n    new MyConstruct(this, \"my-construct\", {\n      propertyA: \"valueA\",\n    });\n  }\n}\n\n\n`;\n\n      const exampleCollectionCode = `\n// This file will be synthesized to check if all examples are working\n\nimport { App } from \"cdktf\";\n// All examples need to be imported here\nimport { BasicExample } from \"./basic\";\n\nconst app = new App();\n\n// All examples need to be initialized here\nnew BasicExample(app, \"basic-example\");\napp.synth();\n`;\n\n      new SampleDir(this, constructExampleFolder, {\n        files: {\n          \"index.ts\": exampleCollectionCode.trim(),\n          \"basic.ts\": constructExampleCode.trim(),\n          \"cdktf.json\": JSON.stringify(\n            {\n              language: \"typescript\",\n              app: `npx ts-node --project ${levels}/tsconfig.dev.json index.ts`,\n              projectId:\n                options.projectId ||\n                \"hybrid-module-fb734dba-eac9-466c-96bb-7eb9c406c28a\",\n            },\n            null,\n            2\n          ),\n          \"README.md\": constructReadmeDocs.trim(),\n        },\n      });\n\n      this.testTask.exec(`cdktf synth`, {\n        cwd: constructExampleFolder,\n      });\n      this.gitignore.addPatterns(`${constructExampleFolder}/cdktf.out`);\n    }\n\n    this.gitignore.addPatterns(\"src/.gen\", \"src/cdktf.out\", \"src/modules\");\n    this.compileTask.prependExec(\"npx 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\"\n\n    # Add README hcl docs\n    if which terraform-docs >/dev/null; then\n      terraform-docs markdown table --output-file \"$TARGET_FOLDER/$dirname/README.md\" \"$TARGET_FOLDER/$dirname\" \n    else\n      docker run --rm --volume \"$SCRIPTPATH/../modules:/terraform-docs\" -u $(id -u) quay.io/terraform-docs/terraform-docs:0.16.0 markdown table --output-file \"/terraform-docs/$dirname/README.md\" /terraform-docs/$dirname\n    fi\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"]}
@@ -75,5 +75,5 @@ describe("MyModule", () => {
75
75
  }
76
76
  exports.TerraformModule = TerraformModule;
77
77
  _a = JSII_RTTI_SYMBOL_1;
78
- TerraformModule[_a] = { fqn: "projen-cdktf-hybrid-construct.TerraformModule", version: "0.5.0" };
78
+ TerraformModule[_a] = { fqn: "projen-cdktf-hybrid-construct.TerraformModule", version: "0.5.2" };
79
79
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90ZXJyYWZvcm0tbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7OztHQUdHO0FBRUgsbUNBQXVEO0FBQ3ZELHdDQUEyRTtBQUUzRSx5Q0FBc0M7QUF3Q3RDOzs7O0dBSUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEsc0JBQWdCO0lBQ25ELFlBQVksT0FBK0I7UUFDekMsS0FBSyxDQUFDO1lBQ0osR0FBRyxtQkFBUTtZQUNYLEdBQUcsT0FBTztZQUNWLGFBQWEsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsYUFBYSxFQUFFO2dCQUN0RCxZQUFZLEVBQUUsS0FBSzthQUNwQixDQUFDO1lBQ0YsY0FBYyxFQUFFLEVBQUU7U0FDbkIsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsZ0JBQWdCLElBQUksVUFBVSxDQUFDO1FBQ2hFLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxZQUFZLElBQUksUUFBUSxDQUFDO1FBRXRELE1BQU0sZ0JBQWdCLEdBQUc7Ozs7O0NBSzVCLENBQUM7UUFFRSxNQUFNLGlCQUFpQixHQUFHOzs7Ozs7OztDQVE3QixDQUFDO1FBRUUsSUFBSSxDQUFDLFdBQVcsQ0FDZCxnQkFBZ0IsZ0JBQWdCLEVBQUUsRUFDbEMsV0FBVyxZQUFZLEVBQUUsQ0FDMUIsQ0FBQztRQUNGLElBQUksQ0FBQyxVQUFVLENBQ2IsU0FBUyxZQUFZLEVBQUUsRUFDdkIsYUFBYSxZQUFZLEVBQUUsRUFDM0Isa0JBQWtCLEVBQ2xCLG9CQUFvQixDQUNyQixDQUFDO1FBQ0YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFFMUMsSUFBSSxrQkFBUyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQy9CLEtBQUssRUFBRTtnQkFDTCxVQUFVLEVBQUUsZ0JBQWdCLENBQUMsSUFBSSxFQUFFO2dCQUNuQyx5QkFBeUIsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJLEVBQUU7YUFDcEQ7U0FDRixDQUFDLENBQUM7UUFDSCxJQUFJLGlCQUFRLENBQUMsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sc0JBQXNCLEVBQUU7WUFDdkQsU0FBUyxFQUFFLElBQUk7WUFDZixNQUFNLEVBQUUsSUFBSTtZQUNaLEtBQUssRUFBRTtnQkFDTCxHQUFHLENBQUMsT0FBTyxDQUFDLGdCQUFnQixJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FDckMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLGlDQUFpQyxRQUFRLENBQUMsSUFBSSxJQUFJLENBQ2pFO2dCQUNELEVBQUU7YUFDSDtTQUNGLENBQUMsQ0FBQztRQUVILElBQUksaUJBQVEsQ0FBQyxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxhQUFhLEVBQUU7WUFDOUMsU0FBUyxFQUFFLElBQUk7WUFDZixHQUFHLEVBQUU7Z0JBQ0gsUUFBUSxFQUFFLFlBQVk7Z0JBQ3RCLEdBQUcsRUFBRSxzQkFBc0I7Z0JBQzNCLGtCQUFrQixFQUFFLE9BQU8sQ0FBQyxrQkFBa0IsSUFBSSxFQUFFO2dCQUNwRCxnQkFBZ0IsRUFBRSxPQUFPLENBQUMsZ0JBQWdCO2dCQUMxQyxTQUFTLEVBQ1AsT0FBTyxDQUFDLFNBQVM7b0JBQ2pCLHVEQUF1RDthQUMxRDtTQUNGLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUNsRSxDQUFDOztBQXpFSCwwQ0EwRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgSGFzaGlDb3JwLCBJbmMuXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTVBMLTIuMFxuICovXG5cbmltcG9ydCB7IEpzb25GaWxlLCBTYW1wbGVEaXIsIFRleHRGaWxlIH0gZnJvbSBcInByb2plblwiO1xuaW1wb3J0IHsgQ29uc3RydWN0TGlicmFyeSwgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMgfSBmcm9tIFwicHJvamVuL2xpYi9jZGtcIjtcblxuaW1wb3J0IHsgZGVmYXVsdHMgfSBmcm9tIFwiLi9kZWZhdWx0c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50IHtcbiAgLy8gbmFtZSBvZiB0aGUgbW9kdWxlXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLy8gcGF0aCAvIHVybCAvIHJlZ2lzdHJ5IGlkZW50aWZpZXIgZm9yIHRoZSBtb2R1bGVcbiAgcmVhZG9ubHkgc291cmNlOiBzdHJpbmc7XG4gIC8vIHZlcnNpb24gY29uc3RyYWludCAoaHR0cHM6Ly93d3cudGVycmFmb3JtLmlvL2RvY3MvbGFuZ3VhZ2UvcHJvdmlkZXJzL3JlcXVpcmVtZW50cy5odG1sI3ZlcnNpb24tY29uc3RyYWludHMpXG4gIHJlYWRvbmx5IHZlcnNpb246IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zIGV4dGVuZHMgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMge1xuICAvKipcbiAgICogTWluaW11bSB0YXJnZXQgdmVyc2lvbiBvZiB0aGlzIGxpYnJhcnkuXG4gICAqIEBkZWZhdWx0IFwiMC4xOS4wXCJcbiAgICogQGZlYXR1cmVkXG4gICAqL1xuICByZWFkb25seSBjZGt0ZlZlcnNpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIENvbnN0cnVjdCB2ZXJzaW9uIHRvIHVzZVxuICAgKiBAZGVmYXVsdCBcIl4xMC4wLjEwN1wiXG4gICAqL1xuICByZWFkb25seSBjb25zdHJ1Y3RWZXJzaW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiAgTGlzdCBvZiBwcm92aWRlciBiaW5kaW5ncyB0byBnZW5lcmF0ZSBpbiBhZGRpdGlvbiB0byB0aGUgbW9kdWxlcy5cbiAgICovXG4gIHJlYWRvbmx5IHRlcnJhZm9ybVByb3ZpZGVycz86IFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50W107XG5cbiAgLyoqXG4gICAqIExpc3Qgb2YgbW9kdWxlcyB0byBnZW5lcmF0ZSBiaW5kaW5ncyBmb3IuXG4gICAqIEBmZWF0dXJlZFxuICAgKi9cbiAgcmVhZG9ubHkgdGVycmFmb3JtTW9kdWxlczogVGVycmFmb3JtVmVyc2lvbkNvbnN0cmFpbnRbXTtcblxuICAvLyBEZWZhdWx0ZWQgdG8gYSB1dWlkIHN0cmluZyBhcyBjZGt0ZiB3b3VsZFxuICByZWFkb25seSBwcm9qZWN0SWQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogVGVycmFmb3JtIE1vZHVsZXMgcmVwdWJsaXNoZWQgYXMgQ0RLVEYgQ29uc3RydWN0c1xuICpcbiAqIEBwamlkIHRlcnJhZm9ybS1tb2R1bGVcbiAqL1xuZXhwb3J0IGNsYXNzIFRlcnJhZm9ybU1vZHVsZSBleHRlbmRzIENvbnN0cnVjdExpYnJhcnkge1xuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zKSB7XG4gICAgc3VwZXIoe1xuICAgICAgLi4uZGVmYXVsdHMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgICAgZXNsaW50T3B0aW9uczogT2JqZWN0LmFzc2lnbih7fSwgb3B0aW9ucy5lc2xpbnRPcHRpb25zLCB7XG4gICAgICAgIGxpbnRQcm9qZW5SYzogZmFsc2UsXG4gICAgICB9KSxcbiAgICAgIHBvc3RCdWlsZFN0ZXBzOiBbXSxcbiAgICB9KTtcbiAgICBjb25zdCBjb25zdHJ1Y3RWZXJzaW9uID0gb3B0aW9ucy5jb25zdHJ1Y3RWZXJzaW9uIHx8IFwiMTAuMC4xMDdcIjtcbiAgICBjb25zdCBjZGt0ZlZlcnNpb24gPSBvcHRpb25zLmNka3RmVmVyc2lvbiB8fCBcIjAuMTkuMFwiO1xuXG4gICAgY29uc3QgY29uc3RydWN0U3JjQ29kZSA9IGBcbi8vIFJlLUV4cG9ydCBtb2R1bGUgYmluZGluZ3NcbmV4cG9ydCAqIGZyb20gXCIuL3RlcnJhZm9ybU1vZHVsZXNcIjtcblxuLy8gQWRkIHlvdXIgY3VzdG9tIGNvbnN0cnVjdHMgaGVyZVxuYDtcblxuICAgIGNvbnN0IGNvbnN0cnVjdFRlc3RDb2RlID0gYFxuLy8gaW1wb3J0IHsgVGVzdGluZyB9IGZyb20gXCJjZGt0ZlwiO1xuLy8gaW1wb3J0IFwiY2RrdGYvbGliL3Rlc3RpbmcvYWRhcHRlcnMvamVzdFwiO1xuXG4vLyBUbyBsZWFybiBtb3JlIGFib3V0IHRlc3Rpbmcgc2VlIGNkay50Zi90ZXN0aW5nXG5kZXNjcmliZShcIk15TW9kdWxlXCIsICgpID0+IHtcbiAgaXQudG9kbyhcInNob3VsZCBiZSB0ZXN0ZWRcIilcbn0pO1xuYDtcblxuICAgIHRoaXMuYWRkUGVlckRlcHMoXG4gICAgICBgY29uc3RydWN0c0A+PSR7Y29uc3RydWN0VmVyc2lvbn1gLFxuICAgICAgYGNka3RmQD49JHtjZGt0ZlZlcnNpb259YFxuICAgICk7XG4gICAgdGhpcy5hZGREZXZEZXBzKFxuICAgICAgYGNka3RmQCR7Y2RrdGZWZXJzaW9ufWAsXG4gICAgICBgY2RrdGYtY2xpQCR7Y2RrdGZWZXJzaW9ufWAsXG4gICAgICBcInRzLW5vZGVAPj0xMC45LjFcIixcbiAgICAgIFwianNpaS1kb2NnZW5AXjkuMC4wXCJcbiAgICApO1xuICAgIHRoaXMuYWRkS2V5d29yZHMoXCJjZGt0ZlwiLCBcImNka3RmLWh5YnJpZFwiKTtcblxuICAgIG5ldyBTYW1wbGVEaXIodGhpcywgdGhpcy5zcmNkaXIsIHtcbiAgICAgIGZpbGVzOiB7XG4gICAgICAgIFwiaW5kZXgudHNcIjogY29uc3RydWN0U3JjQ29kZS50cmltKCksXG4gICAgICAgIFwiX190ZXN0c19fL2luZGV4LXRlc3QudHNcIjogY29uc3RydWN0VGVzdENvZGUudHJpbSgpLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICBuZXcgVGV4dEZpbGUodGhpcywgYCR7dGhpcy5zcmNkaXJ9L3RlcnJhZm9ybU1vZHVsZXMudHNgLCB7XG4gICAgICBjb21taXR0ZWQ6IHRydWUsXG4gICAgICBtYXJrZXI6IHRydWUsXG4gICAgICBsaW5lczogW1xuICAgICAgICAuLi4ob3B0aW9ucy50ZXJyYWZvcm1Nb2R1bGVzIHx8IFtdKS5tYXAoXG4gICAgICAgICAgKHRmTW9kdWxlKSA9PiBgZXhwb3J0ICogZnJvbSBcIi4vLmdlbi9tb2R1bGVzLyR7dGZNb2R1bGUubmFtZX1cIjtgXG4gICAgICAgICksXG4gICAgICAgIFwiXCIsXG4gICAgICBdLFxuICAgIH0pO1xuXG4gICAgbmV3IEpzb25GaWxlKHRoaXMsIGAke3RoaXMuc3JjZGlyfS9jZGt0Zi5qc29uYCwge1xuICAgICAgY29tbWl0dGVkOiB0cnVlLFxuICAgICAgb2JqOiB7XG4gICAgICAgIGxhbmd1YWdlOiBcInR5cGVzY3JpcHRcIixcbiAgICAgICAgYXBwOiBcIm5weCB0cy1ub2RlIGluZGV4LnRzXCIsXG4gICAgICAgIHRlcnJhZm9ybVByb3ZpZGVyczogb3B0aW9ucy50ZXJyYWZvcm1Qcm92aWRlcnMgfHwgW10sXG4gICAgICAgIHRlcnJhZm9ybU1vZHVsZXM6IG9wdGlvbnMudGVycmFmb3JtTW9kdWxlcyxcbiAgICAgICAgcHJvamVjdElkOlxuICAgICAgICAgIG9wdGlvbnMucHJvamVjdElkIHx8XG4gICAgICAgICAgXCJ0ZXJyYWZvcm0tbW9kdWxlLTk5YTc3MGE3LTNlYzUtNDBmNy04Y2QzLWRiYzcyZjc1YTAwYVwiLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIHRoaXMucHJlQ29tcGlsZVRhc2suZXhlYyhgbnB4IGNka3RmIGdldGAsIHsgY3dkOiB0aGlzLnNyY2RpciB9KTtcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -52,16 +52,16 @@
52
52
  "eslint-config-prettier": "^8.10.0",
53
53
  "eslint-import-resolver-node": "^0.3.9",
54
54
  "eslint-import-resolver-typescript": "^2.7.1",
55
- "eslint-plugin-import": "^2.28.1",
55
+ "eslint-plugin-import": "^2.29.0",
56
56
  "eslint-plugin-prettier": "^4.2.1",
57
57
  "fs-extra": "^10.1.0",
58
58
  "glob": "^7.2.3",
59
59
  "jest": "^27",
60
60
  "jest-junit": "^15",
61
61
  "jsii": "^5.1.0",
62
- "jsii-diff": "^1.90.0",
62
+ "jsii-diff": "^1.91.0",
63
63
  "jsii-docgen": "^9.2.2",
64
- "jsii-pacmak": "^1.90.0",
64
+ "jsii-pacmak": "^1.91.0",
65
65
  "jsii-rosetta": "^5.1.0",
66
66
  "npm-check-updates": "^16",
67
67
  "prettier": "^2.8.8",
@@ -82,7 +82,7 @@
82
82
  ],
83
83
  "main": "lib/index.js",
84
84
  "license": "MPL-2.0",
85
- "version": "0.5.0",
85
+ "version": "0.5.2",
86
86
  "jest": {
87
87
  "testMatch": [
88
88
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",
package/.copywrite.hcl DELETED
@@ -1,22 +0,0 @@
1
- schema_version = 1
2
-
3
- project {
4
- license = "MPL-2.0"
5
- copyright_year = 2022
6
-
7
- # (OPTIONAL) A list of globs that should not have copyright/license headers.
8
- # Supports doublestar glob patterns for more flexibility in defining which
9
- # files or folders should be ignored
10
- header_ignore = [
11
- # "vendors/**",
12
- # "**autogen**",
13
- "**/node_modules/**",
14
- "**/.mergify.yml",
15
- "**/.github/workflows/*.yml",
16
- "**/coverage/**",
17
- "**/test-reports/**",
18
- "**/dist/**",
19
- "examples/**", # this probably should have the headers, but I'm tired of fighting Projen
20
- "test/helper.ts",
21
- ]
22
- }
package/.projenrc.ts DELETED
@@ -1,139 +0,0 @@
1
- /**
2
- * Copyright (c) HashiCorp, Inc.
3
- * SPDX-License-Identifier: MPL-2.0
4
- */
5
-
6
- import { JsiiProject } from "projen/lib/cdk";
7
- import { NpmAccess, UpgradeDependenciesSchedule } from "projen/lib/javascript";
8
- import { AutoApprove } from "./projenrc/auto-approve";
9
- import { Automerge } from "./projenrc/automerge";
10
- import { CustomizedLicense } from "./projenrc/customized-license";
11
- import { UpgradeCDKTF } from "./projenrc/upgrade-cdktf";
12
-
13
- const name = "projen-cdktf-hybrid-construct";
14
-
15
- const githubActionPinnedVersions = {
16
- "actions/checkout": "c85c95e3d7251135ab7dc9ce3241c5835cc595a9", // v3.5.3
17
- "actions/download-artifact": "9bc31d5ccc31df68ecc42ccf4149144866c47d8a", // v3.0.2
18
- "actions/setup-node": "64ed1c7eab4cce3362f8c340dee64e5eaeef8f7c", // v3.6.0
19
- "actions/upload-artifact": "0b7f8abb1508181956e8e162db84b466c27e18ce", // v3.1.2
20
- "amannn/action-semantic-pull-request":
21
- "c3cd5d1ea3580753008872425915e343e351ab54", // v5.2.0
22
- "peter-evans/create-pull-request": "284f54f989303d2699d373481a0cfa13ad5a6666", // v5.0.1
23
- };
24
-
25
- const project = new JsiiProject({
26
- defaultReleaseBranch: "main",
27
- name,
28
- repositoryUrl: `https://github.com/cdktf/${name}.git`,
29
- author: "HashiCorp",
30
- authorAddress: "https://hashicorp.com",
31
- authorOrganization: true,
32
- packageName: name,
33
- prettier: true,
34
- projenrcTs: true,
35
- description:
36
- "Projen template for CDKTF Constructs that should also be used as Terraform Modules.",
37
- licensed: false,
38
- release: true,
39
- releaseToNpm: true,
40
- npmAccess: NpmAccess.PUBLIC,
41
- mergify: false,
42
- depsUpgradeOptions: {
43
- workflowOptions: {
44
- labels: ["auto-approve", "automerge", "dependencies"],
45
- schedule: UpgradeDependenciesSchedule.WEEKLY,
46
- },
47
- },
48
- gitignore: [".idea/"],
49
- workflowGitIdentity: {
50
- name: "team-tf-cdk",
51
- email: "github-team-tf-cdk@hashicorp.com",
52
- },
53
- jsiiVersion: "^5.1.0",
54
- pullRequestTemplate: false,
55
- });
56
- project.tsconfig?.exclude?.push("src/exampleCode/**");
57
- project.tsconfig?.exclude?.push("example/**");
58
- project.tsconfig?.exclude?.push("examples/**");
59
-
60
- project.addPeerDeps("projen@>= 0.72.18");
61
- project.addBundledDeps("change-case");
62
- project.addDevDeps(
63
- "fs-extra",
64
- "glob",
65
- "projen@^0.72.18",
66
- "@types/fs-extra",
67
- "@types/glob",
68
- "@types/change-case",
69
- "ts-node@10.9.1",
70
- "comment-json"
71
- );
72
-
73
- new CustomizedLicense(project);
74
- new AutoApprove(project);
75
- new Automerge(project);
76
- new UpgradeCDKTF(project);
77
-
78
- project.addPackageIgnore("examples");
79
-
80
- project.addTask("buildExample", {
81
- exec: "yarn buildExample:hybrid && yarn buildExample:terraform",
82
- });
83
- project.addTask("buildExample:hybrid", {
84
- exec: "git clean -dfx . && rm -rf lib modules src terraform construct-examples && yarn && yarn projen && yarn && yarn build",
85
- cwd: "./examples/hybrid-module",
86
- });
87
- project.addTask("buildExample:terraform", {
88
- exec: "git clean -dfx . && rm -rf lib modules src terraform construct-examples && yarn && yarn projen && yarn && yarn build",
89
- cwd: "./examples/terraform-module",
90
- });
91
-
92
- project.addTask("upgrade:hybrid", {
93
- exec: "yarn projen upgrade",
94
- cwd: "./examples/hybrid-module",
95
- });
96
- project.addTask("upgrade:terraform", {
97
- exec: "yarn projen upgrade",
98
- cwd: "./examples/terraform-module",
99
- });
100
- project.removeTask("post-upgrade");
101
- const upgradeTask = project.addTask("post-upgrade", {
102
- description: "Runs after upgrading dependencies",
103
- exec: "yarn compile",
104
- });
105
- upgradeTask.exec("yarn projen upgrade:hybrid");
106
- upgradeTask.exec("yarn projen upgrade:terraform");
107
-
108
- project.testTask.exec("yarn buildExample");
109
-
110
- // Run copywrite tool to add copyright headers to all files
111
- project.buildWorkflow?.addPostBuildSteps(
112
- {
113
- name: "Setup Copywrite tool",
114
- uses: "hashicorp/setup-copywrite@867a1a2a064a0626db322392806428f7dc59cb3e", // v1.1.2
115
- },
116
- { name: "Add headers using Copywrite tool", run: "copywrite headers" }
117
- );
118
-
119
- // Use pinned versions of github actions
120
- Object.entries(githubActionPinnedVersions).forEach(([action, sha]) => {
121
- project.github?.actions.set(action, `${action}@${sha}`);
122
- });
123
-
124
- const releaseWorkflow = project.tryFindObjectFile(
125
- ".github/workflows/release.yml"
126
- );
127
- releaseWorkflow?.addOverride("on.push", {
128
- branches: ["main"],
129
- "paths-ignore": [
130
- // don't do a release if the change was only to these files/directories
131
- "examples/**",
132
- ".github/ISSUE_TEMPLATE/**",
133
- ".github/CODEOWNERS",
134
- ".github/dependabot.yml",
135
- ".github/**/*.md",
136
- ],
137
- });
138
-
139
- project.synth();
@@ -1,62 +0,0 @@
1
- /**
2
- * Copyright (c) HashiCorp, Inc.
3
- * SPDX-License-Identifier: MPL-2.0
4
- */
5
-
6
- import { javascript } from "projen";
7
- import { JobPermission } from "projen/lib/github/workflows-model";
8
-
9
- /**
10
- * Approves PRs with the "auto-approve" label
11
- */
12
- export class AutoApprove {
13
- constructor(project: javascript.NodeProject) {
14
- const workflow = project.github?.addWorkflow("auto-approve");
15
-
16
- if (!workflow) throw new Error("no workflow defined");
17
-
18
- workflow.on({
19
- pullRequest: {
20
- types: ["opened", "labeled", "ready_for_review", "reopened"],
21
- },
22
- });
23
-
24
- workflow.addJobs({
25
- approve: {
26
- runsOn: ["ubuntu-latest"],
27
- if: "contains(github.event.pull_request.labels.*.name, 'auto-approve') && github.event.pull_request.draft == false",
28
- steps: [
29
- {
30
- name: "Checkout PR",
31
- uses: "actions/checkout@v3",
32
- with: {
33
- ref: "${{ github.event.pull_request.head.ref }}",
34
- repository:
35
- "${{ github.event.pull_request.head.repo.full_name }}",
36
- },
37
- },
38
- {
39
- name: "Auto-approve PRs by other users as team-tf-cdk",
40
- if: "github.event.pull_request.user.login != 'team-tf-cdk'",
41
- run: "gh pr review ${{ github.event.pull_request.number }} --approve",
42
- env: {
43
- GH_TOKEN: "${{ secrets.PROJEN_GITHUB_TOKEN }}",
44
- },
45
- },
46
- {
47
- name: "Auto-approve PRs by team-tf-cdk as github-actions[bot]",
48
- if: "github.event.pull_request.user.login == 'team-tf-cdk'",
49
- run: "gh pr review ${{ github.event.pull_request.number }} --approve",
50
- env: {
51
- GH_TOKEN: "${{ secrets.GITHUB_TOKEN }}",
52
- },
53
- },
54
- ],
55
- permissions: {
56
- contents: JobPermission.READ,
57
- pullRequests: JobPermission.WRITE,
58
- },
59
- },
60
- });
61
- }
62
- }
@@ -1,55 +0,0 @@
1
- /**
2
- * Copyright (c) HashiCorp, Inc.
3
- * SPDX-License-Identifier: MPL-2.0
4
- */
5
-
6
- import { javascript } from "projen";
7
- import { JobPermission } from "projen/lib/github/workflows-model";
8
-
9
- /**
10
- * Merges PRs with the "automerge" label
11
- */
12
- export class Automerge {
13
- constructor(project: javascript.NodeProject) {
14
- const workflow = project.github?.addWorkflow("automerge");
15
-
16
- if (!workflow) throw new Error("no workflow defined");
17
-
18
- workflow.on({
19
- pullRequest: {
20
- types: [
21
- "opened",
22
- "labeled",
23
- "ready_for_review",
24
- "reopened",
25
- "synchronize",
26
- ],
27
- },
28
- });
29
-
30
- (workflow.concurrency as any) = "${{ github.workflow }}-${{ github.ref }}";
31
-
32
- workflow.addJobs({
33
- automerge: {
34
- runsOn: ["ubuntu-latest"],
35
- if: "contains(github.event.pull_request.labels.*.name, 'automerge') && github.event.pull_request.draft == false",
36
- steps: [
37
- {
38
- name: "Checkout",
39
- uses: "actions/checkout@v3",
40
- },
41
- {
42
- name: "Turn on automerge for this PR",
43
- run: "gh pr merge --auto --squash ${{ github.event.pull_request.number }}",
44
- env: {
45
- GH_TOKEN: "${{ secrets.PROJEN_GITHUB_TOKEN }}",
46
- },
47
- },
48
- ],
49
- permissions: {
50
- contents: JobPermission.READ,
51
- },
52
- },
53
- });
54
- }
55
- }
@@ -1,24 +0,0 @@
1
- /**
2
- * Copyright (c) HashiCorp, Inc.
3
- * SPDX-License-Identifier: MPL-2.0
4
- */
5
-
6
- import { IResolver, License } from "projen";
7
- import { TypeScriptProject } from "projen/lib/typescript";
8
-
9
- const SPDX = "MPL-2.0";
10
-
11
- export class CustomizedLicense extends License {
12
- constructor(project: TypeScriptProject) {
13
- super(project, { spdx: SPDX });
14
-
15
- project.addFields({ license: SPDX });
16
- }
17
-
18
- synthesizeContent(resolver: IResolver) {
19
- return (
20
- "Copyright (c) 2022 HashiCorp, Inc.\n\n" +
21
- super.synthesizeContent(resolver)
22
- );
23
- }
24
- }
@@ -1,116 +0,0 @@
1
- /**
2
- * Copyright (c) HashiCorp, Inc.
3
- * SPDX-License-Identifier: MPL-2.0
4
- */
5
-
6
- import { javascript } from "projen";
7
- import { JobPermission } from "projen/lib/github/workflows-model";
8
-
9
- /**
10
- * Checks for new versions of CDKTF and creates a PR with an upgrade change if there are changes.
11
- */
12
- export class UpgradeCDKTF {
13
- constructor(project: javascript.NodeProject) {
14
- const workflow = project.github?.addWorkflow("upgrade-cdktf");
15
-
16
- if (!workflow) throw new Error("no workflow defined");
17
-
18
- workflow.on({
19
- schedule: [{ cron: "49 */6 * * *" }], // Runs four times a day
20
- workflowDispatch: {}, // allow manual triggering
21
- });
22
-
23
- (workflow.concurrency as any) = "${{ github.workflow }}-${{ github.ref }}";
24
-
25
- workflow.addJobs({
26
- upgrade: {
27
- name: "Upgrade CDKTF",
28
- runsOn: ["ubuntu-latest"],
29
- steps: [
30
- {
31
- name: "Checkout",
32
- uses: "actions/checkout@v3",
33
- },
34
- {
35
- name: "Install",
36
- run: "yarn install",
37
- },
38
- {
39
- name: "Install examples",
40
- run: `ls -d examples/* | xargs -I {} bash -c "cd '{}' && yarn"`,
41
- },
42
- {
43
- name: "Get current CDKTF version",
44
- id: "current_version",
45
- run: [
46
- `OLD_VERSION=$(cd examples/hybrid-module && npm list cdktf --depth=0 --json | jq -r '.dependencies.cdktf.version')`,
47
- `OLD_VERSION_SHORT=$(cut -d "." -f 2 <<< "$OLD_VERSION")`,
48
- `echo "value=$OLD_VERSION" >> $GITHUB_OUTPUT`,
49
- `echo "short=$OLD_VERSION_SHORT" >> $GITHUB_OUTPUT`,
50
- ].join("\n"),
51
- // NOTE: No, there is no good way to do this in Yarn, until (if) we upgrade to Yarn 2+ (see below)
52
- },
53
- {
54
- name: "Get latest CDKTF version",
55
- id: "latest_version",
56
- run: [
57
- `CDKTF_VERSION=$(yarn info cdktf --json | jq -r '.data.version')`,
58
- `CDKTF_VERSION_SHORT=$(cut -d "." -f 2 <<< "$CDKTF_VERSION")`,
59
- `echo "value=$CDKTF_VERSION" >> $GITHUB_OUTPUT`,
60
- `echo "short=$CDKTF_VERSION_SHORT" >> $GITHUB_OUTPUT`,
61
- ].join("\n"),
62
- // IMPORTANT: the above behavior changed in Yarn 2+; `yarn info` instead gives the version of the installed package
63
- // If/when we upgrade we'll likely want to switch to `yarn npm info`: https://yarnpkg.com/cli/npm/info
64
- },
65
- {
66
- name: "Run upgrade script",
67
- if: "steps.current_version.outputs.short != steps.latest_version.outputs.short",
68
- run: "scripts/update-cdktf.sh ${{ steps.latest_version.outputs.value }}",
69
- },
70
- {
71
- name: "Check if there are any changes",
72
- id: "get_changes",
73
- run: `echo "changed=$(git status --porcelain | wc -l)" >> $GITHUB_OUTPUT`,
74
- },
75
- {
76
- name: "Create draft pull request",
77
- if: "steps.get_changes.outputs.changed != 0",
78
- uses: "peter-evans/create-pull-request@v3",
79
- with: {
80
- "commit-message":
81
- "chore!: upgrade to cdktf ${{ steps.latest_version.outputs.value }}",
82
- branch:
83
- "auto/upgrade-cdktf-${{ steps.latest_version.outputs.short }}",
84
- base: "main",
85
- title:
86
- "chore!: upgrade to cdktf ${{ steps.latest_version.outputs.value }}",
87
- body: [
88
- "This PR initiates the upgrade of CDKTF from version `${{ steps.current_version.outputs.value }}` to version `${{ steps.latest_version.outputs.value }}`.",
89
- "Unfortunately, not everything can be automated, and the following steps need to be completed manually:",
90
- " ",
91
- "- [ ] Update `@cdktf/tf-module-stack` to a version compatible with `cdktf@${{ steps.latest_version.outputs.value }}` [here](https://github.com/cdktf/projen-cdktf-hybrid-construct/blob/62c33dca3eaa249b519edd82fa0889ffcd12c6eb/src/hybrid-module.ts#L194). Look up the version [here](https://www.npmjs.com/package/@cdktf/tf-module-stack?activeTab=versions).",
92
- "- [ ] Run `npx projen build`",
93
- " ",
94
- "Please checkout this PR, complete the above steps, push the changes to this branch, and then mark this PR as ready for review to complete the upgrade. Thanks!",
95
- ].join("\n"),
96
- labels: "automerge,auto-approve,dependencies",
97
- token: "${{ secrets.PROJEN_GITHUB_TOKEN }}",
98
- author: "team-tf-cdk <github-team-tf-cdk@hashicorp.com>",
99
- committer: "team-tf-cdk <github-team-tf-cdk@hashicorp.com>",
100
- signoff: true,
101
- "delete-branch": true,
102
- draft: true,
103
- },
104
- },
105
- ],
106
- env: {
107
- CI: "true",
108
- CHECKPOINT_DISABLE: "1",
109
- },
110
- permissions: {
111
- contents: JobPermission.READ,
112
- },
113
- },
114
- });
115
- }
116
- }
@@ -1,36 +0,0 @@
1
- #!/bin/bash
2
- # Copyright (c) HashiCorp, Inc.
3
- # SPDX-License-Identifier: MPL-2.0
4
-
5
- set -ex
6
-
7
- PROJECT_ROOT=$(cd "$(dirname "${BASH_SOURCE:-$0}")/.." && pwd)
8
- CDKTF_VERSION=$1
9
-
10
- if [ -z "$CDKTF_VERSION" ]; then
11
- echo "Usage: $0 <cdktf-version>"
12
- exit 1
13
- fi
14
-
15
- echo "Updating /src cdktf version to $CDKTF_VERSION"
16
- yarn
17
- find ./src -type f -name "*.ts" -print0 | xargs -0 sed -i "s/const cdktfVersion = options.cdktfVersion || \".*\"/const cdktfVersion = options.cdktfVersion || \"$CDKTF_VERSION\"/"
18
- # @TODO This is a hack and will stop working when CDKTF goes 1.0
19
- find ./src -type f -name "*.ts" -print0 | xargs -0 sed -i "s/@default \"0\..*\"/@default \"$CDKTF_VERSION\"/"
20
-
21
- echo "Updating README"
22
- sed -i 's/`cdktf` >= .*/`cdktf` >= '"$CDKTF_VERSION"'/' "$PROJECT_ROOT/README.md"
23
-
24
- npx projen build
25
-
26
- echo "Updating examples"
27
- # Loop through all examples and update the cdktf version
28
- for example in $(find "$PROJECT_ROOT/examples" -mindepth 1 -maxdepth 1 -type d); do
29
- echo "Updating example $example"
30
- cd "$example"
31
- yarn
32
- sed -i "s/cdktfVersion: \".*\",/cdktfVersion: \"$CDKTF_VERSION\",/" ./.projenrc.ts
33
- CI=0 npx projen
34
- done
35
-
36
- echo "Done"