cdk-gitlab-runner 2.1.394 → 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 +7 -1
@@ -11,6 +11,8 @@ const lambda = require("aws-cdk-lib/aws-lambda");
11
11
  const logs = require("aws-cdk-lib/aws-logs");
12
12
  const ssm = require("aws-cdk-lib/aws-ssm");
13
13
  const cr = require("aws-cdk-lib/custom-resources");
14
+ // eslint-disable-next-line import/no-extraneous-dependencies
15
+ const compare_versions_1 = require("compare-versions");
14
16
  const constructs_1 = require("constructs");
15
17
  /**
16
18
  * InstanceInterruptionBehavior enum.
@@ -36,6 +38,9 @@ var InstanceInterruptionBehavior;
36
38
  class GitlabContainerRunner extends constructs_1.Construct {
37
39
  constructor(scope, id, props) {
38
40
  super(scope, id);
41
+ if (!props.gitlabRunnerImage) {
42
+ aws_cdk_lib_1.Annotations.of(this).addWarning('Default Gitlab Runner Image use public.ecr.aws/gitlab/gitlab-runner:latest GitlabRunner Version Maybe > 16.0');
43
+ }
39
44
  const spotFleetId = id;
40
45
  const defaultProps = {
41
46
  gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',
@@ -46,6 +51,9 @@ class GitlabContainerRunner extends constructs_1.Construct {
46
51
  runnerDescription: 'Docker Runner',
47
52
  };
48
53
  const runnerProps = { ...defaultProps, ...props };
54
+ if ((0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') && props.gitlabtoken.includes('glrt-') === false) {
55
+ throw new Error('If gitlabRunnerVersion >= 15.10, gitlabtoken please give glrt-xxxxxxx @see https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html');
56
+ }
49
57
  const tokenParameterStore = new ssm.StringParameter(this, 'GitlabTokenParameter', {
50
58
  stringValue: 'GITLAB_TOKEN',
51
59
  });
@@ -83,7 +91,7 @@ class GitlabContainerRunner extends constructs_1.Construct {
83
91
  this.defaultRunnerSG.connections.allowFromAnyIpv4(aws_ec2_1.Port.tcp(22));
84
92
  const spotOrOnDemand = runnerProps.spotFleet ?? false;
85
93
  if (spotOrOnDemand) {
86
- //throw new Error('yes new spotfleet');
94
+ //--token Error('yes new spotfleet');
87
95
  const imageId = aws_ec2_1.MachineImage.latestAmazonLinux2().getImage(this).imageId;
88
96
  const lt = new aws_ec2_1.CfnLaunchTemplate(this, 'LaunchTemplate', {
89
97
  launchTemplateData: {
@@ -270,18 +278,18 @@ class GitlabContainerRunner extends constructs_1.Construct {
270
278
  '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',
271
279
  'systemctl restart docker && systemctl enable docker',
272
280
  `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \
273
- --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlaburl} --registration-token ${props.gitlabtoken} \
281
+ --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} \
274
282
  --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \
275
283
  --executor docker --docker-image "alpine:latest" --description "${props.runnerDescription}" \
276
- --tag-list "${props.tags?.join(',')}" --docker-privileged`,
284
+ ${(0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') ? undefined : `--tag-list "${props.tags?.join(',')}" `} --docker-privileged`,
277
285
  `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}`,
278
286
  `sed -i 's/concurrent = .*/concurrent = ${props.concurrentJobs}/g' /home/ec2-user/.gitlab-runner/config.toml`,
279
- 'TOKEN=$(cat /home/ec2-user/.gitlab-runner/config.toml | grep token | awk \'{print $3}\'| tr -d \'"\')',
287
+ 'TOKEN=$(cat /home/ec2-user/.gitlab-runner/config.toml | grep \'token \' | awk \'{print $3}\'| tr -d \'"\')',
280
288
  `aws ssm put-parameter --name ${tokenParameterStoreName} --value $TOKEN --overwrite --region ${aws_cdk_lib_1.Stack.of(this).region}`,
281
289
  ];
282
290
  }
283
291
  }
284
292
  _a = JSII_RTTI_SYMBOL_1;
285
- GitlabContainerRunner[_a] = { fqn: "cdk-gitlab-runner.GitlabContainerRunner", version: "2.1.394" };
293
+ GitlabContainerRunner[_a] = { fqn: "cdk-gitlab-runner.GitlabContainerRunner", version: "2.2.0" };
286
294
  exports.GitlabContainerRunner = GitlabContainerRunner;
287
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-instance.js","sourceRoot":"","sources":["../src/gitlab-runner-instance.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  CfnOutput,\n  Fn,\n  Stack,\n  Duration,\n  Lazy,\n  CustomResource,\n  Token,\n} from 'aws-cdk-lib';\nimport {\n  Instance,\n  InstanceType,\n  MachineImage,\n  UserData,\n  BlockDeviceVolume,\n  SubnetType,\n  Vpc,\n  IVpc,\n  IInstance,\n  SecurityGroup,\n  Port,\n  CfnLaunchTemplate,\n  CfnSpotFleet,\n  ISecurityGroup,\n  SubnetSelection,\n  IpAddresses,\n} from 'aws-cdk-lib/aws-ec2';\nimport {\n  IRole,\n  Role,\n  ServicePrincipal,\n  ManagedPolicy,\n  CfnInstanceProfile,\n  PolicyStatement,\n} 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 ssm from 'aws-cdk-lib/aws-ssm';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\n\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n/**\n * GitlabContainerRunner Props.\n */\nexport interface GitlabContainerRunnerProps {\n  /**\n   * Gitlab token for the Register Runner .\n   *\n   * @example\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN' });\n   *\n   * @default - You must to give the token !!!\n   *\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 GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', ec2type: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly ec2type?: 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 GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', selfvpc: newvpc });\n   *\n   * @default - new VPC will be created , 1 Vpc , 2 Public Subnet .\n   *\n   */\n  readonly selfvpc?: 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 EC2 Runner Test Role',\n   *   roleName: 'Myself-Runner-Role',\n   * });\n   *\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', ec2iamrole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly ec2iamrole?: IRole;\n\n  /**\n   * Gitlab Runner register tag1  .\n   *\n   * @example\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag1: 'aa' });\n   *\n   * @deprecated - use tags ['runner', 'gitlab', 'awscdk']\n   *\n   * @default - tag1: gitlab .\n   *\n   */\n  readonly tag1?: string;\n\n  /**\n   * Gitlab Runner register tag2  .\n   *\n   * @example\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag2: 'bb' });\n   *\n   * @deprecated - use tags ['runner', 'gitlab', 'awscdk']\n   *\n   * @default - tag2: awscdk .\n   *\n   */\n  readonly tag2?: string;\n\n  /**\n   * Gitlab Runner register tag3  .\n   *\n   * @example\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag3: 'cc' });\n   *\n   * @deprecated - use tags ['runner', 'gitlab', 'awscdk']\n   *\n   * @default - tag3: runner .\n   *\n   */\n  readonly tag3?: string;\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 GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',gitlaburl: 'https://gitlab.com/'});\n   *\n   * @default - gitlaburl='https://gitlab.com/' , please use https://yourgitlab.com/ do not use https://yourgitlab.com\n   *\n   */\n  readonly gitlaburl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * Gitlab Runner instance Use Spot Fleet or not ?!.\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',spotFleet: true});\n   *\n   * @default - spotFleet=false\n   *\n   */\n  readonly spotFleet?: boolean;\n\n  /**\n   * Gitlab Runner concurrent job configuration.\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',concurrentJobs: 3});\n   *\n   * @default - concurrentJobs=1\n   */\n  readonly concurrentJobs?: number;\n\n  /**\n   * Gitlab Runner description.\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',runnerDescription: 'Simple GitLab Runner'});\n   *\n   * @default - runnerDescription='Docker Runner'\n   */\n  readonly runnerDescription?: string;\n\n  /**\n   * SSH key name\n   *\n   * @default - no ssh key will be assigned , !!! only support spotfleet runner !!! .\n   */\n  readonly keyName?: string;\n\n  /**\n   * The behavior when a Spot Runner Instance is interrupted\n   *\n   * @default - InstanceInterruptionBehavior.TERMINATE , !!! only support spotfleet runner !!! .\n   */\n  readonly instanceInterruptionBehavior?: InstanceInterruptionBehavior;\n\n  /**\n   * the time when the spot fleet allocation expires\n   *\n   * @default - no expiration , !!! only support spotfleet runner !!! .\n   */\n  readonly validUntil?: string;\n\n  /**\n   * VPC subnet for the spot fleet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabContainerRunner(stack, 'testing', {\n   *   gitlabtoken: 'GITLAB_TOKEN',\n   *   ec2type: 't3.large',\n   *   ec2iamrole: role,\n   *   ebsSize: 100,\n   *   selfvpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - public subnet\n   */\n  readonly vpcSubnet?: 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/**\n * InstanceInterruptionBehavior enum.\n */\nexport enum InstanceInterruptionBehavior {\n  /**\n   * hibernate\n   */\n  HIBERNATE = 'hibernate',\n  /**\n   * stop\n   */\n  STOP = 'stop',\n  /**\n   * terminate\n   */\n  TERMINATE = 'terminate',\n}\n\n/**\n * GitlabContainerRunner Construct for create a Gitlab Runner.\n */\nexport class GitlabContainerRunner extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance .\n   */\n  public readonly runnerRole: IRole;\n\n  /**\n   * This represents a Runner EC2 instance , !!! only support On-demand runner instance !!!\n   */\n  public readonly runnerEc2!: IInstance;\n\n  /**\n   * The EC2 runner's vpc.\n   */\n  public readonly vpc!: IVpc;\n\n  /**\n   * The time when the the fleet allocation will expire , !!! only support spotfleet runner !!!\n   */\n  private validUntil?: string;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly defaultRunnerSG!: ISecurityGroup;\n\n  /**\n   * SpotFleetRequestId for this spot fleet , !!! only support spotfleet runner !!!\n   */\n  public readonly spotFleetRequestId!: string;\n\n  /**\n   * the first instance id in this fleet , !!! only support spotfleet runner !!!\n   */\n  readonly spotFleetInstanceId!: string;\n\n  private cfnSpotFleet?: CfnSpotFleet;\n  constructor(scope: Construct, id: string, props: GitlabContainerRunnerProps) {\n    super(scope, id);\n    const spotFleetId = id;\n\n    const defaultProps = {\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      gitlaburl: 'https://gitlab.com/',\n      ec2type: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      concurrentJobs: 1,\n      runnerDescription: 'Docker Runner',\n    };\n    const runnerProps = { ...defaultProps, ...props };\n\n    const tokenParameterStore = new ssm.StringParameter(this, 'GitlabTokenParameter', {\n      stringValue: 'GITLAB_TOKEN',\n    });\n\n    const shell = UserData.forLinux();\n    shell.addCommands(...this.createUserData(runnerProps, tokenParameterStore.parameterName));\n\n    this.runnerRole =\n      runnerProps.ec2iamrole ??\n      new Role(this, 'runner-role', {\n        assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For Gitlab EC2 Runner Role',\n      });\n    this.validUntil = runnerProps.validUntil;\n    const instanceProfile = new CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.runnerRole.roleName],\n    });\n    tokenParameterStore.grantWrite(this.runnerRole);\n    tokenParameterStore.grantRead(this.runnerRole);\n    this.vpc =\n      runnerProps.selfvpc ??\n      new Vpc(this, 'VPC', {\n        ipAddresses: IpAddresses.cidr('10.0.0.0/16'),\n        maxAzs: 2,\n        subnetConfiguration: [\n          {\n            cidrMask: 26,\n            name: 'RunnerVPC',\n            subnetType: SubnetType.PUBLIC,\n          },\n        ],\n        natGateways: 0,\n      });\n    this.defaultRunnerSG = new SecurityGroup(this, 'SpotFleetSg', {\n      vpc: this.vpc,\n    });\n    this.defaultRunnerSG.connections.allowFromAnyIpv4(Port.tcp(22));\n    const spotOrOnDemand = runnerProps.spotFleet ?? false;\n    if (spotOrOnDemand) {\n      //throw new Error('yes new spotfleet');\n\n      const imageId = MachineImage.latestAmazonLinux2().getImage(this).imageId;\n      const lt = new CfnLaunchTemplate(this, 'LaunchTemplate', {\n        launchTemplateData: {\n          imageId,\n          instanceType: runnerProps.ec2type,\n          blockDeviceMappings: [\n            {\n              deviceName: '/dev/xvda',\n              ebs: {\n                volumeSize: runnerProps.ebsSize ?? 60,\n              },\n            },\n          ],\n          userData: Fn.base64(shell.render()),\n          keyName: runnerProps.keyName,\n          tagSpecifications: [\n            {\n              resourceType: 'instance',\n              tags: [\n                {\n                  key: 'Name',\n                  value: `${Stack.of(this).stackName\n                  }/spotFleetGitlabRunner/${spotFleetId}`,\n                },\n              ],\n            },\n          ],\n          instanceMarketOptions: {\n            marketType: 'spot',\n            spotOptions: {\n              instanceInterruptionBehavior:\n                runnerProps.instanceInterruptionBehavior ??\n                InstanceInterruptionBehavior.TERMINATE,\n            },\n          },\n          securityGroupIds: this.defaultRunnerSG.connections.securityGroups.map(\n            (m) => m.securityGroupId,\n          ),\n          iamInstanceProfile: {\n            arn: instanceProfile.attrArn,\n          },\n        },\n      });\n\n      const spotFleetRole = new Role(this, 'FleetRole', {\n        assumedBy: new ServicePrincipal('spotfleet.amazonaws.com'),\n        managedPolicies: [\n          ManagedPolicy.fromAwsManagedPolicyName(\n            'service-role/AmazonEC2SpotFleetTaggingRole',\n          ),\n        ],\n      });\n\n      const vpcSubnetSelection = runnerProps.vpcSubnet ?? {\n        subnetType: SubnetType.PUBLIC,\n      };\n      const subnetConfig = this.vpc\n        .selectSubnets(vpcSubnetSelection)\n        .subnets.map((s) => ({\n          subnetId: s.subnetId,\n        }));\n\n      this.cfnSpotFleet = new CfnSpotFleet(this, id, {\n        spotFleetRequestConfigData: {\n          launchTemplateConfigs: [\n            {\n              launchTemplateSpecification: {\n                launchTemplateId: lt.ref,\n                version: lt.attrLatestVersionNumber,\n              },\n              overrides: subnetConfig,\n            },\n          ],\n          iamFleetRole: spotFleetRole.roleArn,\n          targetCapacity: 1,\n          validUntil: Lazy.string({ produce: () => this.validUntil }),\n          terminateInstancesWithExpiration: true,\n        },\n      });\n      const onEvent = new lambda.Function(this, 'OnEvent', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n        handler: 'index.on_event',\n        runtime: lambda.Runtime.PYTHON_3_8,\n        timeout: Duration.seconds(60),\n      });\n\n      const isComplete = new lambda.Function(this, 'IsComplete', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n        handler: 'index.is_complete',\n        runtime: lambda.Runtime.PYTHON_3_8,\n        timeout: Duration.seconds(60),\n        role: onEvent.role,\n      });\n\n      const myProvider = new cr.Provider(this, 'MyProvider', {\n        onEventHandler: onEvent,\n        isCompleteHandler: isComplete,\n        logRetention: logs.RetentionDays.ONE_DAY,\n      });\n\n      onEvent.addToRolePolicy(\n        new PolicyStatement({\n          actions: ['ec2:DescribeSpotFleetInstances'],\n          resources: ['*'],\n        }),\n      );\n\n      const fleetInstancesId = new CustomResource(this, 'GetInstanceId', {\n        serviceToken: myProvider.serviceToken,\n        properties: {\n          SpotFleetRequestId: this.cfnSpotFleet.ref,\n        },\n      });\n\n      fleetInstancesId.node.addDependency(this.cfnSpotFleet);\n      this.spotFleetInstanceId = Token.asString(\n        fleetInstancesId.getAtt('InstanceId'),\n      );\n      this.spotFleetRequestId = Token.asString(\n        fleetInstancesId.getAtt('SpotInstanceRequestId'),\n      );\n      new CfnOutput(this, 'InstanceId', { value: this.spotFleetInstanceId });\n      new CfnOutput(this, 'SpotFleetId', { value: this.cfnSpotFleet.ref });\n    } else {\n      this.runnerEc2 = new Instance(this, 'GitlabRunner', {\n        instanceType: new InstanceType(runnerProps.ec2type),\n        instanceName: 'Gitlab-Runner',\n        vpc: this.vpc,\n        vpcSubnets: runnerProps.vpcSubnet ?? {\n          subnetType: SubnetType.PUBLIC,\n        },\n        machineImage: MachineImage.latestAmazonLinux2(),\n        role: this.runnerRole,\n        userData: shell,\n        securityGroup: this.defaultRunnerSG,\n        blockDevices: [\n          {\n            deviceName: '/dev/xvda',\n            volume: BlockDeviceVolume.ebs(runnerProps.ebsSize ?? 60),\n          },\n        ],\n      });\n      new CfnOutput(this, 'Runner-Instance-ID', {\n        value: this.runnerEc2.instanceId,\n      });\n    }\n\n    const unregisterRunnerOnEvent = new lambda.Function(this, 'unregisterRunnerOnEvent', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'unregister_runner.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: Duration.seconds(60),\n    });\n\n    const unregisterRunnerProvider = new cr.Provider(this, 'unregisterRunnerProvider', {\n      onEventHandler: unregisterRunnerOnEvent,\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n\n    const unregisterRunnerCR = new CustomResource(this, 'unregisterRunnerCR', {\n      resourceType: 'Custom::unregisterRunnerProvider',\n      serviceToken: unregisterRunnerProvider.serviceToken,\n      properties: {\n        TokenParameterStoreName: tokenParameterStore.parameterName,\n        GitlabUrl: runnerProps.gitlaburl,\n      },\n    });\n\n    tokenParameterStore.grantRead(unregisterRunnerOnEvent);\n    unregisterRunnerCR.node.addDependency(tokenParameterStore);\n    this.runnerRole.addManagedPolicy(\n      ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n    );\n\n    new CfnOutput(this, 'Runner-Role-Arn', {\n      value: this.runnerRole.roleArn,\n    });\n  }\n\n  /**\n   * Add expire time function for spotfleet runner !!! .\n   *\n   * @param duration - Block duration.\n   */\n  public expireAfter(duration: Duration) {\n    const date = new Date();\n    date.setSeconds(date.getSeconds() + duration.toSeconds());\n    this.validUntil = date.toISOString();\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   * @param tokenParameterStoreName - the tokenParameterStoreName to put gitlab runner token.\n   * @returns Array.\n   */\n  public createUserData(props: GitlabContainerRunnerProps, tokenParameterStoreName: string): 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',\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 \"${props.runnerDescription}\" \\\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      `sed -i 's/concurrent = .*/concurrent = ${props.concurrentJobs}/g' /home/ec2-user/.gitlab-runner/config.toml`,\n      'TOKEN=$(cat /home/ec2-user/.gitlab-runner/config.toml | grep token | awk \\'{print $3}\\'| tr -d \\'\"\\')',\n      `aws ssm put-parameter --name ${tokenParameterStoreName} --value $TOKEN --overwrite --region ${Stack.of(this).region}`,\n    ];\n  }\n}\n"]}
295
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-instance.js","sourceRoot":"","sources":["../src/gitlab-runner-instance.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  CfnOutput,\n  Fn,\n  Stack,\n  Duration,\n  Lazy,\n  CustomResource,\n  Token,\n  Annotations,\n} from 'aws-cdk-lib';\nimport {\n  Instance,\n  InstanceType,\n  MachineImage,\n  UserData,\n  BlockDeviceVolume,\n  SubnetType,\n  Vpc,\n  IVpc,\n  IInstance,\n  SecurityGroup,\n  Port,\n  CfnLaunchTemplate,\n  CfnSpotFleet,\n  ISecurityGroup,\n  SubnetSelection,\n  IpAddresses,\n} from 'aws-cdk-lib/aws-ec2';\nimport {\n  IRole,\n  Role,\n  ServicePrincipal,\n  ManagedPolicy,\n  CfnInstanceProfile,\n  PolicyStatement,\n} 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 ssm from 'aws-cdk-lib/aws-ssm';\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';\n\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n/**\n * GitlabContainerRunner Props.\n */\nexport interface GitlabContainerRunnerProps {\n  /**\n   * Gitlab Runner version\n   * Please give me gitlab runner version.\n   */\n  readonly gitlabRunnerVersion: string;\n  /**\n   * Gitlab token for the Register Runner .\n   *\n   * @example\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN' });\n   *\n   * @default - You must to give the token !!!\n   *\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 !!! <--- latest now > 16.0 Gitlab Runner version\n   *\n   */\n  readonly gitlabRunnerImage?: string;\n\n  /**\n   * Runner default EC2 instance type.\n   *\n   * @example\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', ec2type: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly ec2type?: 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 GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', selfvpc: newvpc });\n   *\n   * @default - new VPC will be created , 1 Vpc , 2 Public Subnet .\n   *\n   */\n  readonly selfvpc?: 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 EC2 Runner Test Role',\n   *   roleName: 'Myself-Runner-Role',\n   * });\n   *\n   * new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', ec2iamrole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly ec2iamrole?: IRole;\n  /**\n   * tags for the runner\n   * Unsupported Gitlab Runner 15.10 and later\n   * @see - https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html\n   * @default - ['runner', 'gitlab', 'awscdk']\n   */\n  readonly tags?: string[];\n\n  /**\n   * Gitlab Runner register url .\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',gitlaburl: 'https://gitlab.com/'});\n   *\n   * @default - gitlaburl='https://gitlab.com/' , please use https://yourgitlab.com/ do not use https://yourgitlab.com\n   *\n   */\n  readonly gitlaburl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * Gitlab Runner instance Use Spot Fleet or not ?!.\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',spotFleet: true});\n   *\n   * @default - spotFleet=false\n   *\n   */\n  readonly spotFleet?: boolean;\n\n  /**\n   * Gitlab Runner concurrent job configuration.\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',concurrentJobs: 3});\n   *\n   * @default - concurrentJobs=1\n   */\n  readonly concurrentJobs?: number;\n\n  /**\n   * Gitlab Runner description.\n   *\n   * @example\n   * const runner = new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN',runnerDescription: 'Simple GitLab Runner'});\n   *\n   * @default - runnerDescription='Docker Runner'\n   */\n  readonly runnerDescription?: string;\n\n  /**\n   * SSH key name\n   *\n   * @default - no ssh key will be assigned , !!! only support spotfleet runner !!! .\n   */\n  readonly keyName?: string;\n\n  /**\n   * The behavior when a Spot Runner Instance is interrupted\n   *\n   * @default - InstanceInterruptionBehavior.TERMINATE , !!! only support spotfleet runner !!! .\n   */\n  readonly instanceInterruptionBehavior?: InstanceInterruptionBehavior;\n\n  /**\n   * the time when the spot fleet allocation expires\n   *\n   * @default - no expiration , !!! only support spotfleet runner !!! .\n   */\n  readonly validUntil?: string;\n\n  /**\n   * VPC subnet for the spot fleet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabContainerRunner(stack, 'testing', {\n   *   gitlabtoken: 'GITLAB_TOKEN',\n   *   ec2type: 't3.large',\n   *   ec2iamrole: role,\n   *   ebsSize: 100,\n   *   selfvpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - public subnet\n   */\n  readonly vpcSubnet?: 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/**\n * InstanceInterruptionBehavior enum.\n */\nexport enum InstanceInterruptionBehavior {\n  /**\n   * hibernate\n   */\n  HIBERNATE = 'hibernate',\n  /**\n   * stop\n   */\n  STOP = 'stop',\n  /**\n   * terminate\n   */\n  TERMINATE = 'terminate',\n}\n\n/**\n * GitlabContainerRunner Construct for create a Gitlab Runner.\n */\nexport class GitlabContainerRunner extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance .\n   */\n  public readonly runnerRole: IRole;\n\n  /**\n   * This represents a Runner EC2 instance , !!! only support On-demand runner instance !!!\n   */\n  public readonly runnerEc2!: IInstance;\n\n  /**\n   * The EC2 runner's vpc.\n   */\n  public readonly vpc!: IVpc;\n\n  /**\n   * The time when the the fleet allocation will expire , !!! only support spotfleet runner !!!\n   */\n  private validUntil?: string;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly defaultRunnerSG!: ISecurityGroup;\n\n  /**\n   * SpotFleetRequestId for this spot fleet , !!! only support spotfleet runner !!!\n   */\n  public readonly spotFleetRequestId!: string;\n\n  /**\n   * the first instance id in this fleet , !!! only support spotfleet runner !!!\n   */\n  readonly spotFleetInstanceId!: string;\n\n  private cfnSpotFleet?: CfnSpotFleet;\n  constructor(scope: Construct, id: string, props: GitlabContainerRunnerProps) {\n    super(scope, id);\n    if (!props.gitlabRunnerImage) {\n      Annotations.of(this).addWarning('Default Gitlab Runner Image use public.ecr.aws/gitlab/gitlab-runner:latest GitlabRunner Version Maybe > 16.0');\n    }\n\n    const spotFleetId = id;\n\n    const defaultProps = {\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      gitlaburl: 'https://gitlab.com/',\n      ec2type: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      concurrentJobs: 1,\n      runnerDescription: 'Docker Runner',\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\n    const tokenParameterStore = new ssm.StringParameter(this, 'GitlabTokenParameter', {\n      stringValue: 'GITLAB_TOKEN',\n    });\n\n    const shell = UserData.forLinux();\n    shell.addCommands(...this.createUserData(runnerProps, tokenParameterStore.parameterName));\n\n    this.runnerRole =\n      runnerProps.ec2iamrole ??\n      new Role(this, 'runner-role', {\n        assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For Gitlab EC2 Runner Role',\n      });\n    this.validUntil = runnerProps.validUntil;\n    const instanceProfile = new CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.runnerRole.roleName],\n    });\n    tokenParameterStore.grantWrite(this.runnerRole);\n    tokenParameterStore.grantRead(this.runnerRole);\n    this.vpc =\n      runnerProps.selfvpc ??\n      new Vpc(this, 'VPC', {\n        ipAddresses: IpAddresses.cidr('10.0.0.0/16'),\n        maxAzs: 2,\n        subnetConfiguration: [\n          {\n            cidrMask: 26,\n            name: 'RunnerVPC',\n            subnetType: SubnetType.PUBLIC,\n          },\n        ],\n        natGateways: 0,\n      });\n    this.defaultRunnerSG = new SecurityGroup(this, 'SpotFleetSg', {\n      vpc: this.vpc,\n    });\n    this.defaultRunnerSG.connections.allowFromAnyIpv4(Port.tcp(22));\n    const spotOrOnDemand = runnerProps.spotFleet ?? false;\n    if (spotOrOnDemand) {\n      //--token Error('yes new spotfleet');\n\n      const imageId = MachineImage.latestAmazonLinux2().getImage(this).imageId;\n      const lt = new CfnLaunchTemplate(this, 'LaunchTemplate', {\n        launchTemplateData: {\n          imageId,\n          instanceType: runnerProps.ec2type,\n          blockDeviceMappings: [\n            {\n              deviceName: '/dev/xvda',\n              ebs: {\n                volumeSize: runnerProps.ebsSize ?? 60,\n              },\n            },\n          ],\n          userData: Fn.base64(shell.render()),\n          keyName: runnerProps.keyName,\n          tagSpecifications: [\n            {\n              resourceType: 'instance',\n              tags: [\n                {\n                  key: 'Name',\n                  value: `${Stack.of(this).stackName\n                  }/spotFleetGitlabRunner/${spotFleetId}`,\n                },\n              ],\n            },\n          ],\n          instanceMarketOptions: {\n            marketType: 'spot',\n            spotOptions: {\n              instanceInterruptionBehavior:\n                runnerProps.instanceInterruptionBehavior ??\n                InstanceInterruptionBehavior.TERMINATE,\n            },\n          },\n          securityGroupIds: this.defaultRunnerSG.connections.securityGroups.map(\n            (m) => m.securityGroupId,\n          ),\n          iamInstanceProfile: {\n            arn: instanceProfile.attrArn,\n          },\n        },\n      });\n\n      const spotFleetRole = new Role(this, 'FleetRole', {\n        assumedBy: new ServicePrincipal('spotfleet.amazonaws.com'),\n        managedPolicies: [\n          ManagedPolicy.fromAwsManagedPolicyName(\n            'service-role/AmazonEC2SpotFleetTaggingRole',\n          ),\n        ],\n      });\n\n      const vpcSubnetSelection = runnerProps.vpcSubnet ?? {\n        subnetType: SubnetType.PUBLIC,\n      };\n      const subnetConfig = this.vpc\n        .selectSubnets(vpcSubnetSelection)\n        .subnets.map((s) => ({\n          subnetId: s.subnetId,\n        }));\n\n      this.cfnSpotFleet = new CfnSpotFleet(this, id, {\n        spotFleetRequestConfigData: {\n          launchTemplateConfigs: [\n            {\n              launchTemplateSpecification: {\n                launchTemplateId: lt.ref,\n                version: lt.attrLatestVersionNumber,\n              },\n              overrides: subnetConfig,\n            },\n          ],\n          iamFleetRole: spotFleetRole.roleArn,\n          targetCapacity: 1,\n          validUntil: Lazy.string({ produce: () => this.validUntil }),\n          terminateInstancesWithExpiration: true,\n        },\n      });\n      const onEvent = new lambda.Function(this, 'OnEvent', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n        handler: 'index.on_event',\n        runtime: lambda.Runtime.PYTHON_3_8,\n        timeout: Duration.seconds(60),\n      });\n\n      const isComplete = new lambda.Function(this, 'IsComplete', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n        handler: 'index.is_complete',\n        runtime: lambda.Runtime.PYTHON_3_8,\n        timeout: Duration.seconds(60),\n        role: onEvent.role,\n      });\n\n      const myProvider = new cr.Provider(this, 'MyProvider', {\n        onEventHandler: onEvent,\n        isCompleteHandler: isComplete,\n        logRetention: logs.RetentionDays.ONE_DAY,\n      });\n\n      onEvent.addToRolePolicy(\n        new PolicyStatement({\n          actions: ['ec2:DescribeSpotFleetInstances'],\n          resources: ['*'],\n        }),\n      );\n\n      const fleetInstancesId = new CustomResource(this, 'GetInstanceId', {\n        serviceToken: myProvider.serviceToken,\n        properties: {\n          SpotFleetRequestId: this.cfnSpotFleet.ref,\n        },\n      });\n\n      fleetInstancesId.node.addDependency(this.cfnSpotFleet);\n      this.spotFleetInstanceId = Token.asString(\n        fleetInstancesId.getAtt('InstanceId'),\n      );\n      this.spotFleetRequestId = Token.asString(\n        fleetInstancesId.getAtt('SpotInstanceRequestId'),\n      );\n      new CfnOutput(this, 'InstanceId', { value: this.spotFleetInstanceId });\n      new CfnOutput(this, 'SpotFleetId', { value: this.cfnSpotFleet.ref });\n    } else {\n      this.runnerEc2 = new Instance(this, 'GitlabRunner', {\n        instanceType: new InstanceType(runnerProps.ec2type),\n        instanceName: 'Gitlab-Runner',\n        vpc: this.vpc,\n        vpcSubnets: runnerProps.vpcSubnet ?? {\n          subnetType: SubnetType.PUBLIC,\n        },\n        machineImage: MachineImage.latestAmazonLinux2(),\n        role: this.runnerRole,\n        userData: shell,\n        securityGroup: this.defaultRunnerSG,\n        blockDevices: [\n          {\n            deviceName: '/dev/xvda',\n            volume: BlockDeviceVolume.ebs(runnerProps.ebsSize ?? 60),\n          },\n        ],\n      });\n      new CfnOutput(this, 'Runner-Instance-ID', {\n        value: this.runnerEc2.instanceId,\n      });\n    }\n\n    const unregisterRunnerOnEvent = new lambda.Function(this, 'unregisterRunnerOnEvent', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'unregister_runner.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: Duration.seconds(60),\n    });\n\n    const unregisterRunnerProvider = new cr.Provider(this, 'unregisterRunnerProvider', {\n      onEventHandler: unregisterRunnerOnEvent,\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n\n    const unregisterRunnerCR = new CustomResource(this, 'unregisterRunnerCR', {\n      resourceType: 'Custom::unregisterRunnerProvider',\n      serviceToken: unregisterRunnerProvider.serviceToken,\n      properties: {\n        TokenParameterStoreName: tokenParameterStore.parameterName,\n        GitlabUrl: runnerProps.gitlaburl,\n      },\n    });\n\n    tokenParameterStore.grantRead(unregisterRunnerOnEvent);\n    unregisterRunnerCR.node.addDependency(tokenParameterStore);\n    this.runnerRole.addManagedPolicy(\n      ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n    );\n\n    new CfnOutput(this, 'Runner-Role-Arn', {\n      value: this.runnerRole.roleArn,\n    });\n  }\n\n  /**\n   * Add expire time function for spotfleet runner !!! .\n   *\n   * @param duration - Block duration.\n   */\n  public expireAfter(duration: Duration) {\n    const date = new Date();\n    date.setSeconds(date.getSeconds() + duration.toSeconds());\n    this.validUntil = date.toISOString();\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   * @param tokenParameterStoreName - the tokenParameterStoreName to put gitlab runner token.\n   * @returns Array.\n   */\n  public createUserData(props: GitlabContainerRunnerProps, tokenParameterStoreName: string): 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',\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 \"${props.runnerDescription}\" \\\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      `sed -i 's/concurrent = .*/concurrent = ${props.concurrentJobs}/g' /home/ec2-user/.gitlab-runner/config.toml`,\n      'TOKEN=$(cat /home/ec2-user/.gitlab-runner/config.toml | grep \\'token \\' | awk \\'{print $3}\\'| tr -d \\'\"\\')',\n      `aws ssm put-parameter --name ${tokenParameterStoreName} --value $TOKEN --overwrite --region ${Stack.of(this).region}`,\n    ];\n  }\n}\n"]}
package/lib/integ.api.js CHANGED
@@ -19,7 +19,7 @@ const vpc = aws_ec2_1.Vpc.fromLookup(stack, 'defaultVpc', {
19
19
  isDefault: true,
20
20
  });
21
21
  const runner = new index_1.GitlabContainerRunner(stack, 'testing', {
22
- gitlabtoken: stack.node.tryGetContext('GITLAB_TOKEN') ?? 'GITLAB_TOKEN',
22
+ gitlabtoken: stack.node.tryGetContext('GITLAB_TOKEN') ?? 'glrt-GITLAB_TOKEN',
23
23
  ec2type: 't3.large',
24
24
  ec2iamrole: role,
25
25
  ebsSize: 100,
@@ -31,6 +31,7 @@ const runner = new index_1.GitlabContainerRunner(stack, 'testing', {
31
31
  containerPath: '/tmp/cahce',
32
32
  },
33
33
  ],
34
+ gitlabRunnerVersion: '15.10',
34
35
  });
35
36
  //runner.expireAfter(Duration.hours(1));
36
37
  runner.runnerRole.addManagedPolicy(aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'));
@@ -39,4 +40,4 @@ runner.defaultRunnerSG.connections.allowFromAnyIpv4(aws_ec2_1.Port.tcp(443));
39
40
  //runner.runnerEc2.connections.allowFrom(Peer.ipv4('0.0.0.0/0'), Port.tcp(8080));
40
41
  new aws_cdk_lib_1.CfnOutput(stack, 'role', { value: runner.runnerRole.roleArn });
41
42
  //new CfnOutput(stack, 'InstanceID', { value: runner.runnerEc2.instanceId });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2ludGVnLmFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDZDQUFvRDtBQUNwRCxpREFBZ0Q7QUFDaEQsaURBQTRFO0FBQzVFLG1DQUFnRDtBQUNoRCxNQUFNLEdBQUcsR0FBRztJQUNWLE1BQU0sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQjtJQUN0QyxPQUFPLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUI7Q0FDekMsQ0FBQztBQUNGLE1BQU0sT0FBTyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxPQUFPLEVBQUUsZUFBZSxFQUFFLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztBQUMzRCxNQUFNLElBQUksR0FBRyxJQUFJLGNBQUksQ0FBQyxLQUFLLEVBQUUsYUFBYSxFQUFFO0lBQzFDLFNBQVMsRUFBRSxJQUFJLDBCQUFnQixDQUFDLG1CQUFtQixDQUFDO0lBQ3BELFdBQVcsRUFBRSxpQ0FBaUM7SUFDOUMsUUFBUSxFQUFFLFVBQVU7Q0FDckIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxHQUFHLEdBQUcsYUFBRyxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO0lBQzlDLFNBQVMsRUFBRSxJQUFJO0NBQ2hCLENBQUMsQ0FBQztBQUNILE1BQU0sTUFBTSxHQUFHLElBQUksNkJBQXFCLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRTtJQUN6RCxXQUFXLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLElBQUksY0FBYztJQUN2RSxPQUFPLEVBQUUsVUFBVTtJQUNuQixVQUFVLEVBQUUsSUFBSTtJQUNoQixPQUFPLEVBQUUsR0FBRztJQUNaLE9BQU8sRUFBRSxHQUFHO0lBQ1osU0FBUyxFQUFFLElBQUk7SUFDZixhQUFhLEVBQUU7UUFDYjtZQUNFLFFBQVEsRUFBRSxZQUFZO1lBQ3RCLGFBQWEsRUFBRSxZQUFZO1NBQzVCO0tBQ0Y7Q0FDRixDQUFDLENBQUM7QUFFSCx3Q0FBd0M7QUFDeEMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FDaEMsdUJBQWEsQ0FBQyx3QkFBd0IsQ0FBQyx3QkFBd0IsQ0FBQyxDQUNqRSxDQUFDO0FBQ0YsTUFBTSxDQUFDLGVBQWUsQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsY0FBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ2xFLE1BQU0sQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLGdCQUFnQixDQUFDLGNBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUVuRSxpRkFBaUY7QUFDakYsSUFBSSx1QkFBUyxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO0FBQ25FLDZFQUE2RSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcCwgU3RhY2ssIENmbk91dHB1dCB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IFBvcnQsIFZwYyB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1lYzInO1xuaW1wb3J0IHsgTWFuYWdlZFBvbGljeSwgUm9sZSwgU2VydmljZVByaW5jaXBhbCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0IHsgR2l0bGFiQ29udGFpbmVyUnVubmVyIH0gZnJvbSAnLi9pbmRleCc7XG5jb25zdCBlbnYgPSB7XG4gIHJlZ2lvbjogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfUkVHSU9OLFxuICBhY2NvdW50OiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9BQ0NPVU5ULFxufTtcbmNvbnN0IG1vY2tBcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhtb2NrQXBwLCAndGVzdGluZy1zdGFjaycsIHsgZW52IH0pO1xuY29uc3Qgcm9sZSA9IG5ldyBSb2xlKHN0YWNrLCAncnVubmVyLXJvbGUnLCB7XG4gIGFzc3VtZWRCeTogbmV3IFNlcnZpY2VQcmluY2lwYWwoJ2VjMi5hbWF6b25hd3MuY29tJyksXG4gIGRlc2NyaXB0aW9uOiAnRm9yIEdpdGxhYiBFQzIgUnVubmVyIFRlc3QgUm9sZScsXG4gIHJvbGVOYW1lOiAnVGVzdFJvbGUnLFxufSk7XG5cbmNvbnN0IHZwYyA9IFZwYy5mcm9tTG9va3VwKHN0YWNrLCAnZGVmYXVsdFZwYycsIHtcbiAgaXNEZWZhdWx0OiB0cnVlLFxufSk7XG5jb25zdCBydW5uZXIgPSBuZXcgR2l0bGFiQ29udGFpbmVyUnVubmVyKHN0YWNrLCAndGVzdGluZycsIHtcbiAgZ2l0bGFidG9rZW46IHN0YWNrLm5vZGUudHJ5R2V0Q29udGV4dCgnR0lUTEFCX1RPS0VOJykgPz8gJ0dJVExBQl9UT0tFTicsXG4gIGVjMnR5cGU6ICd0My5sYXJnZScsXG4gIGVjMmlhbXJvbGU6IHJvbGUsXG4gIGVic1NpemU6IDEwMCxcbiAgc2VsZnZwYzogdnBjLFxuICBzcG90RmxlZXQ6IHRydWUsXG4gIGRvY2tlclZvbHVtZXM6IFtcbiAgICB7XG4gICAgICBob3N0UGF0aDogJy90bXAvY2FoY2UnLFxuICAgICAgY29udGFpbmVyUGF0aDogJy90bXAvY2FoY2UnLFxuICAgIH0sXG4gIF0sXG59KTtcblxuLy9ydW5uZXIuZXhwaXJlQWZ0ZXIoRHVyYXRpb24uaG91cnMoMSkpO1xucnVubmVyLnJ1bm5lclJvbGUuYWRkTWFuYWdlZFBvbGljeShcbiAgTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoJ0FtYXpvblMzUmVhZE9ubHlBY2Nlc3MnKSxcbik7XG5ydW5uZXIuZGVmYXVsdFJ1bm5lclNHLmNvbm5lY3Rpb25zLmFsbG93RnJvbUFueUlwdjQoUG9ydC50Y3AoODApKTtcbnJ1bm5lci5kZWZhdWx0UnVubmVyU0cuY29ubmVjdGlvbnMuYWxsb3dGcm9tQW55SXB2NChQb3J0LnRjcCg0NDMpKTtcblxuLy9ydW5uZXIucnVubmVyRWMyLmNvbm5lY3Rpb25zLmFsbG93RnJvbShQZWVyLmlwdjQoJzAuMC4wLjAvMCcpLCBQb3J0LnRjcCg4MDgwKSk7XG5uZXcgQ2ZuT3V0cHV0KHN0YWNrLCAncm9sZScsIHsgdmFsdWU6IHJ1bm5lci5ydW5uZXJSb2xlLnJvbGVBcm4gfSk7XG4vL25ldyBDZm5PdXRwdXQoc3RhY2ssICdJbnN0YW5jZUlEJywgeyB2YWx1ZTogcnVubmVyLnJ1bm5lckVjMi5pbnN0YW5jZUlkIH0pO1xuIl19
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2ludGVnLmFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDZDQUFvRDtBQUNwRCxpREFBZ0Q7QUFDaEQsaURBQTRFO0FBQzVFLG1DQUFnRDtBQUNoRCxNQUFNLEdBQUcsR0FBRztJQUNWLE1BQU0sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQjtJQUN0QyxPQUFPLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUI7Q0FDekMsQ0FBQztBQUNGLE1BQU0sT0FBTyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxPQUFPLEVBQUUsZUFBZSxFQUFFLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztBQUMzRCxNQUFNLElBQUksR0FBRyxJQUFJLGNBQUksQ0FBQyxLQUFLLEVBQUUsYUFBYSxFQUFFO0lBQzFDLFNBQVMsRUFBRSxJQUFJLDBCQUFnQixDQUFDLG1CQUFtQixDQUFDO0lBQ3BELFdBQVcsRUFBRSxpQ0FBaUM7SUFDOUMsUUFBUSxFQUFFLFVBQVU7Q0FDckIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxHQUFHLEdBQUcsYUFBRyxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO0lBQzlDLFNBQVMsRUFBRSxJQUFJO0NBQ2hCLENBQUMsQ0FBQztBQUNILE1BQU0sTUFBTSxHQUFHLElBQUksNkJBQXFCLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRTtJQUN6RCxXQUFXLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLElBQUksbUJBQW1CO0lBQzVFLE9BQU8sRUFBRSxVQUFVO0lBQ25CLFVBQVUsRUFBRSxJQUFJO0lBQ2hCLE9BQU8sRUFBRSxHQUFHO0lBQ1osT0FBTyxFQUFFLEdBQUc7SUFDWixTQUFTLEVBQUUsSUFBSTtJQUNmLGFBQWEsRUFBRTtRQUNiO1lBQ0UsUUFBUSxFQUFFLFlBQVk7WUFDdEIsYUFBYSxFQUFFLFlBQVk7U0FDNUI7S0FDRjtJQUNELG1CQUFtQixFQUFFLE9BQU87Q0FDN0IsQ0FBQyxDQUFDO0FBRUgsd0NBQXdDO0FBQ3hDLE1BQU0sQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQ2hDLHVCQUFhLENBQUMsd0JBQXdCLENBQUMsd0JBQXdCLENBQUMsQ0FDakUsQ0FBQztBQUNGLE1BQU0sQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLGdCQUFnQixDQUFDLGNBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNsRSxNQUFNLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxnQkFBZ0IsQ0FBQyxjQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7QUFFbkUsaUZBQWlGO0FBQ2pGLElBQUksdUJBQVMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztBQUNuRSw2RUFBNkUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIFN0YWNrLCBDZm5PdXRwdXQgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBQb3J0LCBWcGMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IE1hbmFnZWRQb2xpY3ksIFJvbGUsIFNlcnZpY2VQcmluY2lwYWwgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IEdpdGxhYkNvbnRhaW5lclJ1bm5lciB9IGZyb20gJy4vaW5kZXgnO1xuY29uc3QgZW52ID0ge1xuICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTixcbiAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcbn07XG5jb25zdCBtb2NrQXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2sobW9ja0FwcCwgJ3Rlc3Rpbmctc3RhY2snLCB7IGVudiB9KTtcbmNvbnN0IHJvbGUgPSBuZXcgUm9sZShzdGFjaywgJ3J1bm5lci1yb2xlJywge1xuICBhc3N1bWVkQnk6IG5ldyBTZXJ2aWNlUHJpbmNpcGFsKCdlYzIuYW1hem9uYXdzLmNvbScpLFxuICBkZXNjcmlwdGlvbjogJ0ZvciBHaXRsYWIgRUMyIFJ1bm5lciBUZXN0IFJvbGUnLFxuICByb2xlTmFtZTogJ1Rlc3RSb2xlJyxcbn0pO1xuXG5jb25zdCB2cGMgPSBWcGMuZnJvbUxvb2t1cChzdGFjaywgJ2RlZmF1bHRWcGMnLCB7XG4gIGlzRGVmYXVsdDogdHJ1ZSxcbn0pO1xuY29uc3QgcnVubmVyID0gbmV3IEdpdGxhYkNvbnRhaW5lclJ1bm5lcihzdGFjaywgJ3Rlc3RpbmcnLCB7XG4gIGdpdGxhYnRva2VuOiBzdGFjay5ub2RlLnRyeUdldENvbnRleHQoJ0dJVExBQl9UT0tFTicpID8/ICdnbHJ0LUdJVExBQl9UT0tFTicsXG4gIGVjMnR5cGU6ICd0My5sYXJnZScsXG4gIGVjMmlhbXJvbGU6IHJvbGUsXG4gIGVic1NpemU6IDEwMCxcbiAgc2VsZnZwYzogdnBjLFxuICBzcG90RmxlZXQ6IHRydWUsXG4gIGRvY2tlclZvbHVtZXM6IFtcbiAgICB7XG4gICAgICBob3N0UGF0aDogJy90bXAvY2FoY2UnLFxuICAgICAgY29udGFpbmVyUGF0aDogJy90bXAvY2FoY2UnLFxuICAgIH0sXG4gIF0sXG4gIGdpdGxhYlJ1bm5lclZlcnNpb246ICcxNS4xMCcsXG59KTtcblxuLy9ydW5uZXIuZXhwaXJlQWZ0ZXIoRHVyYXRpb24uaG91cnMoMSkpO1xucnVubmVyLnJ1bm5lclJvbGUuYWRkTWFuYWdlZFBvbGljeShcbiAgTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoJ0FtYXpvblMzUmVhZE9ubHlBY2Nlc3MnKSxcbik7XG5ydW5uZXIuZGVmYXVsdFJ1bm5lclNHLmNvbm5lY3Rpb25zLmFsbG93RnJvbUFueUlwdjQoUG9ydC50Y3AoODApKTtcbnJ1bm5lci5kZWZhdWx0UnVubmVyU0cuY29ubmVjdGlvbnMuYWxsb3dGcm9tQW55SXB2NChQb3J0LnRjcCg0NDMpKTtcblxuLy9ydW5uZXIucnVubmVyRWMyLmNvbm5lY3Rpb25zLmFsbG93RnJvbShQZWVyLmlwdjQoJzAuMC4wLjAvMCcpLCBQb3J0LnRjcCg4MDgwKSk7XG5uZXcgQ2ZuT3V0cHV0KHN0YWNrLCAncm9sZScsIHsgdmFsdWU6IHJ1bm5lci5ydW5uZXJSb2xlLnJvbGVBcm4gfSk7XG4vL25ldyBDZm5PdXRwdXQoc3RhY2ssICdJbnN0YW5jZUlEJywgeyB2YWx1ZTogcnVubmVyLnJ1bm5lckVjMi5pbnN0YW5jZUlkIH0pO1xuIl19
@@ -32,6 +32,7 @@ const runner = new gitlab_runner_autoscaling_1.GitlabRunnerAutoscaling(stack, 'T
32
32
  Threshold: 50,
33
33
  },
34
34
  ],
35
+ gitlabRunnerVersion: '15.10',
35
36
  });
36
37
  /**
37
38
  * Scheduled scaling
@@ -48,4 +49,4 @@ runner.autoscalingGroup.scaleOnSchedule('WorkOnWeekdays', {
48
49
  maxCapacity: defaultCapacity,
49
50
  });
50
51
  new aws_cdk_lib_1.CfnOutput(stack, 'role', { value: runner.instanceRole.roleArn });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZ2l0bGFiLXJ1bm5lci1hdXRvc2NhbGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9pbnRlZy5naXRsYWItcnVubmVyLWF1dG9zY2FsaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsNkNBQW9EO0FBQ3BELG1EQUFtRDtBQUNuRCwyQ0FBMkM7QUFDM0MsMkVBQXNFO0FBRXRFLE1BQU0sR0FBRyxHQUFHO0lBQ1YsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO0lBQ3RDLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtDQUN6QyxDQUFDO0FBRUYsTUFBTSxHQUFHLEdBQUcsSUFBSSxpQkFBRyxFQUFFLENBQUM7QUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxDQUFDLEdBQUcsRUFBRSxzQkFBc0IsRUFBRSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7QUFFOUQsTUFBTSxHQUFHLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtJQUNsRCxTQUFTLEVBQUUsSUFBSTtDQUNoQixDQUFDLENBQUM7QUFDSCxNQUFNLGVBQWUsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUN2RSxNQUFNLE1BQU0sR0FBRyxJQUFJLG1EQUF1QixDQUFDLEtBQUssRUFBRSx1QkFBdUIsRUFBRTtJQUN6RSxXQUFXLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDO0lBQ3JELE9BQU8sRUFBRSxFQUFFO0lBQ1gsR0FBRyxFQUFFLEdBQUc7SUFDUixhQUFhLEVBQUUsQ0FBQztZQUNkLFFBQVEsRUFBRSxZQUFZO1lBQ3RCLGFBQWEsRUFBRSxZQUFZO1NBQzVCLENBQUM7SUFDRixXQUFXLEVBQUUsZUFBZTtJQUM1QixXQUFXLEVBQUUsZUFBZTtJQUM1QixZQUFZLEVBQUUsSUFBSTtJQUNsQixNQUFNLEVBQUU7UUFDTjtZQUNFLFNBQVMsRUFBRSx1QkFBdUI7WUFDbEMsVUFBVSxFQUFFLG1CQUFtQjtZQUMvQixTQUFTLEVBQUUsRUFBRTtTQUNkO0tBQ0Y7Q0FDRixDQUFDLENBQUM7QUFFSDs7O0dBR0c7QUFDSCxNQUFNLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLGdCQUFnQixFQUFFO0lBQ3hELFFBQVEsRUFBRSxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLENBQUM7SUFDeEUsV0FBVyxFQUFFLENBQUM7SUFDZCxXQUFXLEVBQUUsQ0FBQztDQUNmLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsZ0JBQWdCLEVBQUU7SUFDeEQsUUFBUSxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQztJQUN2RSxXQUFXLEVBQUUsZUFBZTtJQUM1QixXQUFXLEVBQUUsZUFBZTtDQUM3QixDQUFDLENBQUM7QUFHSCxJQUFJLHVCQUFTLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIFN0YWNrLCBDZm5PdXRwdXQgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBhc2cgZnJvbSAnYXdzLWNkay1saWIvYXdzLWF1dG9zY2FsaW5nJztcbmltcG9ydCAqIGFzIGVjMiBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IEdpdGxhYlJ1bm5lckF1dG9zY2FsaW5nIH0gZnJvbSAnLi9naXRsYWItcnVubmVyLWF1dG9zY2FsaW5nJztcblxuY29uc3QgZW52ID0ge1xuICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTixcbiAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcbn07XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ1Rlc3RTdGFja0F1dG9zY2FsaW5nJywgeyBlbnYgfSk7XG5cbmNvbnN0IHZwYyA9IGVjMi5WcGMuZnJvbUxvb2t1cChzdGFjaywgJ0RlZmF1bHRWcGMnLCB7XG4gIGlzRGVmYXVsdDogdHJ1ZSxcbn0pO1xuY29uc3QgZGVmYXVsdENhcGFjaXR5ID0gcGFyc2VJbnQoc3RhY2subm9kZS50cnlHZXRDb250ZXh0KCdDQVBBQ0lUWScpKTtcbmNvbnN0IHJ1bm5lciA9IG5ldyBHaXRsYWJSdW5uZXJBdXRvc2NhbGluZyhzdGFjaywgJ1Rlc3RSdW5uZXJBdXRvc2NhbGluZycsIHtcbiAgZ2l0bGFiVG9rZW46IHN0YWNrLm5vZGUudHJ5R2V0Q29udGV4dCgnR0lUTEFCX1RPS0VOJyksXG4gIGVic1NpemU6IDEwLFxuICB2cGM6IHZwYyxcbiAgZG9ja2VyVm9sdW1lczogW3tcbiAgICBob3N0UGF0aDogJy90bXAvY2FjaGUnLFxuICAgIGNvbnRhaW5lclBhdGg6ICcvdG1wL2NhY2hlJyxcbiAgfV0sXG4gIG1pbkNhcGFjaXR5OiBkZWZhdWx0Q2FwYWNpdHksXG4gIG1heENhcGFjaXR5OiBkZWZhdWx0Q2FwYWNpdHksXG4gIHNwb3RJbnN0YW5jZTogdHJ1ZSxcbiAgYWxhcm1zOiBbXG4gICAge1xuICAgICAgQWxhcm1OYW1lOiAnR2l0bGFiUnVubmVyRGlza1VzYWdlJyxcbiAgICAgIE1ldHJpY05hbWU6ICdkaXNrX3VzZWRfcGVyY2VudCcsXG4gICAgICBUaHJlc2hvbGQ6IDUwLFxuICAgIH0sXG4gIF0sXG59KTtcblxuLyoqXG4gKiBTY2hlZHVsZWQgc2NhbGluZ1xuICogaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2Nkay9hcGkvbGF0ZXN0L2RvY3MvYXdzLWF1dG9zY2FsaW5nLXJlYWRtZS5odG1sI3NjaGVkdWxlZC1zY2FsaW5nXG4gKi9cbnJ1bm5lci5hdXRvc2NhbGluZ0dyb3VwLnNjYWxlT25TY2hlZHVsZSgnU3RvcE9uV2Vla2VuZHMnLCB7XG4gIHNjaGVkdWxlOiBhc2cuU2NoZWR1bGUuY3Jvbih7IHdlZWtEYXk6ICdmcmknLCBob3VyOiAnMTgnLCBtaW51dGU6ICcwJyB9KSxcbiAgbWluQ2FwYWNpdHk6IDAsXG4gIG1heENhcGFjaXR5OiAwLFxufSk7XG5cbnJ1bm5lci5hdXRvc2NhbGluZ0dyb3VwLnNjYWxlT25TY2hlZHVsZSgnV29ya09uV2Vla2RheXMnLCB7XG4gIHNjaGVkdWxlOiBhc2cuU2NoZWR1bGUuY3Jvbih7IHdlZWtEYXk6ICdtb24nLCBob3VyOiAnOScsIG1pbnV0ZTogJzAnIH0pLFxuICBtaW5DYXBhY2l0eTogZGVmYXVsdENhcGFjaXR5LFxuICBtYXhDYXBhY2l0eTogZGVmYXVsdENhcGFjaXR5LFxufSk7XG5cblxubmV3IENmbk91dHB1dChzdGFjaywgJ3JvbGUnLCB7IHZhbHVlOiBydW5uZXIuaW5zdGFuY2VSb2xlLnJvbGVBcm4gfSk7XG4iXX0=
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZ2l0bGFiLXJ1bm5lci1hdXRvc2NhbGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9pbnRlZy5naXRsYWItcnVubmVyLWF1dG9zY2FsaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsNkNBQW9EO0FBQ3BELG1EQUFtRDtBQUNuRCwyQ0FBMkM7QUFDM0MsMkVBQXNFO0FBRXRFLE1BQU0sR0FBRyxHQUFHO0lBQ1YsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO0lBQ3RDLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtDQUN6QyxDQUFDO0FBRUYsTUFBTSxHQUFHLEdBQUcsSUFBSSxpQkFBRyxFQUFFLENBQUM7QUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxDQUFDLEdBQUcsRUFBRSxzQkFBc0IsRUFBRSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7QUFFOUQsTUFBTSxHQUFHLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtJQUNsRCxTQUFTLEVBQUUsSUFBSTtDQUNoQixDQUFDLENBQUM7QUFDSCxNQUFNLGVBQWUsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUN2RSxNQUFNLE1BQU0sR0FBRyxJQUFJLG1EQUF1QixDQUFDLEtBQUssRUFBRSx1QkFBdUIsRUFBRTtJQUN6RSxXQUFXLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDO0lBQ3JELE9BQU8sRUFBRSxFQUFFO0lBQ1gsR0FBRyxFQUFFLEdBQUc7SUFDUixhQUFhLEVBQUUsQ0FBQztZQUNkLFFBQVEsRUFBRSxZQUFZO1lBQ3RCLGFBQWEsRUFBRSxZQUFZO1NBQzVCLENBQUM7SUFDRixXQUFXLEVBQUUsZUFBZTtJQUM1QixXQUFXLEVBQUUsZUFBZTtJQUM1QixZQUFZLEVBQUUsSUFBSTtJQUNsQixNQUFNLEVBQUU7UUFDTjtZQUNFLFNBQVMsRUFBRSx1QkFBdUI7WUFDbEMsVUFBVSxFQUFFLG1CQUFtQjtZQUMvQixTQUFTLEVBQUUsRUFBRTtTQUNkO0tBQ0Y7SUFDRCxtQkFBbUIsRUFBRSxPQUFPO0NBQzdCLENBQUMsQ0FBQztBQUVIOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsZ0JBQWdCLEVBQUU7SUFDeEQsUUFBUSxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQztJQUN4RSxXQUFXLEVBQUUsQ0FBQztJQUNkLFdBQVcsRUFBRSxDQUFDO0NBQ2YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxnQkFBZ0IsRUFBRTtJQUN4RCxRQUFRLEVBQUUsR0FBRyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDO0lBQ3ZFLFdBQVcsRUFBRSxlQUFlO0lBQzVCLFdBQVcsRUFBRSxlQUFlO0NBQzdCLENBQUMsQ0FBQztBQUdILElBQUksdUJBQVMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcCwgU3RhY2ssIENmbk91dHB1dCB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGFzZyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtYXV0b3NjYWxpbmcnO1xuaW1wb3J0ICogYXMgZWMyIGZyb20gJ2F3cy1jZGstbGliL2F3cy1lYzInO1xuaW1wb3J0IHsgR2l0bGFiUnVubmVyQXV0b3NjYWxpbmcgfSBmcm9tICcuL2dpdGxhYi1ydW5uZXItYXV0b3NjYWxpbmcnO1xuXG5jb25zdCBlbnYgPSB7XG4gIHJlZ2lvbjogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfUkVHSU9OLFxuICBhY2NvdW50OiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9BQ0NPVU5ULFxufTtcblxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCAnVGVzdFN0YWNrQXV0b3NjYWxpbmcnLCB7IGVudiB9KTtcblxuY29uc3QgdnBjID0gZWMyLlZwYy5mcm9tTG9va3VwKHN0YWNrLCAnRGVmYXVsdFZwYycsIHtcbiAgaXNEZWZhdWx0OiB0cnVlLFxufSk7XG5jb25zdCBkZWZhdWx0Q2FwYWNpdHkgPSBwYXJzZUludChzdGFjay5ub2RlLnRyeUdldENvbnRleHQoJ0NBUEFDSVRZJykpO1xuY29uc3QgcnVubmVyID0gbmV3IEdpdGxhYlJ1bm5lckF1dG9zY2FsaW5nKHN0YWNrLCAnVGVzdFJ1bm5lckF1dG9zY2FsaW5nJywge1xuICBnaXRsYWJUb2tlbjogc3RhY2subm9kZS50cnlHZXRDb250ZXh0KCdHSVRMQUJfVE9LRU4nKSxcbiAgZWJzU2l6ZTogMTAsXG4gIHZwYzogdnBjLFxuICBkb2NrZXJWb2x1bWVzOiBbe1xuICAgIGhvc3RQYXRoOiAnL3RtcC9jYWNoZScsXG4gICAgY29udGFpbmVyUGF0aDogJy90bXAvY2FjaGUnLFxuICB9XSxcbiAgbWluQ2FwYWNpdHk6IGRlZmF1bHRDYXBhY2l0eSxcbiAgbWF4Q2FwYWNpdHk6IGRlZmF1bHRDYXBhY2l0eSxcbiAgc3BvdEluc3RhbmNlOiB0cnVlLFxuICBhbGFybXM6IFtcbiAgICB7XG4gICAgICBBbGFybU5hbWU6ICdHaXRsYWJSdW5uZXJEaXNrVXNhZ2UnLFxuICAgICAgTWV0cmljTmFtZTogJ2Rpc2tfdXNlZF9wZXJjZW50JyxcbiAgICAgIFRocmVzaG9sZDogNTAsXG4gICAgfSxcbiAgXSxcbiAgZ2l0bGFiUnVubmVyVmVyc2lvbjogJzE1LjEwJyxcbn0pO1xuXG4vKipcbiAqIFNjaGVkdWxlZCBzY2FsaW5nXG4gKiBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vY2RrL2FwaS9sYXRlc3QvZG9jcy9hd3MtYXV0b3NjYWxpbmctcmVhZG1lLmh0bWwjc2NoZWR1bGVkLXNjYWxpbmdcbiAqL1xucnVubmVyLmF1dG9zY2FsaW5nR3JvdXAuc2NhbGVPblNjaGVkdWxlKCdTdG9wT25XZWVrZW5kcycsIHtcbiAgc2NoZWR1bGU6IGFzZy5TY2hlZHVsZS5jcm9uKHsgd2Vla0RheTogJ2ZyaScsIGhvdXI6ICcxOCcsIG1pbnV0ZTogJzAnIH0pLFxuICBtaW5DYXBhY2l0eTogMCxcbiAgbWF4Q2FwYWNpdHk6IDAsXG59KTtcblxucnVubmVyLmF1dG9zY2FsaW5nR3JvdXAuc2NhbGVPblNjaGVkdWxlKCdXb3JrT25XZWVrZGF5cycsIHtcbiAgc2NoZWR1bGU6IGFzZy5TY2hlZHVsZS5jcm9uKHsgd2Vla0RheTogJ21vbicsIGhvdXI6ICc5JywgbWludXRlOiAnMCcgfSksXG4gIG1pbkNhcGFjaXR5OiBkZWZhdWx0Q2FwYWNpdHksXG4gIG1heENhcGFjaXR5OiBkZWZhdWx0Q2FwYWNpdHksXG59KTtcblxuXG5uZXcgQ2ZuT3V0cHV0KHN0YWNrLCAncm9sZScsIHsgdmFsdWU6IHJ1bm5lci5pbnN0YW5jZVJvbGUucm9sZUFybiB9KTtcbiJdfQ==
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2015-2021 Ole Michelsen
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,133 @@
1
+ # compare-versions
2
+
3
+ ![Build Status](https://github.com/omichelsen/compare-versions/actions/workflows/ci.yml/badge.svg)
4
+ [![Coverage Status](https://coveralls.io/repos/omichelsen/compare-versions/badge.svg?branch=master&service=github)](https://coveralls.io/github/omichelsen/compare-versions?branch=master)
5
+ [![npm bundle size (minified + gzip)](https://img.shields.io/bundlephobia/minzip/compare-versions.svg)](https://bundlephobia.com/result?p=compare-versions)
6
+
7
+ Compare [semver](https://semver.org/) version strings to find greater, equal or lesser. Runs in the browser as well as Node.js/React Native etc. Has no dependencies and is tiny.
8
+
9
+ Supports the full semver specification including versions with different number of digits like `1.0.0`, `1.0`, `1` and pre-releases like `1.0.0-alpha`. Additionally supports the following variations:
10
+
11
+ - Wildcards for minor and patch version like `1.0.x` or `1.0.*`.
12
+ - [Chromium version numbers](https://www.chromium.org/developers/version-numbers) with 4 parts, e.g. version `25.0.1364.126`.
13
+ - Any leading `v` is ignored, e.g. `v1.0` is interpreted as `1.0`.
14
+ - Leading zero is ignored, e.g. `1.01.1` is interpreted as `1.1.1`.
15
+ - [npm version ranges](https://docs.npmjs.com/cli/v6/using-npm/semver#ranges), e.g. `1.2.7 || >=1.2.9 <2.0.0`
16
+
17
+ ## Install
18
+
19
+ ```bash
20
+ $ npm install compare-versions
21
+ ```
22
+
23
+ __Note__: Starting from v5 the main export is now _named_ like so: `import { compareVersions } from 'compare-versions'`.
24
+
25
+ __Note__: Starting from v4 this library includes a ESM version which will automatically be selected by your bundler (webpack, parcel etc). The CJS/UMD version is `lib/umd/index.js` and the new ESM version is `lib/esm/index.js`.
26
+
27
+ ## Usage
28
+
29
+ Will return `1` if first version is greater, `0` if versions are equal, and `-1` if the second version is greater:
30
+
31
+ ```js
32
+ import { compareVersions } from 'compare-versions';
33
+
34
+ compareVersions('11.1.1', '10.0.0'); // 1
35
+ compareVersions('10.0.0', '10.0.0'); // 0
36
+ compareVersions('10.0.0', '11.1.1'); // -1
37
+ ```
38
+
39
+ Can also be used for sorting:
40
+
41
+ ```js
42
+ const versions = [
43
+ '1.5.19',
44
+ '1.2.3',
45
+ '1.5.5'
46
+ ]
47
+ const sorted = versions.sort(compareVersions);
48
+ /*
49
+ [
50
+ '1.2.3',
51
+ '1.5.5',
52
+ '1.5.19'
53
+ ]
54
+ */
55
+ ```
56
+
57
+ ### "Human Readable" Compare
58
+
59
+ The alternative `compare` function accepts an operator which will be more familiar to humans:
60
+
61
+ ```js
62
+ import { compare } from 'compare-versions';
63
+
64
+ compare('10.1.8', '10.0.4', '>'); // true
65
+ compare('10.0.1', '10.0.1', '='); // true
66
+ compare('10.1.1', '10.2.2', '<'); // true
67
+ compare('10.1.1', '10.2.2', '<='); // true
68
+ compare('10.1.1', '10.2.2', '>='); // false
69
+ ```
70
+
71
+ ### Version ranges
72
+
73
+ The `satisfies` function accepts a range to compare, compatible with [npm package versioning](https://docs.npmjs.com/cli/v6/using-npm/semver):
74
+
75
+ ```js
76
+ import { satisfies } from 'compare-versions';
77
+
78
+ satisfies('10.0.1', '~10.0.0'); // true
79
+ satisfies('10.1.0', '~10.0.0'); // false
80
+ satisfies('10.1.2', '^10.0.0'); // true
81
+ satisfies('11.0.0', '^10.0.0'); // false
82
+ satisfies('10.1.8', '>10.0.4'); // true
83
+ satisfies('10.0.1', '=10.0.1'); // true
84
+ satisfies('10.1.1', '<10.2.2'); // true
85
+ satisfies('10.1.1', '<=10.2.2'); // true
86
+ satisfies('10.1.1', '>=10.2.2'); // false
87
+ satisfies('1.4.6', '1.2.7 || >=1.2.9 <2.0.0'); // true
88
+ satisfies('1.2.8', '1.2.7 || >=1.2.9 <2.0.0'); // false
89
+ satisfies('1.5.1', '1.2.3 - 2.3.4'); // true
90
+ satisfies('2.3.5', '1.2.3 - 2.3.4'); // false
91
+ ```
92
+
93
+ ### Validate version numbers
94
+
95
+ Applies the same rules used comparing version numbers and returns a boolean:
96
+
97
+ ```js
98
+ import { validate } from 'compare-versions';
99
+
100
+ validate('1.0.0-rc.1'); // true
101
+ validate('1.0-rc.1'); // false
102
+ validate('foo'); // false
103
+ ```
104
+
105
+ ### Validate version numbers (strict)
106
+
107
+ Validate version numbers strictly according to semver.org; 3 integers, no wildcards, no leading zero or "v" etc:
108
+
109
+ ```js
110
+ import { validateStrict } from 'compare-versions';
111
+
112
+ validate('1.0.0'); // true
113
+ validate('1.0.0-rc.1'); // true
114
+ validate('1.0'); // false
115
+ validate('1.x'); // false
116
+ validate('v1.02'); // false
117
+ ```
118
+
119
+ ### Browser
120
+
121
+ If included directly in the browser, the functions above are available on the global window under the `compareVersions` object:
122
+
123
+ ```html
124
+ <script src=https://unpkg.com/compare-versions/lib/umd/index.js></script>
125
+ <script>
126
+ const { compareVersions, compare, satisfies, validate } = window.compareVersions
127
+ console.log(compareVersions('11.0.0', '10.0.0'))
128
+ console.log(compare('11.0.0', '10.0.0', '>'))
129
+ console.log(satisfies('1.2.0', '^1.0.0'))
130
+ console.log(validate('11.0.0'))
131
+ console.log(validateStrict('11.0.0'))
132
+ </script>
133
+ ```
@@ -0,0 +1,19 @@
1
+ import { CompareOperator } from './utils';
2
+ /**
3
+ * Compare [semver](https://semver.org/) version strings using the specified operator.
4
+ *
5
+ * @param v1 First version to compare
6
+ * @param v2 Second version to compare
7
+ * @param operator Allowed arithmetic operator to use
8
+ * @returns `true` if the comparison between the firstVersion and the secondVersion satisfies the operator, `false` otherwise.
9
+ *
10
+ * @example
11
+ * ```
12
+ * compare('10.1.8', '10.0.4', '>'); // return true
13
+ * compare('10.0.1', '10.0.1', '='); // return true
14
+ * compare('10.1.1', '10.2.2', '<'); // return true
15
+ * compare('10.1.1', '10.2.2', '<='); // return true
16
+ * compare('10.1.1', '10.2.2', '>='); // return false
17
+ * ```
18
+ */
19
+ export declare const compare: (v1: string, v2: string, operator: CompareOperator) => boolean;
@@ -0,0 +1,44 @@
1
+ import { compareVersions } from './compareVersions';
2
+ /**
3
+ * Compare [semver](https://semver.org/) version strings using the specified operator.
4
+ *
5
+ * @param v1 First version to compare
6
+ * @param v2 Second version to compare
7
+ * @param operator Allowed arithmetic operator to use
8
+ * @returns `true` if the comparison between the firstVersion and the secondVersion satisfies the operator, `false` otherwise.
9
+ *
10
+ * @example
11
+ * ```
12
+ * compare('10.1.8', '10.0.4', '>'); // return true
13
+ * compare('10.0.1', '10.0.1', '='); // return true
14
+ * compare('10.1.1', '10.2.2', '<'); // return true
15
+ * compare('10.1.1', '10.2.2', '<='); // return true
16
+ * compare('10.1.1', '10.2.2', '>='); // return false
17
+ * ```
18
+ */
19
+ export const compare = (v1, v2, operator) => {
20
+ // validate input operator
21
+ assertValidOperator(operator);
22
+ // since result of compareVersions can only be -1 or 0 or 1
23
+ // a simple map can be used to replace switch
24
+ const res = compareVersions(v1, v2);
25
+ return operatorResMap[operator].includes(res);
26
+ };
27
+ const operatorResMap = {
28
+ '>': [1],
29
+ '>=': [0, 1],
30
+ '=': [0],
31
+ '<=': [-1, 0],
32
+ '<': [-1],
33
+ '!=': [-1, 1],
34
+ };
35
+ const allowedOperators = Object.keys(operatorResMap);
36
+ const assertValidOperator = (op) => {
37
+ if (typeof op !== 'string') {
38
+ throw new TypeError(`Invalid operator type, expected string but got ${typeof op}`);
39
+ }
40
+ if (allowedOperators.indexOf(op) === -1) {
41
+ throw new Error(`Invalid operator, expected one of ${allowedOperators.join('|')}`);
42
+ }
43
+ };
44
+ //# sourceMappingURL=compare.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compare.js","sourceRoot":"","sources":["../../src/compare.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGpD;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,EAAU,EAAE,EAAU,EAAE,QAAyB,EAAE,EAAE;IAC3E,0BAA0B;IAC1B,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IAE9B,2DAA2D;IAC3D,6CAA6C;IAC7C,MAAM,GAAG,GAAG,eAAe,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IAEpC,OAAO,cAAc,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AAChD,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG;IACrB,GAAG,EAAE,CAAC,CAAC,CAAC;IACR,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IACZ,GAAG,EAAE,CAAC,CAAC,CAAC;IACR,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACb,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;IACT,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;CACd,CAAC;AAEF,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;AAErD,MAAM,mBAAmB,GAAG,CAAC,EAAU,EAAE,EAAE;IACzC,IAAI,OAAO,EAAE,KAAK,QAAQ,EAAE;QAC1B,MAAM,IAAI,SAAS,CACjB,kDAAkD,OAAO,EAAE,EAAE,CAC9D,CAAC;KACH;IACD,IAAI,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE;QACvC,MAAM,IAAI,KAAK,CACb,qCAAqC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAClE,CAAC;KACH;AACH,CAAC,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Compare [semver](https://semver.org/) version strings to find greater, equal or lesser.
3
+ * This library supports the full semver specification, including comparing versions with different number of digits like `1.0.0`, `1.0`, `1`, and pre-release versions like `1.0.0-alpha`.
4
+ * @param v1 - First version to compare
5
+ * @param v2 - Second version to compare
6
+ * @returns Numeric value compatible with the [Array.sort(fn) interface](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#Parameters).
7
+ */
8
+ export declare const compareVersions: (v1: string, v2: string) => 0 | 1 | -1;
@@ -0,0 +1,29 @@
1
+ import { compareSegments, validateAndParse } from './utils';
2
+ /**
3
+ * Compare [semver](https://semver.org/) version strings to find greater, equal or lesser.
4
+ * This library supports the full semver specification, including comparing versions with different number of digits like `1.0.0`, `1.0`, `1`, and pre-release versions like `1.0.0-alpha`.
5
+ * @param v1 - First version to compare
6
+ * @param v2 - Second version to compare
7
+ * @returns Numeric value compatible with the [Array.sort(fn) interface](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#Parameters).
8
+ */
9
+ export const compareVersions = (v1, v2) => {
10
+ // validate input and split into segments
11
+ const n1 = validateAndParse(v1);
12
+ const n2 = validateAndParse(v2);
13
+ // pop off the patch
14
+ const p1 = n1.pop();
15
+ const p2 = n2.pop();
16
+ // validate numbers
17
+ const r = compareSegments(n1, n2);
18
+ if (r !== 0)
19
+ return r;
20
+ // validate pre-release
21
+ if (p1 && p2) {
22
+ return compareSegments(p1.split('.'), p2.split('.'));
23
+ }
24
+ else if (p1 || p2) {
25
+ return p1 ? -1 : 1;
26
+ }
27
+ return 0;
28
+ };
29
+ //# sourceMappingURL=compareVersions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compareVersions.js","sourceRoot":"","sources":["../../src/compareVersions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE5D;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAU,EAAE,EAAU,EAAE,EAAE;IACxD,yCAAyC;IACzC,MAAM,EAAE,GAAG,gBAAgB,CAAC,EAAE,CAAC,CAAC;IAChC,MAAM,EAAE,GAAG,gBAAgB,CAAC,EAAE,CAAC,CAAC;IAEhC,oBAAoB;IACpB,MAAM,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;IACpB,MAAM,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;IAEpB,mBAAmB;IACnB,MAAM,CAAC,GAAG,eAAe,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IAClC,IAAI,CAAC,KAAK,CAAC;QAAE,OAAO,CAAC,CAAC;IAEtB,uBAAuB;IACvB,IAAI,EAAE,IAAI,EAAE,EAAE;QACZ,OAAO,eAAe,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;KACtD;SAAM,IAAI,EAAE,IAAI,EAAE,EAAE;QACnB,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KACpB;IAED,OAAO,CAAC,CAAC;AACX,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { compare } from './compare';
2
+ export { compareVersions } from './compareVersions';
3
+ export { satisfies } from './satisfies';
4
+ export { CompareOperator } from './utils';
5
+ export { validate, validateStrict } from './validate';
@@ -0,0 +1,5 @@
1
+ export { compare } from './compare';
2
+ export { compareVersions } from './compareVersions';
3
+ export { satisfies } from './satisfies';
4
+ export { validate, validateStrict } from './validate';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Match [npm semver](https://docs.npmjs.com/cli/v6/using-npm/semver) version range.
3
+ *
4
+ * @param version Version number to match
5
+ * @param range Range pattern for version
6
+ * @returns `true` if the version number is within the range, `false` otherwise.
7
+ *
8
+ * @example
9
+ * ```
10
+ * satisfies('1.1.0', '^1.0.0'); // return true
11
+ * satisfies('1.1.0', '~1.0.0'); // return false
12
+ * ```
13
+ */
14
+ export declare const satisfies: (version: string, range: string) => boolean;