projen-cdktf-hybrid-construct 0.1.55 → 0.1.58

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -70,7 +70,7 @@
70
70
  },
71
71
  "name": "projen-cdktf-hybrid-construct",
72
72
  "readme": {
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.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### Roadmap\n\n- [x] Add dedicated file for HCL templates\n- [x] Add example folder\n- [x] Add `terraform` example folder\n- [x] [Auto-generate parts of the docs](https://github.com/terraform-aws-modules/terraform-aws-eks/blob/e90c877a741ab3cc4215376a70f7bcc360b6a3d2/.github/workflows/pre-commit.yml)\n- [x] Add example folder to project using this\n- [x] Add testing strategy\n- [x] Add construct / option / docs to publish existing module as construct\n- [x] Add deployment scripts to Github Packages\n- [ ] Add deployment scripts to Artifactory\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.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"
74
74
  },
75
75
  "repository": {
76
76
  "type": "git",
@@ -569,6 +569,6 @@
569
569
  "symbolId": "src/terraform-module:TerraformVersionConstraint"
570
570
  }
571
571
  },
572
- "version": "0.1.55",
573
- "fingerprint": "iQUpIupZYykqny2J6ugHQ6QQAOyVVqJrjR5H3pWcJL8="
572
+ "version": "0.1.58",
573
+ "fingerprint": "8gP7LdvhG/FLHH/4yr9gBFuGgfZkBYcs9Kexo0ghxAk="
574
574
  }
package/CHANGELOG.md CHANGED
@@ -1,2 +1,7 @@
1
1
 
2
- ### [0.1.55](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/compare/v0.1.54...v0.1.55) (2022-05-05)
2
+ ### [0.1.58](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/compare/v0.1.57...v0.1.58) (2022-05-06)
3
+
4
+
5
+ ### Bug Fixes
6
+
7
+ * use levels for tsconfig reference ([#60](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/issues/60)) ([e83b0c7](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/commit/e83b0c7ce7737fedc8f82920fd1de000a310b804))
package/README.md CHANGED
@@ -211,14 +211,39 @@ const project = new HybridModule({
211
211
  });
212
212
  ```
213
213
 
214
- ### Roadmap
215
-
216
- - [x] Add dedicated file for HCL templates
217
- - [x] Add example folder
218
- - [x] Add `terraform` example folder
219
- - [x] [Auto-generate parts of the docs](https://github.com/terraform-aws-modules/terraform-aws-eks/blob/e90c877a741ab3cc4215376a70f7bcc360b6a3d2/.github/workflows/pre-commit.yml)
220
- - [x] Add example folder to project using this
221
- - [x] Add testing strategy
222
- - [x] Add construct / option / docs to publish existing module as construct
223
- - [x] Add deployment scripts to Github Packages
224
- - [ ] Add deployment scripts to Artifactory
214
+ ### Artifactory
215
+
216
+ We have a helper method for easy configuration, but there are also some manual steps required.
217
+
218
+ ```js
219
+ const {
220
+ HybridModule,
221
+ publishToGithubPackages,
222
+ } = require("projen-cdktf-hybrid-construct");
223
+
224
+ const project = new HybridModule({
225
+ // ... all the other options
226
+ ...publishToGithubPackages({
227
+ name: "my-new-hybrid-construct",
228
+ namespace: "my-org",
229
+ registries: ["npm", "pypi", "nuget"], // maven is currently not supported, PRs welcome
230
+ artifactoryApiUrl: "https://artifactory.my-org.com/api/",
231
+ artifactoryRepository: "my-repo", // needs to be the same across all registries, defaults to namespace so "my-org" in this case
232
+ }),
233
+ });
234
+ ```
235
+
236
+ #### Terraform
237
+
238
+ You can find more information about publishing Terraform Modules to Artifactory [here](https://www.jfrog.com/confluence/display/JFROG/Terraform+Registry#TerraformRegistry-SettingupaLocalModule/ProviderRegistry).
239
+
240
+ #### npm (Typescript)
241
+
242
+ 1. [Create a virtual npm registry](https://www.jfrog.com/confluence/display/JFROG/npm+Registry#npmRegistry-VirtualnpmRegistry)
243
+ 2. [Authenticate against artifactory to get a token](https://www.jfrog.com/confluence/display/JFROG/npm+Registry#npmRegistry-AuthenticatingthenpmClient)
244
+ 3. 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
245
+
246
+ #### pypi (Python)
247
+
248
+ 1. Create a [local repository](https://www.jfrog.com/confluence/display/JFROG/PyPI+Repositories#PyPIRepositories-LocalRepositories)
249
+ 2. 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
@@ -214,7 +214,7 @@ app.synth();
214
214
  "basic.ts": constructExampleCode.trim(),
215
215
  "cdktf.json": JSON.stringify({
216
216
  language: "typescript",
217
- app: "npx ts-node --project ../tsconfig.dev.json index.ts",
217
+ app: `npx ts-node --project ${levels}/tsconfig.dev.json index.ts`,
218
218
  projectId: options.projectId || uuid_1.v4(),
219
219
  }, null, 2),
220
220
  "README.md": constructReadmeDocs.trim(),
@@ -304,5 +304,5 @@ terraform -chdir=terraform plan
304
304
  }
305
305
  exports.HybridModule = HybridModule;
306
306
  _a = JSII_RTTI_SYMBOL_1;
307
- HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.1.55" };
308
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hybrid-module.js","sourceRoot":"","sources":["../src/hybrid-module.ts"],"names":[],"mappings":";;;;;AAAA,mCAAiE;AACjE,wCAAsE;AACtE,+BAAkC;AAClC,yCAAsC;AAsDtC,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,IAAY,EAAU,OAAe;QACjE,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE;YACnB,UAAU,EAAE,IAAI;SACjB,CAAC,CAAC;QAH+C,YAAO,GAAP,OAAO,CAAQ;IAInE,CAAC;IAES,iBAAiB,CAAC,CAAY;QACtC,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,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,EAAE,OAAO,CAAC,SAAS,IAAI,SAAI,EAAE;iBACvC,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,EAAE;;EAEnB,cAAc;;aAEH,CAAC,SAAS,EAAE;oBACf,WAAW,EAAE,mBAAmB,CAAC,IAAI,EAAE;iBACxC;aACF,CAAC,CAAC;YAEH,IAAI,CAAC,SAAS,CAAC,WAAW,CACxB,GAAG,cAAc,aAAa,EAC9B,GAAG,cAAc,sBAAsB,CACxC,CAAC;SACH;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,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,qDAAqD;wBAC1D,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,SAAI,EAAE;qBACvC,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;QAEpC,IAAI,UAAU,CACZ,IAAI,EACJ,6BAA6B,EAC7B;;;;;;;;;SASG,CACJ,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;QAClD,MAAA,IAAI,CAAC,IAAI,0CAAE,gBAAgB,CAAC,WAAW,EAAE;IAC3C,CAAC;;AAjQH,oCAkQC","sourcesContent":["import { FileBase, IResolver, Project, SampleDir } from \"projen\";\nimport { JsiiProject, ConstructLibraryOptions } from \"projen/lib/cdk\";\nimport { v4 as uuid } from \"uuid\";\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}\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\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, path: string, private content: string) {\n    super(project, path, {\n      executable: true,\n    });\n  }\n\n  protected synthesizeContent(_: IResolver): string | undefined {\n    return this.content;\n  }\n}\n\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: options.projectId || uuid(),\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# Configure Terraform\n${providerConfig}\n\n            `.trimStart(),\n          \"README.md\": terraformReadmeDocs.trim(),\n        },\n      });\n\n      this.gitignore.addPatterns(\n        `${examplesFolder}/.terraform`,\n        `${examplesFolder}/.terraform.lock.hcl`\n      );\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        .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 ../tsconfig.dev.json index.ts\",\n              projectId: options.projectId || uuid(),\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    new ScriptFile(\n      this,\n      \"./scripts/tf-module-test.sh\",\n      `\n#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nterraform -chdir=terraform init --upgrade\nterraform -chdir=terraform fmt\nterraform -chdir=terraform validate\nterraform -chdir=terraform plan     \n        `\n    );\n\n    this.testTask.exec(\"./scripts/tf-module-test.sh\");\n    this.jest?.addIgnorePattern(\"terraform\");\n  }\n}\n"]}
307
+ HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.1.58" };
308
+ //# 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 { FileBase, IResolver, Project, SampleDir } from \"projen\";\nimport { JsiiProject, ConstructLibraryOptions } from \"projen/lib/cdk\";\nimport { v4 as uuid } from \"uuid\";\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}\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\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, path: string, private content: string) {\n    super(project, path, {\n      executable: true,\n    });\n  }\n\n  protected synthesizeContent(_: IResolver): string | undefined {\n    return this.content;\n  }\n}\n\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: options.projectId || uuid(),\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# Configure Terraform\n${providerConfig}\n\n            `.trimStart(),\n          \"README.md\": terraformReadmeDocs.trim(),\n        },\n      });\n\n      this.gitignore.addPatterns(\n        `${examplesFolder}/.terraform`,\n        `${examplesFolder}/.terraform.lock.hcl`\n      );\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        .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: options.projectId || uuid(),\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    new ScriptFile(\n      this,\n      \"./scripts/tf-module-test.sh\",\n      `\n#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nterraform -chdir=terraform init --upgrade\nterraform -chdir=terraform fmt\nterraform -chdir=terraform validate\nterraform -chdir=terraform plan     \n        `\n    );\n\n    this.testTask.exec(\"./scripts/tf-module-test.sh\");\n    this.jest?.addIgnorePattern(\"terraform\");\n  }\n}\n"]}
@@ -12,4 +12,9 @@ declare type Mutable<T> = T extends AtomicObject ? T : T extends ReadonlyMap<inf
12
12
  declare type Config = Mutable<Pick<ConstructLibraryOptions, "publishToPypi" | "publishToMaven" | "publishToNuget" | "releaseToNpm" | "npmRegistryUrl">>;
13
13
  export declare function publishToRegistries(options: PublishOptions): Config;
14
14
  export declare function publishToGithubPackages(options: PublishOptions): Config;
15
+ export declare type ArtifactoryPublishOptions = PublishOptions & {
16
+ artifactoryApiUrl: string;
17
+ artifactoryRepository?: string;
18
+ };
19
+ export declare function publishToArtifactory(options: ArtifactoryPublishOptions): Config;
15
20
  export {};
package/lib/publishing.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.publishToGithubPackages = exports.publishToRegistries = void 0;
3
+ exports.publishToArtifactory = exports.publishToGithubPackages = exports.publishToRegistries = void 0;
4
4
  const change_case_1 = require("change-case");
5
5
  function publishToRegistries(options) {
6
6
  const { name, namespace, registries } = options;
@@ -51,4 +51,26 @@ function publishToGithubPackages(options) {
51
51
  return config;
52
52
  }
53
53
  exports.publishToGithubPackages = publishToGithubPackages;
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGlzaGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9wdWJsaXNoaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUF5QztBQXlDekMsU0FBZ0IsbUJBQW1CLENBQUMsT0FBdUI7SUFDekQsTUFBTSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLEdBQUcsT0FBTyxDQUFDO0lBQ2hELE1BQU0sa0JBQWtCLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDekQsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDL0MsTUFBTSxNQUFNLEdBQVc7UUFDckIsWUFBWSxFQUFFLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO0tBQ3pDLENBQUM7SUFFRixJQUFJLFVBQVUsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDL0IsTUFBTSxDQUFDLGFBQWEsR0FBRztZQUNyQixRQUFRLEVBQUUsR0FBRyxrQkFBa0IsSUFBSSxhQUFhLEVBQUU7WUFDbEQsTUFBTSxFQUFFLEdBQUcsa0JBQWtCLElBQUksYUFBYSxFQUFFO1NBQ2pELENBQUM7S0FDSDtJQUVELElBQUksVUFBVSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUNoQyxNQUFNLENBQUMsY0FBYyxHQUFHO1lBQ3RCLFdBQVcsRUFBRSxPQUFPLGtCQUFrQixJQUFJLGFBQWEsRUFBRTtZQUN6RCxZQUFZLEVBQUUsT0FBTyxrQkFBa0IsRUFBRTtZQUN6QyxlQUFlLEVBQUUsYUFBYTtTQUMvQixDQUFDO0tBQ0g7SUFFRCxJQUFJLFVBQVUsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDaEMsTUFBTSxTQUFTLEdBQUcsR0FBRyx3QkFBVSxDQUFDLFNBQVMsQ0FBQyxJQUFJLHdCQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUNqRSxNQUFNLENBQUMsY0FBYyxHQUFHO1lBQ3RCLGVBQWUsRUFBRSxTQUFTO1lBQzFCLFNBQVMsRUFBRSxTQUFTO1NBQ3JCLENBQUM7S0FDSDtJQUNELE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUEvQkQsa0RBK0JDO0FBRUQsU0FBZ0IsdUJBQXVCLENBQUMsT0FBdUI7SUFDN0QsTUFBTSxFQUFFLFVBQVUsRUFBRSxHQUFHLE9BQU8sQ0FBQztJQUMvQixNQUFNLE1BQU0sR0FBRyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM1QyxJQUFJLFVBQVUsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDL0IsTUFBTSxJQUFJLEtBQUssQ0FBQyxrREFBa0QsQ0FBQyxDQUFDO0tBQ3JFO0lBQ0QsSUFBSSxVQUFVLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQ2hDLGdMQUFnTDtRQUNoTCxNQUFNLElBQUksS0FBSyxDQUNiLHVGQUF1RixDQUN4RixDQUFDO0tBQ0g7SUFFRCxJQUFJLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDOUIsTUFBTSxDQUFDLGNBQWMsR0FBRyw0QkFBNEIsQ0FBQztLQUN0RDtJQUVELElBQUksVUFBVSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUNoQyxNQUFNLENBQUMsY0FBZSxDQUFDLGtCQUFrQixHQUFHLDhCQUE4QixDQUFDO0tBQzVFO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQXRCRCwwREFzQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBwYXNjYWxDYXNlIH0gZnJvbSBcImNoYW5nZS1jYXNlXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3RMaWJyYXJ5T3B0aW9ucyB9IGZyb20gXCJwcm9qZW4vbGliL2Nka1wiO1xuXG5leHBvcnQgdHlwZSBSZWdpc3RyeSA9IFwibnBtXCIgfCBcIm1hdmVuXCIgfCBcIm51Z2V0XCIgfCBcInB5cGlcIjtcblxuZXhwb3J0IHR5cGUgUHVibGlzaE9wdGlvbnMgPSB7XG4gIG5hbWU6IHN0cmluZztcbiAgbmFtZXNwYWNlOiBzdHJpbmc7XG4gIHJlZ2lzdHJpZXM6IFJlZ2lzdHJ5W107XG59O1xuXG50eXBlIEF0b21pY09iamVjdCA9XG4gIHwgRnVuY3Rpb25cbiAgfCBQcm9taXNlPGFueT5cbiAgfCBEYXRlXG4gIHwgUmVnRXhwXG4gIHwgQm9vbGVhblxuICB8IE51bWJlclxuICB8IFN0cmluZztcblxudHlwZSBNdXRhYmxlPFQ+ID0gVCBleHRlbmRzIEF0b21pY09iamVjdFxuICA/IFRcbiAgOiBUIGV4dGVuZHMgUmVhZG9ubHlNYXA8aW5mZXIgSywgaW5mZXIgVj4gLy8gTWFwIGV4dGVuZHMgUmVhZG9ubHlNYXBcbiAgPyBNYXA8TXV0YWJsZTxLPiwgTXV0YWJsZTxWPj5cbiAgOiBUIGV4dGVuZHMgUmVhZG9ubHlTZXQ8aW5mZXIgVj4gLy8gU2V0IGV4dGVuZHMgUmVhZG9ubHlTZXRcbiAgPyBTZXQ8TXV0YWJsZTxWPj5cbiAgOiBUIGV4dGVuZHMgb2JqZWN0XG4gID8geyAtcmVhZG9ubHkgW0sgaW4ga2V5b2YgVF06IE11dGFibGU8VFtLXT4gfVxuICA6IFQ7XG5cbnR5cGUgQ29uZmlnID0gTXV0YWJsZTxcbiAgUGljazxcbiAgICBDb25zdHJ1Y3RMaWJyYXJ5T3B0aW9ucyxcbiAgICB8IFwicHVibGlzaFRvUHlwaVwiXG4gICAgfCBcInB1Ymxpc2hUb01hdmVuXCJcbiAgICB8IFwicHVibGlzaFRvTnVnZXRcIlxuICAgIHwgXCJyZWxlYXNlVG9OcG1cIlxuICAgIHwgXCJucG1SZWdpc3RyeVVybFwiXG4gID5cbj47XG5cbmV4cG9ydCBmdW5jdGlvbiBwdWJsaXNoVG9SZWdpc3RyaWVzKG9wdGlvbnM6IFB1Ymxpc2hPcHRpb25zKTogQ29uZmlnIHtcbiAgY29uc3QgeyBuYW1lLCBuYW1lc3BhY2UsIHJlZ2lzdHJpZXMgfSA9IG9wdGlvbnM7XG4gIGNvbnN0IHNhbml0aXplZE5hbWVzcGFjZSA9IG5hbWVzcGFjZS5yZXBsYWNlKC8tL2dpLCBcIl9cIik7XG4gIGNvbnN0IHNhbml0aXplZE5hbWUgPSBuYW1lLnJlcGxhY2UoLy0vZ2ksIFwiX1wiKTtcbiAgY29uc3QgY29uZmlnOiBDb25maWcgPSB7XG4gICAgcmVsZWFzZVRvTnBtOiByZWdpc3RyaWVzLmluY2x1ZGVzKFwibnBtXCIpLFxuICB9O1xuXG4gIGlmIChyZWdpc3RyaWVzLmluY2x1ZGVzKFwicHlwaVwiKSkge1xuICAgIGNvbmZpZy5wdWJsaXNoVG9QeXBpID0ge1xuICAgICAgZGlzdE5hbWU6IGAke3Nhbml0aXplZE5hbWVzcGFjZX0tJHtzYW5pdGl6ZWROYW1lfWAsXG4gICAgICBtb2R1bGU6IGAke3Nhbml0aXplZE5hbWVzcGFjZX1fJHtzYW5pdGl6ZWROYW1lfWAsXG4gICAgfTtcbiAgfVxuXG4gIGlmIChyZWdpc3RyaWVzLmluY2x1ZGVzKFwibWF2ZW5cIikpIHtcbiAgICBjb25maWcucHVibGlzaFRvTWF2ZW4gPSB7XG4gICAgICBqYXZhUGFja2FnZTogYGNvbS4ke3Nhbml0aXplZE5hbWVzcGFjZX0uJHtzYW5pdGl6ZWROYW1lfWAsXG4gICAgICBtYXZlbkdyb3VwSWQ6IGBjb20uJHtzYW5pdGl6ZWROYW1lc3BhY2V9YCxcbiAgICAgIG1hdmVuQXJ0aWZhY3RJZDogc2FuaXRpemVkTmFtZSxcbiAgICB9O1xuICB9XG5cbiAgaWYgKHJlZ2lzdHJpZXMuaW5jbHVkZXMoXCJudWdldFwiKSkge1xuICAgIGNvbnN0IG51Z2V0TmFtZSA9IGAke3Bhc2NhbENhc2UobmFtZXNwYWNlKX0uJHtwYXNjYWxDYXNlKG5hbWUpfWA7XG4gICAgY29uZmlnLnB1Ymxpc2hUb051Z2V0ID0ge1xuICAgICAgZG90TmV0TmFtZXNwYWNlOiBudWdldE5hbWUsXG4gICAgICBwYWNrYWdlSWQ6IG51Z2V0TmFtZSxcbiAgICB9O1xuICB9XG4gIHJldHVybiBjb25maWc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBwdWJsaXNoVG9HaXRodWJQYWNrYWdlcyhvcHRpb25zOiBQdWJsaXNoT3B0aW9ucyk6IENvbmZpZyB7XG4gIGNvbnN0IHsgcmVnaXN0cmllcyB9ID0gb3B0aW9ucztcbiAgY29uc3QgY29uZmlnID0gcHVibGlzaFRvUmVnaXN0cmllcyhvcHRpb25zKTtcbiAgaWYgKHJlZ2lzdHJpZXMuaW5jbHVkZXMoXCJweXBpXCIpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiR2l0aHViIFBhY2thZ2VzIGRvZXMgbm90IHN1cHBvcnQgcHl0aG9uIHBhY2thZ2VzXCIpO1xuICB9XG4gIGlmIChyZWdpc3RyaWVzLmluY2x1ZGVzKFwibnVnZXRcIikpIHtcbiAgICAvLyBTZWVtcyBsaWtlIHByb2plbiBkb2VzIG5vdCBzdXBwb3J0IGdpdGh1YiBwYWNrYWdlcyBvbiBudWdldCB5ZXQ6IGh0dHBzOi8vZ2l0aHViLmRldi9wcm9qZW4vcHJvamVuL2Jsb2IvMTRmMzdlYzcwNGFmZGM1MTQzZTZhMjk1NGMxMjUwYjFmMGNjYWRkZi9zcmMvcmVsZWFzZS9wdWJsaXNoZXIudHMjTDM0M1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiR2l0aHViIFBhY2thZ2VzIGRvZXMgc3VwcG9ydCBudWdldCBwYWNrYWdlcywgYnV0IHRoaXMgbGlicmFyeSBkb2VzIG5vdCB5ZXQgc3VwcG9ydCBpdFwiXG4gICAgKTtcbiAgfVxuXG4gIGlmIChyZWdpc3RyaWVzLmluY2x1ZGVzKFwibnBtXCIpKSB7XG4gICAgY29uZmlnLm5wbVJlZ2lzdHJ5VXJsID0gXCJodHRwczovL25wbS5wa2cuZ2l0aHViLmNvbVwiO1xuICB9XG5cbiAgaWYgKHJlZ2lzdHJpZXMuaW5jbHVkZXMoXCJtYXZlblwiKSkge1xuICAgIGNvbmZpZy5wdWJsaXNoVG9NYXZlbiEubWF2ZW5SZXBvc2l0b3J5VXJsID0gXCJodHRwczovL21hdmVuLnBrZy5naXRodWIuY29tXCI7XG4gIH1cblxuICByZXR1cm4gY29uZmlnO1xufVxuIl19
54
+ function publishToArtifactory(options) {
55
+ const { registries, artifactoryApiUrl, artifactoryRepository = options.namespace, } = options;
56
+ const config = publishToRegistries(options);
57
+ if (registries.includes("npm")) {
58
+ config.npmRegistryUrl = `${artifactoryApiUrl}/npm/${artifactoryRepository}/`;
59
+ }
60
+ if (registries.includes("pypi")) {
61
+ config.publishToPypi.twineRegistryUrl = `${artifactoryApiUrl}/pypi/${artifactoryRepository}/`;
62
+ }
63
+ if (registries.includes("maven")) {
64
+ throw new Error("Artifactory does support maven packages, but this library does not yet support it");
65
+ // With no chance to test it the docs dont tell me enough to implement it
66
+ // https://www.jfrog.com/confluence/display/JFROG/Maven+Repository#MavenRepository-ResolvingArtifactsThroughArtifactory
67
+ // config.publishToMaven!.mavenRepositoryUrl = `${artifactoryApiUrl}/`;
68
+ }
69
+ if (registries.includes("nuget")) {
70
+ // Seems like projen does not support artifactory on nuget yet: https://github.dev/projen/projen/blob/14f37ec704afdc5143e6a2954c1250b1f0ccaddf/src/release/publisher.ts#L343
71
+ throw new Error("Artifactory does support nuget packages, but this library does not yet support it");
72
+ }
73
+ return config;
74
+ }
75
+ exports.publishToArtifactory = publishToArtifactory;
76
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["../src/publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import { pascalCase } from \"change-case\";\nimport { ConstructLibraryOptions } from \"projen/lib/cdk\";\n\nexport type Registry = \"npm\" | \"maven\" | \"nuget\" | \"pypi\";\n\nexport type PublishOptions = {\n  name: string;\n  namespace: string;\n  registries: Registry[];\n};\n\ntype AtomicObject =\n  | Function\n  | Promise<any>\n  | Date\n  | RegExp\n  | Boolean\n  | Number\n  | String;\n\ntype Mutable<T> = T extends AtomicObject\n  ? T\n  : T extends ReadonlyMap<infer K, infer V> // Map extends ReadonlyMap\n  ? Map<Mutable<K>, Mutable<V>>\n  : T extends ReadonlySet<infer V> // Set extends ReadonlySet\n  ? Set<Mutable<V>>\n  : T extends object\n  ? { -readonly [K in keyof T]: Mutable<T[K]> }\n  : T;\n\ntype Config = Mutable<\n  Pick<\n    ConstructLibraryOptions,\n    | \"publishToPypi\"\n    | \"publishToMaven\"\n    | \"publishToNuget\"\n    | \"releaseToNpm\"\n    | \"npmRegistryUrl\"\n  >\n>;\n\nexport function publishToRegistries(options: PublishOptions): Config {\n  const { name, namespace, registries } = options;\n  const sanitizedNamespace = namespace.replace(/-/gi, \"_\");\n  const sanitizedName = name.replace(/-/gi, \"_\");\n  const config: Config = {\n    releaseToNpm: registries.includes(\"npm\"),\n  };\n\n  if (registries.includes(\"pypi\")) {\n    config.publishToPypi = {\n      distName: `${sanitizedNamespace}-${sanitizedName}`,\n      module: `${sanitizedNamespace}_${sanitizedName}`,\n    };\n  }\n\n  if (registries.includes(\"maven\")) {\n    config.publishToMaven = {\n      javaPackage: `com.${sanitizedNamespace}.${sanitizedName}`,\n      mavenGroupId: `com.${sanitizedNamespace}`,\n      mavenArtifactId: sanitizedName,\n    };\n  }\n\n  if (registries.includes(\"nuget\")) {\n    const nugetName = `${pascalCase(namespace)}.${pascalCase(name)}`;\n    config.publishToNuget = {\n      dotNetNamespace: nugetName,\n      packageId: nugetName,\n    };\n  }\n  return config;\n}\n\nexport function publishToGithubPackages(options: PublishOptions): Config {\n  const { registries } = options;\n  const config = publishToRegistries(options);\n  if (registries.includes(\"pypi\")) {\n    throw new Error(\"Github Packages does not support python packages\");\n  }\n  if (registries.includes(\"nuget\")) {\n    // Seems like projen does not support github packages on nuget yet: https://github.dev/projen/projen/blob/14f37ec704afdc5143e6a2954c1250b1f0ccaddf/src/release/publisher.ts#L343\n    throw new Error(\n      \"Github Packages does support nuget packages, but this library does not yet support it\"\n    );\n  }\n\n  if (registries.includes(\"npm\")) {\n    config.npmRegistryUrl = \"https://npm.pkg.github.com\";\n  }\n\n  if (registries.includes(\"maven\")) {\n    config.publishToMaven!.mavenRepositoryUrl = \"https://maven.pkg.github.com\";\n  }\n\n  return config;\n}\n\nexport type ArtifactoryPublishOptions = PublishOptions & {\n  // The artifactory url to publish to, e.g. \"https://artifactory.example.com/artifactory/api\"\n  artifactoryApiUrl: string;\n\n  // Name of the artifactory repository to publish to, defaults to the namespace\n  artifactoryRepository?: string;\n};\n\nexport function publishToArtifactory(\n  options: ArtifactoryPublishOptions\n): Config {\n  const {\n    registries,\n    artifactoryApiUrl,\n    artifactoryRepository = options.namespace,\n  } = options;\n  const config = publishToRegistries(options);\n\n  if (registries.includes(\"npm\")) {\n    config.npmRegistryUrl = `${artifactoryApiUrl}/npm/${artifactoryRepository}/`;\n  }\n\n  if (registries.includes(\"pypi\")) {\n    config.publishToPypi!.twineRegistryUrl = `${artifactoryApiUrl}/pypi/${artifactoryRepository}/`;\n  }\n\n  if (registries.includes(\"maven\")) {\n    throw new Error(\n      \"Artifactory does support maven packages, but this library does not yet support it\"\n    );\n    // With no chance to test it the docs dont tell me enough to implement it\n    // https://www.jfrog.com/confluence/display/JFROG/Maven+Repository#MavenRepository-ResolvingArtifactsThroughArtifactory\n    // config.publishToMaven!.mavenRepositoryUrl = `${artifactoryApiUrl}/`;\n  }\n\n  if (registries.includes(\"nuget\")) {\n    // Seems like projen does not support artifactory on nuget yet: https://github.dev/projen/projen/blob/14f37ec704afdc5143e6a2954c1250b1f0ccaddf/src/release/publisher.ts#L343\n    throw new Error(\n      \"Artifactory does support nuget packages, but this library does not yet support it\"\n    );\n  }\n\n  return config;\n}\n"]}
@@ -71,5 +71,5 @@ describe("MyModule", () => {
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.55" };
74
+ TerraformModule[_a] = { fqn: "projen-cdktf-hybrid-construct.TerraformModule", version: "0.1.58" };
75
75
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90ZXJyYWZvcm0tbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQXVEO0FBQ3ZELHdDQUEyRTtBQUMzRSwrQkFBa0M7QUFFbEMseUNBQXNDO0FBd0N0Qzs7OztHQUlHO0FBQ0gsTUFBYSxlQUFnQixTQUFRLHNCQUFnQjtJQUNuRCxZQUFZLE9BQStCO1FBQ3pDLEtBQUssQ0FBQztZQUNKLEdBQUcsbUJBQVE7WUFDWCxHQUFHLE9BQU87WUFDVixhQUFhLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsT0FBTyxDQUFDLGFBQWEsRUFBRTtnQkFDdEQsWUFBWSxFQUFFLEtBQUs7YUFDcEIsQ0FBQztZQUNGLGNBQWMsRUFBRSxFQUFFO1NBQ25CLENBQUMsQ0FBQztRQUNILE1BQU0sZ0JBQWdCLEdBQUcsT0FBTyxDQUFDLGdCQUFnQixJQUFJLFdBQVcsQ0FBQztRQUNqRSxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsWUFBWSxJQUFJLFNBQVMsQ0FBQztRQUV2RCxNQUFNLGdCQUFnQixHQUFHOzs7OztDQUs1QixDQUFDO1FBRUUsTUFBTSxpQkFBaUIsR0FBRzs7Ozs7Ozs7Q0FRN0IsQ0FBQztRQUVFLElBQUksQ0FBQyxXQUFXLENBQUMsY0FBYyxnQkFBZ0IsRUFBRSxFQUFFLFNBQVMsWUFBWSxFQUFFLENBQUMsQ0FBQztRQUM1RSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsWUFBWSxFQUFFLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFFMUMsSUFBSSxrQkFBUyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQy9CLEtBQUssRUFBRTtnQkFDTCxVQUFVLEVBQUUsZ0JBQWdCLENBQUMsSUFBSSxFQUFFO2dCQUNuQyx5QkFBeUIsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJLEVBQUU7YUFDcEQ7U0FDRixDQUFDLENBQUM7UUFDSCxJQUFJLGlCQUFRLENBQUMsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sc0JBQXNCLEVBQUU7WUFDdkQsU0FBUyxFQUFFLElBQUk7WUFDZixNQUFNLEVBQUUsSUFBSTtZQUNaLEtBQUssRUFBRTtnQkFDTCxHQUFHLENBQUMsT0FBTyxDQUFDLGdCQUFnQixJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FDckMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLGlDQUFpQyxRQUFRLENBQUMsSUFBSSxJQUFJLENBQ2pFO2dCQUNELEVBQUU7YUFDSDtTQUNGLENBQUMsQ0FBQztRQUVILElBQUksaUJBQVEsQ0FBQyxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxhQUFhLEVBQUU7WUFDOUMsU0FBUyxFQUFFLElBQUk7WUFDZixHQUFHLEVBQUU7Z0JBQ0gsUUFBUSxFQUFFLFlBQVk7Z0JBQ3RCLEdBQUcsRUFBRSxzQkFBc0I7Z0JBQzNCLGtCQUFrQixFQUFFLE9BQU8sQ0FBQyxrQkFBa0IsSUFBSSxFQUFFO2dCQUNwRCxnQkFBZ0IsRUFBRSxPQUFPLENBQUMsZ0JBQWdCO2dCQUMxQyxTQUFTLEVBQUUsT0FBTyxDQUFDLFNBQVMsSUFBSSxTQUFJLEVBQUU7YUFDdkM7U0FDRixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDOUQsQ0FBQzs7QUEvREgsMENBZ0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSnNvbkZpbGUsIFNhbXBsZURpciwgVGV4dEZpbGUgfSBmcm9tIFwicHJvamVuXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3RMaWJyYXJ5LCBDb25zdHJ1Y3RMaWJyYXJ5T3B0aW9ucyB9IGZyb20gXCJwcm9qZW4vbGliL2Nka1wiO1xuaW1wb3J0IHsgdjQgYXMgdXVpZCB9IGZyb20gXCJ1dWlkXCI7XG5cbmltcG9ydCB7IGRlZmF1bHRzIH0gZnJvbSBcIi4vZGVmYXVsdHNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBUZXJyYWZvcm1WZXJzaW9uQ29uc3RyYWludCB7XG4gIC8vIG5hbWUgb2YgdGhlIG1vZHVsZVxuICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gIC8vIHBhdGggLyB1cmwgLyByZWdpc3RyeSBpZGVudGlmaWVyIGZvciB0aGUgbW9kdWxlXG4gIHJlYWRvbmx5IHNvdXJjZTogc3RyaW5nO1xuICAvLyB2ZXJzaW9uIGNvbnN0cmFpbnQgKGh0dHBzOi8vd3d3LnRlcnJhZm9ybS5pby9kb2NzL2xhbmd1YWdlL3Byb3ZpZGVycy9yZXF1aXJlbWVudHMuaHRtbCN2ZXJzaW9uLWNvbnN0cmFpbnRzKVxuICByZWFkb25seSB2ZXJzaW9uOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGVycmFmb3JtTW9kdWxlT3B0aW9ucyBleHRlbmRzIENvbnN0cnVjdExpYnJhcnlPcHRpb25zIHtcbiAgLyoqXG4gICAqIE1pbmltdW0gdGFyZ2V0IHZlcnNpb24gb2YgdGhpcyBsaWJyYXJ5LlxuICAgKiBAZGVmYXVsdCBcIl4wLjEwLjFcIlxuICAgKiBAZmVhdHVyZWRcbiAgICovXG4gIHJlYWRvbmx5IGNka3RmVmVyc2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogQ29uc3RydWN0IHZlcnNpb24gdG8gdXNlXG4gICAqIEBkZWZhdWx0IFwiXjEwLjAuMTJcIlxuICAgKi9cbiAgcmVhZG9ubHkgY29uc3RydWN0VmVyc2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogIExpc3Qgb2YgcHJvdmlkZXIgYmluZGluZ3MgdG8gZ2VuZXJhdGUgaW4gYWRkaXRpb24gdG8gdGhlIG1vZHVsZXMuXG4gICAqL1xuICByZWFkb25seSB0ZXJyYWZvcm1Qcm92aWRlcnM/OiBUZXJyYWZvcm1WZXJzaW9uQ29uc3RyYWludFtdO1xuXG4gIC8qKlxuICAgKiBMaXN0IG9mIG1vZHVsZXMgdG8gZ2VuZXJhdGUgYmluZGluZ3MgZm9yLlxuICAgKiBAZmVhdHVyZWRcbiAgICovXG4gIHJlYWRvbmx5IHRlcnJhZm9ybU1vZHVsZXM6IFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50W107XG5cbiAgLy8gRGVmYXVsdGVkIHRvIGEgdXVpZCBzdHJpbmcgYXMgY2RrdGYgd291bGRcbiAgcmVhZG9ubHkgcHJvamVjdElkPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFRlcnJhZm9ybSBNb2R1bGVzIHJlcHVibGlzaGVkIGFzIENES1RGIENvbnN0cnVjdHNcbiAqXG4gKiBAcGppZCB0ZXJyYWZvcm0tbW9kdWxlXG4gKi9cbmV4cG9ydCBjbGFzcyBUZXJyYWZvcm1Nb2R1bGUgZXh0ZW5kcyBDb25zdHJ1Y3RMaWJyYXJ5IHtcbiAgY29uc3RydWN0b3Iob3B0aW9uczogVGVycmFmb3JtTW9kdWxlT3B0aW9ucykge1xuICAgIHN1cGVyKHtcbiAgICAgIC4uLmRlZmF1bHRzLFxuICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIGVzbGludE9wdGlvbnM6IE9iamVjdC5hc3NpZ24oe30sIG9wdGlvbnMuZXNsaW50T3B0aW9ucywge1xuICAgICAgICBsaW50UHJvamVuUmM6IGZhbHNlLFxuICAgICAgfSksXG4gICAgICBwb3N0QnVpbGRTdGVwczogW10sXG4gICAgfSk7XG4gICAgY29uc3QgY29uc3RydWN0VmVyc2lvbiA9IG9wdGlvbnMuY29uc3RydWN0VmVyc2lvbiB8fCBcIl4xMC4wLjEwN1wiO1xuICAgIGNvbnN0IGNka3RmVmVyc2lvbiA9IG9wdGlvbnMuY2RrdGZWZXJzaW9uIHx8IFwiXjAuMTAuMVwiO1xuXG4gICAgY29uc3QgY29uc3RydWN0U3JjQ29kZSA9IGBcbi8vIFJlLUV4cG9ydCBtb2R1bGUgYmluZGluZ3NcbmV4cG9ydCAqIGZyb20gXCIuL3RlcnJhZm9ybU1vZHVsZXNcIjtcblxuLy8gQWRkIHlvdXIgY3VzdG9tIGNvbnN0cnVjdHMgaGVyZVxuYDtcblxuICAgIGNvbnN0IGNvbnN0cnVjdFRlc3RDb2RlID0gYFxuLy8gaW1wb3J0IHsgVGVzdGluZyB9IGZyb20gXCJjZGt0ZlwiO1xuLy8gaW1wb3J0IFwiY2RrdGYvbGliL3Rlc3RpbmcvYWRhcHRlcnMvamVzdFwiO1xuXG4vLyBUbyBsZWFybiBtb3JlIGFib3V0IHRlc3Rpbmcgc2VlIGNkay50Zi90ZXN0aW5nXG5kZXNjcmliZShcIk15TW9kdWxlXCIsICgpID0+IHtcbiAgaXQudG9kbyhcInNob3VsZCBiZSB0ZXN0ZWRcIilcbn0pO1xuYDtcblxuICAgIHRoaXMuYWRkUGVlckRlcHMoYGNvbnN0cnVjdHNAJHtjb25zdHJ1Y3RWZXJzaW9ufWAsIGBjZGt0ZkAke2Nka3RmVmVyc2lvbn1gKTtcbiAgICB0aGlzLmFkZERldkRlcHMoYGNka3RmLWNsaUAke2Nka3RmVmVyc2lvbn1gLCBcInRzLW5vZGVcIik7XG4gICAgdGhpcy5hZGRLZXl3b3JkcyhcImNka3RmXCIsIFwiY2RrdGYtaHlicmlkXCIpO1xuXG4gICAgbmV3IFNhbXBsZURpcih0aGlzLCB0aGlzLnNyY2Rpciwge1xuICAgICAgZmlsZXM6IHtcbiAgICAgICAgXCJpbmRleC50c1wiOiBjb25zdHJ1Y3RTcmNDb2RlLnRyaW0oKSxcbiAgICAgICAgXCJfX3Rlc3RzX18vaW5kZXgtdGVzdC50c1wiOiBjb25zdHJ1Y3RUZXN0Q29kZS50cmltKCksXG4gICAgICB9LFxuICAgIH0pO1xuICAgIG5ldyBUZXh0RmlsZSh0aGlzLCBgJHt0aGlzLnNyY2Rpcn0vdGVycmFmb3JtTW9kdWxlcy50c2AsIHtcbiAgICAgIGNvbW1pdHRlZDogdHJ1ZSxcbiAgICAgIG1hcmtlcjogdHJ1ZSxcbiAgICAgIGxpbmVzOiBbXG4gICAgICAgIC4uLihvcHRpb25zLnRlcnJhZm9ybU1vZHVsZXMgfHwgW10pLm1hcChcbiAgICAgICAgICAodGZNb2R1bGUpID0+IGBleHBvcnQgKiBmcm9tIFwiLi8uZ2VuL21vZHVsZXMvJHt0Zk1vZHVsZS5uYW1lfVwiO2BcbiAgICAgICAgKSxcbiAgICAgICAgXCJcIixcbiAgICAgIF0sXG4gICAgfSk7XG5cbiAgICBuZXcgSnNvbkZpbGUodGhpcywgYCR7dGhpcy5zcmNkaXJ9L2Nka3RmLmpzb25gLCB7XG4gICAgICBjb21taXR0ZWQ6IHRydWUsXG4gICAgICBvYmo6IHtcbiAgICAgICAgbGFuZ3VhZ2U6IFwidHlwZXNjcmlwdFwiLFxuICAgICAgICBhcHA6IFwibnB4IHRzLW5vZGUgaW5kZXgudHNcIixcbiAgICAgICAgdGVycmFmb3JtUHJvdmlkZXJzOiBvcHRpb25zLnRlcnJhZm9ybVByb3ZpZGVycyB8fCBbXSxcbiAgICAgICAgdGVycmFmb3JtTW9kdWxlczogb3B0aW9ucy50ZXJyYWZvcm1Nb2R1bGVzLFxuICAgICAgICBwcm9qZWN0SWQ6IG9wdGlvbnMucHJvamVjdElkIHx8IHV1aWQoKSxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICB0aGlzLnByZUNvbXBpbGVUYXNrLmV4ZWMoYGNka3RmIGdldGAsIHsgY3dkOiB0aGlzLnNyY2RpciB9KTtcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -83,7 +83,7 @@
83
83
  ],
84
84
  "main": "lib/index.js",
85
85
  "license": "MIT",
86
- "version": "0.1.55",
86
+ "version": "0.1.58",
87
87
  "jest": {
88
88
  "testMatch": [
89
89
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",
package/releasetag.txt CHANGED
@@ -1 +1 @@
1
- v0.1.55
1
+ v0.1.58
package/version.txt CHANGED
@@ -1 +1 @@
1
- 0.1.55
1
+ 0.1.58