projen-pipelines 0.1.1 → 0.2.0
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 +749 -640
- package/API.md +579 -323
- package/lib/awscdk/base.d.ts +33 -8
- package/lib/awscdk/base.js +86 -35
- package/lib/awscdk/bash.js +11 -16
- package/lib/awscdk/codecatalyst.d.ts +0 -17
- package/lib/awscdk/codecatalyst.js +23 -27
- package/lib/awscdk/github.d.ts +0 -21
- package/lib/awscdk/github.js +15 -65
- package/lib/awscdk/gitlab.d.ts +0 -27
- package/lib/awscdk/gitlab.js +19 -64
- package/lib/steps/artifact-steps.js +2 -2
- package/lib/steps/aws-assume-role.step.d.ts +3 -1
- package/lib/steps/aws-assume-role.step.js +17 -2
- package/lib/steps/registries.d.ts +11 -1
- package/lib/steps/registries.js +21 -4
- package/lib/steps/set-env.step.d.ts +14 -0
- package/lib/steps/set-env.step.js +44 -0
- package/lib/steps/step.d.ts +30 -0
- package/lib/steps/step.js +112 -6
- package/package.json +1 -1
|
@@ -8,7 +8,6 @@ const blueprint_component_workflows_1 = require("@amazon-codecatalyst/blueprint-
|
|
|
8
8
|
const projen_1 = require("projen");
|
|
9
9
|
const base_1 = require("./base");
|
|
10
10
|
const engine_1 = require("../engine");
|
|
11
|
-
const steps_1 = require("../steps");
|
|
12
11
|
const blueprint_1 = require("./codecatalyst/blueprint");
|
|
13
12
|
class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
14
13
|
constructor(app, options) {
|
|
@@ -109,20 +108,11 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
109
108
|
return engine_1.PipelineEngine.CODE_CATALYST;
|
|
110
109
|
}
|
|
111
110
|
createSynth() {
|
|
112
|
-
const steps = [
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderSynthCommands()));
|
|
117
|
-
steps.push(...this.baseOptions.postSynthSteps ?? []);
|
|
118
|
-
steps.push(new steps_1.UploadArtifactStep(this.project, {
|
|
119
|
-
name: 'cloud-assembly',
|
|
120
|
-
path: `${this.app.cdkConfig.cdkout}/`,
|
|
121
|
-
}));
|
|
111
|
+
const steps = [
|
|
112
|
+
this.provideInstallStep(),
|
|
113
|
+
this.provideSynthStep(),
|
|
114
|
+
];
|
|
122
115
|
const codeCatalystSteps = steps.map(s => s.toCodeCatalyst());
|
|
123
|
-
const cmds = [];
|
|
124
|
-
cmds.push(...this.renderInstallCommands());
|
|
125
|
-
cmds.push(...this.renderSynthCommands());
|
|
126
116
|
this.deploymentWorkflowBuilder.addBuildAction({
|
|
127
117
|
actionName: 'SynthCDKApplication',
|
|
128
118
|
input: {
|
|
@@ -153,8 +143,11 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
153
143
|
*/
|
|
154
144
|
}
|
|
155
145
|
createAssetUpload() {
|
|
156
|
-
const
|
|
157
|
-
|
|
146
|
+
const steps = [
|
|
147
|
+
this.provideInstallStep(),
|
|
148
|
+
this.provideAssetUploadStep(),
|
|
149
|
+
];
|
|
150
|
+
const codeCatalystSteps = steps.map(s => s.toCodeCatalyst());
|
|
158
151
|
this.deploymentWorkflowBuilder.addBuildAction({
|
|
159
152
|
actionName: 'PublishAssetsToAWS',
|
|
160
153
|
dependsOn: ['SynthCDKApplication'],
|
|
@@ -164,7 +157,7 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
164
157
|
CI: 'true',
|
|
165
158
|
},
|
|
166
159
|
},
|
|
167
|
-
steps:
|
|
160
|
+
steps: [...codeCatalystSteps.flatMap(s => s.commands)],
|
|
168
161
|
// FIXME is there is an environment, connect it to the workflow
|
|
169
162
|
// needs to react on this.options.iamRoleArns?.synth
|
|
170
163
|
//environment: environment && convertToWorkflowEnvironment(environment),
|
|
@@ -187,9 +180,10 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
187
180
|
dependsOn = `approve_${stage.name}`;
|
|
188
181
|
}
|
|
189
182
|
// Add deployment to existing workflow
|
|
190
|
-
const
|
|
191
|
-
|
|
192
|
-
|
|
183
|
+
const deploySteps = [
|
|
184
|
+
this.provideInstallStep(),
|
|
185
|
+
this.provideDeployStep(stage),
|
|
186
|
+
].map(s => s.toCodeCatalyst());
|
|
193
187
|
this.deploymentWorkflowBuilder.addBuildAction({
|
|
194
188
|
actionName: `deploy_${stage.name}`,
|
|
195
189
|
dependsOn: this.deploymentStages.length > 0 ? ['PublishAssetsToAWS', dependsOn] : ['PublishAssetsToAWS'],
|
|
@@ -199,7 +193,7 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
199
193
|
CI: 'true',
|
|
200
194
|
},
|
|
201
195
|
},
|
|
202
|
-
steps:
|
|
196
|
+
steps: [...deploySteps.flatMap(s => s.commands)],
|
|
203
197
|
// FIXME is there is an environment, connect it to the workflow
|
|
204
198
|
// needs to react on this.options.iamRoleArns?.synth
|
|
205
199
|
//environment: environment && convertToWorkflowEnvironment(environment),
|
|
@@ -224,9 +218,11 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
224
218
|
dependsOn = `approve_${stage.name}`;
|
|
225
219
|
}
|
|
226
220
|
// Add deployment to existing workflow
|
|
227
|
-
const
|
|
228
|
-
|
|
229
|
-
|
|
221
|
+
const steps = [
|
|
222
|
+
this.provideInstallStep(),
|
|
223
|
+
this.provideSynthStep(),
|
|
224
|
+
this.provideDeployStep(stage),
|
|
225
|
+
].map(s => s.toGitlab());
|
|
230
226
|
this.deploymentWorkflowBuilder.addBuildAction({
|
|
231
227
|
actionName: `indeploy_${stage.name}`,
|
|
232
228
|
dependsOn: [dependsOn],
|
|
@@ -236,7 +232,7 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
236
232
|
CI: 'true',
|
|
237
233
|
},
|
|
238
234
|
},
|
|
239
|
-
steps:
|
|
235
|
+
steps: [...steps.flatMap(s => s.commands)],
|
|
240
236
|
// FIXME is there is an environment, connect it to the workflow
|
|
241
237
|
// needs to react on this.options.iamRoleArns?.synth
|
|
242
238
|
//environment: environment && convertToWorkflowEnvironment(environment),
|
|
@@ -248,5 +244,5 @@ class CodeCatalystCDKPipeline extends base_1.CDKPipeline {
|
|
|
248
244
|
}
|
|
249
245
|
exports.CodeCatalystCDKPipeline = CodeCatalystCDKPipeline;
|
|
250
246
|
_a = JSII_RTTI_SYMBOL_1;
|
|
251
|
-
CodeCatalystCDKPipeline[_a] = { fqn: "projen-pipelines.CodeCatalystCDKPipeline", version: "0.
|
|
252
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codecatalyst.js","sourceRoot":"","sources":["../../src/awscdk/codecatalyst.ts"],"names":[],"mappings":"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","sourcesContent":["import { Environment } from '@amazon-codecatalyst/blueprint-component.environments';\nimport { convertToWorkflowEnvironment, WorkflowBuilder } from '@amazon-codecatalyst/blueprint-component.workflows';\nimport { YamlFile, awscdk } from 'projen';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage } from './base';\n\nimport { PipelineEngine } from '../engine';\nimport { PipelineStep, SimpleCommandStep, UploadArtifactStep } from '../steps';\nimport { Blueprint } from './codecatalyst/blueprint';\n\n/*\nNeeds to create:\n- build.yml (creates and mutates pipeline by executing projen build) - comes from projen\n- deploy.yaml (build + deploy to dev)\n- pull-request-lint.yml (executes amannn/action-semantic-pull-request@v5.0.2) - comes from projen\n- release-prod.yaml (deploy to prod - not required, move over to \"manual approvals\" in deplo)\n- upgrade.yaml (upgrade dependencies)  - comes from projen\n\n* synth -> create artifacts\n* upload cdk assets ->  save assets in s3 (lambda), build container images (push to ECR) -- everything in AWS\n* deploy for each stage that is non-production\n* deploy to prod (manual approval)\n\nTODO:\n- account target -- NOT POSSIBLE as we cannot create environments/accounts/targets\n- manual approval for stages -- DONE\n- IAM role per stage, synth, asset - NOT POSSIBLE as we cannot create environments\n- independend stages (all parallel to each other) after synth&assets -- DONE\n- environments support - DONE\n- steps per stage - preInstall, preSynth, ... - DONE\n\nexample: https://github.com/aws-community-dach/event-system-backend\n\ntest docgen: https://github.com/open-constructs/aws-cdk-library\n\n\n*/\n\nexport interface CodeCatalystIamRoleConfig {\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 ARN for the asset publishing step for a specific stage. */\n  readonly assetPublishingPerStage?: { [stage: string]: string };\n  /** IAM role ARNs for different deployment stages. */\n  readonly deployment?: { [stage: string]: string };\n}\n\nexport interface CodeCatalystCDKPipelineOptions extends CDKPipelineOptions {\n  readonly iamRoleArns: CodeCatalystIamRoleConfig;\n}\n\nexport class CodeCatalystCDKPipeline extends CDKPipeline {\n\n  public readonly needsVersionedArtifacts: boolean;\n\n  private deploymentWorkflowBuilder: WorkflowBuilder;\n  private environments: Map<String, Environment> = new Map();\n  private deploymentStages: string[] = [];\n\n  private readonly bp: Blueprint;\n\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: CodeCatalystCDKPipelineOptions) {\n    super(app, options);\n    // see https://github.com/aws/codecatalyst-blueprints/issues/477\n    process.env.CONTEXT_ENVIRONMENTID = 'prod';\n\n    this.bp = new Blueprint({ outdir: '.codecatalyst/workflows' });\n\n    if (this.options.iamRoleArns) {\n      this.createEnvironments();\n    }\n\n    this.deploymentWorkflowBuilder = new WorkflowBuilder(this.bp);\n\n    this.deploymentWorkflowBuilder.setName('deploy');\n    this.deploymentWorkflowBuilder.addBranchTrigger(['main']);\n\n    this.needsVersionedArtifacts = this.options.stages.find(s => s.manualApproval === true) !== undefined;\n\n    this.createSynth();\n    this.createAssetUpload();\n\n    for (const stage of options.stages) {\n      this.createDeployment(stage);\n    }\n\n    for (const stage of (options.independentStages ?? [])) {\n      this.createIndependentDeployment(stage);\n    }\n\n    new YamlFile(this, '.codecatalyst/workflows/deploy.yaml', {\n      obj: () => this.deploymentWorkflowBuilder.getDefinition(),\n    });\n  }\n\n  public createEnvironments() {\n    if (this.options.iamRoleArns.default) {\n      this.environments.set('default',\n        new Environment(this.bp, {\n          environmentType: 'DEVELOPMENT',\n          name: 'default',\n          description: 'default deployment environment',\n          awsAccount: {\n            id: 'default',\n            name: 'awsAccount',\n            awsAccount: { name: 'default-role', arn: this.options.iamRoleArns.default },\n          },\n        }));\n    }\n\n    if (this.options.iamRoleArns.synth) {\n      this.environments.set('synth',\n        new Environment(this.bp, {\n          environmentType: 'DEVELOPMENT',\n          name: 'synth',\n          description: 'synth deployment environment',\n          awsAccount: {\n            id: 'synth',\n            name: 'awsAccount',\n            awsAccount: { name: 'synth-role', arn: this.options.iamRoleArns.synth },\n          },\n        }));\n    }\n\n    if (this.options.iamRoleArns.assetPublishing) {\n      this.environments.set('assetPublishing',\n        new Environment(this.bp, {\n          environmentType: 'DEVELOPMENT',\n          name: 'assetPublishing',\n          description: 'asset publishing deployment environment',\n          awsAccount: {\n            id: 'assetPublishing',\n            name: 'awsAccount',\n            awsAccount: { name: 'assetPublishing-role', arn: this.options.iamRoleArns.assetPublishing },\n          },\n        }));\n    }\n\n    if (this.options.iamRoleArns.assetPublishingPerStage) {\n      for (const [stage, arn] of Object.entries(this.options.iamRoleArns.assetPublishingPerStage)) {\n        this.environments.set(`${stage}AssetPublishing`,\n          new Environment(this.bp, {\n            environmentType: 'DEVELOPMENT',\n            name: `${stage}AssetPublishingPerStage`,\n            description: `${stage} asset publishing deployment environment`,\n            awsAccount: {\n              id: `${stage}AssetPublishingPerStage`,\n              name: 'awsAccount',\n              awsAccount: { name: `${stage}-role`, arn: arn },\n            },\n          }));\n      }\n    }\n\n    if (this.options.iamRoleArns.deployment) {\n      for (const [stage, arn] of Object.entries(this.options.iamRoleArns.deployment)) {\n        this.environments.set(stage,\n          new Environment(this.bp, {\n            environmentType: 'DEVELOPMENT',\n            name: stage,\n            description: `${stage} deployment environment`,\n            awsAccount: {\n              id: stage,\n              name: 'awsAccount',\n              awsAccount: { name: `${stage}-role`, arn: arn },\n            },\n          }));\n      }\n    }\n  }\n\n  /** the type of engine this implementation of CDKPipeline is for */\n  public engineType(): PipelineEngine {\n    return PipelineEngine.CODE_CATALYST;\n  }\n\n  private createSynth(): void {\n    const steps: PipelineStep[] = [];\n\n    steps.push(...this.baseOptions.preInstallSteps ?? []);\n    steps.push(new SimpleCommandStep(this.project, this.renderInstallCommands()));\n\n    steps.push(...this.baseOptions.preSynthSteps ?? []);\n    steps.push(new SimpleCommandStep(this.project, this.renderSynthCommands()));\n    steps.push(...this.baseOptions.postSynthSteps ?? []);\n\n    steps.push(new UploadArtifactStep(this.project, {\n      name: 'cloud-assembly',\n      path: `${this.app.cdkConfig.cdkout}/`,\n    }));\n\n    const codeCatalystSteps = steps.map(s => s.toCodeCatalyst());\n\n    const cmds: string[] = [];\n    cmds.push(...this.renderInstallCommands());\n    cmds.push(...this.renderSynthCommands());\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: 'SynthCDKApplication',\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps:\n        [...codeCatalystSteps.flatMap(s => s.commands)],\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n      environment: convertToWorkflowEnvironment(this.environments.get('default')),\n      output: {},\n    });\n\n    /*\nnot required because codecatalyst automatically uploads artifacts\nFIXME or do we need to create \"artifacts\" here and upload?\nsteps.push({\n      uses: 'actions/upload-artifact@v3',\n      with: {\n        name: 'cloud-assembly',\n        path: `${this.app.cdkConfig.cdkout}/`,\n      },\n    });\n    */\n  }\n\n  public createAssetUpload(): void {\n\n    const cmds: string[] = [];\n    cmds.push(...this.renderAssetUploadCommands());\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: 'PublishAssetsToAWS',\n      dependsOn: ['SynthCDKApplication'],\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps:\n        cmds,\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n\n      output: {},\n    });\n  }\n\n  public createDeployment(stage: DeploymentStage): void {\n    let dependsOn = `deploy_${this.deploymentStages.at(-1)!}`;\n    if (stage.manualApproval === true) {\n      this.deploymentWorkflowBuilder.addGenericAction({\n        Identifier: 'aws/approval@v1',\n        actionName: `approve_${stage.name}`,\n        DependsOn: [dependsOn],\n        Configuration: {\n          ApprovalsRequired: 1,\n        },\n      });\n      dependsOn = `approve_${stage.name}`;\n    }\n    // Add deployment to existing workflow\n    const cmds: string[] = [];\n    cmds.push(...this.renderInstallCommands());\n    cmds.push(...this.renderDeployCommands(stage.name));\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: `deploy_${stage.name}`,\n      dependsOn: this.deploymentStages.length > 0 ? ['PublishAssetsToAWS', dependsOn] : ['PublishAssetsToAWS'],\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps:\n        cmds,\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n\n      output: {},\n      environment: convertToWorkflowEnvironment(this.environments.get(stage.name)),\n    });\n\n    this.deploymentStages.push(stage.name);\n  }\n\n  public createIndependentDeployment(stage: DeploymentStage): void {\n    let dependsOn = 'PublishAssetsToAWS';\n    if (stage.manualApproval === true) {\n      this.deploymentWorkflowBuilder.addGenericAction({\n        Identifier: 'aws/approval@v1',\n        actionName: `approve_${stage.name}`,\n        DependsOn: [dependsOn],\n        Configuration: {\n          ApprovalsRequired: 1,\n        },\n      });\n      dependsOn = `approve_${stage.name}`;\n    }\n    // Add deployment to existing workflow\n    const cmds: string[] = [];\n    cmds.push(...this.renderInstallCommands());\n    cmds.push(...this.renderDeployCommands(stage.name));\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: `indeploy_${stage.name}`,\n      dependsOn: [dependsOn],\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps:\n        cmds,\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n\n      output: {},\n    });\n  }\n\n}\n"]}
|
|
247
|
+
CodeCatalystCDKPipeline[_a] = { fqn: "projen-pipelines.CodeCatalystCDKPipeline", version: "0.2.0" };
|
|
248
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codecatalyst.js","sourceRoot":"","sources":["../../src/awscdk/codecatalyst.ts"],"names":[],"mappings":"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","sourcesContent":["import { Environment } from '@amazon-codecatalyst/blueprint-component.environments';\nimport { convertToWorkflowEnvironment, WorkflowBuilder } from '@amazon-codecatalyst/blueprint-component.workflows';\nimport { YamlFile, awscdk } from 'projen';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage } from './base';\n\nimport { PipelineEngine } from '../engine';\nimport { PipelineStep } from '../steps';\nimport { Blueprint } from './codecatalyst/blueprint';\n\n/*\nNeeds to create:\n- build.yml (creates and mutates pipeline by executing projen build) - comes from projen\n- deploy.yaml (build + deploy to dev)\n- pull-request-lint.yml (executes amannn/action-semantic-pull-request@v5.0.2) - comes from projen\n- release-prod.yaml (deploy to prod - not required, move over to \"manual approvals\" in deplo)\n- upgrade.yaml (upgrade dependencies)  - comes from projen\n\n* synth -> create artifacts\n* upload cdk assets ->  save assets in s3 (lambda), build container images (push to ECR) -- everything in AWS\n* deploy for each stage that is non-production\n* deploy to prod (manual approval)\n\nTODO:\n- account target -- NOT POSSIBLE as we cannot create environments/accounts/targets\n- manual approval for stages -- DONE\n- IAM role per stage, synth, asset - NOT POSSIBLE as we cannot create environments\n- independend stages (all parallel to each other) after synth&assets -- DONE\n- environments support - DONE\n- steps per stage - preInstall, preSynth, ... - DONE\n\nexample: https://github.com/aws-community-dach/event-system-backend\n\ntest docgen: https://github.com/open-constructs/aws-cdk-library\n\n\n*/\n\nexport interface CodeCatalystCDKPipelineOptions extends CDKPipelineOptions {\n  //\n}\n\nexport class CodeCatalystCDKPipeline extends CDKPipeline {\n\n  public readonly needsVersionedArtifacts: boolean;\n\n  private deploymentWorkflowBuilder: WorkflowBuilder;\n  private environments: Map<String, Environment> = new Map();\n  private deploymentStages: string[] = [];\n\n  private readonly bp: Blueprint;\n\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: CodeCatalystCDKPipelineOptions) {\n    super(app, options);\n    // see https://github.com/aws/codecatalyst-blueprints/issues/477\n    process.env.CONTEXT_ENVIRONMENTID = 'prod';\n\n    this.bp = new Blueprint({ outdir: '.codecatalyst/workflows' });\n\n    if (this.options.iamRoleArns) {\n      this.createEnvironments();\n    }\n\n    this.deploymentWorkflowBuilder = new WorkflowBuilder(this.bp);\n\n    this.deploymentWorkflowBuilder.setName('deploy');\n    this.deploymentWorkflowBuilder.addBranchTrigger(['main']);\n\n    this.needsVersionedArtifacts = this.options.stages.find(s => s.manualApproval === true) !== undefined;\n\n    this.createSynth();\n    this.createAssetUpload();\n\n    for (const stage of options.stages) {\n      this.createDeployment(stage);\n    }\n\n    for (const stage of (options.independentStages ?? [])) {\n      this.createIndependentDeployment(stage);\n    }\n\n    new YamlFile(this, '.codecatalyst/workflows/deploy.yaml', {\n      obj: () => this.deploymentWorkflowBuilder.getDefinition(),\n    });\n  }\n\n  public createEnvironments() {\n    if (this.options.iamRoleArns.default) {\n      this.environments.set('default',\n        new Environment(this.bp, {\n          environmentType: 'DEVELOPMENT',\n          name: 'default',\n          description: 'default deployment environment',\n          awsAccount: {\n            id: 'default',\n            name: 'awsAccount',\n            awsAccount: { name: 'default-role', arn: this.options.iamRoleArns.default },\n          },\n        }));\n    }\n\n    if (this.options.iamRoleArns.synth) {\n      this.environments.set('synth',\n        new Environment(this.bp, {\n          environmentType: 'DEVELOPMENT',\n          name: 'synth',\n          description: 'synth deployment environment',\n          awsAccount: {\n            id: 'synth',\n            name: 'awsAccount',\n            awsAccount: { name: 'synth-role', arn: this.options.iamRoleArns.synth },\n          },\n        }));\n    }\n\n    if (this.options.iamRoleArns.assetPublishing) {\n      this.environments.set('assetPublishing',\n        new Environment(this.bp, {\n          environmentType: 'DEVELOPMENT',\n          name: 'assetPublishing',\n          description: 'asset publishing deployment environment',\n          awsAccount: {\n            id: 'assetPublishing',\n            name: 'awsAccount',\n            awsAccount: { name: 'assetPublishing-role', arn: this.options.iamRoleArns.assetPublishing },\n          },\n        }));\n    }\n\n    if (this.options.iamRoleArns.assetPublishingPerStage) {\n      for (const [stage, arn] of Object.entries(this.options.iamRoleArns.assetPublishingPerStage)) {\n        this.environments.set(`${stage}AssetPublishing`,\n          new Environment(this.bp, {\n            environmentType: 'DEVELOPMENT',\n            name: `${stage}AssetPublishingPerStage`,\n            description: `${stage} asset publishing deployment environment`,\n            awsAccount: {\n              id: `${stage}AssetPublishingPerStage`,\n              name: 'awsAccount',\n              awsAccount: { name: `${stage}-role`, arn: arn },\n            },\n          }));\n      }\n    }\n\n    if (this.options.iamRoleArns.deployment) {\n      for (const [stage, arn] of Object.entries(this.options.iamRoleArns.deployment)) {\n        this.environments.set(stage,\n          new Environment(this.bp, {\n            environmentType: 'DEVELOPMENT',\n            name: stage,\n            description: `${stage} deployment environment`,\n            awsAccount: {\n              id: stage,\n              name: 'awsAccount',\n              awsAccount: { name: `${stage}-role`, arn: arn },\n            },\n          }));\n      }\n    }\n  }\n\n  /** the type of engine this implementation of CDKPipeline is for */\n  public engineType(): PipelineEngine {\n    return PipelineEngine.CODE_CATALYST;\n  }\n\n  private createSynth(): void {\n    const steps: PipelineStep[] = [\n      this.provideInstallStep(),\n      this.provideSynthStep(),\n    ];\n\n    const codeCatalystSteps = steps.map(s => s.toCodeCatalyst());\n\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: 'SynthCDKApplication',\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps: [...codeCatalystSteps.flatMap(s => s.commands)],\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n      environment: convertToWorkflowEnvironment(this.environments.get('default')),\n      output: {},\n    });\n\n    /*\nnot required because codecatalyst automatically uploads artifacts\nFIXME or do we need to create \"artifacts\" here and upload?\nsteps.push({\n      uses: 'actions/upload-artifact@v3',\n      with: {\n        name: 'cloud-assembly',\n        path: `${this.app.cdkConfig.cdkout}/`,\n      },\n    });\n    */\n  }\n\n  public createAssetUpload(): void {\n    const steps = [\n      this.provideInstallStep(),\n      this.provideAssetUploadStep(),\n    ];\n    const codeCatalystSteps = steps.map(s => s.toCodeCatalyst());\n\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: 'PublishAssetsToAWS',\n      dependsOn: ['SynthCDKApplication'],\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps: [...codeCatalystSteps.flatMap(s => s.commands)],\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n\n      output: {},\n    });\n  }\n\n  public createDeployment(stage: DeploymentStage): void {\n    let dependsOn = `deploy_${this.deploymentStages.at(-1)!}`;\n    if (stage.manualApproval === true) {\n      this.deploymentWorkflowBuilder.addGenericAction({\n        Identifier: 'aws/approval@v1',\n        actionName: `approve_${stage.name}`,\n        DependsOn: [dependsOn],\n        Configuration: {\n          ApprovalsRequired: 1,\n        },\n      });\n      dependsOn = `approve_${stage.name}`;\n    }\n    // Add deployment to existing workflow\n    const deploySteps = [\n      this.provideInstallStep(),\n      this.provideDeployStep(stage),\n    ].map(s => s.toCodeCatalyst());\n\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: `deploy_${stage.name}`,\n      dependsOn: this.deploymentStages.length > 0 ? ['PublishAssetsToAWS', dependsOn] : ['PublishAssetsToAWS'],\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps: [...deploySteps.flatMap(s => s.commands)],\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n\n      output: {},\n      environment: convertToWorkflowEnvironment(this.environments.get(stage.name)),\n    });\n\n    this.deploymentStages.push(stage.name);\n  }\n\n  public createIndependentDeployment(stage: DeploymentStage): void {\n    let dependsOn = 'PublishAssetsToAWS';\n    if (stage.manualApproval === true) {\n      this.deploymentWorkflowBuilder.addGenericAction({\n        Identifier: 'aws/approval@v1',\n        actionName: `approve_${stage.name}`,\n        DependsOn: [dependsOn],\n        Configuration: {\n          ApprovalsRequired: 1,\n        },\n      });\n      dependsOn = `approve_${stage.name}`;\n    }\n    // Add deployment to existing workflow\n\n    const steps = [\n      this.provideInstallStep(),\n      this.provideSynthStep(),\n      this.provideDeployStep(stage),\n    ].map(s => s.toGitlab());\n\n    this.deploymentWorkflowBuilder.addBuildAction({\n      actionName: `indeploy_${stage.name}`,\n      dependsOn: [dependsOn],\n      input: {\n        Sources: ['WorkflowSource'],\n        Variables: {\n          CI: 'true',\n        },\n      },\n      steps: [...steps.flatMap(s => s.commands)],\n      // FIXME is there is an environment, connect it to the workflow\n      // needs to react on this.options.iamRoleArns?.synth\n      //environment: environment && convertToWorkflowEnvironment(environment),\n\n      // FIXME what about the permissions?\n      // permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n\n      output: {},\n    });\n  }\n\n}\n"]}
|
package/lib/awscdk/github.d.ts
CHANGED
|
@@ -1,31 +1,10 @@
|
|
|
1
1
|
import { awscdk } from 'projen';
|
|
2
2
|
import { CDKPipeline, CDKPipelineOptions, DeploymentStage, IndependentStage } from './base';
|
|
3
3
|
import { PipelineEngine } from '../engine';
|
|
4
|
-
/**
|
|
5
|
-
* Configuration interface for GitHub-specific IAM roles used in the CDK pipeline.
|
|
6
|
-
*/
|
|
7
|
-
export interface GithubIamRoleConfig {
|
|
8
|
-
/** Default IAM role ARN used if no specific role is provided. */
|
|
9
|
-
readonly default?: string;
|
|
10
|
-
/** IAM role ARN for the synthesis step. */
|
|
11
|
-
readonly synth?: string;
|
|
12
|
-
/** IAM role ARN for the asset publishing step. */
|
|
13
|
-
readonly assetPublishing?: string;
|
|
14
|
-
/** IAM role ARN for the asset publishing step for a specific stage. */
|
|
15
|
-
readonly assetPublishingPerStage?: {
|
|
16
|
-
[stage: string]: string;
|
|
17
|
-
};
|
|
18
|
-
/** IAM role ARNs for different deployment stages. */
|
|
19
|
-
readonly deployment?: {
|
|
20
|
-
[stage: string]: string;
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
4
|
/**
|
|
24
5
|
* Extension of the base CDKPipeline options including specific configurations for GitHub.
|
|
25
6
|
*/
|
|
26
7
|
export interface GithubCDKPipelineOptions extends CDKPipelineOptions {
|
|
27
|
-
/** IAM config for GitHub Actions */
|
|
28
|
-
readonly iamRoleArns: GithubIamRoleConfig;
|
|
29
8
|
/**
|
|
30
9
|
* runner tags to use to select runners
|
|
31
10
|
*
|
package/lib/awscdk/github.js
CHANGED
|
@@ -9,7 +9,6 @@ const engine_1 = require("../engine");
|
|
|
9
9
|
const engines_1 = require("../engines");
|
|
10
10
|
const steps_1 = require("../steps");
|
|
11
11
|
const artifact_steps_1 = require("../steps/artifact-steps");
|
|
12
|
-
const aws_assume_role_step_1 = require("../steps/aws-assume-role.step");
|
|
13
12
|
const registries_1 = require("../steps/registries");
|
|
14
13
|
const DEFAULT_RUNNER_TAGS = ['ubuntu-latest'];
|
|
15
14
|
/**
|
|
@@ -70,17 +69,8 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
70
69
|
*/
|
|
71
70
|
createSynth() {
|
|
72
71
|
const steps = [];
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
roleArn: this.options.iamRoleArns.synth,
|
|
76
|
-
sessionName: 'GitHubAction',
|
|
77
|
-
}));
|
|
78
|
-
}
|
|
79
|
-
steps.push(...this.baseOptions.preInstallSteps ?? []);
|
|
80
|
-
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()));
|
|
81
|
-
steps.push(...this.baseOptions.preSynthSteps ?? []);
|
|
82
|
-
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderSynthCommands()));
|
|
83
|
-
steps.push(...this.baseOptions.postSynthSteps ?? []);
|
|
72
|
+
steps.push(this.provideInstallStep());
|
|
73
|
+
steps.push(this.provideSynthStep());
|
|
84
74
|
steps.push(new artifact_steps_1.UploadArtifactStep(this.project, {
|
|
85
75
|
name: 'cloud-assembly',
|
|
86
76
|
path: `${this.app.cdkConfig.cdkout}/`,
|
|
@@ -95,7 +85,6 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
95
85
|
},
|
|
96
86
|
needs: [...githubSteps.flatMap(s => s.needs)],
|
|
97
87
|
permissions: (0, engines_1.mergeJobPermissions)({
|
|
98
|
-
idToken: workflows_model_1.JobPermission.WRITE,
|
|
99
88
|
contents: workflows_model_1.JobPermission.READ,
|
|
100
89
|
}, ...githubSteps.flatMap(s => s.permissions).filter(p => p != undefined)),
|
|
101
90
|
steps: [
|
|
@@ -111,34 +100,17 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
111
100
|
* Creates a job to upload assets to AWS as part of the pipeline.
|
|
112
101
|
*/
|
|
113
102
|
createAssetUpload() {
|
|
114
|
-
const globalPublishRole = this.options.iamRoleArns.assetPublishing ?? this.options.iamRoleArns.default;
|
|
115
103
|
const steps = [
|
|
116
104
|
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: globalPublishRole,
|
|
119
|
-
region: 'us-east-1',
|
|
120
|
-
}),
|
|
121
105
|
new artifact_steps_1.DownloadArtifactStep(this.project, {
|
|
122
106
|
name: 'cloud-assembly',
|
|
123
107
|
path: `${this.app.cdkConfig.cdkout}/`,
|
|
124
108
|
}),
|
|
125
|
-
|
|
126
|
-
|
|
109
|
+
this.provideInstallStep(),
|
|
110
|
+
this.provideAssetUploadStep(),
|
|
127
111
|
];
|
|
128
|
-
if (this.options.iamRoleArns.assetPublishingPerStage) {
|
|
129
|
-
const stages = [...this.options.stages, ...this.options.independentStages ?? []];
|
|
130
|
-
for (const stage of stages) {
|
|
131
|
-
steps.push(new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
|
|
132
|
-
roleArn: this.options.iamRoleArns.assetPublishingPerStage[stage.name] ?? globalPublishRole,
|
|
133
|
-
}));
|
|
134
|
-
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderAssetUploadCommands(stage.name)));
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
else {
|
|
138
|
-
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderAssetUploadCommands()));
|
|
139
|
-
}
|
|
140
112
|
if (this.needsVersionedArtifacts) {
|
|
141
|
-
steps.push(
|
|
113
|
+
steps.push(this.provideAssemblyUploadStep());
|
|
142
114
|
}
|
|
143
115
|
const ghSteps = steps.map(s => s.toGithub());
|
|
144
116
|
this.deploymentWorkflow.addJob('assetUpload', {
|
|
@@ -175,15 +147,10 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
175
147
|
createDeployment(stage) {
|
|
176
148
|
if (stage.manualApproval === true) {
|
|
177
149
|
const steps = [
|
|
178
|
-
|
|
179
|
-
roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
|
|
180
|
-
region: stage.env.region,
|
|
181
|
-
}),
|
|
182
|
-
...this.baseOptions.preInstallSteps ?? [],
|
|
183
|
-
new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
|
|
150
|
+
this.provideInstallStep(),
|
|
184
151
|
new steps_1.SimpleCommandStep(this.project, this.renderInstallPackageCommands(`${this.baseOptions.pkgNamespace}/${this.app.name}@\${{github.event.inputs.version}}`)),
|
|
185
152
|
new steps_1.SimpleCommandStep(this.project, [`mv ./node_modules/${this.baseOptions.pkgNamespace}/${this.app.name} ${this.app.cdkConfig.cdkout}`]),
|
|
186
|
-
|
|
153
|
+
this.provideDeployStep(stage),
|
|
187
154
|
new artifact_steps_1.UploadArtifactStep(this.project, {
|
|
188
155
|
name: `cdk-outputs-${stage.name}`,
|
|
189
156
|
path: `cdk-outputs-${stage.name}.json`,
|
|
@@ -213,7 +180,6 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
213
180
|
...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
214
181
|
},
|
|
215
182
|
permissions: (0, engines_1.mergeJobPermissions)({
|
|
216
|
-
idToken: workflows_model_1.JobPermission.WRITE,
|
|
217
183
|
contents: workflows_model_1.JobPermission.READ,
|
|
218
184
|
}, ...steps.flatMap(s => s.permissions).filter(p => p != undefined)),
|
|
219
185
|
steps: [
|
|
@@ -232,17 +198,12 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
232
198
|
}
|
|
233
199
|
createDeployJob(workflow, jobDependencies, stage) {
|
|
234
200
|
const steps = [
|
|
235
|
-
new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
|
|
236
|
-
roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
|
|
237
|
-
region: stage.env.region,
|
|
238
|
-
}),
|
|
239
201
|
new artifact_steps_1.DownloadArtifactStep(this.project, {
|
|
240
202
|
name: 'cloud-assembly',
|
|
241
203
|
path: `${this.app.cdkConfig.cdkout}/`,
|
|
242
204
|
}),
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
new steps_1.SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),
|
|
205
|
+
this.provideInstallStep(),
|
|
206
|
+
this.provideDeployStep(stage),
|
|
246
207
|
new artifact_steps_1.UploadArtifactStep(this.project, {
|
|
247
208
|
name: `cdk-outputs-${stage.name}`,
|
|
248
209
|
path: `cdk-outputs-${stage.name}.json`,
|
|
@@ -261,7 +222,6 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
261
222
|
...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
262
223
|
},
|
|
263
224
|
permissions: (0, engines_1.mergeJobPermissions)({
|
|
264
|
-
idToken: workflows_model_1.JobPermission.WRITE,
|
|
265
225
|
contents: workflows_model_1.JobPermission.READ,
|
|
266
226
|
}, ...steps.flatMap(s => s.permissions).filter(p => p != undefined)),
|
|
267
227
|
steps: [
|
|
@@ -283,19 +243,10 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
283
243
|
}
|
|
284
244
|
else {
|
|
285
245
|
const steps = [
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
...this.baseOptions.preInstallSteps ?? [],
|
|
291
|
-
new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
|
|
292
|
-
...this.baseOptions.preSynthSteps ?? [],
|
|
293
|
-
new steps_1.SimpleCommandStep(this.project, this.renderSynthCommands()),
|
|
294
|
-
...this.baseOptions.postSynthSteps ?? [],
|
|
295
|
-
new steps_1.SimpleCommandStep(this.project, this.renderDiffCommands(stage.name)),
|
|
296
|
-
...stage.postDiffSteps ?? [],
|
|
297
|
-
new steps_1.SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),
|
|
298
|
-
...stage.postDeploySteps ?? [],
|
|
246
|
+
this.provideInstallStep(),
|
|
247
|
+
this.provideSynthStep(),
|
|
248
|
+
this.provideDiffStep(stage),
|
|
249
|
+
this.provideDeployStep(stage),
|
|
299
250
|
new artifact_steps_1.UploadArtifactStep(this.project, {
|
|
300
251
|
name: `cdk-outputs-${stage.name}`,
|
|
301
252
|
path: `cdk-outputs-${stage.name}.json`,
|
|
@@ -315,7 +266,6 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
315
266
|
...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
316
267
|
},
|
|
317
268
|
permissions: (0, engines_1.mergeJobPermissions)({
|
|
318
|
-
idToken: workflows_model_1.JobPermission.WRITE,
|
|
319
269
|
contents: workflows_model_1.JobPermission.READ,
|
|
320
270
|
}, ...steps.flatMap(s => s.permissions).filter(p => p != undefined)),
|
|
321
271
|
steps: [
|
|
@@ -331,5 +281,5 @@ class GithubCDKPipeline extends base_1.CDKPipeline {
|
|
|
331
281
|
}
|
|
332
282
|
exports.GithubCDKPipeline = GithubCDKPipeline;
|
|
333
283
|
_a = JSII_RTTI_SYMBOL_1;
|
|
334
|
-
GithubCDKPipeline[_a] = { fqn: "projen-pipelines.GithubCDKPipeline", version: "0.
|
|
335
|
-
//# 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, JobPermissions } from 'projen/lib/github/workflows-model';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage, IndependentStage, NamedStageOptions } from './base';\nimport { PipelineEngine } from '../engine';\nimport { mergeJobPermissions } from '../engines';\nimport { PipelineStep, SimpleCommandStep } from '../steps';\nimport { DownloadArtifactStep, UploadArtifactStep } from '../steps/artifact-steps';\nimport { AwsAssumeRoleStep } from '../steps/aws-assume-role.step';\nimport { GithubPackagesLoginStep } from '../steps/registries';\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 ARN for the asset publishing step for a specific stage. */\n  readonly assetPublishingPerStage?: { [stage: string]: 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   * whether to use GitHub environments for deployment stages\n   *\n   * INFO: When using environments consider protection rules instead of using the manual option of projen-pipelines for stages\n   *\n   * @default false\n   */\n  readonly useGithubEnvironments?: 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        preInstallSteps: [\n          new GithubPackagesLoginStep(app, { write: false }),\n          ...options.preInstallSteps ?? [],\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.baseOptions.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.baseOptions.preInstallSteps ?? []);\n    steps.push(new SimpleCommandStep(this.project, this.renderInstallCommands()));\n\n    steps.push(...this.baseOptions.preSynthSteps ?? []);\n    steps.push(new SimpleCommandStep(this.project, this.renderSynthCommands()));\n    steps.push(...this.baseOptions.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: mergeJobPermissions({\n        idToken: JobPermission.WRITE,\n        contents: JobPermission.READ,\n      }, ...(githubSteps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\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 globalPublishRole = this.options.iamRoleArns.assetPublishing ?? this.options.iamRoleArns.default!;\n\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: globalPublishRole,\n        region: 'us-east-1',\n      }),\n      new DownloadArtifactStep(this.project, {\n        name: 'cloud-assembly',\n        path: `${this.app.cdkConfig.cdkout}/`,\n      }),\n      ...this.baseOptions.preInstallSteps ?? [],\n      new SimpleCommandStep(this.project, this.renderInstallCommands()),\n    ];\n\n    if (this.options.iamRoleArns.assetPublishingPerStage) {\n      const stages = [...this.options.stages, ...this.options.independentStages ?? []];\n      for (const stage of stages) {\n        steps.push(new AwsAssumeRoleStep(this.project, {\n          roleArn: this.options.iamRoleArns.assetPublishingPerStage[stage.name] ?? globalPublishRole,\n        }));\n        steps.push(new SimpleCommandStep(this.project, this.renderAssetUploadCommands(stage.name)));\n      }\n    } else {\n      steps.push(new SimpleCommandStep(this.project, this.renderAssetUploadCommands()));\n    }\n\n    if (this.needsVersionedArtifacts) {\n      steps.push(new SimpleCommandStep(this.project, this.renderAssemblyUploadCommands()));\n    }\n\n    const ghSteps = steps.map(s => s.toGithub());\n\n    this.deploymentWorkflow.addJob('assetUpload', {\n      name: 'Publish assets to AWS',\n      needs: ['synth', ...ghSteps.flatMap(s => s.needs)],\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n        ...ghSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      permissions: mergeJobPermissions({\n        idToken: JobPermission.WRITE,\n        contents: this.needsVersionedArtifacts ? JobPermission.WRITE : JobPermission.READ,\n        ...this.useGithubPackages && {\n          packages: JobPermission.WRITE,\n        },\n      }, ...(ghSteps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n      steps: [\n        {\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\n          with: {\n            'fetch-depth': 0,\n          },\n        },\n        ...ghSteps.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.baseOptions.preInstallSteps ?? [],\n        new SimpleCommandStep(this.project, this.renderInstallCommands()),\n        new SimpleCommandStep(this.project, this.renderInstallPackageCommands(`${this.baseOptions.pkgNamespace}/${this.app.name}@\\${{github.event.inputs.version}}`)),\n        new SimpleCommandStep(this.project, [`mv ./node_modules/${this.baseOptions.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        ...this.options.useGithubEnvironments && {\n          environment: stage.name,\n        },\n        env: {\n          CI: 'true',\n          ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        },\n        permissions: mergeJobPermissions({\n          idToken: JobPermission.WRITE,\n          contents: JobPermission.READ,\n        }, ...(steps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v4',\n          },\n          ...steps.flatMap(s => s.steps),\n        ],\n      });\n\n    } else {\n      this.createDeployJob(this.deploymentWorkflow, [...(this.deploymentStages.length > 0 ? [`deploy-${this.deploymentStages.at(-1)!}`] : [])], stage);\n      this.deploymentStages.push(stage.name);\n    }\n  }\n\n  private createDeployJob(workflow: GithubWorkflow, jobDependencies: string[], stage: NamedStageOptions) {\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.baseOptions.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    workflow.addJob(`deploy-${stage.name}`, {\n      name: `Deploy stage ${stage.name} to AWS`,\n      ...this.options.useGithubEnvironments && {\n        environment: stage.name,\n      },\n      needs: ['assetUpload', ...steps.flatMap(s => s.needs), ...jobDependencies],\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n        ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      permissions: mergeJobPermissions({\n        idToken: JobPermission.WRITE,\n        contents: JobPermission.READ,\n      }, ...(steps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n      steps: [\n        {\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\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 independent stage to create.\n   */\n  public createIndependentDeployment(stage: IndependentStage): void {\n    if (stage.deployOnPush || this.options.useGithubEnvironments) {\n      this.createDeployJob(this.deploymentWorkflow, [], stage);\n    } else {\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.baseOptions.preInstallSteps ?? [],\n        new SimpleCommandStep(this.project, this.renderInstallCommands()),\n\n        ...this.baseOptions.preSynthSteps ?? [],\n        new SimpleCommandStep(this.project, this.renderSynthCommands()),\n        ...this.baseOptions.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: mergeJobPermissions({\n          idToken: JobPermission.WRITE,\n          contents: JobPermission.READ,\n        }, ...(steps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v4',\n          },\n          ...steps.flatMap(s => s.steps),\n        ],\n      });\n\n    }\n  }\n}\n"]}
|
|
284
|
+
GithubCDKPipeline[_a] = { fqn: "projen-pipelines.GithubCDKPipeline", version: "0.2.0" };
|
|
285
|
+
//# 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, JobPermissions } from 'projen/lib/github/workflows-model';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage, IndependentStage, NamedStageOptions } from './base';\nimport { PipelineEngine } from '../engine';\nimport { mergeJobPermissions } from '../engines';\nimport { PipelineStep, SimpleCommandStep } from '../steps';\nimport { DownloadArtifactStep, UploadArtifactStep } from '../steps/artifact-steps';\nimport { GithubPackagesLoginStep } from '../steps/registries';\n\nconst DEFAULT_RUNNER_TAGS = ['ubuntu-latest'];\n\n\n/**\n * Extension of the base CDKPipeline options including specific configurations for GitHub.\n */\nexport interface GithubCDKPipelineOptions extends CDKPipelineOptions {\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   * whether to use GitHub environments for deployment stages\n   *\n   * INFO: When using environments consider protection rules instead of using the manual option of projen-pipelines for stages\n   *\n   * @default false\n   */\n  readonly useGithubEnvironments?: 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        preInstallSteps: [\n          new GithubPackagesLoginStep(app, { write: false }),\n          ...options.preInstallSteps ?? [],\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.baseOptions.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    steps.push(this.provideInstallStep());\n    steps.push(this.provideSynthStep());\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: mergeJobPermissions({\n        contents: JobPermission.READ,\n      }, ...(githubSteps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\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\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 DownloadArtifactStep(this.project, {\n        name: 'cloud-assembly',\n        path: `${this.app.cdkConfig.cdkout}/`,\n      }),\n      this.provideInstallStep(),\n      this.provideAssetUploadStep(),\n    ];\n\n    if (this.needsVersionedArtifacts) {\n      steps.push(this.provideAssemblyUploadStep());\n    }\n\n    const ghSteps = steps.map(s => s.toGithub());\n\n    this.deploymentWorkflow.addJob('assetUpload', {\n      name: 'Publish assets to AWS',\n      needs: ['synth', ...ghSteps.flatMap(s => s.needs)],\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n        ...ghSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      permissions: mergeJobPermissions({\n        idToken: JobPermission.WRITE,\n        contents: this.needsVersionedArtifacts ? JobPermission.WRITE : JobPermission.READ,\n        ...this.useGithubPackages && {\n          packages: JobPermission.WRITE,\n        },\n      }, ...(ghSteps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n      steps: [\n        {\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\n          with: {\n            'fetch-depth': 0,\n          },\n        },\n        ...ghSteps.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        this.provideInstallStep(),\n        new SimpleCommandStep(this.project, this.renderInstallPackageCommands(`${this.baseOptions.pkgNamespace}/${this.app.name}@\\${{github.event.inputs.version}}`)),\n        new SimpleCommandStep(this.project, [`mv ./node_modules/${this.baseOptions.pkgNamespace}/${this.app.name} ${this.app.cdkConfig.cdkout}`]),\n        this.provideDeployStep(stage),\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        ...this.options.useGithubEnvironments && {\n          environment: stage.name,\n        },\n        env: {\n          CI: 'true',\n          ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        },\n        permissions: mergeJobPermissions({\n          contents: JobPermission.READ,\n        }, ...(steps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v4',\n          },\n          ...steps.flatMap(s => s.steps),\n        ],\n      });\n\n    } else {\n      this.createDeployJob(this.deploymentWorkflow, [...(this.deploymentStages.length > 0 ? [`deploy-${this.deploymentStages.at(-1)!}`] : [])], stage);\n      this.deploymentStages.push(stage.name);\n    }\n  }\n\n  private createDeployJob(workflow: GithubWorkflow, jobDependencies: string[], stage: NamedStageOptions) {\n    const steps = [\n      new DownloadArtifactStep(this.project, {\n        name: 'cloud-assembly',\n        path: `${this.app.cdkConfig.cdkout}/`,\n      }),\n      this.provideInstallStep(),\n      this.provideDeployStep(stage),\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    workflow.addJob(`deploy-${stage.name}`, {\n      name: `Deploy stage ${stage.name} to AWS`,\n      ...this.options.useGithubEnvironments && {\n        environment: stage.name,\n      },\n      needs: ['assetUpload', ...steps.flatMap(s => s.needs), ...jobDependencies],\n      runsOn: this.options.runnerTags ?? DEFAULT_RUNNER_TAGS,\n      env: {\n        CI: 'true',\n        ...steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      permissions: mergeJobPermissions({\n        contents: JobPermission.READ,\n      }, ...(steps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n      steps: [\n        {\n          name: 'Checkout',\n          uses: 'actions/checkout@v4',\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 independent stage to create.\n   */\n  public createIndependentDeployment(stage: IndependentStage): void {\n    if (stage.deployOnPush || this.options.useGithubEnvironments) {\n      this.createDeployJob(this.deploymentWorkflow, [], stage);\n    } else {\n      const steps = [\n        this.provideInstallStep(),\n        this.provideSynthStep(),\n        this.provideDiffStep(stage),\n        this.provideDeployStep(stage),\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: mergeJobPermissions({\n          contents: JobPermission.READ,\n        }, ...(steps.flatMap(s => s.permissions).filter(p => p != undefined) as JobPermissions[])),\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v4',\n          },\n          ...steps.flatMap(s => s.steps),\n        ],\n      });\n\n    }\n  }\n}\n"]}
|
package/lib/awscdk/gitlab.d.ts
CHANGED
|
@@ -1,31 +1,6 @@
|
|
|
1
1
|
import { awscdk, gitlab } from 'projen';
|
|
2
2
|
import { CDKPipeline, CDKPipelineOptions, DeploymentStage, IndependentStage } from './base';
|
|
3
3
|
import { PipelineEngine } from '../engine';
|
|
4
|
-
/**
|
|
5
|
-
* Configuration for IAM roles used within the GitLab CI/CD pipeline for various stages.
|
|
6
|
-
* Allows specifying different IAM roles for synthesis, asset publishing, and deployment stages,
|
|
7
|
-
* providing granular control over permissions.
|
|
8
|
-
*/
|
|
9
|
-
export interface GitlabIamRoleConfig {
|
|
10
|
-
/** Default IAM role ARN used if specific stage role is not provided. */
|
|
11
|
-
readonly default?: string;
|
|
12
|
-
/** IAM role ARN for the synthesis stage. */
|
|
13
|
-
readonly synth?: string;
|
|
14
|
-
/** IAM role ARN for the asset publishing step. */
|
|
15
|
-
readonly assetPublishing?: string;
|
|
16
|
-
/** IAM role ARN for the asset publishing step for a specific stage. */
|
|
17
|
-
readonly assetPublishingPerStage?: {
|
|
18
|
-
[stage: string]: string;
|
|
19
|
-
};
|
|
20
|
-
/** A map of stage names to IAM role ARNs for the diff operation. */
|
|
21
|
-
readonly diff?: {
|
|
22
|
-
[stage: string]: string;
|
|
23
|
-
};
|
|
24
|
-
/** A map of stage names to IAM role ARNs for the deployment operation. */
|
|
25
|
-
readonly deployment?: {
|
|
26
|
-
[stage: string]: string;
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
4
|
/**
|
|
30
5
|
* Configuration for GitLab runner tags used within the CI/CD pipeline for various stages.
|
|
31
6
|
* This allows for specifying different runners based on the tags for different stages of the pipeline.
|
|
@@ -50,8 +25,6 @@ export interface GitlabRunnerTags {
|
|
|
50
25
|
* Options for configuring the GitLab CDK pipeline, extending the base CDK pipeline options.
|
|
51
26
|
*/
|
|
52
27
|
export interface GitlabCDKPipelineOptions extends CDKPipelineOptions {
|
|
53
|
-
/** IAM role ARNs configuration for the pipeline. */
|
|
54
|
-
readonly iamRoleArns: GitlabIamRoleConfig;
|
|
55
28
|
/** Runner tags configuration for the pipeline. */
|
|
56
29
|
readonly runnerTags?: GitlabRunnerTags;
|
|
57
30
|
/** The Docker image to use for running the pipeline jobs. */
|