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/gitlab.js
CHANGED
|
@@ -6,6 +6,8 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
|
6
6
|
const projen_1 = require("projen");
|
|
7
7
|
const base_1 = require("./base");
|
|
8
8
|
const engine_1 = require("../engine");
|
|
9
|
+
const steps_1 = require("../steps");
|
|
10
|
+
const aws_assume_role_step_1 = require("../steps/aws-assume-role.step");
|
|
9
11
|
/**
|
|
10
12
|
* The GitlabCDKPipeline class extends CDKPipeline to provide a way to configure and execute
|
|
11
13
|
* AWS CDK deployment pipelines within GitLab CI/CD environments. It integrates IAM role management,
|
|
@@ -37,6 +39,9 @@ class GitlabCDKPipeline extends base_1.CDKPipeline {
|
|
|
37
39
|
for (const stage of options.stages) {
|
|
38
40
|
this.createDeployment(stage);
|
|
39
41
|
}
|
|
42
|
+
for (const stage of (options.independentStages ?? [])) {
|
|
43
|
+
this.createIndependentDeployment(stage);
|
|
44
|
+
}
|
|
40
45
|
}
|
|
41
46
|
/**
|
|
42
47
|
* Sets up base job snippets for artifact handling and AWS configuration.
|
|
@@ -85,8 +90,9 @@ class GitlabCDKPipeline extends base_1.CDKPipeline {
|
|
|
85
90
|
|
|
86
91
|
awslogin() {
|
|
87
92
|
roleArn=\${1: -\${AWS_ROLE_ARN}}
|
|
93
|
+
sessionName=\${2:-GitLabRunner-\${CI_PROJECT_ID}-\${CI_PIPELINE_ID}}
|
|
88
94
|
check_variables_defined roleArn AWS_TOKEN
|
|
89
|
-
export $(printf "AWS_ACCESS_KEY_ID=%s AWS_SECRET_ACCESS_KEY=%s AWS_SESSION_TOKEN=%s" $(aws sts assume-role-with-web-identity --role-arn \${roleArn} --role-session-name "
|
|
95
|
+
export $(printf "AWS_ACCESS_KEY_ID=%s AWS_SECRET_ACCESS_KEY=%s AWS_SESSION_TOKEN=%s" $(aws sts assume-role-with-web-identity --role-arn \${roleArn} --role-session-name "\${sessionName}" --web-identity-token \${AWS_TOKEN} --duration-seconds 3600 --query 'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]' --output text))
|
|
90
96
|
# TODO CODE ARTIFACT
|
|
91
97
|
}
|
|
92
98
|
`,
|
|
@@ -101,39 +107,27 @@ awslogin() {
|
|
|
101
107
|
* configured to be cached as artifacts.
|
|
102
108
|
*/
|
|
103
109
|
createSynth() {
|
|
104
|
-
const
|
|
110
|
+
const steps = [];
|
|
105
111
|
if (this.options.iamRoleArns?.synth) {
|
|
106
|
-
|
|
112
|
+
steps.push(new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
|
|
113
|
+
roleArn: this.options.iamRoleArns.synth,
|
|
114
|
+
}));
|
|
107
115
|
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
script.push(...this.renderInstallCommands());
|
|
115
|
-
const preSynthSteps = (this.options.preSynthSteps ?? []).map(s => s.toGitlab());
|
|
116
|
-
script.push(...preSynthSteps.flatMap(s => s.commands));
|
|
117
|
-
extensions.push(...preSynthSteps.flatMap(s => s.extensions));
|
|
118
|
-
needs.push(...preSynthSteps.flatMap(s => s.needs));
|
|
119
|
-
script.push(...this.renderSynthCommands());
|
|
120
|
-
const postSynthSteps = (this.options.postSynthSteps ?? []).map(s => s.toGitlab());
|
|
121
|
-
script.push(...postSynthSteps.flatMap(s => s.commands));
|
|
122
|
-
extensions.push(...postSynthSteps.flatMap(s => s.extensions));
|
|
123
|
-
needs.push(...postSynthSteps.flatMap(s => s.needs));
|
|
116
|
+
steps.push(...this.options.preInstallSteps ?? []);
|
|
117
|
+
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()));
|
|
118
|
+
steps.push(...this.options.preSynthSteps ?? []);
|
|
119
|
+
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderSynthCommands()));
|
|
120
|
+
steps.push(...this.options.postSynthSteps ?? []);
|
|
121
|
+
const gitlabSteps = steps.map(s => s.toGitlab());
|
|
124
122
|
this.config.addStages('synth');
|
|
125
123
|
this.config.addJobs({
|
|
126
124
|
synth: {
|
|
127
|
-
extends: extensions,
|
|
128
|
-
needs: needs,
|
|
125
|
+
extends: ['.aws_base', '.artifacts_cdk', ...gitlabSteps.flatMap(s => s.extensions)],
|
|
126
|
+
needs: gitlabSteps.flatMap(s => s.needs),
|
|
129
127
|
stage: 'synth',
|
|
130
128
|
tags: this.options.runnerTags?.synth ?? this.options.runnerTags?.default,
|
|
131
|
-
script,
|
|
132
|
-
variables: {
|
|
133
|
-
...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
134
|
-
...preSynthSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
135
|
-
...postSynthSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
136
|
-
},
|
|
129
|
+
script: gitlabSteps.flatMap(s => s.commands),
|
|
130
|
+
variables: gitlabSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
137
131
|
},
|
|
138
132
|
});
|
|
139
133
|
}
|
|
@@ -144,25 +138,25 @@ awslogin() {
|
|
|
144
138
|
* of the 'synth' stage, ensuring assets are only published after successful synthesis.
|
|
145
139
|
*/
|
|
146
140
|
createAssetUpload() {
|
|
147
|
-
const
|
|
141
|
+
const steps = [];
|
|
148
142
|
if (this.options.iamRoleArns?.assetPublishing) {
|
|
149
|
-
|
|
143
|
+
steps.push(new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
|
|
144
|
+
roleArn: this.options.iamRoleArns.assetPublishing,
|
|
145
|
+
}));
|
|
150
146
|
}
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
147
|
+
steps.push(...this.options.preInstallSteps ?? []);
|
|
148
|
+
steps.push(new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()));
|
|
149
|
+
steps.push(new steps_1.SimpleCommandStep(this.project, this.getAssetUploadCommands(this.needsVersionedArtifacts)));
|
|
150
|
+
const gitlabSteps = steps.map(s => s.toGitlab());
|
|
155
151
|
this.config.addStages('publish_assets');
|
|
156
152
|
this.config.addJobs({
|
|
157
153
|
publish_assets: {
|
|
158
|
-
extends: ['.aws_base', ...
|
|
154
|
+
extends: ['.aws_base', ...gitlabSteps.flatMap(s => s.extensions)],
|
|
159
155
|
stage: 'publish_assets',
|
|
160
156
|
tags: this.options.runnerTags?.assetPublishing ?? this.options.runnerTags?.default,
|
|
161
|
-
needs: [{ job: 'synth', artifacts: true }, ...
|
|
162
|
-
script,
|
|
163
|
-
variables: {
|
|
164
|
-
...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
165
|
-
},
|
|
157
|
+
needs: [{ job: 'synth', artifacts: true }, ...gitlabSteps.flatMap(s => s.needs)],
|
|
158
|
+
script: gitlabSteps.flatMap(s => s.commands),
|
|
159
|
+
variables: gitlabSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
166
160
|
},
|
|
167
161
|
});
|
|
168
162
|
}
|
|
@@ -175,11 +169,28 @@ awslogin() {
|
|
|
175
169
|
* @param {DeploymentStage} stage - The deployment stage configuration to set up.
|
|
176
170
|
*/
|
|
177
171
|
createDeployment(stage) {
|
|
178
|
-
const
|
|
172
|
+
const diffSteps = [
|
|
173
|
+
new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
|
|
174
|
+
roleArn: this.options.iamRoleArns?.diff?.[stage.name]
|
|
175
|
+
?? this.options.iamRoleArns?.deployment?.[stage.name]
|
|
176
|
+
?? this.options.iamRoleArns?.default,
|
|
177
|
+
}),
|
|
178
|
+
...this.options.preInstallSteps ?? [],
|
|
179
|
+
new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
|
|
180
|
+
new steps_1.SimpleCommandStep(this.project, this.renderDiffCommands(stage.name)),
|
|
181
|
+
].map(s => s.toGitlab());
|
|
182
|
+
const deploySteps = [
|
|
183
|
+
new aws_assume_role_step_1.AwsAssumeRoleStep(this.project, {
|
|
184
|
+
roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default,
|
|
185
|
+
}),
|
|
186
|
+
...this.options.preInstallSteps ?? [],
|
|
187
|
+
new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
|
|
188
|
+
new steps_1.SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),
|
|
189
|
+
].map(s => s.toGitlab());
|
|
179
190
|
this.config.addStages(stage.name);
|
|
180
191
|
this.config.addJobs({
|
|
181
192
|
[`diff-${stage.name}`]: {
|
|
182
|
-
extends: ['.aws_base', ...
|
|
193
|
+
extends: ['.aws_base', ...diffSteps.flatMap(s => s.extensions)],
|
|
183
194
|
stage: stage.name,
|
|
184
195
|
tags: this.options.runnerTags?.diff?.[stage.name] ?? this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,
|
|
185
196
|
only: {
|
|
@@ -188,20 +199,13 @@ awslogin() {
|
|
|
188
199
|
needs: [
|
|
189
200
|
{ job: 'synth', artifacts: true },
|
|
190
201
|
{ job: 'publish_assets' },
|
|
191
|
-
...
|
|
192
|
-
],
|
|
193
|
-
script: [
|
|
194
|
-
`awslogin '${this.options.iamRoleArns?.diff?.[stage.name] ?? this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,
|
|
195
|
-
...preInstallSteps.flatMap(s => s.commands),
|
|
196
|
-
...this.renderInstallCommands(),
|
|
197
|
-
...this.renderDiffCommands(stage.name),
|
|
202
|
+
...diffSteps.flatMap(s => s.needs),
|
|
198
203
|
],
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
},
|
|
204
|
+
script: diffSteps.flatMap(s => s.commands),
|
|
205
|
+
variables: diffSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
202
206
|
},
|
|
203
207
|
[`deploy-${stage.name}`]: {
|
|
204
|
-
extends: ['.aws_base', '.artifacts_cdkdeploy', ...
|
|
208
|
+
extends: ['.aws_base', '.artifacts_cdkdeploy', ...deploySteps.flatMap(s => s.extensions)],
|
|
205
209
|
stage: stage.name,
|
|
206
210
|
tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,
|
|
207
211
|
...stage.manualApproval && {
|
|
@@ -214,26 +218,52 @@ awslogin() {
|
|
|
214
218
|
{ job: 'synth', artifacts: true },
|
|
215
219
|
{ job: 'publish_assets' },
|
|
216
220
|
{ job: `diff-${stage.name}` },
|
|
217
|
-
...
|
|
218
|
-
],
|
|
219
|
-
script: [
|
|
220
|
-
`awslogin '${this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,
|
|
221
|
-
...preInstallSteps.flatMap(s => s.commands),
|
|
222
|
-
...this.renderInstallCommands(),
|
|
223
|
-
...this.renderDeployCommands(stage.name),
|
|
221
|
+
...deploySteps.flatMap(s => s.needs),
|
|
224
222
|
],
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
},
|
|
223
|
+
script: deploySteps.flatMap(s => s.commands),
|
|
224
|
+
variables: deploySteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
228
225
|
},
|
|
229
226
|
});
|
|
230
227
|
this.deploymentStages.push(stage.name);
|
|
231
228
|
}
|
|
229
|
+
/**
|
|
230
|
+
* Creates a job to deploy the CDK application to AWS.
|
|
231
|
+
* @param stage - The independent stage to create.
|
|
232
|
+
*/
|
|
233
|
+
createIndependentDeployment(stage) {
|
|
234
|
+
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
|
+
...this.options.preInstallSteps ?? [],
|
|
240
|
+
new steps_1.SimpleCommandStep(this.project, this.renderInstallCommands()),
|
|
241
|
+
...this.options.preSynthSteps ?? [],
|
|
242
|
+
new steps_1.SimpleCommandStep(this.project, this.renderSynthCommands()),
|
|
243
|
+
...this.options.postSynthSteps ?? [],
|
|
244
|
+
new steps_1.SimpleCommandStep(this.project, this.renderDiffCommands(stage.name)),
|
|
245
|
+
...stage.postDiffSteps ?? [],
|
|
246
|
+
new steps_1.SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),
|
|
247
|
+
...stage.postDeploySteps ?? [],
|
|
248
|
+
].map(s => s.toGitlab());
|
|
249
|
+
this.config.addStages(stage.name);
|
|
250
|
+
this.config.addJobs({
|
|
251
|
+
[`deploy-${stage.name}`]: {
|
|
252
|
+
extends: ['.aws_base', '.artifacts_cdkdeploy', ...steps.flatMap(s => s.extensions)],
|
|
253
|
+
stage: stage.name,
|
|
254
|
+
tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,
|
|
255
|
+
when: projen_1.gitlab.JobWhen.MANUAL,
|
|
256
|
+
needs: steps.flatMap(s => s.needs),
|
|
257
|
+
script: steps.flatMap(s => s.commands),
|
|
258
|
+
variables: steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),
|
|
259
|
+
},
|
|
260
|
+
});
|
|
261
|
+
}
|
|
232
262
|
engineType() {
|
|
233
263
|
return engine_1.PipelineEngine.GITLAB;
|
|
234
264
|
}
|
|
235
265
|
}
|
|
236
266
|
exports.GitlabCDKPipeline = GitlabCDKPipeline;
|
|
237
267
|
_a = JSII_RTTI_SYMBOL_1;
|
|
238
|
-
GitlabCDKPipeline[_a] = { fqn: "projen-pipelines.GitlabCDKPipeline", version: "0.0.
|
|
239
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab.js","sourceRoot":"","sources":["../../src/awscdk/gitlab.ts"],"names":[],"mappings":"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","sourcesContent":["import { awscdk, gitlab } from 'projen';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage } from './base';\nimport { PipelineEngine } from '../engine';\n\n/**\n * Configuration for IAM roles used within the GitLab CI/CD pipeline for various stages.\n * Allows specifying different IAM roles for synthesis, asset publishing, and deployment stages,\n * providing granular control over permissions.\n */\nexport interface GitlabIamRoleConfig {\n  /** Default IAM role ARN used if specific stage role is not provided. */\n  readonly default?: string;\n  /** IAM role ARN for the synthesis stage. */\n  readonly synth?: string;\n  /** IAM role ARN for the asset publishing stage. */\n  readonly assetPublishing?: string;\n  /** A map of stage names to IAM role ARNs for the diff operation. */\n  readonly diff?: { [stage: string]: string };\n  /** A map of stage names to IAM role ARNs for the deployment operation. */\n  readonly deployment?: { [stage: string]: string };\n}\n\n/**\n * Configuration for GitLab runner tags used within the CI/CD pipeline for various stages.\n * This allows for specifying different runners based on the tags for different stages of the pipeline.\n */\nexport interface GitlabRunnerTags {\n  /** Default runner tags used if specific stage tags are not provided. */\n  readonly default?: string[];\n  /** Runner tags for the synthesis stage. */\n  readonly synth?: string[];\n  /** Runner tags for the asset publishing stage. */\n  readonly assetPublishing?: string[];\n  /** A map of stage names to runner tags for the diff operation. */\n  readonly diff?: { [stage: string]: string[] };\n  /** A map of stage names to runner tags for the deployment operation. */\n  readonly deployment?: { [stage: string]: string[] };\n}\n\n/**\n * Options for configuring the GitLab CDK pipeline, extending the base CDK pipeline options.\n */\nexport interface GitlabCDKPipelineOptions extends CDKPipelineOptions {\n  /** IAM role ARNs configuration for the pipeline. */\n  readonly iamRoleArns: GitlabIamRoleConfig;\n  /** Runner tags configuration for the pipeline. */\n  readonly runnerTags?: GitlabRunnerTags;\n  /** The Docker image to use for running the pipeline jobs. */\n  readonly image?: string;\n\n  // readonly publishedCloudAssemblies?: boolean;\n}\n\n/**\n * The GitlabCDKPipeline class extends CDKPipeline to provide a way to configure and execute\n * AWS CDK deployment pipelines within GitLab CI/CD environments. It integrates IAM role management,\n * runner configuration, and defines stages and jobs for the deployment workflow.\n */\nexport class GitlabCDKPipeline extends CDKPipeline {\n\n  /** Indicates if versioned artifacts are required. Currently set to false  */\n  public readonly needsVersionedArtifacts: boolean;\n\n  /** The Docker image used for pipeline jobs. Defaults to a specified image or a default value. */\n  public readonly jobImage: string;\n\n  /** GitLab CI/CD configuration object. */\n  public readonly config: gitlab.GitlabConfiguration;\n\n  /** List of deployment stages as strings. */\n  private deploymentStages: string[] = [];\n\n  /**\n   * Constructs an instance of GitlabCDKPipeline, initializing the GitLab CI/CD configuration\n   * and setting up the necessary stages and jobs for AWS CDK deployment.\n   *\n   * @param {awscdk.AwsCdkTypeScriptApp} app - The AWS CDK app associated with the pipeline.\n   * @param {GitlabCDKPipelineOptions} options - Configuration options for the pipeline.\n   */\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: GitlabCDKPipelineOptions) {\n    super(app, options);\n\n    // TODO use existing config if possible\n    this.config = new gitlab.GitlabConfiguration(app, {\n      stages: [],\n      jobs: {},\n    });\n\n    this.needsVersionedArtifacts = false; // options.publishedCloudAssemblies ?? false;\n    this.jobImage = options.image ?? 'image: jsii/superchain:1-buster-slim-node18';\n\n    this.setupSnippets();\n\n    this.createSynth();\n\n    this.createAssetUpload();\n\n    for (const stage of options.stages) {\n      this.createDeployment(stage);\n    }\n  }\n\n  /**\n   * Sets up base job snippets for artifact handling and AWS configuration.\n   * This method defines reusable job configurations to be extended by specific pipeline jobs,\n   * facilitating artifact caching and AWS authentication setup.\n   */\n  protected setupSnippets() {\n    this.config.addJobs({\n      '.artifacts_cdk': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Assembly - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk.out'],\n        },\n      },\n      '.artifacts_cdkdeploy': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Outputs - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk-outputs-*.json'],\n        },\n      },\n      '.aws_base': {\n        image: { name: this.jobImage },\n        idTokens: {\n          AWS_TOKEN: {\n            aud: 'https://sts.amazonaws.com',\n          },\n        },\n        variables: {\n          CI: 'true',\n          // NPM_REGISTRY: 'xxx'\n        },\n        beforeScript: [\n          `check_variables_defined() {\n  for var in \"$@\"; do\n    if [ -z \"$(eval \"echo \\\\$$var\")\" ]; then\n      log_fatal \"\\${var} not defined\";\n    fi\n  done\n}\n\nawslogin() {\n  roleArn=\\${1: -\\${AWS_ROLE_ARN}}\n  check_variables_defined roleArn AWS_TOKEN\n  export $(printf \"AWS_ACCESS_KEY_ID=%s AWS_SECRET_ACCESS_KEY=%s AWS_SESSION_TOKEN=%s\" $(aws sts assume-role-with-web-identity --role-arn \\${roleArn} --role-session-name \"GitLabRunner-\\${CI_PROJECT_ID}-\\${CI_PIPELINE_ID}\" --web-identity-token \\${AWS_TOKEN} --duration-seconds 3600 --query 'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]' --output text))\n  # TODO CODE ARTIFACT\n}\n`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Creates the 'synth' stage of the pipeline to synthesize AWS CDK applications.\n   * This method configures the job to execute CDK synthesis, applying the appropriate IAM role\n   * for AWS commands and specifying runner tags for job execution. The synthesized outputs are\n   * configured to be cached as artifacts.\n   */\n  protected createSynth(): void {\n    const script = ['echo \"Running CDK synth\"'];\n    if (this.options.iamRoleArns?.synth) {\n      script.push(`awslogin '${this.options.iamRoleArns.synth}'`);\n    }\n    const extensions = ['.aws_base', '.artifacts_cdk'];\n    const needs = [];\n\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());\n    script.push(...preInstallSteps.flatMap(s => s.commands));\n    extensions.push(...preInstallSteps.flatMap(s => s.extensions));\n    needs.push(...preInstallSteps.flatMap(s => s.needs));\n\n    script.push(...this.renderInstallCommands());\n\n    const preSynthSteps = (this.options.preSynthSteps ?? []).map(s => s.toGitlab());\n    script.push(...preSynthSteps.flatMap(s => s.commands));\n    extensions.push(...preSynthSteps.flatMap(s => s.extensions));\n    needs.push(...preSynthSteps.flatMap(s => s.needs));\n\n    script.push(...this.renderSynthCommands());\n\n    const postSynthSteps = (this.options.postSynthSteps ?? []).map(s => s.toGitlab());\n    script.push(...postSynthSteps.flatMap(s => s.commands));\n    extensions.push(...postSynthSteps.flatMap(s => s.extensions));\n    needs.push(...postSynthSteps.flatMap(s => s.needs));\n\n    this.config.addStages('synth');\n    this.config.addJobs({\n      synth: {\n        extends: extensions,\n        needs: needs,\n        stage: 'synth',\n        tags: this.options.runnerTags?.synth ?? this.options.runnerTags?.default,\n        script,\n        variables: {\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      },\n    });\n  }\n\n  /**\n   * Sets up the asset publishing stage of the pipeline.\n   * This method configures a job to upload synthesized assets to AWS, handling IAM role\n   * authentication and specifying runner tags. It depends on the successful completion\n   * of the 'synth' stage, ensuring assets are only published after successful synthesis.\n   */\n  protected createAssetUpload(): void {\n    const script = ['echo \"Publish assets to AWS\"'];\n    if (this.options.iamRoleArns?.assetPublishing) {\n      script.push(`awslogin '${this.options.iamRoleArns.assetPublishing}'`);\n    }\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());\n    script.push(...preInstallSteps.flatMap(s => s.commands));\n\n    script.push(...this.renderInstallCommands());\n    script.push(...this.getAssetUploadCommands(this.needsVersionedArtifacts));\n\n    this.config.addStages('publish_assets');\n    this.config.addJobs({\n      publish_assets: {\n        extends: ['.aws_base', ...preInstallSteps.flatMap(s => s.extensions)],\n        stage: 'publish_assets',\n        tags: this.options.runnerTags?.assetPublishing ?? this.options.runnerTags?.default,\n        needs: [{ job: 'synth', artifacts: true }, ...preInstallSteps.flatMap(s => s.needs)],\n        script,\n        variables: {\n          ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        },\n      },\n    });\n  }\n\n  /**\n   * Dynamically creates deployment stages based on the deployment configuration.\n   * For each provided deployment stage, this method sets up jobs for 'diff' and 'deploy' actions,\n   * applying the correct IAM roles and runner tags. It supports conditional manual approval for\n   * deployment stages, providing flexibility in the deployment workflow.\n   *\n   * @param {DeploymentStage} stage - The deployment stage configuration to set up.\n   */\n  protected createDeployment(stage: DeploymentStage): void {\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());\n\n    this.config.addStages(stage.name);\n    this.config.addJobs({\n      [`diff-${stage.name}`]: {\n        extends: ['.aws_base', ...preInstallSteps.flatMap(s => s.extensions)],\n        stage: stage.name,\n        tags: this.options.runnerTags?.diff?.[stage.name] ?? this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n          ...preInstallSteps.flatMap(s => s.needs),\n        ],\n        script: [\n          `awslogin '${this.options.iamRoleArns?.diff?.[stage.name] ?? this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,\n          ...preInstallSteps.flatMap(s => s.commands),\n          ...this.renderInstallCommands(),\n          ...this.renderDiffCommands(stage.name),\n        ],\n        variables: {\n          ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        },\n      },\n      [`deploy-${stage.name}`]: {\n        extends: ['.aws_base', '.artifacts_cdkdeploy', ...preInstallSteps.flatMap(s => s.extensions)],\n        stage: stage.name,\n        tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        ...stage.manualApproval && {\n          when: gitlab.JobWhen.MANUAL,\n        },\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n          { job: `diff-${stage.name}` },\n          ...preInstallSteps.flatMap(s => s.needs),\n        ],\n        script: [\n          `awslogin '${this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,\n          ...preInstallSteps.flatMap(s => s.commands),\n          ...this.renderInstallCommands(),\n          ...this.renderDeployCommands(stage.name),\n        ],\n        variables: {\n          ...preInstallSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n        },\n      },\n    });\n    this.deploymentStages.push(stage.name);\n  }\n\n  public engineType(): PipelineEngine {\n    return PipelineEngine.GITLAB;\n  }\n\n}\n\n"]}
|
|
268
|
+
GitlabCDKPipeline[_a] = { fqn: "projen-pipelines.GitlabCDKPipeline", version: "0.0.64" };
|
|
269
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab.js","sourceRoot":"","sources":["../../src/awscdk/gitlab.ts"],"names":[],"mappings":"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","sourcesContent":["import { awscdk, gitlab } from 'projen';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage, IndependentStage } from './base';\nimport { PipelineEngine } from '../engine';\nimport { PipelineStep, SimpleCommandStep } from '../steps';\nimport { AwsAssumeRoleStep } from '../steps/aws-assume-role.step';\n\n/**\n * Configuration for IAM roles used within the GitLab CI/CD pipeline for various stages.\n * Allows specifying different IAM roles for synthesis, asset publishing, and deployment stages,\n * providing granular control over permissions.\n */\nexport interface GitlabIamRoleConfig {\n  /** Default IAM role ARN used if specific stage role is not provided. */\n  readonly default?: string;\n  /** IAM role ARN for the synthesis stage. */\n  readonly synth?: string;\n  /** IAM role ARN for the asset publishing stage. */\n  readonly assetPublishing?: string;\n  /** A map of stage names to IAM role ARNs for the diff operation. */\n  readonly diff?: { [stage: string]: string };\n  /** A map of stage names to IAM role ARNs for the deployment operation. */\n  readonly deployment?: { [stage: string]: string };\n}\n\n/**\n * Configuration for GitLab runner tags used within the CI/CD pipeline for various stages.\n * This allows for specifying different runners based on the tags for different stages of the pipeline.\n */\nexport interface GitlabRunnerTags {\n  /** Default runner tags used if specific stage tags are not provided. */\n  readonly default?: string[];\n  /** Runner tags for the synthesis stage. */\n  readonly synth?: string[];\n  /** Runner tags for the asset publishing stage. */\n  readonly assetPublishing?: string[];\n  /** A map of stage names to runner tags for the diff operation. */\n  readonly diff?: { [stage: string]: string[] };\n  /** A map of stage names to runner tags for the deployment operation. */\n  readonly deployment?: { [stage: string]: string[] };\n}\n\n/**\n * Options for configuring the GitLab CDK pipeline, extending the base CDK pipeline options.\n */\nexport interface GitlabCDKPipelineOptions extends CDKPipelineOptions {\n  /** IAM role ARNs configuration for the pipeline. */\n  readonly iamRoleArns: GitlabIamRoleConfig;\n  /** Runner tags configuration for the pipeline. */\n  readonly runnerTags?: GitlabRunnerTags;\n  /** The Docker image to use for running the pipeline jobs. */\n  readonly image?: string;\n\n  // readonly publishedCloudAssemblies?: boolean;\n}\n\n/**\n * The GitlabCDKPipeline class extends CDKPipeline to provide a way to configure and execute\n * AWS CDK deployment pipelines within GitLab CI/CD environments. It integrates IAM role management,\n * runner configuration, and defines stages and jobs for the deployment workflow.\n */\nexport class GitlabCDKPipeline extends CDKPipeline {\n\n  /** Indicates if versioned artifacts are required. Currently set to false  */\n  public readonly needsVersionedArtifacts: boolean;\n\n  /** The Docker image used for pipeline jobs. Defaults to a specified image or a default value. */\n  public readonly jobImage: string;\n\n  /** GitLab CI/CD configuration object. */\n  public readonly config: gitlab.GitlabConfiguration;\n\n  /** List of deployment stages as strings. */\n  private deploymentStages: string[] = [];\n\n  /**\n   * Constructs an instance of GitlabCDKPipeline, initializing the GitLab CI/CD configuration\n   * and setting up the necessary stages and jobs for AWS CDK deployment.\n   *\n   * @param {awscdk.AwsCdkTypeScriptApp} app - The AWS CDK app associated with the pipeline.\n   * @param {GitlabCDKPipelineOptions} options - Configuration options for the pipeline.\n   */\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: GitlabCDKPipelineOptions) {\n    super(app, options);\n\n    // TODO use existing config if possible\n    this.config = new gitlab.GitlabConfiguration(app, {\n      stages: [],\n      jobs: {},\n    });\n\n    this.needsVersionedArtifacts = false; // options.publishedCloudAssemblies ?? false;\n    this.jobImage = options.image ?? 'image: jsii/superchain:1-buster-slim-node18';\n\n    this.setupSnippets();\n\n    this.createSynth();\n\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\n  /**\n   * Sets up base job snippets for artifact handling and AWS configuration.\n   * This method defines reusable job configurations to be extended by specific pipeline jobs,\n   * facilitating artifact caching and AWS authentication setup.\n   */\n  protected setupSnippets() {\n    this.config.addJobs({\n      '.artifacts_cdk': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Assembly - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk.out'],\n        },\n      },\n      '.artifacts_cdkdeploy': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Outputs - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk-outputs-*.json'],\n        },\n      },\n      '.aws_base': {\n        image: { name: this.jobImage },\n        idTokens: {\n          AWS_TOKEN: {\n            aud: 'https://sts.amazonaws.com',\n          },\n        },\n        variables: {\n          CI: 'true',\n          // NPM_REGISTRY: 'xxx'\n        },\n        beforeScript: [\n          `check_variables_defined() {\n  for var in \"$@\"; do\n    if [ -z \"$(eval \"echo \\\\$$var\")\" ]; then\n      log_fatal \"\\${var} not defined\";\n    fi\n  done\n}\n\nawslogin() {\n  roleArn=\\${1: -\\${AWS_ROLE_ARN}}\n  sessionName=\\${2:-GitLabRunner-\\${CI_PROJECT_ID}-\\${CI_PIPELINE_ID}}\n  check_variables_defined roleArn AWS_TOKEN\n  export $(printf \"AWS_ACCESS_KEY_ID=%s AWS_SECRET_ACCESS_KEY=%s AWS_SESSION_TOKEN=%s\" $(aws sts assume-role-with-web-identity --role-arn \\${roleArn} --role-session-name \"\\${sessionName}\" --web-identity-token \\${AWS_TOKEN} --duration-seconds 3600 --query 'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]' --output text))\n  # TODO CODE ARTIFACT\n}\n`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Creates the 'synth' stage of the pipeline to synthesize AWS CDK applications.\n   * This method configures the job to execute CDK synthesis, applying the appropriate IAM role\n   * for AWS commands and specifying runner tags for job execution. The synthesized outputs are\n   * configured to be cached as artifacts.\n   */\n  protected 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      }));\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    const gitlabSteps = steps.map(s => s.toGitlab());\n\n    this.config.addStages('synth');\n    this.config.addJobs({\n      synth: {\n        extends: ['.aws_base', '.artifacts_cdk', ...gitlabSteps.flatMap(s => s.extensions)],\n        needs: gitlabSteps.flatMap(s => s.needs),\n        stage: 'synth',\n        tags: this.options.runnerTags?.synth ?? this.options.runnerTags?.default,\n        script: gitlabSteps.flatMap(s => s.commands),\n        variables: gitlabSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n    });\n  }\n\n  /**\n   * Sets up the asset publishing stage of the pipeline.\n   * This method configures a job to upload synthesized assets to AWS, handling IAM role\n   * authentication and specifying runner tags. It depends on the successful completion\n   * of the 'synth' stage, ensuring assets are only published after successful synthesis.\n   */\n  protected createAssetUpload(): void {\n    const steps = [];\n\n    if (this.options.iamRoleArns?.assetPublishing) {\n      steps.push(new AwsAssumeRoleStep(this.project, {\n        roleArn: this.options.iamRoleArns.assetPublishing,\n      }));\n    }\n    steps.push(...this.options.preInstallSteps ?? []);\n    steps.push(new SimpleCommandStep(this.project, this.renderInstallCommands()));\n    steps.push(new SimpleCommandStep(this.project, this.getAssetUploadCommands(this.needsVersionedArtifacts)));\n\n    const gitlabSteps = steps.map(s => s.toGitlab());\n\n    this.config.addStages('publish_assets');\n    this.config.addJobs({\n      publish_assets: {\n        extends: ['.aws_base', ...gitlabSteps.flatMap(s => s.extensions)],\n        stage: 'publish_assets',\n        tags: this.options.runnerTags?.assetPublishing ?? this.options.runnerTags?.default,\n        needs: [{ job: 'synth', artifacts: true }, ...gitlabSteps.flatMap(s => s.needs)],\n        script: gitlabSteps.flatMap(s => s.commands),\n        variables: gitlabSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n    });\n  }\n\n  /**\n   * Dynamically creates deployment stages based on the deployment configuration.\n   * For each provided deployment stage, this method sets up jobs for 'diff' and 'deploy' actions,\n   * applying the correct IAM roles and runner tags. It supports conditional manual approval for\n   * deployment stages, providing flexibility in the deployment workflow.\n   *\n   * @param {DeploymentStage} stage - The deployment stage configuration to set up.\n   */\n  protected createDeployment(stage: DeploymentStage): void {\n    const diffSteps = [\n      new AwsAssumeRoleStep(this.project, {\n        roleArn: this.options.iamRoleArns?.diff?.[stage.name]\n          ?? this.options.iamRoleArns?.deployment?.[stage.name]\n          ?? this.options.iamRoleArns?.default!,\n      }),\n      ...this.options.preInstallSteps ?? [],\n      new SimpleCommandStep(this.project, this.renderInstallCommands()),\n      new SimpleCommandStep(this.project, this.renderDiffCommands(stage.name)),\n    ].map(s => s.toGitlab());\n\n\n    const deploySteps = [\n      new AwsAssumeRoleStep(this.project, {\n        roleArn: this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default!,\n      }),\n      ...this.options.preInstallSteps ?? [],\n      new SimpleCommandStep(this.project, this.renderInstallCommands()),\n      new SimpleCommandStep(this.project, this.renderDeployCommands(stage.name)),\n    ].map(s => s.toGitlab());\n\n    this.config.addStages(stage.name);\n    this.config.addJobs({\n      [`diff-${stage.name}`]: {\n        extends: ['.aws_base', ...diffSteps.flatMap(s => s.extensions)],\n        stage: stage.name,\n        tags: this.options.runnerTags?.diff?.[stage.name] ?? this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n          ...diffSteps.flatMap(s => s.needs),\n        ],\n        script: diffSteps.flatMap(s => s.commands),\n        variables: diffSteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n      [`deploy-${stage.name}`]: {\n        extends: ['.aws_base', '.artifacts_cdkdeploy', ...deploySteps.flatMap(s => s.extensions)],\n        stage: stage.name,\n        tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        ...stage.manualApproval && {\n          when: gitlab.JobWhen.MANUAL,\n        },\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n          { job: `diff-${stage.name}` },\n          ...deploySteps.flatMap(s => s.needs),\n        ],\n        script: deploySteps.flatMap(s => s.commands),\n        variables: deploySteps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\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    ].map(s => s.toGitlab());\n\n    this.config.addStages(stage.name);\n    this.config.addJobs({\n      [`deploy-${stage.name}`]: {\n        extends: ['.aws_base', '.artifacts_cdkdeploy', ...steps.flatMap(s => s.extensions)],\n        stage: stage.name,\n        tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        when: gitlab.JobWhen.MANUAL,\n        needs: steps.flatMap(s => s.needs),\n        script: steps.flatMap(s => s.commands),\n        variables: steps.reduce((acc, step) => ({ ...acc, ...step.env }), {}),\n      },\n    });\n\n  }\n\n  public engineType(): PipelineEngine {\n    return PipelineEngine.GITLAB;\n  }\n\n}\n\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Project } from 'projen';
|
|
2
|
+
import { GithubStepConfig, GitlabStepConfig, PipelineStep } from './step';
|
|
3
|
+
export interface DownloadArtifactStepConfig {
|
|
4
|
+
readonly name: string;
|
|
5
|
+
readonly path: string;
|
|
6
|
+
}
|
|
7
|
+
export declare class DownloadArtifactStep extends PipelineStep {
|
|
8
|
+
private readonly config;
|
|
9
|
+
constructor(project: Project, config: DownloadArtifactStepConfig);
|
|
10
|
+
toGitlab(): GitlabStepConfig;
|
|
11
|
+
toGithub(): GithubStepConfig;
|
|
12
|
+
}
|
|
13
|
+
export interface UploadArtifactStepConfig {
|
|
14
|
+
readonly name: string;
|
|
15
|
+
readonly path: string;
|
|
16
|
+
}
|
|
17
|
+
export declare class UploadArtifactStep extends PipelineStep {
|
|
18
|
+
private readonly config;
|
|
19
|
+
constructor(project: Project, config: UploadArtifactStepConfig);
|
|
20
|
+
toGithub(): GithubStepConfig;
|
|
21
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UploadArtifactStep = exports.DownloadArtifactStep = void 0;
|
|
4
|
+
const step_1 = require("./step");
|
|
5
|
+
class DownloadArtifactStep extends step_1.PipelineStep {
|
|
6
|
+
constructor(project, config) {
|
|
7
|
+
super(project);
|
|
8
|
+
this.config = config;
|
|
9
|
+
}
|
|
10
|
+
toGitlab() {
|
|
11
|
+
// Nothing to do; artifact is already downloaded for you
|
|
12
|
+
return {
|
|
13
|
+
env: {},
|
|
14
|
+
extensions: [],
|
|
15
|
+
needs: [],
|
|
16
|
+
commands: [],
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
toGithub() {
|
|
20
|
+
return {
|
|
21
|
+
steps: [{
|
|
22
|
+
name: 'Download Artifact',
|
|
23
|
+
uses: 'actions/download-artifact@v4',
|
|
24
|
+
with: {
|
|
25
|
+
name: this.config.name,
|
|
26
|
+
path: this.config.path,
|
|
27
|
+
},
|
|
28
|
+
}],
|
|
29
|
+
needs: [],
|
|
30
|
+
env: {},
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.DownloadArtifactStep = DownloadArtifactStep;
|
|
35
|
+
class UploadArtifactStep extends step_1.PipelineStep {
|
|
36
|
+
constructor(project, config) {
|
|
37
|
+
super(project);
|
|
38
|
+
this.config = config;
|
|
39
|
+
}
|
|
40
|
+
toGithub() {
|
|
41
|
+
return {
|
|
42
|
+
steps: [{
|
|
43
|
+
name: 'Upload Artifact',
|
|
44
|
+
uses: 'actions/upload-artifact@v4',
|
|
45
|
+
with: {
|
|
46
|
+
name: this.config.name,
|
|
47
|
+
path: this.config.path,
|
|
48
|
+
},
|
|
49
|
+
}],
|
|
50
|
+
needs: [],
|
|
51
|
+
env: {},
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
exports.UploadArtifactStep = UploadArtifactStep;
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3Qtc3RlcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvYXJ0aWZhY3Qtc3RlcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsaUNBQTBFO0FBTzFFLE1BQWEsb0JBQXFCLFNBQVEsbUJBQVk7SUFFcEQsWUFBWSxPQUFnQixFQUFtQixNQUFrQztRQUMvRSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFEOEIsV0FBTSxHQUFOLE1BQU0sQ0FBNEI7SUFFakYsQ0FBQztJQUVNLFFBQVE7UUFDYix3REFBd0Q7UUFDeEQsT0FBTztZQUNMLEdBQUcsRUFBRSxFQUFFO1lBQ1AsVUFBVSxFQUFFLEVBQUU7WUFDZCxLQUFLLEVBQUUsRUFBRTtZQUNULFFBQVEsRUFBRSxFQUFFO1NBQ2IsQ0FBQztJQUNKLENBQUM7SUFDTSxRQUFRO1FBQ2IsT0FBTztZQUNMLEtBQUssRUFBRSxDQUFDO29CQUNOLElBQUksRUFBRSxtQkFBbUI7b0JBQ3pCLElBQUksRUFBRSw4QkFBOEI7b0JBQ3BDLElBQUksRUFBRTt3QkFDSixJQUFJLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJO3dCQUN0QixJQUFJLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJO3FCQUN2QjtpQkFDRixDQUFDO1lBQ0YsS0FBSyxFQUFFLEVBQUU7WUFDVCxHQUFHLEVBQUUsRUFBRTtTQUNSLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUE3QkQsb0RBNkJDO0FBUUQsTUFBYSxrQkFBbUIsU0FBUSxtQkFBWTtJQUVsRCxZQUFZLE9BQWdCLEVBQW1CLE1BQWdDO1FBQzdFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUQ4QixXQUFNLEdBQU4sTUFBTSxDQUEwQjtJQUUvRSxDQUFDO0lBRU0sUUFBUTtRQUNiLE9BQU87WUFDTCxLQUFLLEVBQUUsQ0FBQztvQkFDTixJQUFJLEVBQUUsaUJBQWlCO29CQUN2QixJQUFJLEVBQUUsNEJBQTRCO29CQUNsQyxJQUFJLEVBQUU7d0JBQ0osSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSTt3QkFDdEIsSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSTtxQkFDdkI7aUJBQ0YsQ0FBQztZQUNGLEtBQUssRUFBRSxFQUFFO1lBQ1QsR0FBRyxFQUFFLEVBQUU7U0FDUixDQUFDO0lBQ0osQ0FBQztDQUVGO0FBckJELGdEQXFCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2plY3QgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgR2l0aHViU3RlcENvbmZpZywgR2l0bGFiU3RlcENvbmZpZywgUGlwZWxpbmVTdGVwIH0gZnJvbSAnLi9zdGVwJztcblxuZXhwb3J0IGludGVyZmFjZSBEb3dubG9hZEFydGlmYWN0U3RlcENvbmZpZyB7XG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgcGF0aDogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgRG93bmxvYWRBcnRpZmFjdFN0ZXAgZXh0ZW5kcyBQaXBlbGluZVN0ZXAge1xuXG4gIGNvbnN0cnVjdG9yKHByb2plY3Q6IFByb2plY3QsIHByaXZhdGUgcmVhZG9ubHkgY29uZmlnOiBEb3dubG9hZEFydGlmYWN0U3RlcENvbmZpZykge1xuICAgIHN1cGVyKHByb2plY3QpO1xuICB9XG5cbiAgcHVibGljIHRvR2l0bGFiKCk6IEdpdGxhYlN0ZXBDb25maWcge1xuICAgIC8vIE5vdGhpbmcgdG8gZG87IGFydGlmYWN0IGlzIGFscmVhZHkgZG93bmxvYWRlZCBmb3IgeW91XG4gICAgcmV0dXJuIHtcbiAgICAgIGVudjoge30sXG4gICAgICBleHRlbnNpb25zOiBbXSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICAgIGNvbW1hbmRzOiBbXSxcbiAgICB9O1xuICB9XG4gIHB1YmxpYyB0b0dpdGh1YigpOiBHaXRodWJTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgc3RlcHM6IFt7XG4gICAgICAgIG5hbWU6ICdEb3dubG9hZCBBcnRpZmFjdCcsXG4gICAgICAgIHVzZXM6ICdhY3Rpb25zL2Rvd25sb2FkLWFydGlmYWN0QHY0JyxcbiAgICAgICAgd2l0aDoge1xuICAgICAgICAgIG5hbWU6IHRoaXMuY29uZmlnLm5hbWUsXG4gICAgICAgICAgcGF0aDogdGhpcy5jb25maWcucGF0aCxcbiAgICAgICAgfSxcbiAgICAgIH1dLFxuICAgICAgbmVlZHM6IFtdLFxuICAgICAgZW52OiB7fSxcbiAgICB9O1xuICB9XG59XG5cblxuZXhwb3J0IGludGVyZmFjZSBVcGxvYWRBcnRpZmFjdFN0ZXBDb25maWcge1xuICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBhdGg6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIFVwbG9hZEFydGlmYWN0U3RlcCBleHRlbmRzIFBpcGVsaW5lU3RlcCB7XG5cbiAgY29uc3RydWN0b3IocHJvamVjdDogUHJvamVjdCwgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IFVwbG9hZEFydGlmYWN0U3RlcENvbmZpZykge1xuICAgIHN1cGVyKHByb2plY3QpO1xuICB9XG5cbiAgcHVibGljIHRvR2l0aHViKCk6IEdpdGh1YlN0ZXBDb25maWcge1xuICAgIHJldHVybiB7XG4gICAgICBzdGVwczogW3tcbiAgICAgICAgbmFtZTogJ1VwbG9hZCBBcnRpZmFjdCcsXG4gICAgICAgIHVzZXM6ICdhY3Rpb25zL3VwbG9hZC1hcnRpZmFjdEB2NCcsXG4gICAgICAgIHdpdGg6IHtcbiAgICAgICAgICBuYW1lOiB0aGlzLmNvbmZpZy5uYW1lLFxuICAgICAgICAgIHBhdGg6IHRoaXMuY29uZmlnLnBhdGgsXG4gICAgICAgIH0sXG4gICAgICB9XSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICAgIGVudjoge30sXG4gICAgfTtcbiAgfVxuXG59Il19
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Project } from 'projen';
|
|
2
|
+
import { GithubStepConfig, GitlabStepConfig, PipelineStep } from './step';
|
|
3
|
+
/**
|
|
4
|
+
* Configuration for an AWS AssumeRoleStep
|
|
5
|
+
*/
|
|
6
|
+
export interface AwsAssumeRoleStepConfig {
|
|
7
|
+
/** The ARN of the role to assume */
|
|
8
|
+
readonly roleArn: string;
|
|
9
|
+
/** An identifier for the assumed role session */
|
|
10
|
+
readonly sessionName?: string;
|
|
11
|
+
/** The AWS region that should be set */
|
|
12
|
+
readonly region?: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* A step that assumes a role in AWS
|
|
16
|
+
*/
|
|
17
|
+
export declare class AwsAssumeRoleStep extends PipelineStep {
|
|
18
|
+
private readonly config;
|
|
19
|
+
constructor(project: Project, config: AwsAssumeRoleStepConfig);
|
|
20
|
+
toGitlab(): GitlabStepConfig;
|
|
21
|
+
toGithub(): GithubStepConfig;
|
|
22
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AwsAssumeRoleStep = void 0;
|
|
4
|
+
const step_1 = require("./step");
|
|
5
|
+
/**
|
|
6
|
+
* A step that assumes a role in AWS
|
|
7
|
+
*/
|
|
8
|
+
class AwsAssumeRoleStep extends step_1.PipelineStep {
|
|
9
|
+
constructor(project, config) {
|
|
10
|
+
super(project);
|
|
11
|
+
this.config = config;
|
|
12
|
+
}
|
|
13
|
+
toGitlab() {
|
|
14
|
+
return {
|
|
15
|
+
env: {
|
|
16
|
+
...this.config.region ? { AWS_REGION: this.config.region } : {},
|
|
17
|
+
},
|
|
18
|
+
commands: [
|
|
19
|
+
`awslogin ${this.config.roleArn} ${this.config.sessionName ?? ''}`,
|
|
20
|
+
],
|
|
21
|
+
extensions: [],
|
|
22
|
+
needs: [],
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
toGithub() {
|
|
26
|
+
return {
|
|
27
|
+
steps: [{
|
|
28
|
+
name: 'AWS Credentials',
|
|
29
|
+
uses: 'aws-actions/configure-aws-credentials@v4',
|
|
30
|
+
with: {
|
|
31
|
+
'role-to-assume': this.config.roleArn,
|
|
32
|
+
'role-session-name': this.config.sessionName ?? 'GitHubAction',
|
|
33
|
+
...this.config.region ? { 'aws-region': this.config.region } : { 'aws-region': 'us-east-1' },
|
|
34
|
+
},
|
|
35
|
+
}],
|
|
36
|
+
needs: [],
|
|
37
|
+
env: {},
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.AwsAssumeRoleStep = AwsAssumeRoleStep;
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWFzc3VtZS1yb2xlLnN0ZXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvYXdzLWFzc3VtZS1yb2xlLnN0ZXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsaUNBQTBFO0FBZTFFOztHQUVHO0FBQ0gsTUFBYSxpQkFBa0IsU0FBUSxtQkFBWTtJQUVqRCxZQUFZLE9BQWdCLEVBQW1CLE1BQStCO1FBQzVFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUQ4QixXQUFNLEdBQU4sTUFBTSxDQUF5QjtJQUU5RSxDQUFDO0lBRU0sUUFBUTtRQUNiLE9BQU87WUFDTCxHQUFHLEVBQUU7Z0JBQ0gsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRTthQUNoRTtZQUNELFFBQVEsRUFBRTtnQkFDUixZQUFZLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxJQUFJLEVBQUUsRUFBRTthQUNuRTtZQUNELFVBQVUsRUFBRSxFQUFFO1lBQ2QsS0FBSyxFQUFFLEVBQUU7U0FDVixDQUFDO0lBQ0osQ0FBQztJQUVNLFFBQVE7UUFDYixPQUFPO1lBQ0wsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLGlCQUFpQjtvQkFDdkIsSUFBSSxFQUFFLDBDQUEwQztvQkFDaEQsSUFBSSxFQUFFO3dCQUNKLGdCQUFnQixFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTzt3QkFDckMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLElBQUksY0FBYzt3QkFDOUQsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFO3FCQUM3RjtpQkFDRixDQUFDO1lBQ0YsS0FBSyxFQUFFLEVBQUU7WUFDVCxHQUFHLEVBQUUsRUFBRTtTQUNSLENBQUM7SUFDSixDQUFDO0NBRUY7QUFuQ0QsOENBbUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvamVjdCB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgeyBHaXRodWJTdGVwQ29uZmlnLCBHaXRsYWJTdGVwQ29uZmlnLCBQaXBlbGluZVN0ZXAgfSBmcm9tICcuL3N0ZXAnO1xuXG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgYW4gQVdTIEFzc3VtZVJvbGVTdGVwXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXdzQXNzdW1lUm9sZVN0ZXBDb25maWcge1xuICAvKiogVGhlIEFSTiBvZiB0aGUgcm9sZSB0byBhc3N1bWUgKi9cbiAgcmVhZG9ubHkgcm9sZUFybjogc3RyaW5nO1xuICAvKiogQW4gaWRlbnRpZmllciBmb3IgdGhlIGFzc3VtZWQgcm9sZSBzZXNzaW9uICovXG4gIHJlYWRvbmx5IHNlc3Npb25OYW1lPzogc3RyaW5nO1xuICAvKiogVGhlIEFXUyByZWdpb24gdGhhdCBzaG91bGQgYmUgc2V0ICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIHN0ZXAgdGhhdCBhc3N1bWVzIGEgcm9sZSBpbiBBV1NcbiAqL1xuZXhwb3J0IGNsYXNzIEF3c0Fzc3VtZVJvbGVTdGVwIGV4dGVuZHMgUGlwZWxpbmVTdGVwIHtcblxuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBQcm9qZWN0LCBwcml2YXRlIHJlYWRvbmx5IGNvbmZpZzogQXdzQXNzdW1lUm9sZVN0ZXBDb25maWcpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcbiAgfVxuXG4gIHB1YmxpYyB0b0dpdGxhYigpOiBHaXRsYWJTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgZW52OiB7XG4gICAgICAgIC4uLnRoaXMuY29uZmlnLnJlZ2lvbiA/IHsgQVdTX1JFR0lPTjogdGhpcy5jb25maWcucmVnaW9uIH0gOiB7fSxcbiAgICAgIH0sXG4gICAgICBjb21tYW5kczogW1xuICAgICAgICBgYXdzbG9naW4gJHt0aGlzLmNvbmZpZy5yb2xlQXJufSAke3RoaXMuY29uZmlnLnNlc3Npb25OYW1lID8/ICcnfWAsXG4gICAgICBdLFxuICAgICAgZXh0ZW5zaW9uczogW10sXG4gICAgICBuZWVkczogW10sXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyB0b0dpdGh1YigpOiBHaXRodWJTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgc3RlcHM6IFt7XG4gICAgICAgIG5hbWU6ICdBV1MgQ3JlZGVudGlhbHMnLFxuICAgICAgICB1c2VzOiAnYXdzLWFjdGlvbnMvY29uZmlndXJlLWF3cy1jcmVkZW50aWFsc0B2NCcsXG4gICAgICAgIHdpdGg6IHtcbiAgICAgICAgICAncm9sZS10by1hc3N1bWUnOiB0aGlzLmNvbmZpZy5yb2xlQXJuLFxuICAgICAgICAgICdyb2xlLXNlc3Npb24tbmFtZSc6IHRoaXMuY29uZmlnLnNlc3Npb25OYW1lID8/ICdHaXRIdWJBY3Rpb24nLFxuICAgICAgICAgIC4uLnRoaXMuY29uZmlnLnJlZ2lvbiA/IHsgJ2F3cy1yZWdpb24nOiB0aGlzLmNvbmZpZy5yZWdpb24gfSA6IHsgJ2F3cy1yZWdpb24nOiAndXMtZWFzdC0xJyB9LFxuICAgICAgICB9LFxuICAgICAgfV0sXG4gICAgICBuZWVkczogW10sXG4gICAgICBlbnY6IHt9LFxuICAgIH07XG4gIH1cblxufSJdfQ==
|
package/lib/steps/step.d.ts
CHANGED
|
@@ -47,17 +47,17 @@ export declare abstract class PipelineStep {
|
|
|
47
47
|
*/
|
|
48
48
|
constructor(project: Project);
|
|
49
49
|
/**
|
|
50
|
-
* Generates a configuration for a GitLab CI step.
|
|
50
|
+
* Generates a configuration for a GitLab CI step. Should be implemented by subclasses.
|
|
51
51
|
*/
|
|
52
|
-
|
|
52
|
+
toGitlab(): GitlabStepConfig;
|
|
53
53
|
/**
|
|
54
|
-
* Generates a configuration for a GitHub Actions step.
|
|
54
|
+
* Generates a configuration for a GitHub Actions step. Should be implemented by subclasses.
|
|
55
55
|
*/
|
|
56
|
-
|
|
56
|
+
toGithub(): GithubStepConfig;
|
|
57
57
|
/**
|
|
58
|
-
* Generates a configuration for a bash script step.
|
|
58
|
+
* Generates a configuration for a bash script step. Should be implemented by subclasses.
|
|
59
59
|
*/
|
|
60
|
-
|
|
60
|
+
toBash(): BashStepConfig;
|
|
61
61
|
}
|
|
62
62
|
/**
|
|
63
63
|
* Concrete implementation of PipelineStep that executes simple commands.
|
package/lib/steps/step.js
CHANGED
|
@@ -15,10 +15,28 @@ class PipelineStep {
|
|
|
15
15
|
this.project = project;
|
|
16
16
|
// Constructor can be extended to include more setup logic.
|
|
17
17
|
}
|
|
18
|
+
/**
|
|
19
|
+
* Generates a configuration for a GitLab CI step. Should be implemented by subclasses.
|
|
20
|
+
*/
|
|
21
|
+
toGitlab() {
|
|
22
|
+
throw new Error('Method not implemented.');
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Generates a configuration for a GitHub Actions step. Should be implemented by subclasses.
|
|
26
|
+
*/
|
|
27
|
+
toGithub() {
|
|
28
|
+
throw new Error('Method not implemented.');
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Generates a configuration for a bash script step. Should be implemented by subclasses.
|
|
32
|
+
*/
|
|
33
|
+
toBash() {
|
|
34
|
+
throw new Error('Method not implemented.');
|
|
35
|
+
}
|
|
18
36
|
}
|
|
19
37
|
exports.PipelineStep = PipelineStep;
|
|
20
38
|
_a = JSII_RTTI_SYMBOL_1;
|
|
21
|
-
PipelineStep[_a] = { fqn: "projen-pipelines.PipelineStep", version: "0.0.
|
|
39
|
+
PipelineStep[_a] = { fqn: "projen-pipelines.PipelineStep", version: "0.0.64" };
|
|
22
40
|
/**
|
|
23
41
|
* Concrete implementation of PipelineStep that executes simple commands.
|
|
24
42
|
*/
|
|
@@ -64,5 +82,5 @@ class SimpleCommandStep extends PipelineStep {
|
|
|
64
82
|
}
|
|
65
83
|
exports.SimpleCommandStep = SimpleCommandStep;
|
|
66
84
|
_b = JSII_RTTI_SYMBOL_1;
|
|
67
|
-
SimpleCommandStep[_b] = { fqn: "projen-pipelines.SimpleCommandStep", version: "0.0.
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
SimpleCommandStep[_b] = { fqn: "projen-pipelines.SimpleCommandStep", version: "0.0.64" };
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdGVwcy9zdGVwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBOENBOztHQUVHO0FBQ0gsTUFBc0IsWUFBWTtJQUVoQzs7O09BR0c7SUFDSCxZQUFzQixPQUFnQjtRQUFoQixZQUFPLEdBQVAsT0FBTyxDQUFTO1FBQ3BDLDJEQUEyRDtJQUM3RCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxRQUFRO1FBQ2IsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRDs7T0FFRztJQUNJLFFBQVE7UUFDYixNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTTtRQUNYLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDOztBQTdCSCxvQ0E4QkM7OztBQUVEOztHQUVHO0FBQ0gsTUFBYSxpQkFBa0IsU0FBUSxZQUFZO0lBRWpEOzs7O09BSUc7SUFDSCxZQUFZLE9BQWdCLEVBQVksUUFBa0I7UUFDeEQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRHVCLGFBQVEsR0FBUixRQUFRLENBQVU7SUFFMUQsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUTtRQUNiLE9BQU87WUFDTCxVQUFVLEVBQUUsRUFBRSxFQUFFLDZDQUE2QztZQUM3RCxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxzQkFBc0I7WUFDL0MsS0FBSyxFQUFFLEVBQUUsRUFBRSxtQkFBbUI7WUFDOUIsR0FBRyxFQUFFLEVBQUUsRUFBRSw0QkFBNEI7U0FDdEMsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU07UUFDWCxPQUFPO1lBQ0wsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsc0JBQXNCO1NBQ2hELENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSSxRQUFRO1FBQ2IsT0FBTztZQUNMLEtBQUssRUFBRSxFQUFFLEVBQUUsbUJBQW1CO1lBQzlCLEtBQUssRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLG1EQUFtRDtZQUNoRyxHQUFHLEVBQUUsRUFBRSxFQUFFLDRCQUE0QjtTQUN0QyxDQUFDO0lBQ0osQ0FBQzs7QUF6Q0gsOENBMENDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvamVjdCB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgeyBKb2JTdGVwIH0gZnJvbSAncHJvamVuL2xpYi9naXRodWIvd29ya2Zsb3dzLW1vZGVsJztcbmltcG9ydCB7IE5lZWQgfSBmcm9tICdwcm9qZW4vbGliL2dpdGxhYic7XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBpbnRlcmZhY2UgZm9yIGEgR2l0TGFiIENJIHN0ZXAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgR2l0bGFiU3RlcENvbmZpZyB7XG5cbiAgLyoqIExpc3Qgb2Ygam9iIGV4dGVuc2lvbnMgcmVsYXRlZCB0byB0aGUgc3RlcC4gKi9cbiAgcmVhZG9ubHkgZXh0ZW5zaW9uczogc3RyaW5nW107XG5cbiAgLyoqIERlcGVuZGVuY2llcyB3aGljaCBuZWVkIHRvIGJlIGNvbXBsZXRlZCBiZWZvcmUgdGhpcyBzdGVwLiAqL1xuICByZWFkb25seSBuZWVkczogTmVlZFtdO1xuXG4gIC8qKiBTaGVsbCBjb21tYW5kcyB0byBleGVjdXRlIGluIHRoaXMgc3RlcC4gKi9cbiAgcmVhZG9ubHkgY29tbWFuZHM6IHN0cmluZ1tdO1xuXG4gIC8qKiBBZGRpdGlvbmFsIGVudmlyb25tZW50IHZhcmlhYmxlcyB0byBzZXQgZm9yIHRoaXMgc3RlcC4gKi9cbiAgcmVhZG9ubHkgZW52OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9O1xufVxuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gaW50ZXJmYWNlIGZvciBhIEdpdEh1YiBBY3Rpb25zIHN0ZXAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgR2l0aHViU3RlcENvbmZpZyB7XG5cbiAgLyoqIERlcGVuZGVuY2llcyB3aGljaCBuZWVkIHRvIGJlIGNvbXBsZXRlZCBiZWZvcmUgdGhpcyBzdGVwLiAqL1xuICByZWFkb25seSBuZWVkczogc3RyaW5nW107XG5cbiAgLyoqIENvbW1hbmRzIHdyYXBwZWQgYXMgR2l0SHViIEFjdGlvbiBqb2Igc3RlcHMuICovXG4gIHJlYWRvbmx5IHN0ZXBzOiBKb2JTdGVwW107XG5cbiAgLyoqIEFkZGl0aW9uYWwgZW52aXJvbm1lbnQgdmFyaWFibGVzIHRvIHNldCBmb3IgdGhpcyBzdGVwLiAqL1xuICByZWFkb25seSBlbnY6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG59XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBpbnRlcmZhY2UgZm9yIGEgYmFzaCBzY3JpcHQgc3RlcC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCYXNoU3RlcENvbmZpZyB7XG5cbiAgLyoqIFNoZWxsIGNvbW1hbmRzIHRvIGV4ZWN1dGUuICovXG4gIHJlYWRvbmx5IGNvbW1hbmRzOiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBBYnN0cmFjdCBjbGFzcyBkZWZpbmluZyB0aGUgc3RydWN0dXJlIG9mIGEgcGlwZWxpbmUgc3RlcC5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFBpcGVsaW5lU3RlcCB7XG5cbiAgLyoqXG4gICAqIEluaXRpYWxpemVzIGEgbmV3IGluc3RhbmNlIG9mIGEgUGlwZWxpbmVTdGVwIHdpdGggYSByZWZlcmVuY2UgdG8gYSBwcm9qZW4gcHJvamVjdC5cbiAgICogQHBhcmFtIHByb2plY3QgLSBUaGUgcHJvamVuIHByb2plY3QgcmVmZXJlbmNlLlxuICAgKi9cbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIHByb2plY3Q6IFByb2plY3QpIHtcbiAgICAvLyBDb25zdHJ1Y3RvciBjYW4gYmUgZXh0ZW5kZWQgdG8gaW5jbHVkZSBtb3JlIHNldHVwIGxvZ2ljLlxuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlcyBhIGNvbmZpZ3VyYXRpb24gZm9yIGEgR2l0TGFiIENJIHN0ZXAuIFNob3VsZCBiZSBpbXBsZW1lbnRlZCBieSBzdWJjbGFzc2VzLlxuICAgKi9cbiAgcHVibGljIHRvR2l0bGFiKCk6IEdpdGxhYlN0ZXBDb25maWcge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZW5lcmF0ZXMgYSBjb25maWd1cmF0aW9uIGZvciBhIEdpdEh1YiBBY3Rpb25zIHN0ZXAuIFNob3VsZCBiZSBpbXBsZW1lbnRlZCBieSBzdWJjbGFzc2VzLlxuICAgKi9cbiAgcHVibGljIHRvR2l0aHViKCk6IEdpdGh1YlN0ZXBDb25maWcge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZW5lcmF0ZXMgYSBjb25maWd1cmF0aW9uIGZvciBhIGJhc2ggc2NyaXB0IHN0ZXAuIFNob3VsZCBiZSBpbXBsZW1lbnRlZCBieSBzdWJjbGFzc2VzLlxuICAgKi9cbiAgcHVibGljIHRvQmFzaCgpOiBCYXNoU3RlcENvbmZpZyB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG59XG5cbi8qKlxuICogQ29uY3JldGUgaW1wbGVtZW50YXRpb24gb2YgUGlwZWxpbmVTdGVwIHRoYXQgZXhlY3V0ZXMgc2ltcGxlIGNvbW1hbmRzLlxuICovXG5leHBvcnQgY2xhc3MgU2ltcGxlQ29tbWFuZFN0ZXAgZXh0ZW5kcyBQaXBlbGluZVN0ZXAge1xuXG4gIC8qKlxuICAgKiBDb25zdHJ1Y3RzIGEgc2ltcGxlIGNvbW1hbmQgc3RlcCB3aXRoIGEgc3BlY2lmaWVkIHNldCBvZiBjb21tYW5kcy5cbiAgICogQHBhcmFtIHByb2plY3QgLSBUaGUgcHJvamVuIHByb2plY3QgcmVmZXJlbmNlLlxuICAgKiBAcGFyYW0gY29tbWFuZHMgLSBTaGVsbCBjb21tYW5kcyB0byBleGVjdXRlLlxuICAgKi9cbiAgY29uc3RydWN0b3IocHJvamVjdDogUHJvamVjdCwgcHJvdGVjdGVkIGNvbW1hbmRzOiBzdHJpbmdbXSkge1xuICAgIHN1cGVyKHByb2plY3QpO1xuICB9XG5cbiAgLyoqXG4gICAqIENvbnZlcnRzIHRoZSBzdGVwIGludG8gYSBHaXRMYWIgQ0kgY29uZmlndXJhdGlvbi5cbiAgICovXG4gIHB1YmxpYyB0b0dpdGxhYigpOiBHaXRsYWJTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgZXh0ZW5zaW9uczogW10sIC8vIE5vIGpvYiBleHRlbnNpb25zIHNwZWNpZmllZCBmb3IgdGhpcyBzdGVwLlxuICAgICAgY29tbWFuZHM6IHRoaXMuY29tbWFuZHMsIC8vIENvbW1hbmRzIHRvIGJlIHJ1bi5cbiAgICAgIG5lZWRzOiBbXSwgLy8gTm8gZGVwZW5kZW5jaWVzLlxuICAgICAgZW52OiB7fSwgLy8gTm8gZW52aXJvbm1lbnQgdmFyaWFibGVzLlxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQ29udmVydHMgdGhlIHN0ZXAgaW50byBhIEJhc2ggc2NyaXB0IGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBwdWJsaWMgdG9CYXNoKCk6IEJhc2hTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgY29tbWFuZHM6IHRoaXMuY29tbWFuZHMsIC8vIENvbW1hbmRzIHRvIGJlIHJ1bi5cbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENvbnZlcnRzIHRoZSBzdGVwIGludG8gYSBHaXRIdWIgQWN0aW9ucyBzdGVwIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBwdWJsaWMgdG9HaXRodWIoKTogR2l0aHViU3RlcENvbmZpZyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5lZWRzOiBbXSwgLy8gTm8gZGVwZW5kZW5jaWVzLlxuICAgICAgc3RlcHM6IHRoaXMuY29tbWFuZHMubWFwKGMgPT4gKHsgcnVuOiBjIH0pKSwgLy8gTWFwcyBlYWNoIGNvbW1hbmQgaW50byBhIEdpdEh1YiBBY3Rpb24gam9iIHN0ZXAuXG4gICAgICBlbnY6IHt9LCAvLyBObyBlbnZpcm9ubWVudCB2YXJpYWJsZXMuXG4gICAgfTtcbiAgfVxufVxuIl19
|