@rio-cloud/cdk-v2-constructs 4.1.0 → 4.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +144 -22
- package/CHANGELOG.md +15 -0
- package/lib/contributions/team-transport-two/pipeline/build-project.d.ts +3 -3
- package/lib/contributions/team-transport-two/pipeline/build-project.js +4 -4
- package/lib/contributions/team-transport-two/pipeline/buildspecs/buildspec_infrastructure.yaml +14 -0
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.d.ts +36 -3
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.js +100 -63
- package/lib/kafka/index.d.ts +1 -0
- package/lib/kafka/index.js +2 -1
- package/lib/kafka/rio-kafka-event-source.d.ts +46 -0
- package/lib/kafka/rio-kafka-event-source.js +58 -0
- package/node_modules/argparse/CHANGELOG.md +216 -0
- package/node_modules/js-yaml/CHANGELOG.md +616 -0
- package/package.json +2 -2
- package/version.json +1 -1
|
@@ -40,40 +40,81 @@ var PipelineType;
|
|
|
40
40
|
* <p> This gradle command must be provided by the gradle project.
|
|
41
41
|
*/
|
|
42
42
|
PipelineType["STANDARD_GRADLE"] = "STANDARD_GRADLE";
|
|
43
|
+
/**
|
|
44
|
+
* Self-mutating codepipeline deploying the provided AppStack with additional steps needed to access Kafka.
|
|
45
|
+
*
|
|
46
|
+
* Comes with a pre-defined buildspec.yaml for a gradle project. This buildspec.yaml is used for both the main and
|
|
47
|
+
* branch pipeline and includes the following steps
|
|
48
|
+
* - build and test of the artifact via command "./gradlew clean build".
|
|
49
|
+
* <p> This gradle command must be provided by the gradle project.
|
|
50
|
+
* - license-check and upload of license-check-file via command "./gradlew checkLicenses".
|
|
51
|
+
* <p> This gradle command must be provided by the gradle project.
|
|
52
|
+
* - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer.
|
|
53
|
+
* - request a certificate to authenticate against Kafka via mutual TLS
|
|
54
|
+
* - build the container image via command "./gradlew jibBuildTar".
|
|
55
|
+
* <p> This gradle command must be provided by the gradle project.
|
|
56
|
+
*/
|
|
43
57
|
PipelineType["STANDARD_GRADLE_KAFKA"] = "STANDARD_GRADLE_KAFKA";
|
|
58
|
+
/**
|
|
59
|
+
* Self-mutating codepipeline deploying the provided AppStack.
|
|
60
|
+
*
|
|
61
|
+
* Comes with a pre-defined buildspec.yaml to synthesize the AppStack.
|
|
62
|
+
* No branch or vulnerability pipeline is created.
|
|
63
|
+
*/
|
|
64
|
+
PipelineType["STANDARD_INFRASTRUCTURE"] = "STANDARD_INFRASTRUCTURE";
|
|
44
65
|
})(PipelineType = exports.PipelineType || (exports.PipelineType = {}));
|
|
45
66
|
class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
46
67
|
constructor(scope, id, props) {
|
|
47
|
-
var _b, _c, _d, _e, _f;
|
|
48
68
|
super(scope, id, props);
|
|
49
|
-
//
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
const ossLicensesBucket = s3.Bucket.fromBucketName(this, 'OssLicensesBucket', ossLicensesBucketParameter.stringValue);
|
|
58
|
-
const serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {
|
|
69
|
+
// populate external parameters
|
|
70
|
+
this.bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', aws_cdk_lib_1.Fn.importValue('bitbucket-integration-s3-bucket'));
|
|
71
|
+
this.hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);
|
|
72
|
+
this.inputMasterTriggerFile = pipelines.CodePipelineSource.s3(this.bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });
|
|
73
|
+
this.inputBranchTriggerFile = pipelines.CodePipelineSource.s3(this.bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });
|
|
74
|
+
this.ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(this, 'OssLicensesBucketParameter', { parameterName: '/config/oss-licenses/bucket-name' });
|
|
75
|
+
this.ossLicensesBucket = s3.Bucket.fromBucketName(this, 'OssLicensesBucket', this.ossLicensesBucketParameter.stringValue);
|
|
76
|
+
this.serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {
|
|
59
77
|
parameterName: `/config/${props.serviceName}/service-keystore-password`,
|
|
60
78
|
version: 1,
|
|
61
79
|
});
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
parameterName: '/config/nist-data-mirror/url',
|
|
80
|
+
this.accountNameParameter = ssm.StringParameter.fromStringParameterName(this, 'AccountNameParameter', '/config/account/name');
|
|
81
|
+
this.nistDataMirrorUrl = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'NistDataMirrorUrl', {
|
|
82
|
+
parameterName: '/config/nist-data-mirror/url',
|
|
83
|
+
version: 1,
|
|
84
|
+
});
|
|
85
|
+
this.addMainPipeline(props);
|
|
86
|
+
if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {
|
|
87
|
+
this.addBranchPipeline(props);
|
|
88
|
+
this.addVulnerabilityPipeline(props);
|
|
89
|
+
}
|
|
90
|
+
const [feature, packageName] = __dirname.split(path.sep).reverse();
|
|
91
|
+
new index_1.Claidometer(this, 'Claidometer', {
|
|
92
|
+
product: index_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
93
|
+
packageName,
|
|
94
|
+
feature,
|
|
95
|
+
version: '0.0.5',
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
static addLifecycleRuleArtifactBucket(pipeline) {
|
|
99
|
+
const artifactsBucket = pipeline.pipeline.artifactBucket;
|
|
100
|
+
artifactsBucket.addLifecycleRule({
|
|
101
|
+
enabled: true,
|
|
102
|
+
expiration: aws_cdk_lib_1.Duration.days(90),
|
|
65
103
|
});
|
|
66
|
-
|
|
67
|
-
|
|
104
|
+
}
|
|
105
|
+
addMainPipeline(props) {
|
|
106
|
+
var _b, _c;
|
|
107
|
+
const mainBuild = new build_project_1.RioCodeBuildProject(this, 'MainBuild', {
|
|
108
|
+
input: this.inputMasterTriggerFile,
|
|
68
109
|
cdkOutDirectory: 'infrastructure/cdk.out',
|
|
69
110
|
partialBuildSpec: this.loadBuildSpecFromFile(((_b = props === null || props === void 0 ? void 0 : props.codeBuildOptions) === null || _b === void 0 ? void 0 : _b.partialBuildSpecPath) ||
|
|
70
111
|
this.resolveDefaultBuildSpec(props.pipelineType)),
|
|
71
112
|
buildEnvironment: (_c = props === null || props === void 0 ? void 0 : props.codeBuildOptions) === null || _c === void 0 ? void 0 : _c.buildEnvironment,
|
|
72
|
-
hostedZoneName: hostedZone.zoneName,
|
|
113
|
+
hostedZoneName: this.hostedZone.zoneName,
|
|
73
114
|
serviceName: props.serviceName,
|
|
74
115
|
});
|
|
75
116
|
const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {
|
|
76
|
-
synth:
|
|
117
|
+
synth: mainBuild,
|
|
77
118
|
});
|
|
78
119
|
// CloudAssemblyArtifacts must be smaller than 256MB. Due to the gradle artifact we are exceeding this limit and pipeline fails in deployment step.
|
|
79
120
|
// Issue is known and not fixed for already some years. See: https://github.com/aws/aws-cdk/issues/9917
|
|
@@ -97,7 +138,7 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
97
138
|
pre: props.secretsDeployStepProps ? [
|
|
98
139
|
new rio.RioSecretsDeployStep(this, 'DeploySecrets', {
|
|
99
140
|
...props.secretsDeployStepProps,
|
|
100
|
-
input: inputMasterTriggerFile,
|
|
141
|
+
input: this.inputMasterTriggerFile,
|
|
101
142
|
}),
|
|
102
143
|
] : undefined,
|
|
103
144
|
});
|
|
@@ -105,22 +146,31 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
105
146
|
const rule = new events.Rule(this, 'PipelineSchedule', { schedule: events.Schedule.expression('cron(0 9 ? * 2#1 *)') });
|
|
106
147
|
rule.addTarget(new targets.CodePipeline(pipeline.pipeline));
|
|
107
148
|
PipelineStack.addLifecycleRuleArtifactBucket(pipeline);
|
|
108
|
-
ossLicensesBucket.grantReadWrite(
|
|
109
|
-
ossLicensesBucketParameter.grantRead(
|
|
110
|
-
|
|
111
|
-
|
|
149
|
+
this.ossLicensesBucket.grantReadWrite(mainBuild);
|
|
150
|
+
this.ossLicensesBucketParameter.grantRead(mainBuild);
|
|
151
|
+
if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {
|
|
152
|
+
this.serviceKeystorePassword.grantRead(mainBuild);
|
|
153
|
+
}
|
|
154
|
+
this.accountNameParameter.grantRead(mainBuild);
|
|
112
155
|
if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {
|
|
113
|
-
this.grantPermissionsForKafkaIntegration(
|
|
156
|
+
this.grantPermissionsForKafkaIntegration(mainBuild, 'KafkaIntegrationPolicy');
|
|
114
157
|
}
|
|
115
158
|
pipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
159
|
+
new datadog_monitors_1.DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {
|
|
160
|
+
serviceName: props.serviceName,
|
|
161
|
+
pipelineName: this.renamePipelineToLowerCase(pipeline),
|
|
162
|
+
accountId: this.account,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
addBranchPipeline(props) {
|
|
166
|
+
var _b, _c;
|
|
167
|
+
const branchBuild = new build_project_1.RioCodeBuildProject(this, 'BranchBuild', {
|
|
168
|
+
input: this.inputBranchTriggerFile,
|
|
119
169
|
cdkOutDirectory: 'infrastructure/cdk.out',
|
|
120
|
-
partialBuildSpec: this.loadBuildSpecFromFile(((
|
|
170
|
+
partialBuildSpec: this.loadBuildSpecFromFile(((_b = props === null || props === void 0 ? void 0 : props.codeBuildOptions) === null || _b === void 0 ? void 0 : _b.partialBuildSpecPath) ||
|
|
121
171
|
this.resolveDefaultBuildSpec(props.pipelineType)),
|
|
122
|
-
buildEnvironment: (
|
|
123
|
-
hostedZoneName: hostedZone.zoneName,
|
|
172
|
+
buildEnvironment: (_c = props === null || props === void 0 ? void 0 : props.codeBuildOptions) === null || _c === void 0 ? void 0 : _c.buildEnvironment,
|
|
173
|
+
hostedZoneName: this.hostedZone.zoneName,
|
|
124
174
|
serviceName: props.serviceName,
|
|
125
175
|
});
|
|
126
176
|
const branchPipeline = new pipelines.CodePipeline(this, 'BranchPipeline', {
|
|
@@ -130,19 +180,21 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
130
180
|
branchPipeline.addWave('BranchBuild').addPost(branchBuild);
|
|
131
181
|
branchPipeline.buildPipeline();
|
|
132
182
|
PipelineStack.addLifecycleRuleArtifactBucket(branchPipeline);
|
|
133
|
-
ossLicensesBucket.grantReadWrite(branchBuild);
|
|
134
|
-
ossLicensesBucketParameter.grantRead(branchBuild);
|
|
135
|
-
serviceKeystorePassword.grantRead(branchBuild);
|
|
136
|
-
accountNameParameter.grantRead(branchBuild);
|
|
183
|
+
this.ossLicensesBucket.grantReadWrite(branchBuild);
|
|
184
|
+
this.ossLicensesBucketParameter.grantRead(branchBuild);
|
|
185
|
+
this.serviceKeystorePassword.grantRead(branchBuild);
|
|
186
|
+
this.accountNameParameter.grantRead(branchBuild);
|
|
137
187
|
if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {
|
|
138
|
-
this.grantPermissionsForKafkaIntegration(
|
|
188
|
+
this.grantPermissionsForKafkaIntegration(branchBuild, 'BranchKafkaIntegrationPolicy');
|
|
139
189
|
}
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
190
|
+
}
|
|
191
|
+
addVulnerabilityPipeline(props) {
|
|
192
|
+
var _b;
|
|
193
|
+
const vulnerabilityBuild = new build_project_1.RioCodeBuildProject(this, 'VulnerabilityChecks', {
|
|
194
|
+
input: this.inputMasterTriggerFile,
|
|
143
195
|
partialBuildSpec: this.loadBuildSpecFromFile(path.resolve(__dirname, 'buildspecs/buildspec-vulnerability-checks.yaml')),
|
|
144
|
-
buildEnvironment: (
|
|
145
|
-
hostedZoneName: hostedZone.zoneName,
|
|
196
|
+
buildEnvironment: (_b = props === null || props === void 0 ? void 0 : props.codeBuildOptions) === null || _b === void 0 ? void 0 : _b.buildEnvironment,
|
|
197
|
+
hostedZoneName: this.hostedZone.zoneName,
|
|
146
198
|
serviceName: props.serviceName,
|
|
147
199
|
});
|
|
148
200
|
const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {
|
|
@@ -151,39 +203,24 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
151
203
|
});
|
|
152
204
|
vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);
|
|
153
205
|
vulnerabilityPipeline.buildPipeline();
|
|
154
|
-
nistDataMirrorUrl.grantRead(vulnerabilityBuild);
|
|
206
|
+
this.nistDataMirrorUrl.grantRead(vulnerabilityBuild);
|
|
155
207
|
const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', { schedule: events.Schedule.expression('cron(0 5 ? * MON-FRI *)') });
|
|
156
208
|
vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityPipeline.pipeline));
|
|
157
209
|
PipelineStack.addLifecycleRuleArtifactBucket(vulnerabilityPipeline);
|
|
158
|
-
new datadog_monitors_1.DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {
|
|
159
|
-
serviceName: props.serviceName,
|
|
160
|
-
pipelineName: this.renamePipelineToLowerCase(pipeline),
|
|
161
|
-
accountId: this.account,
|
|
162
|
-
});
|
|
163
210
|
new datadog_monitors_1.DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {
|
|
164
211
|
serviceName: props.serviceName,
|
|
165
212
|
pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),
|
|
166
213
|
accountId: this.account,
|
|
167
214
|
});
|
|
168
|
-
const [feature, packageName] = __dirname.split(path.sep).reverse();
|
|
169
|
-
new index_1.Claidometer(this, 'Claidometer', {
|
|
170
|
-
product: index_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
171
|
-
packageName,
|
|
172
|
-
feature,
|
|
173
|
-
version: '0.0.3',
|
|
174
|
-
});
|
|
175
|
-
}
|
|
176
|
-
static addLifecycleRuleArtifactBucket(pipeline) {
|
|
177
|
-
const artifactsBucket = pipeline.pipeline.artifactBucket;
|
|
178
|
-
artifactsBucket.addLifecycleRule({
|
|
179
|
-
enabled: true,
|
|
180
|
-
expiration: aws_cdk_lib_1.Duration.days(90),
|
|
181
|
-
});
|
|
182
215
|
}
|
|
183
216
|
resolveDefaultBuildSpec(pipelineType) {
|
|
184
217
|
switch (pipelineType) {
|
|
185
|
-
case PipelineType.STANDARD_GRADLE:
|
|
186
|
-
|
|
218
|
+
case PipelineType.STANDARD_GRADLE:
|
|
219
|
+
return path.resolve(__dirname, 'buildspecs/buildspec.yaml');
|
|
220
|
+
case PipelineType.STANDARD_GRADLE_KAFKA:
|
|
221
|
+
return path.resolve(__dirname, 'buildspecs/buildspec_kafka.yaml');
|
|
222
|
+
case PipelineType.STANDARD_INFRASTRUCTURE:
|
|
223
|
+
return path.resolve(__dirname, 'buildspecs/buildspec_infrastructure.yaml');
|
|
187
224
|
}
|
|
188
225
|
}
|
|
189
226
|
grantPermissionsForKafkaIntegration(buildProject, policyId) {
|
|
@@ -212,4 +249,4 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
212
249
|
exports.PipelineStack = PipelineStack;
|
|
213
250
|
_a = JSII_RTTI_SYMBOL_1;
|
|
214
251
|
PipelineStack[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.PipelineStack", version: "0.0.0" };
|
|
215
|
-
//# 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, Stack, StackProps } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec } from 'aws-cdk-lib/aws-codebuild';\nimport * as codepipeline 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 * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as pipelines from 'aws-cdk-lib/pipelines';\nimport { CodeBuildStep } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport * as yaml from 'js-yaml';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful/upperToLower';\nimport { Application } from './application-stage';\nimport { RioGradleCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\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   * 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\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 definitiom\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 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  STANDARD_GRADLE_KAFKA = 'STANDARD_GRADLE_KAFKA',\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_4\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\n}\n\nexport class PipelineStack extends Stack {\n  private static addLifecycleRuleArtifactBucket(pipeline: pipelines.CodePipeline) {\n    const artifactsBucket = pipeline.pipeline.artifactBucket;\n    (artifactsBucket as s3.Bucket).addLifecycleRule({\n      enabled: true,\n      expiration: Duration.days(90),\n    });\n  }\n\n\n  constructor(scope: Construct, id: string, props: PipelineStackProps) {\n    super(scope, id, props);\n\n    // Creating the main pipeline\n    const bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', Fn.importValue('bitbucket-integration-s3-bucket'));\n    const hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);\n    const inputMasterTriggerFile = pipelines.CodePipelineSource.s3(bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n    const inputBranchTriggerFile = pipelines.CodePipelineSource.s3(bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n\n    const ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(\n      this,\n      'OssLicensesBucketParameter',\n      {\n        parameterName: '/config/oss-licenses/bucket-name',\n      },\n    );\n    const ossLicensesBucket = s3.Bucket.fromBucketName(\n      this,\n      'OssLicensesBucket',\n      ossLicensesBucketParameter.stringValue,\n    );\n    const serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {\n      parameterName: `/config/${props.serviceName}/service-keystore-password`,\n      version: 1,\n    });\n    const accountNameParameter = ssm.StringParameter.fromStringParameterName(\n      this,\n      'AccountNameParameter',\n      '/config/account/name',\n    );\n    const nistDataMirrorUrl = ssm.StringParameter.fromSecureStringParameterAttributes(\n      this,\n      'NistDataMirrorUrl',\n      {\n        parameterName: '/config/nist-data-mirror/url', version: 1,\n      },\n    );\n\n    const gradlebuild = new RioGradleCodeBuildProject(this, 'GradleBuild', {\n      input: inputMasterTriggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath ||\n          this.resolveDefaultBuildSpec( props.pipelineType)),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      synth: gradlebuild,\n    });\n\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    const stripAssetsStep = 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      },\n    );\n\n    pipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    pipeline.addStage(new Application(this, 'DeployApplicationStacks', {\n      appStackFactory: props.appStackFactory,\n      serviceName: props.serviceName,\n      version: codepipeline.GlobalVariables.executionId,\n    }), {\n      pre: props.secretsDeployStepProps ? [\n        new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n          ...props.secretsDeployStepProps,\n          input: inputMasterTriggerFile,\n        }),\n      ] : undefined,\n    });\n    pipeline.buildPipeline();\n\n    const rule = new events.Rule(this, 'PipelineSchedule', { schedule: events.Schedule.expression('cron(0 9 ? * 2#1 *)') });\n    rule.addTarget(new targets.CodePipeline(pipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(pipeline);\n    ossLicensesBucket.grantReadWrite(gradlebuild);\n    ossLicensesBucketParameter.grantRead(gradlebuild);\n    serviceKeystorePassword.grantRead(gradlebuild);\n    accountNameParameter.grantRead(gradlebuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(gradlebuild, 'KafkaIntegrationPolicy');\n    }\n    pipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);\n\n    // Branch pipeline\n    const branchBuild = new RioGradleCodeBuildProject(this, 'BranchBuild', {\n      input: inputBranchTriggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath ||\n          this.resolveDefaultBuildSpec(props.pipelineType)),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const branchPipeline = new pipelines.CodePipeline(this, 'BranchPipeline', {\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    PipelineStack.addLifecycleRuleArtifactBucket(branchPipeline);\n    ossLicensesBucket.grantReadWrite(branchBuild);\n    ossLicensesBucketParameter.grantRead(branchBuild);\n    serviceKeystorePassword.grantRead(branchBuild);\n    accountNameParameter.grantRead(branchBuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(gradlebuild, 'BranchKafkaIntegrationPolicy');\n    }\n\n    // Vulnerability Pipeline\n    const vulnerabilityBuild = new RioGradleCodeBuildProject(this, 'VulnerabilityChecks', {\n      input: inputMasterTriggerFile,\n      partialBuildSpec: this.loadBuildSpecFromFile(path.resolve(__dirname, 'buildspecs/buildspec-vulnerability-checks.yaml')),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n    nistDataMirrorUrl.grantRead(vulnerabilityBuild);\n\n    const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', { schedule: events.Schedule.expression('cron(0 5 ? * MON-FRI *)') });\n    vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityPipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(vulnerabilityPipeline);\n\n    new DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(pipeline),\n      accountId: this.account,\n    });\n\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\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.3',\n    });\n  }\n\n  private resolveDefaultBuildSpec(pipelineType: PipelineType) {\n    switch (pipelineType) {\n      case PipelineType.STANDARD_GRADLE: return path.resolve(__dirname, 'buildspecs/buildspec.yaml');\n      case PipelineType.STANDARD_GRADLE_KAFKA: return path.resolve(__dirname, 'buildspecs/buildspec_kafka.yaml');\n    }\n  }\n\n  private grantPermissionsForKafkaIntegration(buildProject: RioGradleCodeBuildProject, 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: pipelines.CodePipeline): 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.pipeline.pipelineName,\n      },\n    });\n    return upperToLowerCr.getAtt('Lower');\n  }\n}\n"]}
|
|
252
|
+
//# 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, Stack, StackProps } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec } from 'aws-cdk-lib/aws-codebuild';\nimport * as codepipeline 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 { 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 * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful/upperToLower';\nimport { Application } from './application-stage';\nimport { RioCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\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   * 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\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 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_4\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\n}\n\nexport class PipelineStack extends Stack {\n  private static addLifecycleRuleArtifactBucket(pipeline: pipelines.CodePipeline) {\n    const artifactsBucket = pipeline.pipeline.artifactBucket;\n    (artifactsBucket as s3.Bucket).addLifecycleRule({\n      enabled: true,\n      expiration: Duration.days(90),\n    });\n  }\n\n  private readonly bucket: 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\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.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.addMainPipeline(props);\n\n    if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {\n      this.addBranchPipeline(props);\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.5',\n    });\n  }\n\n  private addMainPipeline(props: PipelineStackProps) {\n    const mainBuild = new RioCodeBuildProject(this, 'MainBuild', {\n      input: this.inputMasterTriggerFile,\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    });\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      synth: mainBuild,\n    });\n\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    const stripAssetsStep = 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      },\n    );\n\n    pipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    pipeline.addStage(new Application(this, 'DeployApplicationStacks', {\n      appStackFactory: props.appStackFactory,\n      serviceName: props.serviceName,\n      version: codepipeline.GlobalVariables.executionId,\n    }), {\n      pre: props.secretsDeployStepProps ? [\n        new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n          ...props.secretsDeployStepProps,\n          input: this.inputMasterTriggerFile,\n        }),\n      ] : undefined,\n    });\n    pipeline.buildPipeline();\n\n    const rule = new events.Rule(this, 'PipelineSchedule', { schedule: events.Schedule.expression('cron(0 9 ? * 2#1 *)') });\n    rule.addTarget(new targets.CodePipeline(pipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(pipeline);\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    pipeline.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) {\n    const branchBuild = new RioCodeBuildProject(this, 'BranchBuild', {\n      input: this.inputBranchTriggerFile,\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    });\n    const branchPipeline = new pipelines.CodePipeline(this, 'BranchPipeline', {\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    PipelineStack.addLifecycleRuleArtifactBucket(branchPipeline);\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    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n    this.nistDataMirrorUrl.grantRead(vulnerabilityBuild);\n\n    const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', { schedule: events.Schedule.expression('cron(0 5 ? * MON-FRI *)') });\n    vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityPipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(vulnerabilityPipeline);\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\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: pipelines.CodePipeline): 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.pipeline.pipelineName,\n      },\n    });\n    return upperToLowerCr.getAtt('Lower');\n  }\n}\n"]}
|
package/lib/kafka/index.d.ts
CHANGED
package/lib/kafka/index.js
CHANGED
|
@@ -12,4 +12,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
13
|
__exportStar(require("./kafka-topic"), exports);
|
|
14
14
|
__exportStar(require("./kafka-event-spec"), exports);
|
|
15
|
-
|
|
15
|
+
__exportStar(require("./rio-kafka-event-source"), exports);
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMva2Fma2EvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsZ0RBQThCO0FBQzlCLHFEQUFtQztBQUNuQywyREFBeUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2thZmthLXRvcGljJztcbmV4cG9ydCAqIGZyb20gJy4va2Fma2EtZXZlbnQtc3BlYyc7XG5leHBvcnQgKiBmcm9tICcuL3Jpby1rYWZrYS1ldmVudC1zb3VyY2UnO1xuIl19
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import * as lambda from 'aws-cdk-lib/aws-lambda';
|
|
2
|
+
import * as lambdaEventSource from 'aws-cdk-lib/aws-lambda-event-sources';
|
|
3
|
+
import * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';
|
|
4
|
+
/**
|
|
5
|
+
* Properties for RioKafkaEventSource
|
|
6
|
+
*/
|
|
7
|
+
export interface RioKafkaEventSourceProps extends lambdaEventSource.BaseStreamEventSourceProps {
|
|
8
|
+
/**
|
|
9
|
+
* The Kafka topic to subscribe to
|
|
10
|
+
*/
|
|
11
|
+
readonly topic: string;
|
|
12
|
+
/**
|
|
13
|
+
* The secret with the Kafka credentials, see https://docs.aws.amazon.com/msk/latest/developerguide/msk-authentication.html for details.
|
|
14
|
+
*
|
|
15
|
+
* You can use the `create-and-sign-certificate` script from the `kafka-integration` to create a suitable AWS Secrets Manager secret.
|
|
16
|
+
* Simply add the `--fqdn <fqdn> --lambda` parameters to the `create-and-sign-certificate` script and the script generates a secret named `kafka-integration/msk-certificate/<fqdn>` with all relevant data.
|
|
17
|
+
*
|
|
18
|
+
* Please note that we do only support the `--lambda` parameter if the `--fqdn` parameter is present.
|
|
19
|
+
* We encourage you to use the `--fqdn` parameter for all your Kafka consumers and producers as this eases the recovery process in the case of a disaster.
|
|
20
|
+
* (Otherwise, i.e., if you do not use the `--fqdn` parameter, your certificates CNAME contains the AWS account ID and you need to change all ACLs in case of a corrupted AWS account.)
|
|
21
|
+
*/
|
|
22
|
+
readonly secret: secretsmanager.ISecret;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Use the Rio Kafka as a streaming source for AWS Lambda.
|
|
26
|
+
*
|
|
27
|
+
* ```
|
|
28
|
+
* const lambda = new nodejs.NodejsFunction(this, 'KafkaConsumerFunction', {
|
|
29
|
+
* entry: 'path.to.handler.ts',
|
|
30
|
+
* handler: 'handlerName',
|
|
31
|
+
* });
|
|
32
|
+
*
|
|
33
|
+
* const secret = Secret.fromSecretNameV2(this, 'ConsumerSecret', 'kafka-integration/msk-certificate/<FQDN>')
|
|
34
|
+
*
|
|
35
|
+
* lambda.addEventSource(new RioKafkaEventSource({
|
|
36
|
+
* secret,
|
|
37
|
+
* topic: '<TOPIC/NAME>',
|
|
38
|
+
* startingPosition: StartingPosition.TRIM_HORIZON,
|
|
39
|
+
* }));
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
export declare class RioKafkaEventSource implements lambda.IEventSource {
|
|
43
|
+
private props;
|
|
44
|
+
constructor(props: RioKafkaEventSourceProps);
|
|
45
|
+
bind(target: lambda.IFunction): void;
|
|
46
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.RioKafkaEventSource = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const cdk = require("aws-cdk-lib");
|
|
7
|
+
const ec2 = require("aws-cdk-lib/aws-ec2");
|
|
8
|
+
const iam = require("aws-cdk-lib/aws-iam");
|
|
9
|
+
const lambdaEventSource = require("aws-cdk-lib/aws-lambda-event-sources");
|
|
10
|
+
const ssm = require("aws-cdk-lib/aws-ssm");
|
|
11
|
+
const rio = require("../rio-landing-zone");
|
|
12
|
+
/**
|
|
13
|
+
* Use the Rio Kafka as a streaming source for AWS Lambda.
|
|
14
|
+
*
|
|
15
|
+
* ```
|
|
16
|
+
* const lambda = new nodejs.NodejsFunction(this, 'KafkaConsumerFunction', {
|
|
17
|
+
* entry: 'path.to.handler.ts',
|
|
18
|
+
* handler: 'handlerName',
|
|
19
|
+
* });
|
|
20
|
+
*
|
|
21
|
+
* const secret = Secret.fromSecretNameV2(this, 'ConsumerSecret', 'kafka-integration/msk-certificate/<FQDN>')
|
|
22
|
+
*
|
|
23
|
+
* lambda.addEventSource(new RioKafkaEventSource({
|
|
24
|
+
* secret,
|
|
25
|
+
* topic: '<TOPIC/NAME>',
|
|
26
|
+
* startingPosition: StartingPosition.TRIM_HORIZON,
|
|
27
|
+
* }));
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
class RioKafkaEventSource {
|
|
31
|
+
constructor(props) {
|
|
32
|
+
this.props = props;
|
|
33
|
+
}
|
|
34
|
+
bind(target) {
|
|
35
|
+
const bootstrapServersParameter = ssm.StringParameter.fromStringParameterName(target, 'BootstrapServersParameter', '/config/kafka-integration/bootstrap-server');
|
|
36
|
+
const vpc = rio.RioLandingZone.getDefaultVpc(target);
|
|
37
|
+
const securityGroup = new ec2.SecurityGroup(target, 'LambdaSecurityGroup', { vpc });
|
|
38
|
+
const delegate = new lambdaEventSource.SelfManagedKafkaEventSource({
|
|
39
|
+
bootstrapServers: cdk.Fn.split(',', bootstrapServersParameter.stringValue),
|
|
40
|
+
...this.props,
|
|
41
|
+
vpc,
|
|
42
|
+
vpcSubnets: {
|
|
43
|
+
subnets: vpc.privateSubnets,
|
|
44
|
+
},
|
|
45
|
+
securityGroup,
|
|
46
|
+
authenticationMethod: lambdaEventSource.AuthenticationMethod.CLIENT_CERTIFICATE_TLS_AUTH,
|
|
47
|
+
});
|
|
48
|
+
delegate.bind(target);
|
|
49
|
+
this.props.secret.grantRead(target);
|
|
50
|
+
bootstrapServersParameter.grantRead(target);
|
|
51
|
+
const policy = iam.ManagedPolicy.fromManagedPolicyArn(target, 'ManagedAWSLambdaMSKExecutionRole', 'arn:aws:iam::aws:policy/service-role/AWSLambdaMSKExecutionRole');
|
|
52
|
+
target.role.addManagedPolicy(policy);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
exports.RioKafkaEventSource = RioKafkaEventSource;
|
|
56
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
57
|
+
RioKafkaEventSource[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.RioKafkaEventSource", version: "0.0.0" };
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmlvLWthZmthLWV2ZW50LXNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9rYWZrYS9yaW8ta2Fma2EtZXZlbnQtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQW1DO0FBQ25DLDJDQUEyQztBQUMzQywyQ0FBMkM7QUFFM0MsMEVBQTBFO0FBRTFFLDJDQUEyQztBQUUzQywyQ0FBMkM7QUF1QjNDOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQWEsbUJBQW1CO0lBRTlCLFlBQW9CLEtBQStCO1FBQS9CLFVBQUssR0FBTCxLQUFLLENBQTBCO0lBQ25ELENBQUM7SUFFRCxJQUFJLENBQUMsTUFBd0I7UUFDM0IsTUFBTSx5QkFBeUIsR0FBRyxHQUFHLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLE1BQU0sRUFBRSwyQkFBMkIsRUFBRSw0Q0FBNEMsQ0FBQyxDQUFDO1FBRWpLLE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3JELE1BQU0sYUFBYSxHQUFHLElBQUksR0FBRyxDQUFDLGFBQWEsQ0FBQyxNQUFNLEVBQUUscUJBQXFCLEVBQUUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBRXBGLE1BQU0sUUFBUSxHQUFHLElBQUksaUJBQWlCLENBQUMsMkJBQTJCLENBQUM7WUFDakUsZ0JBQWdCLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLHlCQUF5QixDQUFDLFdBQVcsQ0FBQztZQUMxRSxHQUFHLElBQUksQ0FBQyxLQUFLO1lBQ2IsR0FBRztZQUNILFVBQVUsRUFBRTtnQkFDVixPQUFPLEVBQUUsR0FBRyxDQUFDLGNBQWM7YUFDNUI7WUFDRCxhQUFhO1lBQ2Isb0JBQW9CLEVBQUUsaUJBQWlCLENBQUMsb0JBQW9CLENBQUMsMkJBQTJCO1NBQ3pGLENBQUMsQ0FBQztRQUVILFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFdEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3BDLHlCQUF5QixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUU1QyxNQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsYUFBYSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sRUFBRSxrQ0FBa0MsRUFBRSxnRUFBZ0UsQ0FBQyxDQUFDO1FBQ3BLLE1BQU0sQ0FBQyxJQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDeEMsQ0FBQzs7QUE3Qkgsa0RBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGVjMiBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCAqIGFzIGxhbWJkYUV2ZW50U291cmNlIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEtZXZlbnQtc291cmNlcyc7XG5pbXBvcnQgKiBhcyBzZWNyZXRzbWFuYWdlciBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc2VjcmV0c21hbmFnZXInO1xuaW1wb3J0ICogYXMgc3NtIGZyb20gJ2F3cy1jZGstbGliL2F3cy1zc20nO1xuXG5pbXBvcnQgKiBhcyByaW8gZnJvbSAnLi4vcmlvLWxhbmRpbmctem9uZSc7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgUmlvS2Fma2FFdmVudFNvdXJjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJpb0thZmthRXZlbnRTb3VyY2VQcm9wcyBleHRlbmRzIGxhbWJkYUV2ZW50U291cmNlLkJhc2VTdHJlYW1FdmVudFNvdXJjZVByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBLYWZrYSB0b3BpYyB0byBzdWJzY3JpYmUgdG9cbiAgICovXG4gIHJlYWRvbmx5IHRvcGljOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgc2VjcmV0IHdpdGggdGhlIEthZmthIGNyZWRlbnRpYWxzLCBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL21zay9sYXRlc3QvZGV2ZWxvcGVyZ3VpZGUvbXNrLWF1dGhlbnRpY2F0aW9uLmh0bWwgZm9yIGRldGFpbHMuXG4gICAqXG4gICAqIFlvdSBjYW4gdXNlIHRoZSBgY3JlYXRlLWFuZC1zaWduLWNlcnRpZmljYXRlYCBzY3JpcHQgZnJvbSB0aGUgYGthZmthLWludGVncmF0aW9uYCB0byBjcmVhdGUgYSBzdWl0YWJsZSBBV1MgU2VjcmV0cyBNYW5hZ2VyIHNlY3JldC5cbiAgICogU2ltcGx5IGFkZCB0aGUgYC0tZnFkbiA8ZnFkbj4gLS1sYW1iZGFgIHBhcmFtZXRlcnMgdG8gdGhlIGBjcmVhdGUtYW5kLXNpZ24tY2VydGlmaWNhdGVgIHNjcmlwdCBhbmQgdGhlIHNjcmlwdCBnZW5lcmF0ZXMgYSBzZWNyZXQgbmFtZWQgYGthZmthLWludGVncmF0aW9uL21zay1jZXJ0aWZpY2F0ZS88ZnFkbj5gIHdpdGggYWxsIHJlbGV2YW50IGRhdGEuXG4gICAqXG4gICAqIFBsZWFzZSBub3RlIHRoYXQgd2UgZG8gb25seSBzdXBwb3J0IHRoZSBgLS1sYW1iZGFgIHBhcmFtZXRlciBpZiB0aGUgYC0tZnFkbmAgcGFyYW1ldGVyIGlzIHByZXNlbnQuXG4gICAqIFdlIGVuY291cmFnZSB5b3UgdG8gdXNlIHRoZSBgLS1mcWRuYCBwYXJhbWV0ZXIgZm9yIGFsbCB5b3VyIEthZmthIGNvbnN1bWVycyBhbmQgcHJvZHVjZXJzIGFzIHRoaXMgZWFzZXMgdGhlIHJlY292ZXJ5IHByb2Nlc3MgaW4gdGhlIGNhc2Ugb2YgYSBkaXNhc3Rlci5cbiAgICogKE90aGVyd2lzZSwgaS5lLiwgaWYgeW91IGRvIG5vdCB1c2UgdGhlIGAtLWZxZG5gIHBhcmFtZXRlciwgeW91ciBjZXJ0aWZpY2F0ZXMgQ05BTUUgY29udGFpbnMgdGhlIEFXUyBhY2NvdW50IElEIGFuZCB5b3UgbmVlZCB0byBjaGFuZ2UgYWxsIEFDTHMgaW4gY2FzZSBvZiBhIGNvcnJ1cHRlZCBBV1MgYWNjb3VudC4pXG4gICAqL1xuICByZWFkb25seSBzZWNyZXQ6IHNlY3JldHNtYW5hZ2VyLklTZWNyZXQ7XG59XG5cbi8qKlxuICogVXNlIHRoZSBSaW8gS2Fma2EgYXMgYSBzdHJlYW1pbmcgc291cmNlIGZvciBBV1MgTGFtYmRhLlxuICpcbiAqIGBgYFxuICogIGNvbnN0IGxhbWJkYSA9IG5ldyBub2RlanMuTm9kZWpzRnVuY3Rpb24odGhpcywgJ0thZmthQ29uc3VtZXJGdW5jdGlvbicsIHtcbiAqICAgICBlbnRyeTogJ3BhdGgudG8uaGFuZGxlci50cycsXG4gKiAgICAgaGFuZGxlcjogJ2hhbmRsZXJOYW1lJyxcbiAqICAgfSk7XG4gKlxuICogICBjb25zdCBzZWNyZXQgPSBTZWNyZXQuZnJvbVNlY3JldE5hbWVWMih0aGlzLCAnQ29uc3VtZXJTZWNyZXQnLCAna2Fma2EtaW50ZWdyYXRpb24vbXNrLWNlcnRpZmljYXRlLzxGUUROPicpXG4gKlxuICogICBsYW1iZGEuYWRkRXZlbnRTb3VyY2UobmV3IFJpb0thZmthRXZlbnRTb3VyY2Uoe1xuICogICAgIHNlY3JldCxcbiAqICAgICB0b3BpYzogJzxUT1BJQy9OQU1FPicsXG4gKiAgICAgc3RhcnRpbmdQb3NpdGlvbjogU3RhcnRpbmdQb3NpdGlvbi5UUklNX0hPUklaT04sXG4gKiAgIH0pKTtcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgUmlvS2Fma2FFdmVudFNvdXJjZSBpbXBsZW1lbnRzIGxhbWJkYS5JRXZlbnRTb3VyY2Uge1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcHJvcHM6IFJpb0thZmthRXZlbnRTb3VyY2VQcm9wcykge1xuICB9XG5cbiAgYmluZCh0YXJnZXQ6IGxhbWJkYS5JRnVuY3Rpb24pOiB2b2lkIHtcbiAgICBjb25zdCBib290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyID0gc3NtLlN0cmluZ1BhcmFtZXRlci5mcm9tU3RyaW5nUGFyYW1ldGVyTmFtZSh0YXJnZXQsICdCb290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyJywgJy9jb25maWcva2Fma2EtaW50ZWdyYXRpb24vYm9vdHN0cmFwLXNlcnZlcicpO1xuXG4gICAgY29uc3QgdnBjID0gcmlvLlJpb0xhbmRpbmdab25lLmdldERlZmF1bHRWcGModGFyZ2V0KTtcbiAgICBjb25zdCBzZWN1cml0eUdyb3VwID0gbmV3IGVjMi5TZWN1cml0eUdyb3VwKHRhcmdldCwgJ0xhbWJkYVNlY3VyaXR5R3JvdXAnLCB7IHZwYyB9KTtcblxuICAgIGNvbnN0IGRlbGVnYXRlID0gbmV3IGxhbWJkYUV2ZW50U291cmNlLlNlbGZNYW5hZ2VkS2Fma2FFdmVudFNvdXJjZSh7XG4gICAgICBib290c3RyYXBTZXJ2ZXJzOiBjZGsuRm4uc3BsaXQoJywnLCBib290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyLnN0cmluZ1ZhbHVlKSxcbiAgICAgIC4uLnRoaXMucHJvcHMsXG4gICAgICB2cGMsXG4gICAgICB2cGNTdWJuZXRzOiB7XG4gICAgICAgIHN1Ym5ldHM6IHZwYy5wcml2YXRlU3VibmV0cyxcbiAgICAgIH0sXG4gICAgICBzZWN1cml0eUdyb3VwLFxuICAgICAgYXV0aGVudGljYXRpb25NZXRob2Q6IGxhbWJkYUV2ZW50U291cmNlLkF1dGhlbnRpY2F0aW9uTWV0aG9kLkNMSUVOVF9DRVJUSUZJQ0FURV9UTFNfQVVUSCxcbiAgICB9KTtcblxuICAgIGRlbGVnYXRlLmJpbmQodGFyZ2V0KTtcblxuICAgIHRoaXMucHJvcHMuc2VjcmV0LmdyYW50UmVhZCh0YXJnZXQpO1xuICAgIGJvb3RzdHJhcFNlcnZlcnNQYXJhbWV0ZXIuZ3JhbnRSZWFkKHRhcmdldCk7XG5cbiAgICBjb25zdCBwb2xpY3kgPSBpYW0uTWFuYWdlZFBvbGljeS5mcm9tTWFuYWdlZFBvbGljeUFybih0YXJnZXQsICdNYW5hZ2VkQVdTTGFtYmRhTVNLRXhlY3V0aW9uUm9sZScsICdhcm46YXdzOmlhbTo6YXdzOnBvbGljeS9zZXJ2aWNlLXJvbGUvQVdTTGFtYmRhTVNLRXhlY3V0aW9uUm9sZScpO1xuICAgIHRhcmdldC5yb2xlIS5hZGRNYW5hZ2VkUG9saWN5KHBvbGljeSk7XG4gIH1cbn1cbiJdfQ==
|