projen-cdktf-hybrid-construct 0.1.65 → 0.1.66

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
@@ -601,6 +601,6 @@
601
601
  "symbolId": "src/terraform-module:TerraformVersionConstraint"
602
602
  }
603
603
  },
604
- "version": "0.1.65",
605
- "fingerprint": "pVAJ18bvmTKcQUJK90R7IlZ9OYe/LKqZTzMZqyAdxfU="
604
+ "version": "0.1.66",
605
+ "fingerprint": "d21YBvDFGEQ7Qc23NlA8Qye2tMA7CS5kOiyPZQyxXlA="
606
606
  }
package/CHANGELOG.md CHANGED
@@ -1,7 +1,7 @@
1
1
 
2
- ### [0.1.65](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/compare/v0.1.64...v0.1.65) (2022-05-09)
2
+ ### [0.1.66](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/compare/v0.1.65...v0.1.66) (2022-05-09)
3
3
 
4
4
 
5
- ### Features
5
+ ### Bug Fixes
6
6
 
7
- * use static project id ([#67](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/issues/67)) ([dc4d4d1](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/commit/dc4d4d10844bff179fdf2cc54a766eaaa584c38a))
7
+ * fix publishing to github ([92ef352](https://github.com/DanielMSchmidt/projen-cdktf-hybrid-construct/commit/92ef352256ad10e4022848ae1273ebe76d0bbe16))
@@ -318,5 +318,5 @@ done
318
318
  }
319
319
  exports.HybridModule = HybridModule;
320
320
  _a = JSII_RTTI_SYMBOL_1;
321
- HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.1.65" };
321
+ HybridModule[_a] = { fqn: "projen-cdktf-hybrid-construct.HybridModule", version: "0.1.66" };
322
322
  //# 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.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(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"]}
@@ -9,12 +9,31 @@ declare type AtomicObject = Function | Promise<any> | Date | RegExp | Boolean |
9
9
  declare type Mutable<T> = T extends AtomicObject ? T : T extends ReadonlyMap<infer K, infer V> ? Map<Mutable<K>, Mutable<V>> : T extends ReadonlySet<infer V> ? Set<Mutable<V>> : T extends object ? {
10
10
  -readonly [K in keyof T]: Mutable<T[K]>;
11
11
  } : T;
12
- declare type Config = Mutable<Pick<ConstructLibraryOptions, "publishToPypi" | "publishToMaven" | "publishToNuget" | "releaseToNpm" | "npmRegistryUrl">>;
13
- export declare function publishToRegistries(options: PublishOptions): Config;
14
- export declare function publishToGithubPackages(options: PublishOptions): Config;
12
+ declare type PublishingConfig = Mutable<Pick<ConstructLibraryOptions, "publishToPypi" | "publishToMaven" | "publishToNuget" | "releaseToNpm" | "npmRegistryUrl">>;
13
+ export declare function publishToRegistries(options: PublishOptions): PublishingConfig;
14
+ export declare type GithubRegistry = "npm" | "maven";
15
+ declare type GitHubPublishOptions = {
16
+ /**
17
+ * The GitHub repository of this project.
18
+ */
19
+ repositoryName: string;
20
+ /**
21
+ * The GitHub owner of this project.
22
+ */
23
+ repositoryOwner: string;
24
+ /**
25
+ * Registries to publish to
26
+ */
27
+ registries: GithubRegistry[];
28
+ };
29
+ export declare type GitHubPublishConfig = {
30
+ name: string;
31
+ repositoryUrl: string;
32
+ } & PublishingConfig;
33
+ export declare function publishToGithubPackages(options: GitHubPublishOptions): GitHubPublishConfig;
15
34
  export declare type ArtifactoryPublishOptions = PublishOptions & {
16
35
  artifactoryApiUrl: string;
17
36
  artifactoryRepository?: string;
18
37
  };
19
- export declare function publishToArtifactory(options: ArtifactoryPublishOptions): Config;
38
+ export declare function publishToArtifactory(options: ArtifactoryPublishOptions): PublishingConfig;
20
39
  export {};
package/lib/publishing.js CHANGED
@@ -33,22 +33,23 @@ function publishToRegistries(options) {
33
33
  }
34
34
  exports.publishToRegistries = publishToRegistries;
35
35
  function publishToGithubPackages(options) {
36
- const { registries } = options;
37
- const config = publishToRegistries(options);
38
- if (registries.includes("pypi")) {
39
- throw new Error("Github Packages does not support python packages");
40
- }
41
- if (registries.includes("nuget")) {
42
- // Seems like projen does not support github packages on nuget yet: https://github.dev/projen/projen/blob/14f37ec704afdc5143e6a2954c1250b1f0ccaddf/src/release/publisher.ts#L343
43
- throw new Error("Github Packages does support nuget packages, but this library does not yet support it");
44
- }
36
+ const { registries, repositoryName, repositoryOwner } = options;
37
+ const config = publishToRegistries({
38
+ name: repositoryName,
39
+ namespace: repositoryOwner,
40
+ registries,
41
+ });
45
42
  if (registries.includes("npm")) {
46
43
  config.npmRegistryUrl = "https://npm.pkg.github.com";
47
44
  }
48
45
  if (registries.includes("maven")) {
49
- config.publishToMaven.mavenRepositoryUrl = "https://maven.pkg.github.com";
46
+ config.publishToMaven.mavenRepositoryUrl = `https://maven.pkg.github.com/${repositoryOwner}/${repositoryName}`;
50
47
  }
51
- return config;
48
+ return {
49
+ ...config,
50
+ repositoryUrl: `https://github.com/${repositoryOwner}/${repositoryName}.git`,
51
+ name: `@${repositoryOwner}/${repositoryName}`,
52
+ };
52
53
  }
53
54
  exports.publishToGithubPackages = publishToGithubPackages;
54
55
  function publishToArtifactory(options) {
@@ -73,4 +74,4 @@ function publishToArtifactory(options) {
73
74
  return config;
74
75
  }
75
76
  exports.publishToArtifactory = publishToArtifactory;
76
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["../src/publishing.ts"],"names":[],"mappings":";;;AAAA,6CAAyC;AAyCzC,SAAgB,mBAAmB,CAAC,OAAuB;IACzD,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAChD,MAAM,kBAAkB,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACzD,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC/C,MAAM,MAAM,GAAW;QACrB,YAAY,EAAE,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC;KACzC,CAAC;IAEF,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;QAC/B,MAAM,CAAC,aAAa,GAAG;YACrB,QAAQ,EAAE,GAAG,kBAAkB,IAAI,aAAa,EAAE;YAClD,MAAM,EAAE,GAAG,kBAAkB,IAAI,aAAa,EAAE;SACjD,CAAC;KACH;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QAChC,MAAM,CAAC,cAAc,GAAG;YACtB,WAAW,EAAE,OAAO,kBAAkB,IAAI,aAAa,EAAE;YACzD,YAAY,EAAE,OAAO,kBAAkB,EAAE;YACzC,eAAe,EAAE,aAAa;SAC/B,CAAC;KACH;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QAChC,MAAM,SAAS,GAAG,GAAG,wBAAU,CAAC,SAAS,CAAC,IAAI,wBAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QACjE,MAAM,CAAC,cAAc,GAAG;YACtB,eAAe,EAAE,SAAS;YAC1B,SAAS,EAAE,SAAS;SACrB,CAAC;KACH;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AA/BD,kDA+BC;AAED,SAAgB,uBAAuB,CAAC,OAAuB;IAC7D,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAC/B,MAAM,MAAM,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;IAC5C,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;QAC/B,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;KACrE;IACD,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QAChC,gLAAgL;QAChL,MAAM,IAAI,KAAK,CACb,uFAAuF,CACxF,CAAC;KACH;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;QAC9B,MAAM,CAAC,cAAc,GAAG,4BAA4B,CAAC;KACtD;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QAChC,MAAM,CAAC,cAAe,CAAC,kBAAkB,GAAG,8BAA8B,CAAC;KAC5E;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAtBD,0DAsBC;AAUD,SAAgB,oBAAoB,CAClC,OAAkC;IAElC,MAAM,EACJ,UAAU,EACV,iBAAiB,EACjB,qBAAqB,GAAG,OAAO,CAAC,SAAS,GAC1C,GAAG,OAAO,CAAC;IACZ,MAAM,MAAM,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;IAE5C,IAAI,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;QAC9B,MAAM,CAAC,cAAc,GAAG,GAAG,iBAAiB,QAAQ,qBAAqB,GAAG,CAAC;KAC9E;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;QAC/B,MAAM,CAAC,aAAc,CAAC,gBAAgB,GAAG,GAAG,iBAAiB,SAAS,qBAAqB,GAAG,CAAC;KAChG;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QAChC,MAAM,IAAI,KAAK,CACb,mFAAmF,CACpF,CAAC;QACF,yEAAyE;QACzE,uHAAuH;QACvH,uEAAuE;KACxE;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QAChC,4KAA4K;QAC5K,MAAM,IAAI,KAAK,CACb,mFAAmF,CACpF,CAAC;KACH;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAnCD,oDAmCC","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"]}
77
+ //# 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 PublishingConfig = Mutable<\n  Pick<\n    ConstructLibraryOptions,\n    | \"publishToPypi\"\n    | \"publishToMaven\"\n    | \"publishToNuget\"\n    | \"releaseToNpm\"\n    | \"npmRegistryUrl\"\n  >\n>;\n\nexport function publishToRegistries(options: PublishOptions): PublishingConfig {\n  const { name, namespace, registries } = options;\n  const sanitizedNamespace = namespace.replace(/-/gi, \"_\");\n  const sanitizedName = name.replace(/-/gi, \"_\");\n  const config: PublishingConfig = {\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 type GithubRegistry = \"npm\" | \"maven\";\ntype GitHubPublishOptions = {\n  /**\n   * The GitHub repository of this project.\n   */\n  repositoryName: string;\n\n  /**\n   * The GitHub owner of this project.\n   */\n  repositoryOwner: string;\n\n  /**\n   * Registries to publish to\n   */\n  registries: GithubRegistry[];\n};\n\nexport type GitHubPublishConfig = {\n  name: string;\n  repositoryUrl: string;\n} & PublishingConfig;\n\nexport function publishToGithubPackages(\n  options: GitHubPublishOptions\n): GitHubPublishConfig {\n  const { registries, repositoryName, repositoryOwner } = options;\n  const config = publishToRegistries({\n    name: repositoryName,\n    namespace: repositoryOwner,\n    registries,\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/${repositoryOwner}/${repositoryName}`;\n  }\n\n  return {\n    ...config,\n    repositoryUrl: `https://github.com/${repositoryOwner}/${repositoryName}.git`,\n    name: `@${repositoryOwner}/${repositoryName}`,\n  };\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): PublishingConfig {\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.65" };
74
+ TerraformModule[_a] = { fqn: "projen-cdktf-hybrid-construct.TerraformModule", version: "0.1.66" };
75
75
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90ZXJyYWZvcm0tbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQXVEO0FBQ3ZELHdDQUEyRTtBQUUzRSx5Q0FBc0M7QUF3Q3RDOzs7O0dBSUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEsc0JBQWdCO0lBQ25ELFlBQVksT0FBK0I7UUFDekMsS0FBSyxDQUFDO1lBQ0osR0FBRyxtQkFBUTtZQUNYLEdBQUcsT0FBTztZQUNWLGFBQWEsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsYUFBYSxFQUFFO2dCQUN0RCxZQUFZLEVBQUUsS0FBSzthQUNwQixDQUFDO1lBQ0YsY0FBYyxFQUFFLEVBQUU7U0FDbkIsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsZ0JBQWdCLElBQUksV0FBVyxDQUFDO1FBQ2pFLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxZQUFZLElBQUksU0FBUyxDQUFDO1FBRXZELE1BQU0sZ0JBQWdCLEdBQUc7Ozs7O0NBSzVCLENBQUM7UUFFRSxNQUFNLGlCQUFpQixHQUFHOzs7Ozs7OztDQVE3QixDQUFDO1FBRUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxjQUFjLGdCQUFnQixFQUFFLEVBQUUsU0FBUyxZQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQzVFLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxZQUFZLEVBQUUsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4RCxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQztRQUUxQyxJQUFJLGtCQUFTLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDL0IsS0FBSyxFQUFFO2dCQUNMLFVBQVUsRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUU7Z0JBQ25DLHlCQUF5QixFQUFFLGlCQUFpQixDQUFDLElBQUksRUFBRTthQUNwRDtTQUNGLENBQUMsQ0FBQztRQUNILElBQUksaUJBQVEsQ0FBQyxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxzQkFBc0IsRUFBRTtZQUN2RCxTQUFTLEVBQUUsSUFBSTtZQUNmLE1BQU0sRUFBRSxJQUFJO1lBQ1osS0FBSyxFQUFFO2dCQUNMLEdBQUcsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLElBQUksRUFBRSxDQUFDLENBQUMsR0FBRyxDQUNyQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsaUNBQWlDLFFBQVEsQ0FBQyxJQUFJLElBQUksQ0FDakU7Z0JBQ0QsRUFBRTthQUNIO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxpQkFBUSxDQUFDLElBQUksRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLGFBQWEsRUFBRTtZQUM5QyxTQUFTLEVBQUUsSUFBSTtZQUNmLEdBQUcsRUFBRTtnQkFDSCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIsR0FBRyxFQUFFLHNCQUFzQjtnQkFDM0Isa0JBQWtCLEVBQUUsT0FBTyxDQUFDLGtCQUFrQixJQUFJLEVBQUU7Z0JBQ3BELGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxnQkFBZ0I7Z0JBQzFDLFNBQVMsRUFDUCxPQUFPLENBQUMsU0FBUztvQkFDakIsdURBQXVEO2FBQzFEO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQzlELENBQUM7O0FBakVILDBDQWtFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEpzb25GaWxlLCBTYW1wbGVEaXIsIFRleHRGaWxlIH0gZnJvbSBcInByb2plblwiO1xuaW1wb3J0IHsgQ29uc3RydWN0TGlicmFyeSwgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMgfSBmcm9tIFwicHJvamVuL2xpYi9jZGtcIjtcblxuaW1wb3J0IHsgZGVmYXVsdHMgfSBmcm9tIFwiLi9kZWZhdWx0c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50IHtcbiAgLy8gbmFtZSBvZiB0aGUgbW9kdWxlXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLy8gcGF0aCAvIHVybCAvIHJlZ2lzdHJ5IGlkZW50aWZpZXIgZm9yIHRoZSBtb2R1bGVcbiAgcmVhZG9ubHkgc291cmNlOiBzdHJpbmc7XG4gIC8vIHZlcnNpb24gY29uc3RyYWludCAoaHR0cHM6Ly93d3cudGVycmFmb3JtLmlvL2RvY3MvbGFuZ3VhZ2UvcHJvdmlkZXJzL3JlcXVpcmVtZW50cy5odG1sI3ZlcnNpb24tY29uc3RyYWludHMpXG4gIHJlYWRvbmx5IHZlcnNpb246IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zIGV4dGVuZHMgQ29uc3RydWN0TGlicmFyeU9wdGlvbnMge1xuICAvKipcbiAgICogTWluaW11bSB0YXJnZXQgdmVyc2lvbiBvZiB0aGlzIGxpYnJhcnkuXG4gICAqIEBkZWZhdWx0IFwiXjAuMTAuMVwiXG4gICAqIEBmZWF0dXJlZFxuICAgKi9cbiAgcmVhZG9ubHkgY2RrdGZWZXJzaW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBDb25zdHJ1Y3QgdmVyc2lvbiB0byB1c2VcbiAgICogQGRlZmF1bHQgXCJeMTAuMC4xMlwiXG4gICAqL1xuICByZWFkb25seSBjb25zdHJ1Y3RWZXJzaW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiAgTGlzdCBvZiBwcm92aWRlciBiaW5kaW5ncyB0byBnZW5lcmF0ZSBpbiBhZGRpdGlvbiB0byB0aGUgbW9kdWxlcy5cbiAgICovXG4gIHJlYWRvbmx5IHRlcnJhZm9ybVByb3ZpZGVycz86IFRlcnJhZm9ybVZlcnNpb25Db25zdHJhaW50W107XG5cbiAgLyoqXG4gICAqIExpc3Qgb2YgbW9kdWxlcyB0byBnZW5lcmF0ZSBiaW5kaW5ncyBmb3IuXG4gICAqIEBmZWF0dXJlZFxuICAgKi9cbiAgcmVhZG9ubHkgdGVycmFmb3JtTW9kdWxlczogVGVycmFmb3JtVmVyc2lvbkNvbnN0cmFpbnRbXTtcblxuICAvLyBEZWZhdWx0ZWQgdG8gYSB1dWlkIHN0cmluZyBhcyBjZGt0ZiB3b3VsZFxuICByZWFkb25seSBwcm9qZWN0SWQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogVGVycmFmb3JtIE1vZHVsZXMgcmVwdWJsaXNoZWQgYXMgQ0RLVEYgQ29uc3RydWN0c1xuICpcbiAqIEBwamlkIHRlcnJhZm9ybS1tb2R1bGVcbiAqL1xuZXhwb3J0IGNsYXNzIFRlcnJhZm9ybU1vZHVsZSBleHRlbmRzIENvbnN0cnVjdExpYnJhcnkge1xuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBUZXJyYWZvcm1Nb2R1bGVPcHRpb25zKSB7XG4gICAgc3VwZXIoe1xuICAgICAgLi4uZGVmYXVsdHMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgICAgZXNsaW50T3B0aW9uczogT2JqZWN0LmFzc2lnbih7fSwgb3B0aW9ucy5lc2xpbnRPcHRpb25zLCB7XG4gICAgICAgIGxpbnRQcm9qZW5SYzogZmFsc2UsXG4gICAgICB9KSxcbiAgICAgIHBvc3RCdWlsZFN0ZXBzOiBbXSxcbiAgICB9KTtcbiAgICBjb25zdCBjb25zdHJ1Y3RWZXJzaW9uID0gb3B0aW9ucy5jb25zdHJ1Y3RWZXJzaW9uIHx8IFwiXjEwLjAuMTA3XCI7XG4gICAgY29uc3QgY2RrdGZWZXJzaW9uID0gb3B0aW9ucy5jZGt0ZlZlcnNpb24gfHwgXCJeMC4xMC4xXCI7XG5cbiAgICBjb25zdCBjb25zdHJ1Y3RTcmNDb2RlID0gYFxuLy8gUmUtRXhwb3J0IG1vZHVsZSBiaW5kaW5nc1xuZXhwb3J0ICogZnJvbSBcIi4vdGVycmFmb3JtTW9kdWxlc1wiO1xuXG4vLyBBZGQgeW91ciBjdXN0b20gY29uc3RydWN0cyBoZXJlXG5gO1xuXG4gICAgY29uc3QgY29uc3RydWN0VGVzdENvZGUgPSBgXG4vLyBpbXBvcnQgeyBUZXN0aW5nIH0gZnJvbSBcImNka3RmXCI7XG4vLyBpbXBvcnQgXCJjZGt0Zi9saWIvdGVzdGluZy9hZGFwdGVycy9qZXN0XCI7XG5cbi8vIFRvIGxlYXJuIG1vcmUgYWJvdXQgdGVzdGluZyBzZWUgY2RrLnRmL3Rlc3RpbmdcbmRlc2NyaWJlKFwiTXlNb2R1bGVcIiwgKCkgPT4ge1xuICBpdC50b2RvKFwic2hvdWxkIGJlIHRlc3RlZFwiKVxufSk7XG5gO1xuXG4gICAgdGhpcy5hZGRQZWVyRGVwcyhgY29uc3RydWN0c0Ake2NvbnN0cnVjdFZlcnNpb259YCwgYGNka3RmQCR7Y2RrdGZWZXJzaW9ufWApO1xuICAgIHRoaXMuYWRkRGV2RGVwcyhgY2RrdGYtY2xpQCR7Y2RrdGZWZXJzaW9ufWAsIFwidHMtbm9kZVwiKTtcbiAgICB0aGlzLmFkZEtleXdvcmRzKFwiY2RrdGZcIiwgXCJjZGt0Zi1oeWJyaWRcIik7XG5cbiAgICBuZXcgU2FtcGxlRGlyKHRoaXMsIHRoaXMuc3JjZGlyLCB7XG4gICAgICBmaWxlczoge1xuICAgICAgICBcImluZGV4LnRzXCI6IGNvbnN0cnVjdFNyY0NvZGUudHJpbSgpLFxuICAgICAgICBcIl9fdGVzdHNfXy9pbmRleC10ZXN0LnRzXCI6IGNvbnN0cnVjdFRlc3RDb2RlLnRyaW0oKSxcbiAgICAgIH0sXG4gICAgfSk7XG4gICAgbmV3IFRleHRGaWxlKHRoaXMsIGAke3RoaXMuc3JjZGlyfS90ZXJyYWZvcm1Nb2R1bGVzLnRzYCwge1xuICAgICAgY29tbWl0dGVkOiB0cnVlLFxuICAgICAgbWFya2VyOiB0cnVlLFxuICAgICAgbGluZXM6IFtcbiAgICAgICAgLi4uKG9wdGlvbnMudGVycmFmb3JtTW9kdWxlcyB8fCBbXSkubWFwKFxuICAgICAgICAgICh0Zk1vZHVsZSkgPT4gYGV4cG9ydCAqIGZyb20gXCIuLy5nZW4vbW9kdWxlcy8ke3RmTW9kdWxlLm5hbWV9XCI7YFxuICAgICAgICApLFxuICAgICAgICBcIlwiLFxuICAgICAgXSxcbiAgICB9KTtcblxuICAgIG5ldyBKc29uRmlsZSh0aGlzLCBgJHt0aGlzLnNyY2Rpcn0vY2RrdGYuanNvbmAsIHtcbiAgICAgIGNvbW1pdHRlZDogdHJ1ZSxcbiAgICAgIG9iajoge1xuICAgICAgICBsYW5ndWFnZTogXCJ0eXBlc2NyaXB0XCIsXG4gICAgICAgIGFwcDogXCJucHggdHMtbm9kZSBpbmRleC50c1wiLFxuICAgICAgICB0ZXJyYWZvcm1Qcm92aWRlcnM6IG9wdGlvbnMudGVycmFmb3JtUHJvdmlkZXJzIHx8IFtdLFxuICAgICAgICB0ZXJyYWZvcm1Nb2R1bGVzOiBvcHRpb25zLnRlcnJhZm9ybU1vZHVsZXMsXG4gICAgICAgIHByb2plY3RJZDpcbiAgICAgICAgICBvcHRpb25zLnByb2plY3RJZCB8fFxuICAgICAgICAgIFwidGVycmFmb3JtLW1vZHVsZS05OWE3NzBhNy0zZWM1LTQwZjctOGNkMy1kYmM3MmY3NWEwMGFcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICB0aGlzLnByZUNvbXBpbGVUYXNrLmV4ZWMoYGNka3RmIGdldGAsIHsgY3dkOiB0aGlzLnNyY2RpciB9KTtcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -80,7 +80,7 @@
80
80
  ],
81
81
  "main": "lib/index.js",
82
82
  "license": "MIT",
83
- "version": "0.1.65",
83
+ "version": "0.1.66",
84
84
  "jest": {
85
85
  "testMatch": [
86
86
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",
package/releasetag.txt CHANGED
@@ -1 +1 @@
1
- v0.1.65
1
+ v0.1.66
package/version.txt CHANGED
@@ -1 +1 @@
1
- 0.1.65
1
+ 0.1.66