cdk-gitlab-runner 2.1.393 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/.jsii +93 -117
  2. package/API.md +28 -47
  3. package/README.md +49 -17
  4. package/lib/gitlab-runner-autoscaling.d.ts +5 -0
  5. package/lib/gitlab-runner-autoscaling.js +9 -4
  6. package/lib/gitlab-runner-instance.d.ts +8 -38
  7. package/lib/gitlab-runner-instance.js +14 -6
  8. package/lib/integ.api.js +3 -2
  9. package/lib/integ.gitlab-runner-autoscaling.js +2 -1
  10. package/node_modules/compare-versions/LICENSE +21 -0
  11. package/node_modules/compare-versions/README.md +133 -0
  12. package/node_modules/compare-versions/lib/esm/compare.d.ts +19 -0
  13. package/node_modules/compare-versions/lib/esm/compare.js +44 -0
  14. package/node_modules/compare-versions/lib/esm/compare.js.map +1 -0
  15. package/node_modules/compare-versions/lib/esm/compareVersions.d.ts +8 -0
  16. package/node_modules/compare-versions/lib/esm/compareVersions.js +29 -0
  17. package/node_modules/compare-versions/lib/esm/compareVersions.js.map +1 -0
  18. package/node_modules/compare-versions/lib/esm/index.d.ts +5 -0
  19. package/node_modules/compare-versions/lib/esm/index.js +5 -0
  20. package/node_modules/compare-versions/lib/esm/index.js.map +1 -0
  21. package/node_modules/compare-versions/lib/esm/satisfies.d.ts +14 -0
  22. package/node_modules/compare-versions/lib/esm/satisfies.js +66 -0
  23. package/node_modules/compare-versions/lib/esm/satisfies.js.map +1 -0
  24. package/node_modules/compare-versions/lib/esm/utils.d.ts +7 -0
  25. package/node_modules/compare-versions/lib/esm/utils.js +37 -0
  26. package/node_modules/compare-versions/lib/esm/utils.js.map +1 -0
  27. package/node_modules/compare-versions/lib/esm/validate.d.ts +28 -0
  28. package/node_modules/compare-versions/lib/esm/validate.js +31 -0
  29. package/node_modules/compare-versions/lib/esm/validate.js.map +1 -0
  30. package/node_modules/compare-versions/lib/umd/index.js +216 -0
  31. package/node_modules/compare-versions/lib/umd/index.js.map +1 -0
  32. package/node_modules/compare-versions/package.json +45 -0
  33. package/node_modules/compare-versions/src/compare.ts +54 -0
  34. package/node_modules/compare-versions/src/compareVersions.ts +31 -0
  35. package/node_modules/compare-versions/src/index.ts +5 -0
  36. package/node_modules/compare-versions/src/satisfies.ts +69 -0
  37. package/node_modules/compare-versions/src/utils.ts +50 -0
  38. package/node_modules/compare-versions/src/validate.ts +36 -0
  39. package/package.json +8 -2
package/API.md CHANGED
@@ -302,6 +302,18 @@ import { GitlabContainerRunnerProps } from 'cdk-gitlab-runner'
302
302
  const gitlabContainerRunnerProps: GitlabContainerRunnerProps = { ... }
303
303
  ```
304
304
 
305
+ ##### `gitlabRunnerVersion`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.gitlabRunnerVersion"></a>
306
+
307
+ ```typescript
308
+ public readonly gitlabRunnerVersion: string;
309
+ ```
310
+
311
+ - *Type:* `string`
312
+
313
+ Gitlab Runner version Please give me gitlab runner version.
314
+
315
+ ---
316
+
305
317
  ##### `gitlabtoken`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.gitlabtoken"></a>
306
318
 
307
319
  ```typescript
@@ -389,7 +401,7 @@ public readonly gitlabRunnerImage: string;
389
401
  ```
390
402
 
391
403
  - *Type:* `string`
392
- - *Default:* public.ecr.aws/gitlab/gitlab-runner:latest
404
+ - *Default:* public.ecr.aws/gitlab/gitlab-runner:latest !!! <--- latest now > 16.0 Gitlab Runner version
393
405
 
394
406
  Image URL of Gitlab Runner.
395
407
 
@@ -473,51 +485,6 @@ Gitlab Runner instance Use Spot Fleet or not ?!.
473
485
 
474
486
  ---
475
487
 
476
- ##### ~~`tag1`~~<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tag1"></a>
477
-
478
- - *Deprecated:* - use tags ['runner', 'gitlab', 'awscdk']
479
-
480
- ```typescript
481
- public readonly tag1: string;
482
- ```
483
-
484
- - *Type:* `string`
485
- - *Default:* tag1: gitlab .
486
-
487
- Gitlab Runner register tag1 .
488
-
489
- ---
490
-
491
- ##### ~~`tag2`~~<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tag2"></a>
492
-
493
- - *Deprecated:* - use tags ['runner', 'gitlab', 'awscdk']
494
-
495
- ```typescript
496
- public readonly tag2: string;
497
- ```
498
-
499
- - *Type:* `string`
500
- - *Default:* tag2: awscdk .
501
-
502
- Gitlab Runner register tag2 .
503
-
504
- ---
505
-
506
- ##### ~~`tag3`~~<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tag3"></a>
507
-
508
- - *Deprecated:* - use tags ['runner', 'gitlab', 'awscdk']
509
-
510
- ```typescript
511
- public readonly tag3: string;
512
- ```
513
-
514
- - *Type:* `string`
515
- - *Default:* tag3: runner .
516
-
517
- Gitlab Runner register tag3 .
518
-
519
- ---
520
-
521
488
  ##### `tags`<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tags"></a>
522
489
 
523
490
  ```typescript
@@ -527,7 +494,9 @@ public readonly tags: string[];
527
494
  - *Type:* `string`[]
528
495
  - *Default:* ['runner', 'gitlab', 'awscdk']
529
496
 
530
- tags for the runner.
497
+ tags for the runner Unsupported Gitlab Runner 15.10 and later.
498
+
499
+ > - https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html
531
500
 
532
501
  ---
533
502
 
@@ -569,6 +538,18 @@ import { GitlabRunnerAutoscalingProps } from 'cdk-gitlab-runner'
569
538
  const gitlabRunnerAutoscalingProps: GitlabRunnerAutoscalingProps = { ... }
570
539
  ```
571
540
 
541
+ ##### `gitlabRunnerVersion`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabRunnerAutoscalingProps.property.gitlabRunnerVersion"></a>
542
+
543
+ ```typescript
544
+ public readonly gitlabRunnerVersion: string;
545
+ ```
546
+
547
+ - *Type:* `string`
548
+
549
+ Gitlab Runner version Please give me gitlab runner version.
550
+
551
+ ---
552
+
572
553
  ##### `gitlabToken`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabRunnerAutoscalingProps.property.gitlabToken"></a>
573
554
 
574
555
  ```typescript
package/README.md CHANGED
@@ -35,16 +35,38 @@ It will be used with AWS IAM Role, so you don't need to put AKSK in Gitlab envir
35
35
 
36
36
  ## Before start you need gitlab runner token in your `gitlab project` or `gitlab group`
37
37
 
38
- ### In Group
39
-
38
+ ## In Group before Gitlab 15.10
39
+ This registration process is only supported in GitLab Runner 15.10 or later
40
+ This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
41
+
40
42
  Group > Settings > CI/CD
41
43
  ![group](image/group_runner_page.png)
42
44
 
43
- ### In Project
45
+ ## In Group after Gitlab 15.10
46
+ This registration process is only supported in GitLab Runner 15.10 or later
47
+ This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
48
+
49
+ Group > Build > Runners
50
+ ![group](image/gitlab-runner-new-register.png)
51
+ ![group](image/gitlab-runner-new-register-1.png)
52
+ ![group](image/gitlab-runner-new-register-2.png)
53
+ ![group](image/gitlab-runner-new-register-3.jpg)
54
+
55
+
56
+ ### In Project before Gitlab 15.10
57
+ This registration process is only supported in GitLab Runner 15.10 or later
58
+ This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
44
59
 
45
60
  Project > Settings > CI/CD > Runners
46
61
  ![project](image/project_runner_page.png)
47
62
 
63
+ ### In Project after Gitlab 15.10
64
+ This registration process is only supported in GitLab Runner 15.10 or later
65
+ This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
66
+
67
+ Project > Settings > CI/CD > Runners
68
+ ![project](image/gitlab-runner-new-register-project.png)
69
+
48
70
  ## Usage
49
71
 
50
72
  Replace your gitlab runner token in `$GITLABTOKEN`
@@ -69,12 +91,12 @@ npm install cdk-gitlab-runner@cdkv1
69
91
  import { GitlabContainerRunner } from 'cdk-gitlab-runner';
70
92
 
71
93
  // If want change instance type to t3.large .
72
- new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '$GITLABTOKEN', ec2type:'t3.large' });
94
+ new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: 'glrt-GITLABTOKEN', ec2type:'t3.large',gitlabRunnerVersion: '15.10' });
73
95
  // OR
74
96
  // Just create a gitlab runner , by default instance type is t3.micro .
75
97
  import { GitlabContainerRunner } from 'cdk-gitlab-runner';
76
98
 
77
- new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '$GITLABTOKEN' });})
99
+ new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: 'glrt-GITLABTOKEN', gitlabRunnerVersion: '15.10' });
78
100
  ```
79
101
 
80
102
  ### Gitlab Server Customize Url .
@@ -86,21 +108,23 @@ If you want change what you want tag name .
86
108
  import { GitlabContainerRunner } from 'cdk-gitlab-runner';
87
109
 
88
110
  new GitlabContainerRunner(this, 'runner-instance-change-tag', {
89
- gitlabtoken: '$GITLABTOKEN',
111
+ gitlabtoken: 'glrt-GITLABTOKEN',
90
112
  gitlaburl: 'https://gitlab.my.com/',
113
+ gitlabRunnerVersion: '15.10'
91
114
  });
92
115
  ```
93
116
 
94
117
  ### Tags
95
118
 
96
119
  If you want change what you want tag name .
97
-
120
+ !!! Not support Gitlab Runner 15.10 and later !!!
98
121
  ```typescript
99
122
  // If you want change what you want tag name .
100
123
  import { GitlabContainerRunner } from 'cdk-gitlab-runner';
101
124
 
102
125
  new GitlabContainerRunner(this, 'runner-instance-change-tag', {
103
- gitlabtoken: '$GITLABTOKEN',
126
+ gitlabtoken: 'glrt-GITLABTOKEN',
127
+ gitlabRunnerVersion: '15.10',
104
128
  tags: ['aa', 'bb', 'cc'],
105
129
  });
106
130
  ```
@@ -115,7 +139,8 @@ import { GitlabContainerRunner } from 'cdk-gitlab-runner';
115
139
  import { ManagedPolicy } from 'aws-cdk-lib/aws-iam';
116
140
 
117
141
  const runner = new GitlabContainerRunner(this, 'runner-instance-add-policy', {
118
- gitlabtoken: '$GITLABTOKEN',
142
+ gitlabtoken: 'glrt-GITLABTOKEN',
143
+ gitlabRunnerVersion: '15.10',
119
144
  tags: ['aa', 'bb', 'cc'],
120
145
  });
121
146
  runner.runnerRole.addManagedPolicy(
@@ -133,7 +158,8 @@ import { GitlabContainerRunner } from 'cdk-gitlab-runner';
133
158
  import { Port, Peer } from 'aws-cdk-lib/aws-ec2';
134
159
 
135
160
  const runner = new GitlabContainerRunner(this, 'runner-add-SG-ingress', {
136
- gitlabtoken: 'GITLABTOKEN',
161
+ gitlabtoken: 'glrt-GITLABTOKEN',
162
+ gitlabRunnerVersion: '15.10',
137
163
  tags: ['aa', 'bb', 'cc'],
138
164
  });
139
165
 
@@ -167,7 +193,8 @@ const newvpc = new Vpc(stack, 'VPC', {
167
193
  });
168
194
 
169
195
  const runner = new GitlabContainerRunner(this, 'testing', {
170
- gitlabtoken: '$GITLABTOKEN',
196
+ gitlabtoken: 'glrt-GITLABTOKEN',
197
+ gitlabRunnerVersion: '15.10',
171
198
  ec2type: 't3.small',
172
199
  selfvpc: newvpc,
173
200
  });
@@ -189,7 +216,8 @@ const role = new Role(this, 'runner-role', {
189
216
  });
190
217
 
191
218
  const runner = new GitlabContainerRunner(stack, 'testing', {
192
- gitlabtoken: '$GITLAB_TOKEN',
219
+ gitlabtoken: 'glrt-GITLABTOKEN',
220
+ gitlabRunnerVersion: '15.10',
193
221
  ec2iamrole: role,
194
222
  });
195
223
  runner.runnerRole.addManagedPolicy(
@@ -205,7 +233,8 @@ runner.runnerRole.addManagedPolicy(
205
233
  import { GitlabContainerRunner } from 'cdk-gitlab-runner';
206
234
 
207
235
  new GitlabContainerRunner(stack, 'testing', {
208
- gitlabtoken: '$GITLAB_TOKEN',
236
+ gitlabtoken: 'glrt-GITLABTOKEN',
237
+ gitlabRunnerVersion: '15.10',
209
238
  ebsSize: 50,
210
239
  });
211
240
  ```
@@ -218,7 +247,8 @@ new GitlabContainerRunner(stack, 'testing', {
218
247
  import { GitlabRunnerAutoscaling } from 'cdk-gitlab-runner';
219
248
 
220
249
  new GitlabRunnerAutoscaling(stack, 'testing', {
221
- gitlabToken: '$GITLAB_TOKEN',
250
+ gitlabToken: 'glrt-GITLABTOKEN',
251
+ gitlabRunnerVersion: '15.10',
222
252
  minCapacity: 2,
223
253
  maxCapacity: 2,
224
254
  });
@@ -233,7 +263,8 @@ new GitlabRunnerAutoscaling(stack, 'testing', {
233
263
  import { GitlabContainerRunner, BlockDuration } from 'cdk-gitlab-runner';
234
264
 
235
265
  const runner = new GitlabContainerRunner(stack, 'testing', {
236
- gitlabtoken: 'GITLAB_TOKEN',
266
+ gitlabToken: 'glrt-GITLABTOKEN',
267
+ gitlabRunnerVersion: '15.10',
237
268
  ec2type: 't3.large',
238
269
  spotFleet: true,
239
270
  });
@@ -248,7 +279,8 @@ runner.expireAfter(Duration.hours(1));
248
279
  import { GitlabContainerRunner, BlockDuration } from 'cdk-gitlab-runner';
249
280
 
250
281
  const runner = new GitlabContainerRunner(stack, 'testing', {
251
- gitlabtoken: 'GITLAB_TOKEN',
282
+ gitlabToken: 'glrt-GITLABTOKEN',
283
+ gitlabRunnerVersion: '15.10',
252
284
  ec2type: 't3.large',
253
285
  dockerVolumes: [
254
286
  {
@@ -264,7 +296,7 @@ const runner = new GitlabContainerRunner(stack, 'testing', {
264
296
  ![runner](image/group_runner2.png)
265
297
 
266
298
  #### you can use tag `gitlab` , `runner` , `awscdk` ,
267
-
299
+ > !!!!! Not Support Gitlab Runner after 15.10 and later
268
300
  ## Example _`gitlab-ci.yaml`_
269
301
 
270
302
  [gitlab docs see more ...](https://docs.gitlab.com/ee/ci/yaml/README.html)
@@ -8,6 +8,11 @@ import { DockerVolumes } from './gitlab-runner-interfaces';
8
8
  * GitlabRunnerAutoscaling Props.
9
9
  */
10
10
  export interface GitlabRunnerAutoscalingProps {
11
+ /**
12
+ * Gitlab Runner version
13
+ * Please give me gitlab runner version.
14
+ */
15
+ readonly gitlabRunnerVersion: string;
11
16
  /**
12
17
  * Gitlab token.
13
18
  *
@@ -15,6 +15,8 @@ const assets = require("aws-cdk-lib/aws-s3-assets");
15
15
  const sns = require("aws-cdk-lib/aws-sns");
16
16
  const subscriptions = require("aws-cdk-lib/aws-sns-subscriptions");
17
17
  const cr = require("aws-cdk-lib/custom-resources");
18
+ // eslint-disable-next-line import/no-extraneous-dependencies
19
+ const compare_versions_1 = require("compare-versions");
18
20
  const constructs_1 = require("constructs");
19
21
  /**
20
22
  * GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.
@@ -35,6 +37,9 @@ class GitlabRunnerAutoscaling extends constructs_1.Construct {
35
37
  ],
36
38
  };
37
39
  const runnerProps = { ...defaultProps, ...props };
40
+ if ((0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') && props.gitlabToken.includes('glrt-') === false) {
41
+ throw new Error('If gitlabRunnerVersion >= 15.10, gitlabtoken please give glrt-xxxxxxx @see https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html');
42
+ }
38
43
  const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {
39
44
  path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),
40
45
  });
@@ -230,15 +235,15 @@ class GitlabRunnerAutoscaling extends constructs_1.Construct {
230
235
  'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',
231
236
  'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',
232
237
  `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \
233
- --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} --registration-token ${props.gitlabToken} \
238
+ --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} ${(0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') ? '--token' : '--registration-token'} ${props.gitlabToken} \
234
239
  --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \
235
240
  --executor docker --docker-image "alpine:latest" --description "A Runner on EC2 Instance (${props.instanceType})" \
236
- --tag-list "${props.tags?.join(',')}" --docker-privileged`,
241
+ ${(0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') ? undefined : `--tag-list "${props.tags?.join(',')}" `} --docker-privileged`,
237
242
  `sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,
238
243
  ];
239
244
  }
240
245
  }
241
246
  _a = JSII_RTTI_SYMBOL_1;
242
- GitlabRunnerAutoscaling[_a] = { fqn: "cdk-gitlab-runner.GitlabRunnerAutoscaling", version: "2.1.393" };
247
+ GitlabRunnerAutoscaling[_a] = { fqn: "cdk-gitlab-runner.GitlabRunnerAutoscaling", version: "2.2.0" };
243
248
  exports.GitlabRunnerAutoscaling = GitlabRunnerAutoscaling;
244
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-autoscaling.js","sourceRoot":"","sources":["../src/gitlab-runner-autoscaling.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport * as asg from 'aws-cdk-lib/aws-autoscaling';\nimport { FunctionHook } from 'aws-cdk-lib/aws-autoscaling-hooktargets';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as assets from 'aws-cdk-lib/aws-s3-assets';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as subscriptions from 'aws-cdk-lib/aws-sns-subscriptions';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n\n/**\n * GitlabRunnerAutoscaling Props.\n */\nexport interface GitlabRunnerAutoscalingProps {\n  /**\n   * Gitlab token.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN' });\n   */\n  readonly gitlabToken: string;\n\n  /**\n   * Image URL of Gitlab Runner.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });\n   *\n   * @default public.ecr.aws/gitlab/gitlab-runner:latest\n   *\n   */\n  readonly gitlabRunnerImage?: string;\n\n  /**\n   * Runner default EC2 instance type.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceType: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly instanceType?: string;\n\n  /**\n   * VPC for the Gitlab Runner .\n   *\n   * @example\n   * const newVpc = new Vpc(stack, 'NewVPC', {\n   *   ipAddresses: IpAddresses.cidr('10.0.0.0/16'),\n   *   maxAzs: 2,\n   *   subnetConfiguration: [{\n   *     cidrMask: 26,\n   *     name: 'RunnerVPC',\n   *     subnetType: SubnetType.PUBLIC,\n   *   }],\n   *   natGateways: 0,\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', vpc: newVpc });\n   *\n   * @default - A new VPC will be created.\n   *\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * IAM role for the Gitlab Runner Instance .\n   *\n   * @example\n   * const role = new Role(stack, 'runner-role', {\n   *   assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n   *   description: 'For Gitlab Runner Test Role',\n   *   roleName: 'Runner-Role',\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceRole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * Run worker nodes as EC2 Spot\n   *\n   * @default - false\n   */\n  readonly spotInstance?: boolean;\n\n  /**\n   * Minimum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', minCapacity: 2 });\n   *\n   * @default - minCapacity: 1\n   *\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', maxCapacity: 4 });\n   *\n   * @default - desiredCapacity\n   *\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Desired capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', desiredCapacity: 2 });\n   *\n   * @default - minCapacity, and leave unchanged during deployment\n   *\n   */\n  readonly desiredCapacity?: number;\n\n  /**\n   * tags for the runner\n   *\n   * @default - ['runner', 'gitlab', 'awscdk']\n   */\n  readonly tags?: string[];\n\n  /**\n   * Gitlab Runner register url .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN',gitlabUrl: 'https://gitlab.com/'});\n   *\n   * @default - https://gitlab.com/ , The trailing slash is mandatory.\n   *\n   */\n  readonly gitlabUrl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * VPC subnet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabRunnerAutoscaling(stack, 'testing', {\n   *   gitlabToken: 'GITLAB_TOKEN',\n   *   instanceType: 't3.large',\n   *   instanceRole: role,\n   *   ebsSize: 100,\n   *   vpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - SubnetType.PRIVATE subnet\n   */\n  readonly vpcSubnet?: ec2.SubnetSelection;\n\n  /**\n   * add another Gitlab Container Runner Docker Volumes Path at job runner runtime.\n   *\n   * more detail see https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section\n   *\n   * @default - already mount \"/var/run/docker.sock:/var/run/docker.sock\"\n   *\n   * @example\n   * dockerVolumes: [\n   *   {\n   *     hostPath: '/tmp/cache',\n   *     containerPath: '/tmp/cache',\n   *   },\n   * ],\n   */\n  readonly dockerVolumes?: DockerVolumes[];\n\n  /**\n   * Parameters of put_metric_alarm function\n   *\n   * https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/cloudwatch.html#CloudWatch.Client.put_metric_alarm\n   *\n   * @default - [{\n   *     AlarmName: 'GitlabRunnerDiskUsage',\n   *     MetricName: 'disk_used_percent',\n   * }]\n   *\n   */\n  readonly alarms?: object[];\n}\n\n/**\n * GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.\n */\nexport class GitlabRunnerAutoscaling extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance.\n   */\n  public readonly instanceRole: iam.IRole;\n\n  /**\n   * This represents a Runner Auto Scaling Group\n   */\n  public readonly autoscalingGroup: asg.AutoScalingGroup;\n\n  /**\n   * The EC2 runner's VPC.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly securityGroup: ec2.ISecurityGroup;\n\n  /**\n   * The SNS topic to suscribe alarms for EC2 runner's metrics.\n   */\n  public readonly topicAlarm: sns.ITopic;\n\n\n  constructor(scope: Construct, id: string, props: GitlabRunnerAutoscalingProps) {\n    super(scope, id);\n    const defaultProps = {\n      instanceType: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      gitlabUrl: 'https://gitlab.com/',\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      alarms: [\n        {\n          AlarmName: 'GitlabRunnerDiskUsage',\n          MetricName: 'disk_used_percent',\n        },\n      ],\n    };\n    const runnerProps = { ...defaultProps, ...props };\n\n    const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {\n      path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),\n    });\n\n    const userData = ec2.UserData.forLinux();\n    userData.addS3DownloadCommand({\n      bucket: asset.bucket,\n      bucketKey: asset.s3ObjectKey,\n      localFile: '/opt/aws/amazon-cloudwatch-agent/etc/amazon-cloudwatch-agent.json',\n    });\n    userData.addCommands(...this.createUserData(runnerProps));\n\n    this.instanceRole =\n      runnerProps.instanceRole ??\n      new iam.Role(this, 'GitlabRunnerInstanceRole', {\n        assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For EC2 Instance (Gitlab Runner) Role',\n        managedPolicies: [\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchAgentServerPolicy'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n        ],\n      });\n\n    this.vpc = runnerProps.vpc ?? new ec2.Vpc(this, 'VPC');\n\n    this.securityGroup = new ec2.SecurityGroup(this, 'GitlabRunnerSecurityGroup', {\n      vpc: this.vpc,\n    });\n    const instanceProfile = new iam.CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.instanceRole.roleName],\n    });\n    const lt = new ec2.CfnLaunchTemplate(this, 'GitlabRunnerLaunchTemplate', {\n      launchTemplateData: {\n        imageId: ec2.MachineImage.latestAmazonLinux2().getImage(this).imageId,\n        instanceType: runnerProps.instanceType,\n        instanceMarketOptions: {\n          marketType: runnerProps.spotInstance ? 'spot' : undefined,\n          spotOptions: runnerProps.spotInstance ? {\n            spotInstanceType: 'one-time',\n          } : undefined,\n        },\n        userData: cdk.Fn.base64(userData.render()),\n        blockDeviceMappings: [\n          {\n            deviceName: '/dev/xvda',\n            ebs: {\n              volumeSize: runnerProps.ebsSize ?? 60,\n            },\n          },\n        ],\n        iamInstanceProfile: {\n          arn: instanceProfile.attrArn,\n        },\n        securityGroupIds: this.securityGroup.connections.securityGroups.map(\n          (m) => m.securityGroupId,\n        ),\n      },\n    });\n\n    this.autoscalingGroup = new asg.AutoScalingGroup(this, 'GitlabRunnerAutoscalingGroup', {\n      instanceType: new ec2.InstanceType(runnerProps.instanceType),\n      autoScalingGroupName: `Gitlab Runners (${runnerProps.instanceType})`,\n      vpc: this.vpc,\n      vpcSubnets: runnerProps.vpcSubnet,\n      machineImage: ec2.MachineImage.latestAmazonLinux2(),\n      minCapacity: runnerProps.minCapacity,\n      maxCapacity: runnerProps.maxCapacity,\n      desiredCapacity: runnerProps.desiredCapacity,\n    });\n\n    const cfnAsg = this.autoscalingGroup.node.tryFindChild('ASG') as asg.CfnAutoScalingGroup;\n    cfnAsg.addPropertyDeletionOverride('LaunchConfigurationName');\n    cfnAsg.addPropertyOverride('LaunchTemplate', {\n      LaunchTemplateId: lt.ref,\n      Version: lt.attrLatestVersionNumber,\n    });\n    this.autoscalingGroup.node.tryRemoveChild('LaunchConfig');\n\n    this.topicAlarm = new sns.Topic(this, 'GitlabRunnerAlarm');\n    const alarms = JSON.stringify(runnerProps.alarms);\n\n    // Put alarms at launch\n    const registerFunction = new lambda.Function(this, 'GitlabRunnerRegisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.register',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n        SNS_TOPIC_ARN: this.topicAlarm.topicArn,\n      },\n    });\n    registerFunction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'cloudwatch:PutMetricAlarm',\n        ],\n      }),\n    );\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookLaunching', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_LAUNCHING,\n      notificationTarget: new FunctionHook(registerFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    // Add an alarm action to terminate invalid instances\n    const alarmAction = new lambda.Function(this, 'GitlabRunnerAlarmAction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_alarm',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n    alarmAction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'autoscaling:SetInstanceHealth',\n        ],\n      }),\n    );\n    const alarmSubscription = new subscriptions.LambdaSubscription(alarmAction);\n    this.topicAlarm.addSubscription(alarmSubscription);\n\n    // Unregister gitlab runners and remove alarms on instance termination or CFn stack deletion\n    const unregisterRole = new iam.Role(this, 'GitlabRunnerUnregisterRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      description: 'For Gitlab Runner Unregistering Function Role',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n      ],\n    });\n    unregisterRole.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'ssm:SendCommand',\n          'autoscaling:DescribeAutoScalingGroups',\n          'cloudwatch:DeleteAlarms',\n        ],\n      }),\n    );\n\n    const unregisterFunction = new lambda.Function(this, 'GitlabRunnerUnregisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.unregister',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookTerminating', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_TERMINATING,\n      notificationTarget: new FunctionHook(unregisterFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    const unregisterCustomResource = new lambda.Function(this, 'GitlabRunnerUnregisterCustomResource', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    const unregisterProvider = new cr.Provider(this, 'GitlabRunnerUnregisterProvider', {\n      onEventHandler: unregisterCustomResource,\n    });\n\n    const customResource = new cdk.CustomResource(this, 'GitlabRunnerCustomResource', {\n      serviceToken: unregisterProvider.serviceToken,\n      properties: {\n        AutoScalingGroupNames: [this.autoscalingGroup.autoScalingGroupName],\n      },\n    });\n    customResource.node.addDependency(unregisterProvider);\n\n    new cdk.CfnOutput(this, 'GitlabRunnerAutoScalingGroupArn', {\n      value: this.autoscalingGroup.autoScalingGroupArn,\n    });\n  }\n\n  private dockerVolumesList(dockerVolume: DockerVolumes[] | undefined): string {\n    let tempString: string = '--docker-volumes \"/var/run/docker.sock:/var/run/docker.sock\"';\n    if (dockerVolume) {\n      let tempList: string[] = [];\n      dockerVolume.forEach(e => {\n        tempList.push(`\"${e.hostPath}:${e.containerPath}\"`);\n      });\n      tempList.forEach(e => {\n        tempString = `${tempString} --docker-volumes ${e}`;\n      });\n    }\n    return tempString;\n  }\n  /**\n   * @param props\n   * @returns Array.\n   */\n  public createUserData(props: GitlabRunnerAutoscalingProps): string[] {\n    return [\n      'yum update -y',\n      'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',\n      'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',\n      `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \\\n      --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} --registration-token ${props.gitlabToken} \\\n      --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \\\n      --executor docker --docker-image \"alpine:latest\" --description \"A Runner on EC2 Instance (${props.instanceType})\" \\\n      --tag-list \"${props.tags?.join(',')}\" --docker-privileged`,\n      `sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,\n    ];\n  }\n}\n"]}
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-autoscaling.js","sourceRoot":"","sources":["../src/gitlab-runner-autoscaling.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport * as asg from 'aws-cdk-lib/aws-autoscaling';\nimport { FunctionHook } from 'aws-cdk-lib/aws-autoscaling-hooktargets';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as assets from 'aws-cdk-lib/aws-s3-assets';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as subscriptions from 'aws-cdk-lib/aws-sns-subscriptions';\nimport * as cr from 'aws-cdk-lib/custom-resources';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { compare } from 'compare-versions';\nimport { Construct } from 'constructs';\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n\n/**\n * GitlabRunnerAutoscaling Props.\n */\nexport interface GitlabRunnerAutoscalingProps {\n  /**\n   * Gitlab Runner version\n   * Please give me gitlab runner version.\n   */\n  readonly gitlabRunnerVersion: string;\n  /**\n   * Gitlab token.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN' });\n   */\n  readonly gitlabToken: string;\n\n  /**\n   * Image URL of Gitlab Runner.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });\n   *\n   * @default public.ecr.aws/gitlab/gitlab-runner:latest\n   *\n   */\n  readonly gitlabRunnerImage?: string;\n\n  /**\n   * Runner default EC2 instance type.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceType: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly instanceType?: string;\n\n  /**\n   * VPC for the Gitlab Runner .\n   *\n   * @example\n   * const newVpc = new Vpc(stack, 'NewVPC', {\n   *   ipAddresses: IpAddresses.cidr('10.0.0.0/16'),\n   *   maxAzs: 2,\n   *   subnetConfiguration: [{\n   *     cidrMask: 26,\n   *     name: 'RunnerVPC',\n   *     subnetType: SubnetType.PUBLIC,\n   *   }],\n   *   natGateways: 0,\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', vpc: newVpc });\n   *\n   * @default - A new VPC will be created.\n   *\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * IAM role for the Gitlab Runner Instance .\n   *\n   * @example\n   * const role = new Role(stack, 'runner-role', {\n   *   assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n   *   description: 'For Gitlab Runner Test Role',\n   *   roleName: 'Runner-Role',\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceRole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * Run worker nodes as EC2 Spot\n   *\n   * @default - false\n   */\n  readonly spotInstance?: boolean;\n\n  /**\n   * Minimum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', minCapacity: 2 });\n   *\n   * @default - minCapacity: 1\n   *\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', maxCapacity: 4 });\n   *\n   * @default - desiredCapacity\n   *\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Desired capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', desiredCapacity: 2 });\n   *\n   * @default - minCapacity, and leave unchanged during deployment\n   *\n   */\n  readonly desiredCapacity?: number;\n\n  /**\n   * tags for the runner\n   *\n   * @default - ['runner', 'gitlab', 'awscdk']\n   */\n  readonly tags?: string[];\n\n  /**\n   * Gitlab Runner register url .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN',gitlabUrl: 'https://gitlab.com/'});\n   *\n   * @default - https://gitlab.com/ , The trailing slash is mandatory.\n   *\n   */\n  readonly gitlabUrl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * VPC subnet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabRunnerAutoscaling(stack, 'testing', {\n   *   gitlabToken: 'GITLAB_TOKEN',\n   *   instanceType: 't3.large',\n   *   instanceRole: role,\n   *   ebsSize: 100,\n   *   vpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - SubnetType.PRIVATE subnet\n   */\n  readonly vpcSubnet?: ec2.SubnetSelection;\n\n  /**\n   * add another Gitlab Container Runner Docker Volumes Path at job runner runtime.\n   *\n   * more detail see https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section\n   *\n   * @default - already mount \"/var/run/docker.sock:/var/run/docker.sock\"\n   *\n   * @example\n   * dockerVolumes: [\n   *   {\n   *     hostPath: '/tmp/cache',\n   *     containerPath: '/tmp/cache',\n   *   },\n   * ],\n   */\n  readonly dockerVolumes?: DockerVolumes[];\n\n  /**\n   * Parameters of put_metric_alarm function\n   *\n   * https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/cloudwatch.html#CloudWatch.Client.put_metric_alarm\n   *\n   * @default - [{\n   *     AlarmName: 'GitlabRunnerDiskUsage',\n   *     MetricName: 'disk_used_percent',\n   * }]\n   *\n   */\n  readonly alarms?: object[];\n}\n\n/**\n * GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.\n */\nexport class GitlabRunnerAutoscaling extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance.\n   */\n  public readonly instanceRole: iam.IRole;\n\n  /**\n   * This represents a Runner Auto Scaling Group\n   */\n  public readonly autoscalingGroup: asg.AutoScalingGroup;\n\n  /**\n   * The EC2 runner's VPC.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly securityGroup: ec2.ISecurityGroup;\n\n  /**\n   * The SNS topic to suscribe alarms for EC2 runner's metrics.\n   */\n  public readonly topicAlarm: sns.ITopic;\n\n\n  constructor(scope: Construct, id: string, props: GitlabRunnerAutoscalingProps) {\n    super(scope, id);\n    const defaultProps = {\n      instanceType: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      gitlabUrl: 'https://gitlab.com/',\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      alarms: [\n        {\n          AlarmName: 'GitlabRunnerDiskUsage',\n          MetricName: 'disk_used_percent',\n        },\n      ],\n    };\n    const runnerProps = { ...defaultProps, ...props };\n    if (compare(props.gitlabRunnerVersion, '15.10', '>=') && props.gitlabToken.includes('glrt-') === false) {\n      throw new Error('If gitlabRunnerVersion >= 15.10, gitlabtoken please give glrt-xxxxxxx @see https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html');\n    }\n    const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {\n      path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),\n    });\n\n    const userData = ec2.UserData.forLinux();\n    userData.addS3DownloadCommand({\n      bucket: asset.bucket,\n      bucketKey: asset.s3ObjectKey,\n      localFile: '/opt/aws/amazon-cloudwatch-agent/etc/amazon-cloudwatch-agent.json',\n    });\n    userData.addCommands(...this.createUserData(runnerProps));\n\n    this.instanceRole =\n      runnerProps.instanceRole ??\n      new iam.Role(this, 'GitlabRunnerInstanceRole', {\n        assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For EC2 Instance (Gitlab Runner) Role',\n        managedPolicies: [\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchAgentServerPolicy'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n        ],\n      });\n\n    this.vpc = runnerProps.vpc ?? new ec2.Vpc(this, 'VPC');\n\n    this.securityGroup = new ec2.SecurityGroup(this, 'GitlabRunnerSecurityGroup', {\n      vpc: this.vpc,\n    });\n    const instanceProfile = new iam.CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.instanceRole.roleName],\n    });\n    const lt = new ec2.CfnLaunchTemplate(this, 'GitlabRunnerLaunchTemplate', {\n      launchTemplateData: {\n        imageId: ec2.MachineImage.latestAmazonLinux2().getImage(this).imageId,\n        instanceType: runnerProps.instanceType,\n        instanceMarketOptions: {\n          marketType: runnerProps.spotInstance ? 'spot' : undefined,\n          spotOptions: runnerProps.spotInstance ? {\n            spotInstanceType: 'one-time',\n          } : undefined,\n        },\n        userData: cdk.Fn.base64(userData.render()),\n        blockDeviceMappings: [\n          {\n            deviceName: '/dev/xvda',\n            ebs: {\n              volumeSize: runnerProps.ebsSize ?? 60,\n            },\n          },\n        ],\n        iamInstanceProfile: {\n          arn: instanceProfile.attrArn,\n        },\n        securityGroupIds: this.securityGroup.connections.securityGroups.map(\n          (m) => m.securityGroupId,\n        ),\n      },\n    });\n\n    this.autoscalingGroup = new asg.AutoScalingGroup(this, 'GitlabRunnerAutoscalingGroup', {\n      instanceType: new ec2.InstanceType(runnerProps.instanceType),\n      autoScalingGroupName: `Gitlab Runners (${runnerProps.instanceType})`,\n      vpc: this.vpc,\n      vpcSubnets: runnerProps.vpcSubnet,\n      machineImage: ec2.MachineImage.latestAmazonLinux2(),\n      minCapacity: runnerProps.minCapacity,\n      maxCapacity: runnerProps.maxCapacity,\n      desiredCapacity: runnerProps.desiredCapacity,\n    });\n\n    const cfnAsg = this.autoscalingGroup.node.tryFindChild('ASG') as asg.CfnAutoScalingGroup;\n    cfnAsg.addPropertyDeletionOverride('LaunchConfigurationName');\n    cfnAsg.addPropertyOverride('LaunchTemplate', {\n      LaunchTemplateId: lt.ref,\n      Version: lt.attrLatestVersionNumber,\n    });\n    this.autoscalingGroup.node.tryRemoveChild('LaunchConfig');\n\n    this.topicAlarm = new sns.Topic(this, 'GitlabRunnerAlarm');\n    const alarms = JSON.stringify(runnerProps.alarms);\n\n    // Put alarms at launch\n    const registerFunction = new lambda.Function(this, 'GitlabRunnerRegisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.register',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n        SNS_TOPIC_ARN: this.topicAlarm.topicArn,\n      },\n    });\n    registerFunction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'cloudwatch:PutMetricAlarm',\n        ],\n      }),\n    );\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookLaunching', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_LAUNCHING,\n      notificationTarget: new FunctionHook(registerFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    // Add an alarm action to terminate invalid instances\n    const alarmAction = new lambda.Function(this, 'GitlabRunnerAlarmAction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_alarm',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n    alarmAction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'autoscaling:SetInstanceHealth',\n        ],\n      }),\n    );\n    const alarmSubscription = new subscriptions.LambdaSubscription(alarmAction);\n    this.topicAlarm.addSubscription(alarmSubscription);\n\n    // Unregister gitlab runners and remove alarms on instance termination or CFn stack deletion\n    const unregisterRole = new iam.Role(this, 'GitlabRunnerUnregisterRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      description: 'For Gitlab Runner Unregistering Function Role',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n      ],\n    });\n    unregisterRole.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'ssm:SendCommand',\n          'autoscaling:DescribeAutoScalingGroups',\n          'cloudwatch:DeleteAlarms',\n        ],\n      }),\n    );\n\n    const unregisterFunction = new lambda.Function(this, 'GitlabRunnerUnregisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.unregister',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookTerminating', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_TERMINATING,\n      notificationTarget: new FunctionHook(unregisterFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    const unregisterCustomResource = new lambda.Function(this, 'GitlabRunnerUnregisterCustomResource', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    const unregisterProvider = new cr.Provider(this, 'GitlabRunnerUnregisterProvider', {\n      onEventHandler: unregisterCustomResource,\n    });\n\n    const customResource = new cdk.CustomResource(this, 'GitlabRunnerCustomResource', {\n      serviceToken: unregisterProvider.serviceToken,\n      properties: {\n        AutoScalingGroupNames: [this.autoscalingGroup.autoScalingGroupName],\n      },\n    });\n    customResource.node.addDependency(unregisterProvider);\n\n    new cdk.CfnOutput(this, 'GitlabRunnerAutoScalingGroupArn', {\n      value: this.autoscalingGroup.autoScalingGroupArn,\n    });\n  }\n\n  private dockerVolumesList(dockerVolume: DockerVolumes[] | undefined): string {\n    let tempString: string = '--docker-volumes \"/var/run/docker.sock:/var/run/docker.sock\"';\n    if (dockerVolume) {\n      let tempList: string[] = [];\n      dockerVolume.forEach(e => {\n        tempList.push(`\"${e.hostPath}:${e.containerPath}\"`);\n      });\n      tempList.forEach(e => {\n        tempString = `${tempString} --docker-volumes ${e}`;\n      });\n    }\n    return tempString;\n  }\n  /**\n   * @param props\n   * @returns Array.\n   */\n  public createUserData(props: GitlabRunnerAutoscalingProps): string[] {\n    return [\n      'yum update -y',\n      'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',\n      'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',\n      `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \\\n      --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} ${compare(props.gitlabRunnerVersion, '15.10', '>=') ? '--token' : '--registration-token'} ${props.gitlabToken} \\\n      --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \\\n      --executor docker --docker-image \"alpine:latest\" --description \"A Runner on EC2 Instance (${props.instanceType})\" \\\n      ${compare(props.gitlabRunnerVersion, '15.10', '>=') ? undefined : `--tag-list \"${props.tags?.join(',')}\" `} --docker-privileged`,\n      `sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,\n    ];\n  }\n}\n"]}
@@ -7,6 +7,11 @@ import { DockerVolumes } from './gitlab-runner-interfaces';
7
7
  * GitlabContainerRunner Props.
8
8
  */
9
9
  export interface GitlabContainerRunnerProps {
10
+ /**
11
+ * Gitlab Runner version
12
+ * Please give me gitlab runner version.
13
+ */
14
+ readonly gitlabRunnerVersion: string;
10
15
  /**
11
16
  * Gitlab token for the Register Runner .
12
17
  *
@@ -23,7 +28,7 @@ export interface GitlabContainerRunnerProps {
23
28
  * @example
24
29
  * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });
25
30
  *
26
- * @default public.ecr.aws/gitlab/gitlab-runner:latest
31
+ * @default public.ecr.aws/gitlab/gitlab-runner:latest !!! <--- latest now > 16.0 Gitlab Runner version
27
32
  *
28
33
  */
29
34
  readonly gitlabRunnerImage?: string;
@@ -74,45 +79,10 @@ export interface GitlabContainerRunnerProps {
74
79
  *
75
80
  */
76
81
  readonly ec2iamrole?: IRole;
77
- /**
78
- * Gitlab Runner register tag1 .
79
- *
80
- * @example
81
- * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag1: 'aa' });
82
- *
83
- * @deprecated - use tags ['runner', 'gitlab', 'awscdk']
84
- *
85
- * @default - tag1: gitlab .
86
- *
87
- */
88
- readonly tag1?: string;
89
- /**
90
- * Gitlab Runner register tag2 .
91
- *
92
- * @example
93
- * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag2: 'bb' });
94
- *
95
- * @deprecated - use tags ['runner', 'gitlab', 'awscdk']
96
- *
97
- * @default - tag2: awscdk .
98
- *
99
- */
100
- readonly tag2?: string;
101
- /**
102
- * Gitlab Runner register tag3 .
103
- *
104
- * @example
105
- * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag3: 'cc' });
106
- *
107
- * @deprecated - use tags ['runner', 'gitlab', 'awscdk']
108
- *
109
- * @default - tag3: runner .
110
- *
111
- */
112
- readonly tag3?: string;
113
82
  /**
114
83
  * tags for the runner
115
- *
84
+ * Unsupported Gitlab Runner 15.10 and later
85
+ * @see - https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html
116
86
  * @default - ['runner', 'gitlab', 'awscdk']
117
87
  */
118
88
  readonly tags?: string[];