@rio-cloud/cdk-v2-constructs 6.1.0 → 6.2.2

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.
@@ -0,0 +1,352 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.RunnerRoles = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ const aws_ecr_1 = require("aws-cdk-lib/aws-ecr");
8
+ const aws_iam_1 = require("aws-cdk-lib/aws-iam");
9
+ const aws_s3_1 = require("aws-cdk-lib/aws-s3");
10
+ const aws_ssm_1 = require("aws-cdk-lib/aws-ssm");
11
+ const constructs_1 = require("constructs");
12
+ const rio_landing_zone_1 = require("../../../rio-landing-zone");
13
+ /**
14
+ * This construct provides a set of base roles for gitlab runners in order to build, test, validate and deploy applications
15
+ * on RIO. The roles need to be assumed during job runtime to perform more permissive actions, such as creating certificates to
16
+ * authenticate towards the RIO MSK, pushing docker images to ECR, performing a secrets backup, deploying stacks,
17
+ * or to publish an SPA to a S3 bucket. Do not assume the deployment role unless needed.
18
+ * The base role can be the default role attached to GitLab runners.
19
+ * The role allows to read various basic parameters such as the NIST data mirror, the OSS license bucket, DataDog keys
20
+ * and to pull ECR images form public Gallery or the specified account in the environment.
21
+ * The Role ARNs are export using CFNOutputs. Use the outputs to configure environment variables in your GitLab group.
22
+ */
23
+ class RunnerRoles extends constructs_1.Construct {
24
+ constructor(scope, id, props) {
25
+ super(scope, id);
26
+ const accountNameParameter = rio_landing_zone_1.RioLandingZone.getAccountNameParameter(scope);
27
+ const teamNameParameter = rio_landing_zone_1.RioLandingZone.getTeamIdentifierParameter(scope);
28
+ const nistMirrorParameter = aws_ssm_1.StringParameter.fromStringParameterName(this, 'NistMirrorParameter', '/config/nist-data-mirror/url');
29
+ const ossLicensesBucketParameter = aws_ssm_1.StringParameter.fromStringParameterAttributes(this, 'OssLicensesBucketParameter', {
30
+ parameterName: '/config/oss-licenses/bucket-name',
31
+ });
32
+ const ossLicensesBucket = aws_s3_1.Bucket.fromBucketName(this, 'OssLicensesBucket', ossLicensesBucketParameter.stringValue);
33
+ const ddApiKeyParam = aws_ssm_1.StringParameter.fromStringParameterAttributes(this, 'DataDogApiKeyParam', {
34
+ parameterName: '/rio/config/datadog-integration/api-key',
35
+ });
36
+ const ddSiteParam = aws_ssm_1.StringParameter.fromStringParameterAttributes(this, 'DataDogSiteParam', {
37
+ parameterName: '/rio/config/datadog-integration/site',
38
+ });
39
+ const kafkaIntegrationPolicy = aws_iam_1.ManagedPolicy.fromManagedPolicyArn(this, 'KafkaIntegrationPolicy', aws_cdk_lib_1.Fn.importValue('kafka-integration-policy-arn'));
40
+ this.runnerBaseRole = new aws_iam_1.Role(this, 'GlRunnerBuildRole', {
41
+ assumedBy: new aws_iam_1.ServicePrincipal('ec2.amazonaws.com', {}),
42
+ inlinePolicies: {
43
+ CdkSynthLookUp: aws_iam_1.PolicyDocument.fromJson({
44
+ Version: '2012-10-17',
45
+ Statement: [
46
+ {
47
+ Effect: 'Allow',
48
+ Action: ['s3:*Object', 's3:ListBucket', 's3:GetBucketLocation'],
49
+ Resource: ['arn:aws:s3:::cdktoolkit-*'],
50
+ },
51
+ {
52
+ Sid: 'assumerole',
53
+ Effect: 'Allow',
54
+ Action: ['sts:AssumeRole', 'iam:PassRole'],
55
+ Resource: [
56
+ 'arn:aws:iam::*:role/cdk-readOnlyRole',
57
+ 'arn:aws:iam::*:role/cdk-hnb659fds-lookup-role-*',
58
+ ],
59
+ },
60
+ {
61
+ Sid: 'pullEcrImages',
62
+ Effect: 'Allow',
63
+ Action: [
64
+ 'ecr:BatchCheckLayerAvailability',
65
+ 'ecr:BatchGetImage',
66
+ 'ecr:DescribeImages',
67
+ 'ecr:DescribeRepositories',
68
+ 'ecr:GetDownloadUrlForLayer',
69
+ ],
70
+ Resource: [
71
+ `${props.env.account}.dkr.ecr.${props.env.region}.amazonaws.com/*`,
72
+ ],
73
+ },
74
+ ],
75
+ }),
76
+ },
77
+ });
78
+ this.runnerBaseRole.node.defaultChild.overrideLogicalId('GlRunnerBuildRole');
79
+ nistMirrorParameter.grantRead(this.runnerBaseRole);
80
+ ossLicensesBucketParameter.grantRead(this.runnerBaseRole);
81
+ ossLicensesBucket.grantReadWrite(this.runnerBaseRole);
82
+ accountNameParameter.grantRead(this.runnerBaseRole);
83
+ teamNameParameter.grantRead(this.runnerBaseRole);
84
+ ddApiKeyParam.grantRead(this.runnerBaseRole);
85
+ ddSiteParam.grantRead(this.runnerBaseRole);
86
+ aws_ecr_1.PublicGalleryAuthorizationToken.grantRead(this.runnerBaseRole);
87
+ const webContentPublishRole = new aws_iam_1.Role(this, 'GlRunnerS3WebContentDeployRole', {
88
+ roleName: 'gl-runner-web-content-s3-deploy-role',
89
+ assumedBy: this.runnerBaseRole,
90
+ inlinePolicies: {
91
+ PublishWebContentOnS3: aws_iam_1.PolicyDocument.fromJson({
92
+ Version: '2012-10-17',
93
+ Statement: [
94
+ {
95
+ Effect: 'Allow',
96
+ Action: [
97
+ 's3:Abort*',
98
+ 's3:DeleteObject*',
99
+ 's3:GetBucket*',
100
+ 's3:GetObject*',
101
+ 's3:List*',
102
+ 's3:PutObject',
103
+ 's3:PutObjectLegalHold',
104
+ 's3:PutObjectRetention',
105
+ 's3:PutObjectTagging',
106
+ 's3:PutObjectVersionTagging',
107
+ ],
108
+ Resource: ['arn:aws:s3:::*'],
109
+ },
110
+ {
111
+ Action: [
112
+ 'ssm:DescribeParameters',
113
+ 'ssm:GetParameter',
114
+ 'ssm:GetParameterHistory',
115
+ 'ssm:GetParameters',
116
+ 'ssm:GetParametersByPath',
117
+ ],
118
+ Effect: 'Allow',
119
+ Resource: [
120
+ `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/config/*`,
121
+ `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/secret/*`,
122
+ ],
123
+ },
124
+ ],
125
+ }),
126
+ },
127
+ });
128
+ webContentPublishRole.node.defaultChild.overrideLogicalId('GlRunnerS3WebContentDeployRole');
129
+ const createMSKCertRole = new aws_iam_1.Role(this, 'GlRunnerCreateAndSignCertRole', {
130
+ roleName: 'gl-runner-create-and-sign-rio-msk-cert-role',
131
+ assumedBy: this.runnerBaseRole,
132
+ inlinePolicies: {
133
+ ParameterStoreReadKeyStore: aws_iam_1.PolicyDocument.fromJson({
134
+ Version: '2012-10-17',
135
+ Statement: [
136
+ {
137
+ Action: [
138
+ 'ssm:DescribeParameters',
139
+ 'ssm:GetParameter',
140
+ 'ssm:GetParameterHistory',
141
+ 'ssm:GetParameters',
142
+ 'ssm:GetParametersByPath',
143
+ ],
144
+ Effect: 'Allow',
145
+ Resource: [
146
+ `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/config/*`,
147
+ `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/secret/*`,
148
+ ],
149
+ },
150
+ ],
151
+ }),
152
+ SecretsManagerReadKeyStore: aws_iam_1.PolicyDocument.fromJson({
153
+ Version: '2012-10-17',
154
+ Statement: [
155
+ {
156
+ Action: [
157
+ 'secretsmanager:DescribeSecret',
158
+ 'secretsmanager:GetSecretValue',
159
+ 'secretsmanager:GetResourcePolicy',
160
+ 'secretsmanager:ListSecretVersionIds',
161
+ ],
162
+ Effect: 'Allow',
163
+ Resource: [
164
+ `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/secret/*/service-keystore-password-??????`,
165
+ `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/secret/*/service-keystore-password`,
166
+ `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/config/*/service-keystore-password-??????`,
167
+ `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/config/*/service-keystore-password`,
168
+ ],
169
+ },
170
+ ],
171
+ }),
172
+ },
173
+ managedPolicies: [kafkaIntegrationPolicy],
174
+ });
175
+ accountNameParameter.grantRead(createMSKCertRole);
176
+ teamNameParameter.grantRead(this.runnerBaseRole);
177
+ createMSKCertRole.node.defaultChild.overrideLogicalId('GlRunnerCreateAndSignCertRole');
178
+ const ecrDeployRole = new aws_iam_1.Role(this, 'GlRunnerECRDeployRole', {
179
+ roleName: 'gl-runner-deploy-to-ecr-role',
180
+ assumedBy: this.runnerBaseRole,
181
+ inlinePolicies: {
182
+ DeployToECR: aws_iam_1.PolicyDocument.fromJson({
183
+ Version: '2012-10-17',
184
+ Statement: [
185
+ {
186
+ Action: [
187
+ 'ecr:BatchCheckLayerAvailability',
188
+ 'ecr:BatchGetImage',
189
+ 'ecr:CompleteLayerUpload',
190
+ 'ecr:GetDownloadUrlForLayer',
191
+ 'ecr:InitiateLayerUpload',
192
+ 'ecr:PutImage',
193
+ 'ecr:UploadLayerPart',
194
+ 'ecr:GetAuthorizationToken',
195
+ 'ecr:DescribeRepositories',
196
+ ],
197
+ Effect: 'Allow',
198
+ Resource: [
199
+ `${props.env.account}.dkr.ecr.${props.env.region}.amazonaws.com/*`,
200
+ ],
201
+ },
202
+ ],
203
+ }),
204
+ },
205
+ });
206
+ aws_ecr_1.PublicGalleryAuthorizationToken.grantRead(ecrDeployRole);
207
+ ecrDeployRole.node.defaultChild.overrideLogicalId('GlRunnerECRDeployRole');
208
+ const iamPolicyKMS = new aws_iam_1.PolicyStatement({
209
+ actions: ['kms:Decrypt'],
210
+ resources: [
211
+ 'arn:aws:kms:*:903404386550:key/*',
212
+ `arn:aws:kms:*:${props.env.account}:key/*`,
213
+ ],
214
+ conditions: {
215
+ 'ForAnyValue:StringLike': {
216
+ 'kms:ResourceAliases': 'alias/rio-lz-backup-key*',
217
+ },
218
+ },
219
+ });
220
+ const iamPolicyLambdaExecution = new aws_iam_1.PolicyStatement({
221
+ actions: ['lambda:InvokeFunction'],
222
+ resources: [
223
+ `arn:aws:lambda:eu-west-1:${props.env.account}:function:SecretsRestoreHandler`,
224
+ ],
225
+ });
226
+ const secretsBackUpRole = new aws_iam_1.Role(this, 'GlRunnerSecretsBackupRole', {
227
+ roleName: 'gl-runner-secrets-backup-role',
228
+ assumedBy: this.runnerBaseRole,
229
+ inlinePolicies: {
230
+ SecretsBackup: new aws_iam_1.PolicyDocument({
231
+ statements: [iamPolicyKMS, iamPolicyLambdaExecution],
232
+ }),
233
+ },
234
+ });
235
+ secretsBackUpRole.node.defaultChild.overrideLogicalId('GlRunnerSecretsBackupRole');
236
+ const deployRole = new aws_iam_1.Role(this, 'GlRunnerCDKDeployRole', {
237
+ roleName: 'gl-runner-cdk-deploy-role',
238
+ assumedBy: this.runnerBaseRole,
239
+ managedPolicies: [kafkaIntegrationPolicy], // required to create Kafka topics and publish event specification in deploy jobs
240
+ inlinePolicies: {
241
+ CdkDeploy: aws_iam_1.PolicyDocument.fromJson({
242
+ Version: '2012-10-17',
243
+ Statement: [
244
+ {
245
+ Effect: 'Allow',
246
+ Action: [
247
+ 'cloudformation:DescribeStacks',
248
+ 'cloudformation:CreateChangeSet',
249
+ 'cloudformation:DescribeChangeSet',
250
+ 'cloudformation:ExecuteChangeSet',
251
+ 'cloudformation:DescribeStackEvents',
252
+ 'cloudformation:DeleteChangeSet',
253
+ 'cloudformation:GetTemplate',
254
+ ],
255
+ Resource: [
256
+ `arn:aws:cloudformation:${props.env.region}:${props.env.account}:stack/*`,
257
+ ],
258
+ },
259
+ {
260
+ Effect: 'Allow',
261
+ Action: ['s3:*Object', 's3:ListBucket', 's3:GetBucketLocation'],
262
+ Resource: ['arn:aws:s3:::cdktoolkit-*'],
263
+ },
264
+ {
265
+ Sid: 'assumerole',
266
+ Effect: 'Allow',
267
+ Action: ['sts:AssumeRole', 'iam:PassRole'],
268
+ Resource: [
269
+ 'arn:aws:iam::*:role/cdk-readOnlyRole',
270
+ 'arn:aws:iam::*:role/cdk-hnb659fds-deploy-role-*',
271
+ 'arn:aws:iam::*:role/cdk-hnb659fds-file-publishing-*',
272
+ 'arn:aws:iam::*:role/cdk-hnb659fds-lookup-role-*',
273
+ ],
274
+ },
275
+ ],
276
+ }),
277
+ CfnDeploy: aws_iam_1.PolicyDocument.fromJson({
278
+ Version: '2012-10-17',
279
+ Statement: [
280
+ {
281
+ Effect: 'Allow',
282
+ Action: ['*'],
283
+ Resource: [
284
+ `arn:aws:cloudformation:${props.env.region}:${props.env.account}:stack/*`,
285
+ ],
286
+ Condition: {
287
+ 'ForAnyValue:StringEquals': {
288
+ 'aws:CalledVia': 'cloudformation.amazonaws.com',
289
+ },
290
+ },
291
+ },
292
+ ],
293
+ }),
294
+ },
295
+ });
296
+ deployRole.node.defaultChild.overrideLogicalId('GlRunnerCDKDeployRole');
297
+ const glRunnerCdkDeployRoleArn = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKDeployRoleArn', {
298
+ value: deployRole.roleArn,
299
+ exportName: 'gl-runner-cdk-deploy-role-arn',
300
+ });
301
+ glRunnerCdkDeployRoleArn.overrideLogicalId('GlRunnerCDKDeployRoleArn');
302
+ const glRunnerCdkDeployRoleName = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKDeployRoleName', {
303
+ value: deployRole.roleName,
304
+ exportName: 'gl-runner-cdk-deploy-role-name',
305
+ });
306
+ glRunnerCdkDeployRoleName.overrideLogicalId('GlRunnerCDKDeployRoleName');
307
+ const glRunnerCdkCreateAndSignCertRoleName = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKCreateAndSignCertRoleName', {
308
+ value: createMSKCertRole.roleName,
309
+ exportName: 'gl-runner-cdk-create-and-sign-msk-cert-role-name',
310
+ });
311
+ glRunnerCdkCreateAndSignCertRoleName.overrideLogicalId('GlRunnerCDKCreateAndSignCertRoleName');
312
+ const glRunnerCdkCreateAndSignCertRoleArn = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKCreateAndSignCertRoleArn', {
313
+ value: createMSKCertRole.roleArn,
314
+ exportName: 'gl-runner-cdk-create-and-sign-msk-cert-role-arn',
315
+ });
316
+ glRunnerCdkCreateAndSignCertRoleArn.overrideLogicalId('GlRunnerCDKCreateAndSignCertRoleArn');
317
+ const glRunnerCdkPublishWebContentRoleName = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKPublishWebContentRoleName', {
318
+ value: webContentPublishRole.roleName,
319
+ exportName: 'gl-runner-cdk-publish-web-content-on-s3-role-name',
320
+ });
321
+ glRunnerCdkPublishWebContentRoleName.overrideLogicalId('GlRunnerCDKPublishWebContentRoleName');
322
+ const glRunnerCdkPublishWebContentRoleArn = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKPublishWebContentRoleArn', {
323
+ value: webContentPublishRole.roleArn,
324
+ exportName: 'gl-runner-cdk-publish-web-content-on-s3-role-arn',
325
+ });
326
+ glRunnerCdkPublishWebContentRoleArn.overrideLogicalId('GlRunnerCDKPublishWebContentRoleArn');
327
+ const glRunnerCdkDeployToEcrRoleName = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKDeployToEcrRoleName', {
328
+ value: ecrDeployRole.roleName,
329
+ exportName: 'gl-runner-cdk-deploy-to-ecr-role-name',
330
+ });
331
+ glRunnerCdkDeployToEcrRoleName.overrideLogicalId('GlRunnerCDKDeployToEcrRoleName');
332
+ const glRunnerCdkDeployToEcrRoleArn = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKDeployToEcrRoleArn', {
333
+ value: ecrDeployRole.roleArn,
334
+ exportName: 'gl-runner-cdk-deploy-to-ecr-role-arn',
335
+ });
336
+ glRunnerCdkDeployToEcrRoleArn.overrideLogicalId('GlRunnerCDKDeployToEcrRoleArn');
337
+ const glRunnerCdkSecretsBackupRoleName = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKSecretsBackupRoleName', {
338
+ value: secretsBackUpRole.roleName,
339
+ exportName: 'gl-runner-cdk-secrets-backup-role-name',
340
+ });
341
+ glRunnerCdkSecretsBackupRoleName.overrideLogicalId('GlRunnerCDKSecretsBackupRoleName');
342
+ const glRunnerCdkSecretsBackupRoleArn = new aws_cdk_lib_1.CfnOutput(scope, 'GlRunnerCDKSecretsBackupRoleArn', {
343
+ value: secretsBackUpRole.roleArn,
344
+ exportName: 'gl-runner-cdk-secrets-backup-role-arn',
345
+ });
346
+ glRunnerCdkSecretsBackupRoleArn.overrideLogicalId('GlRunnerCDKSecretsBackupRoleArn');
347
+ }
348
+ }
349
+ exports.RunnerRoles = RunnerRoles;
350
+ _a = JSII_RTTI_SYMBOL_1;
351
+ RunnerRoles[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.RunnerRoles", version: "0.0.0" };
352
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runner-roles.js","sourceRoot":"","sources":["../../../../src/contributions/smart-route/gitlab-runner/runner-roles.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnOutput, Environment, Fn, Stack } from 'aws-cdk-lib';\nimport { PublicGalleryAuthorizationToken } from 'aws-cdk-lib/aws-ecr';\nimport {\n  CfnRole,\n  ManagedPolicy,\n  PolicyDocument,\n  PolicyStatement,\n  Role,\n  ServicePrincipal,\n} from 'aws-cdk-lib/aws-iam';\nimport { Bucket } from 'aws-cdk-lib/aws-s3';\nimport { StringParameter } from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\nimport { RioLandingZone } from '../../../rio-landing-zone';\n\nexport interface RunnerRoleProps {\n  readonly env: Environment;\n}\n\n/**\n * This construct provides a set of base roles for gitlab runners in order to build, test, validate and deploy applications\n * on RIO. The roles need to be assumed during job runtime to perform more permissive actions, such as creating certificates to\n * authenticate towards the RIO MSK, pushing docker images to ECR, performing a secrets backup, deploying stacks,\n * or to publish an SPA to a S3 bucket. Do not assume the deployment role unless needed.\n * The base role can be the default role attached to GitLab runners.\n * The role allows to read various basic parameters such as the NIST data mirror, the OSS license bucket, DataDog keys\n * and to pull ECR images form public Gallery or the specified account in the environment.\n * The Role ARNs are export using CFNOutputs. Use the outputs to configure environment variables in your GitLab group.\n */\nexport class RunnerRoles extends Construct {\n  readonly runnerBaseRole: Role;\n  constructor(scope: Stack, id: string, props: RunnerRoleProps) {\n    super(scope, id);\n    const accountNameParameter = RioLandingZone.getAccountNameParameter(scope);\n    const teamNameParameter = RioLandingZone.getTeamIdentifierParameter(scope);\n\n    const nistMirrorParameter = StringParameter.fromStringParameterName(\n      this,\n      'NistMirrorParameter',\n      '/config/nist-data-mirror/url',\n    );\n\n    const ossLicensesBucketParameter =\n      StringParameter.fromStringParameterAttributes(\n        this,\n        'OssLicensesBucketParameter',\n        {\n          parameterName: '/config/oss-licenses/bucket-name',\n        },\n      );\n    const ossLicensesBucket = Bucket.fromBucketName(\n      this,\n      'OssLicensesBucket',\n      ossLicensesBucketParameter.stringValue,\n    );\n\n    const ddApiKeyParam = StringParameter.fromStringParameterAttributes(\n      this,\n      'DataDogApiKeyParam',\n      {\n        parameterName: '/rio/config/datadog-integration/api-key',\n      },\n    );\n    const ddSiteParam = StringParameter.fromStringParameterAttributes(\n      this,\n      'DataDogSiteParam',\n      {\n        parameterName: '/rio/config/datadog-integration/site',\n      },\n    );\n\n    const kafkaIntegrationPolicy = ManagedPolicy.fromManagedPolicyArn(\n      this,\n      'KafkaIntegrationPolicy',\n      Fn.importValue('kafka-integration-policy-arn'),\n    );\n\n    this.runnerBaseRole = new Role(this, 'GlRunnerBuildRole', {\n      assumedBy: new ServicePrincipal('ec2.amazonaws.com', {}),\n      inlinePolicies: {\n        CdkSynthLookUp: PolicyDocument.fromJson({\n          Version: '2012-10-17',\n          Statement: [\n            {\n              Effect: 'Allow',\n              Action: ['s3:*Object', 's3:ListBucket', 's3:GetBucketLocation'],\n              Resource: ['arn:aws:s3:::cdktoolkit-*'],\n            },\n            {\n              Sid: 'assumerole',\n              Effect: 'Allow',\n              Action: ['sts:AssumeRole', 'iam:PassRole'],\n              Resource: [\n                'arn:aws:iam::*:role/cdk-readOnlyRole',\n                'arn:aws:iam::*:role/cdk-hnb659fds-lookup-role-*',\n              ],\n            },\n            {\n              Sid: 'pullEcrImages',\n              Effect: 'Allow',\n              Action: [\n                'ecr:BatchCheckLayerAvailability',\n                'ecr:BatchGetImage',\n                'ecr:DescribeImages',\n                'ecr:DescribeRepositories',\n                'ecr:GetDownloadUrlForLayer',\n              ],\n              Resource: [\n                `${props.env.account}.dkr.ecr.${props.env.region}.amazonaws.com/*`,\n              ],\n            },\n          ],\n        }),\n      },\n    });\n    (this.runnerBaseRole.node.defaultChild as CfnRole).overrideLogicalId(\n      'GlRunnerBuildRole',\n    );\n    nistMirrorParameter.grantRead(this.runnerBaseRole);\n    ossLicensesBucketParameter.grantRead(this.runnerBaseRole);\n    ossLicensesBucket.grantReadWrite(this.runnerBaseRole);\n    accountNameParameter.grantRead(this.runnerBaseRole);\n    teamNameParameter.grantRead(this.runnerBaseRole);\n    ddApiKeyParam.grantRead(this.runnerBaseRole);\n    ddSiteParam.grantRead(this.runnerBaseRole);\n    PublicGalleryAuthorizationToken.grantRead(this.runnerBaseRole);\n\n    const webContentPublishRole = new Role(\n      this,\n      'GlRunnerS3WebContentDeployRole',\n      {\n        roleName: 'gl-runner-web-content-s3-deploy-role',\n        assumedBy: this.runnerBaseRole,\n        inlinePolicies: {\n          PublishWebContentOnS3: PolicyDocument.fromJson({\n            Version: '2012-10-17',\n            Statement: [\n              {\n                Effect: 'Allow',\n                Action: [\n                  's3:Abort*',\n                  's3:DeleteObject*',\n                  's3:GetBucket*',\n                  's3:GetObject*',\n                  's3:List*',\n                  's3:PutObject',\n                  's3:PutObjectLegalHold',\n                  's3:PutObjectRetention',\n                  's3:PutObjectTagging',\n                  's3:PutObjectVersionTagging',\n                ],\n                Resource: ['arn:aws:s3:::*'],\n              },\n              {\n                Action: [\n                  'ssm:DescribeParameters',\n                  'ssm:GetParameter',\n                  'ssm:GetParameterHistory',\n                  'ssm:GetParameters',\n                  'ssm:GetParametersByPath',\n                ],\n                Effect: 'Allow',\n                Resource: [\n                  `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/config/*`,\n                  `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/secret/*`,\n                ],\n              },\n            ],\n          }),\n        },\n      },\n    );\n    (webContentPublishRole.node.defaultChild as CfnRole).overrideLogicalId(\n      'GlRunnerS3WebContentDeployRole',\n    );\n\n    const createMSKCertRole = new Role(this, 'GlRunnerCreateAndSignCertRole', {\n      roleName: 'gl-runner-create-and-sign-rio-msk-cert-role',\n      assumedBy: this.runnerBaseRole,\n      inlinePolicies: {\n        ParameterStoreReadKeyStore: PolicyDocument.fromJson({\n          Version: '2012-10-17',\n          Statement: [\n            {\n              Action: [\n                'ssm:DescribeParameters',\n                'ssm:GetParameter',\n                'ssm:GetParameterHistory',\n                'ssm:GetParameters',\n                'ssm:GetParametersByPath',\n              ],\n              Effect: 'Allow',\n              Resource: [\n                `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/config/*`,\n                `arn:aws:ssm:${props.env.region}:${props.env.account}:parameter/secret/*`,\n              ],\n            },\n          ],\n        }),\n        SecretsManagerReadKeyStore: PolicyDocument.fromJson({\n          Version: '2012-10-17',\n          Statement: [\n            {\n              Action: [\n                'secretsmanager:DescribeSecret',\n                'secretsmanager:GetSecretValue',\n                'secretsmanager:GetResourcePolicy',\n                'secretsmanager:ListSecretVersionIds',\n              ],\n              Effect: 'Allow',\n              Resource: [\n                `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/secret/*/service-keystore-password-??????`,\n                `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/secret/*/service-keystore-password`,\n                `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/config/*/service-keystore-password-??????`,\n                `arn:aws:secretsmanager:${props.env.region}:${props.env.account}:secret:/config/*/service-keystore-password`,\n              ],\n            },\n          ],\n        }),\n      },\n      managedPolicies: [kafkaIntegrationPolicy],\n    });\n    accountNameParameter.grantRead(createMSKCertRole);\n    teamNameParameter.grantRead(this.runnerBaseRole);\n    (createMSKCertRole.node.defaultChild as CfnRole).overrideLogicalId(\n      'GlRunnerCreateAndSignCertRole',\n    );\n\n    const ecrDeployRole = new Role(this, 'GlRunnerECRDeployRole', {\n      roleName: 'gl-runner-deploy-to-ecr-role',\n      assumedBy: this.runnerBaseRole,\n      inlinePolicies: {\n        DeployToECR: PolicyDocument.fromJson({\n          Version: '2012-10-17',\n          Statement: [\n            {\n              Action: [\n                'ecr:BatchCheckLayerAvailability',\n                'ecr:BatchGetImage',\n                'ecr:CompleteLayerUpload',\n                'ecr:GetDownloadUrlForLayer',\n                'ecr:InitiateLayerUpload',\n                'ecr:PutImage',\n                'ecr:UploadLayerPart',\n                'ecr:GetAuthorizationToken',\n                'ecr:DescribeRepositories',\n              ],\n              Effect: 'Allow',\n              Resource: [\n                `${props.env.account}.dkr.ecr.${props.env.region}.amazonaws.com/*`,\n              ],\n            },\n          ],\n        }),\n      },\n    });\n    PublicGalleryAuthorizationToken.grantRead(ecrDeployRole);\n    (ecrDeployRole.node.defaultChild as CfnRole).overrideLogicalId(\n      'GlRunnerECRDeployRole',\n    );\n\n    const iamPolicyKMS = new PolicyStatement({\n      actions: ['kms:Decrypt'],\n      resources: [\n        'arn:aws:kms:*:903404386550:key/*',\n        `arn:aws:kms:*:${props.env.account}:key/*`,\n      ],\n      conditions: {\n        'ForAnyValue:StringLike': {\n          'kms:ResourceAliases': 'alias/rio-lz-backup-key*',\n        },\n      },\n    });\n    const iamPolicyLambdaExecution = new PolicyStatement({\n      actions: ['lambda:InvokeFunction'],\n      resources: [\n        `arn:aws:lambda:eu-west-1:${props.env.account}:function:SecretsRestoreHandler`,\n      ],\n    });\n    const secretsBackUpRole = new Role(this, 'GlRunnerSecretsBackupRole', {\n      roleName: 'gl-runner-secrets-backup-role',\n      assumedBy: this.runnerBaseRole,\n      inlinePolicies: {\n        SecretsBackup: new PolicyDocument({\n          statements: [iamPolicyKMS, iamPolicyLambdaExecution],\n        }),\n      },\n    });\n    (secretsBackUpRole.node.defaultChild as CfnRole).overrideLogicalId(\n      'GlRunnerSecretsBackupRole',\n    );\n\n    const deployRole = new Role(this, 'GlRunnerCDKDeployRole', {\n      roleName: 'gl-runner-cdk-deploy-role',\n      assumedBy: this.runnerBaseRole,\n      managedPolicies: [kafkaIntegrationPolicy], // required to create Kafka topics and publish event specification in deploy jobs\n      inlinePolicies: {\n        CdkDeploy: PolicyDocument.fromJson({\n          Version: '2012-10-17',\n          Statement: [\n            {\n              Effect: 'Allow',\n              Action: [\n                'cloudformation:DescribeStacks',\n                'cloudformation:CreateChangeSet',\n                'cloudformation:DescribeChangeSet',\n                'cloudformation:ExecuteChangeSet',\n                'cloudformation:DescribeStackEvents',\n                'cloudformation:DeleteChangeSet',\n                'cloudformation:GetTemplate',\n              ],\n              Resource: [\n                `arn:aws:cloudformation:${props.env.region}:${props.env.account}:stack/*`,\n              ],\n            },\n            {\n              Effect: 'Allow',\n              Action: ['s3:*Object', 's3:ListBucket', 's3:GetBucketLocation'],\n              Resource: ['arn:aws:s3:::cdktoolkit-*'],\n            },\n            {\n              Sid: 'assumerole',\n              Effect: 'Allow',\n              Action: ['sts:AssumeRole', 'iam:PassRole'],\n              Resource: [\n                'arn:aws:iam::*:role/cdk-readOnlyRole',\n                'arn:aws:iam::*:role/cdk-hnb659fds-deploy-role-*',\n                'arn:aws:iam::*:role/cdk-hnb659fds-file-publishing-*',\n                'arn:aws:iam::*:role/cdk-hnb659fds-lookup-role-*',\n              ],\n            },\n          ],\n        }),\n        CfnDeploy: PolicyDocument.fromJson({\n          Version: '2012-10-17',\n          Statement: [\n            {\n              Effect: 'Allow',\n              Action: ['*'],\n              Resource: [\n                `arn:aws:cloudformation:${props.env.region}:${props.env.account}:stack/*`,\n              ],\n              Condition: {\n                'ForAnyValue:StringEquals': {\n                  'aws:CalledVia': 'cloudformation.amazonaws.com',\n                },\n              },\n            },\n          ],\n        }),\n      },\n    });\n    (deployRole.node.defaultChild as CfnRole).overrideLogicalId(\n      'GlRunnerCDKDeployRole',\n    );\n\n    const glRunnerCdkDeployRoleArn = new CfnOutput(\n      scope,\n      'GlRunnerCDKDeployRoleArn',\n      {\n        value: deployRole.roleArn,\n        exportName: 'gl-runner-cdk-deploy-role-arn',\n      },\n    );\n    glRunnerCdkDeployRoleArn.overrideLogicalId('GlRunnerCDKDeployRoleArn');\n    const glRunnerCdkDeployRoleName = new CfnOutput(\n      scope,\n      'GlRunnerCDKDeployRoleName',\n      {\n        value: deployRole.roleName,\n        exportName: 'gl-runner-cdk-deploy-role-name',\n      },\n    );\n    glRunnerCdkDeployRoleName.overrideLogicalId('GlRunnerCDKDeployRoleName');\n\n    const glRunnerCdkCreateAndSignCertRoleName = new CfnOutput(\n      scope,\n      'GlRunnerCDKCreateAndSignCertRoleName',\n      {\n        value: createMSKCertRole.roleName,\n        exportName: 'gl-runner-cdk-create-and-sign-msk-cert-role-name',\n      },\n    );\n    glRunnerCdkCreateAndSignCertRoleName.overrideLogicalId(\n      'GlRunnerCDKCreateAndSignCertRoleName',\n    );\n    const glRunnerCdkCreateAndSignCertRoleArn = new CfnOutput(\n      scope,\n      'GlRunnerCDKCreateAndSignCertRoleArn',\n      {\n        value: createMSKCertRole.roleArn,\n        exportName: 'gl-runner-cdk-create-and-sign-msk-cert-role-arn',\n      },\n    );\n    glRunnerCdkCreateAndSignCertRoleArn.overrideLogicalId(\n      'GlRunnerCDKCreateAndSignCertRoleArn',\n    );\n\n    const glRunnerCdkPublishWebContentRoleName = new CfnOutput(\n      scope,\n      'GlRunnerCDKPublishWebContentRoleName',\n      {\n        value: webContentPublishRole.roleName,\n        exportName: 'gl-runner-cdk-publish-web-content-on-s3-role-name',\n      },\n    );\n    glRunnerCdkPublishWebContentRoleName.overrideLogicalId(\n      'GlRunnerCDKPublishWebContentRoleName',\n    );\n    const glRunnerCdkPublishWebContentRoleArn = new CfnOutput(\n      scope,\n      'GlRunnerCDKPublishWebContentRoleArn',\n      {\n        value: webContentPublishRole.roleArn,\n        exportName: 'gl-runner-cdk-publish-web-content-on-s3-role-arn',\n      },\n    );\n    glRunnerCdkPublishWebContentRoleArn.overrideLogicalId(\n      'GlRunnerCDKPublishWebContentRoleArn',\n    );\n\n    const glRunnerCdkDeployToEcrRoleName = new CfnOutput(\n      scope,\n      'GlRunnerCDKDeployToEcrRoleName',\n      {\n        value: ecrDeployRole.roleName,\n        exportName: 'gl-runner-cdk-deploy-to-ecr-role-name',\n      },\n    );\n    glRunnerCdkDeployToEcrRoleName.overrideLogicalId(\n      'GlRunnerCDKDeployToEcrRoleName',\n    );\n    const glRunnerCdkDeployToEcrRoleArn = new CfnOutput(\n      scope,\n      'GlRunnerCDKDeployToEcrRoleArn',\n      {\n        value: ecrDeployRole.roleArn,\n        exportName: 'gl-runner-cdk-deploy-to-ecr-role-arn',\n      },\n    );\n    glRunnerCdkDeployToEcrRoleArn.overrideLogicalId(\n      'GlRunnerCDKDeployToEcrRoleArn',\n    );\n\n    const glRunnerCdkSecretsBackupRoleName = new CfnOutput(\n      scope,\n      'GlRunnerCDKSecretsBackupRoleName',\n      {\n        value: secretsBackUpRole.roleName,\n        exportName: 'gl-runner-cdk-secrets-backup-role-name',\n      },\n    );\n    glRunnerCdkSecretsBackupRoleName.overrideLogicalId(\n      'GlRunnerCDKSecretsBackupRoleName',\n    );\n    const glRunnerCdkSecretsBackupRoleArn = new CfnOutput(\n      scope,\n      'GlRunnerCDKSecretsBackupRoleArn',\n      {\n        value: secretsBackUpRole.roleArn,\n        exportName: 'gl-runner-cdk-secrets-backup-role-arn',\n      },\n    );\n    glRunnerCdkSecretsBackupRoleArn.overrideLogicalId(\n      'GlRunnerCDKSecretsBackupRoleArn',\n    );\n  }\n}\n"]}
@@ -0,0 +1,7 @@
1
+ import { Construct } from 'constructs';
2
+ /**
3
+ * The construct creates a service linked role required to run GitLab Runners using Spot EC2 instances.
4
+ */
5
+ export declare class SpotServiceLinkedRole extends Construct {
6
+ constructor(scope: Construct, id: string);
7
+ }
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SpotServiceLinkedRole = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const aws_iam_1 = require("aws-cdk-lib/aws-iam");
7
+ const constructs_1 = require("constructs");
8
+ /**
9
+ * The construct creates a service linked role required to run GitLab Runners using Spot EC2 instances.
10
+ */
11
+ class SpotServiceLinkedRole extends constructs_1.Construct {
12
+ constructor(scope, id) {
13
+ super(scope, id);
14
+ new aws_iam_1.CfnServiceLinkedRole(scope, 'Ec2SpotServiceLinkedRole', {
15
+ awsServiceName: 'spot.amazonaws.com',
16
+ });
17
+ }
18
+ }
19
+ exports.SpotServiceLinkedRole = SpotServiceLinkedRole;
20
+ _a = JSII_RTTI_SYMBOL_1;
21
+ SpotServiceLinkedRole[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.SpotServiceLinkedRole", version: "0.0.0" };
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BvdC1yb2xlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbnRyaWJ1dGlvbnMvc21hcnQtcm91dGUvZ2l0bGFiLXJ1bm5lci9zcG90LXJvbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxpREFBMkQ7QUFDM0QsMkNBQXVDO0FBR3ZDOztHQUVHO0FBQ0gsTUFBYSxxQkFBc0IsU0FBUSxzQkFBUztJQUNsRCxZQUFZLEtBQWdCLEVBQUUsRUFBVTtRQUN0QyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLElBQUksOEJBQW9CLENBQUMsS0FBSyxFQUFFLDBCQUEwQixFQUFFO1lBQzFELGNBQWMsRUFBRSxvQkFBb0I7U0FDckMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUFOSCxzREFPQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENmblNlcnZpY2VMaW5rZWRSb2xlIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWlhbSc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuXG4vKipcbiAqIFRoZSBjb25zdHJ1Y3QgY3JlYXRlcyBhIHNlcnZpY2UgbGlua2VkIHJvbGUgcmVxdWlyZWQgdG8gcnVuIEdpdExhYiBSdW5uZXJzIHVzaW5nIFNwb3QgRUMyIGluc3RhbmNlcy5cbiAqL1xuZXhwb3J0IGNsYXNzIFNwb3RTZXJ2aWNlTGlua2VkUm9sZSBleHRlbmRzIENvbnN0cnVjdCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIG5ldyBDZm5TZXJ2aWNlTGlua2VkUm9sZShzY29wZSwgJ0VjMlNwb3RTZXJ2aWNlTGlua2VkUm9sZScsIHtcbiAgICAgIGF3c1NlcnZpY2VOYW1lOiAnc3BvdC5hbWF6b25hd3MuY29tJyxcbiAgICB9KTtcbiAgfVxufVxuIl19
package/lib/index.d.ts CHANGED
@@ -21,3 +21,4 @@ export * from './contributions/team-claid/datadog-usage-monitoring';
21
21
  export * from './contributions/team-oubout-order-book/aws-ecs-abruptly-stopped-monitor';
22
22
  export * from './backup';
23
23
  export * as backup from './backup';
24
+ export * from './contributions/smart-route/gitlab-runner';
package/lib/index.js CHANGED
@@ -38,4 +38,5 @@ __exportStar(require("./contributions/team-claid/datadog-usage-monitoring"), exp
38
38
  __exportStar(require("./contributions/team-oubout-order-book/aws-ecs-abruptly-stopped-monitor"), exports);
39
39
  __exportStar(require("./backup"), exports);
40
40
  exports.backup = require("./backup");
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw2Q0FBMkI7QUFFM0IsNkNBQTJDO0FBRTNDLHFEQUFtQztBQUNuQyxzREFBb0M7QUFDcEMsb0RBQWtDO0FBRWxDLGdFQUE4QztBQUM5Qyx1Q0FBcUM7QUFFckMseUVBQXVEO0FBQ3ZELDhFQUE0RDtBQUM1RCwrREFBNkM7QUFFN0MsMENBQXdCO0FBQ3hCLG1DQUFpQztBQUVqQyw0Q0FBMEI7QUFDMUIsdUNBQXFDO0FBQ3JDLDJDQUF5QztBQUV6QywwRUFBd0Q7QUFFeEQsNkVBQTJEO0FBQzNELDhFQUE0RDtBQUU1RCxtRkFBaUU7QUFDakUsc0ZBQW9FO0FBRXBFLDBHQUF3RjtBQUV4RiwyQ0FBeUI7QUFDekIscUNBQW1DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bCc7XG5cbmV4cG9ydCAqIGFzIHdhdGNoZnVsdjIgZnJvbSAnLi93YXRjaGZ1bHYyJztcblxuZXhwb3J0ICogZnJvbSAnLi9yaW8tbGFuZGluZy16b25lJztcbmV4cG9ydCAqIGZyb20gJy4vcmlvLWxvYWQtYmFsYW5jZXInO1xuZXhwb3J0ICogZnJvbSAnLi9yaW8tY2xhaWRvbWV0ZXInO1xuXG5leHBvcnQgKiBmcm9tICcuL2ZhcmdhdGUvcmlvLWZhcmdhdGUtc2VydmljZSc7XG5leHBvcnQgKiBhcyBmYXJnYXRlIGZyb20gJy4vZmFyZ2F0ZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vcGlwZWxpbmUvcmlvLWJpdGJ1Y2tldC1zb3VyY2UtYWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZWxpbmUvcmlvLWJhY2t1cC1zZWNyZXRzLXJlc3RvcmUtc3RhZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9waXBlbGluZS9yaW8tcGlwZWxpbmUtdHlwZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4va2Fma2EnO1xuZXhwb3J0ICogYXMga2Fma2EgZnJvbSAnLi9rYWZrYSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vZGF0YWRvZyc7XG5leHBvcnQgKiBhcyBkYXRhZG9nIGZyb20gJy4vZGF0YWRvZyc7XG5leHBvcnQgKiBhcyBkYXRhZG9ndjIgZnJvbSAnLi9kYXRhZG9ndjInO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvY29wLWZyb250ZW5kL2Nsb3VkZnJvbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvdGVhbS10cmFuc3BvcnQtdHdvL2RhdGFkb2cnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9waXBlbGluZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vY29udHJpYnV0aW9ucy90ZWFtLWNsYWlkL2F3cy1iYWNrdXAtbW9uaXRvcmluZyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvdGVhbS1jbGFpZC9kYXRhZG9nLXVzYWdlLW1vbml0b3JpbmcnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvdGVhbS1vdWJvdXQtb3JkZXItYm9vay9hd3MtZWNzLWFicnVwdGx5LXN0b3BwZWQtbW9uaXRvcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vYmFja3VwJztcbmV4cG9ydCAqIGFzIGJhY2t1cCBmcm9tICcuL2JhY2t1cCc7XG4iXX0=
41
+ __exportStar(require("./contributions/smart-route/gitlab-runner"), exports);
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw2Q0FBMkI7QUFFM0IsNkNBQTJDO0FBRTNDLHFEQUFtQztBQUNuQyxzREFBb0M7QUFDcEMsb0RBQWtDO0FBRWxDLGdFQUE4QztBQUM5Qyx1Q0FBcUM7QUFFckMseUVBQXVEO0FBQ3ZELDhFQUE0RDtBQUM1RCwrREFBNkM7QUFFN0MsMENBQXdCO0FBQ3hCLG1DQUFpQztBQUVqQyw0Q0FBMEI7QUFDMUIsdUNBQXFDO0FBQ3JDLDJDQUF5QztBQUV6QywwRUFBd0Q7QUFFeEQsNkVBQTJEO0FBQzNELDhFQUE0RDtBQUU1RCxtRkFBaUU7QUFDakUsc0ZBQW9FO0FBRXBFLDBHQUF3RjtBQUV4RiwyQ0FBeUI7QUFDekIscUNBQW1DO0FBRW5DLDRFQUEwRCIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwnO1xuXG5leHBvcnQgKiBhcyB3YXRjaGZ1bHYyIGZyb20gJy4vd2F0Y2hmdWx2Mic7XG5cbmV4cG9ydCAqIGZyb20gJy4vcmlvLWxhbmRpbmctem9uZSc7XG5leHBvcnQgKiBmcm9tICcuL3Jpby1sb2FkLWJhbGFuY2VyJztcbmV4cG9ydCAqIGZyb20gJy4vcmlvLWNsYWlkb21ldGVyJztcblxuZXhwb3J0ICogZnJvbSAnLi9mYXJnYXRlL3Jpby1mYXJnYXRlLXNlcnZpY2UnO1xuZXhwb3J0ICogYXMgZmFyZ2F0ZSBmcm9tICcuL2ZhcmdhdGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL3BpcGVsaW5lL3Jpby1iaXRidWNrZXQtc291cmNlLWFjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVsaW5lL3Jpby1iYWNrdXAtc2VjcmV0cy1yZXN0b3JlLXN0YWdlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZWxpbmUvcmlvLXBpcGVsaW5lLXR5cGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2thZmthJztcbmV4cG9ydCAqIGFzIGthZmthIGZyb20gJy4va2Fma2EnO1xuXG5leHBvcnQgKiBmcm9tICcuL2RhdGFkb2cnO1xuZXhwb3J0ICogYXMgZGF0YWRvZyBmcm9tICcuL2RhdGFkb2cnO1xuZXhwb3J0ICogYXMgZGF0YWRvZ3YyIGZyb20gJy4vZGF0YWRvZ3YyJztcblxuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL2NvcC1mcm9udGVuZC9jbG91ZGZyb250JztcblxuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9kYXRhZG9nJztcbmV4cG9ydCAqIGZyb20gJy4vY29udHJpYnV0aW9ucy90ZWFtLXRyYW5zcG9ydC10d28vcGlwZWxpbmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvdGVhbS1jbGFpZC9hd3MtYmFja3VwLW1vbml0b3JpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL3RlYW0tY2xhaWQvZGF0YWRvZy11c2FnZS1tb25pdG9yaW5nJztcblxuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL3RlYW0tb3Vib3V0LW9yZGVyLWJvb2svYXdzLWVjcy1hYnJ1cHRseS1zdG9wcGVkLW1vbml0b3InO1xuXG5leHBvcnQgKiBmcm9tICcuL2JhY2t1cCc7XG5leHBvcnQgKiBhcyBiYWNrdXAgZnJvbSAnLi9iYWNrdXAnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvc21hcnQtcm91dGUvZ2l0bGFiLXJ1bm5lcic7XG4iXX0=
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.1.0",
18
+ "version": "6.2.2",
19
19
  "types": "lib/index.d.ts",
20
20
  "stability": "stable",
21
21
  "exports": {
@@ -51,7 +51,8 @@
51
51
  "bump": "commit-and-tag-version -a",
52
52
  "test": "jest --coverage",
53
53
  "test:watch": "jest --watch",
54
- "eslint": "eslint --ext .ts,.tsx --fix --no-error-on-unmatched-pattern src test",
54
+ "eslint": "eslint --ext .ts,.tsx --no-error-on-unmatched-pattern src test",
55
+ "eslint-fix": "eslint --ext .ts,.tsx --fix --no-error-on-unmatched-pattern src test",
55
56
  "docgen": "jsii-docgen -o ./docs/API.md",
56
57
  "cdk": "cdk",
57
58
  "release:check": "node release-commit-check.js",
@@ -99,6 +100,9 @@
99
100
  "@datadog/datadog-api-client": "^1.24.0",
100
101
  "js-yaml": "~4.1.0"
101
102
  },
103
+ "optionalDependencies": {
104
+ "@pepperize/cdk-autoscaling-gitlab-runner": "^0.2.613"
105
+ },
102
106
  "bundledDependencies": [
103
107
  "js-yaml"
104
108
  ],
package/version.json CHANGED
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": "6.1.0"
2
+ "version": "6.2.2"
3
3
  }