projen-pipelines 0.0.62 → 0.0.64
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +293 -130
- package/API.md +233 -15
- package/lib/awscdk/base.d.ts +32 -3
- package/lib/awscdk/base.js +29 -2
- package/lib/awscdk/bash.js +1 -1
- package/lib/awscdk/github.d.ts +6 -1
- package/lib/awscdk/github.js +146 -130
- package/lib/awscdk/gitlab.d.ts +6 -1
- package/lib/awscdk/gitlab.js +94 -64
- package/lib/steps/artifact-steps.d.ts +21 -0
- package/lib/steps/artifact-steps.js +56 -0
- package/lib/steps/aws-assume-role.step.d.ts +22 -0
- package/lib/steps/aws-assume-role.step.js +42 -0
- package/lib/steps/step.d.ts +6 -6
- package/lib/steps/step.js +21 -3
- package/package.json +5 -5
package/lib/awscdk/github.js
CHANGED
|
@@ -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
|
-
|
|
71
|
-
|
|
72
|
-
|
|
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
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
steps.push(
|
|
83
|
-
steps.push(...this.
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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
|
-
...
|
|
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: [...
|
|
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
|
|
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', ...
|
|
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
|
-
...
|
|
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
|
-
...
|
|
163
|
-
|
|
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:
|
|
191
|
+
needs: steps.flatMap(s => s.needs),
|
|
193
192
|
runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,
|
|
194
193
|
env: {
|
|
195
194
|
CI: 'true',
|
|
196
|
-
...
|
|
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
|
-
...
|
|
218
|
-
|
|
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', ...
|
|
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
|
-
...
|
|
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
|
-
...
|
|
275
|
-
|
|
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.
|
|
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.64" };
|
|
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"]}
|
package/lib/awscdk/gitlab.d.ts
CHANGED
|
@@ -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
|
}
|