@hallcor/pulumi-projen-project-types 0.0.62 → 0.0.64

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
@@ -95,7 +95,7 @@
95
95
  },
96
96
  "name": "@hallcor/pulumi-projen-project-types",
97
97
  "readme": {
98
- "markdown": "# Pulumi Projen Project Types\n\nCollection of [Projen](https://github.com/projen/projen) project types for use\nwith [Pulumi](https://www.pulumi.com/)\n\n## Getting Started\n\n_projen_ doesn't need to be installed. You will be using\n[npx](https://docs.npmjs.com/cli/v7/commands/npx) to run _projen_ which takes\ncare of all required setup steps.\n\nTo create a new project, run the following command and follow the instructions:\n\n```console\n$ mkdir my-project\n$ cd my-project\n$ npx projen new --from @hallcor/pulumi-projen-project-types PROJECT-TYPE\nšŸ¤– Synthesizing project...\n...\n```\n\nOnce your project is created, you can configure your project by editing\n`.projenrc.ts` or `.projenrc.py` and re-running `npx projen` to synthesize again.\n\n> The files generated by _projen_ are considered an \"implementation detail\" and\n> _projen_ protects them from being manually edited (most files are marked\n> read-only, and an \"anti tamper\" check is configured in the CI build workflow\n> to ensure that files are not updated during build).\n\n## Projen commands\n\nFor the TypeScript based projects the project commands can be viewed an run\nusing the package manager (e.g. `yarn build`, `yarn package`, etc). For\nnon-TypeScript based projects (i.e. Python) you can use projen to view and run\nproject commands.\n\nProjen is built around a standard build process for all projects. Each project\nwill have these standard [tasks](https://projen.io/docs/concepts/tasks).\n\n1. `default`: The \"default\" task that executes projen and synthesizes the project\n2. `pre-compile`: Task that runs prior to `compile`\n3. `compile`: Compiles the project (e.g. `tsc --build` for TypeScript projects)\n4. `post-compile`: Task that runs after `compile`\n5. `test`: Task that runs the project tests\n6. `package`: Task that runs steps to package the project for publishing\n\nThere is also a standard `build` task the chains the above 6 tasks in order.\n\nThere is a great [tasks guide] where you can find more information on adding new\ntasks, editing existing tasks, etc.\n\n**List available commands**\n\n```console\n$ npx projen --help\nprojen [command]\n\nCommands:\n projen new [PROJECT-TYPE-NAME] [OPTIONS] Creates a new projen project\n\n For a complete list of the available options for a specific project type, run:\n projen new [PROJECT-TYPE-NAME] --help\n projen build Full release build\n projen bump Bumps version based on latest git tag and generates a changelog entry\n projen clobber hard resets to HEAD of origin and cleans the local repo\n projen compile Only compile\n projen default Synthesize project files\n projen dist\n projen eject Remove projen from the project\n projen install Install and upgrade dependencies\n projen package Creates the distribution package\n projen post-compile Runs after successful compilation\n projen pre-compile Prepare the project for compilation\n projen publish:git Prepends the release changelog onto the project changelog, creates a release commit, and tags the release\n projen release Prepare a release from \"main\" branch\n projen test Run tests\n projen unbump Restores version to 0.0.0\n projen completion generate completion script\n\nOptions:\n --post Run post-synthesis steps such as installing dependencies. Use --no-post to skip [boolean] [default: true]\n -w, --watch Keep running and resynthesize when projenrc changes [boolean] [default: false]\n --debug Debug logs [boolean] [default: false]\n --rc path to .projenrc.js file [deprecated] [string] [default: \"/Users/chall/personal/pulumi-lambda-builders/.projenrc.js\"]\n --help Show help [boolean]\n --version Show version number\n\n```\n\n**Run a specific command**\n\n```console\n$ npx projen build\n```\n\n**Inspect a specific command**\n\n```console\n$ npx projen build -i\ndescription: Full release build\n- default\n description: Synthesize project files\n - exec: python .projenrc.py\n- pre-compile\n description: Prepare the project for compilation\n- compile\n description: Only compile\n- post-compile\n description: Runs after successful compilation\n- test\n description: Run tests\n - exec: npm ci\n - exec: pytest\n- package\n description: Creates the distribution package\n - dist\n - exec: mkdir -p dist\n - exec: cp version.json dist/\n - exec: git checkout version.json\n```\n\n## Project types\n\nCurrently supported project types\n\n- `PythonComponent`: Creates a Pulumi Python Component project\n- `TypeScriptComponent`: Creates a Pulumi TypeScript Component project\n\n### Pulumi Python Component\n\n```console\n$ mkdir my-python-component\n$ cd my-python-component\n$ npx projen new --from @hallcor/pulumi-projen-project-types python_component\n```\n\n\n#### Example\n\n```python\nfrom hallcor.pulumi_projen_project_types import PythonComponent\n\nproject = PythonComponent(\n module_name=\"pulumi_lambda_builders\",\n component_name=\"lambda-builders\",\n name=\"pulumi-lambda-builders\",\n version=\"0.1.0\",\n deps=[\n \"aws_lambda_builders\",\n ],\n dev_deps=[\n \"pyfakefs\",\n \"numpy\",\n \"hallcor.pulumi-projen-project-types\",\n ],\n)\n\nproject.synth()\n```\n\n#### Configuration Options\n\n- [componentName](https://github.com/corymhall/pulumi-projen-project-types/blob/main/API.md#componentnameoptional-)\nBy default the `name` of the of the Pulumi component will be taken from the\nproject `name`. This can be overridden by using the `componentName` property.\n\nFor a full list of input properties supported see the [Input Property Reference](https://github.com/corymhall/pulumi-projen-project-types/blob/main/API.md#typescriptprojectprops-)\n\n- [pulumi_python_options](https://github.com/corymhall/pulumi-projen-project-types/blob/main/API.md#pulumipythonoptionsoptional-)\nThis can be used to override some of the default Pulumi options. For example you\ncan specify a specific version of `pulumi` to use.\n\n```python\n\nproject = PythonComponent(\n ...,\n pulumi_python_options=PulumiPythonOptions(\n pulumi_version=\">=3.159 <4.0\" # this is the default value\n ),\n)\n```\n\nFor publishing related options see the [publishing section](#publishing)\n\n### Pulumi TypeScript Component\n\n```console\n$ mkdir my-python-component\n$ cd my-python-component\n$ npx projen new --from @hallcor/pulumi-projen-project-types type_script_component --name my-component\n```\n\n#### Example\n\n\n```ts\nimport { TypeScriptComponent } from '@hallcor/pulumi-projen-project-types';\n\nconst project = new TypeScriptComponent({\n defaultReleaseBranch: 'main',\n devDeps: [\n '@hallcor/pulumi-projen-project-types',\n ],\n name: 'my-component',\n projenrcTs: true,\n\n // deps: [], /* Runtime dependencies of this module. */\n // description: undefined, /* The description is just a string that helps people understand the purpose of the package. */\n // packageName: undefined, /* The \"name\" in package.json. */\n});\nproject.synth();\n```\n\n#### Configuration Options\n\n- TODO\n\n## Publishing\n\nThe Pulumi Component project types also setup publishing workflows to publish\ngit tags and GitHub releases. By default these will\n\n> [!IMPORTANT]\n> The publishing workflows rely on [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version)\n> which means your commits must follow [Conventional Commits](https://conventionalcommits.org/)\n\n- Create an annotated tag on push to the `main` branch\n- Create a GitHub release for the tag when the tag is created\n\n### Release Trigger\n\nBy default the project will publish a new tag on every commit to the `main`\nbranch. This can be configured via the `releaseTrigger` option.\n\n- `scheduled`: Run the release workflow on a schedule\n- `manual`: Creates a publish task which can be run locally to publish a tag\n- `continuous`: Run the release workflow on every commit to the `main` branch\n\n**On a schedule**\n\n```ts\nnew TypeScriptComponent({\n ...,\n releaseTrigger: ReleaseTrigger.scheduled({ schedule: '0 0 * * 2' }), // run every tuesday\n});\n```\n\n**Manual**\n\n```ts\nnew TypeScriptComponent({\n ...,\n releaseTrigger: ReleaseTrigger.manual(),\n});\n```\n\n### GitHub Credentials\n\nFor the release workflow to create tags, specific credentials are needed.\nBy default it expects a GitHub secret variable named `PROJEN_GITHUB_TOKEN` with\n`read/write` access to `contents`. A separate token from the builtin `${{ secrets.GITHUB_TOKEN }}`\nis needed in order to trigger the downstream `release-github` workflow.\n\nThis can be customized using the `projenCredentials` option.\n\n**From a different secret**\n\n```ts\nnew TypeScriptComponent({\n ...,\n projenCredentials: GithubCredentials.fromPersonalAccessToken({ secret: 'MY_GITHUB_TOKEN' }),\n});\n```\n\n**From a GitHub app**\n```ts\nnew TypeScriptComponent({\n ...,\n projenCredentials: GithubCredentials.fromApp({\n privateKeySecret: 'MY_GITHUB_APP_PRIVATE_KEY',\n appIdSecret: 'MY_GITHUB_APP_ID',\n }),\n});\n```\n\n"
98
+ "markdown": "# Pulumi Projen Project Types\n\nCollection of [Projen](https://github.com/projen/projen) project types for use\nwith [Pulumi](https://www.pulumi.com/)\n\n## Getting Started\n\n_projen_ doesn't need to be installed. You will be using\n[npx](https://docs.npmjs.com/cli/v7/commands/npx) to run _projen_ which takes\ncare of all required setup steps.\n\nTo create a new project, run the following command and follow the instructions:\n\n```console\n$ mkdir my-project\n$ cd my-project\n$ npx projen new --from @hallcor/pulumi-projen-project-types PROJECT-TYPE\nšŸ¤– Synthesizing project...\n...\n```\n\nOnce your project is created, you can configure your project by editing\n`.projenrc.ts` or `.projenrc.py` and re-running `npx projen` to synthesize again.\n\n> The files generated by _projen_ are considered an \"implementation detail\" and\n> _projen_ protects them from being manually edited (most files are marked\n> read-only, and an \"anti tamper\" check is configured in the CI build workflow\n> to ensure that files are not updated during build).\n\n## Projen commands\n\nFor the TypeScript based projects the project commands can be viewed an run\nusing the package manager (e.g. `yarn build`, `yarn package`, etc). For\nnon-TypeScript based projects (i.e. Python) you can use projen to view and run\nproject commands.\n\nProjen is built around a standard build process for all projects. Each project\nwill have these standard [tasks](https://projen.io/docs/concepts/tasks).\n\n1. `default`: The \"default\" task that executes projen and synthesizes the project\n2. `pre-compile`: Task that runs prior to `compile`\n3. `compile`: Compiles the project (e.g. `tsc --build` for TypeScript projects)\n4. `post-compile`: Task that runs after `compile`\n5. `test`: Task that runs the project tests\n6. `package`: Task that runs steps to package the project for publishing\n\nThere is also a standard `build` task the chains the above 6 tasks in order.\n\nThere is a great [tasks guide] where you can find more information on adding new\ntasks, editing existing tasks, etc.\n\n**List available commands**\n\n```console\n$ npx projen --help\nprojen [command]\n\nCommands:\n projen new [PROJECT-TYPE-NAME] [OPTIONS] Creates a new projen project\n\n For a complete list of the available options for a specific project type, run:\n projen new [PROJECT-TYPE-NAME] --help\n projen build Full release build\n projen bump Bumps version based on latest git tag and generates a changelog entry\n projen clobber hard resets to HEAD of origin and cleans the local repo\n projen compile Only compile\n projen default Synthesize project files\n projen dist\n projen eject Remove projen from the project\n projen install Install and upgrade dependencies\n projen package Creates the distribution package\n projen post-compile Runs after successful compilation\n projen pre-compile Prepare the project for compilation\n projen publish:git Prepends the release changelog onto the project changelog, creates a release commit, and tags the release\n projen release Prepare a release from \"main\" branch\n projen test Run tests\n projen unbump Restores version to 0.0.0\n projen completion generate completion script\n\nOptions:\n --post Run post-synthesis steps such as installing dependencies. Use --no-post to skip [boolean] [default: true]\n -w, --watch Keep running and resynthesize when projenrc changes [boolean] [default: false]\n --debug Debug logs [boolean] [default: false]\n --rc path to .projenrc.js file [deprecated] [string] [default: \"/Users/chall/personal/pulumi-lambda-builders/.projenrc.js\"]\n --help Show help [boolean]\n --version Show version number\n\n```\n\n**Run a specific command**\n\n```console\n$ npx projen build\n```\n\n**Inspect a specific command**\n\n```console\n$ npx projen build -i\ndescription: Full release build\n- default\n description: Synthesize project files\n - exec: python .projenrc.py\n- pre-compile\n description: Prepare the project for compilation\n- compile\n description: Only compile\n- post-compile\n description: Runs after successful compilation\n- test\n description: Run tests\n - exec: npm ci\n - exec: pytest\n- package\n description: Creates the distribution package\n - dist\n - exec: mkdir -p dist\n - exec: cp version.json dist/\n - exec: git checkout version.json\n```\n\n## Project types\n\nCurrently supported project types\n\n- `PythonComponent`: Creates a Pulumi Python Component project\n- `TypeScriptComponent`: Creates a Pulumi TypeScript Component project\n\n### Pulumi Python Component\n\n```console\n$ mkdir my-python-component\n$ cd my-python-component\n$ npx projen new --from @hallcor/pulumi-projen-project-types python_component\n```\n\n\n#### Example\n\n```python\nfrom hallcor.pulumi_projen_project_types import PythonComponent\n\nproject = PythonComponent(\n module_name=\"pulumi_lambda_builders\",\n component_name=\"lambda-builders\",\n name=\"pulumi-lambda-builders\",\n version=\"0.1.0\",\n deps=[\n \"aws_lambda_builders\",\n ],\n dev_deps=[\n \"pyfakefs\",\n \"numpy\",\n \"hallcor.pulumi-projen-project-types\",\n ],\n)\n\nproject.synth()\n```\n\n#### Configuration Options\n\n- [componentName](https://github.com/corymhall/pulumi-projen-project-types/blob/main/API.md#componentnameoptional-)\nBy default the `name` of the of the Pulumi component will be taken from the\nproject `name`. This can be overridden by using the `componentName` property.\n\nFor a full list of input properties supported see the [Input Property Reference](https://github.com/corymhall/pulumi-projen-project-types/blob/main/API.md#typescriptprojectprops-)\n\n- [pulumi_python_options](https://github.com/corymhall/pulumi-projen-project-types/blob/main/API.md#pulumipythonoptionsoptional-)\nThis can be used to override some of the default Pulumi options. For example you\ncan specify a specific version of `pulumi` to use.\n\n```python\n\nproject = PythonComponent(\n ...,\n pulumi_python_options=PulumiPythonOptions(\n pulumi_version=\">=3.159 <4.0\" # this is the default value\n ),\n)\n```\n\nFor publishing related options see the [publishing section](#publishing)\n\n### Pulumi TypeScript Component\n\n```console\n$ mkdir my-python-component\n$ cd my-python-component\n$ npx projen new --from @hallcor/pulumi-projen-project-types type_script_component --name my-component\n```\n\n#### Example\n\n\n```ts\nimport { TypeScriptComponent } from '@hallcor/pulumi-projen-project-types';\n\nconst project = new TypeScriptComponent({\n defaultReleaseBranch: 'main',\n devDeps: [\n '@hallcor/pulumi-projen-project-types',\n ],\n name: 'my-component',\n projenrcTs: true,\n\n // deps: [], /* Runtime dependencies of this module. */\n // description: undefined, /* The description is just a string that helps people understand the purpose of the package. */\n // packageName: undefined, /* The \"name\" in package.json. */\n});\nproject.synth();\n```\n\n#### Configuration Options\n\n- TODO\n\n## Publishing\n\nThe Pulumi Component project types also setup publishing workflows to publish\ngit tags and GitHub releases. By default these will\n\n> [!IMPORTANT]\n> The publishing workflows rely on [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version)\n> which means your commits must follow [Conventional Commits](https://conventionalcommits.org/)\n\n- Create an annotated tag on push to the `main` branch\n- Create a GitHub release for the tag when the tag is created\n\n### Release Trigger\n\nBy default the project will publish a new tag on every commit to the `main`\nbranch. This can be configured via the `releaseTrigger` option.\n\n- `scheduled`: Run the release workflow on a schedule\n- `manual`: Creates a publish task which can be run locally to publish a tag\n- `continuous`: Run the release workflow on every commit to the `main` branch\n\n**On a schedule**\n\n```ts\nnew TypeScriptComponent({\n ...,\n releaseTrigger: ReleaseTrigger.scheduled({ schedule: '0 0 * * 2' }), // run every tuesday\n});\n```\n\n**Manual**\n\n```ts\nnew TypeScriptComponent({\n ...,\n releaseTrigger: ReleaseTrigger.manual(),\n});\n```\n\n### GitHub Credentials\n\nFor the release workflow to create tags, specific credentials are needed.\nBy default it expects a GitHub secret variable named `PROJEN_GITHUB_TOKEN` with\n`read/write` access to `contents`. A separate token from the builtin `${{ secrets.GITHUB_TOKEN }}`\nis needed in order to trigger the downstream `release-github` workflow.\n\nThis can be customized using the `projenCredentials` option.\n\n**From a different secret**\n\n```ts\nnew TypeScriptComponent({\n ...,\n projenCredentials: GithubCredentials.fromPersonalAccessToken({ secret: 'MY_GITHUB_TOKEN' }),\n});\n```\n\n**From a GitHub app**\n```ts\nnew TypeScriptComponent({\n ...,\n projenCredentials: GithubCredentials.fromApp({\n privateKeySecret: 'MY_GITHUB_APP_PRIVATE_KEY',\n appIdSecret: 'MY_GITHUB_APP_ID',\n }),\n});\n```\n\n## Pulumi ESC setup for GitHub Actions\n\nUse the `PulumiEscSetup` helper to add the [`pulumi/esc-action`](https://github.com/pulumi/esc-action) to generated workflows and control which secrets are exported. The helper keeps the step id stable (`esc`) so you can safely reference the action outputs from later steps.\n\n### Option-to-input mapping\n\n- `exportEnvironmentVariables` → `export-environment-variables`\n- `version` → `version`\n- `cloudUrl` → `cloud-url`\n- `keys` (deprecated) → `keys` and automatically sets `export-environment-variables` to `true` for backward compatibility\n\n### Examples\n\n**Export specific mappings with passthrough**\n\n```ts\nimport { ExportEnvironmentVariables, PulumiEscSetup } from '@hallcor/pulumi-projen-project-types';\n\nconst esc = PulumiEscSetup.fromPersonalAccessToken({\n environment: 'acme/catalog/prod',\n exportEnvironmentVariables: ExportEnvironmentVariables.fromMapping([\n 'AWS_ACCESS_KEY_ID', // direct mapping\n 'CD_TOKEN=DEPLOY_TOKEN', // remap the ESC secret DEPLOY_TOKEN to CD_TOKEN\n '*', // passthrough any remaining secrets\n ]),\n});\n\nproject.github?.addWorkflow('deploy').addJobs({\n deploy: {\n runsOn: ['ubuntu-latest'],\n steps: [\n { uses: 'actions/checkout@v4' },\n ...esc.setupSteps,\n { run: `echo \"Deploy token is ${esc.output('CD_TOKEN')}\"` },\n ],\n },\n});\n```\n\n**Pin ESC CLI version and use a custom Pulumi Cloud URL**\n\n```ts\nconst esc = PulumiEscSetup.fromPersonalAccessToken({\n environment: 'acme/catalog/prod',\n version: '0.10.0',\n cloudUrl: 'https://api.enterprise.pulumi.com',\n});\n```\n\n**Native OIDC authentication**\n\n```ts\nimport { JobPermission } from 'projen/lib/github/workflows-model';\n\nconst esc = PulumiEscSetup.fromOidcAuth({\n environment: 'acme/catalog/prod',\n organization: 'acme',\n});\n\nproject.github?.addWorkflow('ci').addJobs({\n build: {\n permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n runsOn: ['ubuntu-latest'],\n steps: [\n { uses: 'actions/checkout@v4' },\n ...esc.setupSteps,\n { run: 'echo \"Pulumi token is available via esc outputs\"' },\n ],\n },\n});\n```\n\n> [!NOTE]\n> ESC step outputs are available as `${{ steps.esc.outputs.<KEY> }}` or via `PulumiEscSetup.output('<KEY>')` when the helper is used. Existing workflows that still rely on the deprecated `keys` option continue to work, though new workflows should prefer `exportEnvironmentVariables` for fine-grained control.\n"
99
99
  },
100
100
  "repository": {
101
101
  "type": "git",
@@ -1700,13 +1700,15 @@
1700
1700
  "@hallcor/pulumi-projen-project-types.PulumiEscSetup": {
1701
1701
  "assembly": "@hallcor/pulumi-projen-project-types",
1702
1702
  "docs": {
1703
- "stability": "stable"
1703
+ "remarks": "The underlying ESC action exposes outputs for each secret in the ESC\nenvironment (including any remapped names when `exportEnvironmentVariables`\nis configured). A stable step id is used so downstream steps can reference\nthose outputs consistently.",
1704
+ "stability": "stable",
1705
+ "summary": "Utilities for configuring Pulumi ESC inside GitHub workflows."
1704
1706
  },
1705
1707
  "fqn": "@hallcor/pulumi-projen-project-types.PulumiEscSetup",
1706
1708
  "kind": "class",
1707
1709
  "locationInModule": {
1708
1710
  "filename": "src/pulumi-esc-setup.ts",
1709
- "line": 157
1711
+ "line": 165
1710
1712
  },
1711
1713
  "methods": [
1712
1714
  {
@@ -1716,7 +1718,7 @@
1716
1718
  },
1717
1719
  "locationInModule": {
1718
1720
  "filename": "src/pulumi-esc-setup.ts",
1719
- "line": 212
1721
+ "line": 222
1720
1722
  },
1721
1723
  "name": "fromOidcAuth",
1722
1724
  "parameters": [
@@ -1743,7 +1745,7 @@
1743
1745
  },
1744
1746
  "locationInModule": {
1745
1747
  "filename": "src/pulumi-esc-setup.ts",
1746
- "line": 166
1748
+ "line": 175
1747
1749
  },
1748
1750
  "name": "fromPersonalAccessToken",
1749
1751
  "parameters": [
@@ -1760,10 +1762,54 @@
1760
1762
  }
1761
1763
  },
1762
1764
  "static": true
1765
+ },
1766
+ {
1767
+ "docs": {
1768
+ "remarks": "Outputs are exposed for every secret in the ESC environment (including any\nremapped names defined via `exportEnvironmentVariables`). Use the output\nkey exactly as it appears in the ESC action output object.",
1769
+ "stability": "stable",
1770
+ "summary": "Returns a GitHub Actions expression for a Pulumi ESC output value."
1771
+ },
1772
+ "locationInModule": {
1773
+ "filename": "src/pulumi-esc-setup.ts",
1774
+ "line": 317
1775
+ },
1776
+ "name": "output",
1777
+ "parameters": [
1778
+ {
1779
+ "docs": {
1780
+ "summary": "The ESC output key to reference."
1781
+ },
1782
+ "name": "key",
1783
+ "type": {
1784
+ "primitive": "string"
1785
+ }
1786
+ }
1787
+ ],
1788
+ "returns": {
1789
+ "type": {
1790
+ "primitive": "string"
1791
+ }
1792
+ }
1763
1793
  }
1764
1794
  ],
1765
1795
  "name": "PulumiEscSetup",
1766
1796
  "properties": [
1797
+ {
1798
+ "docs": {
1799
+ "remarks": "Use this to build references to the\naction outputs.",
1800
+ "stability": "stable",
1801
+ "summary": "The step id assigned to the ESC action."
1802
+ },
1803
+ "immutable": true,
1804
+ "locationInModule": {
1805
+ "filename": "src/pulumi-esc-setup.ts",
1806
+ "line": 304
1807
+ },
1808
+ "name": "escActionStepId",
1809
+ "type": {
1810
+ "primitive": "string"
1811
+ }
1812
+ },
1767
1813
  {
1768
1814
  "docs": {
1769
1815
  "stability": "stable"
@@ -1771,7 +1817,7 @@
1771
1817
  "immutable": true,
1772
1818
  "locationInModule": {
1773
1819
  "filename": "src/pulumi-esc-setup.ts",
1774
- "line": 281
1820
+ "line": 292
1775
1821
  },
1776
1822
  "name": "setupSteps",
1777
1823
  "type": {
@@ -1790,7 +1836,7 @@
1790
1836
  "immutable": true,
1791
1837
  "locationInModule": {
1792
1838
  "filename": "src/pulumi-esc-setup.ts",
1793
- "line": 285
1839
+ "line": 296
1794
1840
  },
1795
1841
  "name": "keys",
1796
1842
  "optional": true,
@@ -1810,7 +1856,7 @@
1810
1856
  "immutable": true,
1811
1857
  "locationInModule": {
1812
1858
  "filename": "src/pulumi-esc-setup.ts",
1813
- "line": 277
1859
+ "line": 288
1814
1860
  },
1815
1861
  "name": "permissions",
1816
1862
  "optional": true,
@@ -9476,6 +9522,6 @@
9476
9522
  "symbolId": "src/structs/typescript-options/project-props:TypeScriptProjectProps"
9477
9523
  }
9478
9524
  },
9479
- "version": "0.0.62",
9480
- "fingerprint": "P5n6//1ShM5sDdC+p6xbu9vFxz1toWi5vg4gUIMhkWQ="
9525
+ "version": "0.0.64",
9526
+ "fingerprint": "+BwQuzYtj/vLmjoklwR8LSl9mDBhitzKeN7AndeKYmQ="
9481
9527
  }
package/API.md CHANGED
@@ -11623,6 +11623,40 @@ public readonly permissions: JobPermissions;
11623
11623
 
11624
11624
  ### PulumiEscSetup <a name="PulumiEscSetup" id="@hallcor/pulumi-projen-project-types.PulumiEscSetup"></a>
11625
11625
 
11626
+ Utilities for configuring Pulumi ESC inside GitHub workflows.
11627
+
11628
+ The underlying ESC action exposes outputs for each secret in the ESC
11629
+ environment (including any remapped names when `exportEnvironmentVariables`
11630
+ is configured). A stable step id is used so downstream steps can reference
11631
+ those outputs consistently.
11632
+
11633
+ #### Methods <a name="Methods" id="Methods"></a>
11634
+
11635
+ | **Name** | **Description** |
11636
+ | --- | --- |
11637
+ | <code><a href="#@hallcor/pulumi-projen-project-types.PulumiEscSetup.output">output</a></code> | Returns a GitHub Actions expression for a Pulumi ESC output value. |
11638
+
11639
+ ---
11640
+
11641
+ ##### `output` <a name="output" id="@hallcor/pulumi-projen-project-types.PulumiEscSetup.output"></a>
11642
+
11643
+ ```typescript
11644
+ public output(key: string): string
11645
+ ```
11646
+
11647
+ Returns a GitHub Actions expression for a Pulumi ESC output value.
11648
+
11649
+ Outputs are exposed for every secret in the ESC environment (including any
11650
+ remapped names defined via `exportEnvironmentVariables`). Use the output
11651
+ key exactly as it appears in the ESC action output object.
11652
+
11653
+ ###### `key`<sup>Required</sup> <a name="key" id="@hallcor/pulumi-projen-project-types.PulumiEscSetup.output.parameter.key"></a>
11654
+
11655
+ - *Type:* string
11656
+
11657
+ The ESC output key to reference.
11658
+
11659
+ ---
11626
11660
 
11627
11661
  #### Static Functions <a name="Static Functions" id="Static Functions"></a>
11628
11662
 
@@ -11672,12 +11706,28 @@ secret can be specified here.
11672
11706
 
11673
11707
  | **Name** | **Type** | **Description** |
11674
11708
  | --- | --- | --- |
11709
+ | <code><a href="#@hallcor/pulumi-projen-project-types.PulumiEscSetup.property.escActionStepId">escActionStepId</a></code> | <code>string</code> | The step id assigned to the ESC action. |
11675
11710
  | <code><a href="#@hallcor/pulumi-projen-project-types.PulumiEscSetup.property.setupSteps">setupSteps</a></code> | <code>projen.github.workflows.JobStep[]</code> | *No description.* |
11676
11711
  | <code><a href="#@hallcor/pulumi-projen-project-types.PulumiEscSetup.property.keys">keys</a></code> | <code>string[]</code> | *No description.* |
11677
11712
  | <code><a href="#@hallcor/pulumi-projen-project-types.PulumiEscSetup.property.permissions">permissions</a></code> | <code>projen.github.workflows.JobPermissions</code> | *No description.* |
11678
11713
 
11679
11714
  ---
11680
11715
 
11716
+ ##### `escActionStepId`<sup>Required</sup> <a name="escActionStepId" id="@hallcor/pulumi-projen-project-types.PulumiEscSetup.property.escActionStepId"></a>
11717
+
11718
+ ```typescript
11719
+ public readonly escActionStepId: string;
11720
+ ```
11721
+
11722
+ - *Type:* string
11723
+
11724
+ The step id assigned to the ESC action.
11725
+
11726
+ Use this to build references to the
11727
+ action outputs.
11728
+
11729
+ ---
11730
+
11681
11731
  ##### `setupSteps`<sup>Required</sup> <a name="setupSteps" id="@hallcor/pulumi-projen-project-types.PulumiEscSetup.property.setupSteps"></a>
11682
11732
 
11683
11733
  ```typescript
package/README.md CHANGED
@@ -283,3 +283,77 @@ new TypeScriptComponent({
283
283
  });
284
284
  ```
285
285
 
286
+ ## Pulumi ESC setup for GitHub Actions
287
+
288
+ Use the `PulumiEscSetup` helper to add the [`pulumi/esc-action`](https://github.com/pulumi/esc-action) to generated workflows and control which secrets are exported. The helper keeps the step id stable (`esc`) so you can safely reference the action outputs from later steps.
289
+
290
+ ### Option-to-input mapping
291
+
292
+ - `exportEnvironmentVariables` → `export-environment-variables`
293
+ - `version` → `version`
294
+ - `cloudUrl` → `cloud-url`
295
+ - `keys` (deprecated) → `keys` and automatically sets `export-environment-variables` to `true` for backward compatibility
296
+
297
+ ### Examples
298
+
299
+ **Export specific mappings with passthrough**
300
+
301
+ ```ts
302
+ import { ExportEnvironmentVariables, PulumiEscSetup } from '@hallcor/pulumi-projen-project-types';
303
+
304
+ const esc = PulumiEscSetup.fromPersonalAccessToken({
305
+ environment: 'acme/catalog/prod',
306
+ exportEnvironmentVariables: ExportEnvironmentVariables.fromMapping([
307
+ 'AWS_ACCESS_KEY_ID', // direct mapping
308
+ 'CD_TOKEN=DEPLOY_TOKEN', // remap the ESC secret DEPLOY_TOKEN to CD_TOKEN
309
+ '*', // passthrough any remaining secrets
310
+ ]),
311
+ });
312
+
313
+ project.github?.addWorkflow('deploy').addJobs({
314
+ deploy: {
315
+ runsOn: ['ubuntu-latest'],
316
+ steps: [
317
+ { uses: 'actions/checkout@v4' },
318
+ ...esc.setupSteps,
319
+ { run: `echo "Deploy token is ${esc.output('CD_TOKEN')}"` },
320
+ ],
321
+ },
322
+ });
323
+ ```
324
+
325
+ **Pin ESC CLI version and use a custom Pulumi Cloud URL**
326
+
327
+ ```ts
328
+ const esc = PulumiEscSetup.fromPersonalAccessToken({
329
+ environment: 'acme/catalog/prod',
330
+ version: '0.10.0',
331
+ cloudUrl: 'https://api.enterprise.pulumi.com',
332
+ });
333
+ ```
334
+
335
+ **Native OIDC authentication**
336
+
337
+ ```ts
338
+ import { JobPermission } from 'projen/lib/github/workflows-model';
339
+
340
+ const esc = PulumiEscSetup.fromOidcAuth({
341
+ environment: 'acme/catalog/prod',
342
+ organization: 'acme',
343
+ });
344
+
345
+ project.github?.addWorkflow('ci').addJobs({
346
+ build: {
347
+ permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },
348
+ runsOn: ['ubuntu-latest'],
349
+ steps: [
350
+ { uses: 'actions/checkout@v4' },
351
+ ...esc.setupSteps,
352
+ { run: 'echo "Pulumi token is available via esc outputs"' },
353
+ ],
354
+ },
355
+ });
356
+ ```
357
+
358
+ > [!NOTE]
359
+ > ESC step outputs are available as `${{ steps.esc.outputs.<KEY> }}` or via `PulumiEscSetup.output('<KEY>')` when the helper is used. Existing workflows that still rely on the deprecated `keys` option continue to work, though new workflows should prefer `exportEnvironmentVariables` for fine-grained control.
@@ -91,5 +91,5 @@ class GithubCredentials {
91
91
  }
92
92
  exports.GithubCredentials = GithubCredentials;
93
93
  _a = JSII_RTTI_SYMBOL_1;
94
- GithubCredentials[_a] = { fqn: "@hallcor/pulumi-projen-project-types.GithubCredentials", version: "0.0.62" };
94
+ GithubCredentials[_a] = { fqn: "@hallcor/pulumi-projen-project-types.GithubCredentials", version: "0.0.64" };
95
95
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2l0aHViLWNyZWRlbnRpYWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2dpdGh1Yi1jcmVkZW50aWFscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQVlBOztHQUVHO0FBQ0gsTUFBYSxpQkFBaUI7SUFDNUI7Ozs7Ozs7O09BUUc7SUFDSSxNQUFNLENBQUMsdUJBQXVCLENBQ25DLFVBQXVELEVBQUU7UUFFekQsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7UUFDMUQsT0FBTyxJQUFJLGlCQUFpQixDQUFDO1lBQzNCLFVBQVUsRUFBRSxPQUFPLENBQUMsY0FBYztnQkFDaEMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsVUFBVTtnQkFDbkMsQ0FBQyxDQUFDLEVBQUU7WUFDTixRQUFRLEVBQUUsUUFBUSxNQUFNLElBQUksT0FBTyxDQUFDLE1BQU0sSUFBSSxxQkFBcUIsS0FBSztTQUN6RSxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7Ozs7Ozs7Ozs7T0FVRztJQUNJLE1BQU0sQ0FBQyxPQUFPLENBQUMsVUFBdUMsRUFBRTtRQUM3RCxNQUFNLGNBQWMsR0FBRyxPQUFPLENBQUMsY0FBYyxJQUFJLHNCQUFzQixDQUFDO1FBQ3hFLE1BQU0sZ0JBQWdCLEdBQ3BCLE9BQU8sQ0FBQyxnQkFBZ0IsSUFBSSx3QkFBd0IsQ0FBQztRQUV2RCxNQUFNLFVBQVUsR0FBYyxFQUFFLENBQUM7UUFDakMsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7UUFDMUQsSUFBSSxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDM0IsSUFBSSxPQUFPLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUNoQyxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUM7b0JBQzFELE1BQU0sSUFBSSxLQUFLLENBQ2Isd0RBQXdELENBQ3pELENBQUM7Z0JBQ0osQ0FBQztnQkFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGdCQUFnQixDQUFDLEVBQUUsQ0FBQztvQkFDNUQsTUFBTSxJQUFJLEtBQUssQ0FDYiwwREFBMEQsQ0FDM0QsQ0FBQztnQkFDSixDQUFDO1lBQ0gsQ0FBQztZQUNELFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ3hELENBQUM7UUFFRCxPQUFPLElBQUksaUJBQWlCLENBQUM7WUFDM0IsV0FBVyxFQUFFLE9BQU8sQ0FBQyxjQUFjLEVBQUUsV0FBVztZQUNoRCxVQUFVLEVBQUU7Z0JBQ1YsR0FBRyxVQUFVO2dCQUNiO29CQUNFLElBQUksRUFBRSxnQkFBZ0I7b0JBQ3RCLEVBQUUsRUFBRSxnQkFBZ0I7b0JBQ3BCLElBQUksRUFBRSxvQ0FBb0M7b0JBQzFDLElBQUksRUFBRTt3QkFDSixRQUFRLEVBQUUsUUFBUSxNQUFNLElBQUksY0FBYyxLQUFLLEVBQUUsbUJBQW1CO3dCQUNwRSxhQUFhLEVBQUUsUUFBUSxNQUFNLElBQUksZ0JBQWdCLEtBQUs7cUJBQ3ZEO2lCQUNGO2FBQ0Y7WUFDRCxRQUFRLEVBQUUsMkNBQTJDO1NBQ3RELENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxZQUFxQyxPQUFpQztRQUFqQyxZQUFPLEdBQVAsT0FBTyxDQUEwQjtJQUFHLENBQUM7SUFFMUU7O09BRUc7SUFDSCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRUQsSUFBVyxXQUFXO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUM7SUFDbEMsQ0FBQztJQUVEOzs7T0FHRztJQUNILElBQVcsUUFBUTtRQUNqQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO0lBQy9CLENBQUM7O0FBN0ZILDhDQThGQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEpvYlBlcm1pc3Npb25zLCBKb2JTdGVwIH0gZnJvbSAncHJvamVuL2xpYi9naXRodWIvd29ya2Zsb3dzLW1vZGVsJztcbmltcG9ydCB7XG4gIEdpdGh1YkNyZWRlbnRpYWxzQXBwT3B0aW9ucyxcbiAgR2l0aHViQ3JlZGVudGlhbHNQZXJzb25hbEFjY2Vzc1Rva2VuT3B0aW9ucyxcbn0gZnJvbSAnLi9zdHJ1Y3RzJztcblxuaW50ZXJmYWNlIEdpdGh1YkNyZWRlbnRpYWxzT3B0aW9ucyB7XG4gIHJlYWRvbmx5IHNldHVwU3RlcHM6IEpvYlN0ZXBbXTtcbiAgcmVhZG9ubHkgdG9rZW5SZWY6IHN0cmluZztcbiAgcmVhZG9ubHkgcGVybWlzc2lvbnM/OiBKb2JQZXJtaXNzaW9ucztcbn1cblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgbWV0aG9kIG9mIHByb3ZpZGluZyBHaXRIdWIgQVBJIGFjY2VzcyBmb3IgcHJvamVuIHdvcmtmbG93cy5cbiAqL1xuZXhwb3J0IGNsYXNzIEdpdGh1YkNyZWRlbnRpYWxzIHtcbiAgLyoqXG4gICAqIFByb3ZpZGUgQVBJIGFjY2VzcyB0aHJvdWdoIGEgR2l0SHViIHBlcnNvbmFsIGFjY2VzcyB0b2tlbi5cbiAgICpcbiAgICogVGhlIHRva2VuIG11c3QgYmUgYWRkZWQgYXMgYSBzZWNyZXQgdG8gdGhlIEdpdEh1YiByZXBvLCBhbmQgdGhlIG5hbWUgb2YgdGhlXG4gICAqIHNlY3JldCBjYW4gYmUgc3BlY2lmaWVkIGhlcmUuXG4gICAqXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYXV0aGVudGljYXRpb24va2VlcGluZy15b3VyLWFjY291bnQtYW5kLWRhdGEtc2VjdXJlL2NyZWF0aW5nLWEtcGVyc29uYWwtYWNjZXNzLXRva2VuXG4gICAqIEBkZWZhdWx0IC0gYSBzZWNyZXQgbmFtZWQgXCJQUk9KRU5fR0lUSFVCX1RPS0VOXCJcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZnJvbVBlcnNvbmFsQWNjZXNzVG9rZW4oXG4gICAgb3B0aW9uczogR2l0aHViQ3JlZGVudGlhbHNQZXJzb25hbEFjY2Vzc1Rva2VuT3B0aW9ucyA9IHt9LFxuICApIHtcbiAgICBjb25zdCBwcmVmaXggPSBvcHRpb25zLnB1bHVtaUVzY1NldHVwID8gJ2VudicgOiAnc2VjcmV0cyc7XG4gICAgcmV0dXJuIG5ldyBHaXRodWJDcmVkZW50aWFscyh7XG4gICAgICBzZXR1cFN0ZXBzOiBvcHRpb25zLnB1bHVtaUVzY1NldHVwXG4gICAgICAgID8gb3B0aW9ucy5wdWx1bWlFc2NTZXR1cC5zZXR1cFN0ZXBzXG4gICAgICAgIDogW10sXG4gICAgICB0b2tlblJlZjogYFxcJHt7ICR7cHJlZml4fS4ke29wdGlvbnMuc2VjcmV0ID8/ICdQUk9KRU5fR0lUSFVCX1RPS0VOJ30gfX1gLFxuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIFByb3ZpZGUgQVBJIGFjY2VzcyB0aHJvdWdoIGEgR2l0SHViIEFwcC5cbiAgICpcbiAgICogVGhlIEdpdEh1YiBBcHAgbXVzdCBiZSBpbnN0YWxsZWQgb24gdGhlIEdpdEh1YiByZXBvLCBpdHMgQXBwIElEIGFuZCBhXG4gICAqIHByaXZhdGUga2V5IG11c3QgYmUgYWRkZWQgYXMgc2VjcmV0cyB0byB0aGUgcmVwby4gVGhlIG5hbWUgb2YgdGhlIHNlY3JldHNcbiAgICogY2FuIGJlIHNwZWNpZmllZCBoZXJlLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZG9jcy5naXRodWIuY29tL2VuL2RldmVsb3BlcnMvYXBwcy9idWlsZGluZy1naXRodWItYXBwcy9jcmVhdGluZy1hLWdpdGh1Yi1hcHBcbiAgICogQHNlZSBodHRwczovL3Byb2plbi5pby9kb2NzL2ludGVncmF0aW9ucy9naXRodWIvI2dpdGh1Yi1hcHBcbiAgICogQGRlZmF1bHQgLSBhcHAgaWQgc3RvcmVkIGluIFwiUFJPSkVOX0FQUF9DTElFTlRfSURcIiBhbmQgcHJpdmF0ZSBrZXkgc3RvcmVkIGluIFwiUFJPSkVOX0FQUF9QUklWQVRFX0tFWVwiIHdpdGggYWxsIHBlcm1pc3Npb25zIGF0dGFjaGVkIHRvIHRoZSBhcHBcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZnJvbUFwcChvcHRpb25zOiBHaXRodWJDcmVkZW50aWFsc0FwcE9wdGlvbnMgPSB7fSkge1xuICAgIGNvbnN0IGNsaWVudElkU2VjcmV0ID0gb3B0aW9ucy5jbGllbnRJZFNlY3JldCA/PyAnUFJPSkVOX0FQUF9DTElFTlRfSUQnO1xuICAgIGNvbnN0IHByaXZhdGVLZXlTZWNyZXQgPVxuICAgICAgb3B0aW9ucy5wcml2YXRlS2V5U2VjcmV0ID8/ICdQUk9KRU5fQVBQX1BSSVZBVEVfS0VZJztcblxuICAgIGNvbnN0IHNldHVwU3RlcHM6IEpvYlN0ZXBbXSA9IFtdO1xuICAgIGNvbnN0IHByZWZpeCA9IG9wdGlvbnMucHVsdW1pRXNjU2V0dXAgPyAnZW52JyA6ICdzZWNyZXRzJztcbiAgICBpZiAob3B0aW9ucy5wdWx1bWlFc2NTZXR1cCkge1xuICAgICAgaWYgKG9wdGlvbnMucHVsdW1pRXNjU2V0dXAua2V5cykge1xuICAgICAgICBpZiAoIW9wdGlvbnMucHVsdW1pRXNjU2V0dXAua2V5cy5pbmNsdWRlcyhjbGllbnRJZFNlY3JldCkpIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgICBgY2xpZW50SWRTZWNyZXQgd2FzIG5vdCBpbmNsdWRlZCBpbiBwdWx1bWlFc2NTZXR1cC5rZXlzYCxcbiAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICAgIGlmICghb3B0aW9ucy5wdWx1bWlFc2NTZXR1cC5rZXlzLmluY2x1ZGVzKHByaXZhdGVLZXlTZWNyZXQpKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgICAgYHByaXZhdGVLZXlTZWNyZXQgd2FzIG5vdCBpbmNsdWRlZCBpbiBwdWx1bWlFc2NTZXR1cC5rZXlzYCxcbiAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBzZXR1cFN0ZXBzLnB1c2goLi4ub3B0aW9ucy5wdWx1bWlFc2NTZXR1cC5zZXR1cFN0ZXBzKTtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV3IEdpdGh1YkNyZWRlbnRpYWxzKHtcbiAgICAgIHBlcm1pc3Npb25zOiBvcHRpb25zLnB1bHVtaUVzY1NldHVwPy5wZXJtaXNzaW9ucyxcbiAgICAgIHNldHVwU3RlcHM6IFtcbiAgICAgICAgLi4uc2V0dXBTdGVwcyxcbiAgICAgICAge1xuICAgICAgICAgIG5hbWU6ICdHZW5lcmF0ZSB0b2tlbicsXG4gICAgICAgICAgaWQ6ICdnZW5lcmF0ZV90b2tlbicsXG4gICAgICAgICAgdXNlczogJ2FjdGlvbnMvY3JlYXRlLWdpdGh1Yi1hcHAtdG9rZW5AdjEnLFxuICAgICAgICAgIHdpdGg6IHtcbiAgICAgICAgICAgICdhcHAtaWQnOiBgXFwke3sgJHtwcmVmaXh9LiR7Y2xpZW50SWRTZWNyZXR9IH19YCwgLy8gY2FuIGJlIGNsaWVudC1pZFxuICAgICAgICAgICAgJ3ByaXZhdGUta2V5JzogYFxcJHt7ICR7cHJlZml4fS4ke3ByaXZhdGVLZXlTZWNyZXR9IH19YCxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIHRva2VuUmVmOiAnJHt7IHN0ZXBzLmdlbmVyYXRlX3Rva2VuLm91dHB1dHMudG9rZW4gfX0nLFxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IG9wdGlvbnM6IEdpdGh1YkNyZWRlbnRpYWxzT3B0aW9ucykge31cblxuICAvKipcbiAgICogU2V0dXAgc3RlcHMgdG8gb2J0YWluIEdpdEh1YiBjcmVkZW50aWFscy5cbiAgICovXG4gIHB1YmxpYyBnZXQgc2V0dXBTdGVwcygpOiBKb2JTdGVwW10ge1xuICAgIHJldHVybiBbLi4udGhpcy5vcHRpb25zLnNldHVwU3RlcHNdO1xuICB9XG5cbiAgcHVibGljIGdldCBwZXJtaXNzaW9ucygpOiBKb2JQZXJtaXNzaW9ucyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIHRoaXMub3B0aW9ucy5wZXJtaXNzaW9ucztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgdmFsdWUgdG8gdXNlIGluIGEgd29ya2Zsb3cgd2hlbiBhIEdpdEh1YiB0b2tlbiBpcyBleHBlY3RlZC4gVGhpc1xuICAgKiB0eXBpY2FsbHkgbG9va3MgbGlrZSBcIiR7eyBzb21lLnBhdGgudG8uYS52YWx1ZSB9fVwiLlxuICAgKi9cbiAgcHVibGljIGdldCB0b2tlblJlZigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLm9wdGlvbnMudG9rZW5SZWY7XG4gIH1cbn1cbiJdfQ==
@@ -99,8 +99,17 @@ export interface PulumiEscPersonalAccessTokenOptions extends PulumiEscActionOpti
99
99
  */
100
100
  readonly secret?: string;
101
101
  }
102
+ /**
103
+ * Utilities for configuring Pulumi ESC inside GitHub workflows.
104
+ *
105
+ * The underlying ESC action exposes outputs for each secret in the ESC
106
+ * environment (including any remapped names when `exportEnvironmentVariables`
107
+ * is configured). A stable step id is used so downstream steps can reference
108
+ * those outputs consistently.
109
+ */
102
110
  export declare class PulumiEscSetup {
103
111
  private readonly options;
112
+ private static readonly ESC_ACTION_STEP_ID;
104
113
  /**
105
114
  * Provides ESC access using a personal access token.
106
115
  *
@@ -119,4 +128,19 @@ export declare class PulumiEscSetup {
119
128
  get permissions(): JobPermissions | undefined;
120
129
  get setupSteps(): JobStep[];
121
130
  get keys(): string[] | undefined;
131
+ /**
132
+ * The step id assigned to the ESC action. Use this to build references to the
133
+ * action outputs.
134
+ */
135
+ get escActionStepId(): string;
136
+ /**
137
+ * Returns a GitHub Actions expression for a Pulumi ESC output value.
138
+ *
139
+ * Outputs are exposed for every secret in the ESC environment (including any
140
+ * remapped names defined via `exportEnvironmentVariables`). Use the output
141
+ * key exactly as it appears in the ESC action output object.
142
+ *
143
+ * @param key The ESC output key to reference.
144
+ */
145
+ output(key: string): string;
122
146
  }
@@ -44,7 +44,7 @@ class ExportEnvironmentVariables {
44
44
  }
45
45
  exports.ExportEnvironmentVariables = ExportEnvironmentVariables;
46
46
  _a = JSII_RTTI_SYMBOL_1;
47
- ExportEnvironmentVariables[_a] = { fqn: "@hallcor/pulumi-projen-project-types.ExportEnvironmentVariables", version: "0.0.62" };
47
+ ExportEnvironmentVariables[_a] = { fqn: "@hallcor/pulumi-projen-project-types.ExportEnvironmentVariables", version: "0.0.64" };
48
48
  var PulumiTokenType;
49
49
  (function (PulumiTokenType) {
50
50
  PulumiTokenType["ORG"] = "urn:pulumi:token-type:access_token:organization";
@@ -79,7 +79,15 @@ class PulumiToken {
79
79
  }
80
80
  exports.PulumiToken = PulumiToken;
81
81
  _b = JSII_RTTI_SYMBOL_1;
82
- PulumiToken[_b] = { fqn: "@hallcor/pulumi-projen-project-types.PulumiToken", version: "0.0.62" };
82
+ PulumiToken[_b] = { fqn: "@hallcor/pulumi-projen-project-types.PulumiToken", version: "0.0.64" };
83
+ /**
84
+ * Utilities for configuring Pulumi ESC inside GitHub workflows.
85
+ *
86
+ * The underlying ESC action exposes outputs for each secret in the ESC
87
+ * environment (including any remapped names when `exportEnvironmentVariables`
88
+ * is configured). A stable step id is used so downstream steps can reference
89
+ * those outputs consistently.
90
+ */
83
91
  class PulumiEscSetup {
84
92
  /**
85
93
  * Provides ESC access using a personal access token.
@@ -108,6 +116,7 @@ class PulumiEscSetup {
108
116
  keys: options.keys,
109
117
  setupSteps: [
110
118
  {
119
+ id: PulumiEscSetup.ESC_ACTION_STEP_ID,
111
120
  uses: 'pulumi/esc-action@v1',
112
121
  with: {
113
122
  environment: options.environment,
@@ -165,6 +174,7 @@ class PulumiEscSetup {
165
174
  }
166
175
  const setupSteps = [
167
176
  {
177
+ id: PulumiEscSetup.ESC_ACTION_STEP_ID,
168
178
  uses: 'pulumi/esc-action@v1',
169
179
  with: escActionInputs,
170
180
  },
@@ -189,8 +199,28 @@ class PulumiEscSetup {
189
199
  get keys() {
190
200
  return this.options.keys;
191
201
  }
202
+ /**
203
+ * The step id assigned to the ESC action. Use this to build references to the
204
+ * action outputs.
205
+ */
206
+ get escActionStepId() {
207
+ return PulumiEscSetup.ESC_ACTION_STEP_ID;
208
+ }
209
+ /**
210
+ * Returns a GitHub Actions expression for a Pulumi ESC output value.
211
+ *
212
+ * Outputs are exposed for every secret in the ESC environment (including any
213
+ * remapped names defined via `exportEnvironmentVariables`). Use the output
214
+ * key exactly as it appears in the ESC action output object.
215
+ *
216
+ * @param key The ESC output key to reference.
217
+ */
218
+ output(key) {
219
+ return `\${{ steps.${this.escActionStepId}.outputs.${key} }}`;
220
+ }
192
221
  }
193
222
  exports.PulumiEscSetup = PulumiEscSetup;
194
223
  _c = JSII_RTTI_SYMBOL_1;
195
- PulumiEscSetup[_c] = { fqn: "@hallcor/pulumi-projen-project-types.PulumiEscSetup", version: "0.0.62" };
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pulumi-esc-setup.js","sourceRoot":"","sources":["../src/pulumi-esc-setup.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  JobPermission,\n  JobPermissions,\n  JobStep,\n} from 'projen/lib/github/workflows-model';\n\ninterface PulumiEscSetupOptions {\n  readonly setupSteps: JobStep[];\n  readonly keys?: string[];\n  readonly permissions?: JobPermissions;\n}\n\n/**\n * Configuration for exporting environment variables from ESC.\n */\nexport class ExportEnvironmentVariables {\n  private constructor(private readonly value: boolean | string[]) {}\n\n  /**\n   * Do not export environment variables. This is the default.\n   */\n  public static disabled(): ExportEnvironmentVariables {\n    return new ExportEnvironmentVariables(false);\n  }\n\n  /**\n   * Provide explicit mappings to export.\n   *\n   * Each entry should follow the ESC action mapping format, for example\n   * `GITHUB_TOKEN=PULUMI_BOT_TOKEN` or `AWS_ACCESS_KEY_ID`.\n   */\n  public static fromMapping(mapping: string[]): ExportEnvironmentVariables {\n    return new ExportEnvironmentVariables(mapping);\n  }\n\n  /**\n   * @internal\n   */\n  public _render(): boolean | string {\n    if (Array.isArray(this.value)) {\n      return this.value.join('\\n');\n    }\n    return this.value;\n  }\n\n  /**\n   * @internal\n   */\n  public _usesMapping(): boolean {\n    return Array.isArray(this.value);\n  }\n}\n\nexport interface PulumiEscActionOptions {\n  /**\n   * The ESC environment to open\n   */\n  readonly environment: string;\n\n  /**\n   * list of keys to inject into the current action/workflow environment.\n   *\n   * @default all keys from the environment will be injected\n   * @deprecated use `exportEnvironmentVariables` instead\n   */\n  readonly keys?: string[];\n\n  /**\n   * Whether to export environment variables from ESC.\n   *\n   * Can also be an array of mapping strings to explicitly control which variables\n   * are exported (joined with newlines for the action input).\n   *\n   * @default ExportEnvironmentVariables.disabled()\n   */\n  readonly exportEnvironmentVariables?: ExportEnvironmentVariables;\n\n  /**\n   * The Pulumi Cloud URL to target.\n   *\n   * @default - Use the default Pulumi Cloud URL\n   */\n  readonly cloudUrl?: string;\n}\n\nexport enum PulumiTokenType {\n  ORG = 'urn:pulumi:token-type:access_token:organization',\n  TEAM = 'urn:pulumi:token-type:access_token:team',\n  PERSONAL = 'urn:pulumi:token-type:access_token:personal',\n}\n\nexport abstract class PulumiToken {\n  /**\n   * Note: organization tokens are only valid for enterprise organizations\n   */\n  public static fromOrgToken(scope?: string): PulumiToken {\n    return {\n      scope,\n      tokenType: PulumiTokenType.ORG,\n    };\n  }\n\n  /**\n   * @param userName the username of the Pulumi user to request the user token. Defaults to the organization name\n   */\n  public static fromPersonalToken(userName?: string): PulumiToken {\n    return {\n      scope: `user:${userName ?? 'USER_NAME'}`,\n      tokenType: PulumiTokenType.PERSONAL,\n    };\n  }\n\n  public static fromTeamToken(teamName: string): PulumiToken {\n    return {\n      scope: `team:${teamName}`,\n      tokenType: PulumiTokenType.TEAM,\n    };\n  }\n\n  /**\n   * The token scope. Scope is only optional for\n   * organization tokens\n   */\n  public abstract scope?: string;\n  public abstract tokenType: PulumiTokenType;\n}\n\nexport interface PulumiAuthOptions extends PulumiEscActionOptions {\n  /**\n   * The Pulumi organization to authenticate with\n   */\n  readonly organization: string;\n\n  /**\n   * The type of pulumi token to get\n   *\n   *\n   * @default PulumiToken.fromPersonalToken()\n   */\n  readonly requestedToken?: PulumiToken;\n\n  /**\n   * The requested expiration time (in seconds) for the generated token when\n   * using ESC OIDC authentication.\n   */\n  readonly oidcTokenExpiration?: number;\n}\n\nexport interface PulumiEscPersonalAccessTokenOptions\n  extends PulumiEscActionOptions {\n  /**\n   * The secret name for the access token\n   */\n  readonly secret?: string;\n}\n\nexport class PulumiEscSetup {\n  /**\n   * Provides ESC access using a personal access token.\n   *\n   * The token must be added as a secret to the GitHub repo, and the name of the\n   * secret can be specified here.\n   *\n   * @default - a secret named \"PULUMI_ACCESS_TOKEN\"\n   */\n  public static fromPersonalAccessToken(\n    options: PulumiEscPersonalAccessTokenOptions,\n  ) {\n    const secret = options.secret ?? 'PULUMI_ACCESS_TOKEN';\n    if (options.keys && options.exportEnvironmentVariables) {\n      throw new Error(\n        'Do not provide both \"keys\" and \"exportEnvironmentVariables\". Specify only one.',\n      );\n    }\n    const exportEnvironmentVariables =\n      options.exportEnvironmentVariables ?? ExportEnvironmentVariables.disabled();\n\n    let keys: string | undefined;\n    let exportEnvironmentVariablesInput: boolean | string =\n      exportEnvironmentVariables._render();\n\n    if (options.keys) {\n      keys = options.keys.join(',');\n      exportEnvironmentVariablesInput = true;\n    } else if (exportEnvironmentVariables._usesMapping()) {\n      keys = undefined;\n    }\n\n    return new PulumiEscSetup({\n      keys: options.keys,\n      setupSteps: [\n        {\n          uses: 'pulumi/esc-action@v1',\n          with: {\n            environment: options.environment,\n            keys,\n            'export-environment-variables': exportEnvironmentVariablesInput,\n            'cloud-url': options.cloudUrl,\n          },\n          env: {\n            PULUMI_ACCESS_TOKEN: `\\${{ secrets.${secret} }}`,\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Provides ESC access using OIDC authentication via the pulumi/auth-actions\n   * action.\n   */\n  public static fromOidcAuth(options: PulumiAuthOptions) {\n    const token =\n      options.requestedToken ??\n      PulumiToken.fromPersonalToken(options.organization);\n    const scope = token.scope\n      ? token.scope.replace('USER_NAME', options.organization)\n      : undefined;\n    if (token.tokenType !== PulumiTokenType.ORG && !scope) {\n      throw new Error(\n        `PulumiTokenType ${token.tokenType} requires a \"scope\" to be set`,\n      );\n    }\n    if (options.keys && options.exportEnvironmentVariables) {\n      throw new Error(\n        'Do not provide both \"keys\" and \"exportEnvironmentVariables\". Specify only one.',\n      );\n    }\n    const exportEnvironmentVariables =\n      options.exportEnvironmentVariables ?? ExportEnvironmentVariables.disabled();\n\n    let keys: string | undefined;\n    let exportEnvironmentVariablesInput: boolean | string =\n      exportEnvironmentVariables._render();\n\n    if (options.keys) {\n      keys = options.keys.join(',');\n      exportEnvironmentVariablesInput = true;\n    } else if (exportEnvironmentVariables._usesMapping()) {\n      keys = undefined;\n    }\n\n    const escActionInputs: Record<string, any> = {\n      environment: options.environment,\n      keys,\n      'export-environment-variables': exportEnvironmentVariablesInput,\n      'cloud-url': options.cloudUrl,\n    };\n\n    escActionInputs['oidc-auth'] = true;\n    escActionInputs['oidc-organization'] = options.organization;\n    escActionInputs['oidc-requested-token-type'] = token.tokenType;\n    if (scope) {\n      escActionInputs['oidc-scope'] = scope;\n    }\n    if (options.oidcTokenExpiration !== undefined) {\n      escActionInputs['oidc-token-expiration'] = options.oidcTokenExpiration;\n    }\n\n    const setupSteps: JobStep[] = [\n      {\n        uses: 'pulumi/esc-action@v1',\n        with: escActionInputs,\n      },\n    ];\n\n    return new PulumiEscSetup({\n      keys: options.keys,\n      permissions: {\n        idToken: JobPermission.WRITE,\n      },\n      setupSteps,\n    });\n  }\n  private constructor(private readonly options: PulumiEscSetupOptions) {}\n\n  public get permissions(): JobPermissions | undefined {\n    return this.options.permissions;\n  }\n\n  public get setupSteps() {\n    return this.options.setupSteps;\n  }\n\n  public get keys(): string[] | undefined {\n    return this.options.keys;\n  }\n}\n"]}
224
+ PulumiEscSetup[_c] = { fqn: "@hallcor/pulumi-projen-project-types.PulumiEscSetup", version: "0.0.64" };
225
+ PulumiEscSetup.ESC_ACTION_STEP_ID = 'esc';
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pulumi-esc-setup.js","sourceRoot":"","sources":["../src/pulumi-esc-setup.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  JobPermission,\n  JobPermissions,\n  JobStep,\n} from 'projen/lib/github/workflows-model';\n\ninterface PulumiEscSetupOptions {\n  readonly setupSteps: JobStep[];\n  readonly keys?: string[];\n  readonly permissions?: JobPermissions;\n}\n\n/**\n * Configuration for exporting environment variables from ESC.\n */\nexport class ExportEnvironmentVariables {\n  private constructor(private readonly value: boolean | string[]) {}\n\n  /**\n   * Do not export environment variables. This is the default.\n   */\n  public static disabled(): ExportEnvironmentVariables {\n    return new ExportEnvironmentVariables(false);\n  }\n\n  /**\n   * Provide explicit mappings to export.\n   *\n   * Each entry should follow the ESC action mapping format, for example\n   * `GITHUB_TOKEN=PULUMI_BOT_TOKEN` or `AWS_ACCESS_KEY_ID`.\n   */\n  public static fromMapping(mapping: string[]): ExportEnvironmentVariables {\n    return new ExportEnvironmentVariables(mapping);\n  }\n\n  /**\n   * @internal\n   */\n  public _render(): boolean | string {\n    if (Array.isArray(this.value)) {\n      return this.value.join('\\n');\n    }\n    return this.value;\n  }\n\n  /**\n   * @internal\n   */\n  public _usesMapping(): boolean {\n    return Array.isArray(this.value);\n  }\n}\n\nexport interface PulumiEscActionOptions {\n  /**\n   * The ESC environment to open\n   */\n  readonly environment: string;\n\n  /**\n   * list of keys to inject into the current action/workflow environment.\n   *\n   * @default all keys from the environment will be injected\n   * @deprecated use `exportEnvironmentVariables` instead\n   */\n  readonly keys?: string[];\n\n  /**\n   * Whether to export environment variables from ESC.\n   *\n   * Can also be an array of mapping strings to explicitly control which variables\n   * are exported (joined with newlines for the action input).\n   *\n   * @default ExportEnvironmentVariables.disabled()\n   */\n  readonly exportEnvironmentVariables?: ExportEnvironmentVariables;\n\n  /**\n   * The Pulumi Cloud URL to target.\n   *\n   * @default - Use the default Pulumi Cloud URL\n   */\n  readonly cloudUrl?: string;\n}\n\nexport enum PulumiTokenType {\n  ORG = 'urn:pulumi:token-type:access_token:organization',\n  TEAM = 'urn:pulumi:token-type:access_token:team',\n  PERSONAL = 'urn:pulumi:token-type:access_token:personal',\n}\n\nexport abstract class PulumiToken {\n  /**\n   * Note: organization tokens are only valid for enterprise organizations\n   */\n  public static fromOrgToken(scope?: string): PulumiToken {\n    return {\n      scope,\n      tokenType: PulumiTokenType.ORG,\n    };\n  }\n\n  /**\n   * @param userName the username of the Pulumi user to request the user token. Defaults to the organization name\n   */\n  public static fromPersonalToken(userName?: string): PulumiToken {\n    return {\n      scope: `user:${userName ?? 'USER_NAME'}`,\n      tokenType: PulumiTokenType.PERSONAL,\n    };\n  }\n\n  public static fromTeamToken(teamName: string): PulumiToken {\n    return {\n      scope: `team:${teamName}`,\n      tokenType: PulumiTokenType.TEAM,\n    };\n  }\n\n  /**\n   * The token scope. Scope is only optional for\n   * organization tokens\n   */\n  public abstract scope?: string;\n  public abstract tokenType: PulumiTokenType;\n}\n\nexport interface PulumiAuthOptions extends PulumiEscActionOptions {\n  /**\n   * The Pulumi organization to authenticate with\n   */\n  readonly organization: string;\n\n  /**\n   * The type of pulumi token to get\n   *\n   *\n   * @default PulumiToken.fromPersonalToken()\n   */\n  readonly requestedToken?: PulumiToken;\n\n  /**\n   * The requested expiration time (in seconds) for the generated token when\n   * using ESC OIDC authentication.\n   */\n  readonly oidcTokenExpiration?: number;\n}\n\nexport interface PulumiEscPersonalAccessTokenOptions\n  extends PulumiEscActionOptions {\n  /**\n   * The secret name for the access token\n   */\n  readonly secret?: string;\n}\n\n/**\n * Utilities for configuring Pulumi ESC inside GitHub workflows.\n *\n * The underlying ESC action exposes outputs for each secret in the ESC\n * environment (including any remapped names when `exportEnvironmentVariables`\n * is configured). A stable step id is used so downstream steps can reference\n * those outputs consistently.\n */\nexport class PulumiEscSetup {\n  private static readonly ESC_ACTION_STEP_ID = 'esc';\n  /**\n   * Provides ESC access using a personal access token.\n   *\n   * The token must be added as a secret to the GitHub repo, and the name of the\n   * secret can be specified here.\n   *\n   * @default - a secret named \"PULUMI_ACCESS_TOKEN\"\n   */\n  public static fromPersonalAccessToken(\n    options: PulumiEscPersonalAccessTokenOptions,\n  ) {\n    const secret = options.secret ?? 'PULUMI_ACCESS_TOKEN';\n    if (options.keys && options.exportEnvironmentVariables) {\n      throw new Error(\n        'Do not provide both \"keys\" and \"exportEnvironmentVariables\". Specify only one.',\n      );\n    }\n    const exportEnvironmentVariables =\n      options.exportEnvironmentVariables ?? ExportEnvironmentVariables.disabled();\n\n    let keys: string | undefined;\n    let exportEnvironmentVariablesInput: boolean | string =\n      exportEnvironmentVariables._render();\n\n    if (options.keys) {\n      keys = options.keys.join(',');\n      exportEnvironmentVariablesInput = true;\n    } else if (exportEnvironmentVariables._usesMapping()) {\n      keys = undefined;\n    }\n\n    return new PulumiEscSetup({\n      keys: options.keys,\n      setupSteps: [\n        {\n          id: PulumiEscSetup.ESC_ACTION_STEP_ID,\n          uses: 'pulumi/esc-action@v1',\n          with: {\n            environment: options.environment,\n            keys,\n            'export-environment-variables': exportEnvironmentVariablesInput,\n            'cloud-url': options.cloudUrl,\n          },\n          env: {\n            PULUMI_ACCESS_TOKEN: `\\${{ secrets.${secret} }}`,\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Provides ESC access using OIDC authentication via the pulumi/auth-actions\n   * action.\n   */\n  public static fromOidcAuth(options: PulumiAuthOptions) {\n    const token =\n      options.requestedToken ??\n      PulumiToken.fromPersonalToken(options.organization);\n    const scope = token.scope\n      ? token.scope.replace('USER_NAME', options.organization)\n      : undefined;\n    if (token.tokenType !== PulumiTokenType.ORG && !scope) {\n      throw new Error(\n        `PulumiTokenType ${token.tokenType} requires a \"scope\" to be set`,\n      );\n    }\n    if (options.keys && options.exportEnvironmentVariables) {\n      throw new Error(\n        'Do not provide both \"keys\" and \"exportEnvironmentVariables\". Specify only one.',\n      );\n    }\n    const exportEnvironmentVariables =\n      options.exportEnvironmentVariables ?? ExportEnvironmentVariables.disabled();\n\n    let keys: string | undefined;\n    let exportEnvironmentVariablesInput: boolean | string =\n      exportEnvironmentVariables._render();\n\n    if (options.keys) {\n      keys = options.keys.join(',');\n      exportEnvironmentVariablesInput = true;\n    } else if (exportEnvironmentVariables._usesMapping()) {\n      keys = undefined;\n    }\n\n    const escActionInputs: Record<string, any> = {\n      environment: options.environment,\n      keys,\n      'export-environment-variables': exportEnvironmentVariablesInput,\n      'cloud-url': options.cloudUrl,\n    };\n\n    escActionInputs['oidc-auth'] = true;\n    escActionInputs['oidc-organization'] = options.organization;\n    escActionInputs['oidc-requested-token-type'] = token.tokenType;\n    if (scope) {\n      escActionInputs['oidc-scope'] = scope;\n    }\n    if (options.oidcTokenExpiration !== undefined) {\n      escActionInputs['oidc-token-expiration'] = options.oidcTokenExpiration;\n    }\n\n    const setupSteps: JobStep[] = [\n      {\n        id: PulumiEscSetup.ESC_ACTION_STEP_ID,\n        uses: 'pulumi/esc-action@v1',\n        with: escActionInputs,\n      },\n    ];\n\n    return new PulumiEscSetup({\n      keys: options.keys,\n      permissions: {\n        idToken: JobPermission.WRITE,\n      },\n      setupSteps,\n    });\n  }\n  private constructor(private readonly options: PulumiEscSetupOptions) {}\n\n  public get permissions(): JobPermissions | undefined {\n    return this.options.permissions;\n  }\n\n  public get setupSteps() {\n    return this.options.setupSteps;\n  }\n\n  public get keys(): string[] | undefined {\n    return this.options.keys;\n  }\n\n  /**\n   * The step id assigned to the ESC action. Use this to build references to the\n   * action outputs.\n   */\n  public get escActionStepId(): string {\n    return PulumiEscSetup.ESC_ACTION_STEP_ID;\n  }\n\n  /**\n   * Returns a GitHub Actions expression for a Pulumi ESC output value.\n   *\n   * Outputs are exposed for every secret in the ESC environment (including any\n   * remapped names defined via `exportEnvironmentVariables`). Use the output\n   * key exactly as it appears in the ESC action output object.\n   *\n   * @param key The ESC output key to reference.\n   */\n  public output(key: string): string {\n    return `\\${{ steps.${this.escActionStepId}.outputs.${key} }}`;\n  }\n}\n"]}
package/lib/python.js CHANGED
@@ -236,5 +236,5 @@ class PythonComponent extends python_1.PythonProject {
236
236
  }
237
237
  exports.PythonComponent = PythonComponent;
238
238
  _a = JSII_RTTI_SYMBOL_1;
239
- PythonComponent[_a] = { fqn: "@hallcor/pulumi-projen-project-types.PythonComponent", version: "0.0.62" };
239
+ PythonComponent[_a] = { fqn: "@hallcor/pulumi-projen-project-types.PythonComponent", version: "0.0.64" };
240
240
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"python.js","sourceRoot":"","sources":["../src/python.ts"],"names":[],"mappings":"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","sourcesContent":["import { statSync } from 'fs';\nimport { join } from 'path';\nimport { SampleDir, SampleFile, YamlFile } from 'projen';\nimport { BuildWorkflow } from 'projen/lib/build';\nimport { AutoMerge, GithubCredentials } from 'projen/lib/github';\nimport { PythonProject } from 'projen/lib/python';\nimport { Release } from 'projen/lib/release';\nimport { toPythonVersionRange } from 'projen/lib/util/semver';\nimport { PythonComponentOptions } from './structs';\n\n// devDeps and __news__.args.devDeps will always be the same\n// projen doesn't let you override\n//\n// hack to workaround https://github.com/projen/projen/issues/2475\nfunction handleDevDeps(options: PythonComponentOptions): any {\n  const initOptions = options as any;\n  if ('__new__' in initOptions) {\n    const newDevDeps: string[] = initOptions.__new__.args.devDeps;\n    const newDeps: string[] = initOptions.__new__.args.deps;\n    if (\n      !newDevDeps ||\n      newDevDeps.length !== 1 ||\n      !newDevDeps[0].match(/(@hallcor\\/pulumi-projen-project-types)@?(.*)?/)\n    ) {\n      throw new Error(\n        'Something went wrong, devDeps should have only one entry for @hallcor/pulumi-projen-project-types',\n      );\n    }\n    const matches = newDevDeps[0].match(\n      /(@hallcor\\/pulumi-projen-project-types)@?(.*)?/,\n    )!;\n    const version = matches[2];\n    if (version) {\n      if (version.startsWith('file:')) {\n        if (\n          !newDeps ||\n          newDeps.length === 0 ||\n          !newDeps.find((d) => d.includes('hallcor'))\n        ) {\n          throw new Error(\n            'If you are using `projen new` pointing to a local version of @hallcor/pulumi-projen-project-types, ' +\n              'you must add the location of the local .whl file to the `--deps` command line argument.\\n' +\n              'For example:\\n' +\n              'npx projen new --from @hallcor/pulumi-projen-project-types@file:../path/to/local/project --deps \"../path/to/local/project/dist/hallcor_pulumi_projen_project_types-0.0.0-py3-none-any.whl\"\\n',\n          );\n        }\n        const dep = newDeps.find((d) => d.includes('hallcor'))!;\n        const cwd = process.cwd();\n        try {\n          statSync(join(cwd, dep));\n        } catch (e: any) {\n          if (e.code === 'ENOENT') {\n            throw new Error(\n              `The file provided in '--deps ${newDeps[0]}' does not exist. Please make sure the path is correct.`,\n            );\n          }\n          throw e;\n        }\n        initOptions.devDeps = [dep];\n        initOptions.__new__.args.devDeps = initOptions.devDeps;\n        initOptions.deps = newDeps.filter((d) => d !== dep);\n        initOptions.__new__.args.deps = initOptions.deps;\n        return initOptions;\n      } else {\n        const range = toPythonVersionRange(version);\n        initOptions.devDeps = [`hallcor.pulumi-projen-project-types${range}`];\n        initOptions.__new__.args.devDeps = initOptions.devDeps;\n        return initOptions;\n      }\n    }\n    initOptions.devDeps = [`hallcor.pulumi-projen-project-types`];\n    initOptions.__new__.args.devDeps = initOptions.devDeps;\n    return initOptions;\n  }\n  // otherwise this isn't an `projen new` operation and just return the option values\n  return options;\n}\n\nexport class PythonComponent extends PythonProject {\n  /**\n   * The PR build GitHub workflow. `undefined` if `buildWorkflow` is disabled.\n   */\n  public readonly buildWorkflow?: BuildWorkflow;\n\n  /**\n   * Component that sets up mergify for merging approved pull requests.\n   */\n  public readonly autoMerge?: AutoMerge;\n\n  constructor(options: PythonComponentOptions) {\n    const initOptions = handleDevDeps(options);\n    const projenCredentials = options.projenCredentials;\n    let githubCredentials: GithubCredentials | undefined;\n    if (options.projenCredentials) {\n      const creds = GithubCredentials.fromPersonalAccessToken();\n      (creds as any).options.setupSteps = options.projenCredentials.setupSteps;\n      (creds as any).options.tokenRef = options.projenCredentials.tokenRef;\n      githubCredentials = creds;\n    }\n    super({\n      ...initOptions,\n      pip: true,\n      github: true,\n      poetry: false,\n      venv: true,\n      sample: false,\n      venvOptions: {\n        envdir: 'venv',\n      },\n      projenCredentials: githubCredentials,\n    });\n    const pulumiVersion =\n      options.pulumiPythonOptions?.pulumiVersion ?? '>=3.159 <4.0';\n    this.addDependency(`pulumi@${pulumiVersion}`);\n\n    new YamlFile(this, 'PulumiPlugin.yaml', {\n      obj: {\n        runtime: 'python',\n      },\n    });\n\n    const componentName = options.componentName ?? this.name;\n\n    this.postCompileTask.spawn(\n      this.addTask('get-schema', {\n        description: 'Validate schema is valid',\n        exec: 'pulumi package get-schema ./ > /dev/null',\n      }),\n    );\n\n    if (options.sample ?? true) {\n      new SampleDir(this, 'tests', {\n        files: {\n          '__init__.py': '',\n          'example_test.py': [\n            'def test_example():',\n            '    assert True == True',\n          ].join('\\n'),\n        },\n      });\n\n      new SampleDir(this, this.moduleName, {\n        files: {\n          '__init__.py': '',\n          'example_component.py': [\n            'import pulumi',\n            'from typing import Optional, TypedDict',\n            '',\n            '',\n            'class ExampleComponentArgs(TypedDict):',\n            '    requiredArgument: str',\n            '    \"\"\"A required string argument\"\"\"',\n\n            '    optionalArgument: Optional[str]',\n            '    \"\"\"An optional string argument\"\"\"',\n            '',\n            '',\n            'class ExampleComponent(pulumi.ComponentResource):',\n            '    exampleOutput: pulumi.Output[str]',\n            '    \"\"\"An example output value\"\"\"',\n            '',\n            '    def __init__(',\n            '        self,',\n            '        name: str,',\n            '        args: ExampleComponentArgs,',\n            '        opts: Optional[pulumi.ResourceOptions] = None,',\n            '    ) -> None:',\n            `        super().__init__(\"${componentName}:index:ExampleComponent\", name, {}, opts)`,\n            '        # Component code goes here',\n            '        #',\n            '        #',\n            '        self.register_outputs(',\n            '            {',\n            '                \"exampleOutput\": \"\",  # output values',\n            '            }',\n            '        )',\n            '',\n          ].join('\\n'),\n        },\n      });\n    }\n\n    const artifactsDirectory = 'dist';\n    const versionFilePath = join(artifactsDirectory, 'version.json');\n\n    new SampleFile(this, '__main__.py', {\n      contents: [\n        'from pulumi.provider.experimental import component_provider_host',\n        `from ${this.moduleName}.example_component import ExampleComponent`,\n        '',\n        'if __name__ == \"__main__\":',\n        '    # Call the component provider host. This will discover any ComponentResource',\n        '    # subclasses in this package, infer their schema and host a provider that',\n        '    # allows constructing these components from a Pulumi program.',\n        '    component_provider_host(',\n        `        name=\"${componentName}\",`,\n        '        # List your components here that you want to export',\n        '        components=[',\n        '            ExampleComponent,',\n        '        ],',\n        '    )',\n      ].join('\\n'),\n    });\n\n    const github = this.github;\n    if (!github) {\n      throw new Error('This project must be a github project');\n    }\n    const installTask = this.tasks.tryFind('install');\n    if (!installTask) {\n      throw new Error('install task not found');\n    }\n\n    this.buildWorkflow = new BuildWorkflow(this, {\n      ...options.buildWorkflowOptions,\n      buildTask: this.buildTask,\n      artifactsDirectory: 'dist',\n      preBuildSteps: [\n        ...(options.buildWorkflowOptions?.preBuildSteps ?? []),\n        {\n          name: 'Setup Python',\n          uses: 'actions/setup-python@v5',\n        },\n        { run: 'python -m venv venv' },\n        { run: this.github.project.runTaskCommand(installTask) },\n        {\n          uses: 'pulumi/actions@v6',\n          with: {\n            'pulumi-version': 'latest',\n          },\n        },\n      ],\n    });\n\n    const buildName = this.buildWorkflow.name;\n    const buildWorkflow = this.github.tryFindWorkflow(buildName);\n    if (!buildWorkflow) {\n      throw new Error(`could not find build workflow ${buildName}`);\n    }\n    const mutationJob = buildWorkflow.getJob('self-mutation');\n    buildWorkflow?.updateJob('self-mutation', {\n      ...mutationJob,\n      permissions: {\n        ...mutationJob.permissions,\n        ...projenCredentials?.permissions,\n      },\n    });\n\n    if ((options.autoMerge ?? true) && this.github?.mergify) {\n      this.autoMerge = new AutoMerge(this.github, options.autoMergeOptions);\n      if (options.githubOptions?.pullRequestLint ?? true) {\n        this.autoMerge.addConditions('status-success=Validate PR title');\n      }\n      this.autoMerge.addConditionsLater({\n        render: () =>\n          this.buildWorkflow?.buildJobIds.map((id) => `status-success=${id}`) ??\n          [],\n      });\n    }\n\n    if (options.release ?? true) {\n      new Release(this, {\n        artifactsDirectory,\n        branch: 'main',\n        task: this.packageTask,\n        versionFile: versionFilePath,\n        releaseTrigger: options.releaseTrigger,\n      });\n    }\n  }\n}\n"]}
package/lib/release.js CHANGED
@@ -81,7 +81,7 @@ class ReleaseWorkflow extends constructs_1.Construct {
81
81
  }
82
82
  exports.ReleaseWorkflow = ReleaseWorkflow;
83
83
  _a = JSII_RTTI_SYMBOL_1;
84
- ReleaseWorkflow[_a] = { fqn: "@hallcor/pulumi-projen-project-types.ReleaseWorkflow", version: "0.0.62" };
84
+ ReleaseWorkflow[_a] = { fqn: "@hallcor/pulumi-projen-project-types.ReleaseWorkflow", version: "0.0.64" };
85
85
  class TagRelease extends release_1.Release {
86
86
  constructor(scope, props) {
87
87
  if (!props.task) {
@@ -193,5 +193,5 @@ class TagRelease extends release_1.Release {
193
193
  }
194
194
  exports.TagRelease = TagRelease;
195
195
  _b = JSII_RTTI_SYMBOL_1;
196
- TagRelease[_b] = { fqn: "@hallcor/pulumi-projen-project-types.TagRelease", version: "0.0.62" };
196
+ TagRelease[_b] = { fqn: "@hallcor/pulumi-projen-project-types.TagRelease", version: "0.0.64" };
197
197
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"release.js","sourceRoot":"","sources":["../src/release.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { Construct } from 'constructs';\nimport { Project, Task } from 'projen';\nimport { GitHub, WorkflowSteps } from 'projen/lib/github';\nimport { DEFAULT_GITHUB_ACTIONS_USER } from 'projen/lib/github/constants';\n\nimport {\n  JobPermission,\n  JobPermissions,\n  JobStep,\n} from 'projen/lib/github/workflows-model';\nimport { Release as ProjenRelease, ReleaseTrigger } from 'projen/lib/release';\nimport { TagReleaseOptions } from './structs';\n\nexport interface GitTagPublishOptions {\n  /**\n   * Additional permissions to add to the Git Tag Job\n   */\n  readonly permissions?: JobPermissions;\n}\n\nexport interface CreateReleaseOptions {\n  /**\n   * The path to the changelog file to generate release notes from\n   */\n  readonly changelogPath: string;\n\n  /**\n   * The name of the release tag. This could be something like `${{ github.ref_name }}`\n   * or `$(cat dist/releasetag.txt)`\n   */\n  readonly releaseTag: string;\n\n  /**\n   * Whether to only run this step if the `release-exists` step returned true\n   * @default false\n   */\n  readonly verifyReleaseExists?: boolean;\n}\n\nexport class ReleaseWorkflow extends Construct {\n  public static releaseExists(): JobStep {\n    return {\n      id: 'release-exists',\n      name: 'Verify if release exists',\n      run: [\n        'if gh release view ${{ github.ref_name }} --repo=${{ github.repository }} &>/dev/null',\n        'then',\n        'echo \"result=true\" >> $GITHUB_OUTPUT',\n        'else',\n        'echo \"result=false\" >> $GITHUB_OUTPUT',\n        'fi',\n      ].join('\\n'),\n      env: {\n        GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}',\n      },\n    };\n  }\n  public static createRelease(options: CreateReleaseOptions): JobStep {\n    return {\n      name: 'Create Release',\n      if: options.verifyReleaseExists\n        ? '!fromJSON(steps.release-exists.outputs.result)'\n        : undefined,\n      run: [\n        'gh release create',\n        options.releaseTag,\n        '--repo ${{ github.repository }}',\n        `--notes-file ${options.changelogPath}`,\n        `--title ${options.releaseTag}`,\n        '--verify-tag',\n      ].join(' '),\n      env: {\n        GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}',\n      },\n    };\n  }\n  constructor(scope: Construct, id: string, changelogPath: string) {\n    super(scope, id);\n    const project = Project.of(this);\n    const github = GitHub.of(project);\n    if (!github) {\n      throw new Error('ReleaseWorkflow requires a GitHub Project');\n    }\n\n    const workflowName = 'github-release';\n\n    if (github.tryFindWorkflow(workflowName)) {\n      throw new Error('A release workflow already exists');\n    }\n\n    const release = github.addWorkflow(workflowName);\n    release.runName = 'Release ${{ github.ref_name }}';\n    release.on({ push: { tags: ['v*.*.*'] } });\n\n    release.addJob('publish-to-github-release', {\n      permissions: {\n        contents: JobPermission.WRITE,\n      },\n      runsOn: ['ubuntu-latest'],\n      steps: [\n        WorkflowSteps.checkout({ with: { fetchDepth: 0 } }),\n        ReleaseWorkflow.releaseExists(),\n        ReleaseWorkflow.createRelease({\n          changelogPath,\n          releaseTag: '${{ github.ref_name }}',\n          verifyReleaseExists: true,\n        }),\n      ],\n      name: 'Publish to GitHub Release',\n    });\n  }\n}\n\nexport class TagRelease extends ProjenRelease {\n  public readonly trigger: ReleaseTrigger;\n  public readonly publishTask: Task;\n  constructor(scope: Construct, props: TagReleaseOptions) {\n    if (!props.task) {\n      throw new Error('TagRelease requires a release task');\n    }\n    super(scope, {\n      ...props,\n      task: props.task,\n      githubRelease: false,\n    });\n\n    const project = Project.of(this);\n    this.trigger = props.releaseTrigger ?? ReleaseTrigger.continuous();\n\n    const changelogFileName = 'changelog.md';\n    const versionFileName = 'version.txt';\n    const releaseTagFileName = 'releasetag.txt';\n\n    const changelogFile = path.posix.join(\n      this.artifactsDirectory,\n      changelogFileName,\n    );\n    const releaseTagFile = path.posix.join(\n      this.artifactsDirectory,\n      releaseTagFileName,\n    );\n    const versionFile = path.posix.join(\n      this.artifactsDirectory,\n      versionFileName,\n    );\n\n    this.publishTask = this.publisher.publishToGit({\n      changelogFile,\n      releaseTagFile,\n      versionFile,\n      projectChangelogFile: this.trigger.changelogPath,\n      gitBranch: props.branch,\n      gitPushCommand: this.trigger.gitPushCommand,\n    });\n\n    project.addGitIgnore(this.artifactsDirectory);\n    const github = GitHub.of(project);\n    if (!github) {\n      throw new Error('ReleaseWorkflow requires a GitHub Project');\n    }\n\n    const downloadArtifact = WorkflowSteps.downloadArtifact({\n      with: {\n        name: 'build-artifact',\n        path: this.artifactsDirectory,\n      },\n    });\n    const restoreArtifact = {\n      name: 'Restore build artifact permissions',\n      run: `cd ${this.artifactsDirectory} && setfacl --restore=permissions-backup.acl`,\n      continueOnError: true,\n    };\n\n    this.addJobs({\n      release_git: {\n        permissions: {\n          contents: JobPermission.WRITE,\n          ...props.gitTagPublishOptions?.permissions,\n        },\n        if: \"needs.release.outputs.tag_exists != 'true' && needs.release.outputs.latest_commit == github.sha\",\n        name: 'Publish Git Tag',\n        needs: ['release'],\n        runsOn: ['ubuntu-latest'],\n        steps: [\n          ...github.projenCredentials.setupSteps,\n          WorkflowSteps.checkout({\n            with: {\n              ref: props.branch,\n              token: github.projenCredentials.tokenRef,\n            },\n          }),\n          downloadArtifact,\n          restoreArtifact,\n          WorkflowSteps.setupGitIdentity({\n            gitIdentity: props.gitIdentity ?? DEFAULT_GITHUB_ACTIONS_USER,\n          }),\n          {\n            name: 'Release',\n            env: {\n              VERSION_FILE: versionFile,\n              CHANGELOG: this.trigger.changelogPath ?? '',\n              RELEASE_TAG_FILE: releaseTagFile,\n              GITHUB_TOKEN: github.projenCredentials.tokenRef,\n            },\n            run: project.runTaskCommand(this.publishTask),\n          },\n        ],\n      },\n    });\n\n    if (!this.trigger.isManual) {\n      this.addJobs({\n        release_github: {\n          permissions: {\n            contents: JobPermission.WRITE,\n          },\n          needs: ['release_git', 'release'],\n          if: \"needs.release.outputs.tag_exists != 'true' && needs.release.outputs.latest_commit == github.sha\",\n          name: 'Publish GitHub Release',\n          runsOn: ['ubuntu-latest'],\n          steps: [\n            downloadArtifact,\n            restoreArtifact,\n            ReleaseWorkflow.createRelease({\n              changelogPath: changelogFile,\n              releaseTag: `$(cat ${releaseTagFile})`,\n            }),\n          ],\n        },\n      });\n    } else {\n      if (this.trigger.changelogPath) {\n        new ReleaseWorkflow(this, 'release-github', this.trigger.changelogPath);\n      } else {\n        this.project.logger.warn(\n          'manual release trigger has no changelogPath, not generating release-github workflow',\n        );\n      }\n    }\n  }\n}\n"]}
@@ -46,5 +46,5 @@ class TypeScriptProject extends typescript_1.TypeScriptProject {
46
46
  }
47
47
  exports.TypeScriptProject = TypeScriptProject;
48
48
  _a = JSII_RTTI_SYMBOL_1;
49
- TypeScriptProject[_a] = { fqn: "@hallcor/pulumi-projen-project-types.TypeScriptProject", version: "0.0.62" };
49
+ TypeScriptProject[_a] = { fqn: "@hallcor/pulumi-projen-project-types.TypeScriptProject", version: "0.0.64" };
50
50
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdC1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzY3JpcHQtYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1DQUFtQztBQUNuQyw4Q0FBc0Q7QUFDdEQsc0RBQWtEO0FBQ2xELHNEQUFxRjtBQUNyRiwwREFBaUU7QUFHakUsTUFBYSxpQkFBa0IsU0FBUSw4QkFBdUI7SUFDNUQsWUFBWSxPQUErQjtRQUN6QyxNQUFNLGlCQUFpQixHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQztRQUNwRCxJQUFJLGlCQUFnRCxDQUFDO1FBQ3JELElBQUksT0FBTyxDQUFDLGlCQUFpQixFQUFFLENBQUM7WUFDOUIsTUFBTSxLQUFLLEdBQUcsMEJBQWlCLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztZQUN6RCxLQUFhLENBQUMsT0FBTyxDQUFDLFVBQVUsR0FBRyxPQUFPLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDO1lBQ3hFLEtBQWEsQ0FBQyxPQUFPLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUM7WUFDckUsaUJBQWlCLEdBQUcsS0FBSyxDQUFDO1FBQzVCLENBQUM7UUFDRCxLQUFLLENBQUM7WUFDSixRQUFRLEVBQUUsSUFBSTtZQUNkLGVBQWUsRUFBRTtnQkFDZixRQUFRLEVBQUU7b0JBQ1IsV0FBVyxFQUFFLElBQUk7aUJBQ2xCO2FBQ0Y7WUFDRCxhQUFhLEVBQUU7Z0JBQ2IsSUFBSSxFQUFFLE9BQU8sQ0FBQyxhQUFhLEVBQUUsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sSUFBSSxLQUFLLENBQUM7Z0JBQzlELFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUSxJQUFJLElBQUk7Z0JBQ2xDLEdBQUcsT0FBTyxDQUFDLGFBQWE7YUFDekI7WUFDRCxXQUFXLEVBQUU7Z0JBQ1gsY0FBYyxFQUFFLGtCQUFrQjthQUNuQztZQUNELEdBQUcsT0FBTztZQUNWLGlCQUFpQixFQUFFLGlCQUFpQjtTQUNyQyxDQUFDLENBQUM7UUFFSCxJQUFBLHFDQUFzQixFQUFDLElBQUksRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBRWhELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzlELFVBQVUsRUFBRSxLQUFLLENBQ2Ysa0JBQVMsQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFO1lBQzFCLGlCQUFpQixFQUFFLElBQUksc0JBQVMsQ0FBQyxXQUFXLENBQUM7U0FDOUMsQ0FBQyxDQUNILENBQUM7UUFFRixJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUM1QyxDQUFDOztBQXZDSCw4Q0F3Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBKc29uUGF0Y2ggfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgR2l0aHViQ3JlZGVudGlhbHMgfSBmcm9tICdwcm9qZW4vbGliL2dpdGh1Yic7XG5pbXBvcnQgeyBUcmFuc2Zvcm0gfSBmcm9tICdwcm9qZW4vbGliL2phdmFzY3JpcHQnO1xuaW1wb3J0IHsgVHlwZVNjcmlwdFByb2plY3QgYXMgUHJvamVuVHlwZVNjcmlwdFByb2plY3QgfSBmcm9tICdwcm9qZW4vbGliL3R5cGVzY3JpcHQnO1xuaW1wb3J0IHsgc2V0V29ya2Zsb3dQZXJtaXNzaW9ucyB9IGZyb20gJy4vaW50ZXJuYWwvanNpaS1wcm9qZWN0JztcbmltcG9ydCB7IFR5cGVTY3JpcHRQcm9qZWN0UHJvcHMgfSBmcm9tICcuL3N0cnVjdHMnO1xuXG5leHBvcnQgY2xhc3MgVHlwZVNjcmlwdFByb2plY3QgZXh0ZW5kcyBQcm9qZW5UeXBlU2NyaXB0UHJvamVjdCB7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IFR5cGVTY3JpcHRQcm9qZWN0UHJvcHMpIHtcbiAgICBjb25zdCBwcm9qZW5DcmVkZW50aWFscyA9IG9wdGlvbnMucHJvamVuQ3JlZGVudGlhbHM7XG4gICAgbGV0IGdpdGh1YkNyZWRlbnRpYWxzOiBHaXRodWJDcmVkZW50aWFscyB8IHVuZGVmaW5lZDtcbiAgICBpZiAob3B0aW9ucy5wcm9qZW5DcmVkZW50aWFscykge1xuICAgICAgY29uc3QgY3JlZHMgPSBHaXRodWJDcmVkZW50aWFscy5mcm9tUGVyc29uYWxBY2Nlc3NUb2tlbigpO1xuICAgICAgKGNyZWRzIGFzIGFueSkub3B0aW9ucy5zZXR1cFN0ZXBzID0gb3B0aW9ucy5wcm9qZW5DcmVkZW50aWFscy5zZXR1cFN0ZXBzO1xuICAgICAgKGNyZWRzIGFzIGFueSkub3B0aW9ucy50b2tlblJlZiA9IG9wdGlvbnMucHJvamVuQ3JlZGVudGlhbHMudG9rZW5SZWY7XG4gICAgICBnaXRodWJDcmVkZW50aWFscyA9IGNyZWRzO1xuICAgIH1cbiAgICBzdXBlcih7XG4gICAgICBwcmV0dGllcjogdHJ1ZSxcbiAgICAgIHByZXR0aWVyT3B0aW9uczoge1xuICAgICAgICBzZXR0aW5nczoge1xuICAgICAgICAgIHNpbmdsZVF1b3RlOiB0cnVlLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICAgIGVzbGludE9wdGlvbnM6IHtcbiAgICAgICAgZGlyczogb3B0aW9ucy5lc2xpbnRPcHRpb25zPy5kaXJzID8/IFtvcHRpb25zLnNyY2RpciA/PyAnc3JjJ10sXG4gICAgICAgIHByZXR0aWVyOiBvcHRpb25zLnByZXR0aWVyID8/IHRydWUsXG4gICAgICAgIC4uLm9wdGlvbnMuZXNsaW50T3B0aW9ucyxcbiAgICAgIH0sXG4gICAgICBqZXN0T3B0aW9uczoge1xuICAgICAgICBjb25maWdGaWxlUGF0aDogJ2plc3QuY29uZmlnLmpzb24nLFxuICAgICAgfSxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgICBwcm9qZW5DcmVkZW50aWFsczogZ2l0aHViQ3JlZGVudGlhbHMsXG4gICAgfSk7XG5cbiAgICBzZXRXb3JrZmxvd1Blcm1pc3Npb25zKHRoaXMsIHByb2plbkNyZWRlbnRpYWxzKTtcblxuICAgIGNvbnN0IGplc3RDb25maWcgPSB0aGlzLnRyeUZpbmRPYmplY3RGaWxlKCdqZXN0LmNvbmZpZy5qc29uJyk7XG4gICAgamVzdENvbmZpZz8ucGF0Y2goXG4gICAgICBKc29uUGF0Y2guYWRkKCcvdHJhbnNmb3JtJywge1xuICAgICAgICAnXi4rXFxcXC4odHxqKXN4PyQnOiBuZXcgVHJhbnNmb3JtKCdAc3djL2plc3QnKSxcbiAgICAgIH0pLFxuICAgICk7XG5cbiAgICB0aGlzLmFkZERldkRlcHMoJ0Bzd2MvY29yZScsICdAc3djL2plc3QnKTtcbiAgfVxufVxuIl19
package/lib/typescript.js CHANGED
@@ -108,5 +108,5 @@ class TypeScriptComponent extends typescript_base_1.TypeScriptProject {
108
108
  }
109
109
  exports.TypeScriptComponent = TypeScriptComponent;
110
110
  _a = JSII_RTTI_SYMBOL_1;
111
- TypeScriptComponent[_a] = { fqn: "@hallcor/pulumi-projen-project-types.TypeScriptComponent", version: "0.0.62" };
111
+ TypeScriptComponent[_a] = { fqn: "@hallcor/pulumi-projen-project-types.TypeScriptComponent", version: "0.0.64" };
112
112
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90eXBlc2NyaXB0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQTZDO0FBRTdDLHVEQUFzRDtBQUV0RCxNQUFhLG1CQUFvQixTQUFRLG1DQUFpQjtJQUV4RCxZQUFZLE9BQW1DO1FBQzdDLEtBQUssQ0FBQztZQUNKLEdBQUcsT0FBTztZQUNWLFVBQVUsRUFBRSxPQUFPLENBQUMsVUFBVSxJQUFJLGNBQWM7WUFDaEQsVUFBVSxFQUFFLEtBQUs7WUFDakIsb0JBQW9CLEVBQUU7Z0JBQ3BCLGFBQWEsRUFBRTtvQkFDYixHQUFHLENBQUMsT0FBTyxDQUFDLG9CQUFvQixFQUFFLGFBQWEsSUFBSSxFQUFFLENBQUM7b0JBQ3REO3dCQUNFLElBQUksRUFBRSxtQkFBbUI7d0JBQ3pCLElBQUksRUFBRTs0QkFDSixnQkFBZ0IsRUFBRSxRQUFRO3lCQUMzQjtxQkFDRjtpQkFDRjthQUNGO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQy9CLElBQUksaUJBQVEsQ0FBQyxJQUFJLEVBQUUsbUJBQW1CLEVBQUU7WUFDdEMsR0FBRyxFQUFFO2dCQUNILE9BQU8sRUFBRSxRQUFRO2FBQ2xCO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQ3hCLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFO1lBQ3pCLFdBQVcsRUFBRSwwQkFBMEI7WUFDdkMsSUFBSSxFQUFFLDBDQUEwQztTQUNqRCxDQUFDLENBQ0gsQ0FBQztRQUVGLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUNoRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDYixJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDO1FBQ2hELENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLGFBQWEsR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDaEMscUNBQXFDO1lBQ3JDLDZCQUE2QjtZQUM3QixvQkFBb0I7WUFDcEIsZ0VBQWdFO1lBQ2hFLElBQUk7UUFDTixDQUFDO1FBRUQsSUFBSSxPQUFPLENBQUMsVUFBVSxJQUFJLElBQUksRUFBRSxDQUFDO1lBQy9CLElBQUksa0JBQVMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFO2dCQUN6QixLQUFLLEVBQUU7b0JBQ0wsVUFBVSxFQUFFO3dCQUNWLGdDQUFnQzt3QkFDaEMsc0NBQXNDO3FCQUN2QyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7b0JBQ1osc0JBQXNCLEVBQUU7d0JBQ3RCLDJDQUEyQzt3QkFDM0MsRUFBRTt3QkFDRixLQUFLO3dCQUNMLHFDQUFxQzt3QkFDckMsS0FBSzt3QkFDTCx5Q0FBeUM7d0JBQ3pDLDBCQUEwQjt3QkFDMUIsR0FBRzt3QkFDSCxFQUFFO3dCQUNGLEtBQUs7d0JBQ0wseUJBQXlCO3dCQUN6QixLQUFLO3dCQUNMLGtFQUFrRTt3QkFDbEUsd0JBQXdCO3dCQUN4QixzREFBc0Q7d0JBQ3RELEVBQUU7d0JBQ0YsZ0JBQWdCO3dCQUNoQixtQkFBbUI7d0JBQ25CLGlDQUFpQzt3QkFDakMsNkNBQTZDO3dCQUM3QyxPQUFPO3dCQUNQLDZEQUE2RDt3QkFDN0QscUVBQXFFO3dCQUNyRSw0REFBNEQ7d0JBQzVELGNBQWMsSUFBSSxDQUFDLGFBQWEsOENBQThDO3dCQUM5RSxFQUFFO3dCQUNGLHVDQUF1Qzt3QkFDdkMsUUFBUTt3QkFDUixhQUFhO3dCQUNiLFFBQVE7d0JBQ1IsdUNBQXVDO3dCQUN2Qyw0QkFBNEI7d0JBQzVCLFlBQVk7d0JBQ1osb0VBQW9FO3dCQUNwRSxrREFBa0Q7d0JBQ2xELGVBQWU7d0JBQ2YsYUFBYTt3QkFDYiw0QkFBNEI7d0JBQzVCLFdBQVc7d0JBQ1gsRUFBRTt3QkFDRiwyREFBMkQ7d0JBQzNELDRCQUE0Qjt3QkFDNUIsZUFBZTt3QkFDZiw2QkFBNkI7d0JBQzdCLFNBQVM7d0JBQ1QsS0FBSzt3QkFDTCxLQUFLO3FCQUNOLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztpQkFDYjthQUNGLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDOztBQXpHSCxrREEwR0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTYW1wbGVEaXIsIFlhbWxGaWxlIH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IFR5cGVTY3JpcHRDb21wb25lbnRPcHRpb25zIH0gZnJvbSAnLi9zdHJ1Y3RzJztcbmltcG9ydCB7IFR5cGVTY3JpcHRQcm9qZWN0IH0gZnJvbSAnLi90eXBlc2NyaXB0LWJhc2UnO1xuXG5leHBvcnQgY2xhc3MgVHlwZVNjcmlwdENvbXBvbmVudCBleHRlbmRzIFR5cGVTY3JpcHRQcm9qZWN0IHtcbiAgcHJpdmF0ZSByZWFkb25seSBjb21wb25lbnROYW1lOiBzdHJpbmc7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IFR5cGVTY3JpcHRDb21wb25lbnRPcHRpb25zKSB7XG4gICAgc3VwZXIoe1xuICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIGVudHJ5cG9pbnQ6IG9wdGlvbnMuZW50cnlwb2ludCA/PyAnc3JjL2luZGV4LnRzJyxcbiAgICAgIHNhbXBsZUNvZGU6IGZhbHNlLFxuICAgICAgYnVpbGRXb3JrZmxvd09wdGlvbnM6IHtcbiAgICAgICAgcHJlQnVpbGRTdGVwczogW1xuICAgICAgICAgIC4uLihvcHRpb25zLmJ1aWxkV29ya2Zsb3dPcHRpb25zPy5wcmVCdWlsZFN0ZXBzID8/IFtdKSxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB1c2VzOiAncHVsdW1pL2FjdGlvbnNAdjYnLFxuICAgICAgICAgICAgd2l0aDoge1xuICAgICAgICAgICAgICAncHVsdW1pLXZlcnNpb24nOiAnbGF0ZXN0JyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICB0aGlzLmFkZERlcHMoJ0BwdWx1bWkvcHVsdW1pJyk7XG4gICAgbmV3IFlhbWxGaWxlKHRoaXMsICdQdWx1bWlQbHVnaW4ueWFtbCcsIHtcbiAgICAgIG9iajoge1xuICAgICAgICBydW50aW1lOiAnbm9kZWpzJyxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICB0aGlzLnBvc3RDb21waWxlVGFzay5zcGF3bihcbiAgICAgIHRoaXMuYWRkVGFzaygnZ2V0LXNjaGVtYScsIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdWYWxpZGF0ZSBzY2hlbWEgaXMgdmFsaWQnLFxuICAgICAgICBleGVjOiAncHVsdW1pIHBhY2thZ2UgZ2V0LXNjaGVtYSAuLyA+IC9kZXYvbnVsbCcsXG4gICAgICB9KSxcbiAgICApO1xuXG4gICAgY29uc3QgbWF0Y2hlcyA9IHRoaXMucGFja2FnZS5wYWNrYWdlTmFtZS5tYXRjaCgvKEAuKj9cXC8pPyguKykvKTtcbiAgICBpZiAoIW1hdGNoZXMpIHtcbiAgICAgIHRoaXMuY29tcG9uZW50TmFtZSA9IHRoaXMucGFja2FnZS5wYWNrYWdlTmFtZTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5jb21wb25lbnROYW1lID0gbWF0Y2hlc1syXTtcbiAgICAgIC8vIFRPRE86IGRvIHNvbWV0aGluZyB3aXRoIG5hbWVzcGFjZT9cbiAgICAgIC8vIGxldCBuYW1lc3BhY2UgPSB1bmRlZmluZWQ7XG4gICAgICAvLyBpZiAobWF0Y2hlc1sxXSkge1xuICAgICAgLy8gICBuYW1lc3BhY2UgPSBtYXRjaGVzWzFdLnN1YnN0cmluZygxLCBtYXRjaGVzWzFdLmxlbmd0aCAtIDEpO1xuICAgICAgLy8gfVxuICAgIH1cblxuICAgIGlmIChvcHRpb25zLnNhbXBsZUNvZGUgPz8gdHJ1ZSkge1xuICAgICAgbmV3IFNhbXBsZURpcih0aGlzLCAnc3JjJywge1xuICAgICAgICBmaWxlczoge1xuICAgICAgICAgICdpbmRleC50cyc6IFtcbiAgICAgICAgICAgICcvLyBleHBvcnQgeW91ciBjb21wb25lbnRzIGhlcmUnLFxuICAgICAgICAgICAgXCJleHBvcnQgKiBmcm9tICcuL2V4YW1wbGUtY29tcG9uZW50JztcIixcbiAgICAgICAgICBdLmpvaW4oJ1xcbicpLFxuICAgICAgICAgICdleGFtcGxlLWNvbXBvbmVudC50cyc6IFtcbiAgICAgICAgICAgIFwiaW1wb3J0ICogYXMgcHVsdW1pIGZyb20gJ0BwdWx1bWkvcHVsdW1pJztcIixcbiAgICAgICAgICAgICcnLFxuICAgICAgICAgICAgJy8qKicsXG4gICAgICAgICAgICAnICogSW5wdXQgYXJndW1lbnRzIHRvIHRoZSBjb21wb25lbnQnLFxuICAgICAgICAgICAgJyAqLycsXG4gICAgICAgICAgICAnZXhwb3J0IGludGVyZmFjZSBFeGFtcGxlQ29tcG9uZW50QXJncyB7JyxcbiAgICAgICAgICAgICcgIC8vIENvbXBvbmVudCBpbnB1dHMuLi4nLFxuICAgICAgICAgICAgJ30nLFxuICAgICAgICAgICAgJycsXG4gICAgICAgICAgICAnLyoqJyxcbiAgICAgICAgICAgICcgKiBBbiBleGFtcGxlIGNvbXBvbmVudCcsXG4gICAgICAgICAgICAnICovJyxcbiAgICAgICAgICAgICdleHBvcnQgY2xhc3MgRXhhbXBsZUNvbXBvbmVudCBleHRlbmRzIHB1bHVtaS5Db21wb25lbnRSZXNvdXJjZSB7JyxcbiAgICAgICAgICAgICcgIC8vIENvbXBvbmVudCBvdXRwdXRzJyxcbiAgICAgICAgICAgICcgIC8vIHB1YmxpYyByZWFkb25seSByb2xlQXJuOiBwdWx1bWkuT3V0cHV0PHN0cmluZz47JyxcbiAgICAgICAgICAgICcnLFxuICAgICAgICAgICAgJyAgY29uc3RydWN0b3IoJyxcbiAgICAgICAgICAgICcgICAgbmFtZTogc3RyaW5nLCcsXG4gICAgICAgICAgICAnICAgIGFyZ3M6IEV4YW1wbGVDb21wb25lbnRBcmdzLCcsXG4gICAgICAgICAgICAnICAgIG9wdHM/OiBwdWx1bWkuQ29tcG9uZW50UmVzb3VyY2VPcHRpb25zLCcsXG4gICAgICAgICAgICAnICApIHsnLFxuICAgICAgICAgICAgJyAgICAvLyB0eXBlIGhhcyB0aGUgZm9ybWF0IG9mICR7cGFja2FnZX06aW5kZXg6JHtjbGFzc05hbWV9JyxcbiAgICAgICAgICAgICcgICAgLy8gd2hlcmUgcGFja2FnZSBuZWVkcyB0byBtYXRjaCB0aGUgYG5hbWVgIGluIHlvdXIgcGFja2FnZS5qc29uJyxcbiAgICAgICAgICAgICcgICAgLy8gYW5kIGNsYXNzTmFtZSBuZWVkcyB0byBtYXRjaCB0aGUgbmFtZSBvZiB0aGlzIGNsYXNzJyxcbiAgICAgICAgICAgIGAgICAgc3VwZXIoJyR7dGhpcy5jb21wb25lbnROYW1lfTppbmRleDpFeGFtcGxlQ29tcG9uZW50JywgbmFtZSwgYXJncywgb3B0cyk7YCxcbiAgICAgICAgICAgICcnLFxuICAgICAgICAgICAgJyAgICAvLyBDb21wb25lbnQgcmVzb3VyY2VzIGdvIGhlcmUuLi4nLFxuICAgICAgICAgICAgJyAgICAvLycsXG4gICAgICAgICAgICAnICAgIC8vIGUuZy4nLFxuICAgICAgICAgICAgJyAgICAvLycsXG4gICAgICAgICAgICAnICAgIC8vIGNvbnN0IHJvbGUgPSBuZXcgYXdzLmlhbS5Sb2xlKCcsXG4gICAgICAgICAgICAnICAgIC8vICAgYCR7bmFtZX0tcG9saWN5YCwnLFxuICAgICAgICAgICAgJyAgICAvLyAgIHsnLFxuICAgICAgICAgICAgJyAgICAvLyAgICAgYXNzdW1lUm9sZVBvbGljeTogYXdzLmlhbS5hc3N1bWVSb2xlUG9saWN5Rm9yUHJpbmNpcGFsKCcsXG4gICAgICAgICAgICAnICAgIC8vICAgICAgIGF3cy5pYW0uUHJpbmNpcGFscy5MYW1iZGFQcmluY2lwYWwsJyxcbiAgICAgICAgICAgICcgICAgLy8gICAgICksJyxcbiAgICAgICAgICAgICcgICAgLy8gICB9LCcsXG4gICAgICAgICAgICAnICAgIC8vICAgeyBwYXJlbnQ6IHRoaXMgfSwnLFxuICAgICAgICAgICAgJyAgICAvLyApOycsXG4gICAgICAgICAgICAnJyxcbiAgICAgICAgICAgICcgICAgLy8gcmVnaXN0ZXIgYW55IG9mIHRoZSBjb21wb25lbnQgb3V0cHV0cyBoZXJlIGFzIHdlbGwnLFxuICAgICAgICAgICAgJyAgICB0aGlzLnJlZ2lzdGVyT3V0cHV0cyh7JyxcbiAgICAgICAgICAgICcgICAgICAvLyBlLmcuJyxcbiAgICAgICAgICAgICcgICAgICAvLyByb2xlQXJuOiByb2xlLmFybiwnLFxuICAgICAgICAgICAgJyAgICB9KTsnLFxuICAgICAgICAgICAgJyAgfScsXG4gICAgICAgICAgICAnfVxcbicsXG4gICAgICAgICAgXS5qb2luKCdcXG4nKSxcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -76,7 +76,7 @@
76
76
  "publishConfig": {
77
77
  "access": "public"
78
78
  },
79
- "version": "0.0.62",
79
+ "version": "0.0.64",
80
80
  "types": "lib/index.d.ts",
81
81
  "stability": "stable",
82
82
  "jsii": {