@rio-cloud/cdk-v2-constructs 6.14.0 → 6.15.0-alpha.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 +214 -47
- package/docs/API.md +159 -13
- package/docs/changelog.md +14 -0
- package/lib/contributions/team-transport-two/pipeline/buildspecs.d.ts +5 -0
- package/lib/contributions/team-transport-two/pipeline/buildspecs.js +191 -0
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.d.ts +49 -2
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.js +94 -22
- package/package.json +5 -4
- package/version.json +1 -1
- package/lib/contributions/team-transport-two/pipeline/buildspecs/buildspec-vulnerability-checks.yaml +0 -23
- package/lib/contributions/team-transport-two/pipeline/buildspecs/buildspec.yaml +0 -61
- package/lib/contributions/team-transport-two/pipeline/buildspecs/buildspec_infrastructure.yaml +0 -14
- package/lib/contributions/team-transport-two/pipeline/buildspecs/buildspec_kafka.yaml +0 -64
|
@@ -21,6 +21,7 @@ const pipelines_1 = require("aws-cdk-lib/pipelines");
|
|
|
21
21
|
const yaml = require("js-yaml");
|
|
22
22
|
const application_stage_1 = require("./application-stage");
|
|
23
23
|
const build_project_1 = require("./build-project");
|
|
24
|
+
const buildspecs_1 = require("./buildspecs");
|
|
24
25
|
const datadog_monitors_1 = require("./datadog-monitors");
|
|
25
26
|
const monitoring_deploy_step_1 = require("./monitoring-deploy-step");
|
|
26
27
|
const rio = require("../../../index");
|
|
@@ -68,6 +69,7 @@ var PipelineType;
|
|
|
68
69
|
class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
69
70
|
constructor(scope, id, props) {
|
|
70
71
|
super(scope, id, props);
|
|
72
|
+
this._features = this.parseFeatures(props);
|
|
71
73
|
// populate external parameters
|
|
72
74
|
this._bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', aws_cdk_lib_1.Fn.importValue('bitbucket-integration-s3-bucket'));
|
|
73
75
|
this._cacheBucket = new s3.Bucket(this, 'CacheBucket', {
|
|
@@ -97,9 +99,11 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
97
99
|
this._codePipelineType = props.codePipelineType ?? codepipeline.PipelineType.V1;
|
|
98
100
|
this._mainCodeBuildProject = this.createRioCodeBuildProject('MainBuild', this._inputMasterTriggerFile, props);
|
|
99
101
|
this.addMainPipeline(props, this._mainCodeBuildProject);
|
|
100
|
-
if (
|
|
102
|
+
if (this._features.branchPipeline) {
|
|
101
103
|
this._branchCodeBuildProject = this.createRioCodeBuildProject('BranchBuild', this._inputBranchTriggerFile, props);
|
|
102
|
-
this.addBranchPipeline(
|
|
104
|
+
this.addBranchPipeline(this._branchCodeBuildProject);
|
|
105
|
+
}
|
|
106
|
+
if (this._features.vulnerabilityPipeline) {
|
|
103
107
|
this.addVulnerabilityPipeline(props);
|
|
104
108
|
}
|
|
105
109
|
const [feature, packageName] = __dirname.split(path.sep).reverse();
|
|
@@ -107,7 +111,7 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
107
111
|
product: index_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
108
112
|
packageName,
|
|
109
113
|
feature,
|
|
110
|
-
version: '0.0.
|
|
114
|
+
version: '0.0.24',
|
|
111
115
|
});
|
|
112
116
|
}
|
|
113
117
|
get mainCodebuildProject() {
|
|
@@ -119,12 +123,59 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
119
123
|
}
|
|
120
124
|
return this._branchCodeBuildProject;
|
|
121
125
|
}
|
|
126
|
+
parseFeatures(props) {
|
|
127
|
+
if (props.pipelineType && props.features) {
|
|
128
|
+
throw Error('You cannot provide both a pipelineType and features. Please use features only.');
|
|
129
|
+
}
|
|
130
|
+
if (props.features?.kafkaIntegration && !props.features?.gradleBuild) {
|
|
131
|
+
throw Error('Kafka integration is only supported for pipelines with gradle build');
|
|
132
|
+
}
|
|
133
|
+
if (props.features?.frontendBucketName && !props.features?.npmBuild) {
|
|
134
|
+
throw Error('Frontend bucket name can only be set when npm build is enabled');
|
|
135
|
+
}
|
|
136
|
+
if (props.pipelineType) {
|
|
137
|
+
switch (props.pipelineType) {
|
|
138
|
+
case PipelineType.STANDARD_GRADLE:
|
|
139
|
+
return {
|
|
140
|
+
branchPipeline: true,
|
|
141
|
+
vulnerabilityPipeline: true,
|
|
142
|
+
gradleBuild: true,
|
|
143
|
+
npmBuild: false,
|
|
144
|
+
kafkaIntegration: false,
|
|
145
|
+
};
|
|
146
|
+
case PipelineType.STANDARD_GRADLE_KAFKA:
|
|
147
|
+
return {
|
|
148
|
+
branchPipeline: true,
|
|
149
|
+
vulnerabilityPipeline: true,
|
|
150
|
+
gradleBuild: true,
|
|
151
|
+
npmBuild: false,
|
|
152
|
+
kafkaIntegration: true,
|
|
153
|
+
};
|
|
154
|
+
case PipelineType.STANDARD_INFRASTRUCTURE:
|
|
155
|
+
return {
|
|
156
|
+
branchPipeline: false,
|
|
157
|
+
vulnerabilityPipeline: false,
|
|
158
|
+
gradleBuild: false,
|
|
159
|
+
npmBuild: false,
|
|
160
|
+
kafkaIntegration: false,
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
return {
|
|
165
|
+
branchPipeline: props.features?.branchPipeline ?? true,
|
|
166
|
+
vulnerabilityPipeline: props.features?.vulnerabilityPipeline ?? true,
|
|
167
|
+
gradleBuild: props.features?.gradleBuild ?? false,
|
|
168
|
+
npmBuild: props.features?.npmBuild ?? false,
|
|
169
|
+
kafkaIntegration: props.features?.kafkaIntegration ?? false,
|
|
170
|
+
frontendBucketName: props.features?.frontendBucketName,
|
|
171
|
+
additionalBuildCommands: props.features?.additionalBuildCommands,
|
|
172
|
+
};
|
|
173
|
+
}
|
|
122
174
|
createRioCodeBuildProject(name, triggerFile, props) {
|
|
123
175
|
return new build_project_1.RioCodeBuildProject(this, name, {
|
|
124
176
|
input: triggerFile,
|
|
125
177
|
cdkOutDirectory: 'infrastructure/cdk.out',
|
|
126
|
-
partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath ||
|
|
127
|
-
this.resolveDefaultBuildSpec(props.pipelineType)),
|
|
178
|
+
partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath) || (0, buildspecs_1.createMainBuildSpec)(this._features),
|
|
128
179
|
buildEnvironment: props?.codeBuildOptions?.buildEnvironment,
|
|
129
180
|
hostedZoneName: this._hostedZone.zoneName,
|
|
130
181
|
serviceName: props.serviceName,
|
|
@@ -145,34 +196,45 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
145
196
|
codePipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });
|
|
146
197
|
const capabilityMonitoringDeployStep = this.createCapabilityMonitoringDeployStep(mainBuild, props);
|
|
147
198
|
const secretsDeployStepProps = this.createSecretsDeployStep(props);
|
|
199
|
+
const frontendDeployStep = this.createDeployFrontendDeployStep(mainBuild);
|
|
200
|
+
const postSteps = [];
|
|
201
|
+
if (capabilityMonitoringDeployStep) {
|
|
202
|
+
postSteps.push(capabilityMonitoringDeployStep);
|
|
203
|
+
}
|
|
204
|
+
if (frontendDeployStep) {
|
|
205
|
+
postSteps.push(frontendDeployStep);
|
|
206
|
+
}
|
|
148
207
|
codePipeline.addStage(new application_stage_1.Application(this, 'DeployApplicationStacks', {
|
|
149
208
|
appStackFactory: props.appStackFactory,
|
|
150
209
|
serviceName: props.serviceName,
|
|
151
210
|
version: process.env.PIPELINE_EXECUTION_ID ?? 'PIPELINE_EXECUTION_ID not set',
|
|
152
211
|
}), {
|
|
153
212
|
pre: secretsDeployStepProps ? [secretsDeployStepProps] : undefined,
|
|
154
|
-
post:
|
|
213
|
+
post: postSteps,
|
|
155
214
|
});
|
|
156
215
|
codePipeline.buildPipeline();
|
|
157
216
|
this.tagCodeBuildProject(stripAssetsStep, 'project_type', 'strip_assets');
|
|
158
217
|
this.tagCodeBuildProject(secretsDeployStepProps, 'project_type', 'deploy_secrets');
|
|
159
218
|
this.tagCodeBuildProject(mainBuild, 'project_type', 'build');
|
|
160
219
|
this.tagCodeBuildProject(capabilityMonitoringDeployStep, 'project_type', 'deploy_capability_monitoring');
|
|
220
|
+
this.tagCodeBuildProject(frontendDeployStep, 'project_type', 'deploy_frontend');
|
|
161
221
|
if (capabilityMonitoringDeployStep) {
|
|
162
222
|
const monitoringTestsuiteRunnerBucket = aws_s3_1.Bucket.fromBucketName(this, 'MonitoringTestsuiteRunnerBucket', `monitoring-testsuite-runner-${this.account}`);
|
|
163
223
|
monitoringTestsuiteRunnerBucket.grantWrite(capabilityMonitoringDeployStep);
|
|
164
224
|
}
|
|
225
|
+
if (frontendDeployStep) {
|
|
226
|
+
const frontendBucket = s3.Bucket.fromBucketName(this, 'FrontendBucket', this._features.frontendBucketName);
|
|
227
|
+
frontendBucket.grantReadWrite(frontendDeployStep);
|
|
228
|
+
}
|
|
165
229
|
const rule = new events.Rule(this, 'PipelineSchedule', {
|
|
166
230
|
schedule: events.Schedule.expression(props.pipelineSchedules?.mainPipeline || 'cron(0 9 ? * 2#1 *)'),
|
|
167
231
|
});
|
|
168
232
|
rule.addTarget(new targets.CodePipeline(codePipeline.pipeline));
|
|
169
233
|
this._ossLicensesBucket.grantReadWrite(mainBuild);
|
|
170
234
|
this._ossLicensesBucketParameter.grantRead(mainBuild);
|
|
171
|
-
|
|
172
|
-
this._serviceKeystorePassword.grantRead(mainBuild);
|
|
173
|
-
}
|
|
235
|
+
this._serviceKeystorePassword.grantRead(mainBuild);
|
|
174
236
|
this._accountNameParameter.grantRead(mainBuild);
|
|
175
|
-
if (
|
|
237
|
+
if (this._features.kafkaIntegration) {
|
|
176
238
|
this.grantPermissionsForKafkaIntegration(mainBuild, 'KafkaIntegrationPolicy');
|
|
177
239
|
}
|
|
178
240
|
codePipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);
|
|
@@ -182,7 +244,7 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
182
244
|
accountId: this.account,
|
|
183
245
|
});
|
|
184
246
|
}
|
|
185
|
-
addBranchPipeline(
|
|
247
|
+
addBranchPipeline(branchBuild) {
|
|
186
248
|
const branchPipeline = new codepipeline.Pipeline(this, 'BranchPipeline', {
|
|
187
249
|
artifactBucket: this._cacheBucket,
|
|
188
250
|
pipelineType: this._codePipelineType,
|
|
@@ -200,14 +262,14 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
200
262
|
this._ossLicensesBucketParameter.grantRead(branchBuild);
|
|
201
263
|
this._serviceKeystorePassword.grantRead(branchBuild);
|
|
202
264
|
this._accountNameParameter.grantRead(branchBuild);
|
|
203
|
-
if (
|
|
265
|
+
if (this._features.kafkaIntegration) {
|
|
204
266
|
this.grantPermissionsForKafkaIntegration(branchBuild, 'BranchKafkaIntegrationPolicy');
|
|
205
267
|
}
|
|
206
268
|
}
|
|
207
269
|
addVulnerabilityPipeline(props) {
|
|
208
270
|
const vulnerabilityBuild = new build_project_1.RioCodeBuildProject(this, 'VulnerabilityChecks', {
|
|
209
271
|
input: this._inputMasterTriggerFile,
|
|
210
|
-
partialBuildSpec:
|
|
272
|
+
partialBuildSpec: (0, buildspecs_1.createVulnerabilityBuildSpec)(this._features),
|
|
211
273
|
buildEnvironment: props?.codeBuildOptions?.buildEnvironment,
|
|
212
274
|
hostedZoneName: this._hostedZone.zoneName,
|
|
213
275
|
serviceName: props.serviceName,
|
|
@@ -288,15 +350,22 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
288
350
|
return undefined;
|
|
289
351
|
}
|
|
290
352
|
}
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
return path.resolve(__dirname, 'buildspecs/buildspec.yaml');
|
|
295
|
-
case PipelineType.STANDARD_GRADLE_KAFKA:
|
|
296
|
-
return path.resolve(__dirname, 'buildspecs/buildspec_kafka.yaml');
|
|
297
|
-
case PipelineType.STANDARD_INFRASTRUCTURE:
|
|
298
|
-
return path.resolve(__dirname, 'buildspecs/buildspec_infrastructure.yaml');
|
|
353
|
+
createDeployFrontendDeployStep(mainBuild) {
|
|
354
|
+
if (!this._features.frontendBucketName) {
|
|
355
|
+
return undefined;
|
|
299
356
|
}
|
|
357
|
+
const frontendBuildOutput = mainBuild.addOutputDirectory('build');
|
|
358
|
+
return new pipelines_1.CodeBuildStep('DeployFrontend', {
|
|
359
|
+
input: frontendBuildOutput,
|
|
360
|
+
buildEnvironment: {
|
|
361
|
+
buildImage: aws_codebuild_1.LinuxLambdaBuildImage.AMAZON_LINUX_2023_NODE_20,
|
|
362
|
+
computeType: aws_codebuild_1.ComputeType.LAMBDA_1GB,
|
|
363
|
+
},
|
|
364
|
+
commands: [
|
|
365
|
+
`aws s3 sync --exclude index.html --cache-control max-age=31536000 ./ 's3://${this._features.frontendBucketName}'`,
|
|
366
|
+
`aws s3 cp --cache-control no-cache index.html 's3://${this._features.frontendBucketName}'`,
|
|
367
|
+
],
|
|
368
|
+
});
|
|
300
369
|
}
|
|
301
370
|
grantPermissionsForKafkaIntegration(buildProject, policyId) {
|
|
302
371
|
const buildProjectRole = buildProject.project.role;
|
|
@@ -308,6 +377,9 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
308
377
|
}
|
|
309
378
|
}
|
|
310
379
|
loadBuildSpecFromFile(buildSpecPath) {
|
|
380
|
+
if (!buildSpecPath) {
|
|
381
|
+
return undefined;
|
|
382
|
+
}
|
|
311
383
|
return aws_codebuild_1.BuildSpec.fromObject(yaml.load(fs.readFileSync(buildSpecPath, { encoding: 'utf-8' })));
|
|
312
384
|
}
|
|
313
385
|
renamePipelineToLowerCase(pipeline) {
|
|
@@ -329,4 +401,4 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
329
401
|
exports.PipelineStack = PipelineStack;
|
|
330
402
|
_a = JSII_RTTI_SYMBOL_1;
|
|
331
403
|
PipelineStack[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.PipelineStack", version: "0.0.0" };
|
|
332
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline-stack.js","sourceRoot":"","sources":["../../../../src/contributions/team-transport-two/pipeline/pipeline-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration, Fn, Reference, RemovalPolicy, Stack, StackProps, Tags } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec, ComputeType, LinuxLambdaBuildImage } from 'aws-cdk-lib/aws-codebuild';\nimport * as codepipeline from 'aws-cdk-lib/aws-codepipeline';\nimport { IPipeline } from 'aws-cdk-lib/aws-codepipeline';\nimport * as codepipeline_actions from 'aws-cdk-lib/aws-codepipeline-actions';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\nimport { IHostedZone } from 'aws-cdk-lib/aws-route53';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { Bucket, IBucket } from 'aws-cdk-lib/aws-s3';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { IStringParameter } from 'aws-cdk-lib/aws-ssm';\nimport * as pipelines from 'aws-cdk-lib/pipelines';\nimport { CodeBuildStep, CodePipelineSource } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport * as yaml from 'js-yaml';\nimport { Application } from './application-stage';\nimport { RioCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\nimport { RioCapabilityMonitoringDeployStep } from './monitoring-deploy-step';\nimport { DatadogAlertType } from '../../../datadog';\nimport { INotification } from '../../../datadogv2';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful';\n\n\nexport interface PipelineSchedulesProps {\n  readonly mainPipeline?: string;\n  readonly vulnerabilityPipeline?: string;\n}\n\n/**\n * @struct\n */\nexport interface PipelineStackProps extends StackProps {\n  /**\n   * The name of the service\n   * - This has to be the same name as the repository as the s3 trigger file created by the bitbucket-integration uses this as a prefix\n   * - The serviceName is available as an environment variable SERVICE_NAME in the CodeBuildStep\n   * - The serviceName is available in the AppStackProps in the appStackFactory\n   * - The serviceName is available as stackName property in the AppStackProps in the appStackFactory. I.e. the stack is named after the service\n   * - The serviceName is handed over to all Datadog monitors\n   * - RIO convention is that uploaded license-check-files are named after the service, i.e. serviceName.txt\n   */\n  readonly serviceName: string;\n\n  /**\n   * Provider for appStack to be deployed.\n   *\n   * This acts as a wrapper for all resources you want to deploy via the pipeline.\n   */\n  readonly appStackFactory: IAppStackFactory;\n\n  /**\n   * Defines which kind of pipeline is deployed.\n   */\n  readonly pipelineType: PipelineType;\n\n  /**\n   * Defines how often the pipeline is triggered automatically. Is defined via a cron expression.\n   *\n   * See https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n   *\n   * Default values:\n   * - main pipeline: cron(0 9 ? * 2#1 *)\n   * - vulnerability pipeline: cron(0 5 ? * MON-FRI *)\n   */\n  readonly pipelineSchedules?: PipelineSchedulesProps;\n\n\n  /**\n   * Path to secrets file containing encrypted secrets.\n   *\n   * The RioSecretsDeployStep is added prior to deployment of the AppStack if a path is provided.\n   *\n   * No secrets are deployed if no path is provided.\n   */\n  readonly secretsDeployStepProps?: PipelineStackRioSecretsDeployStepProps;\n\n  /**\n   * CodeBuild options overriding the rio-specific defaults.\n   */\n  readonly codeBuildOptions?: CodeBuildOptions;\n  /**\n   * If present, the capability monitoring deploy step is added to the pipeline.\n   */\n  readonly monitoringDeployStepProps?: PipelineStackRioMonitoringDeployStepProps;\n  /**\n   * @deprecated Please use the `vulnerabilityNotification` property instead.\n   * If `opsgenie` is specified, an Exception is thrown, as this is not supported anymore.\n   */\n  readonly datadogAlertType?: DatadogAlertType;\n  /**\n   * Notification type for the auto-generated vulnerability pipeline monitor. Defaults to slack.\n   */\n  readonly vulnerabilityNotification?: INotification;\n  /**\n   * CodePipeline PipelineType (V1 or V2). Defaults to V1.\n   */\n  readonly codePipelineType?: codepipeline.PipelineType;\n}\n\n/**\n * Provider interface to create the AppStack within the specific scope\n *\n * Simply place the AppStack creation into the create-method:\n * @example\n *\n * // Use e.g. within ApplicationProps as JSONObject:\n * \\{ create: (construct, props) =\\> new Stack(construct, 'AppStack', props) \\}\n *\n * // or simply as class interface within your stack implementation:\n * class PipelineStage extends Stage implements IAppStackFactory \\{\n *   constructor(scope: Construct, id: string, props: StageProps) \\{\n *     super(scope, id, props);\n *     // your stage definition\n *   \\}\n *\n *   create(scope: Construct, props: AppStackProps): void \\{\n *     // app stack initiation goes in here\n *   \\}\n * \\}\n */\nexport interface IAppStackFactory {\n  /**\n   * Factory method, being invoked with the specific scope during pipeline instantiation\n   *\n   * @param scope - The parent construct for the app stack\n   * @param props - The app stacks properties\n   */\n  create(scope: Construct, props: AppStackProps): void;\n}\n\nexport interface AppStackProps extends StackProps {\n  readonly serviceName: string;\n  readonly version: string;\n}\n\n/**\n * Selected properties being handed over to RioSecretsDeployStep.\n *\n * @see rio.RioSecretsDeployStep\n * @see rio.RioSecretsDeployStepProps\n */\nexport interface PipelineStackRioSecretsDeployStepProps {\n  readonly secretsFilePath: string;\n}\n\nexport interface PipelineStackRioMonitoringDeployStepProps {\n  /**\n   * Map \\{directory: filenames\\} containing  .jar or .zip files created in main build step to be uploaded to the monitoring-testsuite-runner bucket, e.g.\n   * ```\n   * {\n   *  'availability-monitoring/build/libs': ['foo-availability.jar'],\n   *  'performance-monitoring/build/libs': ['api-check.zip', 'foo-performance.jar'],\n   * }\n   * ```\n   */\n  readonly monitoringArtifacts: { [directory: string]: string[] };\n}\n\nexport enum PipelineType {\n\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack. Be aware: The provided service won't have access to Kafka.\n   *\n   * Comes with a pre-defined buildspec.yaml for a gradle project. This buildspec.yaml is used for both the main and\n   * branch pipeline and includes the following steps\n   * - build and test of the artifact via command \"./gradlew clean build\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - license-check and upload of license-check-file via command \"./gradlew checkLicenses\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer.\n   * - build the container image via command \"./gradlew jibBuildTar\".\n   * <p> This gradle command must be provided by the gradle project.\n   */\n  STANDARD_GRADLE = 'STANDARD_GRADLE',\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack with additional steps needed to access Kafka.\n   *\n   * Comes with a pre-defined buildspec.yaml for a gradle project. This buildspec.yaml is used for both the main and\n   * branch pipeline and includes the following steps\n   * - build and test of the artifact via command \"./gradlew clean build\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - license-check and upload of license-check-file via command \"./gradlew checkLicenses\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer.\n   * - request a certificate to authenticate against Kafka via mutual TLS\n   * - build the container image via command \"./gradlew jibBuildTar\".\n   * <p> This gradle command must be provided by the gradle project.\n   */\n  STANDARD_GRADLE_KAFKA = 'STANDARD_GRADLE_KAFKA',\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack.\n   *\n   * Comes with a pre-defined buildspec.yaml to synthesize the AppStack.\n   * No branch or vulnerability pipeline is created.\n   */\n  STANDARD_INFRASTRUCTURE = 'STANDARD_INFRASTRUCTURE',\n}\n\n/**\n * @param partialBuildSpecPath - Path to a custom build-spec file to use for the main and branch pipeline.\n * A pre-defined buildspec.yaml fitting the pipelineType is used if not provided.\n * @param buildEnvironment - Custom CodeBuild build environment overriding the rio-specific defaults. The defaults are:\n *          buildImage: AMAZON_LINUX_2_5\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\n}\n\nexport class PipelineStack extends Stack {\n  private readonly _mainCodeBuildProject: CodeBuildStep;\n  private readonly _branchCodeBuildProject: CodeBuildStep | undefined;\n  private readonly _bucket: IBucket;\n  private readonly _cacheBucket: IBucket;\n  private readonly _hostedZone: IHostedZone;\n  private readonly _inputMasterTriggerFile: CodePipelineSource;\n  private readonly _inputBranchTriggerFile: CodePipelineSource;\n  private readonly _ossLicensesBucketParameter: IStringParameter;\n  private readonly _ossLicensesBucket: IBucket;\n  private readonly _serviceKeystorePassword: IStringParameter;\n  private readonly _accountNameParameter: IStringParameter;\n  private readonly _nistDataMirrorUrl: IStringParameter;\n  private readonly _codePipelineType: codepipeline.PipelineType;\n\n  constructor(scope: Construct, id: string, props: PipelineStackProps) {\n    super(scope, id, props);\n\n    // populate external parameters\n    this._bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', Fn.importValue('bitbucket-integration-s3-bucket'));\n    this._cacheBucket = new s3.Bucket(this, 'CacheBucket', {\n      removalPolicy: RemovalPolicy.DESTROY,\n      autoDeleteObjects: true,\n      lifecycleRules: [\n        {\n          expiration: Duration.days(30),\n          abortIncompleteMultipartUploadAfter: Duration.days(7),\n        },\n      ],\n    });\n    this._hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);\n    this._inputMasterTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n    this._inputBranchTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n\n    this._ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(this, 'OssLicensesBucketParameter', { parameterName: '/config/oss-licenses/bucket-name' });\n    this._ossLicensesBucket = s3.Bucket.fromBucketName(this, 'OssLicensesBucket', this._ossLicensesBucketParameter.stringValue);\n    this._serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {\n      parameterName: `/config/${props.serviceName}/service-keystore-password`,\n      version: 1,\n    });\n    this._accountNameParameter = ssm.StringParameter.fromStringParameterName(this, 'AccountNameParameter', '/config/account/name');\n    this._nistDataMirrorUrl = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'NistDataMirrorUrl', {\n      parameterName: '/config/nist-data-mirror/url',\n      version: 1,\n    });\n\n    this._codePipelineType = props.codePipelineType ?? codepipeline.PipelineType.V1;\n\n    this._mainCodeBuildProject = this.createRioCodeBuildProject('MainBuild', this._inputMasterTriggerFile, props);\n    this.addMainPipeline(props, this._mainCodeBuildProject);\n\n    if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {\n      this._branchCodeBuildProject = this.createRioCodeBuildProject('BranchBuild', this._inputBranchTriggerFile, props);\n      this.addBranchPipeline(props, this._branchCodeBuildProject);\n      this.addVulnerabilityPipeline(props);\n    }\n\n    const [feature, packageName] = __dirname.split(path.sep).reverse();\n    new Claidometer(this, 'Claidometer', {\n      product: ClaidometerProduct.CDK_CONTRIBUTION,\n      packageName,\n      feature,\n      version: '0.0.23',\n    });\n  }\n\n  public get mainCodebuildProject() {\n    return this._mainCodeBuildProject;\n  }\n\n  public get branchCodeBuildProject(): CodeBuildStep {\n    if (this._branchCodeBuildProject == undefined) {\n      throw Error('The pipeline type you have selected does not support a branch codebuild project');\n    }\n    return this._branchCodeBuildProject;\n  }\n\n  private createRioCodeBuildProject(name: string, triggerFile: CodePipelineSource, props: PipelineStackProps) {\n    return new RioCodeBuildProject(this, name, {\n      input: triggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath ||\n        this.resolveDefaultBuildSpec(props.pipelineType)),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n      cacheBucket: this._cacheBucket,\n    });\n  }\n\n  private addMainPipeline(props: PipelineStackProps, mainBuild: CodeBuildStep) {\n    const pipeline = new codepipeline.Pipeline(this, 'Pipeline', {\n      artifactBucket: this._cacheBucket,\n      pipelineType: this._codePipelineType,\n    });\n    const codePipeline = new pipelines.CodePipeline(pipeline, 'CodePipeline', {\n      codePipeline: pipeline,\n      synth: mainBuild,\n    });\n    Tags.of(pipeline).add('pipeline_type', 'build');\n\n    const stripAssetsStep = this.createStripAssetsStep(codePipeline);\n    codePipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    const capabilityMonitoringDeployStep = this.createCapabilityMonitoringDeployStep(mainBuild, props);\n    const secretsDeployStepProps = this.createSecretsDeployStep(props);\n\n    codePipeline.addStage(new Application(this, 'DeployApplicationStacks', {\n      appStackFactory: props.appStackFactory,\n      serviceName: props.serviceName,\n      version: process.env.PIPELINE_EXECUTION_ID ?? 'PIPELINE_EXECUTION_ID not set',\n    }), {\n      pre: secretsDeployStepProps ? [secretsDeployStepProps] : undefined,\n      post: capabilityMonitoringDeployStep ? [capabilityMonitoringDeployStep] : undefined,\n    });\n    codePipeline.buildPipeline();\n\n    this.tagCodeBuildProject(stripAssetsStep, 'project_type', 'strip_assets');\n    this.tagCodeBuildProject(secretsDeployStepProps, 'project_type', 'deploy_secrets');\n    this.tagCodeBuildProject(mainBuild, 'project_type', 'build');\n    this.tagCodeBuildProject(capabilityMonitoringDeployStep, 'project_type', 'deploy_capability_monitoring');\n\n    if (capabilityMonitoringDeployStep) {\n      const monitoringTestsuiteRunnerBucket = Bucket.fromBucketName(this, 'MonitoringTestsuiteRunnerBucket', `monitoring-testsuite-runner-${this.account}`);\n      monitoringTestsuiteRunnerBucket.grantWrite(capabilityMonitoringDeployStep);\n    }\n\n    const rule = new events.Rule(this, 'PipelineSchedule', {\n      schedule: events.Schedule.expression(props.pipelineSchedules?.mainPipeline || 'cron(0 9 ? * 2#1 *)'),\n    });\n    rule.addTarget(new targets.CodePipeline(codePipeline.pipeline));\n\n    this._ossLicensesBucket.grantReadWrite(mainBuild);\n    this._ossLicensesBucketParameter.grantRead(mainBuild);\n    if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {\n      this._serviceKeystorePassword.grantRead(mainBuild);\n    }\n    this._accountNameParameter.grantRead(mainBuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(mainBuild, 'KafkaIntegrationPolicy');\n    }\n    codePipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);\n\n    new DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(pipeline),\n      accountId: this.account,\n    });\n  }\n\n  private addBranchPipeline(props: PipelineStackProps, branchBuild: CodeBuildStep) {\n    const branchPipeline = new codepipeline.Pipeline(this, 'BranchPipeline', {\n      artifactBucket: this._cacheBucket,\n      pipelineType: this._codePipelineType,\n    });\n    const branchCodePipeline = new pipelines.CodePipeline(branchPipeline, 'CodePipeline', {\n      codePipeline: branchPipeline,\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    Tags.of(branchPipeline).add('pipeline_type', 'branch');\n    branchCodePipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchCodePipeline.buildPipeline();\n\n    this.tagCodeBuildProject(branchBuild, 'project_type', 'branch_build');\n\n    this._ossLicensesBucket.grantReadWrite(branchBuild);\n    this._ossLicensesBucketParameter.grantRead(branchBuild);\n    this._serviceKeystorePassword.grantRead(branchBuild);\n    this._accountNameParameter.grantRead(branchBuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(branchBuild, 'BranchKafkaIntegrationPolicy');\n    }\n  }\n\n  private addVulnerabilityPipeline(props: PipelineStackProps) {\n    const vulnerabilityBuild = new RioCodeBuildProject(this, 'VulnerabilityChecks', {\n      input: this._inputMasterTriggerFile,\n      partialBuildSpec: this.loadBuildSpecFromFile(path.resolve(__dirname, 'buildspecs/buildspec-vulnerability-checks.yaml')),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n      cacheBucket: this._cacheBucket,\n    });\n    const vulnerabilityPipeline = new codepipeline.Pipeline(this, 'VulnerabilityPipeline', {\n      artifactBucket: this._cacheBucket,\n      pipelineType: this._codePipelineType,\n    });\n    const vulnerabilityCodePipeline = new pipelines.CodePipeline(vulnerabilityPipeline, 'CodePipeline', {\n      codePipeline: vulnerabilityPipeline,\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    Tags.of(vulnerabilityPipeline).add('pipeline_type', 'vulnerability');\n\n    vulnerabilityCodePipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityCodePipeline.buildPipeline();\n    Tags.of(vulnerabilityBuild.project).add('project_type', 'vulnerability_check');\n    this._nistDataMirrorUrl.grantRead(vulnerabilityBuild);\n\n    const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', {\n      schedule: events.Schedule.expression(props.pipelineSchedules?.vulnerabilityPipeline || 'cron(0 5 ? * MON-FRI *)'),\n    });\n    vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityCodePipeline.pipeline));\n\n    if (props.datadogAlertType === 'opsgenie') {\n      throw Error('The OpsGenie alertType is not supported anymore. Please use the vulnerabilityNotification property instead.');\n    }\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n      notification: props.vulnerabilityNotification,\n    });\n  }\n\n  private createStripAssetsStep(pipeline: pipelines.CodePipeline): CodeBuildStep {\n    // CloudAssemblyArtifacts must be smaller than 256MB. Due to the gradle artifact we are exceeding this limit and pipeline fails in deployment step.\n    // Issue is known and not fixed for already some years. See: https://github.com/aws/aws-cdk/issues/9917\n    // Dirty fix: Assets are already uploaded and thus not needed. Remove them from pipeline artifact.\n    return new CodeBuildStep(\n      'StripAssetsFromAssembly', {\n        input: pipeline.cloudAssemblyFileSet,\n        commands: [\n          'S3_PATH=${CODEBUILD_SOURCE_VERSION#\"arn:aws:s3:::\"}',\n          'ZIP_ARCHIVE=$(basename $S3_PATH)',\n          'rm -rfv asset.*',\n          'zip -r -q -A $ZIP_ARCHIVE *',\n          'aws s3 cp $ZIP_ARCHIVE s3://$S3_PATH',\n        ],\n        buildEnvironment: {\n          buildImage: LinuxLambdaBuildImage.AMAZON_LINUX_2023_NODE_20,\n          computeType: ComputeType.LAMBDA_1GB,\n        },\n      },\n    );\n  }\n\n  private createCapabilityMonitoringDeployStep(mainBuild: CodeBuildStep, props: PipelineStackProps): CodeBuildStep | undefined {\n    if (props.monitoringDeployStepProps) {\n      const monitoringArtifacts = Object.keys(props.monitoringDeployStepProps.monitoringArtifacts).map((key) => {\n        const output = mainBuild.addOutputDirectory(key);\n        return {\n          input: output,\n          files: props.monitoringDeployStepProps!.monitoringArtifacts[key],\n        };\n      });\n      return new RioCapabilityMonitoringDeployStep(this, 'DeployCapabilityMonitoring', {\n        monitoringArtifacts: monitoringArtifacts,\n      });\n    } else {\n      return undefined;\n    }\n  }\n\n  private createSecretsDeployStep(props: PipelineStackProps): rio.RioSecretsDeployStep | undefined {\n    if (props.secretsDeployStepProps) {\n      return new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n        ...props.secretsDeployStepProps,\n        input: this._inputMasterTriggerFile,\n      });\n    } else {\n      return undefined;\n    }\n  }\n\n  private resolveDefaultBuildSpec(pipelineType: PipelineType) {\n    switch (pipelineType) {\n      case PipelineType.STANDARD_GRADLE:\n        return path.resolve(__dirname, 'buildspecs/buildspec.yaml');\n      case PipelineType.STANDARD_GRADLE_KAFKA:\n        return path.resolve(__dirname, 'buildspecs/buildspec_kafka.yaml');\n      case PipelineType.STANDARD_INFRASTRUCTURE:\n        return path.resolve(__dirname, 'buildspecs/buildspec_infrastructure.yaml');\n    }\n  }\n\n  private grantPermissionsForKafkaIntegration(buildProject: RioCodeBuildProject, policyId: string) {\n    const buildProjectRole = buildProject.project.role;\n    if (buildProjectRole) {\n      buildProjectRole.addManagedPolicy(\n        ManagedPolicy.fromManagedPolicyArn(this,\n          policyId,\n          Fn.importValue('kafka-integration-policy-arn'),\n        ),\n      );\n    } else {\n      throw Error(`Could not add managed policy for kafka-integration to CodeBuild project of ${buildProject.id} due to missing role.`);\n    }\n  }\n\n  private loadBuildSpecFromFile(buildSpecPath: string): BuildSpec {\n    return BuildSpec.fromObject(yaml.load(fs.readFileSync(buildSpecPath, { encoding: 'utf-8' })) as Object);\n  }\n\n  private renamePipelineToLowerCase(pipeline: IPipeline): Reference {\n    const upperToLowerCr = new cdk.CustomResource(this, `${pipeline.node.id}-UpperToLower`, {\n      resourceType: 'Custom::UpperToLower',\n      serviceToken: UpperToLower.getOrCreate(this).provider.serviceToken,\n      properties: {\n        Upper: pipeline.pipelineName,\n      },\n    });\n    return upperToLowerCr.getAtt('Lower');\n  }\n\n  private tagCodeBuildProject(project: CodeBuildStep | undefined, key: string, value: string) {\n    if (project) {\n      Tags.of(project.project).add(key, value);\n    }\n  }\n}\n"]}
|
|
404
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline-stack.js","sourceRoot":"","sources":["../../../../src/contributions/team-transport-two/pipeline/pipeline-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration, Fn, Reference, RemovalPolicy, Stack, StackProps, Tags } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec, ComputeType, LinuxLambdaBuildImage } from 'aws-cdk-lib/aws-codebuild';\nimport * as codepipeline from 'aws-cdk-lib/aws-codepipeline';\nimport { IPipeline } from 'aws-cdk-lib/aws-codepipeline';\nimport * as codepipeline_actions from 'aws-cdk-lib/aws-codepipeline-actions';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\nimport { IHostedZone } from 'aws-cdk-lib/aws-route53';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { Bucket, IBucket } from 'aws-cdk-lib/aws-s3';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { IStringParameter } from 'aws-cdk-lib/aws-ssm';\nimport * as pipelines from 'aws-cdk-lib/pipelines';\nimport { CodeBuildStep, CodePipelineSource } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport * as yaml from 'js-yaml';\nimport { Application } from './application-stage';\nimport { RioCodeBuildProject } from './build-project';\nimport { createMainBuildSpec, createVulnerabilityBuildSpec } from './buildspecs';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\nimport { RioCapabilityMonitoringDeployStep } from './monitoring-deploy-step';\nimport { DatadogAlertType } from '../../../datadog';\nimport { INotification } from '../../../datadogv2';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful';\n\n\nexport interface PipelineSchedulesProps {\n  readonly mainPipeline?: string;\n  readonly vulnerabilityPipeline?: string;\n}\n\n/**\n * @struct\n */\nexport interface PipelineStackProps extends StackProps {\n  /**\n   * The name of the service\n   * - This has to be the same name as the repository as the s3 trigger file created by the bitbucket-integration uses this as a prefix\n   * - The serviceName is available as an environment variable SERVICE_NAME in the CodeBuildStep\n   * - The serviceName is available in the AppStackProps in the appStackFactory\n   * - The serviceName is available as stackName property in the AppStackProps in the appStackFactory. I.e. the stack is named after the service\n   * - The serviceName is handed over to all Datadog monitors\n   * - RIO convention is that uploaded license-check-files are named after the service, i.e. serviceName.txt\n   */\n  readonly serviceName: string;\n\n  /**\n   * Provider for appStack to be deployed.\n   *\n   * This acts as a wrapper for all resources you want to deploy via the pipeline.\n   */\n  readonly appStackFactory: IAppStackFactory;\n\n  /**\n   * Defines which kind of pipeline is deployed.\n   *\n   * Use the features to combine different opinionated, RIO-specific pipeline features such as adding a branch pipeline or supporting Kafka.\n   */\n  readonly features?: PipelineFeatures;\n\n  /**\n   * @deprecated Use the `features` property instead. For now, the pipeline types are mapped to the features.\n   * Defines which kind of pipeline is deployed.\n   */\n  readonly pipelineType?: PipelineType;\n\n  /**\n   * Defines how often the pipeline is triggered automatically. Is defined via a cron expression.\n   *\n   * See https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n   *\n   * Default values:\n   * - main pipeline: cron(0 9 ? * 2#1 *)\n   * - vulnerability pipeline: cron(0 5 ? * MON-FRI *)\n   */\n  readonly pipelineSchedules?: PipelineSchedulesProps;\n\n\n  /**\n   * Path to secrets file containing encrypted secrets.\n   *\n   * The RioSecretsDeployStep is added prior to deployment of the AppStack if a path is provided.\n   *\n   * No secrets are deployed if no path is provided.\n   */\n  readonly secretsDeployStepProps?: PipelineStackRioSecretsDeployStepProps;\n\n  /**\n   * CodeBuild options overriding the rio-specific defaults.\n   */\n  readonly codeBuildOptions?: CodeBuildOptions;\n  /**\n   * If present, the capability monitoring deploy step is added to the pipeline.\n   */\n  readonly monitoringDeployStepProps?: PipelineStackRioMonitoringDeployStepProps;\n  /**\n   * @deprecated Please use the `vulnerabilityNotification` property instead.\n   * If `opsgenie` is specified, an Exception is thrown, as this is not supported anymore.\n   */\n  readonly datadogAlertType?: DatadogAlertType;\n  /**\n   * Notification type for the auto-generated vulnerability pipeline monitor. Defaults to slack.\n   */\n  readonly vulnerabilityNotification?: INotification;\n  /**\n   * CodePipeline PipelineType (V1 or V2). Defaults to V1.\n   */\n  readonly codePipelineType?: codepipeline.PipelineType;\n}\n\n/**\n * Provider interface to create the AppStack within the specific scope\n *\n * Simply place the AppStack creation into the create-method:\n * @example\n *\n * // Use e.g. within ApplicationProps as JSONObject:\n * \\{ create: (construct, props) =\\> new Stack(construct, 'AppStack', props) \\}\n *\n * // or simply as class interface within your stack implementation:\n * class PipelineStage extends Stage implements IAppStackFactory \\{\n *   constructor(scope: Construct, id: string, props: StageProps) \\{\n *     super(scope, id, props);\n *     // your stage definition\n *   \\}\n *\n *   create(scope: Construct, props: AppStackProps): void \\{\n *     // app stack initiation goes in here\n *   \\}\n * \\}\n */\nexport interface IAppStackFactory {\n  /**\n   * Factory method, being invoked with the specific scope during pipeline instantiation\n   *\n   * @param scope - The parent construct for the app stack\n   * @param props - The app stacks properties\n   */\n  create(scope: Construct, props: AppStackProps): void;\n}\n\nexport interface AppStackProps extends StackProps {\n  readonly serviceName: string;\n  readonly version: string;\n}\n\n/**\n * Selected properties being handed over to RioSecretsDeployStep.\n *\n * @see rio.RioSecretsDeployStep\n * @see rio.RioSecretsDeployStepProps\n */\nexport interface PipelineStackRioSecretsDeployStepProps {\n  readonly secretsFilePath: string;\n}\n\nexport interface PipelineStackRioMonitoringDeployStepProps {\n  /**\n   * Map \\{directory: filenames\\} containing  .jar or .zip files created in main build step to be uploaded to the monitoring-testsuite-runner bucket, e.g.\n   * ```\n   * {\n   *  'availability-monitoring/build/libs': ['foo-availability.jar'],\n   *  'performance-monitoring/build/libs': ['api-check.zip', 'foo-performance.jar'],\n   * }\n   * ```\n   */\n  readonly monitoringArtifacts: { [directory: string]: string[] };\n}\n\nexport interface PipelineFeatures {\n  /**\n   * Create a branch pipeline used by renovate. Defaults to `true`.\n   */\n  readonly branchPipeline?: boolean;\n  /**\n   * Create a vulnerability pipeline to scan dependencies for vulnerabilities. Defaults to `true`.\n   */\n  readonly vulnerabilityPipeline?: boolean;\n  /**\n   * Run a standard gradle build in the repository root. Defaults to `false`:\n   * - build and test of the artifact via command \"./gradlew clean build\"\n   * - license-check and upload of license-check-file via command \"./gradlew checkLicenses\"\n   * - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer\n   * - build the container image via command \"./gradlew jibBuildTar\"\n   */\n  readonly gradleBuild?: boolean;\n  /**\n   * Run a standard npm build in the repository root. Defaults to `false`:\n   * - run linter via command \"npm run lint\"\n   * - run tests via command \"npm run test:ci\"\n   * - run a license check by calling the script \"check-oss-licenses.sh\" (from the RIO frontend template)\n   * - build the artifact via command \"npm run build\"\n   */\n  readonly npmBuild?: boolean;\n  /**\n   * Add required steps and permissions to support Kafka. Currently, this requires `gradleBuild` to be set to `true`. Defaults to `false`.\n   */\n  readonly kafkaIntegration?: boolean;\n  /**\n   * S3 Bucket to deploy frontend to. Requires `npmBuild` to be set to `true`. If set, the output of the npm build is deployed to the provided bucket.\n   */\n  readonly frontendBucketName?: string;\n  /**\n   * Additional build commands for main and branch pipeline. Will be added after all build & test commands, before the infrastructure build.\n   */\n  readonly additionalBuildCommands?: string[];\n}\n\nexport enum PipelineType {\n\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack. Be aware: The provided service won't have access to Kafka.\n   *\n   * Comes with a pre-defined buildspec.yaml for a gradle project. This buildspec.yaml is used for both the main and\n   * branch pipeline and includes the following steps\n   * - build and test of the artifact via command \"./gradlew clean build\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - license-check and upload of license-check-file via command \"./gradlew checkLicenses\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer.\n   * - build the container image via command \"./gradlew jibBuildTar\".\n   * <p> This gradle command must be provided by the gradle project.\n   */\n  STANDARD_GRADLE = 'STANDARD_GRADLE',\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack with additional steps needed to access Kafka.\n   *\n   * Comes with a pre-defined buildspec.yaml for a gradle project. This buildspec.yaml is used for both the main and\n   * branch pipeline and includes the following steps\n   * - build and test of the artifact via command \"./gradlew clean build\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - license-check and upload of license-check-file via command \"./gradlew checkLicenses\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer.\n   * - request a certificate to authenticate against Kafka via mutual TLS\n   * - build the container image via command \"./gradlew jibBuildTar\".\n   * <p> This gradle command must be provided by the gradle project.\n   */\n  STANDARD_GRADLE_KAFKA = 'STANDARD_GRADLE_KAFKA',\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack.\n   *\n   * Comes with a pre-defined buildspec.yaml to synthesize the AppStack.\n   * No branch or vulnerability pipeline is created.\n   */\n  STANDARD_INFRASTRUCTURE = 'STANDARD_INFRASTRUCTURE',\n}\n\n/**\n * @param partialBuildSpecPath - Path to a custom build-spec file to use for the main and branch pipeline.\n * A pre-defined buildspec.yaml fitting the pipelineType is used if not provided.\n * @param buildEnvironment - Custom CodeBuild build environment overriding the rio-specific defaults. The defaults are:\n *          buildImage: AMAZON_LINUX_2_5\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\n}\n\nexport class PipelineStack extends Stack {\n  private readonly _features: PipelineFeatures;\n  private readonly _mainCodeBuildProject: CodeBuildStep;\n  private readonly _branchCodeBuildProject: CodeBuildStep | undefined;\n  private readonly _bucket: IBucket;\n  private readonly _cacheBucket: IBucket;\n  private readonly _hostedZone: IHostedZone;\n  private readonly _inputMasterTriggerFile: CodePipelineSource;\n  private readonly _inputBranchTriggerFile: CodePipelineSource;\n  private readonly _ossLicensesBucketParameter: IStringParameter;\n  private readonly _ossLicensesBucket: IBucket;\n  private readonly _serviceKeystorePassword: IStringParameter;\n  private readonly _accountNameParameter: IStringParameter;\n  private readonly _nistDataMirrorUrl: IStringParameter;\n  private readonly _codePipelineType: codepipeline.PipelineType;\n\n  constructor(scope: Construct, id: string, props: PipelineStackProps) {\n    super(scope, id, props);\n\n    this._features = this.parseFeatures(props);\n\n    // populate external parameters\n    this._bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', Fn.importValue('bitbucket-integration-s3-bucket'));\n    this._cacheBucket = new s3.Bucket(this, 'CacheBucket', {\n      removalPolicy: RemovalPolicy.DESTROY,\n      autoDeleteObjects: true,\n      lifecycleRules: [\n        {\n          expiration: Duration.days(30),\n          abortIncompleteMultipartUploadAfter: Duration.days(7),\n        },\n      ],\n    });\n    this._hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);\n    this._inputMasterTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n    this._inputBranchTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n\n    this._ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(this, 'OssLicensesBucketParameter', { parameterName: '/config/oss-licenses/bucket-name' });\n    this._ossLicensesBucket = s3.Bucket.fromBucketName(this, 'OssLicensesBucket', this._ossLicensesBucketParameter.stringValue);\n    this._serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {\n      parameterName: `/config/${props.serviceName}/service-keystore-password`,\n      version: 1,\n    });\n    this._accountNameParameter = ssm.StringParameter.fromStringParameterName(this, 'AccountNameParameter', '/config/account/name');\n    this._nistDataMirrorUrl = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'NistDataMirrorUrl', {\n      parameterName: '/config/nist-data-mirror/url',\n      version: 1,\n    });\n\n    this._codePipelineType = props.codePipelineType ?? codepipeline.PipelineType.V1;\n\n    this._mainCodeBuildProject = this.createRioCodeBuildProject('MainBuild', this._inputMasterTriggerFile, props);\n    this.addMainPipeline(props, this._mainCodeBuildProject);\n\n    if (this._features.branchPipeline) {\n      this._branchCodeBuildProject = this.createRioCodeBuildProject('BranchBuild', this._inputBranchTriggerFile, props);\n      this.addBranchPipeline(this._branchCodeBuildProject);\n    }\n    if (this._features.vulnerabilityPipeline) {\n      this.addVulnerabilityPipeline(props);\n    }\n\n    const [feature, packageName] = __dirname.split(path.sep).reverse();\n    new Claidometer(this, 'Claidometer', {\n      product: ClaidometerProduct.CDK_CONTRIBUTION,\n      packageName,\n      feature,\n      version: '0.0.24',\n    });\n  }\n\n  public get mainCodebuildProject() {\n    return this._mainCodeBuildProject;\n  }\n\n  public get branchCodeBuildProject(): CodeBuildStep {\n    if (this._branchCodeBuildProject == undefined) {\n      throw Error('The pipeline type you have selected does not support a branch codebuild project');\n    }\n    return this._branchCodeBuildProject;\n  }\n\n  private parseFeatures(props: PipelineStackProps): PipelineFeatures {\n    if (props.pipelineType && props.features) {\n      throw Error('You cannot provide both a pipelineType and features. Please use features only.');\n    }\n    if (props.features?.kafkaIntegration && !props.features?.gradleBuild) {\n      throw Error('Kafka integration is only supported for pipelines with gradle build');\n    }\n    if (props.features?.frontendBucketName && !props.features?.npmBuild) {\n      throw Error('Frontend bucket name can only be set when npm build is enabled');\n    }\n    if (props.pipelineType) {\n      switch (props.pipelineType) {\n        case PipelineType.STANDARD_GRADLE:\n          return {\n            branchPipeline: true,\n            vulnerabilityPipeline: true,\n            gradleBuild: true,\n            npmBuild: false,\n            kafkaIntegration: false,\n          };\n        case PipelineType.STANDARD_GRADLE_KAFKA:\n          return {\n            branchPipeline: true,\n            vulnerabilityPipeline: true,\n            gradleBuild: true,\n            npmBuild: false,\n            kafkaIntegration: true,\n          };\n        case PipelineType.STANDARD_INFRASTRUCTURE:\n          return {\n            branchPipeline: false,\n            vulnerabilityPipeline: false,\n            gradleBuild: false,\n            npmBuild: false,\n            kafkaIntegration: false,\n          };\n      }\n    }\n    return {\n      branchPipeline: props.features?.branchPipeline ?? true,\n      vulnerabilityPipeline: props.features?.vulnerabilityPipeline ?? true,\n      gradleBuild: props.features?.gradleBuild ?? false,\n      npmBuild: props.features?.npmBuild ?? false,\n      kafkaIntegration: props.features?.kafkaIntegration ?? false,\n      frontendBucketName: props.features?.frontendBucketName,\n      additionalBuildCommands: props.features?.additionalBuildCommands,\n    };\n  }\n\n  private createRioCodeBuildProject(name: string, triggerFile: CodePipelineSource, props: PipelineStackProps) {\n    return new RioCodeBuildProject(this, name, {\n      input: triggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath) || createMainBuildSpec(this._features),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n      cacheBucket: this._cacheBucket,\n    });\n  }\n\n  private addMainPipeline(props: PipelineStackProps, mainBuild: CodeBuildStep) {\n    const pipeline = new codepipeline.Pipeline(this, 'Pipeline', {\n      artifactBucket: this._cacheBucket,\n      pipelineType: this._codePipelineType,\n    });\n    const codePipeline = new pipelines.CodePipeline(pipeline, 'CodePipeline', {\n      codePipeline: pipeline,\n      synth: mainBuild,\n    });\n    Tags.of(pipeline).add('pipeline_type', 'build');\n\n    const stripAssetsStep = this.createStripAssetsStep(codePipeline);\n    codePipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    const capabilityMonitoringDeployStep = this.createCapabilityMonitoringDeployStep(mainBuild, props);\n    const secretsDeployStepProps = this.createSecretsDeployStep(props);\n    const frontendDeployStep = this.createDeployFrontendDeployStep(mainBuild);\n    const postSteps = [];\n    if (capabilityMonitoringDeployStep) {\n      postSteps.push(capabilityMonitoringDeployStep);\n    }\n    if (frontendDeployStep) {\n      postSteps.push(frontendDeployStep);\n    }\n\n    codePipeline.addStage(new Application(this, 'DeployApplicationStacks', {\n      appStackFactory: props.appStackFactory,\n      serviceName: props.serviceName,\n      version: process.env.PIPELINE_EXECUTION_ID ?? 'PIPELINE_EXECUTION_ID not set',\n    }), {\n      pre: secretsDeployStepProps ? [secretsDeployStepProps] : undefined,\n      post: postSteps,\n    });\n\n    codePipeline.buildPipeline();\n\n    this.tagCodeBuildProject(stripAssetsStep, 'project_type', 'strip_assets');\n    this.tagCodeBuildProject(secretsDeployStepProps, 'project_type', 'deploy_secrets');\n    this.tagCodeBuildProject(mainBuild, 'project_type', 'build');\n    this.tagCodeBuildProject(capabilityMonitoringDeployStep, 'project_type', 'deploy_capability_monitoring');\n    this.tagCodeBuildProject(frontendDeployStep, 'project_type', 'deploy_frontend');\n\n    if (capabilityMonitoringDeployStep) {\n      const monitoringTestsuiteRunnerBucket = Bucket.fromBucketName(this, 'MonitoringTestsuiteRunnerBucket', `monitoring-testsuite-runner-${this.account}`);\n      monitoringTestsuiteRunnerBucket.grantWrite(capabilityMonitoringDeployStep);\n    }\n    if (frontendDeployStep) {\n      const frontendBucket = s3.Bucket.fromBucketName(this, 'FrontendBucket', this._features.frontendBucketName!!);\n      frontendBucket.grantReadWrite(frontendDeployStep);\n    }\n\n    const rule = new events.Rule(this, 'PipelineSchedule', {\n      schedule: events.Schedule.expression(props.pipelineSchedules?.mainPipeline || 'cron(0 9 ? * 2#1 *)'),\n    });\n    rule.addTarget(new targets.CodePipeline(codePipeline.pipeline));\n\n    this._ossLicensesBucket.grantReadWrite(mainBuild);\n    this._ossLicensesBucketParameter.grantRead(mainBuild);\n    this._serviceKeystorePassword.grantRead(mainBuild);\n    this._accountNameParameter.grantRead(mainBuild);\n    if (this._features.kafkaIntegration) {\n      this.grantPermissionsForKafkaIntegration(mainBuild, 'KafkaIntegrationPolicy');\n    }\n    codePipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);\n\n    new DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(pipeline),\n      accountId: this.account,\n    });\n  }\n\n  private addBranchPipeline(branchBuild: CodeBuildStep) {\n    const branchPipeline = new codepipeline.Pipeline(this, 'BranchPipeline', {\n      artifactBucket: this._cacheBucket,\n      pipelineType: this._codePipelineType,\n    });\n    const branchCodePipeline = new pipelines.CodePipeline(branchPipeline, 'CodePipeline', {\n      codePipeline: branchPipeline,\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    Tags.of(branchPipeline).add('pipeline_type', 'branch');\n    branchCodePipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchCodePipeline.buildPipeline();\n\n    this.tagCodeBuildProject(branchBuild, 'project_type', 'branch_build');\n\n    this._ossLicensesBucket.grantReadWrite(branchBuild);\n    this._ossLicensesBucketParameter.grantRead(branchBuild);\n    this._serviceKeystorePassword.grantRead(branchBuild);\n    this._accountNameParameter.grantRead(branchBuild);\n    if (this._features.kafkaIntegration) {\n      this.grantPermissionsForKafkaIntegration(branchBuild, 'BranchKafkaIntegrationPolicy');\n    }\n  }\n\n  private addVulnerabilityPipeline(props: PipelineStackProps) {\n    const vulnerabilityBuild = new RioCodeBuildProject(this, 'VulnerabilityChecks', {\n      input: this._inputMasterTriggerFile,\n      partialBuildSpec: createVulnerabilityBuildSpec(this._features),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n      cacheBucket: this._cacheBucket,\n    });\n    const vulnerabilityPipeline = new codepipeline.Pipeline(this, 'VulnerabilityPipeline', {\n      artifactBucket: this._cacheBucket,\n      pipelineType: this._codePipelineType,\n    });\n    const vulnerabilityCodePipeline = new pipelines.CodePipeline(vulnerabilityPipeline, 'CodePipeline', {\n      codePipeline: vulnerabilityPipeline,\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    Tags.of(vulnerabilityPipeline).add('pipeline_type', 'vulnerability');\n\n    vulnerabilityCodePipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityCodePipeline.buildPipeline();\n    Tags.of(vulnerabilityBuild.project).add('project_type', 'vulnerability_check');\n    this._nistDataMirrorUrl.grantRead(vulnerabilityBuild);\n\n    const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', {\n      schedule: events.Schedule.expression(props.pipelineSchedules?.vulnerabilityPipeline || 'cron(0 5 ? * MON-FRI *)'),\n    });\n    vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityCodePipeline.pipeline));\n\n    if (props.datadogAlertType === 'opsgenie') {\n      throw Error('The OpsGenie alertType is not supported anymore. Please use the vulnerabilityNotification property instead.');\n    }\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n      notification: props.vulnerabilityNotification,\n    });\n  }\n\n  private createStripAssetsStep(pipeline: pipelines.CodePipeline): CodeBuildStep {\n    // CloudAssemblyArtifacts must be smaller than 256MB. Due to the gradle artifact we are exceeding this limit and pipeline fails in deployment step.\n    // Issue is known and not fixed for already some years. See: https://github.com/aws/aws-cdk/issues/9917\n    // Dirty fix: Assets are already uploaded and thus not needed. Remove them from pipeline artifact.\n    return new CodeBuildStep(\n      'StripAssetsFromAssembly', {\n        input: pipeline.cloudAssemblyFileSet,\n        commands: [\n          'S3_PATH=${CODEBUILD_SOURCE_VERSION#\"arn:aws:s3:::\"}',\n          'ZIP_ARCHIVE=$(basename $S3_PATH)',\n          'rm -rfv asset.*',\n          'zip -r -q -A $ZIP_ARCHIVE *',\n          'aws s3 cp $ZIP_ARCHIVE s3://$S3_PATH',\n        ],\n        buildEnvironment: {\n          buildImage: LinuxLambdaBuildImage.AMAZON_LINUX_2023_NODE_20,\n          computeType: ComputeType.LAMBDA_1GB,\n        },\n      },\n    );\n  }\n\n  private createCapabilityMonitoringDeployStep(mainBuild: CodeBuildStep, props: PipelineStackProps): CodeBuildStep | undefined {\n    if (props.monitoringDeployStepProps) {\n      const monitoringArtifacts = Object.keys(props.monitoringDeployStepProps.monitoringArtifacts).map((key) => {\n        const output = mainBuild.addOutputDirectory(key);\n        return {\n          input: output,\n          files: props.monitoringDeployStepProps!.monitoringArtifacts[key],\n        };\n      });\n      return new RioCapabilityMonitoringDeployStep(this, 'DeployCapabilityMonitoring', {\n        monitoringArtifacts: monitoringArtifacts,\n      });\n    } else {\n      return undefined;\n    }\n  }\n\n  private createSecretsDeployStep(props: PipelineStackProps): rio.RioSecretsDeployStep | undefined {\n    if (props.secretsDeployStepProps) {\n      return new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n        ...props.secretsDeployStepProps,\n        input: this._inputMasterTriggerFile,\n      });\n    } else {\n      return undefined;\n    }\n  }\n\n  private createDeployFrontendDeployStep(mainBuild: CodeBuildStep): CodeBuildStep | undefined {\n    if (!this._features.frontendBucketName) {\n      return undefined;\n    }\n    const frontendBuildOutput = mainBuild.addOutputDirectory('build');\n    return new CodeBuildStep('DeployFrontend', {\n      input: frontendBuildOutput,\n      buildEnvironment: {\n        buildImage: LinuxLambdaBuildImage.AMAZON_LINUX_2023_NODE_20,\n        computeType: ComputeType.LAMBDA_1GB,\n      },\n      commands: [\n        `aws s3 sync --exclude index.html --cache-control max-age=31536000 ./ 's3://${this._features.frontendBucketName}'`,\n        `aws s3 cp --cache-control no-cache index.html 's3://${this._features.frontendBucketName}'`,\n      ],\n    });\n  }\n\n  private grantPermissionsForKafkaIntegration(buildProject: RioCodeBuildProject, policyId: string) {\n    const buildProjectRole = buildProject.project.role;\n    if (buildProjectRole) {\n      buildProjectRole.addManagedPolicy(\n        ManagedPolicy.fromManagedPolicyArn(this,\n          policyId,\n          Fn.importValue('kafka-integration-policy-arn'),\n        ),\n      );\n    } else {\n      throw Error(`Could not add managed policy for kafka-integration to CodeBuild project of ${buildProject.id} due to missing role.`);\n    }\n  }\n\n  private loadBuildSpecFromFile(buildSpecPath?: string): BuildSpec | undefined {\n    if (!buildSpecPath) {\n      return undefined;\n    }\n    return BuildSpec.fromObject(yaml.load(fs.readFileSync(buildSpecPath, { encoding: 'utf-8' })) as Object);\n  }\n\n  private renamePipelineToLowerCase(pipeline: IPipeline): Reference {\n    const upperToLowerCr = new cdk.CustomResource(this, `${pipeline.node.id}-UpperToLower`, {\n      resourceType: 'Custom::UpperToLower',\n      serviceToken: UpperToLower.getOrCreate(this).provider.serviceToken,\n      properties: {\n        Upper: pipeline.pipelineName,\n      },\n    });\n    return upperToLowerCr.getAtt('Lower');\n  }\n\n  private tagCodeBuildProject(project: CodeBuildStep | undefined, key: string, value: string) {\n    if (project) {\n      Tags.of(project.project).add(key, value);\n    }\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
],
|
|
16
16
|
"main": "lib/index.js",
|
|
17
17
|
"license": "Apache-2.0",
|
|
18
|
-
"version": "6.
|
|
18
|
+
"version": "6.15.0-alpha.0",
|
|
19
19
|
"types": "lib/index.d.ts",
|
|
20
20
|
"stability": "stable",
|
|
21
21
|
"exports": {
|
|
@@ -45,10 +45,10 @@
|
|
|
45
45
|
},
|
|
46
46
|
"scripts": {
|
|
47
47
|
"compile": "jsii",
|
|
48
|
-
"build": "npm run compile && node esbuild.mjs && npm run
|
|
49
|
-
"copy-assets": "copyfiles --error --up 1 src/contributions/team-transport-two/pipeline/buildspecs/buildspec*.yaml lib",
|
|
48
|
+
"build": "npm run compile && node esbuild.mjs && npm run eslint && npm test",
|
|
50
49
|
"watch": "jsii -w",
|
|
51
50
|
"bump": "commit-and-tag-version -a -i docs/changelog.md",
|
|
51
|
+
"bump:alpha": "commit-and-tag-version -a -i docs/changelog.md --prerelease alpha",
|
|
52
52
|
"test": "jest --coverage",
|
|
53
53
|
"test:watch": "jest --watch",
|
|
54
54
|
"eslint": "eslint --ext .ts,.tsx --no-error-on-unmatched-pattern src test",
|
|
@@ -57,8 +57,10 @@
|
|
|
57
57
|
"cdk": "cdk",
|
|
58
58
|
"release:check": "node release-commit-check.js",
|
|
59
59
|
"release:build": "npm run build && npm run docgen && npm run bump",
|
|
60
|
+
"release:build:alpha": "npm run build && npm run docgen && npm run bump:alpha",
|
|
60
61
|
"release:push": "echo '✅ pushing release' && git push origin master --follow-tags",
|
|
61
62
|
"release": "npm run release:check && npm run release:build",
|
|
63
|
+
"release:alpha": "npm run release:check && npm run release:build:alpha",
|
|
62
64
|
"release:dry-run": "npm run build && npm run docgen && npm run release:check && commit-and-tag-version -i docs/changelog.md -a --dry-run"
|
|
63
65
|
},
|
|
64
66
|
"devDependencies": {
|
|
@@ -74,7 +76,6 @@
|
|
|
74
76
|
"aws-sdk-client-mock": "^4.1.0",
|
|
75
77
|
"commit-and-tag-version": "^12.5.0",
|
|
76
78
|
"constructs": "10.4.2",
|
|
77
|
-
"copyfiles": "2.4.1",
|
|
78
79
|
"esbuild": "0.24.0",
|
|
79
80
|
"eslint": "8.54.0",
|
|
80
81
|
"eslint-import-resolver-node": "0.3.9",
|
package/version.json
CHANGED
package/lib/contributions/team-transport-two/pipeline/buildspecs/buildspec-vulnerability-checks.yaml
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
version: 0.2
|
|
2
|
-
env:
|
|
3
|
-
variables:
|
|
4
|
-
LANG: C.UTF-8
|
|
5
|
-
parameter-store:
|
|
6
|
-
NIST_DATA_MIRROR_URL: /config/nist-data-mirror/url
|
|
7
|
-
phases:
|
|
8
|
-
install:
|
|
9
|
-
runtime-versions:
|
|
10
|
-
java: corretto17
|
|
11
|
-
build:
|
|
12
|
-
commands:
|
|
13
|
-
# Keep this echo statement for identifying the default buildspec in our test
|
|
14
|
-
- echo "Using standard gradle build spec for vulnerability checks..."
|
|
15
|
-
|
|
16
|
-
# RUNNING OWASP VULNERABILITY CHECK
|
|
17
|
-
- ./gradlew -Dorg.gradle.jvmargs=-Xmx4g dependencyCheckAnalyze
|
|
18
|
-
cache:
|
|
19
|
-
paths:
|
|
20
|
-
- /root/.cache/**/*
|
|
21
|
-
- /root/.gradle/caches/**/*
|
|
22
|
-
- /root/.gradle/wrapper/**/*
|
|
23
|
-
- /root/.gradle/dependency-check-data/**/*
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
version: '0.2'
|
|
2
|
-
env:
|
|
3
|
-
parameter-store:
|
|
4
|
-
SERVICE_KEYSTORE_PASSWORD: /config/${SERVICE_NAME}/service-keystore-password
|
|
5
|
-
LICENSE_BUCKET_NAME: /config/oss-licenses/bucket-name
|
|
6
|
-
ACCOUNT_NAME: /config/account/name
|
|
7
|
-
phases:
|
|
8
|
-
install:
|
|
9
|
-
runtime-versions:
|
|
10
|
-
java: corretto17
|
|
11
|
-
nodejs: 20
|
|
12
|
-
pre_build:
|
|
13
|
-
commands:
|
|
14
|
-
- (echo "Build triggered by commit " && git log --pretty=format:"%h%x09%an%x09%s" -n 1 ) | tr -d "\n"
|
|
15
|
-
build:
|
|
16
|
-
commands:
|
|
17
|
-
# Keep this echo statement for identifying the default buildspec in our test
|
|
18
|
-
- echo "Using standard gradle build spec..."
|
|
19
|
-
|
|
20
|
-
# BUILD AND TEST
|
|
21
|
-
- ./gradlew clean build
|
|
22
|
-
|
|
23
|
-
# LICENSE CHECKING
|
|
24
|
-
- set -u; aws s3 cp s3://${LICENSE_BUCKET_NAME}/whitelist-gradle.txt licenses/approved_licenses.txt
|
|
25
|
-
- ./gradlew checkLicenses
|
|
26
|
-
- set -u; aws s3 cp licenses/licenses.txt s3://${LICENSE_BUCKET_NAME}/reports/${ACCOUNT_NAME}/${SERVICE_NAME}.txt
|
|
27
|
-
|
|
28
|
-
# SELF CERT SIGNING
|
|
29
|
-
- set -u; keytool -genkey -alias InternalServiceCertificate -keyalg RSA -keystore containerfiles/service-keystore.p12 -validity 3650 -storetype PKCS12 -dname "CN=internal.service.${SERVICE_NAME}.${HOSTED_ZONE}, OU=Logistics, O=Rio, L=Munich, ST=BY, C=DE" -keypass ${SERVICE_KEYSTORE_PASSWORD} -storepass ${SERVICE_KEYSTORE_PASSWORD}
|
|
30
|
-
|
|
31
|
-
# DOCKER IMAGE BUILD
|
|
32
|
-
- ./gradlew jibBuildTar --quiet
|
|
33
|
-
|
|
34
|
-
# npm synth action
|
|
35
|
-
- cd infrastructure
|
|
36
|
-
- npm ci
|
|
37
|
-
# mute stdout of cdk synth to not dump the resulting Cfn template in logs
|
|
38
|
-
- npm run cdk synth 1> /dev/null
|
|
39
|
-
|
|
40
|
-
# In pipeline: Error parsing reference: is not a valid repository/tag: invalid reference format.
|
|
41
|
-
# workaround due to https://github.com/aws/aws-cdk/issues/18044',
|
|
42
|
-
- find ./ -type f -name "*DeployApplicationStacks*.assets.json" -print0 | xargs -0 sed --in-place 's|docker load -i asset.|docker load -i ../asset.|g'
|
|
43
|
-
|
|
44
|
-
- cd ..
|
|
45
|
-
post_build:
|
|
46
|
-
commands:
|
|
47
|
-
- (echo "Build triggered by commit " && git log --pretty=format:"%h%x09%an%x09%s" -n 1 ) | tr -d "\n"
|
|
48
|
-
reports:
|
|
49
|
-
JunitTestResults:
|
|
50
|
-
files:
|
|
51
|
-
- '**/*'
|
|
52
|
-
base-directory: build/test-results
|
|
53
|
-
|
|
54
|
-
cache:
|
|
55
|
-
paths:
|
|
56
|
-
- /cert/**/*
|
|
57
|
-
- /root/.cache/**/*
|
|
58
|
-
- /root/.gradle/caches/**/*
|
|
59
|
-
- /root/.gradle/wrapper/**/*
|
|
60
|
-
- /root/google-cloud-tools-java/jib/**/*
|
|
61
|
-
- target/jib-cache/**/*
|