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

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 CHANGED
@@ -6140,7 +6140,7 @@
6140
6140
  "kind": "interface",
6141
6141
  "locationInModule": {
6142
6142
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6143
- "line": 19
6143
+ "line": 20
6144
6144
  },
6145
6145
  "name": "GitLabRunnerProps",
6146
6146
  "properties": [
@@ -6152,7 +6152,22 @@
6152
6152
  "immutable": true,
6153
6153
  "locationInModule": {
6154
6154
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6155
- "line": 20
6155
+ "line": 24
6156
+ },
6157
+ "name": "cache",
6158
+ "type": {
6159
+ "fqn": "aws-cdk-lib.aws_s3.IBucket"
6160
+ }
6161
+ },
6162
+ {
6163
+ "abstract": true,
6164
+ "docs": {
6165
+ "stability": "stable"
6166
+ },
6167
+ "immutable": true,
6168
+ "locationInModule": {
6169
+ "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6170
+ "line": 21
6156
6171
  },
6157
6172
  "name": "env",
6158
6173
  "type": {
@@ -6167,7 +6182,7 @@
6167
6182
  "immutable": true,
6168
6183
  "locationInModule": {
6169
6184
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6170
- "line": 22
6185
+ "line": 23
6171
6186
  },
6172
6187
  "name": "managerInstanceType",
6173
6188
  "optional": true,
@@ -6183,17 +6198,12 @@
6183
6198
  "immutable": true,
6184
6199
  "locationInModule": {
6185
6200
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6186
- "line": 21
6201
+ "line": 22
6187
6202
  },
6188
6203
  "name": "runnersWorkerProps",
6189
6204
  "optional": true,
6190
6205
  "type": {
6191
- "collection": {
6192
- "elementtype": {
6193
- "fqn": "@rio-cloud/cdk-v2-constructs.GitlabRunnerWorkerProps"
6194
- },
6195
- "kind": "array"
6196
- }
6206
+ "fqn": "@rio-cloud/cdk-v2-constructs.GitlabRunnerWorkerProps"
6197
6207
  }
6198
6208
  }
6199
6209
  ],
@@ -6203,7 +6213,7 @@
6203
6213
  "assembly": "@rio-cloud/cdk-v2-constructs",
6204
6214
  "base": "constructs.Construct",
6205
6215
  "docs": {
6206
- "remarks": "By default, the construct will create a Runner with a manager T3 Micro instance which will be enabled to spawn T3 Large Runner\nworker spot instance. The default runner Role has only the permissions to upload and download from the S3 runner cache.\n\nminimal configuration with runner spot instance:\n```ts\nnew SpotServiceLinkedRole(stack, 'SpotLinkedRole');\nnew GitlabRunner(stack, 'GitLabRunner', {\n env: {account: '123456789012', region: 'eu-west-1'}\n});\n```\nrecommended:\n```ts\nnew SpotServiceLinkedRole(stack, 'SpotLinkedRole');\nconst runnerRoles = new RunnerRoles(stack, 'RunnerRoles', {env: {account: '123456789012', region: 'eu-west-1'}});\nnew GitlabRunner(stack, 'GitLabRunner', {\n env: {account: '123456789012', region: 'eu-west-1'},\n runnersWorkerProps: [\n {\n token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power\n gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab\n instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner\n spotPrice: 0.2, // exemplary spot price\n requestSpotPrice: true,\n defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role\n },\n {\n token: myTokenForTaggedRunner2, // with this runner we want to run all generic jobs that do not require much processing power\n gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab\n instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.MEDIUM), // exemplary smaller runner\n spotPrice: 0.044, // exemplary spot price\n requestSpotPrice: true,\n defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role\n },\n ],\n});\n```",
6216
+ "remarks": "By default, the construct will create a Runner with a manager T3 Micro instance which will be enabled to spawn T3 Large Runner\nworker spot instance. The default runner Role has only the permissions to upload and download from the S3 runner cache.\n\nminimal configuration with runner spot instance:\n```ts\nnew SpotServiceLinkedRole(stack, 'SpotLinkedRole');\nconst myBucket = new Bucket(stack, 'MyShareRunnerCache', {\n enforceSSL: true,\n publicReadAccess: false,\n encryption: BucketEncryption.S3_MANAGED,\n lifecycleRules: [\n {\n enabled: true,\n expiration: Duration.days(30),\n },\n ],\n });\nnew GitlabRunner(stack, 'GitLabRunner', {\n env: {account: '123456789012', region: 'eu-west-1'},\n cache: myBucket // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners\n});\n```\nrecommended:\n```ts\nnew SpotServiceLinkedRole(stack, 'SpotLinkedRole');\nconst runnerRoles = new RunnerRoles(stack, 'RunnerRoles', {env: {account: '123456789012', region: 'eu-west-1'}});\nconst myBucket = new Bucket(stack, 'MyShareRunnerCache', {\n enforceSSL: true,\n publicReadAccess: false,\n encryption: BucketEncryption.S3_MANAGED,\n lifecycleRules: [\n {\n enabled: true,\n expiration: Duration.days(30),\n },\n ],\n });\nnew GitlabRunner(stack, 'GitLabRunner', {\n env: {account: '123456789012', region: 'eu-west-1'},\n cache: myBucket // // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners\n runnersWorkerProps: {\n token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power\n gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab\n instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner\n spotPrice: 0.2, // exemplary spot price\n requestSpotPrice: true,\n defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role\n },\n});\n```",
6207
6217
  "stability": "stable",
6208
6218
  "summary": "The construct create the GitLabRunner Manager instance which will autoscale Runner instances based on the configuration."
6209
6219
  },
@@ -6214,7 +6224,7 @@
6214
6224
  },
6215
6225
  "locationInModule": {
6216
6226
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6217
- "line": 102
6227
+ "line": 116
6218
6228
  },
6219
6229
  "parameters": [
6220
6230
  {
@@ -6240,7 +6250,7 @@
6240
6250
  "kind": "class",
6241
6251
  "locationInModule": {
6242
6252
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6243
- "line": 95
6253
+ "line": 111
6244
6254
  },
6245
6255
  "name": "GitlabRunner",
6246
6256
  "symbolId": "src/contributions/smart-route/gitlab-runner/autoscaling-runner:GitlabRunner"
@@ -6257,7 +6267,7 @@
6257
6267
  "kind": "interface",
6258
6268
  "locationInModule": {
6259
6269
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6260
- "line": 31
6270
+ "line": 33
6261
6271
  },
6262
6272
  "name": "GitlabRunnerWorkerProps",
6263
6273
  "properties": [
@@ -6270,7 +6280,7 @@
6270
6280
  "immutable": true,
6271
6281
  "locationInModule": {
6272
6282
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6273
- "line": 43
6283
+ "line": 45
6274
6284
  },
6275
6285
  "name": "defaultWorkerRole",
6276
6286
  "type": {
@@ -6286,7 +6296,7 @@
6286
6296
  "immutable": true,
6287
6297
  "locationInModule": {
6288
6298
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6289
- "line": 35
6299
+ "line": 37
6290
6300
  },
6291
6301
  "name": "gitInstanceUrl",
6292
6302
  "type": {
@@ -6302,7 +6312,7 @@
6302
6312
  "immutable": true,
6303
6313
  "locationInModule": {
6304
6314
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6305
- "line": 37
6315
+ "line": 39
6306
6316
  },
6307
6317
  "name": "instanceType",
6308
6318
  "type": {
@@ -6318,7 +6328,7 @@
6318
6328
  "immutable": true,
6319
6329
  "locationInModule": {
6320
6330
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6321
- "line": 41
6331
+ "line": 43
6322
6332
  },
6323
6333
  "name": "requestSpotPrice",
6324
6334
  "type": {
@@ -6334,7 +6344,7 @@
6334
6344
  "immutable": true,
6335
6345
  "locationInModule": {
6336
6346
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6337
- "line": 39
6347
+ "line": 41
6338
6348
  },
6339
6349
  "name": "spotPrice",
6340
6350
  "type": {
@@ -6350,7 +6360,7 @@
6350
6360
  "immutable": true,
6351
6361
  "locationInModule": {
6352
6362
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6353
- "line": 33
6363
+ "line": 35
6354
6364
  },
6355
6365
  "name": "token",
6356
6366
  "type": {
@@ -6367,7 +6377,7 @@
6367
6377
  "immutable": true,
6368
6378
  "locationInModule": {
6369
6379
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6370
- "line": 45
6380
+ "line": 47
6371
6381
  },
6372
6382
  "name": "maxBuilds",
6373
6383
  "optional": true,
@@ -6385,7 +6395,7 @@
6385
6395
  "immutable": true,
6386
6396
  "locationInModule": {
6387
6397
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6388
- "line": 47
6398
+ "line": 49
6389
6399
  },
6390
6400
  "name": "maxIdleInstance",
6391
6401
  "optional": true,
@@ -6403,7 +6413,7 @@
6403
6413
  "immutable": true,
6404
6414
  "locationInModule": {
6405
6415
  "filename": "src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts",
6406
- "line": 49
6416
+ "line": 51
6407
6417
  },
6408
6418
  "name": "maxIdleTime",
6409
6419
  "optional": true,
@@ -16728,5 +16738,5 @@
16728
16738
  }
16729
16739
  },
16730
16740
  "version": "0.0.0",
16731
- "fingerprint": "rzGg3npyOR1/DDc02aMZX7iKNdxl68n9K1t+ii5Zskw="
16741
+ "fingerprint": "vkv0ByaY8bMTd8OsR9NHooh1ytKdvwQivH2W8ggVLS4="
16732
16742
  }
package/CHANGELOG.md CHANGED
@@ -2,6 +2,15 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version) for commit guidelines.
4
4
 
5
+ ## [6.3.1](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.3.0&sourceBranch=refs%2Ftags%2Fv6.3.1) (2024-08-01)
6
+
7
+ ## [6.3.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.2.2&sourceBranch=refs%2Ftags%2Fv6.3.0) (2024-07-23)
8
+
9
+
10
+ ### Features
11
+
12
+ * adjust gitlab runner construct to handle new registration process and change worker props since now one manager can only handle one runner group ([f744213](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/f74421342e21729a4b8732e4913ad31d93f0d818))
13
+
5
14
  ## [6.2.2](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.2.1&sourceBranch=refs%2Ftags%2Fv6.2.2) (2024-07-19)
6
15
 
7
16
  ## [6.2.1](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.2.0&sourceBranch=refs%2Ftags%2Fv6.2.1) (2024-07-19)
package/docs/API.md CHANGED
@@ -2497,34 +2497,48 @@ worker spot instance. The default runner Role has only the permissions to upload
2497
2497
  minimal configuration with runner spot instance:
2498
2498
  ```ts
2499
2499
  new SpotServiceLinkedRole(stack, 'SpotLinkedRole');
2500
+ const myBucket = new Bucket(stack, 'MyShareRunnerCache', {
2501
+ enforceSSL: true,
2502
+ publicReadAccess: false,
2503
+ encryption: BucketEncryption.S3_MANAGED,
2504
+ lifecycleRules: [
2505
+ {
2506
+ enabled: true,
2507
+ expiration: Duration.days(30),
2508
+ },
2509
+ ],
2510
+ });
2500
2511
  new GitlabRunner(stack, 'GitLabRunner', {
2501
- env: {account: '123456789012', region: 'eu-west-1'}
2512
+ env: {account: '123456789012', region: 'eu-west-1'},
2513
+ cache: myBucket // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners
2502
2514
  });
2503
2515
  ```
2504
2516
  recommended:
2505
2517
  ```ts
2506
2518
  new SpotServiceLinkedRole(stack, 'SpotLinkedRole');
2507
2519
  const runnerRoles = new RunnerRoles(stack, 'RunnerRoles', {env: {account: '123456789012', region: 'eu-west-1'}});
2520
+ const myBucket = new Bucket(stack, 'MyShareRunnerCache', {
2521
+ enforceSSL: true,
2522
+ publicReadAccess: false,
2523
+ encryption: BucketEncryption.S3_MANAGED,
2524
+ lifecycleRules: [
2525
+ {
2526
+ enabled: true,
2527
+ expiration: Duration.days(30),
2528
+ },
2529
+ ],
2530
+ });
2508
2531
  new GitlabRunner(stack, 'GitLabRunner', {
2509
2532
  env: {account: '123456789012', region: 'eu-west-1'},
2510
- runnersWorkerProps: [
2511
- {
2512
- token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power
2513
- gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
2514
- instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner
2515
- spotPrice: 0.2, // exemplary spot price
2516
- requestSpotPrice: true,
2517
- defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
2518
- },
2519
- {
2520
- token: myTokenForTaggedRunner2, // with this runner we want to run all generic jobs that do not require much processing power
2521
- gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
2522
- instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.MEDIUM), // exemplary smaller runner
2523
- spotPrice: 0.044, // exemplary spot price
2524
- requestSpotPrice: true,
2525
- defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
2526
- },
2527
- ],
2533
+ cache: myBucket // // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners
2534
+ runnersWorkerProps: {
2535
+ token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power
2536
+ gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
2537
+ instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner
2538
+ spotPrice: 0.2, // exemplary spot price
2539
+ requestSpotPrice: true,
2540
+ defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
2541
+ },
2528
2542
  });
2529
2543
  ```
2530
2544
 
@@ -9959,9 +9973,20 @@ const gitLabRunnerProps: GitLabRunnerProps = { ... }
9959
9973
 
9960
9974
  | **Name** | **Type** | **Description** |
9961
9975
  | --- | --- | --- |
9976
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.GitLabRunnerProps.property.cache">cache</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | *No description.* |
9962
9977
  | <code><a href="#@rio-cloud/cdk-v2-constructs.GitLabRunnerProps.property.env">env</a></code> | <code>aws-cdk-lib.Environment</code> | *No description.* |
9963
9978
  | <code><a href="#@rio-cloud/cdk-v2-constructs.GitLabRunnerProps.property.managerInstanceType">managerInstanceType</a></code> | <code>aws-cdk-lib.aws_ec2.InstanceType</code> | *No description.* |
9964
- | <code><a href="#@rio-cloud/cdk-v2-constructs.GitLabRunnerProps.property.runnersWorkerProps">runnersWorkerProps</a></code> | <code><a href="#@rio-cloud/cdk-v2-constructs.GitlabRunnerWorkerProps">GitlabRunnerWorkerProps</a>[]</code> | *No description.* |
9979
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.GitLabRunnerProps.property.runnersWorkerProps">runnersWorkerProps</a></code> | <code><a href="#@rio-cloud/cdk-v2-constructs.GitlabRunnerWorkerProps">GitlabRunnerWorkerProps</a></code> | *No description.* |
9980
+
9981
+ ---
9982
+
9983
+ ##### `cache`<sup>Required</sup> <a name="cache" id="@rio-cloud/cdk-v2-constructs.GitLabRunnerProps.property.cache"></a>
9984
+
9985
+ ```typescript
9986
+ public readonly cache: IBucket;
9987
+ ```
9988
+
9989
+ - *Type:* aws-cdk-lib.aws_s3.IBucket
9965
9990
 
9966
9991
  ---
9967
9992
 
@@ -9988,10 +10013,10 @@ public readonly managerInstanceType: InstanceType;
9988
10013
  ##### `runnersWorkerProps`<sup>Optional</sup> <a name="runnersWorkerProps" id="@rio-cloud/cdk-v2-constructs.GitLabRunnerProps.property.runnersWorkerProps"></a>
9989
10014
 
9990
10015
  ```typescript
9991
- public readonly runnersWorkerProps: GitlabRunnerWorkerProps[];
10016
+ public readonly runnersWorkerProps: GitlabRunnerWorkerProps;
9992
10017
  ```
9993
10018
 
9994
- - *Type:* <a href="#@rio-cloud/cdk-v2-constructs.GitlabRunnerWorkerProps">GitlabRunnerWorkerProps</a>[]
10019
+ - *Type:* <a href="#@rio-cloud/cdk-v2-constructs.GitlabRunnerWorkerProps">GitlabRunnerWorkerProps</a>
9995
10020
 
9996
10021
  ---
9997
10022
 
@@ -1,6 +1,7 @@
1
1
  import { Environment, Stack } from 'aws-cdk-lib';
2
2
  import { InstanceType } from 'aws-cdk-lib/aws-ec2';
3
3
  import { IRole } from 'aws-cdk-lib/aws-iam';
4
+ import { IBucket } from 'aws-cdk-lib/aws-s3';
4
5
  import { IStringParameter } from 'aws-cdk-lib/aws-ssm';
5
6
  import { Construct } from 'constructs';
6
7
  /**
@@ -10,8 +11,9 @@ import { Construct } from 'constructs';
10
11
  */
11
12
  export interface GitLabRunnerProps {
12
13
  readonly env: Environment;
13
- readonly runnersWorkerProps?: GitlabRunnerWorkerProps[];
14
+ readonly runnersWorkerProps?: GitlabRunnerWorkerProps;
14
15
  readonly managerInstanceType?: InstanceType;
16
+ readonly cache: IBucket;
15
17
  }
16
18
  /**
17
19
  * The GitlabRunnerWorkerProps interface provides a simplified GitLab Runner worker configuration
@@ -48,34 +50,48 @@ export type GitlabInstanceUrl = 'https://gitlab.cicd.man' | 'https://gitlab.coll
48
50
  * minimal configuration with runner spot instance:
49
51
  * ```ts
50
52
  * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');
53
+ * const myBucket = new Bucket(stack, 'MyShareRunnerCache', {
54
+ * enforceSSL: true,
55
+ * publicReadAccess: false,
56
+ * encryption: BucketEncryption.S3_MANAGED,
57
+ * lifecycleRules: [
58
+ * {
59
+ * enabled: true,
60
+ * expiration: Duration.days(30),
61
+ * },
62
+ * ],
63
+ * });
51
64
  * new GitlabRunner(stack, 'GitLabRunner', {
52
- * env: {account: '123456789012', region: 'eu-west-1'}
65
+ * env: {account: '123456789012', region: 'eu-west-1'},
66
+ * cache: myBucket // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners
53
67
  * });
54
68
  *```
55
69
  * recommended:
56
70
  * ```ts
57
71
  * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');
58
72
  * const runnerRoles = new RunnerRoles(stack, 'RunnerRoles', {env: {account: '123456789012', region: 'eu-west-1'}});
73
+ * const myBucket = new Bucket(stack, 'MyShareRunnerCache', {
74
+ * enforceSSL: true,
75
+ * publicReadAccess: false,
76
+ * encryption: BucketEncryption.S3_MANAGED,
77
+ * lifecycleRules: [
78
+ * {
79
+ * enabled: true,
80
+ * expiration: Duration.days(30),
81
+ * },
82
+ * ],
83
+ * });
59
84
  * new GitlabRunner(stack, 'GitLabRunner', {
60
85
  * env: {account: '123456789012', region: 'eu-west-1'},
61
- * runnersWorkerProps: [
62
- * {
63
- * token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power
64
- * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
65
- * instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner
66
- * spotPrice: 0.2, // exemplary spot price
67
- * requestSpotPrice: true,
68
- * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
69
- * },
70
- * {
71
- * token: myTokenForTaggedRunner2, // with this runner we want to run all generic jobs that do not require much processing power
72
- * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
73
- * instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.MEDIUM), // exemplary smaller runner
74
- * spotPrice: 0.044, // exemplary spot price
75
- * requestSpotPrice: true,
76
- * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
77
- * },
78
- * ],
86
+ * cache: myBucket // // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners
87
+ * runnersWorkerProps: {
88
+ * token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power
89
+ * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
90
+ * instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner
91
+ * spotPrice: 0.2, // exemplary spot price
92
+ * requestSpotPrice: true,
93
+ * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
94
+ * },
79
95
  * });
80
96
  * ```
81
97
  */
@@ -17,121 +17,135 @@ const rio_landing_zone_1 = require("../../../rio-landing-zone");
17
17
  * minimal configuration with runner spot instance:
18
18
  * ```ts
19
19
  * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');
20
+ * const myBucket = new Bucket(stack, 'MyShareRunnerCache', {
21
+ * enforceSSL: true,
22
+ * publicReadAccess: false,
23
+ * encryption: BucketEncryption.S3_MANAGED,
24
+ * lifecycleRules: [
25
+ * {
26
+ * enabled: true,
27
+ * expiration: Duration.days(30),
28
+ * },
29
+ * ],
30
+ * });
20
31
  * new GitlabRunner(stack, 'GitLabRunner', {
21
- * env: {account: '123456789012', region: 'eu-west-1'}
32
+ * env: {account: '123456789012', region: 'eu-west-1'},
33
+ * cache: myBucket // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners
22
34
  * });
23
35
  *```
24
36
  * recommended:
25
37
  * ```ts
26
38
  * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');
27
39
  * const runnerRoles = new RunnerRoles(stack, 'RunnerRoles', {env: {account: '123456789012', region: 'eu-west-1'}});
40
+ * const myBucket = new Bucket(stack, 'MyShareRunnerCache', {
41
+ * enforceSSL: true,
42
+ * publicReadAccess: false,
43
+ * encryption: BucketEncryption.S3_MANAGED,
44
+ * lifecycleRules: [
45
+ * {
46
+ * enabled: true,
47
+ * expiration: Duration.days(30),
48
+ * },
49
+ * ],
50
+ * });
28
51
  * new GitlabRunner(stack, 'GitLabRunner', {
29
52
  * env: {account: '123456789012', region: 'eu-west-1'},
30
- * runnersWorkerProps: [
31
- * {
32
- * token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power
33
- * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
34
- * instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner
35
- * spotPrice: 0.2, // exemplary spot price
36
- * requestSpotPrice: true,
37
- * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
38
- * },
39
- * {
40
- * token: myTokenForTaggedRunner2, // with this runner we want to run all generic jobs that do not require much processing power
41
- * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
42
- * instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.MEDIUM), // exemplary smaller runner
43
- * spotPrice: 0.044, // exemplary spot price
44
- * requestSpotPrice: true,
45
- * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
46
- * },
47
- * ],
53
+ * cache: myBucket // // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners
54
+ * runnersWorkerProps: {
55
+ * token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power
56
+ * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
57
+ * instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner
58
+ * spotPrice: 0.2, // exemplary spot price
59
+ * requestSpotPrice: true,
60
+ * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
61
+ * },
48
62
  * });
49
63
  * ```
50
64
  */
51
65
  class GitlabRunner extends constructs_1.Construct {
52
66
  constructor(scope, id, props) {
53
67
  super(scope, id);
54
- this.autoscalingConfig = [
55
- {
56
- periods: ['* * 7-24 * * mon-fri *'],
68
+ this.autoscalingConfig = [{
69
+ periods: ['* * 7-22 * * mon-fri *'],
57
70
  timezone: 'Europe/Berlin',
58
- },
59
- ];
71
+ }];
60
72
  const vpc = rio_landing_zone_1.RioLandingZone.getDefaultVpc(scope);
61
73
  const runnerConfig = props.runnersWorkerProps
62
74
  ? this.createWorkerConfigurations(props.runnersWorkerProps, props.env)
63
75
  : this.getDefaultRunnerWorkerConfig(props.env);
64
76
  const managerInstance = props.managerInstanceType ??
65
77
  aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.T3, aws_ec2_1.InstanceSize.MICRO);
66
- new cdk_autoscaling_gitlab_runner_1.GitlabRunnerAutoscaling(scope, `GLR${scope.stackName}`, {
67
- runners: runnerConfig,
78
+ const runner = new cdk_autoscaling_gitlab_runner_1.GitlabRunnerAutoscaling(scope, `GLR${scope.stackName}`, {
79
+ runners: [runnerConfig],
68
80
  network: {
69
81
  vpc: vpc,
70
82
  },
71
83
  manager: {
72
84
  instanceType: managerInstance,
73
85
  },
86
+ cache: { bucket: props.cache },
74
87
  checkInterval: 30, // check every 30s for pending jobs
75
88
  concurrent: 300, // Global limit of concurrent jobs,
76
89
  });
90
+ // due to the new registration process we have to register the runner by running explicit commands on start of the manager
91
+ runner.manager.userData.addCommands('cp /etc/gitlab-runner/config.toml /etc/gitlab-runner/config_back.toml', // avoid toml merge conflicts
92
+ `gitlab-runner register --non-interactive --template-config /etc/gitlab-runner/config_back.toml --token ${props.runnersWorkerProps?.token.stringValue}`, 'gitlab-runner restart');
77
93
  }
78
94
  createWorkerConfigurations(workerProps, env) {
79
- return workerProps.map((val) => ({
80
- token: val.token,
81
- role: val.defaultWorkerRole,
95
+ return {
96
+ token: workerProps.token,
97
+ role: workerProps.defaultWorkerRole,
82
98
  configuration: {
83
- url: val.gitInstanceUrl,
99
+ url: workerProps.gitInstanceUrl,
84
100
  machine: {
85
101
  autoscaling: this.autoscalingConfig,
86
- maxBuilds: val.maxBuilds ?? 10,
87
- idleCount: val.maxIdleInstance ?? 5,
88
- idleTime: val.maxIdleTime ?? 900,
102
+ maxBuilds: workerProps.maxBuilds ?? 10,
103
+ idleCount: workerProps.maxIdleInstance ?? 5,
104
+ idleTime: workerProps.maxIdleTime ?? 900,
89
105
  machineOptions: {
90
- requestSpotInstance: val.requestSpotPrice,
91
- spotPrice: val.spotPrice,
106
+ requestSpotInstance: workerProps.requestSpotPrice,
107
+ spotPrice: workerProps.spotPrice,
92
108
  },
93
109
  },
94
110
  environment: [
95
111
  'DOCKER_DRIVER=overlay2',
96
112
  'DOCKER_TLS_DIRCE=/certs',
97
- `DOCKER_AUTH_CONFIG={"credHelpers": { "public.ecr.aws": "ecr-login", "${env.account}.dkr.ecr.<region>.amazonaws.com": "ecr-login" } }`,
113
+ `DOCKER_AUTH_CONFIG={"credHelpers": { "public.ecr.aws": "ecr-login", "${env.account}.dkr.ecr.${env.region}.amazonaws.com": "ecr-login" } }`,
98
114
  ],
99
115
  },
100
- instanceType: val.instanceType,
101
- }));
116
+ instanceType: workerProps.instanceType,
117
+ };
102
118
  }
103
119
  getDefaultRunnerWorkerConfig(env) {
104
120
  const gitLabRunnerTokenParameter = aws_ssm_1.StringParameter.fromStringParameterAttributes(this, 'RunnerToken', {
105
121
  parameterName: '/config/gitlab-runner-cdk/token',
106
122
  });
107
- return [
108
- {
109
- token: gitLabRunnerTokenParameter,
110
- configuration: {
111
- url: 'https://gitlab.cicd.man',
112
- limit: 0,
113
- machine: {
114
- maxBuilds: 10,
115
- autoscaling: this.autoscalingConfig,
116
- idleCount: 5,
117
- idleTime: 900,
118
- machineOptions: {
119
- requestSpotInstance: true,
120
- spotPrice: 0.09,
121
- },
123
+ return {
124
+ token: gitLabRunnerTokenParameter,
125
+ configuration: {
126
+ url: 'https://gitlab.cicd.man',
127
+ limit: 0,
128
+ machine: {
129
+ maxBuilds: 10,
130
+ autoscaling: this.autoscalingConfig,
131
+ idleCount: 5,
132
+ idleTime: 900,
133
+ machineOptions: {
134
+ requestSpotInstance: true,
135
+ spotPrice: 0.09,
122
136
  },
123
- environment: [
124
- 'DOCKER_DRIVER=overlay2',
125
- 'DOCKER_TLS_DIRCE=/certs',
126
- `DOCKER_AUTH_CONFIG={"credHelpers": { "public.ecr.aws": "ecr-login", "${env.account}.dkr.ecr.<region>.amazonaws.com": "ecr-login" } }`,
127
- ],
128
137
  },
129
- instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.T3, aws_ec2_1.InstanceSize.LARGE),
138
+ environment: [
139
+ 'DOCKER_DRIVER=overlay2',
140
+ 'DOCKER_TLS_DIRCE=/certs',
141
+ `DOCKER_AUTH_CONFIG={"credHelpers": { "public.ecr.aws": "ecr-login", "${env.account}.dkr.ecr.${env.region}.amazonaws.com": "ecr-login" } }`,
142
+ ],
130
143
  },
131
- ];
144
+ instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.T3, aws_ec2_1.InstanceSize.LARGE),
145
+ };
132
146
  }
133
147
  }
134
148
  exports.GitlabRunner = GitlabRunner;
135
149
  _a = JSII_RTTI_SYMBOL_1;
136
150
  GitlabRunner[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.GitlabRunner", version: "0.0.0" };
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autoscaling-runner.js","sourceRoot":"","sources":["../../../../src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport {\n  AutoscalingConfiguration,\n  GitlabRunnerAutoscaling,\n  GitlabRunnerAutoscalingJobRunnerProps,\n} from '@pepperize/cdk-autoscaling-gitlab-runner';\nimport { Environment, Stack } from 'aws-cdk-lib';\nimport { InstanceClass, InstanceSize, InstanceType } from 'aws-cdk-lib/aws-ec2';\nimport { IRole } from 'aws-cdk-lib/aws-iam';\nimport { IStringParameter, StringParameter } from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\nimport { RioLandingZone } from '../../../rio-landing-zone';\n\n/**\n * The GitLabRunnerProps require the VPC ID, a defined environment of account and region, optional\n * runner configuration and optionally the GitLab Runner Manager instance type. By default, a T3 Micro instance will be used.\n * For larger workloads and very active teams it is recommended to use T3 Small for the manager instead.\n */\nexport interface GitLabRunnerProps {\n  readonly env: Environment;\n  readonly runnersWorkerProps?: GitlabRunnerWorkerProps[];\n  readonly managerInstanceType?: InstanceType;\n}\n\n/**\n * The GitlabRunnerWorkerProps interface provides a simplified GitLab Runner worker configuration\n * requiring a token as an SSM parameter, one of the valid gitlab URLs, instance of you choice, the desired max spot price,\n * whether to use spot instance or not and a default role.\n * It is recommended to use the RunnerRoles construct, and it's exposed default runner role.\n */\nexport interface GitlabRunnerWorkerProps {\n  /** The SSM StringParameter with the registered runner token  */\n  readonly token: IStringParameter;\n  /** The GitLab instance URL, either https://gitlab.cicd.man or https://gitlab.collaborationlayer-traton.com */\n  readonly gitInstanceUrl: GitlabInstanceUrl;\n  /** The instance type for the runner worker */\n  readonly instanceType: InstanceType;\n  /** The desired max spot price */\n  readonly spotPrice: number;\n  /** Whether to use spot instance or not, Requires ServiceLinked Role for EC2 Spot to be deployed in the account */\n  readonly requestSpotPrice: boolean;\n  /** The default role for the runner worker when spawned */\n  readonly defaultWorkerRole: IRole;\n  /** The maximum number of builds for an instance before it has to be decommissioned. Default 10 */\n  readonly maxBuilds?: number;\n  /** The maximum number of instances to keep idle for new incoming jobs. Default 5 */\n  readonly maxIdleInstance?: number;\n  /** The maximum idle time seconds for an instance. Default 900 seconds */\n  readonly maxIdleTime?: number;\n}\n\nexport type GitlabInstanceUrl =\n  | 'https://gitlab.cicd.man'\n  | 'https://gitlab.collaborationlayer-traton.com';\n\n/**\n * The construct create the GitLabRunner Manager instance which will autoscale Runner instances based on the configuration.\n * By default, the construct will create a Runner with a manager T3 Micro instance which will be enabled to spawn T3 Large Runner\n * worker spot instance. The default runner Role has only the permissions to upload and download from the S3 runner cache.\n *\n * minimal configuration with runner spot instance:\n * ```ts\n * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');\n * new GitlabRunner(stack, 'GitLabRunner', {\n *  env: {account: '123456789012', region: 'eu-west-1'}\n * });\n *```\n * recommended:\n * ```ts\n * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');\n * const runnerRoles = new RunnerRoles(stack, 'RunnerRoles', {env: {account: '123456789012', region: 'eu-west-1'}});\n * new GitlabRunner(stack, 'GitLabRunner', {\n *  env: {account: '123456789012', region: 'eu-west-1'},\n *  runnersWorkerProps: [\n *    {\n *      token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power\n *      gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab\n *      instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner\n *      spotPrice: 0.2, // exemplary spot price\n *      requestSpotPrice: true,\n *      defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role\n *    },\n *    {\n *      token: myTokenForTaggedRunner2, // with this runner we want to run all generic jobs that do not require much processing power\n *      gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab\n *      instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.MEDIUM), // exemplary smaller runner\n *      spotPrice: 0.044, // exemplary spot price\n *      requestSpotPrice: true,\n *      defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role\n *    },\n *  ],\n * });\n * ```\n */\nexport class GitlabRunner extends Construct {\n  private autoscalingConfig: AutoscalingConfiguration[] = [\n    {\n      periods: ['* * 7-24 * * mon-fri *'],\n      timezone: 'Europe/Berlin',\n    },\n  ];\n  constructor(scope: Stack, id: string, props: GitLabRunnerProps) {\n    super(scope, id);\n\n    const vpc = RioLandingZone.getDefaultVpc(scope);\n\n    const runnerConfig = props.runnersWorkerProps\n      ? this.createWorkerConfigurations(props.runnersWorkerProps, props.env)\n      : this.getDefaultRunnerWorkerConfig(props.env);\n\n    const managerInstance =\n      props.managerInstanceType ??\n      InstanceType.of(InstanceClass.T3, InstanceSize.MICRO);\n\n    new GitlabRunnerAutoscaling(scope, `GLR${scope.stackName}`, {\n      runners: runnerConfig,\n      network: {\n        vpc: vpc,\n      },\n      manager: {\n        instanceType: managerInstance,\n      },\n      checkInterval: 30, // check every 30s for pending jobs\n      concurrent: 300, // Global limit of concurrent jobs,\n    });\n  }\n\n  private createWorkerConfigurations(\n    workerProps: GitlabRunnerWorkerProps[],\n    env: Environment,\n  ): GitlabRunnerAutoscalingJobRunnerProps[] {\n    return workerProps.map((val) => ({\n      token: val.token,\n      role: val.defaultWorkerRole,\n      configuration: {\n        url: val.gitInstanceUrl,\n        machine: {\n          autoscaling: this.autoscalingConfig,\n          maxBuilds: val.maxBuilds ?? 10,\n          idleCount: val.maxIdleInstance ?? 5,\n          idleTime: val.maxIdleTime ?? 900,\n          machineOptions: {\n            requestSpotInstance: val.requestSpotPrice,\n            spotPrice: val.spotPrice,\n          },\n        },\n        environment: [\n          'DOCKER_DRIVER=overlay2',\n          'DOCKER_TLS_DIRCE=/certs',\n          `DOCKER_AUTH_CONFIG={\"credHelpers\": { \"public.ecr.aws\": \"ecr-login\", \"${\n            env.account\n          }.dkr.ecr.<region>.amazonaws.com\": \"ecr-login\" } }`,\n        ],\n      },\n      instanceType: val.instanceType,\n    }));\n  }\n\n  private getDefaultRunnerWorkerConfig(\n    env: Environment,\n  ): GitlabRunnerAutoscalingJobRunnerProps[] {\n    const gitLabRunnerTokenParameter =\n      StringParameter.fromStringParameterAttributes(this, 'RunnerToken', {\n        parameterName: '/config/gitlab-runner-cdk/token',\n      });\n    return [\n      {\n        token: gitLabRunnerTokenParameter,\n        configuration: {\n          url: 'https://gitlab.cicd.man',\n          limit: 0,\n          machine: {\n            maxBuilds: 10,\n            autoscaling: this.autoscalingConfig,\n            idleCount: 5,\n            idleTime: 900,\n            machineOptions: {\n              requestSpotInstance: true,\n              spotPrice: 0.09,\n            },\n          },\n          environment: [\n            'DOCKER_DRIVER=overlay2',\n            'DOCKER_TLS_DIRCE=/certs',\n            `DOCKER_AUTH_CONFIG={\"credHelpers\": { \"public.ecr.aws\": \"ecr-login\", \"${\n              env.account\n            }.dkr.ecr.<region>.amazonaws.com\": \"ecr-login\" } }`,\n          ],\n        },\n        instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.LARGE),\n      },\n    ];\n  }\n}\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autoscaling-runner.js","sourceRoot":"","sources":["../../../../src/contributions/smart-route/gitlab-runner/autoscaling-runner.ts"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport {\n  AutoscalingConfiguration,\n  GitlabRunnerAutoscaling,\n  GitlabRunnerAutoscalingJobRunnerProps,\n} from '@pepperize/cdk-autoscaling-gitlab-runner';\nimport { Environment, Stack } from 'aws-cdk-lib';\nimport { InstanceClass, InstanceSize, InstanceType } from 'aws-cdk-lib/aws-ec2';\nimport { IRole } from 'aws-cdk-lib/aws-iam';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\nimport { IStringParameter, StringParameter } from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\nimport { RioLandingZone } from '../../../rio-landing-zone';\n\n/**\n * The GitLabRunnerProps require the VPC ID, a defined environment of account and region, optional\n * runner configuration and optionally the GitLab Runner Manager instance type. By default, a T3 Micro instance will be used.\n * For larger workloads and very active teams it is recommended to use T3 Small for the manager instead.\n */\nexport interface GitLabRunnerProps {\n  readonly env: Environment;\n  readonly runnersWorkerProps?: GitlabRunnerWorkerProps;\n  readonly managerInstanceType?: InstanceType;\n  readonly cache: IBucket;\n}\n\n/**\n * The GitlabRunnerWorkerProps interface provides a simplified GitLab Runner worker configuration\n * requiring a token as an SSM parameter, one of the valid gitlab URLs, instance of you choice, the desired max spot price,\n * whether to use spot instance or not and a default role.\n * It is recommended to use the RunnerRoles construct, and it's exposed default runner role.\n */\nexport interface GitlabRunnerWorkerProps {\n  /** The SSM StringParameter with the registered runner token  */\n  readonly token: IStringParameter;\n  /** The GitLab instance URL, either https://gitlab.cicd.man or https://gitlab.collaborationlayer-traton.com */\n  readonly gitInstanceUrl: GitlabInstanceUrl;\n  /** The instance type for the runner worker */\n  readonly instanceType: InstanceType;\n  /** The desired max spot price */\n  readonly spotPrice: number;\n  /** Whether to use spot instance or not, Requires ServiceLinked Role for EC2 Spot to be deployed in the account */\n  readonly requestSpotPrice: boolean;\n  /** The default role for the runner worker when spawned */\n  readonly defaultWorkerRole: IRole;\n  /** The maximum number of builds for an instance before it has to be decommissioned. Default 10 */\n  readonly maxBuilds?: number;\n  /** The maximum number of instances to keep idle for new incoming jobs. Default 5 */\n  readonly maxIdleInstance?: number;\n  /** The maximum idle time seconds for an instance. Default 900 seconds */\n  readonly maxIdleTime?: number;\n}\n\nexport type GitlabInstanceUrl =\n  | 'https://gitlab.cicd.man'\n  | 'https://gitlab.collaborationlayer-traton.com';\n\n/**\n * The construct create the GitLabRunner Manager instance which will autoscale Runner instances based on the configuration.\n * By default, the construct will create a Runner with a manager T3 Micro instance which will be enabled to spawn T3 Large Runner\n * worker spot instance. The default runner Role has only the permissions to upload and download from the S3 runner cache.\n *\n * minimal configuration with runner spot instance:\n * ```ts\n * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');\n * const myBucket = new Bucket(stack, 'MyShareRunnerCache', {\n *     enforceSSL: true,\n *     publicReadAccess: false,\n *     encryption: BucketEncryption.S3_MANAGED,\n *     lifecycleRules: [\n *       {\n *         enabled: true,\n *         expiration: Duration.days(30),\n *       },\n *     ],\n *   });\n * new GitlabRunner(stack, 'GitLabRunner', {\n *  env: {account: '123456789012', region: 'eu-west-1'},\n *  cache: myBucket // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners\n * });\n *```\n * recommended:\n * ```ts\n * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');\n * const runnerRoles = new RunnerRoles(stack, 'RunnerRoles', {env: {account: '123456789012', region: 'eu-west-1'}});\n * const myBucket = new Bucket(stack, 'MyShareRunnerCache', {\n *     enforceSSL: true,\n *     publicReadAccess: false,\n *     encryption: BucketEncryption.S3_MANAGED,\n *     lifecycleRules: [\n *       {\n *         enabled: true,\n *         expiration: Duration.days(30),\n *       },\n *     ],\n *   });\n * new GitlabRunner(stack, 'GitLabRunner', {\n *  env: {account: '123456789012', region: 'eu-west-1'},\n *  cache: myBucket // // use a S3 bucket without public access and a retention defined, use one cache bucket for all you runners\n *  runnersWorkerProps: {\n *    token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power\n *    gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab\n *    instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner\n *    spotPrice: 0.2, // exemplary spot price\n *    requestSpotPrice: true,\n *    defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role\n *  },\n * });\n * ```\n */\nexport class GitlabRunner extends Construct {\n  private autoscalingConfig: AutoscalingConfiguration[] = [{\n    periods: ['* * 7-22 * * mon-fri *'],\n    timezone: 'Europe/Berlin',\n  }];\n  constructor(scope: Stack, id : string, props: GitLabRunnerProps) {\n    super(scope, id);\n\n    const vpc = RioLandingZone.getDefaultVpc(scope);\n\n    const runnerConfig = props.runnersWorkerProps\n      ? this.createWorkerConfigurations(props.runnersWorkerProps, props.env)\n      : this.getDefaultRunnerWorkerConfig(props.env);\n\n    const managerInstance =\n      props.managerInstanceType ??\n      InstanceType.of(InstanceClass.T3, InstanceSize.MICRO);\n\n    const runner = new GitlabRunnerAutoscaling(scope, `GLR${scope.stackName}`, {\n      runners: [runnerConfig],\n      network: {\n        vpc: vpc,\n      },\n      manager: {\n        instanceType: managerInstance,\n      },\n      cache: { bucket: props.cache },\n      checkInterval: 30, // check every 30s for pending jobs\n      concurrent: 300, // Global limit of concurrent jobs,\n    });\n    // due to the new registration process we have to register the runner by running explicit commands on start of the manager\n    runner.manager.userData.addCommands(\n      'cp  /etc/gitlab-runner/config.toml  /etc/gitlab-runner/config_back.toml', // avoid toml merge conflicts\n      `gitlab-runner register --non-interactive --template-config /etc/gitlab-runner/config_back.toml --token ${props.runnersWorkerProps?.token.stringValue}`,\n      'gitlab-runner restart', // restart the runner to ensure the config is picked up correctly\n    );\n  }\n\n  private createWorkerConfigurations(workerProps: GitlabRunnerWorkerProps, env: Environment): GitlabRunnerAutoscalingJobRunnerProps {\n    return {\n      token: workerProps.token,\n      role: workerProps.defaultWorkerRole,\n      configuration: {\n        url: workerProps.gitInstanceUrl,\n        machine: {\n          autoscaling: this.autoscalingConfig,\n          maxBuilds: workerProps.maxBuilds ?? 10,\n          idleCount: workerProps.maxIdleInstance ?? 5,\n          idleTime: workerProps.maxIdleTime ?? 900,\n          machineOptions: {\n            requestSpotInstance: workerProps.requestSpotPrice,\n            spotPrice: workerProps.spotPrice,\n          },\n        },\n        environment: [\n          'DOCKER_DRIVER=overlay2',\n          'DOCKER_TLS_DIRCE=/certs',\n          `DOCKER_AUTH_CONFIG={\"credHelpers\": { \"public.ecr.aws\": \"ecr-login\", \"${\n            env.account\n          }.dkr.ecr.${env.region}.amazonaws.com\": \"ecr-login\" } }`,\n        ],\n      },\n      instanceType: workerProps.instanceType,\n    };\n  }\n\n  private getDefaultRunnerWorkerConfig(\n    env: Environment,\n  ): GitlabRunnerAutoscalingJobRunnerProps {\n    const gitLabRunnerTokenParameter =\n      StringParameter.fromStringParameterAttributes(this, 'RunnerToken', {\n        parameterName: '/config/gitlab-runner-cdk/token',\n      });\n    return {\n      token: gitLabRunnerTokenParameter,\n      configuration: {\n        url: 'https://gitlab.cicd.man',\n        limit: 0,\n        machine: {\n          maxBuilds: 10,\n          autoscaling: this.autoscalingConfig,\n          idleCount: 5,\n          idleTime: 900,\n          machineOptions: {\n            requestSpotInstance: true,\n            spotPrice: 0.09,\n          },\n        },\n        environment: [\n          'DOCKER_DRIVER=overlay2',\n          'DOCKER_TLS_DIRCE=/certs',\n          `DOCKER_AUTH_CONFIG={\"credHelpers\": { \"public.ecr.aws\": \"ecr-login\", \"${\n            env.account\n          }.dkr.ecr.${env.region}.amazonaws.com\": \"ecr-login\" } }`,\n        ],\n      },\n      instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.LARGE),\n    };\n  }\n}\n"]}
@@ -68,7 +68,7 @@ class RunnerRoles extends constructs_1.Construct {
68
68
  'ecr:GetDownloadUrlForLayer',
69
69
  ],
70
70
  Resource: [
71
- `${props.env.account}.dkr.ecr.${props.env.region}.amazonaws.com/*`,
71
+ `arn:aws:ecr:${props.env.region}:${props.env.account}:repository/*`,
72
72
  ],
73
73
  },
74
74
  ],
@@ -349,4 +349,4 @@ class RunnerRoles extends constructs_1.Construct {
349
349
  exports.RunnerRoles = RunnerRoles;
350
350
  _a = JSII_RTTI_SYMBOL_1;
351
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"]}
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":";;;;;AAAA,6CAAgE;AAChE,iDAAsE;AACtE,iDAO6B;AAC7B,+CAA4C;AAC5C,iDAAsD;AACtD,2CAAuC;AACvC,gEAA2D;AAM3D;;;;;;;;;GASG;AACH,MAAa,WAAY,SAAQ,sBAAS;IAExC,YAAY,KAAY,EAAE,EAAU,EAAE,KAAsB;QAC1D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,MAAM,oBAAoB,GAAG,iCAAc,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAC3E,MAAM,iBAAiB,GAAG,iCAAc,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAE3E,MAAM,mBAAmB,GAAG,yBAAe,CAAC,uBAAuB,CACjE,IAAI,EACJ,qBAAqB,EACrB,8BAA8B,CAC/B,CAAC;QAEF,MAAM,0BAA0B,GAC9B,yBAAe,CAAC,6BAA6B,CAC3C,IAAI,EACJ,4BAA4B,EAC5B;YACE,aAAa,EAAE,kCAAkC;SAClD,CACF,CAAC;QACJ,MAAM,iBAAiB,GAAG,eAAM,CAAC,cAAc,CAC7C,IAAI,EACJ,mBAAmB,EACnB,0BAA0B,CAAC,WAAW,CACvC,CAAC;QAEF,MAAM,aAAa,GAAG,yBAAe,CAAC,6BAA6B,CACjE,IAAI,EACJ,oBAAoB,EACpB;YACE,aAAa,EAAE,yCAAyC;SACzD,CACF,CAAC;QACF,MAAM,WAAW,GAAG,yBAAe,CAAC,6BAA6B,CAC/D,IAAI,EACJ,kBAAkB,EAClB;YACE,aAAa,EAAE,sCAAsC;SACtD,CACF,CAAC;QAEF,MAAM,sBAAsB,GAAG,uBAAa,CAAC,oBAAoB,CAC/D,IAAI,EACJ,wBAAwB,EACxB,gBAAE,CAAC,WAAW,CAAC,8BAA8B,CAAC,CAC/C,CAAC;QAEF,IAAI,CAAC,cAAc,GAAG,IAAI,cAAI,CAAC,IAAI,EAAE,mBAAmB,EAAE;YACxD,SAAS,EAAE,IAAI,0BAAgB,CAAC,mBAAmB,EAAE,EAAE,CAAC;YACxD,cAAc,EAAE;gBACd,cAAc,EAAE,wBAAc,CAAC,QAAQ,CAAC;oBACtC,OAAO,EAAE,YAAY;oBACrB,SAAS,EAAE;wBACT;4BACE,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE,CAAC,YAAY,EAAE,eAAe,EAAE,sBAAsB,CAAC;4BAC/D,QAAQ,EAAE,CAAC,2BAA2B,CAAC;yBACxC;wBACD;4BACE,GAAG,EAAE,YAAY;4BACjB,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE,CAAC,gBAAgB,EAAE,cAAc,CAAC;4BAC1C,QAAQ,EAAE;gCACR,sCAAsC;gCACtC,iDAAiD;6BAClD;yBACF;wBACD;4BACE,GAAG,EAAE,eAAe;4BACpB,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE;gCACN,iCAAiC;gCACjC,mBAAmB;gCACnB,oBAAoB;gCACpB,0BAA0B;gCAC1B,4BAA4B;6BAC7B;4BACD,QAAQ,EAAE;gCACR,eAAe,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,eAAe;6BACpE;yBACF;qBACF;iBACF,CAAC;aACH;SACF,CAAC,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAwB,CAAC,iBAAiB,CAClE,mBAAmB,CACpB,CAAC;QACF,mBAAmB,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACnD,0BAA0B,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1D,iBAAiB,CAAC,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACtD,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACpD,iBAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACjD,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC7C,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3C,yCAA+B,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAE/D,MAAM,qBAAqB,GAAG,IAAI,cAAI,CACpC,IAAI,EACJ,gCAAgC,EAChC;YACE,QAAQ,EAAE,sCAAsC;YAChD,SAAS,EAAE,IAAI,CAAC,cAAc;YAC9B,cAAc,EAAE;gBACd,qBAAqB,EAAE,wBAAc,CAAC,QAAQ,CAAC;oBAC7C,OAAO,EAAE,YAAY;oBACrB,SAAS,EAAE;wBACT;4BACE,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE;gCACN,WAAW;gCACX,kBAAkB;gCAClB,eAAe;gCACf,eAAe;gCACf,UAAU;gCACV,cAAc;gCACd,uBAAuB;gCACvB,uBAAuB;gCACvB,qBAAqB;gCACrB,4BAA4B;6BAC7B;4BACD,QAAQ,EAAE,CAAC,gBAAgB,CAAC;yBAC7B;wBACD;4BACE,MAAM,EAAE;gCACN,wBAAwB;gCACxB,kBAAkB;gCAClB,yBAAyB;gCACzB,mBAAmB;gCACnB,yBAAyB;6BAC1B;4BACD,MAAM,EAAE,OAAO;4BACf,QAAQ,EAAE;gCACR,eAAe,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,qBAAqB;gCACzE,eAAe,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,qBAAqB;6BAC1E;yBACF;qBACF;iBACF,CAAC;aACH;SACF,CACF,CAAC;QACD,qBAAqB,CAAC,IAAI,CAAC,YAAwB,CAAC,iBAAiB,CACpE,gCAAgC,CACjC,CAAC;QAEF,MAAM,iBAAiB,GAAG,IAAI,cAAI,CAAC,IAAI,EAAE,+BAA+B,EAAE;YACxE,QAAQ,EAAE,6CAA6C;YACvD,SAAS,EAAE,IAAI,CAAC,cAAc;YAC9B,cAAc,EAAE;gBACd,0BAA0B,EAAE,wBAAc,CAAC,QAAQ,CAAC;oBAClD,OAAO,EAAE,YAAY;oBACrB,SAAS,EAAE;wBACT;4BACE,MAAM,EAAE;gCACN,wBAAwB;gCACxB,kBAAkB;gCAClB,yBAAyB;gCACzB,mBAAmB;gCACnB,yBAAyB;6BAC1B;4BACD,MAAM,EAAE,OAAO;4BACf,QAAQ,EAAE;gCACR,eAAe,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,qBAAqB;gCACzE,eAAe,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,qBAAqB;6BAC1E;yBACF;qBACF;iBACF,CAAC;gBACF,0BAA0B,EAAE,wBAAc,CAAC,QAAQ,CAAC;oBAClD,OAAO,EAAE,YAAY;oBACrB,SAAS,EAAE;wBACT;4BACE,MAAM,EAAE;gCACN,+BAA+B;gCAC/B,+BAA+B;gCAC/B,kCAAkC;gCAClC,qCAAqC;6BACtC;4BACD,MAAM,EAAE,OAAO;4BACf,QAAQ,EAAE;gCACR,0BAA0B,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,oDAAoD;gCACnH,0BAA0B,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,6CAA6C;gCAC5G,0BAA0B,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,oDAAoD;gCACnH,0BAA0B,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,6CAA6C;6BAC7G;yBACF;qBACF;iBACF,CAAC;aACH;YACD,eAAe,EAAE,CAAC,sBAAsB,CAAC;SAC1C,CAAC,CAAC;QACH,oBAAoB,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;QAClD,iBAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAChD,iBAAiB,CAAC,IAAI,CAAC,YAAwB,CAAC,iBAAiB,CAChE,+BAA+B,CAChC,CAAC;QAEF,MAAM,aAAa,GAAG,IAAI,cAAI,CAAC,IAAI,EAAE,uBAAuB,EAAE;YAC5D,QAAQ,EAAE,8BAA8B;YACxC,SAAS,EAAE,IAAI,CAAC,cAAc;YAC9B,cAAc,EAAE;gBACd,WAAW,EAAE,wBAAc,CAAC,QAAQ,CAAC;oBACnC,OAAO,EAAE,YAAY;oBACrB,SAAS,EAAE;wBACT;4BACE,MAAM,EAAE;gCACN,iCAAiC;gCACjC,mBAAmB;gCACnB,yBAAyB;gCACzB,4BAA4B;gCAC5B,yBAAyB;gCACzB,cAAc;gCACd,qBAAqB;gCACrB,2BAA2B;gCAC3B,0BAA0B;6BAC3B;4BACD,MAAM,EAAE,OAAO;4BACf,QAAQ,EAAE;gCACR,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,YAAY,KAAK,CAAC,GAAG,CAAC,MAAM,kBAAkB;6BACnE;yBACF;qBACF;iBACF,CAAC;aACH;SACF,CAAC,CAAC;QACH,yCAA+B,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACxD,aAAa,CAAC,IAAI,CAAC,YAAwB,CAAC,iBAAiB,CAC5D,uBAAuB,CACxB,CAAC;QAEF,MAAM,YAAY,GAAG,IAAI,yBAAe,CAAC;YACvC,OAAO,EAAE,CAAC,aAAa,CAAC;YACxB,SAAS,EAAE;gBACT,kCAAkC;gBAClC,iBAAiB,KAAK,CAAC,GAAG,CAAC,OAAO,QAAQ;aAC3C;YACD,UAAU,EAAE;gBACV,wBAAwB,EAAE;oBACxB,qBAAqB,EAAE,0BAA0B;iBAClD;aACF;SACF,CAAC,CAAC;QACH,MAAM,wBAAwB,GAAG,IAAI,yBAAe,CAAC;YACnD,OAAO,EAAE,CAAC,uBAAuB,CAAC;YAClC,SAAS,EAAE;gBACT,4BAA4B,KAAK,CAAC,GAAG,CAAC,OAAO,iCAAiC;aAC/E;SACF,CAAC,CAAC;QACH,MAAM,iBAAiB,GAAG,IAAI,cAAI,CAAC,IAAI,EAAE,2BAA2B,EAAE;YACpE,QAAQ,EAAE,+BAA+B;YACzC,SAAS,EAAE,IAAI,CAAC,cAAc;YAC9B,cAAc,EAAE;gBACd,aAAa,EAAE,IAAI,wBAAc,CAAC;oBAChC,UAAU,EAAE,CAAC,YAAY,EAAE,wBAAwB,CAAC;iBACrD,CAAC;aACH;SACF,CAAC,CAAC;QACF,iBAAiB,CAAC,IAAI,CAAC,YAAwB,CAAC,iBAAiB,CAChE,2BAA2B,CAC5B,CAAC;QAEF,MAAM,UAAU,GAAG,IAAI,cAAI,CAAC,IAAI,EAAE,uBAAuB,EAAE;YACzD,QAAQ,EAAE,2BAA2B;YACrC,SAAS,EAAE,IAAI,CAAC,cAAc;YAC9B,eAAe,EAAE,CAAC,sBAAsB,CAAC,EAAE,iFAAiF;YAC5H,cAAc,EAAE;gBACd,SAAS,EAAE,wBAAc,CAAC,QAAQ,CAAC;oBACjC,OAAO,EAAE,YAAY;oBACrB,SAAS,EAAE;wBACT;4BACE,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE;gCACN,+BAA+B;gCAC/B,gCAAgC;gCAChC,kCAAkC;gCAClC,iCAAiC;gCACjC,oCAAoC;gCACpC,gCAAgC;gCAChC,4BAA4B;6BAC7B;4BACD,QAAQ,EAAE;gCACR,0BAA0B,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,UAAU;6BAC1E;yBACF;wBACD;4BACE,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE,CAAC,YAAY,EAAE,eAAe,EAAE,sBAAsB,CAAC;4BAC/D,QAAQ,EAAE,CAAC,2BAA2B,CAAC;yBACxC;wBACD;4BACE,GAAG,EAAE,YAAY;4BACjB,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE,CAAC,gBAAgB,EAAE,cAAc,CAAC;4BAC1C,QAAQ,EAAE;gCACR,sCAAsC;gCACtC,iDAAiD;gCACjD,qDAAqD;gCACrD,iDAAiD;6BAClD;yBACF;qBACF;iBACF,CAAC;gBACF,SAAS,EAAE,wBAAc,CAAC,QAAQ,CAAC;oBACjC,OAAO,EAAE,YAAY;oBACrB,SAAS,EAAE;wBACT;4BACE,MAAM,EAAE,OAAO;4BACf,MAAM,EAAE,CAAC,GAAG,CAAC;4BACb,QAAQ,EAAE;gCACR,0BAA0B,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,UAAU;6BAC1E;4BACD,SAAS,EAAE;gCACT,0BAA0B,EAAE;oCAC1B,eAAe,EAAE,8BAA8B;iCAChD;6BACF;yBACF;qBACF;iBACF,CAAC;aACH;SACF,CAAC,CAAC;QACF,UAAU,CAAC,IAAI,CAAC,YAAwB,CAAC,iBAAiB,CACzD,uBAAuB,CACxB,CAAC;QAEF,MAAM,wBAAwB,GAAG,IAAI,uBAAS,CAC5C,KAAK,EACL,0BAA0B,EAC1B;YACE,KAAK,EAAE,UAAU,CAAC,OAAO;YACzB,UAAU,EAAE,+BAA+B;SAC5C,CACF,CAAC;QACF,wBAAwB,CAAC,iBAAiB,CAAC,0BAA0B,CAAC,CAAC;QACvE,MAAM,yBAAyB,GAAG,IAAI,uBAAS,CAC7C,KAAK,EACL,2BAA2B,EAC3B;YACE,KAAK,EAAE,UAAU,CAAC,QAAQ;YAC1B,UAAU,EAAE,gCAAgC;SAC7C,CACF,CAAC;QACF,yBAAyB,CAAC,iBAAiB,CAAC,2BAA2B,CAAC,CAAC;QAEzE,MAAM,oCAAoC,GAAG,IAAI,uBAAS,CACxD,KAAK,EACL,sCAAsC,EACtC;YACE,KAAK,EAAE,iBAAiB,CAAC,QAAQ;YACjC,UAAU,EAAE,kDAAkD;SAC/D,CACF,CAAC;QACF,oCAAoC,CAAC,iBAAiB,CACpD,sCAAsC,CACvC,CAAC;QACF,MAAM,mCAAmC,GAAG,IAAI,uBAAS,CACvD,KAAK,EACL,qCAAqC,EACrC;YACE,KAAK,EAAE,iBAAiB,CAAC,OAAO;YAChC,UAAU,EAAE,iDAAiD;SAC9D,CACF,CAAC;QACF,mCAAmC,CAAC,iBAAiB,CACnD,qCAAqC,CACtC,CAAC;QAEF,MAAM,oCAAoC,GAAG,IAAI,uBAAS,CACxD,KAAK,EACL,sCAAsC,EACtC;YACE,KAAK,EAAE,qBAAqB,CAAC,QAAQ;YACrC,UAAU,EAAE,mDAAmD;SAChE,CACF,CAAC;QACF,oCAAoC,CAAC,iBAAiB,CACpD,sCAAsC,CACvC,CAAC;QACF,MAAM,mCAAmC,GAAG,IAAI,uBAAS,CACvD,KAAK,EACL,qCAAqC,EACrC;YACE,KAAK,EAAE,qBAAqB,CAAC,OAAO;YACpC,UAAU,EAAE,kDAAkD;SAC/D,CACF,CAAC;QACF,mCAAmC,CAAC,iBAAiB,CACnD,qCAAqC,CACtC,CAAC;QAEF,MAAM,8BAA8B,GAAG,IAAI,uBAAS,CAClD,KAAK,EACL,gCAAgC,EAChC;YACE,KAAK,EAAE,aAAa,CAAC,QAAQ;YAC7B,UAAU,EAAE,uCAAuC;SACpD,CACF,CAAC;QACF,8BAA8B,CAAC,iBAAiB,CAC9C,gCAAgC,CACjC,CAAC;QACF,MAAM,6BAA6B,GAAG,IAAI,uBAAS,CACjD,KAAK,EACL,+BAA+B,EAC/B;YACE,KAAK,EAAE,aAAa,CAAC,OAAO;YAC5B,UAAU,EAAE,sCAAsC;SACnD,CACF,CAAC;QACF,6BAA6B,CAAC,iBAAiB,CAC7C,+BAA+B,CAChC,CAAC;QAEF,MAAM,gCAAgC,GAAG,IAAI,uBAAS,CACpD,KAAK,EACL,kCAAkC,EAClC;YACE,KAAK,EAAE,iBAAiB,CAAC,QAAQ;YACjC,UAAU,EAAE,wCAAwC;SACrD,CACF,CAAC;QACF,gCAAgC,CAAC,iBAAiB,CAChD,kCAAkC,CACnC,CAAC;QACF,MAAM,+BAA+B,GAAG,IAAI,uBAAS,CACnD,KAAK,EACL,iCAAiC,EACjC;YACE,KAAK,EAAE,iBAAiB,CAAC,OAAO;YAChC,UAAU,EAAE,uCAAuC;SACpD,CACF,CAAC;QACF,+BAA+B,CAAC,iBAAiB,CAC/C,iCAAiC,CAClC,CAAC;IACJ,CAAC;;AArbH,kCAsbC","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                `arn:aws:ecr:${props.env.region}:${props.env.account}:repository/*`,\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"]}
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.2.2",
18
+ "version": "6.3.1",
19
19
  "types": "lib/index.d.ts",
20
20
  "stability": "stable",
21
21
  "exports": {
package/version.json CHANGED
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": "6.2.2"
2
+ "version": "6.3.1"
3
3
  }