projen-pipelines 0.0.62 → 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,50 +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',
103
- ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
104
- ...preSynthSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
105
- ...postSynthSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
92
+ ...githubSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
106
93
  },
107
- needs: [...preInstallSteps.flatMap(s => s.needs), ...preSynthSteps.flatMap(s => s.needs), ...postSynthSteps.flatMap(s => s.needs)],
94
+ needs: [...githubSteps.flatMap(s => s.needs)],
108
95
  permissions: {
109
96
  idToken: workflows_model_1.JobPermission.WRITE,
110
97
  contents: workflows_model_1.JobPermission.READ,
@@ -112,21 +99,40 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
112
99
  packages: workflows_model_1.JobPermission.READ,
113
100
  },
114
101
  },
115
- steps,
102
+ steps: [
103
+ {
104
+ name: 'Checkout',
105
+ uses: 'actions/checkout@v4',
106
+ },
107
+ ...githubSteps.flatMap(s => s.steps),
108
+ ],
116
109
  });
117
110
  }
118
111
  /**
119
112
  * Creates a job to upload assets to AWS as part of the pipeline.
120
113
  */
121
114
  createAssetUpload() {
122
- 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());
123
129
  this.deploymentWorkflow.addJob('assetUpload', {
124
130
  name: 'Publish assets to AWS',
125
- needs: ['synth', ...preInstallSteps.flatMap(s => s.needs)],
131
+ needs: ['synth', ...steps.flatMap(s => s.needs)],
126
132
  runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
127
133
  env: {
128
134
  CI: 'true',
129
- ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
135
+ ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
130
136
  },
131
137
  permissions: {
132
138
  idToken: workflows_model_1.JobPermission.WRITE,
@@ -135,37 +141,16 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
135
141
  packages: workflows_model_1.JobPermission.WRITE,
136
142
  },
137
143
  },
138
- steps: [{
144
+ steps: [
145
+ {
139
146
  name: 'Checkout',
140
147
  uses: 'actions/checkout@v4',
141
148
  with: {
142
149
  'fetch-depth': 0,
143
150
  },
144
- }, {
145
- name: 'Setup GIT identity',
146
- run: 'git config --global user.name "github-actions" && git config --global user.email "github-actions@github.com"',
147
- }, {
148
- name: 'AWS Credentials',
149
- uses: 'aws-actions/configure-aws-credentials@master',
150
- with: {
151
- 'role-to-assume': this.options.iamRoleArns?.assetPublishing ?? this.options.iamRoleArns?.default,
152
- 'role-session-name': 'GitHubAction',
153
- 'aws-region': 'us-east-1',
154
- },
155
- }, {
156
- uses: 'actions/download-artifact@v4',
157
- with: {
158
- name: 'cloud-assembly',
159
- path: `${this.app.cdkConfig.cdkout}/`,
160
- },
161
151
  },
162
- ...preInstallSteps.flatMap(s => s.steps),
163
- ...this.renderInstallCommands().map(cmd => ({
164
- run: cmd,
165
- })),
166
- ...this.getAssetUploadCommands(this.needsVersionedArtifacts).map(cmd => ({
167
- run: cmd,
168
- }))],
152
+ ...steps.flatMap(s => s.steps),
153
+ ],
169
154
  });
170
155
  }
171
156
  /**
@@ -173,8 +158,22 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
173
158
  * @param stage - The deployment stage to create.
174
159
  */
175
160
  createDeployment(stage) {
176
- const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGithub());
177
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());
178
177
  // Create new workflow for deployment
179
178
  const stageWorkflow = this.app.github.addWorkflow(`release-${stage.name}`);
180
179
  stageWorkflow.on({
@@ -189,11 +188,11 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
189
188
  });
190
189
  stageWorkflow.addJob('deploy', {
191
190
  name: `Release stage ${stage.name} to AWS`,
192
- needs: preInstallSteps.flatMap(s => s.needs),
191
+ needs: steps.flatMap(s => s.needs),
193
192
  runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
194
193
  env: {
195
194
  CI: 'true',
196
- ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
195
+ ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
197
196
  },
198
197
  permissions: {
199
198
  idToken: workflows_model_1.JobPermission.WRITE,
@@ -202,49 +201,41 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
202
201
  packages: workflows_model_1.JobPermission.READ,
203
202
  },
204
203
  },
205
- steps: [{
204
+ steps: [
205
+ {
206
206
  name: 'Checkout',
207
207
  uses: 'actions/checkout@v4',
208
- }, {
209
- name: 'AWS Credentials',
210
- uses: 'aws-actions/configure-aws-credentials@master',
211
- with: {
212
- 'role-to-assume': this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
213
- 'role-session-name': 'GitHubAction',
214
- 'aws-region': stage.env.region,
215
- },
216
208
  },
217
- ...preInstallSteps.flatMap(s => s.steps),
218
- ...this.renderInstallCommands().map(cmd => ({
219
- run: cmd,
220
- })),
221
- ...this.renderInstallPackageCommands(`${this.options.pkgNamespace}/${this.app.name}@\${{github.event.inputs.version}}`).map(cmd => ({
222
- run: cmd,
223
- })),
224
- {
225
- run: `mv ./node_modules/${this.options.pkgNamespace}/${this.app.name} ${this.app.cdkConfig.cdkout}`,
226
- },
227
- ...this.renderDeployCommands(stage.name).map(cmd => ({
228
- run: cmd,
229
- })),
230
- {
231
- uses: 'actions/upload-artifact@v3',
232
- with: {
233
- name: `cdk-outputs-${stage.name}`,
234
- path: `cdk-outputs-${stage.name}.json`,
235
- },
236
- }],
209
+ ...steps.flatMap(s => s.steps),
210
+ ],
237
211
  });
238
212
  }
239
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());
240
231
  // Add deployment to CI/CD workflow
241
232
  this.deploymentWorkflow.addJob(`deploy-${stage.name}`, {
242
233
  name: `Deploy stage ${stage.name} to AWS`,
243
- 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)}`] : [])],
244
235
  runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
245
236
  env: {
246
237
  CI: 'true',
247
- ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
238
+ ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
248
239
  },
249
240
  permissions: {
250
241
  idToken: workflows_model_1.JobPermission.WRITE,
@@ -253,44 +244,69 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
253
244
  packages: workflows_model_1.JobPermission.READ,
254
245
  },
255
246
  },
256
- steps: [{
247
+ steps: [
248
+ {
257
249
  name: 'Checkout',
258
250
  uses: 'actions/checkout@v4',
259
- }, {
260
- name: 'AWS Credentials',
261
- uses: 'aws-actions/configure-aws-credentials@master',
262
- with: {
263
- 'role-to-assume': this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
264
- 'role-session-name': 'GitHubAction',
265
- 'aws-region': stage.env.region,
266
- },
267
- }, {
268
- uses: 'actions/download-artifact@v4',
269
- with: {
270
- name: 'cloud-assembly',
271
- path: `${this.app.cdkConfig.cdkout}/`,
272
- },
273
251
  },
274
- ...preInstallSteps.flatMap(s => s.steps),
275
- ...this.renderInstallCommands().map(cmd => ({
276
- run: cmd,
277
- })),
278
- ...this.renderDeployCommands(stage.name).map(cmd => ({
279
- run: cmd,
280
- })),
281
- {
282
- uses: 'actions/upload-artifact@v3',
283
- with: {
284
- name: `cdk-outputs-${stage.name}`,
285
- path: `cdk-outputs-${stage.name}.json`,
286
- },
287
- }],
252
+ ...steps.flatMap(s => s.steps),
253
+ ],
288
254
  });
289
255
  this.deploymentStages.push(stage.name);
290
256
  }
291
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
+ }
292
308
  }
293
309
  exports.GithubCDKPipeline = GithubCDKPipeline;
294
310
  _a = JSII_RTTI_SYMBOL_1;
295
- GithubCDKPipeline[_a] = { fqn: "projen-pipelines.GithubCDKPipeline", version: "0.0.62" };
296
- //# 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        ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        ...preSynthSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        ...postSynthSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\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        ...preInstallSteps.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        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          ...preInstallSteps.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          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          ...preInstallSteps.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          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":"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","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
  }