deployable-awscdk-app-ts 0.1.680 → 0.1.682

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/lib/steps.js CHANGED
@@ -1,163 +1,512 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.checkoutStep = checkoutStep;
4
- exports.setNodeVersionStep = setNodeVersionStep;
5
- exports.installDependenciesStep = installDependenciesStep;
6
- exports.deploymentStep = deploymentStep;
7
- exports.setAwsCredentialsSteps = setAwsCredentialsSteps;
8
- exports.setNpmConfig = setNpmConfig;
9
- exports.checkActiveDeploymentStep = checkActiveDeploymentStep;
10
- exports.postDeploymentStep = postDeploymentStep;
11
- exports.preDeploymentStep = preDeploymentStep;
12
- exports.preInstallDependenciesStep = preInstallDependenciesStep;
13
- const projen_1 = require("projen");
3
+ exports.DeployableAwsCdkTypeScriptAppStepsFactory = void 0;
4
+ const github_1 = require("projen/lib/github");
5
+ const workflows_model_1 = require("projen/lib/github/workflows-model");
14
6
  const javascript_1 = require("projen/lib/javascript");
15
- function checkoutStep() {
16
- return {
17
- name: 'Checkout',
18
- uses: 'actions/checkout@v4',
19
- with: {
20
- 'ref': '${{ github.sha }}',
21
- 'fetch-depth': 0,
22
- },
23
- };
24
- }
25
- function setNodeVersionStep(nodeVersion, checkActiveDeployment) {
26
- return {
27
- ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),
28
- name: 'Setup Node.js',
29
- uses: 'actions/setup-node@v4',
30
- with: {
31
- 'node-version': nodeVersion,
32
- },
33
- };
34
- }
35
- function installDependenciesStep(command, checkActiveDeployment) {
36
- return {
37
- ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),
38
- name: 'Install dependencies',
39
- run: command,
40
- };
41
- }
42
- function getPackageManagerCommandPrefix(packageManager) {
43
- if (packageManager === projen_1.javascript.NodePackageManager.NPM) {
44
- return 'npm run';
7
+ const types_1 = require("./types");
8
+ const checkActiveDeploymentStepId = 'deployment-check';
9
+ const skipIfAlreadyActiveDeploymentCondition = `steps.${checkActiveDeploymentStepId}.outputs.has_active_deployment != 'true'`;
10
+ /**
11
+ * Factory to create reusable steps for the deployment workflow
12
+ * @experimental
13
+ */
14
+ class DeployableAwsCdkTypeScriptAppStepsFactory {
15
+ /**
16
+ * Validate that the provided environment deployment dependencies are valid
17
+ * @param deployOptions The deployment options
18
+ * @param environmentDependencies The environment deployment dependencies to validate
19
+ */
20
+ static validateEnvironmentDeploymentDependencies(deployOptions, environmentDependencies) {
21
+ if (deployOptions.jobStrategy !== types_1.DeployJobStrategy.MULTI_JOB) {
22
+ throw new Error('Environment deployment dependencies are only supported for MULTI_JOB strategy');
23
+ }
24
+ Object.entries(environmentDependencies).forEach(([env, deps]) => {
25
+ const hasEnvironment = deployOptions.environments.some(e => e.name === env);
26
+ if (!hasEnvironment) {
27
+ throw new Error(`Environment "${env}" defined in dependencies does not exist in deployOptions.environments`);
28
+ }
29
+ deps.forEach(dep => {
30
+ const hasDepEnvironment = deployOptions.environments.some(e => e.name === dep);
31
+ if (!hasDepEnvironment) {
32
+ throw new Error(`Dependency environment "${dep}" for environment "${env}" does not exist in deployOptions.environments`);
33
+ }
34
+ });
35
+ });
45
36
  }
46
- if (packageManager === projen_1.javascript.NodePackageManager.YARN) {
47
- return 'yarn';
37
+ /**
38
+ * Create a new DeployableAwsCdkTypeScriptAppStepsFactory
39
+ * @param project The project
40
+ * @param props The factory properties
41
+ */
42
+ constructor(project, props) {
43
+ this.project = project;
44
+ this.props = props;
48
45
  }
49
- if (packageManager === projen_1.javascript.NodePackageManager.PNPM) {
50
- return 'pnpm';
46
+ /**
47
+ * Condition to skip a step if an active deployment is already present
48
+ * @returns JobStep condition or undefined if checkActiveDeployment is false
49
+ */
50
+ get skipIfAlreadyActiveDeploymentCondition() {
51
+ return this.props.checkActiveDeployment ? { if: `\${{ ${skipIfAlreadyActiveDeploymentCondition} }}` } : undefined;
51
52
  }
52
- throw new Error(`Invalid package manager selected (${packageManager})`);
53
- }
54
- function deploymentStep(checkActiveDeployment, packageManager) {
55
- return {
56
- ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),
57
- name: 'Deployment',
58
- run: `${getPackageManagerCommandPrefix(packageManager)} deploy:workflow`,
59
- };
60
- }
61
- function setAwsCredentialsInEnvironment(checkActiveDeployment) {
62
- const commands = [
63
- 'echo "AWS_ACCESS_KEY_ID=$accessKeyId" >> $GITHUB_ENV',
64
- 'echo "AWS_SECRET_ACCESS_KEY=$secretAccessKey" >> $GITHUB_ENV',
65
- 'echo "AWS_REGION=$region" >> $GITHUB_ENV',
66
- ];
67
- const condition = checkActiveDeployment ?
68
- `\${{ matrix.assumeRole == 'false' && ${skipIfAlreadyActiveDeploymentCondition} }}` :
69
- '${{ matrix.assumeRole == \'false\' }}';
70
- return {
71
- if: condition,
72
- name: 'Configure AWS Credentials',
73
- run: `${commands.join('\n')}`,
74
- env: {
75
- accessKeyId: '${{ secrets[matrix.accessKeyIdSecretName] }}',
76
- secretAccessKey: '${{ secrets[matrix.secretAccessKeySecretName] }}',
77
- region: '${{ matrix.region }}',
78
- },
79
- };
80
- }
81
- function assumeAwsRoleStep(checkActiveDeployment, authProvider) {
82
- const condition = checkActiveDeployment ?
83
- `\${{ matrix.assumeRole == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :
84
- '${{ matrix.assumeRole == \'true\' }}';
85
- const secretsParams = authProvider === javascript_1.CodeArtifactAuthProvider.ACCESS_AND_SECRET_KEY_PAIR ?
86
- {
87
- 'aws-access-key-id': '${{ secrets[matrix.accessKeyIdSecretName] }}',
88
- 'aws-secret-access-key': '${{ secrets[matrix.secretAccessKeySecretName] }}',
53
+ get checkoutStep() {
54
+ return github_1.WorkflowSteps.checkout({
55
+ with: {
56
+ fetchDepth: 0,
57
+ ref: '${{ github.sha }}',
58
+ },
59
+ });
60
+ }
61
+ /**
62
+ * Step to run before installing dependencies if exists
63
+ * @returns JobStep or undefined if no preInstallTaskName is provided
64
+ */
65
+ get preInstallDependenciesStep() {
66
+ if (!this.props.preInstallTaskName) {
67
+ return undefined;
68
+ }
69
+ return {
70
+ ...this.skipIfAlreadyActiveDeploymentCondition,
71
+ name: this.props.preInstallTaskName,
72
+ run: `npx projen ${this.props.preInstallTaskName}`,
73
+ };
74
+ }
75
+ /**
76
+ * Step to check if there is an active deployment for the environment in the matrix strategy
77
+ * @returns JobStep
78
+ */
79
+ get checkActiveDeploymentStepForMatrix() {
80
+ return this.getCheckActiveDeploymentStepForEnvironment('${{ matrix.environment }}');
81
+ }
82
+ /**
83
+ * Step to check if there is an active deployment for a specific environment
84
+ * @param environment The environment to check
85
+ * @returns JobStep
86
+ */
87
+ getCheckActiveDeploymentStepForEnvironment(environment) {
88
+ if (!this.props.checkActiveDeployment) {
89
+ return undefined;
90
+ }
91
+ return {
92
+ id: checkActiveDeploymentStepId,
93
+ uses: 'AminFazlMondo/check-deployed-environment@v1',
94
+ with: {
95
+ environment: environment,
96
+ },
97
+ env: {
98
+ GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}',
99
+ },
100
+ };
101
+ }
102
+ /**
103
+ * Step to setup AWS credentials in the environment for the matrix strategy
104
+ * @returns JobStep[]
105
+ */
106
+ get setupAwsCredentialsStepsForMatrix() {
107
+ return [
108
+ this.setupAwsCredentialsInEnvironmentForMatrix,
109
+ this.assumeAwsRoleStepForMatrix,
110
+ ];
111
+ }
112
+ /**
113
+ * Get the steps to setup AWS credentials for a specific environment
114
+ * @param environmentOptions The environment options
115
+ * @returns JobStep[]
116
+ */
117
+ getSetupAwsCredentialsStepsForEnvironment(environmentOptions) {
118
+ const steps = [];
119
+ const fromEnvVariableStep = this.getSetupAwsCredentialsInEnvironmentForEnvironment(environmentOptions.awsCredentials.roleToAssume ? true : false, environmentOptions.awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID', environmentOptions.awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY', environmentOptions.awsCredentials.region);
120
+ if (fromEnvVariableStep) {
121
+ steps.push(fromEnvVariableStep);
122
+ }
123
+ const assumeRoleStep = this.getAssumeAwsRoleStepForEnvironment(environmentOptions.awsCredentials.roleToAssume ? true : false, environmentOptions.awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID', environmentOptions.awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY', environmentOptions.awsCredentials.region, environmentOptions.awsCredentials.roleToAssume ?? '', environmentOptions.awsCredentials.assumeRoleDurationSeconds ?? 900);
124
+ if (assumeRoleStep) {
125
+ steps.push(assumeRoleStep);
126
+ }
127
+ return steps;
128
+ }
129
+ /**
130
+ * Step to setup AWS credentials in the environment for the matrix strategy
131
+ * @returns JobStep
132
+ */
133
+ get setupAwsCredentialsInEnvironmentForMatrix() {
134
+ return this.getSetupAwsCredentialsInEnvironmentForEnvironment('matrix.assumeRole', 'matrix.accessKeyIdSecretName', 'matrix.secretAccessKeySecretName', '${{ matrix.region }}');
135
+ }
136
+ /**
137
+ * Step to setup AWS credentials in the environment for a specific environment
138
+ * @param assumeRoleFlag Whether to assume a role, can be a boolean or a string for matrix strategy
139
+ * @param accessKeyIdSecretName The GitHub secret name for the access key ID
140
+ * @param secretAccessKeySecretName The GitHub secret name for the secret access key
141
+ * @param region The region
142
+ * @returns JobStep or undefined if no AWS credentials are provided,
143
+ * if assumeRoleFlag is boolean will be evaluated and return a JobStep only if false
144
+ * if assumeRoleFlag is string will always return a JobStep (for matrix strategy)
145
+ */
146
+ getSetupAwsCredentialsInEnvironmentForEnvironment(assumeRoleFlag, accessKeyIdSecretName, secretAccessKeySecretName, region) {
147
+ function getCondition(factory) {
148
+ if (typeof assumeRoleFlag === 'boolean') {
149
+ if (assumeRoleFlag) {
150
+ return undefined;
151
+ }
152
+ return factory.props.checkActiveDeployment ? skipIfAlreadyActiveDeploymentCondition : undefined;
153
+ }
154
+ return factory.props.checkActiveDeployment ?
155
+ `\${{ ${assumeRoleFlag} == 'false' && ${skipIfAlreadyActiveDeploymentCondition} }}` :
156
+ `\${{ ${assumeRoleFlag} == 'false' }}`;
157
+ }
158
+ const commands = [
159
+ 'echo "AWS_ACCESS_KEY_ID=$accessKeyId" >> $GITHUB_ENV',
160
+ 'echo "AWS_SECRET_ACCESS_KEY=$secretAccessKey" >> $GITHUB_ENV',
161
+ 'echo "AWS_REGION=$region" >> $GITHUB_ENV',
162
+ ];
163
+ if (typeof assumeRoleFlag === 'boolean' && assumeRoleFlag) {
164
+ return undefined;
165
+ }
166
+ const condition = getCondition(this);
167
+ return {
168
+ if: condition,
169
+ name: 'Configure AWS Credentials',
170
+ run: `${commands.join('\n')}`,
171
+ env: {
172
+ accessKeyId: `\${{ secrets[${accessKeyIdSecretName}] }}`,
173
+ secretAccessKey: `\${{ secrets[${secretAccessKeySecretName}] }}`,
174
+ region,
175
+ },
176
+ };
177
+ }
178
+ /**
179
+ * Step to assume an AWS role for the matrix strategy
180
+ * @returns JobStep
181
+ */
182
+ get assumeAwsRoleStepForMatrix() {
183
+ return this.getAssumeAwsRoleStepForEnvironment('matrix.assumeRole', 'matrix.accessKeyIdSecretName', 'matrix.secretAccessKeySecretName', '${{ matrix.region }}', '${{ matrix.roleToAssume }}', '${{ matrix.assumeRoleDurationSeconds }}');
184
+ }
185
+ /**
186
+ * Step to assume an AWS role for a specific environment
187
+ * @param assumeRoleFlag Whether to assume a role, can be a boolean or a string for matrix strategy
188
+ * @param accessKeyIdSecretName The GitHub secret name for the access key ID
189
+ * @param secretAccessKeySecretName The GitHub secret name for the secret access key
190
+ * @param region The region
191
+ * @param roleToAssume The role to assume
192
+ * @param assumeRoleDurationSeconds The duration for assuming the role
193
+ * @returns JobStep or undefined if assumeRoleFlag is boolean and false
194
+ * if assumeRoleFlag is string will always return a JobStep (for matrix strategy)
195
+ */
196
+ getAssumeAwsRoleStepForEnvironment(assumeRoleFlag, accessKeyIdSecretName, secretAccessKeySecretName, region, roleToAssume, assumeRoleDurationSeconds) {
197
+ function getCondition(factory) {
198
+ if (typeof assumeRoleFlag === 'boolean') {
199
+ if (!assumeRoleFlag) {
200
+ return undefined;
201
+ }
202
+ return factory.props.checkActiveDeployment ? skipIfAlreadyActiveDeploymentCondition : undefined;
203
+ }
204
+ return factory.props.checkActiveDeployment ?
205
+ `\${{ ${assumeRoleFlag} == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :
206
+ `\${{ ${assumeRoleFlag} == 'true' }}`;
207
+ }
208
+ if (typeof assumeRoleFlag === 'boolean' && !assumeRoleFlag) {
209
+ return undefined;
210
+ }
211
+ const condition = getCondition(this);
212
+ const secretsParams = this.props.authProvider === javascript_1.CodeArtifactAuthProvider.ACCESS_AND_SECRET_KEY_PAIR ?
213
+ {
214
+ 'aws-access-key-id': `\${{ secrets[${accessKeyIdSecretName}] }}`,
215
+ 'aws-secret-access-key': `\${{ secrets[${secretAccessKeySecretName}] }}`,
216
+ } : undefined;
217
+ return {
218
+ if: condition,
219
+ name: 'Assume AWS Role',
220
+ uses: 'aws-actions/configure-aws-credentials@v4',
221
+ with: {
222
+ ...secretsParams,
223
+ 'role-to-assume': roleToAssume,
224
+ 'aws-region': region,
225
+ 'role-duration-seconds': assumeRoleDurationSeconds,
226
+ },
227
+ };
228
+ }
229
+ /**
230
+ * Step to setup NPM config if provided
231
+ * @returns JobStep or undefined if no npmConfig is provided
232
+ */
233
+ get setupNpmConfigForMatrix() {
234
+ return this.getSetupNpmConfigForEnvironment('${{ matrix.environment }}');
235
+ }
236
+ getSetupNpmConfigForEnvironment(environment) {
237
+ const { npmConfigEnvironment } = this.props;
238
+ if (!npmConfigEnvironment) {
239
+ return undefined;
240
+ }
241
+ const environmentVariableName = 'CONFIG_VALUE';
242
+ return {
243
+ ...this.skipIfAlreadyActiveDeploymentCondition,
244
+ name: 'Setting NPM Config',
245
+ env: {
246
+ [environmentVariableName]: environment,
247
+ },
248
+ run: `npm config set ${npmConfigEnvironment} $${environmentVariableName}`,
249
+ };
250
+ }
251
+ /**
252
+ * Get the step to run a specific script
253
+ * @param scriptName The name of the script to run
254
+ * @param stepName The name of the step in the workflow
255
+ * @param hasScriptFlag Whether the script should be run
256
+ * @returns The job step to run the script or undefined if not applicable
257
+ * If hasScriptFlag is boolean and false will return undefined
258
+ * If hasScriptFlag is string will always return a JobStep (for matrix strategy)
259
+ */
260
+ getRunScriptStep(scriptName, stepName, hasScriptFlag) {
261
+ function getCondition(factory) {
262
+ if (typeof hasScriptFlag === 'boolean') {
263
+ if (!hasScriptFlag) {
264
+ return undefined;
265
+ }
266
+ return factory.props.checkActiveDeployment ? skipIfAlreadyActiveDeploymentCondition : undefined;
267
+ }
268
+ return factory.props.checkActiveDeployment ?
269
+ `\${{ ${hasScriptFlag} == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :
270
+ `\${{ ${hasScriptFlag} == 'true' }}`;
271
+ }
272
+ if (typeof hasScriptFlag === 'boolean' && !hasScriptFlag) {
273
+ return undefined;
274
+ }
275
+ const condition = getCondition(this);
276
+ return {
277
+ if: condition,
278
+ name: `Run ${stepName}`,
279
+ run: `${this.project.runScriptCommand} ${scriptName}`,
280
+ };
281
+ }
282
+ /**
283
+ * Step to deploy the workflow
284
+ * @returns JobStep
285
+ */
286
+ get deploymentStep() {
287
+ return this.getRunScriptStep('deploy:workflow', 'Deployment', true);
288
+ }
289
+ /**
290
+ * Step to run post deployment script in matrix strategy
291
+ * @returns JobStep
292
+ */
293
+ get preDeploymentStepForMatrix() {
294
+ return this.getPreDeploymentStepForEnvironment('matrix.hasPreDeployTask', '${{ matrix.preDeploymentScript }}');
295
+ }
296
+ /**
297
+ * Get the pre-deployment step for a specific environment
298
+ * @param hasPreDeployTaskFlag Whether the pre-deployment task should be run
299
+ * @param preDeploymentScript The script to run
300
+ * @returns The job step to run the pre-deployment script or undefined if not applicable
301
+ * If hasPreDeployTaskFlag is boolean and false will return undefined
302
+ * If hasPreDeployTaskFlag is string will always return a JobStep (for matrix strategy)
303
+ */
304
+ getPreDeploymentStepForEnvironment(hasPreDeployTaskFlag, preDeploymentScript) {
305
+ return this.getRunScriptStep(preDeploymentScript, 'Pre Deployment', hasPreDeployTaskFlag);
306
+ }
307
+ /**
308
+ * Step to run post deployment script in matrix strategy
309
+ * @returns JobStep
310
+ */
311
+ get postDeploymentStepForMatrix() {
312
+ return this.getPostDeploymentStepForEnvironment('matrix.hasPostDeployTask', '${{ matrix.postDeploymentScript }}');
313
+ }
314
+ /**
315
+ * Get the post-deployment step for a specific environment
316
+ * @param hasPostDeployTaskFlag Whether the post-deployment task should be run
317
+ * @param postDeploymentScript The script to run
318
+ * @returns The job step to run the post-deployment script or undefined if not applicable
319
+ * If hasPostDeployTaskFlag is boolean and false will return undefined
320
+ * If hasPostDeployTaskFlag is string will always return a JobStep (for matrix strategy)
321
+ */
322
+ getPostDeploymentStepForEnvironment(hasPostDeployTaskFlag, postDeploymentScript) {
323
+ return this.getRunScriptStep(postDeploymentScript, 'Post Deployment', hasPostDeployTaskFlag);
324
+ }
325
+ /**
326
+ * Get all deployment jobs whether for matrix strategy or not
327
+ * @returns Record of jobs
328
+ */
329
+ get deploymentJobs() {
330
+ if (this.props.deployOptions.environments.length === 0) {
331
+ this.project.logger.warn('The project does not have any environment set, make sure this is desired setting');
332
+ }
333
+ return this.props.jobStrategy === types_1.DeployJobStrategy.MATRIX ? this.deploymentJobsForMatrix : this.getDeploymentJobsForMultiJob();
334
+ }
335
+ /**
336
+ * Get deployment jobs for matrix strategy
337
+ * @returns Record of jobs
338
+ */
339
+ get deploymentJobsForMatrix() {
340
+ const { environments, environmentVariableName } = this.props.deployOptions;
341
+ const include = environments.map(environmentOptions => {
342
+ const { awsCredentials } = environmentOptions;
343
+ const assumeRole = awsCredentials.roleToAssume ? 'true' : 'false';
344
+ const assumeRoleSettings = awsCredentials.roleToAssume ? {
345
+ roleToAssume: awsCredentials.roleToAssume,
346
+ assumeRoleDurationSeconds: awsCredentials.assumeRoleDurationSeconds || 900,
347
+ } : undefined;
348
+ const accessKeyIdSecretName = awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID';
349
+ const secretAccessKeySecretName = awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY';
350
+ const hasPostDeployTask = environmentOptions.postDeployWorkflowScript ? 'true' : 'false';
351
+ const hasPreDeployTask = environmentOptions.preDeployWorkflowScript ? 'true' : 'false';
352
+ return {
353
+ environment: environmentOptions.name,
354
+ accessKeyIdSecretName,
355
+ secretAccessKeySecretName,
356
+ region: awsCredentials.region,
357
+ assumeRole,
358
+ hasPostDeployTask,
359
+ postDeploymentScript: environmentOptions.postDeployWorkflowScript || '',
360
+ hasPreDeployTask,
361
+ preDeploymentScript: environmentOptions.preDeployWorkflowScript || '',
362
+ ...assumeRoleSettings,
363
+ };
364
+ });
365
+ const deployJobEnv = environmentVariableName ? {
366
+ [environmentVariableName]: '${{ matrix.environment }}',
89
367
  } : undefined;
90
- return {
91
- if: condition,
92
- name: 'Assume AWS Role',
93
- uses: 'aws-actions/configure-aws-credentials@v4',
94
- with: {
95
- ...secretsParams,
96
- 'role-to-assume': '${{ matrix.roleToAssume }}',
97
- 'aws-region': '${{ matrix.region }}',
98
- 'role-duration-seconds': '${{ matrix.assumeRoleDurationSeconds }}',
99
- },
100
- };
101
- }
102
- function setAwsCredentialsSteps(checkActiveDeployment, authProvider = javascript_1.CodeArtifactAuthProvider.ACCESS_AND_SECRET_KEY_PAIR) {
103
- return [
104
- setAwsCredentialsInEnvironment(checkActiveDeployment),
105
- assumeAwsRoleStep(checkActiveDeployment, authProvider),
106
- ];
107
- }
108
- function setNpmConfig(configName, configValue, checkActiveDeployment) {
109
- const environmentVariableName = 'CONFIG_VALUE';
110
- return {
111
- ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),
112
- name: 'Setting NPM Config',
113
- env: {
114
- [environmentVariableName]: configValue,
115
- },
116
- run: `npm config set ${configName} $${environmentVariableName}`,
117
- };
118
- }
119
- const checkActiveDeploymentStepId = 'deployment-check';
120
- function checkActiveDeploymentStep() {
121
- return {
122
- id: checkActiveDeploymentStepId,
123
- uses: 'AminFazlMondo/check-deployed-environment@v1',
124
- with: {
125
- environment: '${{ matrix.environment }}',
126
- },
127
- env: {
128
- GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}',
129
- },
130
- };
131
- }
132
- const skipIfAlreadyActiveDeploymentCondition = `steps.${checkActiveDeploymentStepId}.outputs.has_active_deployment != 'true'`;
133
- function getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment) {
134
- return checkActiveDeployment ? { if: `\${{ ${skipIfAlreadyActiveDeploymentCondition} }}` } : undefined;
135
- }
136
- function postDeploymentStep(checkActiveDeployment, packageManager) {
137
- const condition = checkActiveDeployment ?
138
- `\${{ matrix.hasPostDeployTask == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :
139
- '${{ matrix.hasPostDeployTask == \'true\' }}';
140
- return {
141
- if: condition,
142
- name: 'Post Deployment',
143
- run: `${getPackageManagerCommandPrefix(packageManager)} \${{ matrix.postDeploymentScript }}`,
144
- };
145
- }
146
- function preDeploymentStep(checkActiveDeployment, packageManager) {
147
- const condition = checkActiveDeployment ?
148
- `\${{ matrix.hasPreDeployTask == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :
149
- '${{ matrix.hasPreDeployTask == \'true\' }}';
150
- return {
151
- if: condition,
152
- name: 'Pre Deployment',
153
- run: `${getPackageManagerCommandPrefix(packageManager)} \${{ matrix.preDeploymentScript }}`,
154
- };
368
+ const jobDefinition = {
369
+ runsOn: ['ubuntu-latest'],
370
+ concurrency: {
371
+ 'group': '${{ matrix.environment }}-deploy',
372
+ 'cancel-in-progress': false,
373
+ },
374
+ needs: [
375
+ 'release_github',
376
+ ],
377
+ permissions: {
378
+ contents: workflows_model_1.JobPermission.READ,
379
+ deployments: workflows_model_1.JobPermission.READ,
380
+ idToken: this.props.authProvider === javascript_1.CodeArtifactAuthProvider.GITHUB_OIDC ? workflows_model_1.JobPermission.WRITE : undefined,
381
+ },
382
+ strategy: {
383
+ maxParallel: 1,
384
+ matrix: {
385
+ domain: {
386
+ environment: include.map(e => e.environment),
387
+ },
388
+ include,
389
+ },
390
+ },
391
+ environment: {
392
+ name: '${{ matrix.environment }}',
393
+ },
394
+ env: deployJobEnv,
395
+ steps: [],
396
+ };
397
+ jobDefinition.steps.push(this.checkoutStep);
398
+ const preInstallDependenciesStep = this.preInstallDependenciesStep;
399
+ if (preInstallDependenciesStep) {
400
+ jobDefinition.steps.push(preInstallDependenciesStep);
401
+ }
402
+ jobDefinition.steps.push(...(this.project).renderWorkflowSetup());
403
+ const checkActiveDeploymentStepForMatrix = this.checkActiveDeploymentStepForMatrix;
404
+ if (checkActiveDeploymentStepForMatrix) {
405
+ jobDefinition.steps.push(checkActiveDeploymentStepForMatrix);
406
+ }
407
+ jobDefinition.steps.push(...this.setupAwsCredentialsStepsForMatrix);
408
+ const setupNpmConfigStep = this.setupNpmConfigForMatrix;
409
+ if (setupNpmConfigStep) {
410
+ jobDefinition.steps.push(setupNpmConfigStep);
411
+ }
412
+ jobDefinition.steps.push(this.preDeploymentStepForMatrix);
413
+ jobDefinition.steps.push(this.deploymentStep);
414
+ jobDefinition.steps.push(this.postDeploymentStepForMatrix);
415
+ return { deploy: jobDefinition };
416
+ }
417
+ /**
418
+ * Get the IDs of the jobs that must be completed before the specified environment's deployment job
419
+ * @param environmentName The name of the environment
420
+ * @returns An array of job IDs
421
+ */
422
+ getDeploymentJobPrerequisiteJobIds(environmentName) {
423
+ const result = ['release_github'];
424
+ if (!this.props.environmentDependencies) {
425
+ const index = this.props.deployOptions.environments.findIndex(env => env.name === environmentName);
426
+ const prerequisiteEnvironment = index > 0 ? this.props.deployOptions.environments[index - 1] : undefined;
427
+ if (prerequisiteEnvironment) {
428
+ result.push(getDeployJobId(prerequisiteEnvironment.name));
429
+ }
430
+ }
431
+ else {
432
+ const dependencies = this.props.environmentDependencies[environmentName];
433
+ if (dependencies) {
434
+ dependencies.forEach(dep => {
435
+ result.push(getDeployJobId(dep));
436
+ });
437
+ }
438
+ }
439
+ return result;
440
+ }
441
+ /**
442
+ * Get deployment jobs for multi-job strategy
443
+ * @returns Record of jobs
444
+ */
445
+ getDeploymentJobsForMultiJob() {
446
+ const { environmentVariableName, environments } = this.props.deployOptions;
447
+ const jobs = environments.map((environmentOptions) => {
448
+ return [getDeployJobId(environmentOptions.name), this.getJobForEnvironment(environmentOptions, environmentVariableName)];
449
+ });
450
+ return Object.fromEntries(jobs);
451
+ }
452
+ /**
453
+ * Get the job definition for a specific environment
454
+ * @param environmentOptions The environment options
455
+ * @param environmentVariableName The name of the environment variable to set with the environment name, if any
456
+ * @returns The job definition for the environment
457
+ */
458
+ getJobForEnvironment(environmentOptions, environmentVariableName) {
459
+ const { name } = environmentOptions;
460
+ const deployJobEnv = environmentVariableName ? {
461
+ [environmentVariableName]: name,
462
+ } : undefined;
463
+ const jobDefinition = {
464
+ runsOn: ['ubuntu-latest'],
465
+ concurrency: {
466
+ 'group': `${name}-deploy`,
467
+ 'cancel-in-progress': false,
468
+ },
469
+ needs: this.getDeploymentJobPrerequisiteJobIds(name),
470
+ permissions: {
471
+ contents: workflows_model_1.JobPermission.READ,
472
+ deployments: workflows_model_1.JobPermission.READ,
473
+ idToken: this.props.authProvider === javascript_1.CodeArtifactAuthProvider.GITHUB_OIDC ? workflows_model_1.JobPermission.WRITE : undefined,
474
+ },
475
+ environment: {
476
+ name: name,
477
+ },
478
+ env: deployJobEnv,
479
+ steps: [],
480
+ };
481
+ jobDefinition.steps.push(this.checkoutStep);
482
+ const preInstallDependenciesStep = this.preInstallDependenciesStep;
483
+ if (preInstallDependenciesStep) {
484
+ jobDefinition.steps.push(preInstallDependenciesStep);
485
+ }
486
+ jobDefinition.steps.push(...(this.project).renderWorkflowSetup());
487
+ const checkActiveDeploymentStep = this.getCheckActiveDeploymentStepForEnvironment(name);
488
+ if (checkActiveDeploymentStep) {
489
+ jobDefinition.steps.push(checkActiveDeploymentStep);
490
+ }
491
+ jobDefinition.steps.push(...this.getSetupAwsCredentialsStepsForEnvironment(environmentOptions));
492
+ const setupNpmConfigStep = this.getSetupNpmConfigForEnvironment(name);
493
+ if (setupNpmConfigStep) {
494
+ jobDefinition.steps.push(setupNpmConfigStep);
495
+ }
496
+ const preDeploymentStep = this.getPreDeploymentStepForEnvironment(environmentOptions.preDeployWorkflowScript ? true : false, environmentOptions.preDeployWorkflowScript || '');
497
+ if (preDeploymentStep) {
498
+ jobDefinition.steps.push(preDeploymentStep);
499
+ }
500
+ jobDefinition.steps.push(this.deploymentStep);
501
+ const postDeploymentStep = this.getPostDeploymentStepForEnvironment(environmentOptions.postDeployWorkflowScript ? true : false, environmentOptions.postDeployWorkflowScript || '');
502
+ if (postDeploymentStep) {
503
+ jobDefinition.steps.push(postDeploymentStep);
504
+ }
505
+ return jobDefinition;
506
+ }
155
507
  }
156
- function preInstallDependenciesStep(taskName, checkActiveDeployment) {
157
- return {
158
- ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),
159
- name: taskName,
160
- run: `npx projen ${taskName}`,
161
- };
508
+ exports.DeployableAwsCdkTypeScriptAppStepsFactory = DeployableAwsCdkTypeScriptAppStepsFactory;
509
+ function getDeployJobId(environmentName) {
510
+ return `Deploy-${environmentName}`;
162
511
  }
163
- //# 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';\nimport { CodeArtifactAuthProvider } from 'projen/lib/javascript';\n\nexport function checkoutStep(): JobStep {\n  return {\n    name: 'Checkout',\n    uses: 'actions/checkout@v4',\n    with: {\n      'ref': '${{ github.sha }}',\n      'fetch-depth': 0,\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@v4',\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) {return 'npm run';}\n\n  if (packageManager === javascript.NodePackageManager.YARN) {return 'yarn';}\n\n  if (packageManager === javascript.NodePackageManager.PNPM) {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: `${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, authProvider: CodeArtifactAuthProvider): JobStep {\n  const condition =\n    checkActiveDeployment ?\n      `\\${{ matrix.assumeRole == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n      '${{ matrix.assumeRole == \\'true\\' }}';\n\n  const secretsParams =\n    authProvider === CodeArtifactAuthProvider.ACCESS_AND_SECRET_KEY_PAIR ?\n      {\n        'aws-access-key-id': '${{ secrets[matrix.accessKeyIdSecretName] }}',\n        'aws-secret-access-key': '${{ secrets[matrix.secretAccessKeySecretName] }}',\n      } : undefined;\n  return {\n    if: condition,\n    name: 'Assume AWS Role',\n    uses: 'aws-actions/configure-aws-credentials@v4',\n    with: {\n      ...secretsParams,\n      'role-to-assume': '${{ matrix.roleToAssume }}',\n      'aws-region': '${{ matrix.region }}',\n      'role-duration-seconds': '${{ matrix.assumeRoleDurationSeconds }}',\n    },\n  };\n}\n\nexport function setAwsCredentialsSteps(\n  checkActiveDeployment: boolean,\n  authProvider: CodeArtifactAuthProvider = CodeArtifactAuthProvider.ACCESS_AND_SECRET_KEY_PAIR)\n  : JobStep[] {\n  return [\n    setAwsCredentialsInEnvironment(checkActiveDeployment),\n    assumeAwsRoleStep(checkActiveDeployment, authProvider),\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}\n\nexport function postDeploymentStep(checkActiveDeployment: boolean, packageManager: javascript.NodePackageManager): JobStep {\n  const condition =\n  checkActiveDeployment ?\n    `\\${{ matrix.hasPostDeployTask == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n    '${{ matrix.hasPostDeployTask == \\'true\\' }}';\n  return {\n    if: condition,\n    name: 'Post Deployment',\n    run: `${getPackageManagerCommandPrefix(packageManager)} \\${{ matrix.postDeploymentScript }}`,\n  };\n}\n\nexport function preDeploymentStep(checkActiveDeployment: boolean, packageManager: javascript.NodePackageManager): JobStep {\n  const condition =\n  checkActiveDeployment ?\n    `\\${{ matrix.hasPreDeployTask == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n    '${{ matrix.hasPreDeployTask == \\'true\\' }}';\n  return {\n    if: condition,\n    name: 'Pre Deployment',\n    run: `${getPackageManagerCommandPrefix(packageManager)} \\${{ matrix.preDeploymentScript }}`,\n  };\n}\n\nexport function preInstallDependenciesStep(taskName: string, checkActiveDeployment: boolean): JobStep {\n  return {\n    ...getSkipIfAlreadyActiveDeploymentCondition(checkActiveDeployment),\n    name: taskName,\n    run: `npx projen ${taskName}`,\n  };\n}"]}
512
+ //# 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 { WorkflowSteps } from 'projen/lib/github';\nimport { JobPermission, JobStep, Job } from 'projen/lib/github/workflows-model';\nimport { CodeArtifactAuthProvider } from 'projen/lib/javascript';\nimport { DeployJobStrategy, DeployOptions, EnvironmentDeploymentDependencies, EnvironmentOptions } from './types';\n\nconst checkActiveDeploymentStepId = 'deployment-check';\nconst skipIfAlreadyActiveDeploymentCondition= `steps.${checkActiveDeploymentStepId}.outputs.has_active_deployment != 'true'`;\n\nexport interface DeployableAwsCdkTypeScriptAppStepsFactoryProps {\n  /**\n   * Deployment options\n   */\n  readonly deployOptions: DeployOptions;\n\n  /**\n   * Whether to check for active deployments before proceeding with deployment\n   */\n  readonly checkActiveDeployment: boolean;\n\n  /**\n   * The name of the task to run before installing dependencies, if any\n   */\n  readonly preInstallTaskName?: string;\n\n  /**\n   * The authentication provider for CodeArtifact, if any\n   */\n  readonly authProvider?: CodeArtifactAuthProvider;\n\n  /**\n   * The npm config to set with the environment that is being deployed, if any\n   * Note: This is not supported for node versions above 18\n   */\n  readonly npmConfigEnvironment?: string;\n\n  /**\n   * Deployment job strategy, whether to use a matrix job or multiple jobs for each environment\n   */\n  readonly jobStrategy: DeployJobStrategy;\n\n  /**\n   * Environment deployment dependencies, if any\n   */\n  readonly environmentDependencies?: EnvironmentDeploymentDependencies;\n}\n\n/**\n * Factory to create reusable steps for the deployment workflow\n * @experimental\n */\nexport class DeployableAwsCdkTypeScriptAppStepsFactory {\n\n  /**\n   * Validate that the provided environment deployment dependencies are valid\n   * @param deployOptions The deployment options\n   * @param environmentDependencies The environment deployment dependencies to validate\n   */\n  public static validateEnvironmentDeploymentDependencies(\n    deployOptions: DeployOptions,\n    environmentDependencies: EnvironmentDeploymentDependencies,\n  ): void {\n\n    if (deployOptions.jobStrategy !== DeployJobStrategy.MULTI_JOB) {\n      throw new Error('Environment deployment dependencies are only supported for MULTI_JOB strategy');\n    }\n\n    Object.entries(environmentDependencies).forEach(([env, deps]) => {\n      const hasEnvironment = deployOptions.environments.some(e => e.name === env);\n      if (!hasEnvironment) {\n        throw new Error(`Environment \"${env}\" defined in dependencies does not exist in deployOptions.environments`);\n      }\n      deps.forEach(dep => {\n        const hasDepEnvironment = deployOptions.environments.some(e => e.name === dep);\n        if (!hasDepEnvironment) {\n          throw new Error(`Dependency environment \"${dep}\" for environment \"${env}\" does not exist in deployOptions.environments`);\n        }\n      });\n    });\n  }\n\n  /**\n   * Create a new DeployableAwsCdkTypeScriptAppStepsFactory\n   * @param project The project\n   * @param props The factory properties\n   */\n  constructor(\n    private readonly project: javascript.NodeProject,\n    private readonly props: DeployableAwsCdkTypeScriptAppStepsFactoryProps,\n  ) {}\n\n  /**\n   * Condition to skip a step if an active deployment is already present\n   * @returns JobStep condition or undefined if checkActiveDeployment is false\n   */\n  public get skipIfAlreadyActiveDeploymentCondition(): JobStep | undefined {\n    return this.props.checkActiveDeployment ? { if: `\\${{ ${skipIfAlreadyActiveDeploymentCondition} }}` } : undefined;\n  }\n\n  public get checkoutStep(): JobStep {\n    return WorkflowSteps.checkout({\n      with: {\n        fetchDepth: 0,\n        ref: '${{ github.sha }}',\n      },\n    });\n  }\n\n  /**\n   * Step to run before installing dependencies if exists\n   * @returns JobStep or undefined if no preInstallTaskName is provided\n   */\n  public get preInstallDependenciesStep(): JobStep | undefined {\n    if (!this.props.preInstallTaskName) {\n      return undefined;\n    }\n\n    return {\n      ...this.skipIfAlreadyActiveDeploymentCondition,\n      name: this.props.preInstallTaskName,\n      run: `npx projen ${this.props.preInstallTaskName}`,\n    };\n  }\n\n  /**\n   * Step to check if there is an active deployment for the environment in the matrix strategy\n   * @returns JobStep\n   */\n  public get checkActiveDeploymentStepForMatrix(): JobStep | undefined {\n    return this.getCheckActiveDeploymentStepForEnvironment('${{ matrix.environment }}');\n  }\n\n  /**\n   * Step to check if there is an active deployment for a specific environment\n   * @param environment The environment to check\n   * @returns JobStep\n   */\n  public getCheckActiveDeploymentStepForEnvironment(environment: string): JobStep | undefined {\n    if (!this.props.checkActiveDeployment) {\n      return undefined;\n    }\n\n    return {\n      id: checkActiveDeploymentStepId,\n      uses: 'AminFazlMondo/check-deployed-environment@v1',\n      with: {\n        environment: environment,\n      },\n      env: {\n        GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}',\n      },\n    };\n  }\n\n  /**\n   * Step to setup AWS credentials in the environment for the matrix strategy\n   * @returns JobStep[]\n   */\n  public get setupAwsCredentialsStepsForMatrix(): JobStep[] {\n    return [\n      this.setupAwsCredentialsInEnvironmentForMatrix,\n      this.assumeAwsRoleStepForMatrix,\n    ];\n  }\n\n  /**\n   * Get the steps to setup AWS credentials for a specific environment\n   * @param environmentOptions The environment options\n   * @returns JobStep[]\n   */\n  public getSetupAwsCredentialsStepsForEnvironment(environmentOptions: EnvironmentOptions): JobStep[] {\n    const steps: JobStep[] = [];\n\n    const fromEnvVariableStep = this.getSetupAwsCredentialsInEnvironmentForEnvironment(\n      environmentOptions.awsCredentials.roleToAssume ? true : false,\n      environmentOptions.awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID',\n      environmentOptions.awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY',\n      environmentOptions.awsCredentials.region,\n    );\n\n    if (fromEnvVariableStep) {\n      steps.push(fromEnvVariableStep);\n    }\n\n    const assumeRoleStep = this.getAssumeAwsRoleStepForEnvironment(\n      environmentOptions.awsCredentials.roleToAssume ? true : false,\n      environmentOptions.awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID',\n      environmentOptions.awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY',\n      environmentOptions.awsCredentials.region,\n      environmentOptions.awsCredentials.roleToAssume ?? '',\n      environmentOptions.awsCredentials.assumeRoleDurationSeconds ?? 900,\n    );\n\n    if (assumeRoleStep) {\n      steps.push(assumeRoleStep);\n    }\n\n    return steps;\n  }\n\n  /**\n   * Step to setup AWS credentials in the environment for the matrix strategy\n   * @returns JobStep\n   */\n  public get setupAwsCredentialsInEnvironmentForMatrix(): JobStep {\n    return this.getSetupAwsCredentialsInEnvironmentForEnvironment(\n      'matrix.assumeRole',\n      'matrix.accessKeyIdSecretName',\n      'matrix.secretAccessKeySecretName',\n      '${{ matrix.region }}',\n    )!;\n  }\n\n  /**\n   * Step to setup AWS credentials in the environment for a specific environment\n   * @param assumeRoleFlag Whether to assume a role, can be a boolean or a string for matrix strategy\n   * @param accessKeyIdSecretName The GitHub secret name for the access key ID\n   * @param secretAccessKeySecretName The GitHub secret name for the secret access key\n   * @param region The region\n   * @returns JobStep or undefined if no AWS credentials are provided,\n   * if assumeRoleFlag is boolean will be evaluated and return a JobStep only if false\n   * if assumeRoleFlag is string will always return a JobStep (for matrix strategy)\n   */\n  public getSetupAwsCredentialsInEnvironmentForEnvironment(\n    assumeRoleFlag: boolean | string,\n    accessKeyIdSecretName: string,\n    secretAccessKeySecretName: string,\n    region: string,\n  ): JobStep | undefined {\n\n    function getCondition(factory: DeployableAwsCdkTypeScriptAppStepsFactory) {\n      if (typeof assumeRoleFlag === 'boolean') {\n        if (assumeRoleFlag) {\n          return undefined;\n        }\n        return factory.props.checkActiveDeployment ? skipIfAlreadyActiveDeploymentCondition : undefined;\n      }\n      return factory.props.checkActiveDeployment ?\n        `\\${{ ${assumeRoleFlag} == 'false' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n        `\\${{ ${assumeRoleFlag} == 'false' }}`;\n    }\n\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    if (typeof assumeRoleFlag === 'boolean' && assumeRoleFlag) {\n      return undefined;\n    }\n\n    const condition = getCondition(this);\n\n    return {\n      if: condition,\n      name: 'Configure AWS Credentials',\n      run: `${commands.join('\\n')}`,\n      env: {\n        accessKeyId: `\\${{ secrets[${accessKeyIdSecretName}] }}`,\n        secretAccessKey: `\\${{ secrets[${secretAccessKeySecretName}] }}`,\n        region,\n      },\n    };\n  }\n\n  /**\n   * Step to assume an AWS role for the matrix strategy\n   * @returns JobStep\n   */\n  public get assumeAwsRoleStepForMatrix(): JobStep {\n    return this.getAssumeAwsRoleStepForEnvironment(\n      'matrix.assumeRole',\n      'matrix.accessKeyIdSecretName',\n      'matrix.secretAccessKeySecretName',\n      '${{ matrix.region }}',\n      '${{ matrix.roleToAssume }}',\n      '${{ matrix.assumeRoleDurationSeconds }}',\n    )!;\n  }\n\n  /**\n   * Step to assume an AWS role for a specific environment\n   * @param assumeRoleFlag Whether to assume a role, can be a boolean or a string for matrix strategy\n   * @param accessKeyIdSecretName The GitHub secret name for the access key ID\n   * @param secretAccessKeySecretName The GitHub secret name for the secret access key\n   * @param region The region\n   * @param roleToAssume The role to assume\n   * @param assumeRoleDurationSeconds The duration for assuming the role\n   * @returns JobStep or undefined if assumeRoleFlag is boolean and false\n   * if assumeRoleFlag is string will always return a JobStep (for matrix strategy)\n   */\n  public getAssumeAwsRoleStepForEnvironment(\n    assumeRoleFlag: boolean | string,\n    accessKeyIdSecretName: string,\n    secretAccessKeySecretName: string,\n    region: string,\n    roleToAssume: string,\n    assumeRoleDurationSeconds?: string | number,\n  ): JobStep | undefined {\n    function getCondition(factory: DeployableAwsCdkTypeScriptAppStepsFactory) {\n      if (typeof assumeRoleFlag === 'boolean') {\n        if (!assumeRoleFlag) {\n          return undefined;\n        }\n        return factory.props.checkActiveDeployment ? skipIfAlreadyActiveDeploymentCondition : undefined;\n      }\n      return factory.props.checkActiveDeployment ?\n        `\\${{ ${assumeRoleFlag} == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n        `\\${{ ${assumeRoleFlag} == 'true' }}`;\n    }\n\n    if (typeof assumeRoleFlag === 'boolean' && !assumeRoleFlag) {\n      return undefined;\n    }\n\n    const condition = getCondition(this);\n\n    const secretsParams =\n      this.props.authProvider === CodeArtifactAuthProvider.ACCESS_AND_SECRET_KEY_PAIR ?\n        {\n          'aws-access-key-id': `\\${{ secrets[${accessKeyIdSecretName}] }}`,\n          'aws-secret-access-key': `\\${{ secrets[${secretAccessKeySecretName}] }}`,\n        } : undefined;\n    return {\n      if: condition,\n      name: 'Assume AWS Role',\n      uses: 'aws-actions/configure-aws-credentials@v4',\n      with: {\n        ...secretsParams,\n        'role-to-assume': roleToAssume,\n        'aws-region': region,\n        'role-duration-seconds': assumeRoleDurationSeconds,\n      },\n    };\n  }\n\n  /**\n   * Step to setup NPM config if provided\n   * @returns JobStep or undefined if no npmConfig is provided\n   */\n  public get setupNpmConfigForMatrix(): JobStep | undefined {\n    return this.getSetupNpmConfigForEnvironment('${{ matrix.environment }}');\n  }\n\n  public getSetupNpmConfigForEnvironment(environment: string): JobStep | undefined {\n    const { npmConfigEnvironment } = this.props;\n    if (!npmConfigEnvironment) {\n      return undefined;\n    }\n\n    const environmentVariableName = 'CONFIG_VALUE';\n    return {\n      ...this.skipIfAlreadyActiveDeploymentCondition,\n      name: 'Setting NPM Config',\n      env: {\n        [environmentVariableName]: environment,\n      },\n      run: `npm config set ${npmConfigEnvironment} $${environmentVariableName}`,\n    };\n  }\n\n  /**\n   * Get the step to run a specific script\n   * @param scriptName The name of the script to run\n   * @param stepName The name of the step in the workflow\n   * @param hasScriptFlag Whether the script should be run\n   * @returns The job step to run the script or undefined if not applicable\n   * If hasScriptFlag is boolean and false will return undefined\n   * If hasScriptFlag is string will always return a JobStep (for matrix strategy)\n   */\n  public getRunScriptStep(\n    scriptName: string,\n    stepName: string,\n    hasScriptFlag: boolean | string,\n  ): JobStep | undefined {\n    function getCondition(factory: DeployableAwsCdkTypeScriptAppStepsFactory) {\n      if (typeof hasScriptFlag === 'boolean') {\n        if (!hasScriptFlag) {\n          return undefined;\n        }\n        return factory.props.checkActiveDeployment ? skipIfAlreadyActiveDeploymentCondition : undefined;\n      }\n      return factory.props.checkActiveDeployment ?\n        `\\${{ ${hasScriptFlag} == 'true' && ${skipIfAlreadyActiveDeploymentCondition} }}` :\n        `\\${{ ${hasScriptFlag} == 'true' }}`;\n    }\n    if (typeof hasScriptFlag === 'boolean' && !hasScriptFlag) {\n      return undefined;\n    }\n\n    const condition = getCondition(this);\n\n    return {\n      if: condition,\n      name: `Run ${stepName}`,\n      run: `${this.project.runScriptCommand} ${scriptName}`,\n    };\n  }\n\n  /**\n   * Step to deploy the workflow\n   * @returns JobStep\n   */\n  public get deploymentStep(): JobStep {\n    return this.getRunScriptStep(\n      'deploy:workflow',\n      'Deployment',\n      true,\n    )!;\n  }\n\n  /**\n   * Step to run post deployment script in matrix strategy\n   * @returns JobStep\n   */\n  public get preDeploymentStepForMatrix(): JobStep {\n    return this.getPreDeploymentStepForEnvironment(\n      'matrix.hasPreDeployTask',\n      '${{ matrix.preDeploymentScript }}',\n    )!;\n  }\n\n  /**\n   * Get the pre-deployment step for a specific environment\n   * @param hasPreDeployTaskFlag Whether the pre-deployment task should be run\n   * @param preDeploymentScript The script to run\n   * @returns The job step to run the pre-deployment script or undefined if not applicable\n   * If hasPreDeployTaskFlag is boolean and false will return undefined\n   * If hasPreDeployTaskFlag is string will always return a JobStep (for matrix strategy)\n   */\n  public getPreDeploymentStepForEnvironment(\n    hasPreDeployTaskFlag: boolean | string,\n    preDeploymentScript: string,\n  ): JobStep | undefined {\n\n    return this.getRunScriptStep(\n      preDeploymentScript,\n      'Pre Deployment',\n      hasPreDeployTaskFlag,\n    );\n  }\n\n  /**\n   * Step to run post deployment script in matrix strategy\n   * @returns JobStep\n   */\n  public get postDeploymentStepForMatrix(): JobStep {\n    return this.getPostDeploymentStepForEnvironment(\n      'matrix.hasPostDeployTask',\n      '${{ matrix.postDeploymentScript }}',\n    )!;\n  }\n\n  /**\n   * Get the post-deployment step for a specific environment\n   * @param hasPostDeployTaskFlag Whether the post-deployment task should be run\n   * @param postDeploymentScript The script to run\n   * @returns The job step to run the post-deployment script or undefined if not applicable\n   * If hasPostDeployTaskFlag is boolean and false will return undefined\n   * If hasPostDeployTaskFlag is string will always return a JobStep (for matrix strategy)\n   */\n  public getPostDeploymentStepForEnvironment(\n    hasPostDeployTaskFlag: boolean | string,\n    postDeploymentScript: string,\n  ): JobStep | undefined {\n\n    return this.getRunScriptStep(\n      postDeploymentScript,\n      'Post Deployment',\n      hasPostDeployTaskFlag,\n    );\n  }\n\n  /**\n   * Get all deployment jobs whether for matrix strategy or not\n   * @returns Record of jobs\n   */\n  public get deploymentJobs(): Record<string, Job> {\n\n    if (this.props.deployOptions.environments.length === 0) {\n      this.project.logger.warn('The project does not have any environment set, make sure this is desired setting');\n    }\n    return this.props.jobStrategy === DeployJobStrategy.MATRIX ? this.deploymentJobsForMatrix : this.getDeploymentJobsForMultiJob();\n  }\n\n  /**\n   * Get deployment jobs for matrix strategy\n   * @returns Record of jobs\n   */\n  public get deploymentJobsForMatrix(): Record<string, Job> {\n\n    const { environments, environmentVariableName } = this.props.deployOptions;\n\n    const include = 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 || 900,\n      }: undefined;\n\n      const accessKeyIdSecretName = awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID';\n      const secretAccessKeySecretName = awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY';\n\n      const hasPostDeployTask = environmentOptions.postDeployWorkflowScript ? 'true' : 'false';\n      const hasPreDeployTask = environmentOptions.preDeployWorkflowScript ? 'true' : 'false';\n\n      return {\n        environment: environmentOptions.name,\n        accessKeyIdSecretName,\n        secretAccessKeySecretName,\n        region: awsCredentials.region,\n        assumeRole,\n        hasPostDeployTask,\n        postDeploymentScript: environmentOptions.postDeployWorkflowScript || '',\n        hasPreDeployTask,\n        preDeploymentScript: environmentOptions.preDeployWorkflowScript || '',\n        ...assumeRoleSettings,\n      };\n    });\n\n    const deployJobEnv = environmentVariableName ? {\n      [environmentVariableName]: '${{ matrix.environment }}',\n    } : undefined;\n\n    const jobDefinition: Job = {\n      runsOn: ['ubuntu-latest'],\n      concurrency: {\n        'group': '${{ matrix.environment }}-deploy',\n        'cancel-in-progress': false,\n      },\n      needs: [\n        'release_github',\n      ],\n      permissions: {\n        contents: JobPermission.READ,\n        deployments: JobPermission.READ,\n        idToken: this.props.authProvider === CodeArtifactAuthProvider.GITHUB_OIDC ? JobPermission.WRITE : undefined,\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      env: deployJobEnv,\n      steps: [],\n    };\n\n    jobDefinition.steps.push(this.checkoutStep);\n\n    const preInstallDependenciesStep = this.preInstallDependenciesStep;\n    if (preInstallDependenciesStep) {\n      jobDefinition.steps.push(preInstallDependenciesStep);\n    }\n\n    jobDefinition.steps.push(...(this.project).renderWorkflowSetup());\n\n    const checkActiveDeploymentStepForMatrix = this.checkActiveDeploymentStepForMatrix;\n    if (checkActiveDeploymentStepForMatrix) {\n      jobDefinition.steps.push(checkActiveDeploymentStepForMatrix);\n    }\n\n    jobDefinition.steps.push(...this.setupAwsCredentialsStepsForMatrix);\n\n    const setupNpmConfigStep = this.setupNpmConfigForMatrix;\n    if (setupNpmConfigStep) {\n      jobDefinition.steps.push(setupNpmConfigStep);\n    }\n\n    jobDefinition.steps.push(this.preDeploymentStepForMatrix);\n    jobDefinition.steps.push(this.deploymentStep);\n    jobDefinition.steps.push(this.postDeploymentStepForMatrix);\n\n    return { deploy: jobDefinition };\n  }\n\n  /**\n   * Get the IDs of the jobs that must be completed before the specified environment's deployment job\n   * @param environmentName The name of the environment\n   * @returns An array of job IDs\n   */\n  public getDeploymentJobPrerequisiteJobIds(environmentName: string): string[] {\n    const result = ['release_github'];\n    if (!this.props.environmentDependencies) {\n      const index = this.props.deployOptions.environments.findIndex(env => env.name === environmentName);\n      const prerequisiteEnvironment = index > 0 ? this.props.deployOptions.environments[index - 1] : undefined;\n      if (prerequisiteEnvironment) {\n        result.push(getDeployJobId(prerequisiteEnvironment.name));\n      }\n    } else {\n      const dependencies = this.props.environmentDependencies[environmentName];\n      if (dependencies) {\n        dependencies.forEach(dep => {\n          result.push(getDeployJobId(dep));\n        });\n      }\n    }\n    return result;\n  }\n\n  /**\n   * Get deployment jobs for multi-job strategy\n   * @returns Record of jobs\n   */\n  public getDeploymentJobsForMultiJob(): Record<string, Job> {\n    const { environmentVariableName, environments } = this.props.deployOptions;\n    const jobs = environments.map((environmentOptions): [string, Job] => {\n      return [getDeployJobId(environmentOptions.name), this.getJobForEnvironment(environmentOptions, environmentVariableName)];\n    });\n    return Object.fromEntries(jobs);\n  }\n\n  /**\n   * Get the job definition for a specific environment\n   * @param environmentOptions The environment options\n   * @param environmentVariableName The name of the environment variable to set with the environment name, if any\n   * @returns The job definition for the environment\n   */\n  public getJobForEnvironment(\n    environmentOptions: EnvironmentOptions,\n    environmentVariableName: string | undefined,\n  ): Job {\n    const { name } = environmentOptions;\n    const deployJobEnv = environmentVariableName ? {\n      [environmentVariableName]: name,\n    } : undefined;\n\n    const jobDefinition: Job = {\n      runsOn: ['ubuntu-latest'],\n      concurrency: {\n        'group': `${name}-deploy`,\n        'cancel-in-progress': false,\n      },\n      needs: this.getDeploymentJobPrerequisiteJobIds(name),\n      permissions: {\n        contents: JobPermission.READ,\n        deployments: JobPermission.READ,\n        idToken: this.props.authProvider === CodeArtifactAuthProvider.GITHUB_OIDC ? JobPermission.WRITE : undefined,\n      },\n      environment: {\n        name: name,\n      },\n      env: deployJobEnv,\n      steps: [],\n    };\n\n    jobDefinition.steps.push(this.checkoutStep);\n\n    const preInstallDependenciesStep = this.preInstallDependenciesStep;\n    if (preInstallDependenciesStep) {\n      jobDefinition.steps.push(preInstallDependenciesStep);\n    }\n\n    jobDefinition.steps.push(...(this.project).renderWorkflowSetup());\n\n    const checkActiveDeploymentStep = this.getCheckActiveDeploymentStepForEnvironment(name);\n    if (checkActiveDeploymentStep) {\n      jobDefinition.steps.push(checkActiveDeploymentStep);\n    }\n\n    jobDefinition.steps.push(...this.getSetupAwsCredentialsStepsForEnvironment(environmentOptions));\n\n    const setupNpmConfigStep = this.getSetupNpmConfigForEnvironment(name);\n    if (setupNpmConfigStep) {\n      jobDefinition.steps.push(setupNpmConfigStep);\n    }\n\n    const preDeploymentStep = this.getPreDeploymentStepForEnvironment(\n      environmentOptions.preDeployWorkflowScript ? true : false,\n      environmentOptions.preDeployWorkflowScript || '',\n    );\n    if (preDeploymentStep) {\n      jobDefinition.steps.push(preDeploymentStep);\n    }\n\n    jobDefinition.steps.push(this.deploymentStep);\n\n    const postDeploymentStep = this.getPostDeploymentStepForEnvironment(\n      environmentOptions.postDeployWorkflowScript ? true : false,\n      environmentOptions.postDeployWorkflowScript || '',\n    );\n    if (postDeploymentStep) {\n      jobDefinition.steps.push(postDeploymentStep);\n    }\n\n    return jobDefinition;\n  }\n\n}\n\nfunction getDeployJobId(environmentName: string): string {\n  return `Deploy-${environmentName}`;\n}\n"]}