@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.
@@ -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 (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {
102
+ if (this._features.branchPipeline) {
101
103
  this._branchCodeBuildProject = this.createRioCodeBuildProject('BranchBuild', this._inputBranchTriggerFile, props);
102
- this.addBranchPipeline(props, this._branchCodeBuildProject);
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.23',
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: capabilityMonitoringDeployStep ? [capabilityMonitoringDeployStep] : undefined,
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
- if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {
172
- this._serviceKeystorePassword.grantRead(mainBuild);
173
- }
235
+ this._serviceKeystorePassword.grantRead(mainBuild);
174
236
  this._accountNameParameter.grantRead(mainBuild);
175
- if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {
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(props, branchBuild) {
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 (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {
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: this.loadBuildSpecFromFile(path.resolve(__dirname, 'buildspecs/buildspec-vulnerability-checks.yaml')),
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
- resolveDefaultBuildSpec(pipelineType) {
292
- switch (pipelineType) {
293
- case PipelineType.STANDARD_GRADLE:
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":";;;;;AAAA,yBAAyB;AACzB,6BAA6B;AAC7B,mCAAmC;AACnC,6CAA8F;AAC9F,6DAA4G;AAC5G,6DAA6D;AAE7D,6EAA6E;AAC7E,iDAAiD;AACjD,0DAA0D;AAC1D,iDAAoD;AAEpD,yCAAyC;AACzC,+CAAqD;AACrD,2CAA2C;AAE3C,mDAAmD;AACnD,qDAA0E;AAE1E,gCAAgC;AAChC,2DAAkD;AAClD,mDAAsD;AACtD,yDAAgH;AAChH,qEAA6E;AAG7E,sCAAsC;AACtC,0CAAiE;AACjE,gDAAiD;AA0IjD,IAAY,YAsCX;AAtCD,WAAY,YAAY;IAEtB;;;;;;;;;;;;OAYG;IACH,mDAAmC,CAAA;IACnC;;;;;;;;;;;;;OAaG;IACH,+DAA+C,CAAA;IAC/C;;;;;OAKG;IACH,mEAAmD,CAAA;AACrD,CAAC,EAtCW,YAAY,4BAAZ,YAAY,QAsCvB;AAcD,MAAa,aAAc,SAAQ,mBAAK;IAetC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAyB;QACjE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,+BAA+B;QAC/B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,eAAe,EAAE,gBAAE,CAAC,WAAW,CAAC,iCAAiC,CAAC,CAAC,CAAC;QAClH,IAAI,CAAC,YAAY,GAAG,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,aAAa,EAAE;YACrD,aAAa,EAAE,2BAAa,CAAC,OAAO;YACpC,iBAAiB,EAAE,IAAI;YACvB,cAAc,EAAE;gBACd;oBACE,UAAU,EAAE,sBAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC7B,mCAAmC,EAAE,sBAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;iBACtD;aACF;SACF,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,cAAc,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;QACjE,IAAI,CAAC,uBAAuB,GAAG,SAAS,CAAC,kBAAkB,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,WAAW,YAAY,GAAG,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE,EAAE,OAAO,EAAE,oBAAoB,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QAC/L,IAAI,CAAC,uBAAuB,GAAG,SAAS,CAAC,kBAAkB,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,WAAW,YAAY,GAAG,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE,EAAE,OAAO,EAAE,oBAAoB,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QAE/L,IAAI,CAAC,2BAA2B,GAAG,GAAG,CAAC,eAAe,CAAC,6BAA6B,CAAC,IAAI,EAAE,4BAA4B,EAAE,EAAE,aAAa,EAAE,kCAAkC,EAAE,CAAC,CAAC;QAChL,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,CAAC,2BAA2B,CAAC,WAAW,CAAC,CAAC;QAC5H,IAAI,CAAC,wBAAwB,GAAG,GAAG,CAAC,eAAe,CAAC,mCAAmC,CAAC,IAAI,EAAE,kBAAkB,EAAE;YAChH,aAAa,EAAE,WAAW,KAAK,CAAC,WAAW,4BAA4B;YACvE,OAAO,EAAE,CAAC;SACX,CAAC,CAAC;QACH,IAAI,CAAC,qBAAqB,GAAG,GAAG,CAAC,eAAe,CAAC,uBAAuB,CAAC,IAAI,EAAE,sBAAsB,EAAE,sBAAsB,CAAC,CAAC;QAC/H,IAAI,CAAC,kBAAkB,GAAG,GAAG,CAAC,eAAe,CAAC,mCAAmC,CAAC,IAAI,EAAE,mBAAmB,EAAE;YAC3G,aAAa,EAAE,8BAA8B;YAC7C,OAAO,EAAE,CAAC;SACX,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,gBAAgB,IAAI,YAAY,CAAC,YAAY,CAAC,EAAE,CAAC;QAEhF,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,yBAAyB,CAAC,WAAW,EAAE,IAAI,CAAC,uBAAuB,EAAE,KAAK,CAAC,CAAC;QAC9G,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAExD,IAAI,KAAK,CAAC,YAAY,KAAK,YAAY,CAAC,uBAAuB,EAAE,CAAC;YAChE,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,yBAAyB,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,KAAK,CAAC,CAAC;YAClH,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,uBAAuB,CAAC,CAAC;YAC5D,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,CAAC,OAAO,EAAE,WAAW,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;QACnE,IAAI,mBAAW,CAAC,IAAI,EAAE,aAAa,EAAE;YACnC,OAAO,EAAE,0BAAkB,CAAC,gBAAgB;YAC5C,WAAW;YACX,OAAO;YACP,OAAO,EAAE,QAAQ;SAClB,CAAC,CAAC;IACL,CAAC;IAED,IAAW,oBAAoB;QAC7B,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAED,IAAW,sBAAsB;QAC/B,IAAI,IAAI,CAAC,uBAAuB,IAAI,SAAS,EAAE,CAAC;YAC9C,MAAM,KAAK,CAAC,iFAAiF,CAAC,CAAC;QACjG,CAAC;QACD,OAAO,IAAI,CAAC,uBAAuB,CAAC;IACtC,CAAC;IAEO,yBAAyB,CAAC,IAAY,EAAE,WAA+B,EAAE,KAAyB;QACxG,OAAO,IAAI,mCAAmB,CAAC,IAAI,EAAE,IAAI,EAAE;YACzC,KAAK,EAAE,WAAW;YAClB,eAAe,EAAE,wBAAwB;YACzC,gBAAgB,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,gBAAgB,EAAE,oBAAoB;gBACxF,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YACnD,gBAAgB,EAAE,KAAK,EAAE,gBAAgB,EAAE,gBAAgB;YAC3D,cAAc,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ;YACzC,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,WAAW,EAAE,IAAI,CAAC,YAAY;SAC/B,CAAC,CAAC;IACL,CAAC;IAEO,eAAe,CAAC,KAAyB,EAAE,SAAwB;QACzE,MAAM,QAAQ,GAAG,IAAI,YAAY,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE;YAC3D,cAAc,EAAE,IAAI,CAAC,YAAY;YACjC,YAAY,EAAE,IAAI,CAAC,iBAAiB;SACrC,CAAC,CAAC;QACH,MAAM,YAAY,GAAG,IAAI,SAAS,CAAC,YAAY,CAAC,QAAQ,EAAE,cAAc,EAAE;YACxE,YAAY,EAAE,QAAQ;YACtB,KAAK,EAAE,SAAS;SACjB,CAAC,CAAC;QACH,kBAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;QAEhD,MAAM,eAAe,GAAG,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC;QACjE,YAAY,CAAC,OAAO,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QAEjE,MAAM,8BAA8B,GAAG,IAAI,CAAC,oCAAoC,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACnG,MAAM,sBAAsB,GAAG,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAEnE,YAAY,CAAC,QAAQ,CAAC,IAAI,+BAAW,CAAC,IAAI,EAAE,yBAAyB,EAAE;YACrE,eAAe,EAAE,KAAK,CAAC,eAAe;YACtC,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,+BAA+B;SAC9E,CAAC,EAAE;YACF,GAAG,EAAE,sBAAsB,CAAC,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,SAAS;YAClE,IAAI,EAAE,8BAA8B,CAAC,CAAC,CAAC,CAAC,8BAA8B,CAAC,CAAC,CAAC,CAAC,SAAS;SACpF,CAAC,CAAC;QACH,YAAY,CAAC,aAAa,EAAE,CAAC;QAE7B,IAAI,CAAC,mBAAmB,CAAC,eAAe,EAAE,cAAc,EAAE,cAAc,CAAC,CAAC;QAC1E,IAAI,CAAC,mBAAmB,CAAC,sBAAsB,EAAE,cAAc,EAAE,gBAAgB,CAAC,CAAC;QACnF,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,mBAAmB,CAAC,8BAA8B,EAAE,cAAc,EAAE,8BAA8B,CAAC,CAAC;QAEzG,IAAI,8BAA8B,EAAE,CAAC;YACnC,MAAM,+BAA+B,GAAG,eAAM,CAAC,cAAc,CAAC,IAAI,EAAE,iCAAiC,EAAE,+BAA+B,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YACtJ,+BAA+B,CAAC,UAAU,CAAC,8BAA8B,CAAC,CAAC;QAC7E,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,kBAAkB,EAAE;YACrD,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,iBAAiB,EAAE,YAAY,IAAI,qBAAqB,CAAC;SACrG,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEhE,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAClD,IAAI,CAAC,2BAA2B,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QACtD,IAAI,KAAK,CAAC,YAAY,KAAK,YAAY,CAAC,uBAAuB,EAAE,CAAC;YAChE,IAAI,CAAC,wBAAwB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAChD,IAAI,KAAK,CAAC,YAAY,KAAK,YAAY,CAAC,qBAAqB,EAAE,CAAC;YAC9D,IAAI,CAAC,mCAAmC,CAAC,SAAS,EAAE,wBAAwB,CAAC,CAAC;QAChF,CAAC;QACD,YAAY,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAE7E,IAAI,4CAAyB,CAAC,IAAI,EAAE,6BAA6B,EAAE;YACjE,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,YAAY,EAAE,IAAI,CAAC,yBAAyB,CAAC,QAAQ,CAAC;YACtD,SAAS,EAAE,IAAI,CAAC,OAAO;SACxB,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB,CAAC,KAAyB,EAAE,WAA0B;QAC7E,MAAM,cAAc,GAAG,IAAI,YAAY,CAAC,QAAQ,CAAC,IAAI,EAAE,gBAAgB,EAAE;YACvE,cAAc,EAAE,IAAI,CAAC,YAAY;YACjC,YAAY,EAAE,IAAI,CAAC,iBAAiB;SACrC,CAAC,CAAC;QACH,MAAM,kBAAkB,GAAG,IAAI,SAAS,CAAC,YAAY,CAAC,cAAc,EAAE,cAAc,EAAE;YACpF,YAAY,EAAE,cAAc;YAC5B,KAAK,EAAE,WAAW;YAClB,YAAY,EAAE,KAAK;SACpB,CAAC,CAAC;QACH,kBAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,GAAG,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;QACvD,kBAAkB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC/D,kBAAkB,CAAC,aAAa,EAAE,CAAC;QAEnC,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,cAAc,EAAE,cAAc,CAAC,CAAC;QAEtE,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;QACpD,IAAI,CAAC,2BAA2B,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACxD,IAAI,CAAC,wBAAwB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACrD,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAClD,IAAI,KAAK,CAAC,YAAY,KAAK,YAAY,CAAC,qBAAqB,EAAE,CAAC;YAC9D,IAAI,CAAC,mCAAmC,CAAC,WAAW,EAAE,8BAA8B,CAAC,CAAC;QACxF,CAAC;IACH,CAAC;IAEO,wBAAwB,CAAC,KAAyB;QACxD,MAAM,kBAAkB,GAAG,IAAI,mCAAmB,CAAC,IAAI,EAAE,qBAAqB,EAAE;YAC9E,KAAK,EAAE,IAAI,CAAC,uBAAuB;YACnC,gBAAgB,EAAE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,gDAAgD,CAAC,CAAC;YACvH,gBAAgB,EAAE,KAAK,EAAE,gBAAgB,EAAE,gBAAgB;YAC3D,cAAc,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ;YACzC,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,WAAW,EAAE,IAAI,CAAC,YAAY;SAC/B,CAAC,CAAC;QACH,MAAM,qBAAqB,GAAG,IAAI,YAAY,CAAC,QAAQ,CAAC,IAAI,EAAE,uBAAuB,EAAE;YACrF,cAAc,EAAE,IAAI,CAAC,YAAY;YACjC,YAAY,EAAE,IAAI,CAAC,iBAAiB;SACrC,CAAC,CAAC;QACH,MAAM,yBAAyB,GAAG,IAAI,SAAS,CAAC,YAAY,CAAC,qBAAqB,EAAE,cAAc,EAAE;YAClG,YAAY,EAAE,qBAAqB;YACnC,KAAK,EAAE,kBAAkB;YACzB,YAAY,EAAE,KAAK;SACpB,CAAC,CAAC;QACH,kBAAI,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,GAAG,CAAC,eAAe,EAAE,eAAe,CAAC,CAAC;QAErE,yBAAyB,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;QACrF,yBAAyB,CAAC,aAAa,EAAE,CAAC;QAC1C,kBAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,cAAc,EAAE,qBAAqB,CAAC,CAAC;QAC/E,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;QAEtD,MAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,+BAA+B,EAAE;YAC/E,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,iBAAiB,EAAE,qBAAqB,IAAI,yBAAyB,CAAC;SAClH,CAAC,CAAC;QACH,iBAAiB,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC,yBAAyB,CAAC,QAAQ,CAAC,CAAC,CAAC;QAE1F,IAAI,KAAK,CAAC,gBAAgB,KAAK,UAAU,EAAE,CAAC;YAC1C,MAAM,KAAK,CAAC,6GAA6G,CAAC,CAAC;QAC7H,CAAC;QACD,IAAI,kEAA+C,CAAC,IAAI,EAAE,mDAAmD,EAAE;YAC7G,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,YAAY,EAAE,IAAI,CAAC,yBAAyB,CAAC,qBAAqB,CAAC;YACnE,SAAS,EAAE,IAAI,CAAC,OAAO;YACvB,YAAY,EAAE,KAAK,CAAC,yBAAyB;SAC9C,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB,CAAC,QAAgC;QAC5D,mJAAmJ;QACnJ,uGAAuG;QACvG,kGAAkG;QAClG,OAAO,IAAI,yBAAa,CACtB,yBAAyB,EAAE;YACzB,KAAK,EAAE,QAAQ,CAAC,oBAAoB;YACpC,QAAQ,EAAE;gBACR,qDAAqD;gBACrD,kCAAkC;gBAClC,iBAAiB;gBACjB,6BAA6B;gBAC7B,sCAAsC;aACvC;YACD,gBAAgB,EAAE;gBAChB,UAAU,EAAE,qCAAqB,CAAC,yBAAyB;gBAC3D,WAAW,EAAE,2BAAW,CAAC,UAAU;aACpC;SACF,CACF,CAAC;IACJ,CAAC;IAEO,oCAAoC,CAAC,SAAwB,EAAE,KAAyB;QAC9F,IAAI,KAAK,CAAC,yBAAyB,EAAE,CAAC;YACpC,MAAM,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,yBAAyB,CAAC,mBAAmB,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;gBACvG,MAAM,MAAM,GAAG,SAAS,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;gBACjD,OAAO;oBACL,KAAK,EAAE,MAAM;oBACb,KAAK,EAAE,KAAK,CAAC,yBAA0B,CAAC,mBAAmB,CAAC,GAAG,CAAC;iBACjE,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,OAAO,IAAI,0DAAiC,CAAC,IAAI,EAAE,4BAA4B,EAAE;gBAC/E,mBAAmB,EAAE,mBAAmB;aACzC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAEO,uBAAuB,CAAC,KAAyB;QACvD,IAAI,KAAK,CAAC,sBAAsB,EAAE,CAAC;YACjC,OAAO,IAAI,GAAG,CAAC,oBAAoB,CAAC,IAAI,EAAE,eAAe,EAAE;gBACzD,GAAG,KAAK,CAAC,sBAAsB;gBAC/B,KAAK,EAAE,IAAI,CAAC,uBAAuB;aACpC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAEO,uBAAuB,CAAC,YAA0B;QACxD,QAAQ,YAAY,EAAE,CAAC;YACrB,KAAK,YAAY,CAAC,eAAe;gBAC/B,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,2BAA2B,CAAC,CAAC;YAC9D,KAAK,YAAY,CAAC,qBAAqB;gBACrC,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,iCAAiC,CAAC,CAAC;YACpE,KAAK,YAAY,CAAC,uBAAuB;gBACvC,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,0CAA0C,CAAC,CAAC;QAC/E,CAAC;IACH,CAAC;IAEO,mCAAmC,CAAC,YAAiC,EAAE,QAAgB;QAC7F,MAAM,gBAAgB,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC;QACnD,IAAI,gBAAgB,EAAE,CAAC;YACrB,gBAAgB,CAAC,gBAAgB,CAC/B,uBAAa,CAAC,oBAAoB,CAAC,IAAI,EACrC,QAAQ,EACR,gBAAE,CAAC,WAAW,CAAC,8BAA8B,CAAC,CAC/C,CACF,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,MAAM,KAAK,CAAC,8EAA8E,YAAY,CAAC,EAAE,uBAAuB,CAAC,CAAC;QACpI,CAAC;IACH,CAAC;IAEO,qBAAqB,CAAC,aAAqB;QACjD,OAAO,yBAAS,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,aAAa,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAW,CAAC,CAAC;IAC1G,CAAC;IAEO,yBAAyB,CAAC,QAAmB;QACnD,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,eAAe,EAAE;YACtF,YAAY,EAAE,sBAAsB;YACpC,YAAY,EAAE,uBAAY,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,YAAY;YAClE,UAAU,EAAE;gBACV,KAAK,EAAE,QAAQ,CAAC,YAAY;aAC7B;SACF,CAAC,CAAC;QACH,OAAO,cAAc,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAEO,mBAAmB,CAAC,OAAkC,EAAE,GAAW,EAAE,KAAa;QACxF,IAAI,OAAO,EAAE,CAAC;YACZ,kBAAI,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;;AAtTH,sCAuTC","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.14.0",
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 copy-assets && npm run eslint && npm test",
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
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": "6.14.0"
2
+ "version": "6.15.0-alpha.0"
3
3
  }
@@ -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/**/*
@@ -1,14 +0,0 @@
1
- version: '0.2'
2
- phases:
3
- install:
4
- runtime-versions:
5
- nodejs: 20
6
- build:
7
- commands:
8
- - cd infrastructure
9
- - npm ci
10
- - npm run cdk synth 1> /dev/null
11
- - cd ..
12
- cache:
13
- paths:
14
- - /root/.cache/**/*