projen-pipelines 0.0.61 → 0.0.63

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.
@@ -6,6 +6,9 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const workflows_model_1 = require("projen/lib/github/workflows-model");
7
7
  const base_1 = require("./base");
8
8
  const engine_1 = require("../engine");
9
+ const steps_1 = require("../steps");
10
+ const artifact_steps_1 = require("../steps/artifact-steps");
11
+ const aws_assume_role_step_1 = require("../steps/aws-assume-role.step");
9
12
  const DEFAULT_RUNNER_TAGS = ['ubuntu-latest'];
10
13
  /**
11
14
  * Implements a CDK Pipeline configured specifically for GitHub workflows.
@@ -52,6 +55,9 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
52
55
  for (const stage of options.stages) {
53
56
  this.createDeployment(stage);
54
57
  }
58
+ for (const stage of (options.independentStages ?? [])) {
59
+ this.createIndependentDeployment(stage);
60
+ }
55
61
  }
56
62
  /** the type of engine this implementation of CDKPipeline is for */
57
63
  engineType() {
@@ -61,47 +67,31 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
61
67
  * Creates a synthesis job for the pipeline using GitHub Actions.
62
68
  */
63
69
  createSynth() {
64
- const steps = [{
65
- name: 'Checkout',
66
- uses: 'actions/checkout@v4',
67
- }];
70
+ const steps = [];
68
71
  if (this.options.iamRoleArns?.synth) {
69
- steps.push({
70
- name: 'AWS Credentials',
71
- uses: 'aws-actions/configure-aws-credentials@master',
72
- with: {
73
- 'role-to-assume': this.options.iamRoleArns.synth,
74
- 'role-session-name': 'GitHubAction',
75
- 'aws-region': 'us-east-1',
76
- },
77
- });
72
+ steps.push(new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
73
+ roleArn: this.options.iamRoleArns.synth,
74
+ sessionName: 'GitHubAction',
75
+ }));
78
76
  }
79
- const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGithub());
80
- const preSynthSteps = (this.options.preSynthSteps ?? []).map(s => s.toGithub());
81
- const postSynthSteps = (this.options.postSynthSteps ?? []).map(s => s.toGithub());
82
- steps.push(...preInstallSteps.flatMap(s => s.steps));
83
- steps.push(...this.renderInstallCommands().map(cmd => ({
84
- run: cmd,
85
- })));
86
- steps.push(...preSynthSteps.flatMap(s => s.steps));
87
- steps.push(...this.renderSynthCommands().map(cmd => ({
88
- run: cmd,
89
- })));
90
- steps.push(...postSynthSteps.flatMap(s => s.steps));
91
- steps.push({
92
- uses: 'actions/upload-artifact@v4',
93
- with: {
94
- name: 'cloud-assembly',
95
- path: `${this.app.cdkConfig.cdkout}/`,
96
- },
97
- });
77
+ steps.push(...this.options.preInstallSteps ?? []);
78
+ steps.push(new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()));
79
+ steps.push(...this.options.preSynthSteps ?? []);
80
+ steps.push(new steps_1.SimpleCommandStep(this.project, this.renderSynthCommands()));
81
+ steps.push(...this.options.postSynthSteps ?? []);
82
+ steps.push(new artifact_steps_1.UploadArtifactStep(this.project, {
83
+ name: 'cloud-assembly',
84
+ path: `${this.app.cdkConfig.cdkout}/`,
85
+ }));
86
+ const githubSteps = steps.map(s => s.toGithub());
98
87
  this.deploymentWorkflow.addJob('synth', {
99
88
  name: 'Synth CDK application',
100
89
  runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
101
90
  env: {
102
91
  CI: 'true',
92
+ ...githubSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
103
93
  },
104
- needs: [...preInstallSteps.flatMap(s => s.needs), ...preSynthSteps.flatMap(s => s.needs), ...postSynthSteps.flatMap(s => s.needs)],
94
+ needs: [...githubSteps.flatMap(s => s.needs)],
105
95
  permissions: {
106
96
  idToken: workflows_model_1.JobPermission.WRITE,
107
97
  contents: workflows_model_1.JobPermission.READ,
@@ -109,20 +99,40 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
109
99
  packages: workflows_model_1.JobPermission.READ,
110
100
  },
111
101
  },
112
- steps,
102
+ steps: [
103
+ {
104
+ name: 'Checkout',
105
+ uses: 'actions/checkout@v4',
106
+ },
107
+ ...githubSteps.flatMap(s => s.steps),
108
+ ],
113
109
  });
114
110
  }
115
111
  /**
116
112
  * Creates a job to upload assets to AWS as part of the pipeline.
117
113
  */
118
114
  createAssetUpload() {
119
- const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGithub());
115
+ const steps = [
116
+ new steps_1.SimpleCommandStep(this.project, ['git config --global user.name "github-actions" && git config --global user.email "github-actions@github.com"']),
117
+ new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
118
+ roleArn: this.options.iamRoleArns?.assetPublishing ?? this.options.iamRoleArns?.default,
119
+ region: 'us-east-1',
120
+ }),
121
+ new artifact_steps_1.DownloadArtifactStep(this.project, {
122
+ name: 'cloud-assembly',
123
+ path: `${this.app.cdkConfig.cdkout}/`,
124
+ }),
125
+ ...this.options.preInstallSteps ?? [],
126
+ new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
127
+ new steps_1.SimpleCommandStep(this.project, this.getAssetUploadCommands(this.needsVersionedArtifacts)),
128
+ ].map(s => s.toGithub());
120
129
  this.deploymentWorkflow.addJob('assetUpload', {
121
130
  name: 'Publish assets to AWS',
122
- needs: ['synth', ...preInstallSteps.flatMap(s => s.needs)],
131
+ needs: ['synth', ...steps.flatMap(s => s.needs)],
123
132
  runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
124
133
  env: {
125
134
  CI: 'true',
135
+ ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
126
136
  },
127
137
  permissions: {
128
138
  idToken: workflows_model_1.JobPermission.WRITE,
@@ -131,37 +141,16 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
131
141
  packages: workflows_model_1.JobPermission.WRITE,
132
142
  },
133
143
  },
134
- steps: [{
144
+ steps: [
145
+ {
135
146
  name: 'Checkout',
136
147
  uses: 'actions/checkout@v4',
137
148
  with: {
138
149
  'fetch-depth': 0,
139
150
  },
140
- }, {
141
- name: 'Setup GIT identity',
142
- run: 'git config --global user.name "github-actions" && git config --global user.email "github-actions@github.com"',
143
- }, {
144
- name: 'AWS Credentials',
145
- uses: 'aws-actions/configure-aws-credentials@master',
146
- with: {
147
- 'role-to-assume': this.options.iamRoleArns?.assetPublishing ?? this.options.iamRoleArns?.default,
148
- 'role-session-name': 'GitHubAction',
149
- 'aws-region': 'us-east-1',
150
- },
151
- }, {
152
- uses: 'actions/download-artifact@v4',
153
- with: {
154
- name: 'cloud-assembly',
155
- path: `${this.app.cdkConfig.cdkout}/`,
156
- },
157
151
  },
158
- ...preInstallSteps.flatMap(s => s.steps),
159
- ...this.renderInstallCommands().map(cmd => ({
160
- run: cmd,
161
- })),
162
- ...this.getAssetUploadCommands(this.needsVersionedArtifacts).map(cmd => ({
163
- run: cmd,
164
- }))],
152
+ ...steps.flatMap(s => s.steps),
153
+ ],
165
154
  });
166
155
  }
167
156
  /**
@@ -169,8 +158,22 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
169
158
  * @param stage - The deployment stage to create.
170
159
  */
171
160
  createDeployment(stage) {
172
- const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGithub());
173
161
  if (stage.manualApproval === true) {
162
+ const steps = [
163
+ new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
164
+ roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
165
+ region: stage.env.region,
166
+ }),
167
+ ...this.options.preInstallSteps ?? [],
168
+ new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
169
+ new steps_1.SimpleCommandStep(this.project, this.renderInstallPackageCommands(`${this.options.pkgNamespace}/${this.app.name}@\${{github.event.inputs.version}}`)),
170
+ new steps_1.SimpleCommandStep(this.project, [`mv ./node_modules/${this.options.pkgNamespace}/${this.app.name} ${this.app.cdkConfig.cdkout}`]),
171
+ new steps_1.SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),
172
+ new artifact_steps_1.UploadArtifactStep(this.project, {
173
+ name: `cdk-outputs-${stage.name}`,
174
+ path: `cdk-outputs-${stage.name}.json`,
175
+ }),
176
+ ].map(s => s.toGithub());
174
177
  // Create new workflow for deployment
175
178
  const stageWorkflow = this.app.github.addWorkflow(`release-${stage.name}`);
176
179
  stageWorkflow.on({
@@ -185,10 +188,11 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
185
188
  });
186
189
  stageWorkflow.addJob('deploy', {
187
190
  name: `Release stage ${stage.name} to AWS`,
188
- needs: preInstallSteps.flatMap(s => s.needs),
191
+ needs: steps.flatMap(s => s.needs),
189
192
  runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
190
193
  env: {
191
194
  CI: 'true',
195
+ ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
192
196
  },
193
197
  permissions: {
194
198
  idToken: workflows_model_1.JobPermission.WRITE,
@@ -197,48 +201,41 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
197
201
  packages: workflows_model_1.JobPermission.READ,
198
202
  },
199
203
  },
200
- steps: [{
204
+ steps: [
205
+ {
201
206
  name: 'Checkout',
202
207
  uses: 'actions/checkout@v4',
203
- }, {
204
- name: 'AWS Credentials',
205
- uses: 'aws-actions/configure-aws-credentials@master',
206
- with: {
207
- 'role-to-assume': this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
208
- 'role-session-name': 'GitHubAction',
209
- 'aws-region': stage.env.region,
210
- },
211
208
  },
212
- ...preInstallSteps.flatMap(s => s.steps),
213
- ...this.renderInstallCommands().map(cmd => ({
214
- run: cmd,
215
- })),
216
- ...this.renderInstallPackageCommands(`${this.options.pkgNamespace}/${this.app.name}@\${{github.event.inputs.version}}`).map(cmd => ({
217
- run: cmd,
218
- })),
219
- {
220
- run: `mv ./node_modules/${this.options.pkgNamespace}/${this.app.name} ${this.app.cdkConfig.cdkout}`,
221
- },
222
- ...this.renderDeployCommands(stage.name).map(cmd => ({
223
- run: cmd,
224
- })),
225
- {
226
- uses: 'actions/upload-artifact@v3',
227
- with: {
228
- name: `cdk-outputs-${stage.name}`,
229
- path: `cdk-outputs-${stage.name}.json`,
230
- },
231
- }],
209
+ ...steps.flatMap(s => s.steps),
210
+ ],
232
211
  });
233
212
  }
234
213
  else {
214
+ const steps = [
215
+ new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
216
+ roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
217
+ region: stage.env.region,
218
+ }),
219
+ new artifact_steps_1.DownloadArtifactStep(this.project, {
220
+ name: 'cloud-assembly',
221
+ path: `${this.app.cdkConfig.cdkout}/`,
222
+ }),
223
+ ...this.options.preInstallSteps ?? [],
224
+ new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
225
+ new steps_1.SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),
226
+ new artifact_steps_1.UploadArtifactStep(this.project, {
227
+ name: `cdk-outputs-${stage.name}`,
228
+ path: `cdk-outputs-${stage.name}.json`,
229
+ }),
230
+ ].map(s => s.toGithub());
235
231
  // Add deployment to CI/CD workflow
236
232
  this.deploymentWorkflow.addJob(`deploy-${stage.name}`, {
237
233
  name: `Deploy stage ${stage.name} to AWS`,
238
- needs: ['assetUpload', ...preInstallSteps.flatMap(s => s.needs), ...(this.deploymentStages.length > 0 ? [`deploy-${this.deploymentStages.at(-1)}`] : [])],
234
+ needs: ['assetUpload', ...steps.flatMap(s => s.needs), ...(this.deploymentStages.length > 0 ? [`deploy-${this.deploymentStages.at(-1)}`] : [])],
239
235
  runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
240
236
  env: {
241
237
  CI: 'true',
238
+ ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
242
239
  },
243
240
  permissions: {
244
241
  idToken: workflows_model_1.JobPermission.WRITE,
@@ -247,44 +244,69 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
247
244
  packages: workflows_model_1.JobPermission.READ,
248
245
  },
249
246
  },
250
- steps: [{
247
+ steps: [
248
+ {
251
249
  name: 'Checkout',
252
250
  uses: 'actions/checkout@v4',
253
- }, {
254
- name: 'AWS Credentials',
255
- uses: 'aws-actions/configure-aws-credentials@master',
256
- with: {
257
- 'role-to-assume': this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
258
- 'role-session-name': 'GitHubAction',
259
- 'aws-region': stage.env.region,
260
- },
261
- }, {
262
- uses: 'actions/download-artifact@v4',
263
- with: {
264
- name: 'cloud-assembly',
265
- path: `${this.app.cdkConfig.cdkout}/`,
266
- },
267
251
  },
268
- ...preInstallSteps.flatMap(s => s.steps),
269
- ...this.renderInstallCommands().map(cmd => ({
270
- run: cmd,
271
- })),
272
- ...this.renderDeployCommands(stage.name).map(cmd => ({
273
- run: cmd,
274
- })),
275
- {
276
- uses: 'actions/upload-artifact@v3',
277
- with: {
278
- name: `cdk-outputs-${stage.name}`,
279
- path: `cdk-outputs-${stage.name}.json`,
280
- },
281
- }],
252
+ ...steps.flatMap(s => s.steps),
253
+ ],
282
254
  });
283
255
  this.deploymentStages.push(stage.name);
284
256
  }
285
257
  }
258
+ /**
259
+ * Creates a job to deploy the CDK application to AWS.
260
+ * @param stage - The independent stage to create.
261
+ */
262
+ createIndependentDeployment(stage) {
263
+ const steps = [
264
+ new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
265
+ roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
266
+ region: stage.env.region,
267
+ }),
268
+ ...this.options.preInstallSteps ?? [],
269
+ new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
270
+ ...this.options.preSynthSteps ?? [],
271
+ new steps_1.SimpleCommandStep(this.project, this.renderSynthCommands()),
272
+ ...this.options.postSynthSteps ?? [],
273
+ new steps_1.SimpleCommandStep(this.project, this.renderDiffCommands(stage.name)),
274
+ ...stage.postDiffSteps ?? [],
275
+ new steps_1.SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),
276
+ ...stage.postDeploySteps ?? [],
277
+ new artifact_steps_1.UploadArtifactStep(this.project, {
278
+ name: `cdk-outputs-${stage.name}`,
279
+ path: `cdk-outputs-${stage.name}.json`,
280
+ }),
281
+ ].map(s => s.toGithub());
282
+ // Create new workflow for deployment
283
+ const stageWorkflow = this.app.github.addWorkflow(`deploy-${stage.name}`);
284
+ stageWorkflow.on({
285
+ workflowDispatch: {},
286
+ });
287
+ stageWorkflow.addJob('deploy', {
288
+ name: `Release stage ${stage.name} to AWS`,
289
+ needs: steps.flatMap(s => s.needs),
290
+ runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
291
+ env: {
292
+ CI: 'true',
293
+ ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
294
+ },
295
+ permissions: {
296
+ idToken: workflows_model_1.JobPermission.WRITE,
297
+ contents: workflows_model_1.JobPermission.READ,
298
+ },
299
+ steps: [
300
+ {
301
+ name: 'Checkout',
302
+ uses: 'actions/checkout@v4',
303
+ },
304
+ ...steps.flatMap(s => s.steps),
305
+ ],
306
+ });
307
+ }
286
308
  }
287
309
  exports.GithubCDKPipeline = GithubCDKPipeline;
288
310
  _a = JSII_RTTI_SYMBOL_1;
289
- GithubCDKPipeline[_a] = { fqn: "projen-pipelines.GithubCDKPipeline", version: "0.0.61" };
290
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../src/awscdk/github.ts"],"names":[],"mappings":"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","sourcesContent":["import { awscdk } from 'projen';\nimport { GithubWorkflow } from 'projen/lib/github';\nimport { JobPermission, JobStep } from 'projen/lib/github/workflows-model';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage } from './base';\nimport { PipelineEngine } from '../engine';\n\nconst DEFAULT_RUNNER_TAGS = ['ubuntu-latest'];\n\n/**\n * Configuration interface for GitHub-specific IAM roles used in the CDK pipeline.\n */\nexport interface GithubIamRoleConfig {\n\n  /** Default IAM role ARN used if no specific role is provided. */\n  readonly default?: string;\n  /** IAM role ARN for the synthesis step. */\n  readonly synth?: string;\n  /** IAM role ARN for the asset publishing step. */\n  readonly assetPublishing?: string;\n  /** IAM role ARNs for different deployment stages. */\n  readonly deployment?: { [stage: string]: string };\n}\n\n/**\n * Extension of the base CDKPipeline options including specific configurations for GitHub.\n */\nexport interface GithubCDKPipelineOptions extends CDKPipelineOptions {\n\n  /** IAM config for GitHub Actions */\n  readonly iamRoleArns: GithubIamRoleConfig;\n\n  /**\n   * runner tags to use to select runners\n   *\n   * @default ['ubuntu-latest']\n   */\n  readonly runnerTags?: string[];\n\n  /** use GitHub Packages to store vesioned artifacts of cloud assembly; also needed for manual approvals */\n  readonly useGithubPackagesForAssembly?: boolean;\n}\n\n\n/**\n * Implements a CDK Pipeline configured specifically for GitHub workflows.\n */\nexport class GithubCDKPipeline extends CDKPipeline {\n\n  /** Indicates if versioned artifacts are needed based on manual approval requirements. */\n  public readonly needsVersionedArtifacts: boolean;\n\n  /** The GitHub workflow associated with the pipeline. */\n  private deploymentWorkflow: GithubWorkflow;\n  /** List of deployment stages for the pipeline. */\n  private deploymentStages: string[] = [];\n\n  protected useGithubPackages: boolean;\n\n  /**\n   * Constructs a new GithubCDKPipeline instance.\n   * @param app - The CDK app associated with this pipeline.\n   * @param options - Configuration options for the pipeline.\n   */\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: GithubCDKPipelineOptions) {\n    super(app, {\n      ...options,\n      ...options.useGithubPackagesForAssembly && {\n        preInstallCommands: [\n          'echo \"GITHUB_TOKEN=${{ secrets.GITHUB_TOKEN }}\" >> $GITHUB_ENV',\n          ...(options.preInstallCommands ?? []),\n        ],\n      },\n    });\n\n    // Initialize the deployment workflow on GitHub.\n    this.deploymentWorkflow = this.app.github!.addWorkflow('deploy');\n    this.deploymentWorkflow.on({\n      push: {\n        branches: [this.branchName],\n      },\n      workflowDispatch: {},\n    });\n\n    // Determine if versioned artifacts are necessary.\n    this.needsVersionedArtifacts = options.stages.find(s => s.manualApproval === true) !== undefined;;\n    this.useGithubPackages = this.needsVersionedArtifacts && (options.useGithubPackagesForAssembly ?? false);\n\n    if (this.useGithubPackages) {\n      app.npmrc.addRegistry('https://npm.pkg.github.com', this.options.pkgNamespace);\n      app.npmrc.addConfig('//npm.pkg.github.com/:_authToken', '${GITHUB_TOKEN}');\n      app.npmrc.addConfig('//npm.pkg.github.com/:always-auth', 'true');\n    }\n\n    // Create jobs for synthesizing, asset uploading, and deployment.\n    this.createSynth();\n\n    this.createAssetUpload();\n\n    for (const stage of options.stages) {\n      this.createDeployment(stage);\n    }\n  }\n\n  /** the type of engine this implementation of CDKPipeline is for */\n  public engineType(): PipelineEngine {\n    return PipelineEngine.GITHUB;\n  }\n\n  /**\n   * Creates a synthesis job for the pipeline using GitHub Actions.\n   */\n  private createSynth(): void {\n    const steps: JobStep[] = [{\n      name: 'Checkout',\n      uses: 'actions/checkout@v4',\n    }];\n\n    if (this.options.iamRoleArns?.synth) {\n      steps.push({\n        name: 'AWS Credentials',\n        uses: 'aws-actions/configure-aws-credentials@master',\n        with: {\n          'role-to-assume': this.options.iamRoleArns.synth,\n          'role-session-name': 'GitHubAction',\n          'aws-region': 'us-east-1',\n        },\n      });\n    }\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGithub());\n    const preSynthSteps = (this.options.preSynthSteps ?? []).map(s => s.toGithub());\n    const postSynthSteps = (this.options.postSynthSteps ?? []).map(s => s.toGithub());\n\n    steps.push(...preInstallSteps.flatMap(s => s.steps));\n    steps.push(...this.renderInstallCommands().map(cmd => ({\n      run: cmd,\n    })));\n\n    steps.push(...preSynthSteps.flatMap(s => s.steps));\n    steps.push(...this.renderSynthCommands().map(cmd => ({\n      run: cmd,\n    })));\n    steps.push(...postSynthSteps.flatMap(s => s.steps));\n\n    steps.push({\n      uses: 'actions/upload-artifact@v4',\n      with: {\n        name: 'cloud-assembly',\n        path: `${this.app.cdkConfig.cdkout}/`,\n      },\n    });\n\n    this.deploymentWorkflow.addJob('synth', {\n      name: 'Synth CDK application',\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n      },\n      needs: [...preInstallSteps.flatMap(s => s.needs), ...preSynthSteps.flatMap(s => s.needs), ...postSynthSteps.flatMap(s => s.needs)],\n      permissions: {\n        idToken: JobPermission.WRITE,\n        contents: JobPermission.READ,\n        ...this.useGithubPackages && {\n          packages: JobPermission.READ,\n        },\n      },\n      steps,\n    });\n  }\n\n  /**\n   * Creates a job to upload assets to AWS as part of the pipeline.\n   */\n  public createAssetUpload(): void {\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGithub());\n\n    this.deploymentWorkflow.addJob('assetUpload', {\n      name: 'Publish assets to AWS',\n      needs: ['synth', ...preInstallSteps.flatMap(s => s.needs)],\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n      },\n      permissions: {\n        idToken: JobPermission.WRITE,\n        contents: this.needsVersionedArtifacts ? JobPermission.WRITE : JobPermission.READ,\n        ...this.useGithubPackages && {\n          packages: JobPermission.WRITE,\n        },\n      },\n      steps: [{\n        name: 'Checkout',\n        uses: 'actions/checkout@v4',\n        with: {\n          'fetch-depth': 0,\n        },\n      }, {\n        name: 'Setup GIT identity',\n        run: 'git config --global user.name \"github-actions\" && git config --global user.email \"github-actions@github.com\"',\n      }, {\n        name: 'AWS Credentials',\n        uses: 'aws-actions/configure-aws-credentials@master',\n        with: {\n          'role-to-assume': this.options.iamRoleArns?.assetPublishing ?? this.options.iamRoleArns?.default,\n          'role-session-name': 'GitHubAction',\n          'aws-region': 'us-east-1',\n        },\n      }, {\n        uses: 'actions/download-artifact@v4',\n        with: {\n          name: 'cloud-assembly',\n          path: `${this.app.cdkConfig.cdkout}/`,\n        },\n      },\n      ...preInstallSteps.flatMap(s => s.steps),\n      ...this.renderInstallCommands().map(cmd => ({\n        run: cmd,\n      })),\n      ...this.getAssetUploadCommands(this.needsVersionedArtifacts).map(cmd => ({\n        run: cmd,\n      }))],\n    });\n  }\n\n  /**\n   * Creates a job to deploy the CDK application to AWS.\n   * @param stage - The deployment stage to create.\n   */\n  public createDeployment(stage: DeploymentStage): void {\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGithub());\n\n    if (stage.manualApproval === true) {\n      // Create new workflow for deployment\n      const stageWorkflow = this.app.github!.addWorkflow(`release-${stage.name}`);\n      stageWorkflow.on({\n        workflowDispatch: {\n          inputs: {\n            version: {\n              description: 'Package version',\n              required: true,\n            },\n          },\n        },\n      });\n      stageWorkflow.addJob('deploy', {\n        name: `Release stage ${stage.name} to AWS`,\n        needs: preInstallSteps.flatMap(s => s.needs),\n        runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n        env: {\n          CI: 'true',\n        },\n        permissions: {\n          idToken: JobPermission.WRITE,\n          contents: JobPermission.READ,\n          ...this.useGithubPackages && {\n            packages: JobPermission.READ,\n          },\n        },\n        steps: [{\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\n        }, {\n          name: 'AWS Credentials',\n          uses: 'aws-actions/configure-aws-credentials@master',\n          with: {\n            'role-to-assume': this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,\n            'role-session-name': 'GitHubAction',\n            'aws-region': stage.env.region,\n          },\n        },\n        ...preInstallSteps.flatMap(s => s.steps),\n        ...this.renderInstallCommands().map(cmd => ({\n          run: cmd,\n        })),\n        ...this.renderInstallPackageCommands(`${this.options.pkgNamespace}/${this.app.name}@\\${{github.event.inputs.version}}`).map(cmd => ({\n          run: cmd,\n        })),\n        {\n          run: `mv ./node_modules/${this.options.pkgNamespace}/${this.app.name} ${this.app.cdkConfig.cdkout}`,\n        },\n        ...this.renderDeployCommands(stage.name).map(cmd => ({\n          run: cmd,\n        })),\n        {\n          uses: 'actions/upload-artifact@v3',\n          with: {\n            name: `cdk-outputs-${stage.name}`,\n            path: `cdk-outputs-${stage.name}.json`,\n          },\n        }],\n      });\n\n    } else {\n      // Add deployment to CI/CD workflow\n      this.deploymentWorkflow.addJob(`deploy-${stage.name}`, {\n        name: `Deploy stage ${stage.name} to AWS`,\n        needs: ['assetUpload', ...preInstallSteps.flatMap(s => s.needs), ...(this.deploymentStages.length > 0 ? [`deploy-${this.deploymentStages.at(-1)!}`] : [])],\n        runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n        env: {\n          CI: 'true',\n        },\n        permissions: {\n          idToken: JobPermission.WRITE,\n          contents: JobPermission.READ,\n          ...this.useGithubPackages && {\n            packages: JobPermission.READ,\n          },\n        },\n        steps: [{\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\n        }, {\n          name: 'AWS Credentials',\n          uses: 'aws-actions/configure-aws-credentials@master',\n          with: {\n            'role-to-assume': this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,\n            'role-session-name': 'GitHubAction',\n            'aws-region': stage.env.region,\n          },\n        }, {\n          uses: 'actions/download-artifact@v4',\n          with: {\n            name: 'cloud-assembly',\n            path: `${this.app.cdkConfig.cdkout}/`,\n          },\n        },\n        ...preInstallSteps.flatMap(s => s.steps),\n        ...this.renderInstallCommands().map(cmd => ({\n          run: cmd,\n        })),\n        ...this.renderDeployCommands(stage.name).map(cmd => ({\n          run: cmd,\n        })),\n        {\n          uses: 'actions/upload-artifact@v3',\n          with: {\n            name: `cdk-outputs-${stage.name}`,\n            path: `cdk-outputs-${stage.name}.json`,\n          },\n        }],\n      });\n      this.deploymentStages.push(stage.name);\n    }\n  }\n}\n"]}
311
+ GithubCDKPipeline[_a] = { fqn: "projen-pipelines.GithubCDKPipeline", version: "0.0.63" };
312
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../src/awscdk/github.ts"],"names":[],"mappings":";;;;;AAEA,uEAAkE;AAClE,iCAA4F;AAC5F,sCAA2C;AAC3C,oCAA2D;AAC3D,4DAAmF;AACnF,wEAAkE;AAElE,MAAM,mBAAmB,GAAG,CAAC,eAAe,CAAC,CAAC;AAqC9C;;GAEG;AACH,MAAa,iBAAkB,SAAQ,kBAAW;IAYhD;;;;OAIG;IACH,YAAY,GAA+B,EAAU,OAAiC;QACpF,KAAK,CAAC,GAAG,EAAE;YACT,GAAG,OAAO;YACV,GAAG,OAAO,CAAC,4BAA4B,IAAI;gBACzC,kBAAkB,EAAE;oBAClB,gEAAgE;oBAChE,GAAG,CAAC,OAAO,CAAC,kBAAkB,IAAI,EAAE,CAAC;iBACtC;aACF;SACF,CAAC,CAAC;QATgD,YAAO,GAAP,OAAO,CAA0B;QAVtF,kDAAkD;QAC1C,qBAAgB,GAAa,EAAE,CAAC;QAoBtC,gDAAgD;QAChD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,GAAG,CAAC,MAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QACjE,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC;YACzB,IAAI,EAAE;gBACJ,QAAQ,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;aAC5B;YACD,gBAAgB,EAAE,EAAE;SACrB,CAAC,CAAC;QAEH,kDAAkD;QAClD,IAAI,CAAC,uBAAuB,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,KAAK,IAAI,CAAC,KAAK,SAAS,CAAC;QAAA,CAAC;QAClG,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,uBAAuB,IAAI,CAAC,OAAO,CAAC,4BAA4B,IAAI,KAAK,CAAC,CAAC;QAEzG,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,4BAA4B,EAAE,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YAC/E,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,kCAAkC,EAAE,iBAAiB,CAAC,CAAC;YAC3E,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,mCAAmC,EAAE,MAAM,CAAC,CAAC;QACnE,CAAC;QAED,iEAAiE;QACjE,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,KAAK,MAAM,KAAK,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC/B,CAAC;QACD,KAAK,MAAM,KAAK,IAAI,CAAC,OAAO,CAAC,iBAAiB,IAAI,EAAE,CAAC,EAAE,CAAC;YACtD,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,mEAAmE;IAC5D,UAAU;QACf,OAAO,uBAAc,CAAC,MAAM,CAAC;IAC/B,CAAC;IAED;;OAEG;IACK,WAAW;QACjB,MAAM,KAAK,GAAmB,EAAE,CAAC;QAEjC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC;YACpC,KAAK,CAAC,IAAI,CAAC,IAAI,wCAAiB,CAAC,IAAI,CAAC,OAAO,EAAE;gBAC7C,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK;gBACvC,WAAW,EAAE,cAAc;aAC5B,CAAC,CAAC,CAAC;QACN,CAAC;QACD,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC;QAClD,KAAK,CAAC,IAAI,CAAC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC;QAE9E,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;QAChD,KAAK,CAAC,IAAI,CAAC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC,CAAC;QAC5E,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC;QAEjD,KAAK,CAAC,IAAI,CAAC,IAAI,mCAAkB,CAAC,IAAI,CAAC,OAAO,EAAE;YAC9C,IAAI,EAAE,gBAAgB;YACtB,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,GAAG;SACtC,CAAC,CAAC,CAAC;QAEJ,MAAM,WAAW,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEjD,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,OAAO,EAAE;YACtC,IAAI,EAAE,uBAAuB;YAC7B,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,mBAAmB;YACtD,GAAG,EAAE;gBACH,EAAE,EAAE,MAAM;gBACV,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;aACpE;YACD,KAAK,EAAE,CAAC,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YAC7C,WAAW,EAAE;gBACX,OAAO,EAAE,+BAAa,CAAC,KAAK;gBAC5B,QAAQ,EAAE,+BAAa,CAAC,IAAI;gBAC5B,GAAG,IAAI,CAAC,iBAAiB,IAAI;oBAC3B,QAAQ,EAAE,+BAAa,CAAC,IAAI;iBAC7B;aACF;YACD,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,qBAAqB;iBAC5B;gBACD,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;aACrC;SACF,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,iBAAiB;QACtB,MAAM,KAAK,GAAG;YACZ,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,8GAA8G,CAAC,CAAC;YACrJ,IAAI,wCAAiB,CAAC,IAAI,CAAC,OAAO,EAAE;gBAClC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,eAAe,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAQ;gBACxF,MAAM,EAAE,WAAW;aACpB,CAAC;YACF,IAAI,qCAAoB,CAAC,IAAI,CAAC,OAAO,EAAE;gBACrC,IAAI,EAAE,gBAAgB;gBACtB,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,GAAG;aACtC,CAAC;YACF,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE;YACrC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACjE,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;SAC/F,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEzB,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,aAAa,EAAE;YAC5C,IAAI,EAAE,uBAAuB;YAC7B,KAAK,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YAChD,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,mBAAmB;YACtD,GAAG,EAAE;gBACH,EAAE,EAAE,MAAM;gBACV,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;aAC9D;YACD,WAAW,EAAE;gBACX,OAAO,EAAE,+BAAa,CAAC,KAAK;gBAC5B,QAAQ,EAAE,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,+BAAa,CAAC,KAAK,CAAC,CAAC,CAAC,+BAAa,CAAC,IAAI;gBACjF,GAAG,IAAI,CAAC,iBAAiB,IAAI;oBAC3B,QAAQ,EAAE,+BAAa,CAAC,KAAK;iBAC9B;aACF;YACD,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,qBAAqB;oBAC3B,IAAI,EAAE;wBACJ,aAAa,EAAE,CAAC;qBACjB;iBACF;gBACD,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;aAC/B;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACI,gBAAgB,CAAC,KAAsB;QAE5C,IAAI,KAAK,CAAC,cAAc,KAAK,IAAI,EAAE,CAAC;YAClC,MAAM,KAAK,GAAG;gBACZ,IAAI,wCAAiB,CAAC,IAAI,CAAC,OAAO,EAAE;oBAClC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAQ;oBACjG,MAAM,EAAE,KAAK,CAAC,GAAG,CAAC,MAAM;iBACzB,CAAC;gBACF,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE;gBACrC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBACjE,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,4BAA4B,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,oCAAoC,CAAC,CAAC;gBACzJ,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,qBAAqB,IAAI,CAAC,OAAO,CAAC,YAAY,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;gBACrI,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBAC1E,IAAI,mCAAkB,CAAC,IAAI,CAAC,OAAO,EAAE;oBACnC,IAAI,EAAE,eAAe,KAAK,CAAC,IAAI,EAAE;oBACjC,IAAI,EAAE,eAAe,KAAK,CAAC,IAAI,OAAO;iBACvC,CAAC;aACH,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;YAEzB,qCAAqC;YACrC,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,MAAO,CAAC,WAAW,CAAC,WAAW,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;YAC5E,aAAa,CAAC,EAAE,CAAC;gBACf,gBAAgB,EAAE;oBAChB,MAAM,EAAE;wBACN,OAAO,EAAE;4BACP,WAAW,EAAE,iBAAiB;4BAC9B,QAAQ,EAAE,IAAI;yBACf;qBACF;iBACF;aACF,CAAC,CAAC;YACH,aAAa,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC7B,IAAI,EAAE,iBAAiB,KAAK,CAAC,IAAI,SAAS;gBAC1C,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;gBAClC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,mBAAmB;gBACtD,GAAG,EAAE;oBACH,EAAE,EAAE,MAAM;oBACV,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;iBAC9D;gBACD,WAAW,EAAE;oBACX,OAAO,EAAE,+BAAa,CAAC,KAAK;oBAC5B,QAAQ,EAAE,+BAAa,CAAC,IAAI;oBAC5B,GAAG,IAAI,CAAC,iBAAiB,IAAI;wBAC3B,QAAQ,EAAE,+BAAa,CAAC,IAAI;qBAC7B;iBACF;gBACD,KAAK,EAAE;oBACL;wBACE,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,qBAAqB;qBAC5B;oBACD,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;iBAC/B;aACF,CAAC,CAAC;QAEL,CAAC;aAAM,CAAC;YAEN,MAAM,KAAK,GAAG;gBACZ,IAAI,wCAAiB,CAAC,IAAI,CAAC,OAAO,EAAE;oBAClC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAQ;oBACjG,MAAM,EAAE,KAAK,CAAC,GAAG,CAAC,MAAM;iBACzB,CAAC;gBACF,IAAI,qCAAoB,CAAC,IAAI,CAAC,OAAO,EAAE;oBACrC,IAAI,EAAE,gBAAgB;oBACtB,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,GAAG;iBACtC,CAAC;gBACF,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE;gBACrC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBACjE,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBAC1E,IAAI,mCAAkB,CAAC,IAAI,CAAC,OAAO,EAAE;oBACnC,IAAI,EAAE,eAAe,KAAK,CAAC,IAAI,EAAE;oBACjC,IAAI,EAAE,eAAe,KAAK,CAAC,IAAI,OAAO;iBACvC,CAAC;aACH,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;YAEzB,mCAAmC;YACnC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,UAAU,KAAK,CAAC,IAAI,EAAE,EAAE;gBACrD,IAAI,EAAE,gBAAgB,KAAK,CAAC,IAAI,SAAS;gBACzC,KAAK,EAAE,CAAC,aAAa,EAAE,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC,CAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBAChJ,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,mBAAmB;gBACtD,GAAG,EAAE;oBACH,EAAE,EAAE,MAAM;oBACV,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;iBAC9D;gBACD,WAAW,EAAE;oBACX,OAAO,EAAE,+BAAa,CAAC,KAAK;oBAC5B,QAAQ,EAAE,+BAAa,CAAC,IAAI;oBAC5B,GAAG,IAAI,CAAC,iBAAiB,IAAI;wBAC3B,QAAQ,EAAE,+BAAa,CAAC,IAAI;qBAC7B;iBACF;gBACD,KAAK,EAAE;oBACL;wBACE,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,qBAAqB;qBAC5B;oBACD,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;iBAC/B;aACF,CAAC,CAAC;YACH,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED;;;OAGG;IACI,2BAA2B,CAAC,KAAuB;QACxD,MAAM,KAAK,GAAG;YACZ,IAAI,wCAAiB,CAAC,IAAI,CAAC,OAAO,EAAE;gBAClC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAQ;gBACjG,MAAM,EAAE,KAAK,CAAC,GAAG,CAAC,MAAM;aACzB,CAAC;YACF,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE;YACrC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAEjE,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE;YACnC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC/D,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,IAAI,EAAE;YAEpC,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACxE,GAAG,KAAK,CAAC,aAAa,IAAI,EAAE;YAE5B,IAAI,yBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC1E,GAAG,KAAK,CAAC,eAAe,IAAI,EAAE;YAE9B,IAAI,mCAAkB,CAAC,IAAI,CAAC,OAAO,EAAE;gBACnC,IAAI,EAAE,eAAe,KAAK,CAAC,IAAI,EAAE;gBACjC,IAAI,EAAE,eAAe,KAAK,CAAC,IAAI,OAAO;aACvC,CAAC;SACH,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEzB,qCAAqC;QACrC,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,MAAO,CAAC,WAAW,CAAC,UAAU,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QAC3E,aAAa,CAAC,EAAE,CAAC;YACf,gBAAgB,EAAE,EAAE;SACrB,CAAC,CAAC;QACH,aAAa,CAAC,MAAM,CAAC,QAAQ,EAAE;YAC7B,IAAI,EAAE,iBAAiB,KAAK,CAAC,IAAI,SAAS;YAC1C,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;YAClC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,mBAAmB;YACtD,GAAG,EAAE;gBACH,EAAE,EAAE,MAAM;gBACV,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;aAC9D;YACD,WAAW,EAAE;gBACX,OAAO,EAAE,+BAAa,CAAC,KAAK;gBAC5B,QAAQ,EAAE,+BAAa,CAAC,IAAI;aAC7B;YACD,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,qBAAqB;iBAC5B;gBACD,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;aAC/B;SACF,CAAC,CAAC;IAEL,CAAC;;AArUH,8CAsUC","sourcesContent":["import { awscdk } from 'projen';\nimport { GithubWorkflow } from 'projen/lib/github';\nimport { JobPermission } from 'projen/lib/github/workflows-model';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage, IndependentStage } from './base';\nimport { PipelineEngine } from '../engine';\nimport { PipelineStep, SimpleCommandStep } from '../steps';\nimport { DownloadArtifactStep, UploadArtifactStep } from '../steps/artifact-steps';\nimport { AwsAssumeRoleStep } from '../steps/aws-assume-role.step';\n\nconst DEFAULT_RUNNER_TAGS = ['ubuntu-latest'];\n\n/**\n * Configuration interface for GitHub-specific IAM roles used in the CDK pipeline.\n */\nexport interface GithubIamRoleConfig {\n\n  /** Default IAM role ARN used if no specific role is provided. */\n  readonly default?: string;\n  /** IAM role ARN for the synthesis step. */\n  readonly synth?: string;\n  /** IAM role ARN for the asset publishing step. */\n  readonly assetPublishing?: string;\n  /** IAM role ARNs for different deployment stages. */\n  readonly deployment?: { [stage: string]: string };\n}\n\n/**\n * Extension of the base CDKPipeline options including specific configurations for GitHub.\n */\nexport interface GithubCDKPipelineOptions extends CDKPipelineOptions {\n\n  /** IAM config for GitHub Actions */\n  readonly iamRoleArns: GithubIamRoleConfig;\n\n  /**\n   * runner tags to use to select runners\n   *\n   * @default ['ubuntu-latest']\n   */\n  readonly runnerTags?: string[];\n\n  /** use GitHub Packages to store vesioned artifacts of cloud assembly; also needed for manual approvals */\n  readonly useGithubPackagesForAssembly?: boolean;\n}\n\n\n/**\n * Implements a CDK Pipeline configured specifically for GitHub workflows.\n */\nexport class GithubCDKPipeline extends CDKPipeline {\n\n  /** Indicates if versioned artifacts are needed based on manual approval requirements. */\n  public readonly needsVersionedArtifacts: boolean;\n\n  /** The GitHub workflow associated with the pipeline. */\n  private deploymentWorkflow: GithubWorkflow;\n  /** List of deployment stages for the pipeline. */\n  private deploymentStages: string[] = [];\n\n  protected useGithubPackages: boolean;\n\n  /**\n   * Constructs a new GithubCDKPipeline instance.\n   * @param app - The CDK app associated with this pipeline.\n   * @param options - Configuration options for the pipeline.\n   */\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: GithubCDKPipelineOptions) {\n    super(app, {\n      ...options,\n      ...options.useGithubPackagesForAssembly && {\n        preInstallCommands: [\n          'echo \"GITHUB_TOKEN=${{ secrets.GITHUB_TOKEN }}\" >> $GITHUB_ENV',\n          ...(options.preInstallCommands ?? []),\n        ],\n      },\n    });\n\n    // Initialize the deployment workflow on GitHub.\n    this.deploymentWorkflow = this.app.github!.addWorkflow('deploy');\n    this.deploymentWorkflow.on({\n      push: {\n        branches: [this.branchName],\n      },\n      workflowDispatch: {},\n    });\n\n    // Determine if versioned artifacts are necessary.\n    this.needsVersionedArtifacts = options.stages.find(s => s.manualApproval === true) !== undefined;;\n    this.useGithubPackages = this.needsVersionedArtifacts && (options.useGithubPackagesForAssembly ?? false);\n\n    if (this.useGithubPackages) {\n      app.npmrc.addRegistry('https://npm.pkg.github.com', this.options.pkgNamespace);\n      app.npmrc.addConfig('//npm.pkg.github.com/:_authToken', '${GITHUB_TOKEN}');\n      app.npmrc.addConfig('//npm.pkg.github.com/:always-auth', 'true');\n    }\n\n    // Create jobs for synthesizing, asset uploading, and deployment.\n    this.createSynth();\n\n    this.createAssetUpload();\n\n    for (const stage of options.stages) {\n      this.createDeployment(stage);\n    }\n    for (const stage of (options.independentStages ?? [])) {\n      this.createIndependentDeployment(stage);\n    }\n  }\n\n  /** the type of engine this implementation of CDKPipeline is for */\n  public engineType(): PipelineEngine {\n    return PipelineEngine.GITHUB;\n  }\n\n  /**\n   * Creates a synthesis job for the pipeline using GitHub Actions.\n   */\n  private createSynth(): void {\n    const steps: PipelineStep[] = [];\n\n    if (this.options.iamRoleArns?.synth) {\n      steps.push(new AwsAssumeRoleStep(this.project, {\n        roleArn: this.options.iamRoleArns.synth,\n        sessionName: 'GitHubAction',\n      }));\n    }\n    steps.push(...this.options.preInstallSteps ?? []);\n    steps.push(new SimpleCommandStep(this.project, this.renderInstallCommands()));\n\n    steps.push(...this.options.preSynthSteps ?? []);\n    steps.push(new SimpleCommandStep(this.project, this.renderSynthCommands()));\n    steps.push(...this.options.postSynthSteps ?? []);\n\n    steps.push(new UploadArtifactStep(this.project, {\n      name: 'cloud-assembly',\n      path: `${this.app.cdkConfig.cdkout}/`,\n    }));\n\n    const githubSteps = steps.map(s => s.toGithub());\n\n    this.deploymentWorkflow.addJob('synth', {\n      name: 'Synth CDK application',\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n        ...githubSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      needs: [...githubSteps.flatMap(s => s.needs)],\n      permissions: {\n        idToken: JobPermission.WRITE,\n        contents: JobPermission.READ,\n        ...this.useGithubPackages && {\n          packages: JobPermission.READ,\n        },\n      },\n      steps: [\n        {\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\n        },\n        ...githubSteps.flatMap(s => s.steps),\n      ],\n    });\n  }\n\n  /**\n   * Creates a job to upload assets to AWS as part of the pipeline.\n   */\n  public createAssetUpload(): void {\n    const steps = [\n      new SimpleCommandStep(this.project, ['git config --global user.name \"github-actions\" && git config --global user.email \"github-actions@github.com\"']),\n      new AwsAssumeRoleStep(this.project, {\n        roleArn: this.options.iamRoleArns?.assetPublishing ?? this.options.iamRoleArns?.default!,\n        region: 'us-east-1',\n      }),\n      new DownloadArtifactStep(this.project, {\n        name: 'cloud-assembly',\n        path: `${this.app.cdkConfig.cdkout}/`,\n      }),\n      ...this.options.preInstallSteps ?? [],\n      new SimpleCommandStep(this.project, this.renderInstallCommands()),\n      new SimpleCommandStep(this.project, this.getAssetUploadCommands(this.needsVersionedArtifacts)),\n    ].map(s => s.toGithub());\n\n    this.deploymentWorkflow.addJob('assetUpload', {\n      name: 'Publish assets to AWS',\n      needs: ['synth', ...steps.flatMap(s => s.needs)],\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n        ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      permissions: {\n        idToken: JobPermission.WRITE,\n        contents: this.needsVersionedArtifacts ? JobPermission.WRITE : JobPermission.READ,\n        ...this.useGithubPackages && {\n          packages: JobPermission.WRITE,\n        },\n      },\n      steps: [\n        {\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\n          with: {\n            'fetch-depth': 0,\n          },\n        },\n        ...steps.flatMap(s => s.steps),\n      ],\n    });\n  }\n\n  /**\n   * Creates a job to deploy the CDK application to AWS.\n   * @param stage - The deployment stage to create.\n   */\n  public createDeployment(stage: DeploymentStage): void {\n\n    if (stage.manualApproval === true) {\n      const steps = [\n        new AwsAssumeRoleStep(this.project, {\n          roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default!,\n          region: stage.env.region,\n        }),\n        ...this.options.preInstallSteps ?? [],\n        new SimpleCommandStep(this.project, this.renderInstallCommands()),\n        new SimpleCommandStep(this.project, this.renderInstallPackageCommands(`${this.options.pkgNamespace}/${this.app.name}@\\${{github.event.inputs.version}}`)),\n        new SimpleCommandStep(this.project, [`mv ./node_modules/${this.options.pkgNamespace}/${this.app.name} ${this.app.cdkConfig.cdkout}`]),\n        new SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),\n        new UploadArtifactStep(this.project, {\n          name: `cdk-outputs-${stage.name}`,\n          path: `cdk-outputs-${stage.name}.json`,\n        }),\n      ].map(s => s.toGithub());\n\n      // Create new workflow for deployment\n      const stageWorkflow = this.app.github!.addWorkflow(`release-${stage.name}`);\n      stageWorkflow.on({\n        workflowDispatch: {\n          inputs: {\n            version: {\n              description: 'Package version',\n              required: true,\n            },\n          },\n        },\n      });\n      stageWorkflow.addJob('deploy', {\n        name: `Release stage ${stage.name} to AWS`,\n        needs: steps.flatMap(s => s.needs),\n        runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n        env: {\n          CI: 'true',\n          ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        },\n        permissions: {\n          idToken: JobPermission.WRITE,\n          contents: JobPermission.READ,\n          ...this.useGithubPackages && {\n            packages: JobPermission.READ,\n          },\n        },\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v4',\n          },\n          ...steps.flatMap(s => s.steps),\n        ],\n      });\n\n    } else {\n\n      const steps = [\n        new AwsAssumeRoleStep(this.project, {\n          roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default!,\n          region: stage.env.region,\n        }),\n        new DownloadArtifactStep(this.project, {\n          name: 'cloud-assembly',\n          path: `${this.app.cdkConfig.cdkout}/`,\n        }),\n        ...this.options.preInstallSteps ?? [],\n        new SimpleCommandStep(this.project, this.renderInstallCommands()),\n        new SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),\n        new UploadArtifactStep(this.project, {\n          name: `cdk-outputs-${stage.name}`,\n          path: `cdk-outputs-${stage.name}.json`,\n        }),\n      ].map(s => s.toGithub());\n\n      // Add deployment to CI/CD workflow\n      this.deploymentWorkflow.addJob(`deploy-${stage.name}`, {\n        name: `Deploy stage ${stage.name} to AWS`,\n        needs: ['assetUpload', ...steps.flatMap(s => s.needs), ...(this.deploymentStages.length > 0 ? [`deploy-${this.deploymentStages.at(-1)!}`] : [])],\n        runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n        env: {\n          CI: 'true',\n          ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        },\n        permissions: {\n          idToken: JobPermission.WRITE,\n          contents: JobPermission.READ,\n          ...this.useGithubPackages && {\n            packages: JobPermission.READ,\n          },\n        },\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v4',\n          },\n          ...steps.flatMap(s => s.steps),\n        ],\n      });\n      this.deploymentStages.push(stage.name);\n    }\n  }\n\n  /**\n   * Creates a job to deploy the CDK application to AWS.\n   * @param stage - The independent stage to create.\n   */\n  public createIndependentDeployment(stage: IndependentStage): void {\n    const steps = [\n      new AwsAssumeRoleStep(this.project, {\n        roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default!,\n        region: stage.env.region,\n      }),\n      ...this.options.preInstallSteps ?? [],\n      new SimpleCommandStep(this.project, this.renderInstallCommands()),\n\n      ...this.options.preSynthSteps ?? [],\n      new SimpleCommandStep(this.project, this.renderSynthCommands()),\n      ...this.options.postSynthSteps ?? [],\n\n      new SimpleCommandStep(this.project, this.renderDiffCommands(stage.name)),\n      ...stage.postDiffSteps ?? [],\n\n      new SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),\n      ...stage.postDeploySteps ?? [],\n\n      new UploadArtifactStep(this.project, {\n        name: `cdk-outputs-${stage.name}`,\n        path: `cdk-outputs-${stage.name}.json`,\n      }),\n    ].map(s => s.toGithub());\n\n    // Create new workflow for deployment\n    const stageWorkflow = this.app.github!.addWorkflow(`deploy-${stage.name}`);\n    stageWorkflow.on({\n      workflowDispatch: {},\n    });\n    stageWorkflow.addJob('deploy', {\n      name: `Release stage ${stage.name} to AWS`,\n      needs: steps.flatMap(s => s.needs),\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n        ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      permissions: {\n        idToken: JobPermission.WRITE,\n        contents: JobPermission.READ,\n      },\n      steps: [\n        {\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\n        },\n        ...steps.flatMap(s => s.steps),\n      ],\n    });\n\n  }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { awscdk, gitlab } from 'projen';
2
- import { CDKPipeline, CDKPipelineOptions, DeploymentStage } from './base';
2
+ import { CDKPipeline, CDKPipelineOptions, DeploymentStage, IndependentStage } from './base';
3
3
  import { PipelineEngine } from '../engine';
4
4
  /**
5
5
  * Configuration for IAM roles used within the GitLab CI/CD pipeline for various stages.
@@ -105,5 +105,10 @@ export declare class GitlabCDKPipeline extends CDKPipeline {
105
105
  * @param {DeploymentStage} stage - The deployment stage configuration to set up.
106
106
  */
107
107
  protected createDeployment(stage: DeploymentStage): void;
108
+ /**
109
+ * Creates a job to deploy the CDK application to AWS.
110
+ * @param stage - The independent stage to create.
111
+ */
112
+ createIndependentDeployment(stage: IndependentStage): void;
108
113
  engineType(): PipelineEngine;
109
114
  }