deployable-awscdk-app-ts 0.0.21 → 0.0.25

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
@@ -7,17 +7,19 @@
7
7
  ]
8
8
  },
9
9
  "dependencies": {
10
- "projen": "^0.45.3"
10
+ "projen": "^0.50.30"
11
11
  },
12
12
  "dependencyClosure": {
13
13
  "projen": {
14
14
  "submodules": {
15
15
  "projen.awscdk": {},
16
+ "projen.build": {},
16
17
  "projen.cdk": {},
17
18
  "projen.cdk8s": {},
18
19
  "projen.cdktf": {},
19
20
  "projen.github": {},
20
21
  "projen.github.workflows": {},
22
+ "projen.gitlab": {},
21
23
  "projen.java": {},
22
24
  "projen.javascript": {},
23
25
  "projen.python": {},
@@ -52,7 +54,7 @@
52
54
  "stability": "stable"
53
55
  },
54
56
  "homepage": "https://github.com/amin.fazl/deployable-awscdk-app-ts.git",
55
- "jsiiVersion": "1.49.0 (build e322d87)",
57
+ "jsiiVersion": "1.52.1 (build 5ccc8f6)",
56
58
  "keywords": [
57
59
  "AWS CDK",
58
60
  "Deployment",
@@ -300,7 +302,7 @@
300
302
  },
301
303
  "locationInModule": {
302
304
  "filename": "src/index.ts",
303
- "line": 51
305
+ "line": 52
304
306
  },
305
307
  "name": "addEnvironments",
306
308
  "parameters": [
@@ -453,6 +455,6 @@
453
455
  "symbolId": "src/types:EnvironmentOptions"
454
456
  }
455
457
  },
456
- "version": "0.0.21",
457
- "fingerprint": "8NxvszEaBf+zN3D6zVpeNSsl9CCnlaf1AJox3Bu7wv8="
458
+ "version": "0.0.25",
459
+ "fingerprint": "JaoHaSBztG8Fe+tSfjCMXd1VspA4rs6tu1CWd8GdeTI="
458
460
  }
package/API.md CHANGED
@@ -119,6 +119,7 @@ const deployableAwsCdkTypeScriptAppOptions: DeployableAwsCdkTypeScriptAppOptions
119
119
  | [`mergify`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertymergify) | `boolean` | Whether mergify should be enabled on this repository or not. |
120
120
  | [`mergifyOptions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertymergifyoptions) | [`projen.github.MergifyOptions`](#projen.github.MergifyOptions) | Options for mergify. |
121
121
  | [`projectType`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojecttype) | [`projen.ProjectType`](#projen.ProjectType) | Which type of project this is (library/app). |
122
+ | [`projenTokenSecret`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojentokensecret) | `string` | The name of a secret which includes a GitHub Personal Access Token to be used by projen workflows. |
122
123
  | [`readme`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyreadme) | [`projen.SampleReadmeProps`](#projen.SampleReadmeProps) | The README setup. |
123
124
  | [`stale`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertystale) | `boolean` | Auto-close of stale issues and pull request. |
124
125
  | [`staleOptions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertystaleoptions) | [`projen.github.StaleOptions`](#projen.github.StaleOptions) | Auto-close stale issues and pull requests. |
@@ -130,6 +131,8 @@ const deployableAwsCdkTypeScriptAppOptions: DeployableAwsCdkTypeScriptAppOptions
130
131
  | [`authorUrl`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyauthorurl) | `string` | Author's URL / Website. |
131
132
  | [`autoDetectBin`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyautodetectbin) | `boolean` | Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section. |
132
133
  | [`bin`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybin) | {[ key: string ]: `string`} | Binary programs vended with your module. |
134
+ | [`bugsEmail`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybugsemail) | `string` | The email address to which issues should be reported. |
135
+ | [`bugsUrl`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybugsurl) | `string` | The url to your project's issue tracker. |
133
136
  | [`bundledDeps`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybundleddeps) | `string`[] | List of dependencies to bundle into this module. |
134
137
  | [`codeArtifactOptions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycodeartifactoptions) | [`projen.javascript.CodeArtifactOptions`](#projen.javascript.CodeArtifactOptions) | Options for publishing npm package to AWS CodeArtifact. |
135
138
  | [`deps`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertydeps) | `string`[] | Runtime dependencies of this module. |
@@ -154,13 +157,12 @@ const deployableAwsCdkTypeScriptAppOptions: DeployableAwsCdkTypeScriptAppOptions
154
157
  | [`repositoryDirectory`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyrepositorydirectory) | `string` | If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives. |
155
158
  | [`scripts`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyscripts) | {[ key: string ]: `string`} | npm scripts to include. |
156
159
  | [`stability`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertystability) | `string` | Package's Stability. |
157
- | [`antitamper`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyantitamper) | `boolean` | Checks that after build there are no modified files on git. |
158
- | [`artifactsDirectory`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyartifactsdirectory) | `string` | A directory which will contain artifacts to be published to npm. |
159
160
  | [`jsiiReleaseVersion`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyjsiireleaseversion) | `string` | Version requirement of `jsii-release` which is used to publish modules to npm. |
160
161
  | [`majorVersion`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertymajorversion) | `number` | Major version to release from the default branch. |
161
162
  | [`npmDistTag`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertynpmdisttag) | `string` | The npmDistTag to use when publishing from the default branch. |
162
163
  | [`postBuildSteps`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypostbuildsteps) | [`projen.github.workflows.JobStep`](#projen.github.workflows.JobStep)[] | Steps to execute after build as part of the release workflow. |
163
164
  | [`prerelease`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprerelease) | `string` | Bump versions from the default branch as pre-releases (e.g. "beta", "alpha", "pre"). |
165
+ | [`publishDryRun`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypublishdryrun) | `boolean` | Instead of actually publishing to package managers, just print the publishing command. |
164
166
  | [`publishTasks`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypublishtasks) | `boolean` | Define publishing tasks that can be executed manually as well as workflows. |
165
167
  | [`releaseBranches`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyreleasebranches) | {[ key: string ]: [`projen.release.BranchOptions`](#projen.release.BranchOptions)} | Defines additional release branches. |
166
168
  | [`releaseEveryCommit`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyreleaseeverycommit) | `boolean` | Automatically release new versions every commit to one of branches in `releaseBranches`. |
@@ -175,6 +177,7 @@ const deployableAwsCdkTypeScriptAppOptions: DeployableAwsCdkTypeScriptAppOptions
175
177
  | [`workflowContainerImage`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyworkflowcontainerimage) | `string` | Container image to use for GitHub workflows. |
176
178
  | [`workflowRunsOn`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyworkflowrunson) | `string`[] | Github Runner selection labels. |
177
179
  | [`defaultReleaseBranch`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertydefaultreleasebranch)<span title="Required">*</span> | `string` | The name of the main release branch. |
180
+ | [`artifactsDirectory`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyartifactsdirectory) | `string` | A directory which will contain build artifacts. |
178
181
  | [`autoApproveProjenUpgrades`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyautoapproveprojenupgrades) | `boolean` | Automatically approve projen upgrade PRs, allowing them to be merged by mergify (if configued). |
179
182
  | [`autoApproveUpgrades`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyautoapproveupgrades) | `boolean` | Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued). |
180
183
  | [`buildWorkflow`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybuildworkflow) | `boolean` | Define a GitHub workflow for building PRs. |
@@ -193,6 +196,9 @@ const deployableAwsCdkTypeScriptAppOptions: DeployableAwsCdkTypeScriptAppOptions
193
196
  | [`mutableBuild`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertymutablebuild) | `boolean` | Automatically update files modified during builds to pull-request branches. |
194
197
  | [`npmignore`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertynpmignore) | `string`[] | Additional entries to .npmignore. |
195
198
  | [`npmignoreEnabled`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertynpmignoreenabled) | `boolean` | Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs. |
199
+ | [`package`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypackage) | `boolean` | Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`). |
200
+ | [`prettier`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprettier) | `boolean` | Setup prettier. |
201
+ | [`prettierOptions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprettieroptions) | [`projen.javascript.PrettierOptions`](#projen.javascript.PrettierOptions) | Prettier options. |
196
202
  | [`projenDevDependency`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojendevdependency) | `boolean` | Indicates of "projen" should be installed as a devDependency. |
197
203
  | [`projenrcJs`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojenrcjs) | `boolean` | Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation. |
198
204
  | [`projenrcJsOptions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojenrcjsoptions) | [`projen.javascript.ProjenrcOptions`](#projen.javascript.ProjenrcOptions) | Options for .projenrc.js. |
@@ -215,7 +221,6 @@ const deployableAwsCdkTypeScriptAppOptions: DeployableAwsCdkTypeScriptAppOptions
215
221
  | [`eslint`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyeslint) | `boolean` | Setup eslint. |
216
222
  | [`eslintOptions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyeslintoptions) | [`projen.javascript.EslintOptions`](#projen.javascript.EslintOptions) | Eslint options. |
217
223
  | [`libdir`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertylibdir) | `string` | Typescript artifacts output directory. |
218
- | [`package`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypackage) | `boolean` | Defines a `yarn package` command that will produce a tarball and place it under `dist/js`. |
219
224
  | [`projenrcTs`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojenrcts) | `boolean` | Use TypeScript for your projenrc file (`.projenrc.ts`). |
220
225
  | [`projenrcTsOptions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojenrctsoptions) | [`projen.typescript.ProjenrcOptions`](#projen.typescript.ProjenrcOptions) | Options for .projenrc.ts. |
221
226
  | [`sampleCode`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertysamplecode) | `boolean` | Generate one-time sample in `src/` and `test/` if there are no files there. |
@@ -227,15 +232,15 @@ const deployableAwsCdkTypeScriptAppOptions: DeployableAwsCdkTypeScriptAppOptions
227
232
  | [`typescriptVersion`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertytypescriptversion) | `string` | TypeScript version to use. |
228
233
  | [`buildCommand`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybuildcommand) | `string` | A command to execute before synthesis. |
229
234
  | [`cdkout`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkout) | `string` | cdk.out directory. |
230
- | [`context`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycontext) | {[ key: string ]: `string`} | Additional context to include in `cdk.json`. |
235
+ | [`context`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycontext) | {[ key: string ]: `any`} | Additional context to include in `cdk.json`. |
231
236
  | [`featureFlags`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyfeatureflags) | `boolean` | Include all feature flags in cdk.json. |
232
237
  | [`requireApproval`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyrequireapproval) | [`projen.awscdk.ApprovalLevel`](#projen.awscdk.ApprovalLevel) | To protect you against unintended changes that affect your security posture, the AWS CDK Toolkit prompts you to approve security-related changes before deploying them. |
233
238
  | [`watchExcludes`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertywatchexcludes) | `string`[] | Glob patterns to exclude from `cdk watch`. |
234
239
  | [`watchIncludes`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertywatchincludes) | `string`[] | Glob patterns to include in `cdk watch`. |
235
240
  | [`cdkVersion`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkversion)<span title="Required">*</span> | `string` | Minimum version of the AWS CDK to depend on. |
236
- | [`cdkAssert`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkassert) | `boolean` | Install the @aws-cdk/assert library? |
237
- | [`cdkAssertions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkassertions) | `boolean` | Install the @aws-cdk/assertions library? |
238
- | [`cdkDependencies`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkdependencies) | `string`[] | Which AWS CDK modules (those that start with "@aws-cdk/") does this library require when consumed? |
241
+ | [`cdkAssert`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkassert) | `boolean` | Warning: NodeJS only. |
242
+ | [`cdkAssertions`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkassertions) | `boolean` | Install the assertions library? |
243
+ | [`cdkDependencies`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkdependencies) | `string`[] | Which AWS CDKv1 modules this project requires. |
239
244
  | [`cdkDependenciesAsDeps`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkdependenciesasdeps) | `boolean` | If this is enabled (default), all modules declared in `cdkDependencies` will be also added as normal `dependencies` (as well as `peerDependencies`). |
240
245
  | [`cdkTestDependencies`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdktestdependencies) | `string`[] | AWS CDK modules required for testing. |
241
246
  | [`cdkVersionPinning`](#deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkversionpinning) | `boolean` | Use pinned version instead of caret version for CDK. |
@@ -483,6 +488,21 @@ Which type of project this is (library/app).
483
488
 
484
489
  ---
485
490
 
491
+ ##### `projenTokenSecret`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.projenTokenSecret" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojentokensecret"></a>
492
+
493
+ ```typescript
494
+ public readonly projenTokenSecret: string;
495
+ ```
496
+
497
+ - *Type:* `string`
498
+ - *Default:* "PROJEN_GITHUB_TOKEN"
499
+
500
+ The name of a secret which includes a GitHub Personal Access Token to be used by projen workflows.
501
+
502
+ This token needs to have the `repo`, `workflows` and `packages` scope.
503
+
504
+ ---
505
+
486
506
  ##### `readme`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.readme" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyreadme"></a>
487
507
 
488
508
  ```typescript
@@ -631,6 +651,30 @@ You can use this option to add/customize how binaries are represented in your `p
631
651
 
632
652
  ---
633
653
 
654
+ ##### `bugsEmail`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.bugsEmail" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybugsemail"></a>
655
+
656
+ ```typescript
657
+ public readonly bugsEmail: string;
658
+ ```
659
+
660
+ - *Type:* `string`
661
+
662
+ The email address to which issues should be reported.
663
+
664
+ ---
665
+
666
+ ##### `bugsUrl`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.bugsUrl" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybugsurl"></a>
667
+
668
+ ```typescript
669
+ public readonly bugsUrl: string;
670
+ ```
671
+
672
+ - *Type:* `string`
673
+
674
+ The url to your project's issue tracker.
675
+
676
+ ---
677
+
634
678
  ##### `bundledDeps`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.bundledDeps" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertybundleddeps"></a>
635
679
 
636
680
  ```typescript
@@ -958,32 +1002,6 @@ Package's Stability.
958
1002
 
959
1003
  ---
960
1004
 
961
- ##### `antitamper`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.antitamper" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyantitamper"></a>
962
-
963
- ```typescript
964
- public readonly antitamper: boolean;
965
- ```
966
-
967
- - *Type:* `boolean`
968
- - *Default:* true
969
-
970
- Checks that after build there are no modified files on git.
971
-
972
- ---
973
-
974
- ##### `artifactsDirectory`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.artifactsDirectory" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyartifactsdirectory"></a>
975
-
976
- ```typescript
977
- public readonly artifactsDirectory: string;
978
- ```
979
-
980
- - *Type:* `string`
981
- - *Default:* "dist"
982
-
983
- A directory which will contain artifacts to be published to npm.
984
-
985
- ---
986
-
987
1005
  ##### `jsiiReleaseVersion`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.jsiiReleaseVersion" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyjsiireleaseversion"></a>
988
1006
 
989
1007
  ```typescript
@@ -1053,6 +1071,19 @@ Bump versions from the default branch as pre-releases (e.g. "beta", "alpha", "pr
1053
1071
 
1054
1072
  ---
1055
1073
 
1074
+ ##### `publishDryRun`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.publishDryRun" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypublishdryrun"></a>
1075
+
1076
+ ```typescript
1077
+ public readonly publishDryRun: boolean;
1078
+ ```
1079
+
1080
+ - *Type:* `boolean`
1081
+ - *Default:* false
1082
+
1083
+ Instead of actually publishing to package managers, just print the publishing command.
1084
+
1085
+ ---
1086
+
1056
1087
  ##### `publishTasks`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.publishTasks" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypublishtasks"></a>
1057
1088
 
1058
1089
  ```typescript
@@ -1248,6 +1279,19 @@ The name of the main release branch.
1248
1279
 
1249
1280
  ---
1250
1281
 
1282
+ ##### `artifactsDirectory`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.artifactsDirectory" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyartifactsdirectory"></a>
1283
+
1284
+ ```typescript
1285
+ public readonly artifactsDirectory: string;
1286
+ ```
1287
+
1288
+ - *Type:* `string`
1289
+ - *Default:* "dist"
1290
+
1291
+ A directory which will contain build artifacts.
1292
+
1293
+ ---
1294
+
1251
1295
  ##### `autoApproveProjenUpgrades`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.autoApproveProjenUpgrades" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyautoapproveprojenupgrades"></a>
1252
1296
 
1253
1297
  ```typescript
@@ -1491,6 +1535,45 @@ Defines an .npmignore file. Normally this is only needed for libraries that are
1491
1535
 
1492
1536
  ---
1493
1537
 
1538
+ ##### `package`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.package" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypackage"></a>
1539
+
1540
+ ```typescript
1541
+ public readonly package: boolean;
1542
+ ```
1543
+
1544
+ - *Type:* `boolean`
1545
+ - *Default:* true
1546
+
1547
+ Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`).
1548
+
1549
+ ---
1550
+
1551
+ ##### `prettier`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.prettier" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprettier"></a>
1552
+
1553
+ ```typescript
1554
+ public readonly prettier: boolean;
1555
+ ```
1556
+
1557
+ - *Type:* `boolean`
1558
+ - *Default:* false
1559
+
1560
+ Setup prettier.
1561
+
1562
+ ---
1563
+
1564
+ ##### `prettierOptions`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.prettierOptions" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprettieroptions"></a>
1565
+
1566
+ ```typescript
1567
+ public readonly prettierOptions: PrettierOptions;
1568
+ ```
1569
+
1570
+ - *Type:* [`projen.javascript.PrettierOptions`](#projen.javascript.PrettierOptions)
1571
+ - *Default:* default options
1572
+
1573
+ Prettier options.
1574
+
1575
+ ---
1576
+
1494
1577
  ##### `projenDevDependency`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.projenDevDependency" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojendevdependency"></a>
1495
1578
 
1496
1579
  ```typescript
@@ -1560,7 +1643,9 @@ Customize the projenUpgrade schedule in cron expression.
1560
1643
 
1561
1644
  ---
1562
1645
 
1563
- ##### `projenUpgradeSecret`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.projenUpgradeSecret" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojenupgradesecret"></a>
1646
+ ##### ~~`projenUpgradeSecret`~~<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.projenUpgradeSecret" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojenupgradesecret"></a>
1647
+
1648
+ - *Deprecated:* use `githubTokenSecret` instead.
1564
1649
 
1565
1650
  ```typescript
1566
1651
  public readonly projenUpgradeSecret: string;
@@ -1785,19 +1870,6 @@ Typescript artifacts output directory.
1785
1870
 
1786
1871
  ---
1787
1872
 
1788
- ##### `package`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.package" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertypackage"></a>
1789
-
1790
- ```typescript
1791
- public readonly package: boolean;
1792
- ```
1793
-
1794
- - *Type:* `boolean`
1795
- - *Default:* true
1796
-
1797
- Defines a `yarn package` command that will produce a tarball and place it under `dist/js`.
1798
-
1799
- ---
1800
-
1801
1873
  ##### `projenrcTs`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.projenrcTs" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertyprojenrcts"></a>
1802
1874
 
1803
1875
  ```typescript
@@ -1949,10 +2021,10 @@ cdk.out directory.
1949
2021
  ##### `context`<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.context" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycontext"></a>
1950
2022
 
1951
2023
  ```typescript
1952
- public readonly context: {[ key: string ]: string};
2024
+ public readonly context: {[ key: string ]: any};
1953
2025
  ```
1954
2026
 
1955
- - *Type:* {[ key: string ]: `string`}
2027
+ - *Type:* {[ key: string ]: `any`}
1956
2028
  - *Default:* no additional context
1957
2029
 
1958
2030
  Additional context to include in `cdk.json`.
@@ -2035,6 +2107,8 @@ public readonly cdkAssert: boolean;
2035
2107
  - *Type:* `boolean`
2036
2108
  - *Default:* will be included by default for AWS CDK >= 1.0.0 < 2.0.0
2037
2109
 
2110
+ Warning: NodeJS only.
2111
+
2038
2112
  Install the @aws-cdk/assert library?
2039
2113
 
2040
2114
  ---
@@ -2048,7 +2122,7 @@ public readonly cdkAssertions: boolean;
2048
2122
  - *Type:* `boolean`
2049
2123
  - *Default:* will be included by default for AWS CDK >= 1.111.0 < 2.0.0
2050
2124
 
2051
- Install the @aws-cdk/assertions library?
2125
+ Install the assertions library?
2052
2126
 
2053
2127
  Only needed for CDK 1.x. If using CDK 2.x then assertions is already included in 'aws-cdk-lib'
2054
2128
 
@@ -2056,7 +2130,7 @@ Only needed for CDK 1.x. If using CDK 2.x then assertions is already included in
2056
2130
 
2057
2131
  ##### ~~`cdkDependencies`~~<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.cdkDependencies" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdkdependencies"></a>
2058
2132
 
2059
- - *Deprecated:* For CDK 2.x use 'peerDeps' instead
2133
+ - *Deprecated:* For CDK 2.x use "deps" instead. (or "peerDeps" if you're building a library)
2060
2134
 
2061
2135
  ```typescript
2062
2136
  public readonly cdkDependencies: string[];
@@ -2064,7 +2138,7 @@ public readonly cdkDependencies: string[];
2064
2138
 
2065
2139
  - *Type:* `string`[]
2066
2140
 
2067
- Which AWS CDK modules (those that start with "@aws-cdk/") does this library require when consumed?
2141
+ Which AWS CDKv1 modules this project requires.
2068
2142
 
2069
2143
  ---
2070
2144
 
@@ -2081,13 +2155,13 @@ public readonly cdkDependenciesAsDeps: boolean;
2081
2155
 
2082
2156
  If this is enabled (default), all modules declared in `cdkDependencies` will be also added as normal `dependencies` (as well as `peerDependencies`).
2083
2157
 
2084
- This is to ensure that downstream consumers actually have your CDK dependencies installed when using npm < 7 or yarn, where peer dependencies are not automatically installed. If this is disabled, `cdkDependencies` will be added to `devDependencies` to ensure they are present during development.
2158
+ This is to ensure that downstream consumers actually have your CDK dependencies installed when using npm < 7 or yarn, where peer dependencies are not automatically installed. If this is disabled, `cdkDependencies` will be added to `devDependencies` to ensure they are present during development. Note: this setting only applies to construct library projects
2085
2159
 
2086
2160
  ---
2087
2161
 
2088
2162
  ##### ~~`cdkTestDependencies`~~<sup>Optional</sup> <a name="deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptAppOptions.property.cdkTestDependencies" id="deployableawscdkapptsdeployableawscdktypescriptappoptionspropertycdktestdependencies"></a>
2089
2163
 
2090
- - *Deprecated:* For CDK 2.x use 'devDeps' instead
2164
+ - *Deprecated:* For CDK 2.x use 'devDeps' (in node.js projects) or 'testDeps' (in java projects) instead
2091
2165
 
2092
2166
  ```typescript
2093
2167
  public readonly cdkTestDependencies: string[];
@@ -2109,7 +2183,7 @@ public readonly cdkVersionPinning: boolean;
2109
2183
 
2110
2184
  Use pinned version instead of caret version for CDK.
2111
2185
 
2112
- You can use this to prevent yarn to mix versions for your CDK dependencies and to prevent auto-updates. If you use experimental features this will let you define the moment you include breaking changes.
2186
+ You can use this to prevent mixed versions for your CDK dependencies and to prevent auto-updates. If you use experimental features this will let you define the moment you include breaking changes.
2113
2187
 
2114
2188
  ---
2115
2189
 
package/changelog.md ADDED
@@ -0,0 +1,2 @@
1
+
2
+ ### [0.0.25](https://github.com/amin.fazl/deployable-awscdk-app-ts/compare/v0.0.24...v0.0.25) (2022-01-14)
package/lib/index.js CHANGED
@@ -129,11 +129,11 @@ class DeployableAwsCdkTypeScriptApp extends projen_1.awscdk.AwsCdkTypeScriptApp
129
129
  jobDefinition.steps.push(...steps.setAwsCredentialsSteps(this.checkActiveDeployment));
130
130
  if (this.deployOptions.npmConfigEnvironment)
131
131
  jobDefinition.steps.push(steps.setNpmConfig(this.deployOptions.npmConfigEnvironment, '${{ matrix.environment }}', this.checkActiveDeployment));
132
- jobDefinition.steps.push(steps.deploymentStep(this.checkActiveDeployment));
132
+ jobDefinition.steps.push(steps.deploymentStep(this.checkActiveDeployment, this.packageManager));
133
133
  (_b = this.release) === null || _b === void 0 ? void 0 : _b.addJobs({ deploy: jobDefinition });
134
134
  }
135
135
  }
136
136
  exports.DeployableAwsCdkTypeScriptApp = DeployableAwsCdkTypeScriptApp;
137
137
  _a = JSII_RTTI_SYMBOL_1;
138
- DeployableAwsCdkTypeScriptApp[_a] = { fqn: "deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptApp", version: "0.0.21" };
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {awscdk, TextFile} from 'projen'\nimport {Job, JobPermission} from 'projen/lib/github/workflows-model'\nimport * as steps from './steps'\nimport {DeployableAwsCdkTypeScriptAppOptions, DeployOptions, EnvironmentOptions} from './types'\n\nexport * from './types'\n\nexport class DeployableAwsCdkTypeScriptApp extends awscdk.AwsCdkTypeScriptApp {\n\n  private readonly deployable: boolean\n  private readonly generateNvmrc: boolean\n  private readonly checkActiveDeployment: boolean\n  private readonly workflowNodeVersion?: string\n  private readonly deployOptions: DeployOptions\n\n  constructor(options: DeployableAwsCdkTypeScriptAppOptions) {\n    const deployable = options.release ?? true\n    super({\n      ...options,\n      release: deployable,\n    })\n    this.deployable = deployable\n    this.generateNvmrc = options.generateNvmrc ?? true\n    this.checkActiveDeployment = options.checkActiveDeployment ?? false\n    this.workflowNodeVersion = options.workflowNodeVersion\n    this.deployOptions = options.deployOptions\n\n    if (!deployable)\n      console.warn('The project is explicitly set to not release, make sure this is desired setting')\n\n    if (this.generateNvmrc && !this.workflowNodeVersion)\n      throw new Error('workflowNodeVersion is required for nvmrc')\n  }\n\n  synth() {\n    if (this.deployable)\n      this.addDeployJobs()\n\n    if (this.generateNvmrc)\n      new TextFile(this, '.nvmrc', {\n        lines: [this.workflowNodeVersion ?? ''],\n      })\n    const deployArgument = this.deployOptions.stackPattern ? ` ${this.deployOptions.stackPattern}`: ''\n    this.addTask('deploy:workflow', {\n      exec: `cdk deploy${deployArgument} --require-approval never`,\n    })\n\n    super.synth()\n  }\n\n  addEnvironments(...items: EnvironmentOptions[]) {\n    this.deployOptions.environments.push(...items)\n  }\n\n  private addDeployJobs() {\n\n    if (this.deployOptions.environments.length === 0)\n      console.warn('The project does not have any environment set, make sure this is desired setting')\n\n    const include = this.deployOptions.environments.map(environmentOptions => {\n      const {awsCredentials} = environmentOptions\n\n      const assumeRole = awsCredentials.roleToAssume ? 'true' : 'false'\n\n      const assumeRoleSettings = awsCredentials.roleToAssume ? {\n        roleToAssume: awsCredentials.roleToAssume,\n        assumeRoleDurationSeconds: (awsCredentials.assumeRoleDurationSeconds || 300).toString(),\n      }: undefined\n\n      const accessKeyIdSecretName = awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID'\n      const secretAccessKeySecretName = awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY'\n\n      return {\n        environment: environmentOptions.name,\n        accessKeyIdSecretName,\n        secretAccessKeySecretName,\n        region: awsCredentials.region,\n        assumeRole,\n        ...assumeRoleSettings,\n      }\n    })\n\n    const jobDefinition: Job = {\n      runsOn: ['ubuntu-latest'],\n      concurrency: 'deploy',\n      needs: [\n        'release_github',\n      ],\n      permissions: {\n        contents: JobPermission.READ,\n        deployments: JobPermission.READ,\n      },\n      strategy: {\n        maxParallel: 1,\n        matrix: {\n          domain: {\n            environment: include.map(e => e.environment),\n          },\n          include,\n        },\n      },\n      environment: {\n        name: '${{ matrix.environment }}',\n      },\n      steps: [],\n    }\n\n    jobDefinition.steps.push(steps.checkoutStep())\n\n    if (this.checkActiveDeployment)\n      jobDefinition.steps.push(steps.checkActiveDeploymentStep())\n\n    if (this.workflowNodeVersion)\n      jobDefinition.steps.push(steps.setNodeVersionStep(this.workflowNodeVersion, this.checkActiveDeployment))\n\n    jobDefinition.steps.push(steps.installDependenciesStep(this.package.installCommand, this.checkActiveDeployment))\n    jobDefinition.steps.push(...steps.setAwsCredentialsSteps(this.checkActiveDeployment))\n\n    if (this.deployOptions.npmConfigEnvironment)\n      jobDefinition.steps.push(steps.setNpmConfig(this.deployOptions.npmConfigEnvironment, '${{ matrix.environment }}', this.checkActiveDeployment))\n\n    jobDefinition.steps.push(steps.deploymentStep(this.checkActiveDeployment))\n\n    this.release?.addJobs({deploy: jobDefinition})\n\n  }\n}"]}
138
+ DeployableAwsCdkTypeScriptApp[_a] = { fqn: "deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptApp", version: "0.0.25" };
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {awscdk, TextFile} from 'projen'\nimport {Job, JobPermission} from 'projen/lib/github/workflows-model'\nimport * as steps from './steps'\nimport {DeployableAwsCdkTypeScriptAppOptions, DeployOptions, EnvironmentOptions} from './types'\n\nexport * from './types'\n\nexport class DeployableAwsCdkTypeScriptApp extends awscdk.AwsCdkTypeScriptApp {\n\n  private readonly deployable: boolean\n  private readonly generateNvmrc: boolean\n  private readonly checkActiveDeployment: boolean\n  private readonly workflowNodeVersion?: string\n  private readonly deployOptions: DeployOptions\n\n  constructor(options: DeployableAwsCdkTypeScriptAppOptions) {\n    const deployable = options.release ?? true\n    super({\n      ...options,\n      release: deployable,\n    })\n    this.deployable = deployable\n    this.generateNvmrc = options.generateNvmrc ?? true\n    this.checkActiveDeployment = options.checkActiveDeployment ?? false\n    this.workflowNodeVersion = options.workflowNodeVersion\n    this.deployOptions = options.deployOptions\n\n    if (!deployable)\n      console.warn('The project is explicitly set to not release, make sure this is desired setting')\n\n    if (this.generateNvmrc && !this.workflowNodeVersion)\n      throw new Error('workflowNodeVersion is required for nvmrc')\n  }\n\n  synth() {\n    if (this.deployable)\n      this.addDeployJobs()\n\n    if (this.generateNvmrc)\n      new TextFile(this, '.nvmrc', {\n        lines: [this.workflowNodeVersion ?? ''],\n      })\n\n    const deployArgument = this.deployOptions.stackPattern ? ` ${this.deployOptions.stackPattern}`: ''\n    this.addTask('deploy:workflow', {\n      exec: `cdk deploy${deployArgument} --require-approval never`,\n    })\n\n    super.synth()\n  }\n\n  addEnvironments(...items: EnvironmentOptions[]) {\n    this.deployOptions.environments.push(...items)\n  }\n\n  private addDeployJobs() {\n\n    if (this.deployOptions.environments.length === 0)\n      console.warn('The project does not have any environment set, make sure this is desired setting')\n\n    const include = this.deployOptions.environments.map(environmentOptions => {\n      const {awsCredentials} = environmentOptions\n\n      const assumeRole = awsCredentials.roleToAssume ? 'true' : 'false'\n\n      const assumeRoleSettings = awsCredentials.roleToAssume ? {\n        roleToAssume: awsCredentials.roleToAssume,\n        assumeRoleDurationSeconds: (awsCredentials.assumeRoleDurationSeconds || 300).toString(),\n      }: undefined\n\n      const accessKeyIdSecretName = awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID'\n      const secretAccessKeySecretName = awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY'\n\n      return {\n        environment: environmentOptions.name,\n        accessKeyIdSecretName,\n        secretAccessKeySecretName,\n        region: awsCredentials.region,\n        assumeRole,\n        ...assumeRoleSettings,\n      }\n    })\n\n    const jobDefinition: Job = {\n      runsOn: ['ubuntu-latest'],\n      concurrency: 'deploy',\n      needs: [\n        'release_github',\n      ],\n      permissions: {\n        contents: JobPermission.READ,\n        deployments: JobPermission.READ,\n      },\n      strategy: {\n        maxParallel: 1,\n        matrix: {\n          domain: {\n            environment: include.map(e => e.environment),\n          },\n          include,\n        },\n      },\n      environment: {\n        name: '${{ matrix.environment }}',\n      },\n      steps: [],\n    }\n\n    jobDefinition.steps.push(steps.checkoutStep())\n\n    if (this.checkActiveDeployment)\n      jobDefinition.steps.push(steps.checkActiveDeploymentStep())\n\n    if (this.workflowNodeVersion)\n      jobDefinition.steps.push(steps.setNodeVersionStep(this.workflowNodeVersion, this.checkActiveDeployment))\n\n    jobDefinition.steps.push(steps.installDependenciesStep(this.package.installCommand, this.checkActiveDeployment))\n    jobDefinition.steps.push(...steps.setAwsCredentialsSteps(this.checkActiveDeployment))\n\n    if (this.deployOptions.npmConfigEnvironment)\n      jobDefinition.steps.push(steps.setNpmConfig(this.deployOptions.npmConfigEnvironment, '${{ matrix.environment }}', this.checkActiveDeployment))\n\n    jobDefinition.steps.push(steps.deploymentStep(this.checkActiveDeployment, this.packageManager))\n\n    this.release?.addJobs({deploy: jobDefinition})\n\n  }\n}"]}
package/lib/steps.d.ts CHANGED
@@ -1,8 +1,9 @@
1
+ import { javascript } from 'projen';
1
2
  import { JobStep } from 'projen/lib/github/workflows-model';
2
3
  export declare function checkoutStep(): JobStep;
3
4
  export declare function setNodeVersionStep(nodeVersion: string, checkActiveDeployment: boolean): JobStep;
4
5
  export declare function installDependenciesStep(command: string, checkActiveDeployment: boolean): JobStep;
5
- export declare function deploymentStep(checkActiveDeployment: boolean): JobStep;
6
+ export declare function deploymentStep(checkActiveDeployment: boolean, packageManager: javascript.NodePackageManager): JobStep;
6
7
  export declare function setAwsCredentialsSteps(checkActiveDeployment: boolean): JobStep[];
7
8
  export declare function setNpmConfig(configName: string, configValue: string, checkActiveDeployment: boolean): JobStep;
8
9
  export declare function checkActiveDeploymentStep(): JobStep;
package/lib/steps.js CHANGED
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.checkActiveDeploymentStep = exports.setNpmConfig = exports.setAwsCredentialsSteps = exports.deploymentStep = exports.installDependenciesStep = exports.setNodeVersionStep = exports.checkoutStep = void 0;
4
+ const projen_1 = require("projen");
4
5
  function checkoutStep() {
5
6
  return {
6
7
  name: 'Checkout',
@@ -30,11 +31,20 @@ function installDependenciesStep(command, checkActiveDeployment) {
30
31
  };
31
32
  }
32
33
  exports.installDependenciesStep = installDependenciesStep;
33
- function deploymentStep(checkActiveDeployment) {
34
+ function getPackageManagerCommandPrefix(packageManager) {
35
+ if (packageManager === projen_1.javascript.NodePackageManager.NPM)
36
+ return 'npm run';
37
+ if (packageManager === projen_1.javascript.NodePackageManager.YARN)
38
+ return 'yarn';
39
+ if (packageManager === projen_1.javascript.NodePackageManager.PNPM)
40
+ return 'pnpm';
41
+ throw new Error(`Invalid package manager selected (${packageManager})`);
42
+ }
43
+ function deploymentStep(checkActiveDeployment, packageManager) {
34
44
  return {
35
45
  ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),
36
46
  name: 'Deployment',
37
- run: 'npx projen deploy:workflow',
47
+ run: `${getPackageManagerCommandPrefix(packageManager)} deploy:workflow`,
38
48
  };
39
49
  }
40
50
  exports.deploymentStep = deploymentStep;
@@ -108,8 +118,8 @@ function checkActiveDeploymentStep() {
108
118
  };
109
119
  }
110
120
  exports.checkActiveDeploymentStep = checkActiveDeploymentStep;
111
- const skipIfAlreadyActiveDeploymentCondition = `steps.${checkActiveDeploymentStepId}.outputs.has_active_deployment == 'true'`;
121
+ const skipIfAlreadyActiveDeploymentCondition = `steps.${checkActiveDeploymentStepId}.outputs.has_active_deployment != 'true'`;
112
122
  function getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment) {
113
123
  return checkActiveDeployment ? { if: `\${{ ${skipIfAlreadyActiveDeploymentCondition} }}` } : undefined;
114
124
  }
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.js","sourceRoot":"","sources":["../src/steps.ts"],"names":[],"mappings":"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","sourcesContent":["import {JobStep} from 'projen/lib/github/workflows-model'\n\nexport function checkoutStep(): JobStep {\n  return {\n    name: 'Checkout',\n    uses: 'actions/checkout@v2',\n    with: {\n      ref: '${{ github.sha }}',\n    },\n  }\n}\n\nexport function setNodeVersionStep(nodeVersion: string, checkActiveDeployment: boolean): JobStep {\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Setup Node.js',\n    uses: 'actions/setup-node@v2.2.0',\n    with: {\n      'node-version': nodeVersion,\n    },\n  }\n}\n\nexport function installDependenciesStep(command: string, checkActiveDeployment: boolean): JobStep {\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Install dependencies',\n    run: command,\n  }\n}\n\nexport function deploymentStep(checkActiveDeployment: boolean): JobStep {\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Deployment',\n    run: 'npx projen deploy:workflow',\n  }\n}\n\nfunction setAwsCredentialsInEnvironment(checkActiveDeployment: boolean): JobStep {\n  const commands = [\n    'echo \"AWS_ACCESS_KEY_ID=$accessKeyId\" >> $GITHUB_ENV',\n    'echo \"AWS_SECRET_ACCESS_KEY=$secretAccessKey\" >> $GITHUB_ENV',\n    'echo \"AWS_REGION=$region\" >> $GITHUB_ENV',\n  ]\n\n  const condition =\n    checkActiveDeployment ?\n      `\\${{ matrix.assumeRole == 'false' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n      '${{ matrix.assumeRole == \\'false\\' }}'\n\n  return {\n    if: condition,\n    name: 'Configure AWS Credentials',\n    run: `\\n${commands.join('\\n')}`,\n    env: {\n      accessKeyId: '${{ secrets[matrix.accessKeyIdSecretName] }}',\n      secretAccessKey: '${{ secrets[matrix.secretAccessKeySecretName] }}',\n      region: '${{ matrix.region }}',\n    },\n  }\n}\n\nfunction assumeAwsRoleStep(checkActiveDeployment: boolean): JobStep {\n  const condition =\n    checkActiveDeployment ?\n      `\\${{ matrix.assumeRole == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n      '${{ matrix.assumeRole == \\'true\\' }}'\n  return {\n    if: condition,\n    name: 'Assume AWS Role',\n    uses: 'aws-actions/configure-aws-credentials@v1',\n    with: {\n      'aws-access-key-id': '${{ secrets[matrix.accessKeyIdSecretName] }}',\n      'aws-secret-access-key': '${{ secrets[matrix.secretAccessKeySecretName] }}',\n      'role-to-assume': '${{ matrix.roleToAssume }}',\n      'aws-region': '${{ matrix.region }}',\n      'role-duration-seconds': 1200, //'${{ matrix.assumeRoleDurationSeconds }}',\n    },\n  }\n}\n\nexport function setAwsCredentialsSteps(checkActiveDeployment: boolean): JobStep[] {\n  return [\n    setAwsCredentialsInEnvironment(checkActiveDeployment),\n    assumeAwsRoleStep(checkActiveDeployment),\n  ]\n}\n\nexport function setNpmConfig(configName: string, configValue: string, checkActiveDeployment: boolean): JobStep {\n  const environmentVariableName = 'CONFIG_VALUE'\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Setting NPM Config',\n    env: {\n      [environmentVariableName]: configValue,\n    },\n    run: `npm config set ${configName} $${environmentVariableName}`,\n  }\n}\n\nconst checkActiveDeploymentStepId = 'deployment-check'\nexport function checkActiveDeploymentStep(): JobStep {\n  return {\n    id: checkActiveDeploymentStepId,\n    uses: 'AminFazlMondo/check-deployed-environment@v1',\n    with: {\n      environment: '${{ matrix.environment }}',\n    },\n    env: {\n      GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}',\n    },\n  }\n}\n\nconst skipIfAlreadyActiveDeploymentCondition= `steps.${checkActiveDeploymentStepId}.outputs.has_active_deployment == 'true'`\n\nfunction getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment: boolean): JobStep | undefined {\n  return checkActiveDeployment ? {if: `\\${{ ${skipIfAlreadyActiveDeploymentCondition} }}`} : undefined\n}"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.js","sourceRoot":"","sources":["../src/steps.ts"],"names":[],"mappings":"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","sourcesContent":["import {javascript} from 'projen'\nimport {JobStep} from 'projen/lib/github/workflows-model'\n\nexport function checkoutStep(): JobStep {\n  return {\n    name: 'Checkout',\n    uses: 'actions/checkout@v2',\n    with: {\n      ref: '${{ github.sha }}',\n    },\n  }\n}\n\nexport function setNodeVersionStep(nodeVersion: string, checkActiveDeployment: boolean): JobStep {\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Setup Node.js',\n    uses: 'actions/setup-node@v2.2.0',\n    with: {\n      'node-version': nodeVersion,\n    },\n  }\n}\n\nexport function installDependenciesStep(command: string, checkActiveDeployment: boolean): JobStep {\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Install dependencies',\n    run: command,\n  }\n}\n\nfunction getPackageManagerCommandPrefix(packageManager: javascript.NodePackageManager): string {\n  if (packageManager === javascript.NodePackageManager.NPM)\n    return 'npm run'\n\n  if (packageManager === javascript.NodePackageManager.YARN)\n    return 'yarn'\n\n  if (packageManager === javascript.NodePackageManager.PNPM)\n    return 'pnpm'\n\n  throw new Error(`Invalid package manager selected (${packageManager})`)\n}\n\nexport function deploymentStep(checkActiveDeployment: boolean, packageManager: javascript.NodePackageManager): JobStep {\n\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Deployment',\n    run: `${getPackageManagerCommandPrefix(packageManager)} deploy:workflow`,\n  }\n}\n\nfunction setAwsCredentialsInEnvironment(checkActiveDeployment: boolean): JobStep {\n  const commands = [\n    'echo \"AWS_ACCESS_KEY_ID=$accessKeyId\" >> $GITHUB_ENV',\n    'echo \"AWS_SECRET_ACCESS_KEY=$secretAccessKey\" >> $GITHUB_ENV',\n    'echo \"AWS_REGION=$region\" >> $GITHUB_ENV',\n  ]\n\n  const condition =\n    checkActiveDeployment ?\n      `\\${{ matrix.assumeRole == 'false' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n      '${{ matrix.assumeRole == \\'false\\' }}'\n\n  return {\n    if: condition,\n    name: 'Configure AWS Credentials',\n    run: `\\n${commands.join('\\n')}`,\n    env: {\n      accessKeyId: '${{ secrets[matrix.accessKeyIdSecretName] }}',\n      secretAccessKey: '${{ secrets[matrix.secretAccessKeySecretName] }}',\n      region: '${{ matrix.region }}',\n    },\n  }\n}\n\nfunction assumeAwsRoleStep(checkActiveDeployment: boolean): JobStep {\n  const condition =\n    checkActiveDeployment ?\n      `\\${{ matrix.assumeRole == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n      '${{ matrix.assumeRole == \\'true\\' }}'\n  return {\n    if: condition,\n    name: 'Assume AWS Role',\n    uses: 'aws-actions/configure-aws-credentials@v1',\n    with: {\n      'aws-access-key-id': '${{ secrets[matrix.accessKeyIdSecretName] }}',\n      'aws-secret-access-key': '${{ secrets[matrix.secretAccessKeySecretName] }}',\n      'role-to-assume': '${{ matrix.roleToAssume }}',\n      'aws-region': '${{ matrix.region }}',\n      'role-duration-seconds': 1200, //'${{ matrix.assumeRoleDurationSeconds }}',\n    },\n  }\n}\n\nexport function setAwsCredentialsSteps(checkActiveDeployment: boolean): JobStep[] {\n  return [\n    setAwsCredentialsInEnvironment(checkActiveDeployment),\n    assumeAwsRoleStep(checkActiveDeployment),\n  ]\n}\n\nexport function setNpmConfig(configName: string, configValue: string, checkActiveDeployment: boolean): JobStep {\n  const environmentVariableName = 'CONFIG_VALUE'\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: 'Setting NPM Config',\n    env: {\n      [environmentVariableName]: configValue,\n    },\n    run: `npm config set ${configName} $${environmentVariableName}`,\n  }\n}\n\nconst checkActiveDeploymentStepId = 'deployment-check'\nexport function checkActiveDeploymentStep(): JobStep {\n  return {\n    id: checkActiveDeploymentStepId,\n    uses: 'AminFazlMondo/check-deployed-environment@v1',\n    with: {\n      environment: '${{ matrix.environment }}',\n    },\n    env: {\n      GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}',\n    },\n  }\n}\n\nconst skipIfAlreadyActiveDeploymentCondition= `steps.${checkActiveDeploymentStepId}.outputs.has_active_deployment != 'true'`\n\nfunction getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment: boolean): JobStep | undefined {\n  return checkActiveDeployment ? {if: `\\${{ ${skipIfAlreadyActiveDeploymentCondition} }}`} : undefined\n}"]}
package/package.json CHANGED
@@ -15,7 +15,10 @@
15
15
  "docgen": "npx projen docgen",
16
16
  "eslint": "npx projen eslint",
17
17
  "package": "npx projen package",
18
+ "package-all": "npx projen package-all",
19
+ "package:js": "npx projen package:js",
18
20
  "post-compile": "npx projen post-compile",
21
+ "post-upgrade": "npx projen post-upgrade",
19
22
  "pre-compile": "npx projen pre-compile",
20
23
  "publish:github": "npx projen publish:github",
21
24
  "publish:npm": "npx projen publish:npm",
@@ -35,36 +38,34 @@
35
38
  },
36
39
  "devDependencies": {
37
40
  "@types/fs-extra": "^9.0.13",
38
- "@types/jest": "*",
41
+ "@types/jest": "^27.4.0",
39
42
  "@types/node": "^12",
40
43
  "@typescript-eslint/eslint-plugin": "^5",
41
44
  "@typescript-eslint/parser": "^5",
42
45
  "eslint": "^8",
43
46
  "eslint-import-resolver-node": "^0.3.6",
44
47
  "eslint-import-resolver-typescript": "^2.5.0",
45
- "eslint-plugin-import": "^2.25.3",
48
+ "eslint-plugin-import": "^2.25.4",
46
49
  "fs-extra": "^9.1.0",
47
- "jest": "^27.4.5",
50
+ "jest": "^27.4.7",
48
51
  "jest-junit": "^13",
49
- "jsii": "^1.49.0",
50
- "jsii-diff": "^1.49.0",
51
- "jsii-docgen": "^4.2.14",
52
- "jsii-pacmak": "^1.49.0",
52
+ "jsii": "^1.52.1",
53
+ "jsii-diff": "^1.52.1",
54
+ "jsii-docgen": "^4.2.39",
53
55
  "json-schema": "^0.4.0",
54
56
  "npm-check-updates": "^12",
55
- "projen": "^0.45.3",
57
+ "projen": "^0.50.30",
56
58
  "standard-version": "^9",
57
59
  "ts-jest": "^27.1.2",
58
60
  "ts-node": "^9",
59
61
  "typescript": "^4.5.4"
60
62
  },
61
63
  "peerDependencies": {
62
- "projen": "^0.45.3"
64
+ "projen": "^0.50.30"
63
65
  },
64
66
  "dependencies": {
65
- "projen": "^0.45.3"
67
+ "projen": "^0.50.30"
66
68
  },
67
- "bundledDependencies": [],
68
69
  "keywords": [
69
70
  "AWS CDK",
70
71
  "Deployment",
@@ -73,11 +74,11 @@
73
74
  ],
74
75
  "main": "lib/index.js",
75
76
  "license": "Apache-2.0",
76
- "version": "0.0.21",
77
+ "version": "0.0.25",
77
78
  "jest": {
78
79
  "testMatch": [
79
- "**/__tests__/**/*.ts?(x)",
80
- "**/?(*.)+(spec|test).ts?(x)"
80
+ "<rootDir>/src/**/__tests__/**/*.ts?(x)",
81
+ "<rootDir>/(test|src)/**/?(*.)+(spec|test).ts?(x)"
81
82
  ],
82
83
  "clearMocks": true,
83
84
  "collectCoverage": true,
@@ -85,6 +86,7 @@
85
86
  "json",
86
87
  "lcov",
87
88
  "clover",
89
+ "cobertura",
88
90
  "text"
89
91
  ],
90
92
  "coverageDirectory": "coverage",
package/releasetag.txt ADDED
@@ -0,0 +1 @@
1
+ v0.0.25
package/version.txt ADDED
@@ -0,0 +1 @@
1
+ 0.0.25