@rio-cloud/cdk-v2-constructs 6.2.1 → 6.3.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.
@@ -1,7 +1,8 @@
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 { StringParameter } from 'aws-cdk-lib/aws-ssm';
4
+ import { IBucket } from 'aws-cdk-lib/aws-s3';
5
+ import { IStringParameter } from 'aws-cdk-lib/aws-ssm';
5
6
  import { Construct } from 'constructs';
6
7
  /**
7
8
  * The GitLabRunnerProps require the VPC ID, a defined environment of account and region, optional
@@ -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
@@ -21,23 +23,23 @@ export interface GitLabRunnerProps {
21
23
  */
22
24
  export interface GitlabRunnerWorkerProps {
23
25
  /** The SSM StringParameter with the registered runner token */
24
- token: StringParameter;
26
+ readonly token: IStringParameter;
25
27
  /** The GitLab instance URL, either https://gitlab.cicd.man or https://gitlab.collaborationlayer-traton.com */
26
- gitInstanceUrl: GitlabInstanceUrl;
28
+ readonly gitInstanceUrl: GitlabInstanceUrl;
27
29
  /** The instance type for the runner worker */
28
- instanceType: InstanceType;
30
+ readonly instanceType: InstanceType;
29
31
  /** The desired max spot price */
30
- spotPrice: number;
32
+ readonly spotPrice: number;
31
33
  /** Whether to use spot instance or not, Requires ServiceLinked Role for EC2 Spot to be deployed in the account */
32
- requestSpotPrice: boolean;
34
+ readonly requestSpotPrice: boolean;
33
35
  /** The default role for the runner worker when spawned */
34
- defaultWorkerRole: IRole;
36
+ readonly defaultWorkerRole: IRole;
35
37
  /** The maximum number of builds for an instance before it has to be decommissioned. Default 10 */
36
- maxBuilds?: number;
38
+ readonly maxBuilds?: number;
37
39
  /** The maximum number of instances to keep idle for new incoming jobs. Default 5 */
38
- maxIdleInstance?: number;
40
+ readonly maxIdleInstance?: number;
39
41
  /** The maximum idle time seconds for an instance. Default 900 seconds */
40
- maxIdleTime?: number;
42
+ readonly maxIdleTime?: number;
41
43
  }
42
44
  export type GitlabInstanceUrl = 'https://gitlab.cicd.man' | 'https://gitlab.collaborationlayer-traton.com';
43
45
  /**
@@ -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
  */
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
+ var _a;
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  exports.GitlabRunner = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
4
6
  // eslint-disable-next-line import/no-extraneous-dependencies
5
7
  const cdk_autoscaling_gitlab_runner_1 = require("@pepperize/cdk-autoscaling-gitlab-runner");
6
8
  const aws_ec2_1 = require("aws-cdk-lib/aws-ec2");
@@ -15,34 +17,48 @@ const rio_landing_zone_1 = require("../../../rio-landing-zone");
15
17
  * minimal configuration with runner spot instance:
16
18
  * ```ts
17
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
+ * });
18
31
  * new GitlabRunner(stack, 'GitLabRunner', {
19
- * 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
20
34
  * });
21
35
  *```
22
36
  * recommended:
23
37
  * ```ts
24
38
  * new SpotServiceLinkedRole(stack, 'SpotLinkedRole');
25
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
+ * });
26
51
  * new GitlabRunner(stack, 'GitLabRunner', {
27
52
  * env: {account: '123456789012', region: 'eu-west-1'},
28
- * runnersWorkerProps: [
29
- * {
30
- * token: myTokenForTaggedRunner1, // with this runner we only want to run jobs that require more power
31
- * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
32
- * instanceType: InstanceType.of(InstanceClass.M7I_FLEX, InstanceSize.XLARGE), // exemplary larger runner
33
- * spotPrice: 0.2, // exemplary spot price
34
- * requestSpotPrice: true,
35
- * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
36
- * },
37
- * {
38
- * token: myTokenForTaggedRunner2, // with this runner we want to run all generic jobs that do not require much processing power
39
- * gitInstanceUrl: 'https://gitlab.cicd.man', // or the Traton GitLab
40
- * instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.MEDIUM), // exemplary smaller runner
41
- * spotPrice: 0.044, // exemplary spot price
42
- * requestSpotPrice: true,
43
- * defaultWorkerRole: runnerRoles.runnerBaseRole, // use the base role
44
- * },
45
- * ],
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
+ * },
46
62
  * });
47
63
  * ```
48
64
  */
@@ -50,79 +66,86 @@ class GitlabRunner extends constructs_1.Construct {
50
66
  constructor(scope, id, props) {
51
67
  super(scope, id);
52
68
  this.autoscalingConfig = [{
53
- periods: ['* * 7-24 * * mon-fri *'],
69
+ periods: ['* * 7-22 * * mon-fri *'],
54
70
  timezone: 'Europe/Berlin',
55
71
  }];
56
72
  const vpc = rio_landing_zone_1.RioLandingZone.getDefaultVpc(scope);
57
- const runnerConfig = props.runnersWorkerProps ?
58
- this.createWorkerConfigurations(props.runnersWorkerProps, props.env) :
59
- this.getDefaultRunnerWorkerConfig(props.env);
60
- const managerInstance = props.managerInstanceType ?? aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.T3, aws_ec2_1.InstanceSize.MICRO);
61
- new cdk_autoscaling_gitlab_runner_1.GitlabRunnerAutoscaling(scope, `GLR${scope.stackName}`, {
62
- runners: runnerConfig,
73
+ const runnerConfig = props.runnersWorkerProps
74
+ ? this.createWorkerConfigurations(props.runnersWorkerProps, props.env)
75
+ : this.getDefaultRunnerWorkerConfig(props.env);
76
+ const managerInstance = props.managerInstanceType ??
77
+ aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.T3, aws_ec2_1.InstanceSize.MICRO);
78
+ const runner = new cdk_autoscaling_gitlab_runner_1.GitlabRunnerAutoscaling(scope, `GLR${scope.stackName}`, {
79
+ runners: [runnerConfig],
63
80
  network: {
64
81
  vpc: vpc,
65
82
  },
66
83
  manager: {
67
84
  instanceType: managerInstance,
68
85
  },
86
+ cache: { bucket: props.cache },
69
87
  checkInterval: 30, // check every 30s for pending jobs
70
88
  concurrent: 300, // Global limit of concurrent jobs,
71
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');
72
93
  }
73
94
  createWorkerConfigurations(workerProps, env) {
74
- return workerProps.map(val => ({
75
- token: val.token,
76
- role: val.defaultWorkerRole,
95
+ return {
96
+ token: workerProps.token,
97
+ role: workerProps.defaultWorkerRole,
77
98
  configuration: {
78
- url: val.gitInstanceUrl,
99
+ url: workerProps.gitInstanceUrl,
79
100
  machine: {
80
101
  autoscaling: this.autoscalingConfig,
81
- maxBuilds: val.maxBuilds ?? 10,
82
- idleCount: val.maxIdleInstance ?? 5,
83
- idleTime: val.maxIdleTime ?? 900,
102
+ maxBuilds: workerProps.maxBuilds ?? 10,
103
+ idleCount: workerProps.maxIdleInstance ?? 5,
104
+ idleTime: workerProps.maxIdleTime ?? 900,
84
105
  machineOptions: {
85
- requestSpotInstance: val.requestSpotPrice,
86
- spotPrice: val.spotPrice,
106
+ requestSpotInstance: workerProps.requestSpotPrice,
107
+ spotPrice: workerProps.spotPrice,
87
108
  },
88
109
  },
89
110
  environment: [
90
111
  'DOCKER_DRIVER=overlay2',
91
112
  'DOCKER_TLS_DIRCE=/certs',
92
- `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" } }`,
93
114
  ],
94
115
  },
95
- instanceType: val.instanceType,
96
- }));
116
+ instanceType: workerProps.instanceType,
117
+ };
97
118
  }
98
119
  getDefaultRunnerWorkerConfig(env) {
99
120
  const gitLabRunnerTokenParameter = aws_ssm_1.StringParameter.fromStringParameterAttributes(this, 'RunnerToken', {
100
121
  parameterName: '/config/gitlab-runner-cdk/token',
101
122
  });
102
- return [{
103
- token: gitLabRunnerTokenParameter,
104
- configuration: {
105
- url: 'https://gitlab.cicd.man',
106
- limit: 0,
107
- machine: {
108
- maxBuilds: 10,
109
- autoscaling: this.autoscalingConfig,
110
- idleCount: 5,
111
- idleTime: 900,
112
- machineOptions: {
113
- requestSpotInstance: true,
114
- spotPrice: 0.09,
115
- },
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,
116
136
  },
117
- environment: [
118
- 'DOCKER_DRIVER=overlay2',
119
- 'DOCKER_TLS_DIRCE=/certs',
120
- `DOCKER_AUTH_CONFIG={"credHelpers": { "public.ecr.aws": "ecr-login", "${env.account}.dkr.ecr.<region>.amazonaws.com": "ecr-login" } }`,
121
- ],
122
137
  },
123
- instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.T3, aws_ec2_1.InstanceSize.LARGE),
124
- }];
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
+ ],
143
+ },
144
+ instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.T3, aws_ec2_1.InstanceSize.LARGE),
145
+ };
125
146
  }
126
147
  }
127
148
  exports.GitlabRunner = GitlabRunner;
128
- //# 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 { StringParameter } from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\nimport { RioLandingZone } from '../../../rio-landing-zone';\n\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  token: StringParameter;\n  /** The GitLab instance URL, either https://gitlab.cicd.man or https://gitlab.collaborationlayer-traton.com */\n  gitInstanceUrl: GitlabInstanceUrl;\n  /** The instance type for the runner worker */\n  instanceType: InstanceType;\n  /** The desired max spot price */\n  spotPrice: number;\n  /** Whether to use spot instance or not, Requires ServiceLinked Role for EC2 Spot to be deployed in the account */\n  requestSpotPrice: boolean;\n  /** The default role for the runner worker when spawned */\n  defaultWorkerRole: IRole;\n  /** The maximum number of builds for an instance before it has to be decommissioned. Default 10 */\n  maxBuilds?: number;\n  /** The maximum number of instances to keep idle for new incoming jobs. Default 5 */\n  maxIdleInstance?: number;\n  /** The maximum idle time seconds for an instance. Default 900 seconds */\n  maxIdleTime?: number;\n}\n\nexport type GitlabInstanceUrl = 'https://gitlab.cicd.man' | 'https://gitlab.collaborationlayer-traton.com'\n\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    periods: ['* * 7-24 * * 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 = props.managerInstanceType ?? 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(workerProps: GitlabRunnerWorkerProps[], env: Environment): GitlabRunnerAutoscalingJobRunnerProps[] {\n    return workerProps.map(val => (\n      {\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\n  private getDefaultRunnerWorkerConfig(env: Environment): GitlabRunnerAutoscalingJobRunnerProps[] {\n    const gitLabRunnerTokenParameter = 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.<region>.amazonaws.com\": \"ecr-login\" } }`,\n        ],\n      },\n      instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.LARGE),\n    }];\n  }\n}"]}
149
+ _a = JSII_RTTI_SYMBOL_1;
150
+ GitlabRunner[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.GitlabRunner", version: "0.0.0" };
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":";;;;;AAAA,6DAA6D;AAC7D,4FAIkD;AAElD,iDAAgF;AAGhF,iDAAwE;AACxE,2CAAuC;AACvC,gEAA2D;AA6C3D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoDG;AACH,MAAa,YAAa,SAAQ,sBAAS;IAKzC,YAAY,KAAY,EAAE,EAAW,EAAE,KAAwB;QAC7D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QALX,sBAAiB,GAA+B,CAAC;gBACvD,OAAO,EAAE,CAAC,wBAAwB,CAAC;gBACnC,QAAQ,EAAE,eAAe;aAC1B,CAAC,CAAC;QAID,MAAM,GAAG,GAAG,iCAAc,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAEhD,MAAM,YAAY,GAAG,KAAK,CAAC,kBAAkB;YAC3C,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC,GAAG,CAAC;YACtE,CAAC,CAAC,IAAI,CAAC,4BAA4B,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEjD,MAAM,eAAe,GACnB,KAAK,CAAC,mBAAmB;YACzB,sBAAY,CAAC,EAAE,CAAC,uBAAa,CAAC,EAAE,EAAE,sBAAY,CAAC,KAAK,CAAC,CAAC;QAExD,MAAM,MAAM,GAAG,IAAI,uDAAuB,CAAC,KAAK,EAAE,MAAM,KAAK,CAAC,SAAS,EAAE,EAAE;YACzE,OAAO,EAAE,CAAC,YAAY,CAAC;YACvB,OAAO,EAAE;gBACP,GAAG,EAAE,GAAG;aACT;YACD,OAAO,EAAE;gBACP,YAAY,EAAE,eAAe;aAC9B;YACD,KAAK,EAAE,EAAE,MAAM,EAAE,KAAK,CAAC,KAAK,EAAE;YAC9B,aAAa,EAAE,EAAE,EAAE,mCAAmC;YACtD,UAAU,EAAE,GAAG,EAAE,mCAAmC;SACrD,CAAC,CAAC;QACH,0HAA0H;QAC1H,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CACjC,yEAAyE,EAAE,6BAA6B;QACxG,0GAA0G,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC,WAAW,EAAE,EACvJ,uBAAuB,CACxB,CAAC;IACJ,CAAC;IAEO,0BAA0B,CAAC,WAAoC,EAAE,GAAgB;QACvF,OAAO;YACL,KAAK,EAAE,WAAW,CAAC,KAAK;YACxB,IAAI,EAAE,WAAW,CAAC,iBAAiB;YACnC,aAAa,EAAE;gBACb,GAAG,EAAE,WAAW,CAAC,cAAc;gBAC/B,OAAO,EAAE;oBACP,WAAW,EAAE,IAAI,CAAC,iBAAiB;oBACnC,SAAS,EAAE,WAAW,CAAC,SAAS,IAAI,EAAE;oBACtC,SAAS,EAAE,WAAW,CAAC,eAAe,IAAI,CAAC;oBAC3C,QAAQ,EAAE,WAAW,CAAC,WAAW,IAAI,GAAG;oBACxC,cAAc,EAAE;wBACd,mBAAmB,EAAE,WAAW,CAAC,gBAAgB;wBACjD,SAAS,EAAE,WAAW,CAAC,SAAS;qBACjC;iBACF;gBACD,WAAW,EAAE;oBACX,wBAAwB;oBACxB,yBAAyB;oBACzB,wEACE,GAAG,CAAC,OACN,YAAY,GAAG,CAAC,MAAM,kCAAkC;iBACzD;aACF;YACD,YAAY,EAAE,WAAW,CAAC,YAAY;SACvC,CAAC;IACJ,CAAC;IAEO,4BAA4B,CAClC,GAAgB;QAEhB,MAAM,0BAA0B,GAC9B,yBAAe,CAAC,6BAA6B,CAAC,IAAI,EAAE,aAAa,EAAE;YACjE,aAAa,EAAE,iCAAiC;SACjD,CAAC,CAAC;QACL,OAAO;YACL,KAAK,EAAE,0BAA0B;YACjC,aAAa,EAAE;gBACb,GAAG,EAAE,yBAAyB;gBAC9B,KAAK,EAAE,CAAC;gBACR,OAAO,EAAE;oBACP,SAAS,EAAE,EAAE;oBACb,WAAW,EAAE,IAAI,CAAC,iBAAiB;oBACnC,SAAS,EAAE,CAAC;oBACZ,QAAQ,EAAE,GAAG;oBACb,cAAc,EAAE;wBACd,mBAAmB,EAAE,IAAI;wBACzB,SAAS,EAAE,IAAI;qBAChB;iBACF;gBACD,WAAW,EAAE;oBACX,wBAAwB;oBACxB,yBAAyB;oBACzB,wEACE,GAAG,CAAC,OACN,YAAY,GAAG,CAAC,MAAM,kCAAkC;iBACzD;aACF;YACD,YAAY,EAAE,sBAAY,CAAC,EAAE,CAAC,uBAAa,CAAC,EAAE,EAAE,sBAAY,CAAC,KAAK,CAAC;SACpE,CAAC;IACJ,CAAC;;AAlGH,oCAmGC","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"]}
@@ -2,7 +2,7 @@ import { Environment, Stack } from 'aws-cdk-lib';
2
2
  import { Role } from 'aws-cdk-lib/aws-iam';
3
3
  import { Construct } from 'constructs';
4
4
  export interface RunnerRoleProps {
5
- env: Environment;
5
+ readonly env: Environment;
6
6
  }
7
7
  /**
8
8
  * This construct provides a set of base roles for gitlab runners in order to build, test, validate and deploy applications