projen-cdktf-hybrid-construct 0.1.70 → 0.2.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/.gitattributes CHANGED
@@ -18,6 +18,7 @@
18
18
  /.projen/deps.json linguist-generated
19
19
  /.projen/files.json linguist-generated
20
20
  /.projen/tasks.json linguist-generated
21
+ /API.md linguist-generated
21
22
  /LICENSE linguist-generated
22
23
  /package.json linguist-generated
23
24
  /tsconfig.dev.json linguist-generated
package/.jsii CHANGED
@@ -10,7 +10,7 @@
10
10
  "change-case": "^4.1.2"
11
11
  },
12
12
  "dependencies": {
13
- "projen": ">= 0.56.2"
13
+ "projen": ">= 0.63.25"
14
14
  },
15
15
  "dependencyClosure": {
16
16
  "projen": {
@@ -20,6 +20,7 @@
20
20
  "projen.cdk": {},
21
21
  "projen.cdk8s": {},
22
22
  "projen.cdktf": {},
23
+ "projen.circleci": {},
23
24
  "projen.github": {},
24
25
  "projen.github.workflows": {},
25
26
  "projen.gitlab": {},
@@ -57,7 +58,7 @@
57
58
  "stability": "stable"
58
59
  },
59
60
  "homepage": "https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct.git",
60
- "jsiiVersion": "1.58.0 (build f8ba112)",
61
+ "jsiiVersion": "1.63.2 (build a8a8833)",
61
62
  "license": "MIT",
62
63
  "metadata": {
63
64
  "jsii": {
@@ -69,7 +70,7 @@
69
70
  },
70
71
  "name": "projen-cdktf-hybrid-construct",
71
72
  "readme": {
72
- "markdown": "# Projen-CDKTF-Hybrid-Construct\n\nProjen template for CDKTF Constructs that should also be used as Terraform Modules and for republishing Terraform Modules as Constructs.\n\n## Usage\n\n### `HybridModule`\n\nIf you want to write a CDKTF construct and also publish it as a Terraform Module you can use the `HybridModule` template.\n\nYou can initialize such a project using `npx projen new --from projen-cdktf-hybrid-construct hybrid-module`.\n\nA configutation might look like this:\n\n```js\nconst { HybridModule } = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // The name of the module & repository need to start with terraform-cdk-\n name: \"terraform-cdk-my-new-hybrid-construct\",\n repositoryUrl:\n \"github.com/DanielMSchmidt/terraform-cdk-my-new-hybrid-construct\",\n\n author: \"Daniel Schmidt\",\n authorAddress: \"danielmschmidt92@gmail.com\",\n\n // If enabled an example folder with terraform code will be created\n terraformExamples: {\n enabled: true,\n folder: \"terraform\",\n // The configuration to add to the example terraform file\n providerConfig: `\n terraform {\n required_providers {\n aws = {\n source = \"hashicorp/aws\"\n version = \"~> 3.74\"\n }\n }\n # Terraform binary version constraint\n required_version = \"~> 1.1.0\"\n }\n\n\n provider \"aws\" {\n region = \"eu-central-1\"\n }\n `,\n },\n\n // If enabled a constructs example folder will be created\n constructExamples: {\n enabled: true,\n folder: \"construct-examples\",\n },\n});\nproject.synth();\n```\n\n### `TerraformModule`\n\nIf you want to republish an existing Terraform module as a CDKTF construct or if you want to repackage them with an easier to use API you can use the `TerraformModule` template.\n\nYou can initialize such a project using `npx projen new --from projen-cdktf-hybrid-construct terraform-module`.\n\nA configutation might look like this:\n\n```js\nconst { TerraformModule } = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new TerraformModule({\n name: \"my-module\",\n author: \"Daniel Schmidt\",\n authorAddress: \"danielmschmidt92@gmail.com\",\n repositoryUrl: \"github.com/DanielMSchmidt/my-module\",\n\n terraformModules: [\n {\n name: \"eks\",\n source: \"terraform-aws-modules/eks/aws\",\n version: \"~> 18.0\",\n },\n {\n name: \"eks-managed-nodegroup\",\n source: \"terraform-aws-modules/eks/aws//modules/eks-managed-node-group\",\n version: \"~> 18.0\",\n },\n ],\n});\n\nproject.synth();\n```\n\n## Publishing\n\n### Open Source\n\nWe have a helper method for easy configuration, but there are still some manual steps required.\n\n```js\nconst {\n HybridModule,\n publishToRegistries,\n} = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // ... all the other options\n ...publishToRegistries({\n name: \"my-new-hybrid-construct\",\n namespace: \"my-org\",\n registries: [\"npm\", \"pypi\", \"nuget\", \"maven\"],\n }),\n});\n```\n\n#### Terraform\n\n1. [Sign in at the registry](https://registry.terraform.io/sign-in)\n2. [Select your repository](https://registry.terraform.io/github/create) and create the module\n\nPlease make sure your repository name starts with `terraform-cdk-`.\n\n#### npm (Typescript)\n\n1. Create an account at [npmjs.com](https://npmjs.com/)\n2. Create an [automation token](https://docs.npmjs.com/creating-and-viewing-access-tokens) on npm\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `NPM_TOKEN` and the value of the token\n\n#### pypi (Python)\n\n1. Create an account at [pypi.org](https://pypi.org/)\n2. Create an [API token](https://pypi.org/help/#apitoken) on pypi\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `TWINE_USERNAME` and the value `__token__` and a second one with the name `TWINE_PASSWORD` and the value of the token\n4. Set the `publishToPypi` section in the options of `HybridModule` or `TerraformModule` (or use the helper mentioned above)\n\n```js\nconst name = \"name-of-my-hybrid-construct\";\nnew HybridModule({\n name,\n // ... other options\n publishToPypi: {\n distName: name,\n module: name.replace(/-/g, \"_\"),\n },\n});\n```\n\n#### Maven (Java)\n\n1. [Create a Sonatype account and repository](https://central.sonatype.org/publish/publish-guide/#introduction)\n2. Create [GitHub Action Secrets](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) to configure maven:\n - `MAVEN_USERNAME`\n - `MAVEN_PASSWORD`\n - `MAVEN_STAGING_PROFILE_ID`\n - `MAVEN_GPG_PRIVATE_KEY_PASSPHRASE`\n - `MAVEN_GPG_PRIVATE_KEY_PASSPHRASE`\n3. Setup the `publishToMaven` section in the options of `HybridModule` or `TerraformModule` (or use the helper mentioned above)\n\n```js\nconst githubNamespace = \"my-org\";\nconst name = \"name-of-my-hybrid-construct\";\nnew HybridModule({\n name,\n // ... other options\n publishToMaven: {\n javaPackage: name.replace(/-/g, \"_\"),\n mavenGroupId: `com.${githubNamespace}`,\n mavenArtifactId: name,\n },\n});\n```\n\n#### NuGet (C#)\n\n1. [Create a NuGet account](https://www.nuget.org/users/account/LogOn) (you might need to create a Microsoft Account if you don't have one)\n2. [Create API keys](https://docs.microsoft.com/en-us/nuget/nuget-org/publish-a-package#create-api-keys)\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `NUGET_API_KEY` and the value of the token\n4. Setup the `publishToNuget` section in the options of `HybridModule` or `TerraformModule` (or use the helper mentioned above)\n\n```js\nconst githubNamespace = \"my-org\";\nconst name = \"name-of-my-hybrid-construct\";\n\nnew HybridModule({\n name,\n // ... other options\n publishToNuget: {\n dotNetNamespace: `MyOrg.NameOfMyHybridConstruct`,\n packageId: `MyOrg.NameOfMyHybridConstruct`,\n },\n});\n```\n\n### Github Packages\n\nWe have a helper method for easy configuration, no extra steps needed:\n\n```js\nconst {\n HybridModule,\n publishToGithubPackages,\n} = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // ... all the other options\n ...publishToGithubPackages({\n name: \"my-new-hybrid-construct\",\n namespace: \"my-org\",\n registries: [\"npm\", \"maven\"], // pypi and nuget are not yet supported\n }),\n});\n```\n\n### Artifactory\n\nWe have a helper method for easy configuration, but there are also some manual steps required.\n\n```js\nconst {\n HybridModule,\n publishToGithubPackages,\n} = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // ... all the other options\n ...publishToGithubPackages({\n name: \"my-new-hybrid-construct\",\n namespace: \"my-org\",\n registries: [\"npm\", \"pypi\", \"nuget\"], // maven is currently not supported, PRs welcome\n artifactoryApiUrl: \"https://artifactory.my-org.com/api/\",\n artifactoryRepository: \"my-repo\", // needs to be the same across all registries, defaults to namespace so \"my-org\" in this case\n }),\n});\n```\n\n#### Terraform\n\nYou can find more information about publishing Terraform Modules to Artifactory [here](https://www.jfrog.com/confluence/display/JFROG/Terraform+Registry#TerraformRegistry-SettingupaLocalModule/ProviderRegistry).\n\n#### npm (Typescript)\n\n1. [Create a virtual npm registry](https://www.jfrog.com/confluence/display/JFROG/npm+Registry#npmRegistry-VirtualnpmRegistry)\n2. [Authenticate against artifactory to get a token](https://www.jfrog.com/confluence/display/JFROG/npm+Registry#npmRegistry-AuthenticatingthenpmClient)\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `NPM_TOKEN` and the value of the token\n\n#### pypi (Python)\n\n1. Create a [local repository](https://www.jfrog.com/confluence/display/JFROG/PyPI+Repositories#PyPIRepositories-LocalRepositories)\n2. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `TWINE_USERNAME` and the artifactory user name and a second one with the name `TWINE_PASSWORD` and the artifactory password\n"
73
+ "markdown": "# Projen-CDKTF-Hybrid-Construct\n\nProjen template for CDKTF Constructs that should also be used as Terraform Modules and for republishing Terraform Modules as Constructs.\n\n## Usage\n\n### `HybridModule`\n\nIf you want to write a CDKTF construct and also publish it as a Terraform Module you can use the `HybridModule` template.\n\nYou can initialize such a project using `npx projen new --from projen-cdktf-hybrid-construct hybrid-module`.\n\nA configutation might look like this:\n\n```js\nconst { HybridModule } = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // The name of the module & repository need to start with terraform-cdk-\n name: \"terraform-cdk-my-new-hybrid-construct\",\n repositoryUrl:\n \"github.com/DanielMSchmidt/terraform-cdk-my-new-hybrid-construct\",\n\n author: \"Daniel Schmidt\",\n authorAddress: \"danielmschmidt92@gmail.com\",\n\n // If enabled an example folder with terraform code will be created\n terraformExamples: {\n enabled: true,\n folder: \"terraform\",\n // The configuration to add to the example terraform file\n providerConfig: `\n terraform {\n required_providers {\n aws = {\n source = \"hashicorp/aws\"\n version = \"~> 3.74\"\n }\n }\n # Terraform binary version constraint\n required_version = \">= 1.2.0\"\n }\n\n\n provider \"aws\" {\n region = \"eu-central-1\"\n }\n `,\n },\n\n // If enabled a constructs example folder will be created\n constructExamples: {\n enabled: true,\n folder: \"construct-examples\",\n },\n});\nproject.synth();\n```\n\n### `TerraformModule`\n\nIf you want to republish an existing Terraform module as a CDKTF construct or if you want to repackage them with an easier to use API you can use the `TerraformModule` template.\n\nYou can initialize such a project using `npx projen new --from projen-cdktf-hybrid-construct terraform-module`.\n\nA configutation might look like this:\n\n```js\nconst { TerraformModule } = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new TerraformModule({\n name: \"my-module\",\n author: \"Daniel Schmidt\",\n authorAddress: \"danielmschmidt92@gmail.com\",\n repositoryUrl: \"github.com/DanielMSchmidt/my-module\",\n\n terraformModules: [\n {\n name: \"eks\",\n source: \"terraform-aws-modules/eks/aws\",\n version: \"~> 18.0\",\n },\n {\n name: \"eks-managed-nodegroup\",\n source: \"terraform-aws-modules/eks/aws//modules/eks-managed-node-group\",\n version: \"~> 18.0\",\n },\n ],\n});\n\nproject.synth();\n```\n\n## Publishing\n\n### Open Source\n\nWe have a helper method for easy configuration, but there are still some manual steps required.\n\n```js\nconst {\n HybridModule,\n publishToRegistries,\n} = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // ... all the other options\n ...publishToRegistries({\n name: \"my-new-hybrid-construct\",\n namespace: \"my-org\",\n registries: [\"npm\", \"pypi\", \"nuget\", \"maven\"],\n }),\n});\n```\n\n#### Terraform\n\n1. [Sign in at the registry](https://registry.terraform.io/sign-in)\n2. [Select your repository](https://registry.terraform.io/github/create) and create the module\n\nPlease make sure your repository name starts with `terraform-cdk-`.\n\n#### npm (Typescript)\n\n1. Create an account at [npmjs.com](https://npmjs.com/)\n2. Create an [automation token](https://docs.npmjs.com/creating-and-viewing-access-tokens) on npm\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `NPM_TOKEN` and the value of the token\n\n#### pypi (Python)\n\n1. Create an account at [pypi.org](https://pypi.org/)\n2. Create an [API token](https://pypi.org/help/#apitoken) on pypi\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `TWINE_USERNAME` and the value `__token__` and a second one with the name `TWINE_PASSWORD` and the value of the token\n4. Set the `publishToPypi` section in the options of `HybridModule` or `TerraformModule` (or use the helper mentioned above)\n\n```js\nconst name = \"name-of-my-hybrid-construct\";\nnew HybridModule({\n name,\n // ... other options\n publishToPypi: {\n distName: name,\n module: name.replace(/-/g, \"_\"),\n },\n});\n```\n\n#### Maven (Java)\n\n1. [Create a Sonatype account and repository](https://central.sonatype.org/publish/publish-guide/#introduction)\n2. Create [GitHub Action Secrets](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) to configure maven:\n - `MAVEN_USERNAME`\n - `MAVEN_PASSWORD`\n - `MAVEN_STAGING_PROFILE_ID`\n - `MAVEN_GPG_PRIVATE_KEY_PASSPHRASE`\n - `MAVEN_GPG_PRIVATE_KEY_PASSPHRASE`\n3. Setup the `publishToMaven` section in the options of `HybridModule` or `TerraformModule` (or use the helper mentioned above)\n\n```js\nconst githubNamespace = \"my-org\";\nconst name = \"name-of-my-hybrid-construct\";\nnew HybridModule({\n name,\n // ... other options\n publishToMaven: {\n javaPackage: name.replace(/-/g, \"_\"),\n mavenGroupId: `com.${githubNamespace}`,\n mavenArtifactId: name,\n },\n});\n```\n\n#### NuGet (C#)\n\n1. [Create a NuGet account](https://www.nuget.org/users/account/LogOn) (you might need to create a Microsoft Account if you don't have one)\n2. [Create API keys](https://docs.microsoft.com/en-us/nuget/nuget-org/publish-a-package#create-api-keys)\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `NUGET_API_KEY` and the value of the token\n4. Setup the `publishToNuget` section in the options of `HybridModule` or `TerraformModule` (or use the helper mentioned above)\n\n```js\nconst githubNamespace = \"my-org\";\nconst name = \"name-of-my-hybrid-construct\";\n\nnew HybridModule({\n name,\n // ... other options\n publishToNuget: {\n dotNetNamespace: `MyOrg.NameOfMyHybridConstruct`,\n packageId: `MyOrg.NameOfMyHybridConstruct`,\n },\n});\n```\n\n### Github Packages\n\nWe have a helper method for easy configuration, no extra steps needed:\n\n```js\nconst {\n HybridModule,\n publishToGithubPackages,\n} = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // ... all the other options\n ...publishToGithubPackages({\n name: \"my-new-hybrid-construct\",\n namespace: \"my-org\",\n registries: [\"npm\", \"maven\"], // pypi and nuget are not yet supported\n }),\n});\n```\n\n### Artifactory\n\nWe have a helper method for easy configuration, but there are also some manual steps required.\n\n```js\nconst {\n HybridModule,\n publishToGithubPackages,\n} = require(\"projen-cdktf-hybrid-construct\");\n\nconst project = new HybridModule({\n // ... all the other options\n ...publishToGithubPackages({\n name: \"my-new-hybrid-construct\",\n namespace: \"my-org\",\n registries: [\"npm\", \"pypi\", \"nuget\"], // maven is currently not supported, PRs welcome\n artifactoryApiUrl: \"https://artifactory.my-org.com/api/\",\n artifactoryRepository: \"my-repo\", // needs to be the same across all registries, defaults to namespace so \"my-org\" in this case\n }),\n});\n```\n\n#### Terraform\n\nYou can find more information about publishing Terraform Modules to Artifactory [here](https://www.jfrog.com/confluence/display/JFROG/Terraform+Registry#TerraformRegistry-SettingupaLocalModule/ProviderRegistry).\n\n#### npm (Typescript)\n\n1. [Create a virtual npm registry](https://www.jfrog.com/confluence/display/JFROG/npm+Registry#npmRegistry-VirtualnpmRegistry)\n2. [Authenticate against artifactory to get a token](https://www.jfrog.com/confluence/display/JFROG/npm+Registry#npmRegistry-AuthenticatingthenpmClient)\n3. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `NPM_TOKEN` and the value of the token\n\n#### pypi (Python)\n\n1. Create a [local repository](https://www.jfrog.com/confluence/display/JFROG/PyPI+Repositories#PyPIRepositories-LocalRepositories)\n2. Create a [GitHub Action Secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) with the name `TWINE_USERNAME` and the artifactory user name and a second one with the name `TWINE_PASSWORD` and the artifactory password\n"
73
74
  },
74
75
  "repository": {
75
76
  "type": "git",
@@ -189,7 +190,7 @@
189
190
  "custom": {
190
191
  "featured": "true"
191
192
  },
192
- "default": "\"^0.10.1\"",
193
+ "default": "\"^0.13.0\"",
193
194
  "stability": "stable",
194
195
  "summary": "Minimum target version of this library."
195
196
  },
@@ -464,7 +465,7 @@
464
465
  "custom": {
465
466
  "featured": "true"
466
467
  },
467
- "default": "\"^0.10.1\"",
468
+ "default": "\"^0.13.0\"",
468
469
  "stability": "stable",
469
470
  "summary": "Minimum target version of this library."
470
471
  },
@@ -601,6 +602,6 @@
601
602
  "symbolId": "src/terraform-module:TerraformVersionConstraint"
602
603
  }
603
604
  },
604
- "version": "0.1.70",
605
- "fingerprint": "6Wi+3J+td/Hp8GmeopeC1bAV+/pQM8Rfh3tVTYzjyRQ="
606
- }
605
+ "version": "0.2.0",
606
+ "fingerprint": "DBwhdPhNzp1pnu6Af03ULsCPtLjXhupZbILjiqGpBms="
607
+ }
package/.projenrc.ts CHANGED
@@ -29,23 +29,24 @@ const project = new JsiiProject({
29
29
  project.tsconfig?.exclude?.push("src/exampleCode/**");
30
30
  project.tsconfig?.exclude?.push("example/**");
31
31
  project.tsconfig?.exclude?.push("examples/**");
32
- project.addTask("buildExample", {
33
- exec: "yarn buildExample:hybrid && yarn buildExample:terraform",
34
- });
35
32
 
36
- project.addPeerDeps("projen@>= 0.56.2");
33
+ project.addPeerDeps("projen@>= 0.63.25");
37
34
  project.addBundledDeps("change-case");
38
35
  project.addDevDeps(
39
36
  "fs-extra",
40
37
  "glob",
41
- "projen@0.56.2",
38
+ "projen@0.63.25",
42
39
  "@types/fs-extra",
43
40
  "@types/glob",
44
- "@types/change-case"
41
+ "@types/change-case",
42
+ "ts-node@10.9.1"
45
43
  );
46
44
 
47
45
  project.addPackageIgnore("examples");
48
46
 
47
+ project.addTask("buildExample", {
48
+ exec: "yarn buildExample:hybrid && yarn buildExample:terraform",
49
+ });
49
50
  project.addTask("buildExample:hybrid", {
50
51
  exec: "git clean -dfx . && rm -rf lib modules src terraform construct-examples && yarn && yarn projen && yarn && yarn build",
51
52
  cwd: "./examples/hybrid-module",
package/API.md CHANGED
@@ -57,6 +57,7 @@ const hybridModuleOptions: HybridModuleOptions = { ... }
57
57
  | **Name** | **Type** | **Description** |
58
58
  | --- | --- | --- |
59
59
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.name">name</a></code> | <code>string</code> | This is the name of your project. |
60
+ | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.commitGenerated">commitGenerated</a></code> | <code>boolean</code> | Whether to commit the managed files by default. |
60
61
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.logging">logging</a></code> | <code>projen.LoggerOptions</code> | Configure logging options such as verbosity. |
61
62
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.outdir">outdir</a></code> | <code>string</code> | The root directory of the project. |
62
63
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.parent">parent</a></code> | <code>projen.Project</code> | The parent project, if this project is part of a bigger project. |
@@ -85,7 +86,7 @@ const hybridModuleOptions: HybridModuleOptions = { ... }
85
86
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.allowLibraryDependencies">allowLibraryDependencies</a></code> | <code>boolean</code> | Allow the project to include `peerDependencies` and `bundledDependencies`. |
86
87
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.authorEmail">authorEmail</a></code> | <code>string</code> | Author's e-mail. |
87
88
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.authorName">authorName</a></code> | <code>string</code> | Author's name. |
88
- | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.authorOrganization">authorOrganization</a></code> | <code>boolean</code> | Author's Organization. |
89
+ | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.authorOrganization">authorOrganization</a></code> | <code>boolean</code> | Is the author an organization. |
89
90
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.authorUrl">authorUrl</a></code> | <code>string</code> | Author's URL / Website. |
90
91
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.autoDetectBin">autoDetectBin</a></code> | <code>boolean</code> | Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section. |
91
92
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.bin">bin</a></code> | <code>{[ key: string ]: string}</code> | Binary programs vended with your module. |
@@ -118,6 +119,7 @@ const hybridModuleOptions: HybridModuleOptions = { ... }
118
119
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.stability">stability</a></code> | <code>string</code> | Package's Stability. |
119
120
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.jsiiReleaseVersion">jsiiReleaseVersion</a></code> | <code>string</code> | Version requirement of `publib` which is used to publish modules to npm. |
120
121
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.majorVersion">majorVersion</a></code> | <code>number</code> | Major version to release from the default branch. |
122
+ | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.minMajorVersion">minMajorVersion</a></code> | <code>number</code> | Minimal Major version to release. |
121
123
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.npmDistTag">npmDistTag</a></code> | <code>string</code> | The npmDistTag to use when publishing from the default branch. |
122
124
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.postBuildSteps">postBuildSteps</a></code> | <code>projen.github.workflows.JobStep[]</code> | Steps to execute after build as part of the release workflow. |
123
125
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.prerelease">prerelease</a></code> | <code>string</code> | Bump versions from the default branch as pre-releases (e.g. "beta", "alpha", "pre"). |
@@ -191,6 +193,7 @@ const hybridModuleOptions: HybridModuleOptions = { ... }
191
193
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.repositoryUrl">repositoryUrl</a></code> | <code>string</code> | Git repository URL. |
192
194
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.compat">compat</a></code> | <code>boolean</code> | Automatically run API compatibility test against the latest version published to npm after compilation. |
193
195
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.compatIgnore">compatIgnore</a></code> | <code>string</code> | Name of the ignore file for API compatibility tests. |
196
+ | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.compressAssembly">compressAssembly</a></code> | <code>boolean</code> | Emit a compressed version of the assembly. |
194
197
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.docgenFilePath">docgenFilePath</a></code> | <code>string</code> | File path for generated docs. |
195
198
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.dotnet">dotnet</a></code> | <code>projen.cdk.JsiiDotNetTarget</code> | *No description.* |
196
199
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModuleOptions.property.excludeTypescript">excludeTypescript</a></code> | <code>string[]</code> | Accepts a list of glob patterns. |
@@ -223,6 +226,19 @@ This is the name of your project.
223
226
 
224
227
  ---
225
228
 
229
+ ##### `commitGenerated`<sup>Optional</sup> <a name="commitGenerated" id="projen-cdktf-hybrid-construct.HybridModuleOptions.property.commitGenerated"></a>
230
+
231
+ ```typescript
232
+ public readonly commitGenerated: boolean;
233
+ ```
234
+
235
+ - *Type:* boolean
236
+ - *Default:* true
237
+
238
+ Whether to commit the managed files by default.
239
+
240
+ ---
241
+
226
242
  ##### `logging`<sup>Optional</sup> <a name="logging" id="projen-cdktf-hybrid-construct.HybridModuleOptions.property.logging"></a>
227
243
 
228
244
  ```typescript
@@ -635,7 +651,7 @@ public readonly authorOrganization: boolean;
635
651
 
636
652
  - *Type:* boolean
637
653
 
638
- Author's Organization.
654
+ Is the author an organization.
639
655
 
640
656
  ---
641
657
 
@@ -1127,6 +1143,24 @@ If not specified, we bump the global latest version.
1127
1143
 
1128
1144
  ---
1129
1145
 
1146
+ ##### `minMajorVersion`<sup>Optional</sup> <a name="minMajorVersion" id="projen-cdktf-hybrid-construct.HybridModuleOptions.property.minMajorVersion"></a>
1147
+
1148
+ ```typescript
1149
+ public readonly minMajorVersion: number;
1150
+ ```
1151
+
1152
+ - *Type:* number
1153
+ - *Default:* No minimum version is being enforced
1154
+
1155
+ Minimal Major version to release.
1156
+
1157
+ This can be useful to set to 1, as breaking changes before the 1.x major
1158
+ release are not incrementing the major version number.
1159
+
1160
+ Can not be set together with `majorVersion`.
1161
+
1162
+ ---
1163
+
1130
1164
  ##### `npmDistTag`<sup>Optional</sup> <a name="npmDistTag" id="projen-cdktf-hybrid-construct.HybridModuleOptions.property.npmDistTag"></a>
1131
1165
 
1132
1166
  ```typescript
@@ -1283,7 +1317,7 @@ public readonly releaseTagPrefix: string;
1283
1317
  ```
1284
1318
 
1285
1319
  - *Type:* string
1286
- - *Default:* no prefix
1320
+ - *Default:* "v"
1287
1321
 
1288
1322
  Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.
1289
1323
 
@@ -2124,6 +2158,19 @@ Name of the ignore file for API compatibility tests.
2124
2158
 
2125
2159
  ---
2126
2160
 
2161
+ ##### `compressAssembly`<sup>Optional</sup> <a name="compressAssembly" id="projen-cdktf-hybrid-construct.HybridModuleOptions.property.compressAssembly"></a>
2162
+
2163
+ ```typescript
2164
+ public readonly compressAssembly: boolean;
2165
+ ```
2166
+
2167
+ - *Type:* boolean
2168
+ - *Default:* false
2169
+
2170
+ Emit a compressed version of the assembly.
2171
+
2172
+ ---
2173
+
2127
2174
  ##### `docgenFilePath`<sup>Optional</sup> <a name="docgenFilePath" id="projen-cdktf-hybrid-construct.HybridModuleOptions.property.docgenFilePath"></a>
2128
2175
 
2129
2176
  ```typescript
@@ -2273,7 +2320,7 @@ public readonly cdktfVersion: string;
2273
2320
  ```
2274
2321
 
2275
2322
  - *Type:* string
2276
- - *Default:* "^0.10.1"
2323
+ - *Default:* "^0.13.0"
2277
2324
 
2278
2325
  Minimum target version of this library.
2279
2326
 
@@ -2418,6 +2465,7 @@ const terraformModuleOptions: TerraformModuleOptions = { ... }
2418
2465
  | **Name** | **Type** | **Description** |
2419
2466
  | --- | --- | --- |
2420
2467
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.name">name</a></code> | <code>string</code> | This is the name of your project. |
2468
+ | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.commitGenerated">commitGenerated</a></code> | <code>boolean</code> | Whether to commit the managed files by default. |
2421
2469
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.logging">logging</a></code> | <code>projen.LoggerOptions</code> | Configure logging options such as verbosity. |
2422
2470
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.outdir">outdir</a></code> | <code>string</code> | The root directory of the project. |
2423
2471
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.parent">parent</a></code> | <code>projen.Project</code> | The parent project, if this project is part of a bigger project. |
@@ -2446,7 +2494,7 @@ const terraformModuleOptions: TerraformModuleOptions = { ... }
2446
2494
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.allowLibraryDependencies">allowLibraryDependencies</a></code> | <code>boolean</code> | Allow the project to include `peerDependencies` and `bundledDependencies`. |
2447
2495
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.authorEmail">authorEmail</a></code> | <code>string</code> | Author's e-mail. |
2448
2496
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.authorName">authorName</a></code> | <code>string</code> | Author's name. |
2449
- | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.authorOrganization">authorOrganization</a></code> | <code>boolean</code> | Author's Organization. |
2497
+ | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.authorOrganization">authorOrganization</a></code> | <code>boolean</code> | Is the author an organization. |
2450
2498
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.authorUrl">authorUrl</a></code> | <code>string</code> | Author's URL / Website. |
2451
2499
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.autoDetectBin">autoDetectBin</a></code> | <code>boolean</code> | Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section. |
2452
2500
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.bin">bin</a></code> | <code>{[ key: string ]: string}</code> | Binary programs vended with your module. |
@@ -2479,6 +2527,7 @@ const terraformModuleOptions: TerraformModuleOptions = { ... }
2479
2527
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.stability">stability</a></code> | <code>string</code> | Package's Stability. |
2480
2528
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.jsiiReleaseVersion">jsiiReleaseVersion</a></code> | <code>string</code> | Version requirement of `publib` which is used to publish modules to npm. |
2481
2529
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.majorVersion">majorVersion</a></code> | <code>number</code> | Major version to release from the default branch. |
2530
+ | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.minMajorVersion">minMajorVersion</a></code> | <code>number</code> | Minimal Major version to release. |
2482
2531
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.npmDistTag">npmDistTag</a></code> | <code>string</code> | The npmDistTag to use when publishing from the default branch. |
2483
2532
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.postBuildSteps">postBuildSteps</a></code> | <code>projen.github.workflows.JobStep[]</code> | Steps to execute after build as part of the release workflow. |
2484
2533
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.prerelease">prerelease</a></code> | <code>string</code> | Bump versions from the default branch as pre-releases (e.g. "beta", "alpha", "pre"). |
@@ -2552,6 +2601,7 @@ const terraformModuleOptions: TerraformModuleOptions = { ... }
2552
2601
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.repositoryUrl">repositoryUrl</a></code> | <code>string</code> | Git repository URL. |
2553
2602
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.compat">compat</a></code> | <code>boolean</code> | Automatically run API compatibility test against the latest version published to npm after compilation. |
2554
2603
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.compatIgnore">compatIgnore</a></code> | <code>string</code> | Name of the ignore file for API compatibility tests. |
2604
+ | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.compressAssembly">compressAssembly</a></code> | <code>boolean</code> | Emit a compressed version of the assembly. |
2555
2605
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.docgenFilePath">docgenFilePath</a></code> | <code>string</code> | File path for generated docs. |
2556
2606
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.dotnet">dotnet</a></code> | <code>projen.cdk.JsiiDotNetTarget</code> | *No description.* |
2557
2607
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModuleOptions.property.excludeTypescript">excludeTypescript</a></code> | <code>string[]</code> | Accepts a list of glob patterns. |
@@ -2583,6 +2633,19 @@ This is the name of your project.
2583
2633
 
2584
2634
  ---
2585
2635
 
2636
+ ##### `commitGenerated`<sup>Optional</sup> <a name="commitGenerated" id="projen-cdktf-hybrid-construct.TerraformModuleOptions.property.commitGenerated"></a>
2637
+
2638
+ ```typescript
2639
+ public readonly commitGenerated: boolean;
2640
+ ```
2641
+
2642
+ - *Type:* boolean
2643
+ - *Default:* true
2644
+
2645
+ Whether to commit the managed files by default.
2646
+
2647
+ ---
2648
+
2586
2649
  ##### `logging`<sup>Optional</sup> <a name="logging" id="projen-cdktf-hybrid-construct.TerraformModuleOptions.property.logging"></a>
2587
2650
 
2588
2651
  ```typescript
@@ -2995,7 +3058,7 @@ public readonly authorOrganization: boolean;
2995
3058
 
2996
3059
  - *Type:* boolean
2997
3060
 
2998
- Author's Organization.
3061
+ Is the author an organization.
2999
3062
 
3000
3063
  ---
3001
3064
 
@@ -3487,6 +3550,24 @@ If not specified, we bump the global latest version.
3487
3550
 
3488
3551
  ---
3489
3552
 
3553
+ ##### `minMajorVersion`<sup>Optional</sup> <a name="minMajorVersion" id="projen-cdktf-hybrid-construct.TerraformModuleOptions.property.minMajorVersion"></a>
3554
+
3555
+ ```typescript
3556
+ public readonly minMajorVersion: number;
3557
+ ```
3558
+
3559
+ - *Type:* number
3560
+ - *Default:* No minimum version is being enforced
3561
+
3562
+ Minimal Major version to release.
3563
+
3564
+ This can be useful to set to 1, as breaking changes before the 1.x major
3565
+ release are not incrementing the major version number.
3566
+
3567
+ Can not be set together with `majorVersion`.
3568
+
3569
+ ---
3570
+
3490
3571
  ##### `npmDistTag`<sup>Optional</sup> <a name="npmDistTag" id="projen-cdktf-hybrid-construct.TerraformModuleOptions.property.npmDistTag"></a>
3491
3572
 
3492
3573
  ```typescript
@@ -3643,7 +3724,7 @@ public readonly releaseTagPrefix: string;
3643
3724
  ```
3644
3725
 
3645
3726
  - *Type:* string
3646
- - *Default:* no prefix
3727
+ - *Default:* "v"
3647
3728
 
3648
3729
  Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.
3649
3730
 
@@ -4484,6 +4565,19 @@ Name of the ignore file for API compatibility tests.
4484
4565
 
4485
4566
  ---
4486
4567
 
4568
+ ##### `compressAssembly`<sup>Optional</sup> <a name="compressAssembly" id="projen-cdktf-hybrid-construct.TerraformModuleOptions.property.compressAssembly"></a>
4569
+
4570
+ ```typescript
4571
+ public readonly compressAssembly: boolean;
4572
+ ```
4573
+
4574
+ - *Type:* boolean
4575
+ - *Default:* false
4576
+
4577
+ Emit a compressed version of the assembly.
4578
+
4579
+ ---
4580
+
4487
4581
  ##### `docgenFilePath`<sup>Optional</sup> <a name="docgenFilePath" id="projen-cdktf-hybrid-construct.TerraformModuleOptions.property.docgenFilePath"></a>
4488
4582
 
4489
4583
  ```typescript
@@ -4645,7 +4739,7 @@ public readonly cdktfVersion: string;
4645
4739
  ```
4646
4740
 
4647
4741
  - *Type:* string
4648
- - *Default:* "^0.10.1"
4742
+ - *Default:* "^0.13.0"
4649
4743
 
4650
4744
  Minimum target version of this library.
4651
4745
 
@@ -5297,6 +5391,7 @@ The command to execute.
5297
5391
  | **Name** | **Type** | **Description** |
5298
5392
  | --- | --- | --- |
5299
5393
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModule.property.buildTask">buildTask</a></code> | <code>projen.Task</code> | *No description.* |
5394
+ | <code><a href="#projen-cdktf-hybrid-construct.HybridModule.property.commitGenerated">commitGenerated</a></code> | <code>boolean</code> | Whether to commit the managed files by default. |
5300
5395
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModule.property.compileTask">compileTask</a></code> | <code>projen.Task</code> | *No description.* |
5301
5396
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModule.property.components">components</a></code> | <code>projen.Component[]</code> | Returns all the components within this project. |
5302
5397
  | <code><a href="#projen-cdktf-hybrid-construct.HybridModule.property.deps">deps</a></code> | <code>projen.Dependencies</code> | Project dependencies. |
@@ -5367,6 +5462,18 @@ public readonly buildTask: Task;
5367
5462
 
5368
5463
  ---
5369
5464
 
5465
+ ##### `commitGenerated`<sup>Required</sup> <a name="commitGenerated" id="projen-cdktf-hybrid-construct.HybridModule.property.commitGenerated"></a>
5466
+
5467
+ ```typescript
5468
+ public readonly commitGenerated: boolean;
5469
+ ```
5470
+
5471
+ - *Type:* boolean
5472
+
5473
+ Whether to commit the managed files by default.
5474
+
5475
+ ---
5476
+
5370
5477
  ##### `compileTask`<sup>Required</sup> <a name="compileTask" id="projen-cdktf-hybrid-construct.HybridModule.property.compileTask"></a>
5371
5478
 
5372
5479
  ```typescript
@@ -6637,6 +6744,7 @@ The command to execute.
6637
6744
  | **Name** | **Type** | **Description** |
6638
6745
  | --- | --- | --- |
6639
6746
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModule.property.buildTask">buildTask</a></code> | <code>projen.Task</code> | *No description.* |
6747
+ | <code><a href="#projen-cdktf-hybrid-construct.TerraformModule.property.commitGenerated">commitGenerated</a></code> | <code>boolean</code> | Whether to commit the managed files by default. |
6640
6748
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModule.property.compileTask">compileTask</a></code> | <code>projen.Task</code> | *No description.* |
6641
6749
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModule.property.components">components</a></code> | <code>projen.Component[]</code> | Returns all the components within this project. |
6642
6750
  | <code><a href="#projen-cdktf-hybrid-construct.TerraformModule.property.deps">deps</a></code> | <code>projen.Dependencies</code> | Project dependencies. |
@@ -6707,6 +6815,18 @@ public readonly buildTask: Task;
6707
6815
 
6708
6816
  ---
6709
6817
 
6818
+ ##### `commitGenerated`<sup>Required</sup> <a name="commitGenerated" id="projen-cdktf-hybrid-construct.TerraformModule.property.commitGenerated"></a>
6819
+
6820
+ ```typescript
6821
+ public readonly commitGenerated: boolean;
6822
+ ```
6823
+
6824
+ - *Type:* boolean
6825
+
6826
+ Whether to commit the managed files by default.
6827
+
6828
+ ---
6829
+
6710
6830
  ##### `compileTask`<sup>Required</sup> <a name="compileTask" id="projen-cdktf-hybrid-construct.TerraformModule.property.compileTask"></a>
6711
6831
 
6712
6832
  ```typescript
package/CHANGELOG.md CHANGED
@@ -1,2 +1,9 @@
1
+ # Changelog
1
2
 
2
- ### [0.1.70](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/compare/v0.1.69...v0.1.70) (2022-05-12)
3
+ ## 0.1.45
4
+
5
+ - _Breaking Change_: `terraformExamplesFolder`, `terraformProvider`, `terraformProvider*Config` are now part of `terraformExamples` and differently structured.
6
+ - Add documentation hook (using docker if `terraform-docs` is not enabled)
7
+ - Add terraform and construct example folders
8
+ - Add tests to the generated code
9
+ - Remove `pre-commit` hooks
package/README.md CHANGED
@@ -38,7 +38,7 @@ const project = new HybridModule({
38
38
  }
39
39
  }
40
40
  # Terraform binary version constraint
41
- required_version = "~> 1.1.0"
41
+ required_version = ">= 1.2.0"
42
42
  }
43
43
 
44
44
 
@@ -12,7 +12,7 @@ export interface TerraformExamplesOption {
12
12
  export interface HybridModuleOptions extends ConstructLibraryOptions {
13
13
  /**
14
14
  * Minimum target version of this library.
15
- * @default "^0.10.1"
15
+ * @default "^0.13.0"
16
16
  * @featured
17
17
  */
18
18
  readonly cdktfVersion?: string;
@@ -103,7 +103,6 @@ ${this.content}`;
103
103
  */
104
104
  class HybridModule extends cdk_1.JsiiProject {
105
105
  constructor(options) {
106
- var _b, _c, _d;
107
106
  super({
108
107
  ...defaults_1.defaults,
109
108
  ...options,
@@ -112,14 +111,15 @@ class HybridModule extends cdk_1.JsiiProject {
112
111
  }),
113
112
  postBuildSteps: [],
114
113
  });
115
- const constructVersion = options.constructVersion || "^10.0.107";
116
- const cdktfVersion = options.cdktfVersion || "^0.10.1";
114
+ const constructVersion = options.constructVersion || "10.0.107";
115
+ const cdktfVersion = options.cdktfVersion || "0.13.0";
116
+ console.log({ cdktfVersion, constructVersion });
117
117
  this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);
118
- this.addDevDeps(`cdktf-cli@${cdktfVersion}`, "ts-node");
118
+ this.addDevDeps(`cdktf-cli@${cdktfVersion}`, "ts-node@>=10.9.1");
119
119
  this.addKeywords("cdk", "cdktf", "cdktf-hybrid", "terraform");
120
120
  this.setScript("terraform:test", "./scripts/tf-module-test.sh");
121
121
  // Module Entrypoint
122
- this.addDeps("cdktf-tf-module-stack");
122
+ this.addDeps("cdktf-tf-module-stack@>=0.2.0");
123
123
  const moduleDocs = `
124
124
  # My Awesome Module
125
125
 
@@ -127,7 +127,10 @@ class HybridModule extends cdk_1.JsiiProject {
127
127
 
128
128
  \`\`\`hcl
129
129
  module "eks_managed_node_group" {
130
- source = "${((_b = options.repositoryUrl) === null || _b === void 0 ? void 0 : _b.replace("https://github.com/", "").replace("http://github.com/", "").replace("github.com/", "")) || "my-github-repo"}//modules/my-awesome-module"
130
+ source = "${options.repositoryUrl
131
+ ?.replace("https://github.com/", "")
132
+ .replace("http://github.com/", "")
133
+ .replace("github.com/", "") || "my-github-repo"}//modules/my-awesome-module"
131
134
 
132
135
  }
133
136
  \`\`\`
@@ -154,7 +157,7 @@ module "eks_managed_node_group" {
154
157
  `
155
158
  terraform {
156
159
  # Terraform binary version constraint
157
- required_version = "~> 1.1.0"
160
+ required_version = ">= 1.2.0"
158
161
 
159
162
  # Define all needed providers here, you can find all available providers here:
160
163
  # https://registry.terraform.io/
@@ -184,7 +187,7 @@ terraform -chdir=${examplesFolder} validate
184
187
  ${options.runPlan ? `terraform -chdir=${examplesFolder} plan` : ""}
185
188
  `);
186
189
  this.testTask.exec("./scripts/tf-module-test.sh");
187
- (_c = this.jest) === null || _c === void 0 ? void 0 : _c.addIgnorePattern(`<rootDir>/${examplesFolder}`);
190
+ this.jest?.addIgnorePattern(`<rootDir>/${examplesFolder}`);
188
191
  }
189
192
  if (options.constructExamples && options.constructExamples.enabled) {
190
193
  const constructExampleFolder = options.constructExamples.folder || "construct-examples";
@@ -252,7 +255,7 @@ app.synth();
252
255
  this.gitignore.addPatterns(`${constructExampleFolder}/cdktf.out`);
253
256
  }
254
257
  this.gitignore.addPatterns("src/.gen", "src/cdktf.out", "src/modules");
255
- this.compileTask.prependExec("cdktf get", {
258
+ this.compileTask.prependExec("npx cdktf get", {
256
259
  cwd: this.srcdir,
257
260
  });
258
261
  this.compileTask.exec("cdktf synth", {
@@ -313,10 +316,10 @@ done
313
316
  name: "Copy HCL Modules",
314
317
  });
315
318
  // ignore dist in tests
316
- (_d = this.jest) === null || _d === void 0 ? void 0 : _d.addIgnorePattern("dist");
319
+ this.jest?.addIgnorePattern("dist");
317
320
  }
318
321
  }
319
322
  exports.HybridModule = HybridModule;
320
323
  _a = JSII_RTTI_SYMBOL_1;
321
- HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.1.70" };
322
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hybrid-module.js","sourceRoot":"","sources":["../src/hybrid-module.ts"],"names":[],"mappings":";;;;;AAAA,6BAA6B;AAC7B,mCAAiE;AACjE,wCAAsE;AACtE,yCAAsC;AA6DtC,MAAM,gBAAgB,GAAG;;;;;;;;;;;;CAYxB,CAAC;AAEF,MAAM,iBAAiB,GAAG;;;;;;;;;;;;;;;;;CAiBzB,CAAC;AAEF,MAAM,aAAa,GAAG;;;;;;;;;;;;;;;;;;;;;;CAsBrB,CAAC;AAEF,MAAM,mBAAmB,GAAG;;;;;;;;;KASvB,CAAC;AAEN,MAAM,UAAW,SAAQ,iBAAQ;IAC/B,YAAY,OAAgB,EAAE,QAAgB,EAAU,OAAe;QACrE,KAAK,CAAC,OAAO,EAAE,QAAQ,EAAE;YACvB,UAAU,EAAE,IAAI;SACjB,CAAC,CAAC;QAHmD,YAAO,GAAP,OAAO,CAAQ;IAIvE,CAAC;IAES,iBAAiB,CAAC,CAAY;QACtC,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;CACF;AAED,MAAM,OAAQ,SAAQ,iBAAQ;IAC5B,YAAY,OAAgB,EAAE,QAAgB,EAAU,OAAe;QACrE,KAAK,CAAC,OAAO,EAAE,QAAQ,EAAE;YACvB,UAAU,EAAE,KAAK;YACjB,SAAS,EAAE,IAAI;YACf,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC;QALmD,YAAO,GAAP,OAAO,CAAQ;IAMvE,CAAC;IAES,iBAAiB,CAAC,CAAY;QACtC,OAAO;EACT,IAAI,CAAC,OAAO,EAAE,CAAC;IACf,CAAC;CACF;AAED;;;;GAIG;AACH,MAAa,YAAa,SAAQ,iBAAW;IAC3C,YAAY,OAA4B;;QACtC,KAAK,CAAC;YACJ,GAAG,mBAAQ;YACX,GAAG,OAAO;YACV,aAAa,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,aAAa,EAAE;gBACtD,YAAY,EAAE,KAAK;aACpB,CAAC;YACF,cAAc,EAAE,EAAE;SACnB,CAAC,CAAC;QACH,MAAM,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,IAAI,WAAW,CAAC;QACjE,MAAM,YAAY,GAAG,OAAO,CAAC,YAAY,IAAI,SAAS,CAAC;QAEvD,IAAI,CAAC,WAAW,CAAC,cAAc,gBAAgB,EAAE,EAAE,SAAS,YAAY,EAAE,CAAC,CAAC;QAC5E,IAAI,CAAC,UAAU,CAAC,aAAa,YAAY,EAAE,EAAE,SAAS,CAAC,CAAC;QACxD,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;QAC9D,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,6BAA6B,CAAC,CAAC;QAEhE,oBAAoB;QACpB,IAAI,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC;QACtC,MAAM,UAAU,GAAG;;;;;;;cAQnB,OAAA,OAAO,CAAC,aAAa,0CACjB,OAAO,CAAC,qBAAqB,EAAE,EAAE,EAClC,OAAO,CAAC,oBAAoB,EAAE,EAAE,EAChC,OAAO,CAAC,aAAa,EAAE,EAAE,MAAK,gBACnC;;;;KAIG,CAAC;QAEF,IAAI,kBAAS,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE;YAC/B,KAAK,EAAE;gBACL,UAAU,EAAE,gBAAgB,CAAC,IAAI,EAAE;gBACnC,cAAc,EAAE,aAAa,CAAC,IAAI,EAAE;gBACpC,sBAAsB,EAAE,UAAU,CAAC,IAAI,EAAE;gBACzC,YAAY,EAAE,IAAI,CAAC,SAAS,CAC1B;oBACE,QAAQ,EAAE,YAAY;oBACtB,GAAG,EAAE,0BAA0B;oBAC/B,kBAAkB,EAAE,CAAC,sBAAsB,CAAC;oBAC5C,gBAAgB,EAAE,EAAE;oBACpB,MAAM,EAAE,SAAS;oBACjB,SAAS,EACP,OAAO,CAAC,SAAS;wBACjB,oDAAoD;iBACvD,EACD,IAAI,EACJ,CAAC,CACF;gBACD,yBAAyB,EAAE,iBAAiB,CAAC,IAAI,EAAE;aACpD;SACF,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,iBAAiB,IAAI,OAAO,CAAC,iBAAiB,CAAC,OAAO,EAAE;YAClE,MAAM,cAAc,GAClB,OAAO,CAAC,iBAAiB,CAAC,cAAc;gBACxC;;;;;;;;;;;;CAYP,CAAC,IAAI,EAAE,CAAC;YACH,MAAM,cAAc,GAClB,OAAO,CAAC,iBAAiB,CAAC,MAAM,IAAI,oBAAoB,CAAC;YAE3D,IAAI,kBAAS,CAAC,IAAI,EAAE,cAAc,EAAE;gBAClC,KAAK,EAAE;oBACL,SAAS,EACP,OAAO,CAAC,iBAAiB,CAAC,WAAW;wBACrC,6BAA6B;oBAC/B,WAAW,EAAE,mBAAmB,CAAC,IAAI,EAAE;iBACxC;aACF,CAAC,CAAC;YAEH,IAAI,OAAO,CACT,IAAI,EACJ,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,aAAa,CAAC,EACxC,cAAc,CACf,CAAC;YAEF,IAAI,CAAC,SAAS,CAAC,WAAW,CACxB,GAAG,cAAc,aAAa,EAC9B,GAAG,cAAc,sBAAsB,CACxC,CAAC;YAEF,IAAI,UAAU,CACZ,IAAI,EACJ,6BAA6B,EAC7B;;;;mBAIW,cAAc;mBACd,cAAc;mBACd,cAAc;EAC/B,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,oBAAoB,cAAc,OAAO,CAAC,CAAC,CAAC,EAAE;WACvD,CACJ,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;YAClD,MAAA,IAAI,CAAC,IAAI,0CAAE,gBAAgB,CAAC,aAAa,cAAc,EAAE,EAAE;SAC5D;QAED,IAAI,OAAO,CAAC,iBAAiB,IAAI,OAAO,CAAC,iBAAiB,CAAC,OAAO,EAAE;YAClE,MAAM,sBAAsB,GAC1B,OAAO,CAAC,iBAAiB,CAAC,MAAM,IAAI,oBAAoB,CAAC;YAE3D,MAAM,MAAM,GAAG,sBAAsB;iBAClC,KAAK,CAAC,GAAG,CAAC;iBACV,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC;iBACZ,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;iBACf,IAAI,CAAC,GAAG,CAAC,CAAC;YAEb,MAAM,mBAAmB,GAAG;;;;;;;;CAQjC,CAAC;YAEI,MAAM,oBAAoB,GAAG;;;;+BAIJ,MAAM;;;;;;;;;;;;;CAapC,CAAC;YAEI,MAAM,qBAAqB,GAAG;;;;;;;;;;;;CAYnC,CAAC;YAEI,IAAI,kBAAS,CAAC,IAAI,EAAE,sBAAsB,EAAE;gBAC1C,KAAK,EAAE;oBACL,UAAU,EAAE,qBAAqB,CAAC,IAAI,EAAE;oBACxC,UAAU,EAAE,oBAAoB,CAAC,IAAI,EAAE;oBACvC,YAAY,EAAE,IAAI,CAAC,SAAS,CAC1B;wBACE,QAAQ,EAAE,YAAY;wBACtB,GAAG,EAAE,yBAAyB,MAAM,6BAA6B;wBACjE,SAAS,EACP,OAAO,CAAC,SAAS;4BACjB,oDAAoD;qBACvD,EACD,IAAI,EACJ,CAAC,CACF;oBACD,WAAW,EAAE,mBAAmB,CAAC,IAAI,EAAE;iBACxC;aACF,CAAC,CAAC;YAEH,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE;gBAChC,GAAG,EAAE,sBAAsB;aAC5B,CAAC,CAAC;YACH,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,sBAAsB,YAAY,CAAC,CAAC;SACnE;QAED,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,UAAU,EAAE,eAAe,EAAE,aAAa,CAAC,CAAC;QACvE,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,WAAW,EAAE;YACxC,GAAG,EAAE,IAAI,CAAC,MAAM;SACjB,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE;YACnC,GAAG,EAAE,IAAI,CAAC,MAAM;YAChB,IAAI,EAAE,uBAAuB;SAC9B,CAAC,CAAC;QAEH,IAAI,UAAU,CACZ,IAAI,EACJ,yBAAyB,EACzB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiDL,CAAC,IAAI,EAAE,CACH,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,2BAA2B,EAAE;YACjD,IAAI,EAAE,kBAAkB;SACzB,CAAC,CAAC;QAEH,uBAAuB;QACvB,MAAA,IAAI,CAAC,IAAI,0CAAE,gBAAgB,CAAC,MAAM,EAAE;IACtC,CAAC;;AAzQH,oCA0QC","sourcesContent":["import * 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.10.1\"\n   * @featured\n   */\n  readonly cdktfVersion?: string;\n\n  /**\n   * Construct version to use\n   * @default \"^10.0.12\"\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.10.1\";\n\n    this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);\n    this.addDevDeps(`cdktf-cli@${cdktfVersion}`, \"ts-node\");\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\");\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.1.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(\"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"]}
324
+ HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.2.0" };
325
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hybrid-module.js","sourceRoot":"","sources":["../src/hybrid-module.ts"],"names":[],"mappings":"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","sourcesContent":["import * 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.13.0\"\n   * @featured\n   */\n  readonly cdktfVersion?: string;\n\n  /**\n   * Construct version to use\n   * @default \"^10.0.12\"\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.13.0\";\n\n    console.log({ cdktfVersion, constructVersion });\n    this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);\n    this.addDevDeps(`cdktf-cli@${cdktfVersion}`, \"ts-node@>=10.9.1\");\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@>=0.2.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"]}
@@ -7,7 +7,7 @@ export interface TerraformVersionConstraint {
7
7
  export interface TerraformModuleOptions extends ConstructLibraryOptions {
8
8
  /**
9
9
  * Minimum target version of this library.
10
- * @default "^0.10.1"
10
+ * @default "^0.13.0"
11
11
  * @featured
12
12
  */
13
13
  readonly cdktfVersion?: string;
@@ -21,8 +21,8 @@ class TerraformModule extends cdk_1.ConstructLibrary {
21
21
  }),
22
22
  postBuildSteps: [],
23
23
  });
24
- const constructVersion = options.constructVersion || "^10.0.107";
25
- const cdktfVersion = options.cdktfVersion || "^0.10.1";
24
+ const constructVersion = options.constructVersion || "10.0.107";
25
+ const cdktfVersion = options.cdktfVersion || "0.13.0";
26
26
  const constructSrcCode = `
27
27
  // Re-Export module bindings
28
28
  export * from "./terraformModules";
@@ -38,8 +38,8 @@ describe("MyModule", () => {
38
38
  it.todo("should be tested")
39
39
  });
40
40
  `;
41
- this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);
42
- this.addDevDeps(`cdktf-cli@${cdktfVersion}`, "ts-node");
41
+ this.addPeerDeps(`constructs@>=${constructVersion}`, `cdktf@>=${cdktfVersion}`);
42
+ this.addDevDeps(`cdktf@${cdktfVersion}`, `cdktf-cli@${cdktfVersion}`, "ts-node@>=10.9.1");
43
43
  this.addKeywords("cdktf", "cdktf-hybrid");
44
44
  new projen_1.SampleDir(this, this.srcdir, {
45
45
  files: {
@@ -66,10 +66,10 @@ describe("MyModule", () => {
66
66
  "terraform-module-99a770a7-3ec5-40f7-8cd3-dbc72f75a00a",
67
67
  },
68
68
  });
69
- this.preCompileTask.exec(`cdktf get`, { cwd: this.srcdir });
69
+ this.preCompileTask.exec(`npx cdktf get`, { cwd: this.srcdir });
70
70
  }
71
71
  }
72
72
  exports.TerraformModule = TerraformModule;
73
73
  _a = JSII_RTTI_SYMBOL_1;
74
- TerraformModule[_a] = { fqn: "projen-cdktf-hybrid-construct.TerraformModule", version: "0.1.70" };
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90ZXJyYWZvcm0tbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQXVEO0FBQ3ZELHdDQUEyRTtBQUUzRSx5Q0FBc0M7QUF3Q3RDOzs7O0dBSUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEsc0JBQWdCO0lBQ25ELFlBQVksT0FBK0I7UUFDekMsS0FBSyxDQUFDO1lBQ0osR0FBRyxtQkFBUTtZQUNYLEdBQUcsT0FBTztZQUNWLGFBQWEsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsYUFBYSxFQUFFO2dCQUN0RCxZQUFZLEVBQUUsS0FBSzthQUNwQixDQUFDO1lBQ0YsY0FBYyxFQUFFLEVBQUU7U0FDbkIsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsZ0JBQWdCLElBQUksV0FBVyxDQUFDO1FBQ2pFLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxZQUFZLElBQUksU0FBUyxDQUFDO1FBRXZELE1BQU0sZ0JBQWdCLEdBQUc7Ozs7O0NBSzVCLENBQUM7UUFFRSxNQUFNLGlCQUFpQixHQUFHOzs7Ozs7OztDQVE3QixDQUFDO1FBRUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxjQUFjLGdCQUFnQixFQUFFLEVBQUUsU0FBUyxZQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQzVFLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxZQUFZLEVBQUUsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4RCxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQztRQUUxQyxJQUFJLGtCQUFTLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDL0IsS0FBSyxFQUFFO2dCQUNMLFVBQVUsRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUU7Z0JBQ25DLHlCQUF5QixFQUFFLGlCQUFpQixDQUFDLElBQUksRUFBRTthQUNwRDtTQUNGLENBQUMsQ0FBQztRQUNILElBQUksaUJBQVEsQ0FBQyxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxzQkFBc0IsRUFBRTtZQUN2RCxTQUFTLEVBQUUsSUFBSTtZQUNmLE1BQU0sRUFBRSxJQUFJO1lBQ1osS0FBSyxFQUFFO2dCQUNMLEdBQUcsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLElBQUksRUFBRSxDQUFDLENBQUMsR0FBRyxDQUNyQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsaUNBQWlDLFFBQVEsQ0FBQyxJQUFJLElBQUksQ0FDakU7Z0JBQ0QsRUFBRTthQUNIO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxpQkFBUSxDQUFDLElBQUksRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLGFBQWEsRUFBRTtZQUM5QyxTQUFTLEVBQUUsSUFBSTtZQUNmLEdBQUcsRUFBRTtnQkFDSCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIsR0FBRyxFQUFFLHNCQUFzQjtnQkFDM0Isa0JBQWtCLEVBQUUsT0FBTyxDQUFDLGtCQUFrQixJQUFJLEVBQUU7Z0JBQ3BELGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxnQkFBZ0I7Z0JBQzFDLFNBQVMsRUFDUCxPQUFPLENBQUMsU0FBUztvQkFDakIsdURBQXVEO2FBQzFEO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQzlELENBQUM7O0FBakVILDBDQWtFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEpzb25GaWxlLCBTYW1wbGVEaXIsIFRleHRGaWxlIH0gZnJvbSBcInByb2plblwiO1xuaW1wb3J0IHsgQ29uc3RydWN0TGlicmFyeSwgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMgfSBmcm9tIFwicHJvamVuL2xpYi9jZGtcIjtcblxuaW1wb3J0IHsgZGVmYXVsdHMgfSBmcm9tIFwiLi9kZWZhdWx0c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50IHtcbiAgLy8gbmFtZSBvZiB0aGUgbW9kdWxlXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLy8gcGF0aCAvIHVybCAvIHJlZ2lzdHJ5IGlkZW50aWZpZXIgZm9yIHRoZSBtb2R1bGVcbiAgcmVhZG9ubHkgc291cmNlOiBzdHJpbmc7XG4gIC8vIHZlcnNpb24gY29uc3RyYWludCAoaHR0cHM6Ly93d3cudGVycmFmb3JtLmlvL2RvY3MvbGFuZ3VhZ2UvcHJvdmlkZXJzL3JlcXVpcmVtZW50cy5odG1sI3ZlcnNpb24tY29uc3RyYWludHMpXG4gIHJlYWRvbmx5IHZlcnNpb246IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zIGV4dGVuZHMgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMge1xuICAvKipcbiAgICogTWluaW11bSB0YXJnZXQgdmVyc2lvbiBvZiB0aGlzIGxpYnJhcnkuXG4gICAqIEBkZWZhdWx0IFwiXjAuMTAuMVwiXG4gICAqIEBmZWF0dXJlZFxuICAgKi9cbiAgcmVhZG9ubHkgY2RrdGZWZXJzaW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBDb25zdHJ1Y3QgdmVyc2lvbiB0byB1c2VcbiAgICogQGRlZmF1bHQgXCJeMTAuMC4xMlwiXG4gICAqL1xuICByZWFkb25seSBjb25zdHJ1Y3RWZXJzaW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiAgTGlzdCBvZiBwcm92aWRlciBiaW5kaW5ncyB0byBnZW5lcmF0ZSBpbiBhZGRpdGlvbiB0byB0aGUgbW9kdWxlcy5cbiAgICovXG4gIHJlYWRvbmx5IHRlcnJhZm9ybVByb3ZpZGVycz86IFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50W107XG5cbiAgLyoqXG4gICAqIExpc3Qgb2YgbW9kdWxlcyB0byBnZW5lcmF0ZSBiaW5kaW5ncyBmb3IuXG4gICAqIEBmZWF0dXJlZFxuICAgKi9cbiAgcmVhZG9ubHkgdGVycmFmb3JtTW9kdWxlczogVGVycmFmb3JtVmVyc2lvbkNvbnN0cmFpbnRbXTtcblxuICAvLyBEZWZhdWx0ZWQgdG8gYSB1dWlkIHN0cmluZyBhcyBjZGt0ZiB3b3VsZFxuICByZWFkb25seSBwcm9qZWN0SWQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogVGVycmFmb3JtIE1vZHVsZXMgcmVwdWJsaXNoZWQgYXMgQ0RLVEYgQ29uc3RydWN0c1xuICpcbiAqIEBwamlkIHRlcnJhZm9ybS1tb2R1bGVcbiAqL1xuZXhwb3J0IGNsYXNzIFRlcnJhZm9ybU1vZHVsZSBleHRlbmRzIENvbnN0cnVjdExpYnJhcnkge1xuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zKSB7XG4gICAgc3VwZXIoe1xuICAgICAgLi4uZGVmYXVsdHMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgICAgZXNsaW50T3B0aW9uczogT2JqZWN0LmFzc2lnbih7fSwgb3B0aW9ucy5lc2xpbnRPcHRpb25zLCB7XG4gICAgICAgIGxpbnRQcm9qZW5SYzogZmFsc2UsXG4gICAgICB9KSxcbiAgICAgIHBvc3RCdWlsZFN0ZXBzOiBbXSxcbiAgICB9KTtcbiAgICBjb25zdCBjb25zdHJ1Y3RWZXJzaW9uID0gb3B0aW9ucy5jb25zdHJ1Y3RWZXJzaW9uIHx8IFwiXjEwLjAuMTA3XCI7XG4gICAgY29uc3QgY2RrdGZWZXJzaW9uID0gb3B0aW9ucy5jZGt0ZlZlcnNpb24gfHwgXCJeMC4xMC4xXCI7XG5cbiAgICBjb25zdCBjb25zdHJ1Y3RTcmNDb2RlID0gYFxuLy8gUmUtRXhwb3J0IG1vZHVsZSBiaW5kaW5nc1xuZXhwb3J0ICogZnJvbSBcIi4vdGVycmFmb3JtTW9kdWxlc1wiO1xuXG4vLyBBZGQgeW91ciBjdXN0b20gY29uc3RydWN0cyBoZXJlXG5gO1xuXG4gICAgY29uc3QgY29uc3RydWN0VGVzdENvZGUgPSBgXG4vLyBpbXBvcnQgeyBUZXN0aW5nIH0gZnJvbSBcImNka3RmXCI7XG4vLyBpbXBvcnQgXCJjZGt0Zi9saWIvdGVzdGluZy9hZGFwdGVycy9qZXN0XCI7XG5cbi8vIFRvIGxlYXJuIG1vcmUgYWJvdXQgdGVzdGluZyBzZWUgY2RrLnRmL3Rlc3RpbmdcbmRlc2NyaWJlKFwiTXlNb2R1bGVcIiwgKCkgPT4ge1xuICBpdC50b2RvKFwic2hvdWxkIGJlIHRlc3RlZFwiKVxufSk7XG5gO1xuXG4gICAgdGhpcy5hZGRQZWVyRGVwcyhgY29uc3RydWN0c0Ake2NvbnN0cnVjdFZlcnNpb259YCwgYGNka3RmQCR7Y2RrdGZWZXJzaW9ufWApO1xuICAgIHRoaXMuYWRkRGV2RGVwcyhgY2RrdGYtY2xpQCR7Y2RrdGZWZXJzaW9ufWAsIFwidHMtbm9kZVwiKTtcbiAgICB0aGlzLmFkZEtleXdvcmRzKFwiY2RrdGZcIiwgXCJjZGt0Zi1oeWJyaWRcIik7XG5cbiAgICBuZXcgU2FtcGxlRGlyKHRoaXMsIHRoaXMuc3JjZGlyLCB7XG4gICAgICBmaWxlczoge1xuICAgICAgICBcImluZGV4LnRzXCI6IGNvbnN0cnVjdFNyY0NvZGUudHJpbSgpLFxuICAgICAgICBcIl9fdGVzdHNfXy9pbmRleC10ZXN0LnRzXCI6IGNvbnN0cnVjdFRlc3RDb2RlLnRyaW0oKSxcbiAgICAgIH0sXG4gICAgfSk7XG4gICAgbmV3IFRleHRGaWxlKHRoaXMsIGAke3RoaXMuc3JjZGlyfS90ZXJyYWZvcm1Nb2R1bGVzLnRzYCwge1xuICAgICAgY29tbWl0dGVkOiB0cnVlLFxuICAgICAgbWFya2VyOiB0cnVlLFxuICAgICAgbGluZXM6IFtcbiAgICAgICAgLi4uKG9wdGlvbnMudGVycmFmb3JtTW9kdWxlcyB8fCBbXSkubWFwKFxuICAgICAgICAgICh0Zk1vZHVsZSkgPT4gYGV4cG9ydCAqIGZyb20gXCIuLy5nZW4vbW9kdWxlcy8ke3RmTW9kdWxlLm5hbWV9XCI7YFxuICAgICAgICApLFxuICAgICAgICBcIlwiLFxuICAgICAgXSxcbiAgICB9KTtcblxuICAgIG5ldyBKc29uRmlsZSh0aGlzLCBgJHt0aGlzLnNyY2Rpcn0vY2RrdGYuanNvbmAsIHtcbiAgICAgIGNvbW1pdHRlZDogdHJ1ZSxcbiAgICAgIG9iajoge1xuICAgICAgICBsYW5ndWFnZTogXCJ0eXBlc2NyaXB0XCIsXG4gICAgICAgIGFwcDogXCJucHggdHMtbm9kZSBpbmRleC50c1wiLFxuICAgICAgICB0ZXJyYWZvcm1Qcm92aWRlcnM6IG9wdGlvbnMudGVycmFmb3JtUHJvdmlkZXJzIHx8IFtdLFxuICAgICAgICB0ZXJyYWZvcm1Nb2R1bGVzOiBvcHRpb25zLnRlcnJhZm9ybU1vZHVsZXMsXG4gICAgICAgIHByb2plY3RJZDpcbiAgICAgICAgICBvcHRpb25zLnByb2plY3RJZCB8fFxuICAgICAgICAgIFwidGVycmFmb3JtLW1vZHVsZS05OWE3NzBhNy0zZWM1LTQwZjctOGNkMy1kYmM3MmY3NWEwMGFcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICB0aGlzLnByZUNvbXBpbGVUYXNrLmV4ZWMoYGNka3RmIGdldGAsIHsgY3dkOiB0aGlzLnNyY2RpciB9KTtcbiAgfVxufVxuIl19
74
+ TerraformModule[_a] = { fqn: "projen-cdktf-hybrid-construct.TerraformModule", version: "0.2.0" };
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90ZXJyYWZvcm0tbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQXVEO0FBQ3ZELHdDQUEyRTtBQUUzRSx5Q0FBc0M7QUF3Q3RDOzs7O0dBSUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEsc0JBQWdCO0lBQ25ELFlBQVksT0FBK0I7UUFDekMsS0FBSyxDQUFDO1lBQ0osR0FBRyxtQkFBUTtZQUNYLEdBQUcsT0FBTztZQUNWLGFBQWEsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsYUFBYSxFQUFFO2dCQUN0RCxZQUFZLEVBQUUsS0FBSzthQUNwQixDQUFDO1lBQ0YsY0FBYyxFQUFFLEVBQUU7U0FDbkIsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsZ0JBQWdCLElBQUksVUFBVSxDQUFDO1FBQ2hFLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxZQUFZLElBQUksUUFBUSxDQUFDO1FBRXRELE1BQU0sZ0JBQWdCLEdBQUc7Ozs7O0NBSzVCLENBQUM7UUFFRSxNQUFNLGlCQUFpQixHQUFHOzs7Ozs7OztDQVE3QixDQUFDO1FBRUUsSUFBSSxDQUFDLFdBQVcsQ0FDZCxnQkFBZ0IsZ0JBQWdCLEVBQUUsRUFDbEMsV0FBVyxZQUFZLEVBQUUsQ0FDMUIsQ0FBQztRQUNGLElBQUksQ0FBQyxVQUFVLENBQ2IsU0FBUyxZQUFZLEVBQUUsRUFDdkIsYUFBYSxZQUFZLEVBQUUsRUFDM0Isa0JBQWtCLENBQ25CLENBQUM7UUFDRixJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQztRQUUxQyxJQUFJLGtCQUFTLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDL0IsS0FBSyxFQUFFO2dCQUNMLFVBQVUsRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUU7Z0JBQ25DLHlCQUF5QixFQUFFLGlCQUFpQixDQUFDLElBQUksRUFBRTthQUNwRDtTQUNGLENBQUMsQ0FBQztRQUNILElBQUksaUJBQVEsQ0FBQyxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxzQkFBc0IsRUFBRTtZQUN2RCxTQUFTLEVBQUUsSUFBSTtZQUNmLE1BQU0sRUFBRSxJQUFJO1lBQ1osS0FBSyxFQUFFO2dCQUNMLEdBQUcsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLElBQUksRUFBRSxDQUFDLENBQUMsR0FBRyxDQUNyQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsaUNBQWlDLFFBQVEsQ0FBQyxJQUFJLElBQUksQ0FDakU7Z0JBQ0QsRUFBRTthQUNIO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxpQkFBUSxDQUFDLElBQUksRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLGFBQWEsRUFBRTtZQUM5QyxTQUFTLEVBQUUsSUFBSTtZQUNmLEdBQUcsRUFBRTtnQkFDSCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIsR0FBRyxFQUFFLHNCQUFzQjtnQkFDM0Isa0JBQWtCLEVBQUUsT0FBTyxDQUFDLGtCQUFrQixJQUFJLEVBQUU7Z0JBQ3BELGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxnQkFBZ0I7Z0JBQzFDLFNBQVMsRUFDUCxPQUFPLENBQUMsU0FBUztvQkFDakIsdURBQXVEO2FBQzFEO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7O0FBeEVILDBDQXlFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEpzb25GaWxlLCBTYW1wbGVEaXIsIFRleHRGaWxlIH0gZnJvbSBcInByb2plblwiO1xuaW1wb3J0IHsgQ29uc3RydWN0TGlicmFyeSwgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMgfSBmcm9tIFwicHJvamVuL2xpYi9jZGtcIjtcblxuaW1wb3J0IHsgZGVmYXVsdHMgfSBmcm9tIFwiLi9kZWZhdWx0c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50IHtcbiAgLy8gbmFtZSBvZiB0aGUgbW9kdWxlXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLy8gcGF0aCAvIHVybCAvIHJlZ2lzdHJ5IGlkZW50aWZpZXIgZm9yIHRoZSBtb2R1bGVcbiAgcmVhZG9ubHkgc291cmNlOiBzdHJpbmc7XG4gIC8vIHZlcnNpb24gY29uc3RyYWludCAoaHR0cHM6Ly93d3cudGVycmFmb3JtLmlvL2RvY3MvbGFuZ3VhZ2UvcHJvdmlkZXJzL3JlcXVpcmVtZW50cy5odG1sI3ZlcnNpb24tY29uc3RyYWludHMpXG4gIHJlYWRvbmx5IHZlcnNpb246IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zIGV4dGVuZHMgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMge1xuICAvKipcbiAgICogTWluaW11bSB0YXJnZXQgdmVyc2lvbiBvZiB0aGlzIGxpYnJhcnkuXG4gICAqIEBkZWZhdWx0IFwiXjAuMTMuMFwiXG4gICAqIEBmZWF0dXJlZFxuICAgKi9cbiAgcmVhZG9ubHkgY2RrdGZWZXJzaW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBDb25zdHJ1Y3QgdmVyc2lvbiB0byB1c2VcbiAgICogQGRlZmF1bHQgXCJeMTAuMC4xMlwiXG4gICAqL1xuICByZWFkb25seSBjb25zdHJ1Y3RWZXJzaW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiAgTGlzdCBvZiBwcm92aWRlciBiaW5kaW5ncyB0byBnZW5lcmF0ZSBpbiBhZGRpdGlvbiB0byB0aGUgbW9kdWxlcy5cbiAgICovXG4gIHJlYWRvbmx5IHRlcnJhZm9ybVByb3ZpZGVycz86IFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50W107XG5cbiAgLyoqXG4gICAqIExpc3Qgb2YgbW9kdWxlcyB0byBnZW5lcmF0ZSBiaW5kaW5ncyBmb3IuXG4gICAqIEBmZWF0dXJlZFxuICAgKi9cbiAgcmVhZG9ubHkgdGVycmFmb3JtTW9kdWxlczogVGVycmFmb3JtVmVyc2lvbkNvbnN0cmFpbnRbXTtcblxuICAvLyBEZWZhdWx0ZWQgdG8gYSB1dWlkIHN0cmluZyBhcyBjZGt0ZiB3b3VsZFxuICByZWFkb25seSBwcm9qZWN0SWQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogVGVycmFmb3JtIE1vZHVsZXMgcmVwdWJsaXNoZWQgYXMgQ0RLVEYgQ29uc3RydWN0c1xuICpcbiAqIEBwamlkIHRlcnJhZm9ybS1tb2R1bGVcbiAqL1xuZXhwb3J0IGNsYXNzIFRlcnJhZm9ybU1vZHVsZSBleHRlbmRzIENvbnN0cnVjdExpYnJhcnkge1xuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zKSB7XG4gICAgc3VwZXIoe1xuICAgICAgLi4uZGVmYXVsdHMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgICAgZXNsaW50T3B0aW9uczogT2JqZWN0LmFzc2lnbih7fSwgb3B0aW9ucy5lc2xpbnRPcHRpb25zLCB7XG4gICAgICAgIGxpbnRQcm9qZW5SYzogZmFsc2UsXG4gICAgICB9KSxcbiAgICAgIHBvc3RCdWlsZFN0ZXBzOiBbXSxcbiAgICB9KTtcbiAgICBjb25zdCBjb25zdHJ1Y3RWZXJzaW9uID0gb3B0aW9ucy5jb25zdHJ1Y3RWZXJzaW9uIHx8IFwiMTAuMC4xMDdcIjtcbiAgICBjb25zdCBjZGt0ZlZlcnNpb24gPSBvcHRpb25zLmNka3RmVmVyc2lvbiB8fCBcIjAuMTMuMFwiO1xuXG4gICAgY29uc3QgY29uc3RydWN0U3JjQ29kZSA9IGBcbi8vIFJlLUV4cG9ydCBtb2R1bGUgYmluZGluZ3NcbmV4cG9ydCAqIGZyb20gXCIuL3RlcnJhZm9ybU1vZHVsZXNcIjtcblxuLy8gQWRkIHlvdXIgY3VzdG9tIGNvbnN0cnVjdHMgaGVyZVxuYDtcblxuICAgIGNvbnN0IGNvbnN0cnVjdFRlc3RDb2RlID0gYFxuLy8gaW1wb3J0IHsgVGVzdGluZyB9IGZyb20gXCJjZGt0ZlwiO1xuLy8gaW1wb3J0IFwiY2RrdGYvbGliL3Rlc3RpbmcvYWRhcHRlcnMvamVzdFwiO1xuXG4vLyBUbyBsZWFybiBtb3JlIGFib3V0IHRlc3Rpbmcgc2VlIGNkay50Zi90ZXN0aW5nXG5kZXNjcmliZShcIk15TW9kdWxlXCIsICgpID0+IHtcbiAgaXQudG9kbyhcInNob3VsZCBiZSB0ZXN0ZWRcIilcbn0pO1xuYDtcblxuICAgIHRoaXMuYWRkUGVlckRlcHMoXG4gICAgICBgY29uc3RydWN0c0A+PSR7Y29uc3RydWN0VmVyc2lvbn1gLFxuICAgICAgYGNka3RmQD49JHtjZGt0ZlZlcnNpb259YFxuICAgICk7XG4gICAgdGhpcy5hZGREZXZEZXBzKFxuICAgICAgYGNka3RmQCR7Y2RrdGZWZXJzaW9ufWAsXG4gICAgICBgY2RrdGYtY2xpQCR7Y2RrdGZWZXJzaW9ufWAsXG4gICAgICBcInRzLW5vZGVAPj0xMC45LjFcIlxuICAgICk7XG4gICAgdGhpcy5hZGRLZXl3b3JkcyhcImNka3RmXCIsIFwiY2RrdGYtaHlicmlkXCIpO1xuXG4gICAgbmV3IFNhbXBsZURpcih0aGlzLCB0aGlzLnNyY2Rpciwge1xuICAgICAgZmlsZXM6IHtcbiAgICAgICAgXCJpbmRleC50c1wiOiBjb25zdHJ1Y3RTcmNDb2RlLnRyaW0oKSxcbiAgICAgICAgXCJfX3Rlc3RzX18vaW5kZXgtdGVzdC50c1wiOiBjb25zdHJ1Y3RUZXN0Q29kZS50cmltKCksXG4gICAgICB9LFxuICAgIH0pO1xuICAgIG5ldyBUZXh0RmlsZSh0aGlzLCBgJHt0aGlzLnNyY2Rpcn0vdGVycmFmb3JtTW9kdWxlcy50c2AsIHtcbiAgICAgIGNvbW1pdHRlZDogdHJ1ZSxcbiAgICAgIG1hcmtlcjogdHJ1ZSxcbiAgICAgIGxpbmVzOiBbXG4gICAgICAgIC4uLihvcHRpb25zLnRlcnJhZm9ybU1vZHVsZXMgfHwgW10pLm1hcChcbiAgICAgICAgICAodGZNb2R1bGUpID0+IGBleHBvcnQgKiBmcm9tIFwiLi8uZ2VuL21vZHVsZXMvJHt0Zk1vZHVsZS5uYW1lfVwiO2BcbiAgICAgICAgKSxcbiAgICAgICAgXCJcIixcbiAgICAgIF0sXG4gICAgfSk7XG5cbiAgICBuZXcgSnNvbkZpbGUodGhpcywgYCR7dGhpcy5zcmNkaXJ9L2Nka3RmLmpzb25gLCB7XG4gICAgICBjb21taXR0ZWQ6IHRydWUsXG4gICAgICBvYmo6IHtcbiAgICAgICAgbGFuZ3VhZ2U6IFwidHlwZXNjcmlwdFwiLFxuICAgICAgICBhcHA6IFwibnB4IHRzLW5vZGUgaW5kZXgudHNcIixcbiAgICAgICAgdGVycmFmb3JtUHJvdmlkZXJzOiBvcHRpb25zLnRlcnJhZm9ybVByb3ZpZGVycyB8fCBbXSxcbiAgICAgICAgdGVycmFmb3JtTW9kdWxlczogb3B0aW9ucy50ZXJyYWZvcm1Nb2R1bGVzLFxuICAgICAgICBwcm9qZWN0SWQ6XG4gICAgICAgICAgb3B0aW9ucy5wcm9qZWN0SWQgfHxcbiAgICAgICAgICBcInRlcnJhZm9ybS1tb2R1bGUtOTlhNzcwYTctM2VjNS00MGY3LThjZDMtZGJjNzJmNzVhMDBhXCIsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgdGhpcy5wcmVDb21waWxlVGFzay5leGVjKGBucHggY2RrdGYgZ2V0YCwgeyBjd2Q6IHRoaXMuc3JjZGlyIH0pO1xuICB9XG59XG4iXX0=
package/package.json CHANGED
@@ -26,7 +26,6 @@
26
26
  "pre-compile": "npx projen pre-compile",
27
27
  "release": "npx projen release",
28
28
  "test": "npx projen test",
29
- "test:update": "npx projen test:update",
30
29
  "test:watch": "npx projen test:watch",
31
30
  "unbump": "npx projen unbump",
32
31
  "upgrade": "npx projen upgrade",
@@ -42,7 +41,7 @@
42
41
  "@types/change-case": "^2.3.1",
43
42
  "@types/fs-extra": "^9.0.13",
44
43
  "@types/glob": "^7.2.0",
45
- "@types/jest": "^27.5.1",
44
+ "@types/jest": "^27",
46
45
  "@types/node": "^14",
47
46
  "@typescript-eslint/eslint-plugin": "^5",
48
47
  "@typescript-eslint/parser": "^5",
@@ -51,26 +50,26 @@
51
50
  "eslint-import-resolver-node": "^0.3.6",
52
51
  "eslint-import-resolver-typescript": "^2.7.1",
53
52
  "eslint-plugin-import": "^2.26.0",
54
- "eslint-plugin-prettier": "^4.0.0",
53
+ "eslint-plugin-prettier": "^4.2.1",
55
54
  "fs-extra": "^10.1.0",
56
- "glob": "^7.2.0",
55
+ "glob": "^7.2.3",
57
56
  "jest": "^27",
58
57
  "jest-junit": "^13",
59
- "jsii": "^1.58.0",
60
- "jsii-diff": "^1.58.0",
61
- "jsii-docgen": "^7.0.7",
62
- "jsii-pacmak": "^1.58.0",
58
+ "jsii": "^1.63.2",
59
+ "jsii-diff": "^1.63.2",
60
+ "jsii-docgen": "^7.0.63",
61
+ "jsii-pacmak": "^1.63.2",
63
62
  "json-schema": "^0.4.0",
64
- "npm-check-updates": "^12",
65
- "prettier": "^2.6.2",
66
- "projen": "0.56.2",
63
+ "npm-check-updates": "^16",
64
+ "prettier": "^2.7.1",
65
+ "projen": "0.63.25",
67
66
  "standard-version": "^9",
68
67
  "ts-jest": "^27",
69
- "ts-node": "^9",
70
- "typescript": "^4.6.4"
68
+ "ts-node": "10.9.1",
69
+ "typescript": "^4.7.4"
71
70
  },
72
71
  "peerDependencies": {
73
- "projen": ">= 0.56.2"
72
+ "projen": ">= 0.63.25"
74
73
  },
75
74
  "dependencies": {
76
75
  "change-case": "^4.1.2"
@@ -80,11 +79,11 @@
80
79
  ],
81
80
  "main": "lib/index.js",
82
81
  "license": "MIT",
83
- "version": "0.1.70",
82
+ "version": "0.2.0",
84
83
  "jest": {
85
84
  "testMatch": [
86
85
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",
87
- "<rootDir>/(test|src)/**/?(*.)+(spec|test).ts?(x)"
86
+ "<rootDir>/(test|src)/**/*(*.)@(spec|test).ts?(x)"
88
87
  ],
89
88
  "clearMocks": true,
90
89
  "collectCoverage": true,
@@ -131,5 +130,10 @@
131
130
  "rootDir": "src"
132
131
  }
133
132
  },
133
+ "resolutions": {
134
+ "@types/responselike": "1.0.0",
135
+ "got": "12.3.1",
136
+ "@types/prettier": "2.6.0"
137
+ },
134
138
  "//": "~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\"."
135
- }
139
+ }
package/releasetag.txt DELETED
@@ -1 +0,0 @@
1
- v0.1.70
package/version.txt DELETED
@@ -1 +0,0 @@
1
- 0.1.70