cdk-gitlab-runner 2.1.182 → 2.1.183
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +505 -11
- package/API.md +1 -1
- package/README.md +1 -1
- package/lib/gitlab-runner-autoscaling.d.ts +2 -2
- package/lib/gitlab-runner-autoscaling.js +4 -8
- package/lib/gitlab-runner-instance.d.ts +1 -1
- package/lib/gitlab-runner-instance.js +5 -9
- package/package.json +3 -3
package/.jsii
CHANGED
|
@@ -7,10 +7,88 @@
|
|
|
7
7
|
]
|
|
8
8
|
},
|
|
9
9
|
"dependencies": {
|
|
10
|
-
"aws-cdk-lib": "^2.
|
|
10
|
+
"aws-cdk-lib": "^2.76.0",
|
|
11
11
|
"constructs": "^10.0.5"
|
|
12
12
|
},
|
|
13
13
|
"dependencyClosure": {
|
|
14
|
+
"@aws-cdk/asset-awscli-v1": {
|
|
15
|
+
"targets": {
|
|
16
|
+
"dotnet": {
|
|
17
|
+
"namespace": "Amazon.CDK.Asset.AwsCliV1",
|
|
18
|
+
"packageId": "Amazon.CDK.Asset.AwsCliV1"
|
|
19
|
+
},
|
|
20
|
+
"go": {
|
|
21
|
+
"moduleName": "github.com/cdklabs/awscdk-asset-awscli-go",
|
|
22
|
+
"packageName": "awscliv1"
|
|
23
|
+
},
|
|
24
|
+
"java": {
|
|
25
|
+
"maven": {
|
|
26
|
+
"artifactId": "cdk-asset-awscli-v1",
|
|
27
|
+
"groupId": "software.amazon.awscdk"
|
|
28
|
+
},
|
|
29
|
+
"package": "software.amazon.awscdk.cdk.asset.awscli.v1"
|
|
30
|
+
},
|
|
31
|
+
"js": {
|
|
32
|
+
"npm": "@aws-cdk/asset-awscli-v1"
|
|
33
|
+
},
|
|
34
|
+
"python": {
|
|
35
|
+
"distName": "aws-cdk.asset-awscli-v1",
|
|
36
|
+
"module": "aws_cdk.asset_awscli_v1"
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
"@aws-cdk/asset-kubectl-v20": {
|
|
41
|
+
"targets": {
|
|
42
|
+
"dotnet": {
|
|
43
|
+
"namespace": "Amazon.CDK.Asset.KubectlV20",
|
|
44
|
+
"packageId": "Amazon.CDK.Asset.KubectlV20"
|
|
45
|
+
},
|
|
46
|
+
"go": {
|
|
47
|
+
"moduleName": "github.com/cdklabs/awscdk-asset-kubectl-go",
|
|
48
|
+
"packageName": "kubectlv20"
|
|
49
|
+
},
|
|
50
|
+
"java": {
|
|
51
|
+
"maven": {
|
|
52
|
+
"artifactId": "cdk-asset-kubectl-v20",
|
|
53
|
+
"groupId": "software.amazon.awscdk"
|
|
54
|
+
},
|
|
55
|
+
"package": "software.amazon.awscdk.cdk.asset.kubectl.v20"
|
|
56
|
+
},
|
|
57
|
+
"js": {
|
|
58
|
+
"npm": "@aws-cdk/asset-kubectl-v20"
|
|
59
|
+
},
|
|
60
|
+
"python": {
|
|
61
|
+
"distName": "aws-cdk.asset-kubectl-v20",
|
|
62
|
+
"module": "aws_cdk.asset_kubectl_v20"
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
"@aws-cdk/asset-node-proxy-agent-v5": {
|
|
67
|
+
"targets": {
|
|
68
|
+
"dotnet": {
|
|
69
|
+
"namespace": "Amazon.CDK.Asset.NodeProxyAgentV5",
|
|
70
|
+
"packageId": "Amazon.CDK.Asset.NodeProxyAgentV5"
|
|
71
|
+
},
|
|
72
|
+
"go": {
|
|
73
|
+
"moduleName": "github.com/cdklabs/awscdk-asset-node-proxy-agent-go",
|
|
74
|
+
"packageName": "nodeproxyagentv5"
|
|
75
|
+
},
|
|
76
|
+
"java": {
|
|
77
|
+
"maven": {
|
|
78
|
+
"artifactId": "cdk-asset-node-proxy-agent-v5",
|
|
79
|
+
"groupId": "software.amazon.awscdk"
|
|
80
|
+
},
|
|
81
|
+
"package": "software.amazon.awscdk.cdk.asset.node.proxy.agent.v5"
|
|
82
|
+
},
|
|
83
|
+
"js": {
|
|
84
|
+
"npm": "@aws-cdk/asset-node-proxy-agent-v5"
|
|
85
|
+
},
|
|
86
|
+
"python": {
|
|
87
|
+
"distName": "aws-cdk.asset-node-proxy-agent-v5",
|
|
88
|
+
"module": "aws_cdk.asset_node_proxy_agent_v5"
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
},
|
|
14
92
|
"aws-cdk-lib": {
|
|
15
93
|
"submodules": {
|
|
16
94
|
"aws-cdk-lib.alexa_ask": {
|
|
@@ -377,6 +455,19 @@
|
|
|
377
455
|
}
|
|
378
456
|
}
|
|
379
457
|
},
|
|
458
|
+
"aws-cdk-lib.aws_billingconductor": {
|
|
459
|
+
"targets": {
|
|
460
|
+
"dotnet": {
|
|
461
|
+
"namespace": "Amazon.CDK.AWS.BillingConductor"
|
|
462
|
+
},
|
|
463
|
+
"java": {
|
|
464
|
+
"package": "software.amazon.awscdk.services.billingconductor"
|
|
465
|
+
},
|
|
466
|
+
"python": {
|
|
467
|
+
"module": "aws_cdk.aws_billingconductor"
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
},
|
|
380
471
|
"aws-cdk-lib.aws_budgets": {
|
|
381
472
|
"targets": {
|
|
382
473
|
"dotnet": {
|
|
@@ -690,6 +781,19 @@
|
|
|
690
781
|
}
|
|
691
782
|
}
|
|
692
783
|
},
|
|
784
|
+
"aws-cdk-lib.aws_comprehend": {
|
|
785
|
+
"targets": {
|
|
786
|
+
"dotnet": {
|
|
787
|
+
"namespace": "Amazon.CDK.AWS.Comprehend"
|
|
788
|
+
},
|
|
789
|
+
"java": {
|
|
790
|
+
"package": "software.amazon.awscdk.services.comprehend"
|
|
791
|
+
},
|
|
792
|
+
"python": {
|
|
793
|
+
"module": "aws_cdk.aws_comprehend"
|
|
794
|
+
}
|
|
795
|
+
}
|
|
796
|
+
},
|
|
693
797
|
"aws-cdk-lib.aws_config": {
|
|
694
798
|
"targets": {
|
|
695
799
|
"dotnet": {
|
|
@@ -716,6 +820,32 @@
|
|
|
716
820
|
}
|
|
717
821
|
}
|
|
718
822
|
},
|
|
823
|
+
"aws-cdk-lib.aws_connectcampaigns": {
|
|
824
|
+
"targets": {
|
|
825
|
+
"dotnet": {
|
|
826
|
+
"namespace": "Amazon.CDK.AWS.ConnectCampaigns"
|
|
827
|
+
},
|
|
828
|
+
"java": {
|
|
829
|
+
"package": "software.amazon.awscdk.services.connectcampaigns"
|
|
830
|
+
},
|
|
831
|
+
"python": {
|
|
832
|
+
"module": "aws_cdk.aws_connectcampaigns"
|
|
833
|
+
}
|
|
834
|
+
}
|
|
835
|
+
},
|
|
836
|
+
"aws-cdk-lib.aws_controltower": {
|
|
837
|
+
"targets": {
|
|
838
|
+
"dotnet": {
|
|
839
|
+
"namespace": "Amazon.CDK.AWS.ControlTower"
|
|
840
|
+
},
|
|
841
|
+
"java": {
|
|
842
|
+
"package": "software.amazon.awscdk.services.controltower"
|
|
843
|
+
},
|
|
844
|
+
"python": {
|
|
845
|
+
"module": "aws_cdk.aws_controltower"
|
|
846
|
+
}
|
|
847
|
+
}
|
|
848
|
+
},
|
|
719
849
|
"aws-cdk-lib.aws_cur": {
|
|
720
850
|
"targets": {
|
|
721
851
|
"dotnet": {
|
|
@@ -807,6 +937,19 @@
|
|
|
807
937
|
}
|
|
808
938
|
}
|
|
809
939
|
},
|
|
940
|
+
"aws-cdk-lib.aws_devicefarm": {
|
|
941
|
+
"targets": {
|
|
942
|
+
"dotnet": {
|
|
943
|
+
"namespace": "Amazon.CDK.AWS.DeviceFarm"
|
|
944
|
+
},
|
|
945
|
+
"java": {
|
|
946
|
+
"package": "software.amazon.awscdk.services.devicefarm"
|
|
947
|
+
},
|
|
948
|
+
"python": {
|
|
949
|
+
"module": "aws_cdk.aws_devicefarm"
|
|
950
|
+
}
|
|
951
|
+
}
|
|
952
|
+
},
|
|
810
953
|
"aws-cdk-lib.aws_devopsguru": {
|
|
811
954
|
"targets": {
|
|
812
955
|
"dotnet": {
|
|
@@ -872,6 +1015,19 @@
|
|
|
872
1015
|
}
|
|
873
1016
|
}
|
|
874
1017
|
},
|
|
1018
|
+
"aws-cdk-lib.aws_docdbelastic": {
|
|
1019
|
+
"targets": {
|
|
1020
|
+
"dotnet": {
|
|
1021
|
+
"namespace": "Amazon.CDK.AWS.DocDBElastic"
|
|
1022
|
+
},
|
|
1023
|
+
"java": {
|
|
1024
|
+
"package": "software.amazon.awscdk.services.docdbelastic"
|
|
1025
|
+
},
|
|
1026
|
+
"python": {
|
|
1027
|
+
"module": "aws_cdk.aws_docdbelastic"
|
|
1028
|
+
}
|
|
1029
|
+
}
|
|
1030
|
+
},
|
|
875
1031
|
"aws-cdk-lib.aws_dynamodb": {
|
|
876
1032
|
"targets": {
|
|
877
1033
|
"dotnet": {
|
|
@@ -1093,6 +1249,19 @@
|
|
|
1093
1249
|
}
|
|
1094
1250
|
}
|
|
1095
1251
|
},
|
|
1252
|
+
"aws-cdk-lib.aws_emrserverless": {
|
|
1253
|
+
"targets": {
|
|
1254
|
+
"dotnet": {
|
|
1255
|
+
"namespace": "Amazon.CDK.AWS.EMRServerless"
|
|
1256
|
+
},
|
|
1257
|
+
"java": {
|
|
1258
|
+
"package": "software.amazon.awscdk.services.emrserverless"
|
|
1259
|
+
},
|
|
1260
|
+
"python": {
|
|
1261
|
+
"module": "aws_cdk.aws_emrserverless"
|
|
1262
|
+
}
|
|
1263
|
+
}
|
|
1264
|
+
},
|
|
1096
1265
|
"aws-cdk-lib.aws_events": {
|
|
1097
1266
|
"targets": {
|
|
1098
1267
|
"dotnet": {
|
|
@@ -1275,6 +1444,19 @@
|
|
|
1275
1444
|
}
|
|
1276
1445
|
}
|
|
1277
1446
|
},
|
|
1447
|
+
"aws-cdk-lib.aws_grafana": {
|
|
1448
|
+
"targets": {
|
|
1449
|
+
"dotnet": {
|
|
1450
|
+
"namespace": "Amazon.CDK.AWS.Grafana"
|
|
1451
|
+
},
|
|
1452
|
+
"java": {
|
|
1453
|
+
"package": "software.amazon.awscdk.services.grafana"
|
|
1454
|
+
},
|
|
1455
|
+
"python": {
|
|
1456
|
+
"module": "aws_cdk.aws_grafana"
|
|
1457
|
+
}
|
|
1458
|
+
}
|
|
1459
|
+
},
|
|
1278
1460
|
"aws-cdk-lib.aws_greengrass": {
|
|
1279
1461
|
"targets": {
|
|
1280
1462
|
"dotnet": {
|
|
@@ -1353,6 +1535,19 @@
|
|
|
1353
1535
|
}
|
|
1354
1536
|
}
|
|
1355
1537
|
},
|
|
1538
|
+
"aws-cdk-lib.aws_identitystore": {
|
|
1539
|
+
"targets": {
|
|
1540
|
+
"dotnet": {
|
|
1541
|
+
"namespace": "Amazon.CDK.AWS.IdentityStore"
|
|
1542
|
+
},
|
|
1543
|
+
"java": {
|
|
1544
|
+
"package": "software.amazon.awscdk.services.identitystore"
|
|
1545
|
+
},
|
|
1546
|
+
"python": {
|
|
1547
|
+
"module": "aws_cdk.aws_identitystore"
|
|
1548
|
+
}
|
|
1549
|
+
}
|
|
1550
|
+
},
|
|
1356
1551
|
"aws-cdk-lib.aws_imagebuilder": {
|
|
1357
1552
|
"targets": {
|
|
1358
1553
|
"dotnet": {
|
|
@@ -1392,6 +1587,19 @@
|
|
|
1392
1587
|
}
|
|
1393
1588
|
}
|
|
1394
1589
|
},
|
|
1590
|
+
"aws-cdk-lib.aws_internetmonitor": {
|
|
1591
|
+
"targets": {
|
|
1592
|
+
"dotnet": {
|
|
1593
|
+
"namespace": "Amazon.CDK.AWS.InternetMonitor"
|
|
1594
|
+
},
|
|
1595
|
+
"java": {
|
|
1596
|
+
"package": "software.amazon.awscdk.services.internetmonitor"
|
|
1597
|
+
},
|
|
1598
|
+
"python": {
|
|
1599
|
+
"module": "aws_cdk.aws_internetmonitor"
|
|
1600
|
+
}
|
|
1601
|
+
}
|
|
1602
|
+
},
|
|
1395
1603
|
"aws-cdk-lib.aws_iot": {
|
|
1396
1604
|
"targets": {
|
|
1397
1605
|
"dotnet": {
|
|
@@ -1470,6 +1678,19 @@
|
|
|
1470
1678
|
}
|
|
1471
1679
|
}
|
|
1472
1680
|
},
|
|
1681
|
+
"aws-cdk-lib.aws_iotfleetwise": {
|
|
1682
|
+
"targets": {
|
|
1683
|
+
"dotnet": {
|
|
1684
|
+
"namespace": "Amazon.CDK.AWS.IoTFleetWise"
|
|
1685
|
+
},
|
|
1686
|
+
"java": {
|
|
1687
|
+
"package": "software.amazon.awscdk.services.iotfleetwise"
|
|
1688
|
+
},
|
|
1689
|
+
"python": {
|
|
1690
|
+
"module": "aws_cdk.aws_iotfleetwise"
|
|
1691
|
+
}
|
|
1692
|
+
}
|
|
1693
|
+
},
|
|
1473
1694
|
"aws-cdk-lib.aws_iotsitewise": {
|
|
1474
1695
|
"targets": {
|
|
1475
1696
|
"dotnet": {
|
|
@@ -1496,6 +1717,19 @@
|
|
|
1496
1717
|
}
|
|
1497
1718
|
}
|
|
1498
1719
|
},
|
|
1720
|
+
"aws-cdk-lib.aws_iottwinmaker": {
|
|
1721
|
+
"targets": {
|
|
1722
|
+
"dotnet": {
|
|
1723
|
+
"namespace": "Amazon.CDK.AWS.IoTTwinMaker"
|
|
1724
|
+
},
|
|
1725
|
+
"java": {
|
|
1726
|
+
"package": "software.amazon.awscdk.services.iottwinmaker"
|
|
1727
|
+
},
|
|
1728
|
+
"python": {
|
|
1729
|
+
"module": "aws_cdk.aws_iottwinmaker"
|
|
1730
|
+
}
|
|
1731
|
+
}
|
|
1732
|
+
},
|
|
1499
1733
|
"aws-cdk-lib.aws_iotwireless": {
|
|
1500
1734
|
"targets": {
|
|
1501
1735
|
"dotnet": {
|
|
@@ -1522,6 +1756,19 @@
|
|
|
1522
1756
|
}
|
|
1523
1757
|
}
|
|
1524
1758
|
},
|
|
1759
|
+
"aws-cdk-lib.aws_ivschat": {
|
|
1760
|
+
"targets": {
|
|
1761
|
+
"dotnet": {
|
|
1762
|
+
"namespace": "Amazon.CDK.AWS.IVSChat"
|
|
1763
|
+
},
|
|
1764
|
+
"java": {
|
|
1765
|
+
"package": "software.amazon.awscdk.services.ivschat"
|
|
1766
|
+
},
|
|
1767
|
+
"python": {
|
|
1768
|
+
"module": "aws_cdk.aws_ivschat"
|
|
1769
|
+
}
|
|
1770
|
+
}
|
|
1771
|
+
},
|
|
1525
1772
|
"aws-cdk-lib.aws_kafkaconnect": {
|
|
1526
1773
|
"targets": {
|
|
1527
1774
|
"dotnet": {
|
|
@@ -1548,6 +1795,19 @@
|
|
|
1548
1795
|
}
|
|
1549
1796
|
}
|
|
1550
1797
|
},
|
|
1798
|
+
"aws-cdk-lib.aws_kendraranking": {
|
|
1799
|
+
"targets": {
|
|
1800
|
+
"dotnet": {
|
|
1801
|
+
"namespace": "Amazon.CDK.AWS.KendraRanking"
|
|
1802
|
+
},
|
|
1803
|
+
"java": {
|
|
1804
|
+
"package": "software.amazon.awscdk.services.kendraranking"
|
|
1805
|
+
},
|
|
1806
|
+
"python": {
|
|
1807
|
+
"module": "aws_cdk.aws_kendraranking"
|
|
1808
|
+
}
|
|
1809
|
+
}
|
|
1810
|
+
},
|
|
1551
1811
|
"aws-cdk-lib.aws_kinesis": {
|
|
1552
1812
|
"targets": {
|
|
1553
1813
|
"dotnet": {
|
|
@@ -1808,6 +2068,19 @@
|
|
|
1808
2068
|
}
|
|
1809
2069
|
}
|
|
1810
2070
|
},
|
|
2071
|
+
"aws-cdk-lib.aws_m2": {
|
|
2072
|
+
"targets": {
|
|
2073
|
+
"dotnet": {
|
|
2074
|
+
"namespace": "Amazon.CDK.AWS.M2"
|
|
2075
|
+
},
|
|
2076
|
+
"java": {
|
|
2077
|
+
"package": "software.amazon.awscdk.services.m2"
|
|
2078
|
+
},
|
|
2079
|
+
"python": {
|
|
2080
|
+
"module": "aws_cdk.aws_m2"
|
|
2081
|
+
}
|
|
2082
|
+
}
|
|
2083
|
+
},
|
|
1811
2084
|
"aws-cdk-lib.aws_macie": {
|
|
1812
2085
|
"targets": {
|
|
1813
2086
|
"dotnet": {
|
|
@@ -1899,6 +2172,19 @@
|
|
|
1899
2172
|
}
|
|
1900
2173
|
}
|
|
1901
2174
|
},
|
|
2175
|
+
"aws-cdk-lib.aws_mediatailor": {
|
|
2176
|
+
"targets": {
|
|
2177
|
+
"dotnet": {
|
|
2178
|
+
"namespace": "Amazon.CDK.AWS.MediaTailor"
|
|
2179
|
+
},
|
|
2180
|
+
"java": {
|
|
2181
|
+
"package": "software.amazon.awscdk.services.mediatailor"
|
|
2182
|
+
},
|
|
2183
|
+
"python": {
|
|
2184
|
+
"module": "aws_cdk.aws_mediatailor"
|
|
2185
|
+
}
|
|
2186
|
+
}
|
|
2187
|
+
},
|
|
1902
2188
|
"aws-cdk-lib.aws_memorydb": {
|
|
1903
2189
|
"targets": {
|
|
1904
2190
|
"dotnet": {
|
|
@@ -1990,6 +2276,45 @@
|
|
|
1990
2276
|
}
|
|
1991
2277
|
}
|
|
1992
2278
|
},
|
|
2279
|
+
"aws-cdk-lib.aws_oam": {
|
|
2280
|
+
"targets": {
|
|
2281
|
+
"dotnet": {
|
|
2282
|
+
"namespace": "Amazon.CDK.AWS.Oam"
|
|
2283
|
+
},
|
|
2284
|
+
"java": {
|
|
2285
|
+
"package": "software.amazon.awscdk.services.oam"
|
|
2286
|
+
},
|
|
2287
|
+
"python": {
|
|
2288
|
+
"module": "aws_cdk.aws_oam"
|
|
2289
|
+
}
|
|
2290
|
+
}
|
|
2291
|
+
},
|
|
2292
|
+
"aws-cdk-lib.aws_omics": {
|
|
2293
|
+
"targets": {
|
|
2294
|
+
"dotnet": {
|
|
2295
|
+
"namespace": "Amazon.CDK.AWS.Omics"
|
|
2296
|
+
},
|
|
2297
|
+
"java": {
|
|
2298
|
+
"package": "software.amazon.awscdk.services.omics"
|
|
2299
|
+
},
|
|
2300
|
+
"python": {
|
|
2301
|
+
"module": "aws_cdk.aws_omics"
|
|
2302
|
+
}
|
|
2303
|
+
}
|
|
2304
|
+
},
|
|
2305
|
+
"aws-cdk-lib.aws_opensearchserverless": {
|
|
2306
|
+
"targets": {
|
|
2307
|
+
"dotnet": {
|
|
2308
|
+
"namespace": "Amazon.CDK.AWS.OpenSearchServerless"
|
|
2309
|
+
},
|
|
2310
|
+
"java": {
|
|
2311
|
+
"package": "software.amazon.awscdk.services.opensearchserverless"
|
|
2312
|
+
},
|
|
2313
|
+
"python": {
|
|
2314
|
+
"module": "aws_cdk.aws_opensearchserverless"
|
|
2315
|
+
}
|
|
2316
|
+
}
|
|
2317
|
+
},
|
|
1993
2318
|
"aws-cdk-lib.aws_opensearchservice": {
|
|
1994
2319
|
"targets": {
|
|
1995
2320
|
"dotnet": {
|
|
@@ -2029,6 +2354,19 @@
|
|
|
2029
2354
|
}
|
|
2030
2355
|
}
|
|
2031
2356
|
},
|
|
2357
|
+
"aws-cdk-lib.aws_organizations": {
|
|
2358
|
+
"targets": {
|
|
2359
|
+
"dotnet": {
|
|
2360
|
+
"namespace": "Amazon.CDK.AWS.Organizations"
|
|
2361
|
+
},
|
|
2362
|
+
"java": {
|
|
2363
|
+
"package": "software.amazon.awscdk.services.organizations"
|
|
2364
|
+
},
|
|
2365
|
+
"python": {
|
|
2366
|
+
"module": "aws_cdk.aws_organizations"
|
|
2367
|
+
}
|
|
2368
|
+
}
|
|
2369
|
+
},
|
|
2032
2370
|
"aws-cdk-lib.aws_panorama": {
|
|
2033
2371
|
"targets": {
|
|
2034
2372
|
"dotnet": {
|
|
@@ -2042,6 +2380,19 @@
|
|
|
2042
2380
|
}
|
|
2043
2381
|
}
|
|
2044
2382
|
},
|
|
2383
|
+
"aws-cdk-lib.aws_personalize": {
|
|
2384
|
+
"targets": {
|
|
2385
|
+
"dotnet": {
|
|
2386
|
+
"namespace": "Amazon.CDK.AWS.Personalize"
|
|
2387
|
+
},
|
|
2388
|
+
"java": {
|
|
2389
|
+
"package": "software.amazon.awscdk.services.personalize"
|
|
2390
|
+
},
|
|
2391
|
+
"python": {
|
|
2392
|
+
"module": "aws_cdk.aws_personalize"
|
|
2393
|
+
}
|
|
2394
|
+
}
|
|
2395
|
+
},
|
|
2045
2396
|
"aws-cdk-lib.aws_pinpoint": {
|
|
2046
2397
|
"targets": {
|
|
2047
2398
|
"dotnet": {
|
|
@@ -2068,6 +2419,19 @@
|
|
|
2068
2419
|
}
|
|
2069
2420
|
}
|
|
2070
2421
|
},
|
|
2422
|
+
"aws-cdk-lib.aws_pipes": {
|
|
2423
|
+
"targets": {
|
|
2424
|
+
"dotnet": {
|
|
2425
|
+
"namespace": "Amazon.CDK.AWS.Pipes"
|
|
2426
|
+
},
|
|
2427
|
+
"java": {
|
|
2428
|
+
"package": "software.amazon.awscdk.services.pipes"
|
|
2429
|
+
},
|
|
2430
|
+
"python": {
|
|
2431
|
+
"module": "aws_cdk.aws_pipes"
|
|
2432
|
+
}
|
|
2433
|
+
}
|
|
2434
|
+
},
|
|
2071
2435
|
"aws-cdk-lib.aws_qldb": {
|
|
2072
2436
|
"targets": {
|
|
2073
2437
|
"dotnet": {
|
|
@@ -2133,6 +2497,19 @@
|
|
|
2133
2497
|
}
|
|
2134
2498
|
}
|
|
2135
2499
|
},
|
|
2500
|
+
"aws-cdk-lib.aws_redshiftserverless": {
|
|
2501
|
+
"targets": {
|
|
2502
|
+
"dotnet": {
|
|
2503
|
+
"namespace": "Amazon.CDK.AWS.RedshiftServerless"
|
|
2504
|
+
},
|
|
2505
|
+
"java": {
|
|
2506
|
+
"package": "software.amazon.awscdk.services.redshiftserverless"
|
|
2507
|
+
},
|
|
2508
|
+
"python": {
|
|
2509
|
+
"module": "aws_cdk.aws_redshiftserverless"
|
|
2510
|
+
}
|
|
2511
|
+
}
|
|
2512
|
+
},
|
|
2136
2513
|
"aws-cdk-lib.aws_refactorspaces": {
|
|
2137
2514
|
"targets": {
|
|
2138
2515
|
"dotnet": {
|
|
@@ -2172,6 +2549,19 @@
|
|
|
2172
2549
|
}
|
|
2173
2550
|
}
|
|
2174
2551
|
},
|
|
2552
|
+
"aws-cdk-lib.aws_resourceexplorer2": {
|
|
2553
|
+
"targets": {
|
|
2554
|
+
"dotnet": {
|
|
2555
|
+
"namespace": "Amazon.CDK.AWS.ResourceExplorer2"
|
|
2556
|
+
},
|
|
2557
|
+
"java": {
|
|
2558
|
+
"package": "software.amazon.awscdk.services.resourceexplorer2"
|
|
2559
|
+
},
|
|
2560
|
+
"python": {
|
|
2561
|
+
"module": "aws_cdk.aws_resourceexplorer2"
|
|
2562
|
+
}
|
|
2563
|
+
}
|
|
2564
|
+
},
|
|
2175
2565
|
"aws-cdk-lib.aws_resourcegroups": {
|
|
2176
2566
|
"targets": {
|
|
2177
2567
|
"dotnet": {
|
|
@@ -2198,6 +2588,19 @@
|
|
|
2198
2588
|
}
|
|
2199
2589
|
}
|
|
2200
2590
|
},
|
|
2591
|
+
"aws-cdk-lib.aws_rolesanywhere": {
|
|
2592
|
+
"targets": {
|
|
2593
|
+
"dotnet": {
|
|
2594
|
+
"namespace": "Amazon.CDK.AWS.RolesAnywhere"
|
|
2595
|
+
},
|
|
2596
|
+
"java": {
|
|
2597
|
+
"package": "software.amazon.awscdk.services.rolesanywhere"
|
|
2598
|
+
},
|
|
2599
|
+
"python": {
|
|
2600
|
+
"module": "aws_cdk.aws_rolesanywhere"
|
|
2601
|
+
}
|
|
2602
|
+
}
|
|
2603
|
+
},
|
|
2201
2604
|
"aws-cdk-lib.aws_route53": {
|
|
2202
2605
|
"targets": {
|
|
2203
2606
|
"dotnet": {
|
|
@@ -2393,6 +2796,19 @@
|
|
|
2393
2796
|
}
|
|
2394
2797
|
}
|
|
2395
2798
|
},
|
|
2799
|
+
"aws-cdk-lib.aws_scheduler": {
|
|
2800
|
+
"targets": {
|
|
2801
|
+
"dotnet": {
|
|
2802
|
+
"namespace": "Amazon.CDK.AWS.Scheduler"
|
|
2803
|
+
},
|
|
2804
|
+
"java": {
|
|
2805
|
+
"package": "software.amazon.awscdk.services.scheduler"
|
|
2806
|
+
},
|
|
2807
|
+
"python": {
|
|
2808
|
+
"module": "aws_cdk.aws_scheduler"
|
|
2809
|
+
}
|
|
2810
|
+
}
|
|
2811
|
+
},
|
|
2396
2812
|
"aws-cdk-lib.aws_sdb": {
|
|
2397
2813
|
"targets": {
|
|
2398
2814
|
"dotnet": {
|
|
@@ -2510,6 +2926,19 @@
|
|
|
2510
2926
|
}
|
|
2511
2927
|
}
|
|
2512
2928
|
},
|
|
2929
|
+
"aws-cdk-lib.aws_simspaceweaver": {
|
|
2930
|
+
"targets": {
|
|
2931
|
+
"dotnet": {
|
|
2932
|
+
"namespace": "Amazon.CDK.AWS.SimSpaceWeaver"
|
|
2933
|
+
},
|
|
2934
|
+
"java": {
|
|
2935
|
+
"package": "software.amazon.awscdk.services.simspaceweaver"
|
|
2936
|
+
},
|
|
2937
|
+
"python": {
|
|
2938
|
+
"module": "aws_cdk.aws_simspaceweaver"
|
|
2939
|
+
}
|
|
2940
|
+
}
|
|
2941
|
+
},
|
|
2513
2942
|
"aws-cdk-lib.aws_sns": {
|
|
2514
2943
|
"targets": {
|
|
2515
2944
|
"dotnet": {
|
|
@@ -2627,6 +3056,19 @@
|
|
|
2627
3056
|
}
|
|
2628
3057
|
}
|
|
2629
3058
|
},
|
|
3059
|
+
"aws-cdk-lib.aws_supportapp": {
|
|
3060
|
+
"targets": {
|
|
3061
|
+
"dotnet": {
|
|
3062
|
+
"namespace": "Amazon.CDK.AWS.SupportApp"
|
|
3063
|
+
},
|
|
3064
|
+
"java": {
|
|
3065
|
+
"package": "software.amazon.awscdk.services.supportapp"
|
|
3066
|
+
},
|
|
3067
|
+
"python": {
|
|
3068
|
+
"module": "aws_cdk.aws_supportapp"
|
|
3069
|
+
}
|
|
3070
|
+
}
|
|
3071
|
+
},
|
|
2630
3072
|
"aws-cdk-lib.aws_synthetics": {
|
|
2631
3073
|
"targets": {
|
|
2632
3074
|
"dotnet": {
|
|
@@ -2640,6 +3082,19 @@
|
|
|
2640
3082
|
}
|
|
2641
3083
|
}
|
|
2642
3084
|
},
|
|
3085
|
+
"aws-cdk-lib.aws_systemsmanagersap": {
|
|
3086
|
+
"targets": {
|
|
3087
|
+
"dotnet": {
|
|
3088
|
+
"namespace": "Amazon.CDK.AWS.SystemsManagerSAP"
|
|
3089
|
+
},
|
|
3090
|
+
"java": {
|
|
3091
|
+
"package": "software.amazon.awscdk.services.systemsmanagersap"
|
|
3092
|
+
},
|
|
3093
|
+
"python": {
|
|
3094
|
+
"module": "aws_cdk.aws_systemsmanagersap"
|
|
3095
|
+
}
|
|
3096
|
+
}
|
|
3097
|
+
},
|
|
2643
3098
|
"aws-cdk-lib.aws_timestream": {
|
|
2644
3099
|
"targets": {
|
|
2645
3100
|
"dotnet": {
|
|
@@ -2666,6 +3121,32 @@
|
|
|
2666
3121
|
}
|
|
2667
3122
|
}
|
|
2668
3123
|
},
|
|
3124
|
+
"aws-cdk-lib.aws_voiceid": {
|
|
3125
|
+
"targets": {
|
|
3126
|
+
"dotnet": {
|
|
3127
|
+
"namespace": "Amazon.CDK.AWS.VoiceID"
|
|
3128
|
+
},
|
|
3129
|
+
"java": {
|
|
3130
|
+
"package": "software.amazon.awscdk.services.voiceid"
|
|
3131
|
+
},
|
|
3132
|
+
"python": {
|
|
3133
|
+
"module": "aws_cdk.aws_voiceid"
|
|
3134
|
+
}
|
|
3135
|
+
}
|
|
3136
|
+
},
|
|
3137
|
+
"aws-cdk-lib.aws_vpclattice": {
|
|
3138
|
+
"targets": {
|
|
3139
|
+
"dotnet": {
|
|
3140
|
+
"namespace": "Amazon.CDK.AWS.VpcLattice"
|
|
3141
|
+
},
|
|
3142
|
+
"java": {
|
|
3143
|
+
"package": "software.amazon.awscdk.services.vpclattice"
|
|
3144
|
+
},
|
|
3145
|
+
"python": {
|
|
3146
|
+
"module": "aws_cdk.aws_vpclattice"
|
|
3147
|
+
}
|
|
3148
|
+
}
|
|
3149
|
+
},
|
|
2669
3150
|
"aws-cdk-lib.aws_waf": {
|
|
2670
3151
|
"targets": {
|
|
2671
3152
|
"dotnet": {
|
|
@@ -2860,11 +3341,24 @@
|
|
|
2860
3341
|
"module": "aws_cdk.region_info"
|
|
2861
3342
|
}
|
|
2862
3343
|
}
|
|
3344
|
+
},
|
|
3345
|
+
"aws-cdk-lib.triggers": {
|
|
3346
|
+
"targets": {
|
|
3347
|
+
"dotnet": {
|
|
3348
|
+
"namespace": "Amazon.CDK.Triggers"
|
|
3349
|
+
},
|
|
3350
|
+
"java": {
|
|
3351
|
+
"package": "software.amazon.awscdk.triggers"
|
|
3352
|
+
},
|
|
3353
|
+
"python": {
|
|
3354
|
+
"module": "aws_cdk.triggers"
|
|
3355
|
+
}
|
|
3356
|
+
}
|
|
2863
3357
|
}
|
|
2864
3358
|
},
|
|
2865
3359
|
"targets": {
|
|
2866
3360
|
"dotnet": {
|
|
2867
|
-
"iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/
|
|
3361
|
+
"iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png",
|
|
2868
3362
|
"namespace": "Amazon.CDK",
|
|
2869
3363
|
"packageId": "Amazon.CDK.Lib"
|
|
2870
3364
|
},
|
|
@@ -2937,7 +3431,7 @@
|
|
|
2937
3431
|
},
|
|
2938
3432
|
"name": "cdk-gitlab-runner",
|
|
2939
3433
|
"readme": {
|
|
2940
|
-
"markdown": "[](https://badge.fury.io/js/cdk-gitlab-runner)\n[](https://badge.fury.io/py/cdk-gitlab-runner)\n\n\n\n\n\n\n\n\n\n\n\n# Welcome to `cdk-gitlab-runner`\nUse AWS CDK to create gitlab runner, and use [gitlab runner](https://gitlab.com/gitlab-org/gitlab-runner) to help you execute your Gitlab Pipeline Job.\n> GitLab Runner is the open source project that is used to run your CI/CD jobs and send the results back to GitLab. [(source repo)](https://gitlab.com/gitlab-org/gitlab-runner)\n\n## Why\nGitlab provides [400 minutes per month for each free user](https://about.gitlab.com/pricing/), hosted Gitlab Runner to execute your gitlab pipeline job.That's pretty good and users don't need to manage gitlab runner. If it is just a simple ci job for test 400, it may be enough.\nBut what if you want to deploy to your AWS production environment through pipeline job?\nIs there any security consideration for using the hosted gitlab runner?!\n\nBut creating Gitlab Runner is not that simple, so I created this OSS so that you can quickly create Gitlab Runner and delete your Gitlab Runner via AWS CDK.\nIt will be used with AWS IAM Role, so you don't need to put AKSK in Gitlab environment variables.\n\n\n\n\n## Note\n### Default will help you generate below services:\n\n- VPC\n - Public Subnet (2)\n- EC2 (1 T3.micro)\n\n## Before start you need gitlab runner token in your `gitlab project` or `gitlab group`\n\n### In Group\n\nGroup > Settings > CI/CD\n\n\n### In Project\n\nProject > Settings > CI/CD > Runners\n\n\n## Usage\n\nReplace your gitlab runner token in `$GITLABTOKEN`\n\n## Install\nUse the npm dist tag to opt in CDKv1 or CDKv2:\n```bash\n// for CDKv2\nnpm install cdk-gitlab-runner\nor\nnpm install cdk-gitlab-runner@latest\n\n// for CDKv1\nnpm install cdk-gitlab-runner@cdkv1\n```\n\n## 💡💡💡 please click [here](https://github.com/neilkuan/cdk-gitlab-runner/tree/cdkv1#readme), if you are using aws-cdk v1.x.x version.💡💡💡\n\n### Instance Type\n\n```typescript\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\n// If want change instance type to t3.large .\nnew GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '$GITLABTOKEN', ec2type:'t3.large' });\n// OR\n// Just create a gitlab runner , by default instance type is t3.micro .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\nnew GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '$GITLABTOKEN' });})\n```\n\n### Gitlab Server Customize Url .\n\nIf you want change what you want tag name .\n\n```typescript\n// If you want change what your self Gitlab Server Url .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\nnew GitlabContainerRunner(this, 'runner-instance-change-tag', {\n gitlabtoken: '$GITLABTOKEN',\n gitlaburl: 'https://gitlab.my.com/',\n});\n```\n\n### Tags\n\nIf you want change what you want tag name .\n\n```typescript\n// If you want change what you want tag name .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\nnew GitlabContainerRunner(this, 'runner-instance-change-tag', {\n gitlabtoken: '$GITLABTOKEN',\n tags: ['aa', 'bb', 'cc'],\n});\n```\n\n### IAM Policy\n\nIf you want add runner other IAM Policy like s3-readonly-access.\n\n```typescript\n// If you want add runner other IAM Policy like s3-readonly-access.\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\nimport { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\n\nconst runner = new GitlabContainerRunner(this, 'runner-instance-add-policy', {\n gitlabtoken: '$GITLABTOKEN',\n tags: ['aa', 'bb', 'cc'],\n});\nrunner.runnerRole.addManagedPolicy(\n ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n);\n```\n\n### Security Group\n\nIf you want add runner other SG Ingress .\n\n```typescript\n// If you want add runner other SG Ingress .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\nimport { Port, Peer } from 'aws-cdk-lib/aws-ec2';\n\nconst runner = new GitlabContainerRunner(this, 'runner-add-SG-ingress', {\n gitlabtoken: 'GITLABTOKEN',\n tags: ['aa', 'bb', 'cc'],\n});\n\n// you can add ingress in your runner SG .\nrunner.defaultRunnerSG.connections.allowFrom(\n Peer.ipv4('0.0.0.0/0'),\n Port.tcp(80),\n);\n```\n\n### Use self VPC\n\n> 2020/06/27 , you can use your self exist VPC or new VPC , but please check your `vpc public Subnet` Auto-assign public IPv4 address must be Yes ,or `vpc private Subnet` route table associated `nat gateway` .\n\n```typescript\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\nimport { Port, Peer, Vpc, SubnetType } from 'aws-cdk-lib/aws-ec2';\nimport { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\n\nconst newvpc = new Vpc(stack, 'VPC', {\n
|
|
3434
|
+
"markdown": "[](https://badge.fury.io/js/cdk-gitlab-runner)\n[](https://badge.fury.io/py/cdk-gitlab-runner)\n\n\n\n\n\n\n\n\n\n\n\n# Welcome to `cdk-gitlab-runner`\nUse AWS CDK to create gitlab runner, and use [gitlab runner](https://gitlab.com/gitlab-org/gitlab-runner) to help you execute your Gitlab Pipeline Job.\n> GitLab Runner is the open source project that is used to run your CI/CD jobs and send the results back to GitLab. [(source repo)](https://gitlab.com/gitlab-org/gitlab-runner)\n\n## Why\nGitlab provides [400 minutes per month for each free user](https://about.gitlab.com/pricing/), hosted Gitlab Runner to execute your gitlab pipeline job.That's pretty good and users don't need to manage gitlab runner. If it is just a simple ci job for test 400, it may be enough.\nBut what if you want to deploy to your AWS production environment through pipeline job?\nIs there any security consideration for using the hosted gitlab runner?!\n\nBut creating Gitlab Runner is not that simple, so I created this OSS so that you can quickly create Gitlab Runner and delete your Gitlab Runner via AWS CDK.\nIt will be used with AWS IAM Role, so you don't need to put AKSK in Gitlab environment variables.\n\n\n\n\n## Note\n### Default will help you generate below services:\n\n- VPC\n - Public Subnet (2)\n- EC2 (1 T3.micro)\n\n## Before start you need gitlab runner token in your `gitlab project` or `gitlab group`\n\n### In Group\n\nGroup > Settings > CI/CD\n\n\n### In Project\n\nProject > Settings > CI/CD > Runners\n\n\n## Usage\n\nReplace your gitlab runner token in `$GITLABTOKEN`\n\n## Install\nUse the npm dist tag to opt in CDKv1 or CDKv2:\n```bash\n// for CDKv2\nnpm install cdk-gitlab-runner\nor\nnpm install cdk-gitlab-runner@latest\n\n// for CDKv1\nnpm install cdk-gitlab-runner@cdkv1\n```\n\n## 💡💡💡 please click [here](https://github.com/neilkuan/cdk-gitlab-runner/tree/cdkv1#readme), if you are using aws-cdk v1.x.x version.💡💡💡\n\n### Instance Type\n\n```typescript\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\n// If want change instance type to t3.large .\nnew GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '$GITLABTOKEN', ec2type:'t3.large' });\n// OR\n// Just create a gitlab runner , by default instance type is t3.micro .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\nnew GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '$GITLABTOKEN' });})\n```\n\n### Gitlab Server Customize Url .\n\nIf you want change what you want tag name .\n\n```typescript\n// If you want change what your self Gitlab Server Url .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\nnew GitlabContainerRunner(this, 'runner-instance-change-tag', {\n gitlabtoken: '$GITLABTOKEN',\n gitlaburl: 'https://gitlab.my.com/',\n});\n```\n\n### Tags\n\nIf you want change what you want tag name .\n\n```typescript\n// If you want change what you want tag name .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\nnew GitlabContainerRunner(this, 'runner-instance-change-tag', {\n gitlabtoken: '$GITLABTOKEN',\n tags: ['aa', 'bb', 'cc'],\n});\n```\n\n### IAM Policy\n\nIf you want add runner other IAM Policy like s3-readonly-access.\n\n```typescript\n// If you want add runner other IAM Policy like s3-readonly-access.\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\nimport { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\n\nconst runner = new GitlabContainerRunner(this, 'runner-instance-add-policy', {\n gitlabtoken: '$GITLABTOKEN',\n tags: ['aa', 'bb', 'cc'],\n});\nrunner.runnerRole.addManagedPolicy(\n ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n);\n```\n\n### Security Group\n\nIf you want add runner other SG Ingress .\n\n```typescript\n// If you want add runner other SG Ingress .\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\nimport { Port, Peer } from 'aws-cdk-lib/aws-ec2';\n\nconst runner = new GitlabContainerRunner(this, 'runner-add-SG-ingress', {\n gitlabtoken: 'GITLABTOKEN',\n tags: ['aa', 'bb', 'cc'],\n});\n\n// you can add ingress in your runner SG .\nrunner.defaultRunnerSG.connections.allowFrom(\n Peer.ipv4('0.0.0.0/0'),\n Port.tcp(80),\n);\n```\n\n### Use self VPC\n\n> 2020/06/27 , you can use your self exist VPC or new VPC , but please check your `vpc public Subnet` Auto-assign public IPv4 address must be Yes ,or `vpc private Subnet` route table associated `nat gateway` .\n\n```typescript\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\nimport { Port, Peer, Vpc, SubnetType } from 'aws-cdk-lib/aws-ec2';\nimport { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\n\nconst newvpc = new Vpc(stack, '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\nconst runner = new GitlabContainerRunner(this, 'testing', {\n gitlabtoken: '$GITLABTOKEN',\n ec2type: 't3.small',\n selfvpc: newvpc,\n});\n```\n\n### Use your self exist role\n\n> 2020/06/27 , you can use your self exist role assign to runner\n\n```typescript\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\nimport { Port, Peer } from 'aws-cdk-lib/aws-ec2';\nimport { ManagedPolicy, Role, ServicePrincipal } from 'aws-cdk-lib/aws-iam';\n\nconst role = new Role(this, 'runner-role', {\n assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n description: 'For Gitlab EC2 Runner Test Role',\n roleName: 'TestRole',\n});\n\nconst runner = new GitlabContainerRunner(stack, 'testing', {\n gitlabtoken: '$GITLAB_TOKEN',\n ec2iamrole: role,\n});\nrunner.runnerRole.addManagedPolicy(\n ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n);\n```\n\n### Custom Gitlab Runner EBS szie\n\n> 2020/08/22 , you can change you want ebs size.\n\n```typescript\nimport { GitlabContainerRunner } from 'cdk-gitlab-runner';\n\nnew GitlabContainerRunner(stack, 'testing', {\n gitlabtoken: '$GITLAB_TOKEN',\n ebsSize: 50,\n});\n```\n\n### Control the number of runners with AutoScalingGroup\n\n> 2020/11/25 , you can set the number of runners.\n\n```typescript\nimport { GitlabRunnerAutoscaling } from 'cdk-gitlab-runner';\n\nnew GitlabRunnerAutoscaling(stack, 'testing', {\n gitlabToken: '$GITLAB_TOKEN',\n minCapacity: 2,\n maxCapacity: 2,\n});\n```\n\n### Support Spotfleet Gitlab Runner\n\n> 2020/08/27 , you can use spotfleet instance be your gitlab runner,\n> after create spotfleet instance will auto output instance id.\n\n```typescript\nimport { GitlabContainerRunner, BlockDuration } from 'cdk-gitlab-runner';\n\nconst runner = new GitlabContainerRunner(stack, 'testing', {\n gitlabtoken: 'GITLAB_TOKEN',\n ec2type: 't3.large',\n spotFleet: true,\n});\n// configure the expiration after 1 hours\nrunner.expireAfter(Duration.hours(1));\n```\n\n> 2020/11/19, you setting job runtime bind host volumes.\n> see more https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section\n\n```typescript\nimport { GitlabContainerRunner, BlockDuration } from 'cdk-gitlab-runner';\n\nconst runner = new GitlabContainerRunner(stack, 'testing', {\n gitlabtoken: 'GITLAB_TOKEN',\n ec2type: 't3.large',\n dockerVolumes: [\n {\n hostPath: '/tmp/cache',\n containerPath: '/tmp/cache',\n },\n ],\n});\n```\n\n## Wait about 6 mins , If success you will see your runner in that page .\n\n\n\n#### you can use tag `gitlab` , `runner` , `awscdk` ,\n\n## Example _`gitlab-ci.yaml`_\n\n[gitlab docs see more ...](https://docs.gitlab.com/ee/ci/yaml/README.html)\n\n```yaml\ndockerjob:\n image: docker:18.09-dind\n variables:\n tags:\n - runner\n - awscdk\n - gitlab\n variables:\n DOCKER_TLS_CERTDIR: \"\"\n before_script:\n - docker info\n script:\n - docker info;\n - echo 'test 123';\n - echo 'hello world 1228'\n```\n\n### If your want to debug you can go to aws console\n\n# `In your runner region !!!`\n\n## AWS Systems Manager > Session Manager > Start a session\n\n\n\n#### click your `runner` and click `start session`\n\n#### in the brower console in put `bash`\n\n```bash\n# become to root\nsudo -i\n\n# list runner container .\nroot# docker ps -a\n\n# modify gitlab-runner/config.toml\n\nroot# cd /home/ec2-user/.gitlab-runner/ && ls\nconfig.toml\n```\n\n\n## :clap: Supporters\n[](https://github.com/neilkuan/cdk-gitlab-runner/stargazers)\n"
|
|
2941
3435
|
},
|
|
2942
3436
|
"repository": {
|
|
2943
3437
|
"type": "git",
|
|
@@ -3056,7 +3550,7 @@
|
|
|
3056
3550
|
},
|
|
3057
3551
|
"locationInModule": {
|
|
3058
3552
|
"filename": "src/gitlab-runner-instance.ts",
|
|
3059
|
-
"line":
|
|
3553
|
+
"line": 602
|
|
3060
3554
|
},
|
|
3061
3555
|
"name": "createUserData",
|
|
3062
3556
|
"parameters": [
|
|
@@ -3094,7 +3588,7 @@
|
|
|
3094
3588
|
},
|
|
3095
3589
|
"locationInModule": {
|
|
3096
3590
|
"filename": "src/gitlab-runner-instance.ts",
|
|
3097
|
-
"line":
|
|
3591
|
+
"line": 578
|
|
3098
3592
|
},
|
|
3099
3593
|
"name": "expireAfter",
|
|
3100
3594
|
"parameters": [
|
|
@@ -3436,7 +3930,7 @@
|
|
|
3436
3930
|
"abstract": true,
|
|
3437
3931
|
"docs": {
|
|
3438
3932
|
"default": "- new VPC will be created , 1 Vpc , 2 Public Subnet .",
|
|
3439
|
-
"example": "const newvpc = new Vpc(stack, 'NEWVPC', {\n
|
|
3933
|
+
"example": "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\nnew GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', selfvpc: newvpc });",
|
|
3440
3934
|
"stability": "experimental",
|
|
3441
3935
|
"summary": "VPC for the Gitlab Runner ."
|
|
3442
3936
|
},
|
|
@@ -3643,7 +4137,7 @@
|
|
|
3643
4137
|
},
|
|
3644
4138
|
"locationInModule": {
|
|
3645
4139
|
"filename": "src/gitlab-runner-autoscaling.ts",
|
|
3646
|
-
"line":
|
|
4140
|
+
"line": 473
|
|
3647
4141
|
},
|
|
3648
4142
|
"name": "createUserData",
|
|
3649
4143
|
"parameters": [
|
|
@@ -4024,7 +4518,7 @@
|
|
|
4024
4518
|
"abstract": true,
|
|
4025
4519
|
"docs": {
|
|
4026
4520
|
"default": "- A new VPC will be created.",
|
|
4027
|
-
"example": "const newVpc = new Vpc(stack, 'NewVPC', {\n
|
|
4521
|
+
"example": "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\nnew GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', vpc: newVpc });",
|
|
4028
4522
|
"stability": "experimental",
|
|
4029
4523
|
"summary": "VPC for the Gitlab Runner ."
|
|
4030
4524
|
},
|
|
@@ -4042,7 +4536,7 @@
|
|
|
4042
4536
|
{
|
|
4043
4537
|
"abstract": true,
|
|
4044
4538
|
"docs": {
|
|
4045
|
-
"default": "-
|
|
4539
|
+
"default": "- SubnetType.PRIVATE subnet",
|
|
4046
4540
|
"example": "const vpc = new Vpc(stack, 'nat', {\nnatGateways: 1,\nmaxAzs: 2,\n});\nconst runner = new GitlabRunnerAutoscaling(stack, 'testing', {\n gitlabToken: 'GITLAB_TOKEN',\n instanceType: 't3.large',\n instanceRole: role,\n ebsSize: 100,\n vpc: vpc,\n vpcSubnet: {\n subnetType: SubnetType.PUBLIC,\n },\n});",
|
|
4047
4541
|
"stability": "experimental",
|
|
4048
4542
|
"summary": "VPC subnet."
|
|
@@ -4100,6 +4594,6 @@
|
|
|
4100
4594
|
"symbolId": "src/gitlab-runner-instance:InstanceInterruptionBehavior"
|
|
4101
4595
|
}
|
|
4102
4596
|
},
|
|
4103
|
-
"version": "2.1.
|
|
4104
|
-
"fingerprint": "
|
|
4597
|
+
"version": "2.1.183",
|
|
4598
|
+
"fingerprint": "FOiWfkVVBYsaIDYvto0W9Sc7WHrw/beMYYo0tvDPkiA="
|
|
4105
4599
|
}
|
package/API.md
CHANGED
package/README.md
CHANGED
|
@@ -154,7 +154,7 @@ import { Port, Peer, Vpc, SubnetType } from 'aws-cdk-lib/aws-ec2';
|
|
|
154
154
|
import { ManagedPolicy } from 'aws-cdk-lib/aws-iam';
|
|
155
155
|
|
|
156
156
|
const newvpc = new Vpc(stack, 'VPC', {
|
|
157
|
-
|
|
157
|
+
ipAddresses: IpAddresses.cidr('10.0.0.0/16'),
|
|
158
158
|
maxAzs: 2,
|
|
159
159
|
subnetConfiguration: [
|
|
160
160
|
{
|
|
@@ -40,7 +40,7 @@ export interface GitlabRunnerAutoscalingProps {
|
|
|
40
40
|
*
|
|
41
41
|
* @example
|
|
42
42
|
* const newVpc = new Vpc(stack, 'NewVPC', {
|
|
43
|
-
*
|
|
43
|
+
* ipAddresses: IpAddresses.cidr('10.0.0.0/16'),
|
|
44
44
|
* maxAzs: 2,
|
|
45
45
|
* subnetConfiguration: [{
|
|
46
46
|
* cidrMask: 26,
|
|
@@ -153,7 +153,7 @@ export interface GitlabRunnerAutoscalingProps {
|
|
|
153
153
|
* },
|
|
154
154
|
* });
|
|
155
155
|
*
|
|
156
|
-
* @default -
|
|
156
|
+
* @default - SubnetType.PRIVATE subnet
|
|
157
157
|
*/
|
|
158
158
|
readonly vpcSubnet?: ec2.SubnetSelection;
|
|
159
159
|
/**
|
|
@@ -65,9 +65,7 @@ class GitlabRunnerAutoscaling extends constructs_1.Construct {
|
|
|
65
65
|
});
|
|
66
66
|
const lt = new ec2.CfnLaunchTemplate(this, 'GitlabRunnerLaunchTemplate', {
|
|
67
67
|
launchTemplateData: {
|
|
68
|
-
imageId: ec2.MachineImage.
|
|
69
|
-
generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,
|
|
70
|
-
}).getImage(this).imageId,
|
|
68
|
+
imageId: ec2.MachineImage.latestAmazonLinux2().getImage(this).imageId,
|
|
71
69
|
instanceType: runnerProps.instanceType,
|
|
72
70
|
instanceMarketOptions: {
|
|
73
71
|
marketType: runnerProps.spotInstance ? 'spot' : undefined,
|
|
@@ -95,9 +93,7 @@ class GitlabRunnerAutoscaling extends constructs_1.Construct {
|
|
|
95
93
|
autoScalingGroupName: `Gitlab Runners (${runnerProps.instanceType})`,
|
|
96
94
|
vpc: this.vpc,
|
|
97
95
|
vpcSubnets: runnerProps.vpcSubnet,
|
|
98
|
-
machineImage: ec2.MachineImage.
|
|
99
|
-
generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,
|
|
100
|
-
}),
|
|
96
|
+
machineImage: ec2.MachineImage.latestAmazonLinux2(),
|
|
101
97
|
minCapacity: runnerProps.minCapacity,
|
|
102
98
|
maxCapacity: runnerProps.maxCapacity,
|
|
103
99
|
desiredCapacity: runnerProps.desiredCapacity,
|
|
@@ -244,5 +240,5 @@ class GitlabRunnerAutoscaling extends constructs_1.Construct {
|
|
|
244
240
|
}
|
|
245
241
|
exports.GitlabRunnerAutoscaling = GitlabRunnerAutoscaling;
|
|
246
242
|
_a = JSII_RTTI_SYMBOL_1;
|
|
247
|
-
GitlabRunnerAutoscaling[_a] = { fqn: "cdk-gitlab-runner.GitlabRunnerAutoscaling", version: "2.1.
|
|
248
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-autoscaling.js","sourceRoot":"","sources":["../src/gitlab-runner-autoscaling.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport * as asg from 'aws-cdk-lib/aws-autoscaling';\nimport { FunctionHook } from 'aws-cdk-lib/aws-autoscaling-hooktargets';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as assets from 'aws-cdk-lib/aws-s3-assets';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as subscriptions from 'aws-cdk-lib/aws-sns-subscriptions';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n\n/**\n * GitlabRunnerAutoscaling Props.\n */\nexport interface GitlabRunnerAutoscalingProps {\n  /**\n   * Gitlab token.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN' });\n   */\n  readonly gitlabToken: string;\n\n  /**\n   * Image URL of Gitlab Runner.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });\n   *\n   * @default public.ecr.aws/gitlab/gitlab-runner:latest\n   *\n   */\n  readonly gitlabRunnerImage?: string;\n\n  /**\n   * Runner default EC2 instance type.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceType: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly instanceType?: string;\n\n  /**\n   * VPC for the Gitlab Runner .\n   *\n   * @example\n   * const newVpc = new Vpc(stack, 'NewVPC', {\n   *   cidr: '10.1.0.0/16',\n   *   maxAzs: 2,\n   *   subnetConfiguration: [{\n   *     cidrMask: 26,\n   *     name: 'RunnerVPC',\n   *     subnetType: SubnetType.PUBLIC,\n   *   }],\n   *   natGateways: 0,\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', vpc: newVpc });\n   *\n   * @default - A new VPC will be created.\n   *\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * IAM role for the Gitlab Runner Instance .\n   *\n   * @example\n   * const role = new Role(stack, 'runner-role', {\n   *   assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n   *   description: 'For Gitlab Runner Test Role',\n   *   roleName: 'Runner-Role',\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceRole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * Run worker nodes as EC2 Spot\n   *\n   * @default - false\n   */\n  readonly spotInstance?: boolean;\n\n  /**\n   * Minimum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', minCapacity: 2 });\n   *\n   * @default - minCapacity: 1\n   *\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', maxCapacity: 4 });\n   *\n   * @default - desiredCapacity\n   *\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Desired capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', desiredCapacity: 2 });\n   *\n   * @default - minCapacity, and leave unchanged during deployment\n   *\n   */\n  readonly desiredCapacity?: number;\n\n  /**\n   * tags for the runner\n   *\n   * @default - ['runner', 'gitlab', 'awscdk']\n   */\n  readonly tags?: string[];\n\n  /**\n   * Gitlab Runner register url .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN',gitlabUrl: 'https://gitlab.com/'});\n   *\n   * @default - https://gitlab.com/ , The trailing slash is mandatory.\n   *\n   */\n  readonly gitlabUrl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * VPC subnet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabRunnerAutoscaling(stack, 'testing', {\n   *   gitlabToken: 'GITLAB_TOKEN',\n   *   instanceType: 't3.large',\n   *   instanceRole: role,\n   *   ebsSize: 100,\n   *   vpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - private subnet\n   */\n  readonly vpcSubnet?: ec2.SubnetSelection;\n\n  /**\n   * add another Gitlab Container Runner Docker Volumes Path at job runner runtime.\n   *\n   * more detail see https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section\n   *\n   * @default - already mount \"/var/run/docker.sock:/var/run/docker.sock\"\n   *\n   * @example\n   * dockerVolumes: [\n   *   {\n   *     hostPath: '/tmp/cache',\n   *     containerPath: '/tmp/cache',\n   *   },\n   * ],\n   */\n  readonly dockerVolumes?: DockerVolumes[];\n\n  /**\n   * Parameters of put_metric_alarm function\n   *\n   * https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/cloudwatch.html#CloudWatch.Client.put_metric_alarm\n   *\n   * @default - [{\n   *     AlarmName: 'GitlabRunnerDiskUsage',\n   *     MetricName: 'disk_used_percent',\n   * }]\n   *\n   */\n  readonly alarms?: object[];\n}\n\n/**\n * GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.\n */\nexport class GitlabRunnerAutoscaling extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance.\n   */\n  public readonly instanceRole: iam.IRole;\n\n  /**\n   * This represents a Runner Auto Scaling Group\n   */\n  public readonly autoscalingGroup: asg.AutoScalingGroup;\n\n  /**\n   * The EC2 runner's VPC.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly securityGroup: ec2.ISecurityGroup;\n\n  /**\n   * The SNS topic to suscribe alarms for EC2 runner's metrics.\n   */\n  public readonly topicAlarm: sns.ITopic;\n\n\n  constructor(scope: Construct, id: string, props: GitlabRunnerAutoscalingProps) {\n    super(scope, id);\n    const defaultProps = {\n      instanceType: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      gitlabUrl: 'https://gitlab.com/',\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      alarms: [\n        {\n          AlarmName: 'GitlabRunnerDiskUsage',\n          MetricName: 'disk_used_percent',\n        },\n      ],\n    };\n    const runnerProps = { ...defaultProps, ...props };\n\n    const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {\n      path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),\n    });\n\n    const userData = ec2.UserData.forLinux();\n    userData.addS3DownloadCommand({\n      bucket: asset.bucket,\n      bucketKey: asset.s3ObjectKey,\n      localFile: '/opt/aws/amazon-cloudwatch-agent/etc/amazon-cloudwatch-agent.json',\n    });\n    userData.addCommands(...this.createUserData(runnerProps));\n\n    this.instanceRole =\n      runnerProps.instanceRole ??\n      new iam.Role(this, 'GitlabRunnerInstanceRole', {\n        assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For EC2 Instance (Gitlab Runner) Role',\n        managedPolicies: [\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchAgentServerPolicy'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n        ],\n      });\n\n    this.vpc = runnerProps.vpc ?? new ec2.Vpc(this, 'VPC');\n\n    this.securityGroup = new ec2.SecurityGroup(this, 'GitlabRunnerSecurityGroup', {\n      vpc: this.vpc,\n    });\n    const instanceProfile = new iam.CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.instanceRole.roleName],\n    });\n    const lt = new ec2.CfnLaunchTemplate(this, 'GitlabRunnerLaunchTemplate', {\n      launchTemplateData: {\n        imageId: ec2.MachineImage.latestAmazonLinux({\n          generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,\n        }).getImage(this).imageId,\n        instanceType: runnerProps.instanceType,\n        instanceMarketOptions: {\n          marketType: runnerProps.spotInstance ? 'spot' : undefined,\n          spotOptions: runnerProps.spotInstance ? {\n            spotInstanceType: 'one-time',\n          } : undefined,\n        },\n        userData: cdk.Fn.base64(userData.render()),\n        blockDeviceMappings: [\n          {\n            deviceName: '/dev/xvda',\n            ebs: {\n              volumeSize: runnerProps.ebsSize ?? 60,\n            },\n          },\n        ],\n        iamInstanceProfile: {\n          arn: instanceProfile.attrArn,\n        },\n        securityGroupIds: this.securityGroup.connections.securityGroups.map(\n          (m) => m.securityGroupId,\n        ),\n      },\n    });\n\n    this.autoscalingGroup = new asg.AutoScalingGroup(this, 'GitlabRunnerAutoscalingGroup', {\n      instanceType: new ec2.InstanceType(runnerProps.instanceType),\n      autoScalingGroupName: `Gitlab Runners (${runnerProps.instanceType})`,\n      vpc: this.vpc,\n      vpcSubnets: runnerProps.vpcSubnet,\n      machineImage: ec2.MachineImage.latestAmazonLinux({\n        generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,\n      }),\n      minCapacity: runnerProps.minCapacity,\n      maxCapacity: runnerProps.maxCapacity,\n      desiredCapacity: runnerProps.desiredCapacity,\n    });\n\n    const cfnAsg = this.autoscalingGroup.node.tryFindChild('ASG') as asg.CfnAutoScalingGroup;\n    cfnAsg.addPropertyDeletionOverride('LaunchConfigurationName');\n    cfnAsg.addPropertyOverride('LaunchTemplate', {\n      LaunchTemplateId: lt.ref,\n      Version: lt.attrLatestVersionNumber,\n    });\n    this.autoscalingGroup.node.tryRemoveChild('LaunchConfig');\n\n    this.topicAlarm = new sns.Topic(this, 'GitlabRunnerAlarm');\n    const alarms = JSON.stringify(runnerProps.alarms);\n\n    // Put alarms at launch\n    const registerFunction = new lambda.Function(this, 'GitlabRunnerRegisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.register',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n        SNS_TOPIC_ARN: this.topicAlarm.topicArn,\n      },\n    });\n    registerFunction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'cloudwatch:PutMetricAlarm',\n        ],\n      }),\n    );\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookLaunching', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_LAUNCHING,\n      notificationTarget: new FunctionHook(registerFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    // Add an alarm action to terminate invalid instances\n    const alarmAction = new lambda.Function(this, 'GitlabRunnerAlarmAction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_alarm',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n    alarmAction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'autoscaling:SetInstanceHealth',\n        ],\n      }),\n    );\n    const alarmSubscription = new subscriptions.LambdaSubscription(alarmAction);\n    this.topicAlarm.addSubscription(alarmSubscription);\n\n    // Unregister gitlab runners and remove alarms on instance termination or CFn stack deletion\n    const unregisterRole = new iam.Role(this, 'GitlabRunnerUnregisterRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      description: 'For Gitlab Runner Unregistering Function Role',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n      ],\n    });\n    unregisterRole.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'ssm:SendCommand',\n          'autoscaling:DescribeAutoScalingGroups',\n          'cloudwatch:DeleteAlarms',\n        ],\n      }),\n    );\n\n    const unregisterFunction = new lambda.Function(this, 'GitlabRunnerUnregisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.unregister',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookTerminating', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_TERMINATING,\n      notificationTarget: new FunctionHook(unregisterFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    const unregisterCustomResource = new lambda.Function(this, 'GitlabRunnerUnregisterCustomResource', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    const unregisterProvider = new cr.Provider(this, 'GitlabRunnerUnregisterProvider', {\n      onEventHandler: unregisterCustomResource,\n    });\n\n    const customResource = new cdk.CustomResource(this, 'GitlabRunnerCustomResource', {\n      serviceToken: unregisterProvider.serviceToken,\n      properties: {\n        AutoScalingGroupNames: [this.autoscalingGroup.autoScalingGroupName],\n      },\n    });\n    customResource.node.addDependency(unregisterProvider);\n\n    new cdk.CfnOutput(this, 'GitlabRunnerAutoScalingGroupArn', {\n      value: this.autoscalingGroup.autoScalingGroupArn,\n    });\n  }\n\n  private dockerVolumesList(dockerVolume: DockerVolumes[] | undefined): string {\n    let tempString: string = '--docker-volumes \"/var/run/docker.sock:/var/run/docker.sock\"';\n    if (dockerVolume) {\n      let tempList: string[] = [];\n      dockerVolume.forEach(e => {\n        tempList.push(`\"${e.hostPath}:${e.containerPath}\"`);\n      });\n      tempList.forEach(e => {\n        tempString = `${tempString} --docker-volumes ${e}`;\n      });\n    }\n    return tempString;\n  }\n  /**\n   * @param props\n   * @returns Array.\n   */\n  public createUserData(props: GitlabRunnerAutoscalingProps): string[] {\n    return [\n      'yum update -y',\n      'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',\n      'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',\n      `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \\\n      --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} --registration-token ${props.gitlabToken} \\\n      --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \\\n      --executor docker --docker-image \"alpine:latest\" --description \"A Runner on EC2 Instance (${props.instanceType})\" \\\n      --tag-list \"${props.tags?.join(',')}\" --docker-privileged`,\n      `sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,\n    ];\n  }\n}\n"]}
|
|
243
|
+
GitlabRunnerAutoscaling[_a] = { fqn: "cdk-gitlab-runner.GitlabRunnerAutoscaling", version: "2.1.183" };
|
|
244
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-autoscaling.js","sourceRoot":"","sources":["../src/gitlab-runner-autoscaling.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport * as asg from 'aws-cdk-lib/aws-autoscaling';\nimport { FunctionHook } from 'aws-cdk-lib/aws-autoscaling-hooktargets';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as assets from 'aws-cdk-lib/aws-s3-assets';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as subscriptions from 'aws-cdk-lib/aws-sns-subscriptions';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n\n/**\n * GitlabRunnerAutoscaling Props.\n */\nexport interface GitlabRunnerAutoscalingProps {\n  /**\n   * Gitlab token.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN' });\n   */\n  readonly gitlabToken: string;\n\n  /**\n   * Image URL of Gitlab Runner.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });\n   *\n   * @default public.ecr.aws/gitlab/gitlab-runner:latest\n   *\n   */\n  readonly gitlabRunnerImage?: string;\n\n  /**\n   * Runner default EC2 instance type.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceType: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly instanceType?: string;\n\n  /**\n   * VPC for the Gitlab Runner .\n   *\n   * @example\n   * const newVpc = new Vpc(stack, 'NewVPC', {\n   *   ipAddresses: IpAddresses.cidr('10.0.0.0/16'),\n   *   maxAzs: 2,\n   *   subnetConfiguration: [{\n   *     cidrMask: 26,\n   *     name: 'RunnerVPC',\n   *     subnetType: SubnetType.PUBLIC,\n   *   }],\n   *   natGateways: 0,\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', vpc: newVpc });\n   *\n   * @default - A new VPC will be created.\n   *\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * IAM role for the Gitlab Runner Instance .\n   *\n   * @example\n   * const role = new Role(stack, 'runner-role', {\n   *   assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n   *   description: 'For Gitlab Runner Test Role',\n   *   roleName: 'Runner-Role',\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceRole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * Run worker nodes as EC2 Spot\n   *\n   * @default - false\n   */\n  readonly spotInstance?: boolean;\n\n  /**\n   * Minimum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', minCapacity: 2 });\n   *\n   * @default - minCapacity: 1\n   *\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', maxCapacity: 4 });\n   *\n   * @default - desiredCapacity\n   *\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Desired capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', desiredCapacity: 2 });\n   *\n   * @default - minCapacity, and leave unchanged during deployment\n   *\n   */\n  readonly desiredCapacity?: number;\n\n  /**\n   * tags for the runner\n   *\n   * @default - ['runner', 'gitlab', 'awscdk']\n   */\n  readonly tags?: string[];\n\n  /**\n   * Gitlab Runner register url .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN',gitlabUrl: 'https://gitlab.com/'});\n   *\n   * @default - https://gitlab.com/ , The trailing slash is mandatory.\n   *\n   */\n  readonly gitlabUrl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * VPC subnet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabRunnerAutoscaling(stack, 'testing', {\n   *   gitlabToken: 'GITLAB_TOKEN',\n   *   instanceType: 't3.large',\n   *   instanceRole: role,\n   *   ebsSize: 100,\n   *   vpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - SubnetType.PRIVATE subnet\n   */\n  readonly vpcSubnet?: ec2.SubnetSelection;\n\n  /**\n   * add another Gitlab Container Runner Docker Volumes Path at job runner runtime.\n   *\n   * more detail see https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section\n   *\n   * @default - already mount \"/var/run/docker.sock:/var/run/docker.sock\"\n   *\n   * @example\n   * dockerVolumes: [\n   *   {\n   *     hostPath: '/tmp/cache',\n   *     containerPath: '/tmp/cache',\n   *   },\n   * ],\n   */\n  readonly dockerVolumes?: DockerVolumes[];\n\n  /**\n   * Parameters of put_metric_alarm function\n   *\n   * https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/cloudwatch.html#CloudWatch.Client.put_metric_alarm\n   *\n   * @default - [{\n   *     AlarmName: 'GitlabRunnerDiskUsage',\n   *     MetricName: 'disk_used_percent',\n   * }]\n   *\n   */\n  readonly alarms?: object[];\n}\n\n/**\n * GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.\n */\nexport class GitlabRunnerAutoscaling extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance.\n   */\n  public readonly instanceRole: iam.IRole;\n\n  /**\n   * This represents a Runner Auto Scaling Group\n   */\n  public readonly autoscalingGroup: asg.AutoScalingGroup;\n\n  /**\n   * The EC2 runner's VPC.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly securityGroup: ec2.ISecurityGroup;\n\n  /**\n   * The SNS topic to suscribe alarms for EC2 runner's metrics.\n   */\n  public readonly topicAlarm: sns.ITopic;\n\n\n  constructor(scope: Construct, id: string, props: GitlabRunnerAutoscalingProps) {\n    super(scope, id);\n    const defaultProps = {\n      instanceType: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      gitlabUrl: 'https://gitlab.com/',\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      alarms: [\n        {\n          AlarmName: 'GitlabRunnerDiskUsage',\n          MetricName: 'disk_used_percent',\n        },\n      ],\n    };\n    const runnerProps = { ...defaultProps, ...props };\n\n    const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {\n      path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),\n    });\n\n    const userData = ec2.UserData.forLinux();\n    userData.addS3DownloadCommand({\n      bucket: asset.bucket,\n      bucketKey: asset.s3ObjectKey,\n      localFile: '/opt/aws/amazon-cloudwatch-agent/etc/amazon-cloudwatch-agent.json',\n    });\n    userData.addCommands(...this.createUserData(runnerProps));\n\n    this.instanceRole =\n      runnerProps.instanceRole ??\n      new iam.Role(this, 'GitlabRunnerInstanceRole', {\n        assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For EC2 Instance (Gitlab Runner) Role',\n        managedPolicies: [\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchAgentServerPolicy'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n        ],\n      });\n\n    this.vpc = runnerProps.vpc ?? new ec2.Vpc(this, 'VPC');\n\n    this.securityGroup = new ec2.SecurityGroup(this, 'GitlabRunnerSecurityGroup', {\n      vpc: this.vpc,\n    });\n    const instanceProfile = new iam.CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.instanceRole.roleName],\n    });\n    const lt = new ec2.CfnLaunchTemplate(this, 'GitlabRunnerLaunchTemplate', {\n      launchTemplateData: {\n        imageId: ec2.MachineImage.latestAmazonLinux2().getImage(this).imageId,\n        instanceType: runnerProps.instanceType,\n        instanceMarketOptions: {\n          marketType: runnerProps.spotInstance ? 'spot' : undefined,\n          spotOptions: runnerProps.spotInstance ? {\n            spotInstanceType: 'one-time',\n          } : undefined,\n        },\n        userData: cdk.Fn.base64(userData.render()),\n        blockDeviceMappings: [\n          {\n            deviceName: '/dev/xvda',\n            ebs: {\n              volumeSize: runnerProps.ebsSize ?? 60,\n            },\n          },\n        ],\n        iamInstanceProfile: {\n          arn: instanceProfile.attrArn,\n        },\n        securityGroupIds: this.securityGroup.connections.securityGroups.map(\n          (m) => m.securityGroupId,\n        ),\n      },\n    });\n\n    this.autoscalingGroup = new asg.AutoScalingGroup(this, 'GitlabRunnerAutoscalingGroup', {\n      instanceType: new ec2.InstanceType(runnerProps.instanceType),\n      autoScalingGroupName: `Gitlab Runners (${runnerProps.instanceType})`,\n      vpc: this.vpc,\n      vpcSubnets: runnerProps.vpcSubnet,\n      machineImage: ec2.MachineImage.latestAmazonLinux2(),\n      minCapacity: runnerProps.minCapacity,\n      maxCapacity: runnerProps.maxCapacity,\n      desiredCapacity: runnerProps.desiredCapacity,\n    });\n\n    const cfnAsg = this.autoscalingGroup.node.tryFindChild('ASG') as asg.CfnAutoScalingGroup;\n    cfnAsg.addPropertyDeletionOverride('LaunchConfigurationName');\n    cfnAsg.addPropertyOverride('LaunchTemplate', {\n      LaunchTemplateId: lt.ref,\n      Version: lt.attrLatestVersionNumber,\n    });\n    this.autoscalingGroup.node.tryRemoveChild('LaunchConfig');\n\n    this.topicAlarm = new sns.Topic(this, 'GitlabRunnerAlarm');\n    const alarms = JSON.stringify(runnerProps.alarms);\n\n    // Put alarms at launch\n    const registerFunction = new lambda.Function(this, 'GitlabRunnerRegisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.register',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n        SNS_TOPIC_ARN: this.topicAlarm.topicArn,\n      },\n    });\n    registerFunction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'cloudwatch:PutMetricAlarm',\n        ],\n      }),\n    );\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookLaunching', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_LAUNCHING,\n      notificationTarget: new FunctionHook(registerFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    // Add an alarm action to terminate invalid instances\n    const alarmAction = new lambda.Function(this, 'GitlabRunnerAlarmAction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_alarm',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n    alarmAction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'autoscaling:SetInstanceHealth',\n        ],\n      }),\n    );\n    const alarmSubscription = new subscriptions.LambdaSubscription(alarmAction);\n    this.topicAlarm.addSubscription(alarmSubscription);\n\n    // Unregister gitlab runners and remove alarms on instance termination or CFn stack deletion\n    const unregisterRole = new iam.Role(this, 'GitlabRunnerUnregisterRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      description: 'For Gitlab Runner Unregistering Function Role',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n      ],\n    });\n    unregisterRole.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'ssm:SendCommand',\n          'autoscaling:DescribeAutoScalingGroups',\n          'cloudwatch:DeleteAlarms',\n        ],\n      }),\n    );\n\n    const unregisterFunction = new lambda.Function(this, 'GitlabRunnerUnregisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.unregister',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookTerminating', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_TERMINATING,\n      notificationTarget: new FunctionHook(unregisterFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    const unregisterCustomResource = new lambda.Function(this, 'GitlabRunnerUnregisterCustomResource', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    const unregisterProvider = new cr.Provider(this, 'GitlabRunnerUnregisterProvider', {\n      onEventHandler: unregisterCustomResource,\n    });\n\n    const customResource = new cdk.CustomResource(this, 'GitlabRunnerCustomResource', {\n      serviceToken: unregisterProvider.serviceToken,\n      properties: {\n        AutoScalingGroupNames: [this.autoscalingGroup.autoScalingGroupName],\n      },\n    });\n    customResource.node.addDependency(unregisterProvider);\n\n    new cdk.CfnOutput(this, 'GitlabRunnerAutoScalingGroupArn', {\n      value: this.autoscalingGroup.autoScalingGroupArn,\n    });\n  }\n\n  private dockerVolumesList(dockerVolume: DockerVolumes[] | undefined): string {\n    let tempString: string = '--docker-volumes \"/var/run/docker.sock:/var/run/docker.sock\"';\n    if (dockerVolume) {\n      let tempList: string[] = [];\n      dockerVolume.forEach(e => {\n        tempList.push(`\"${e.hostPath}:${e.containerPath}\"`);\n      });\n      tempList.forEach(e => {\n        tempString = `${tempString} --docker-volumes ${e}`;\n      });\n    }\n    return tempString;\n  }\n  /**\n   * @param props\n   * @returns Array.\n   */\n  public createUserData(props: GitlabRunnerAutoscalingProps): string[] {\n    return [\n      'yum update -y',\n      'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',\n      'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',\n      `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \\\n      --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} --registration-token ${props.gitlabToken} \\\n      --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \\\n      --executor docker --docker-image \"alpine:latest\" --description \"A Runner on EC2 Instance (${props.instanceType})\" \\\n      --tag-list \"${props.tags?.join(',')}\" --docker-privileged`,\n      `sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,\n    ];\n  }\n}\n"]}
|
|
@@ -66,7 +66,7 @@ class GitlabContainerRunner extends constructs_1.Construct {
|
|
|
66
66
|
this.vpc =
|
|
67
67
|
runnerProps.selfvpc ??
|
|
68
68
|
new aws_ec2_1.Vpc(this, 'VPC', {
|
|
69
|
-
|
|
69
|
+
ipAddresses: aws_ec2_1.IpAddresses.cidr('10.0.0.0/16'),
|
|
70
70
|
maxAzs: 2,
|
|
71
71
|
subnetConfiguration: [
|
|
72
72
|
{
|
|
@@ -84,9 +84,7 @@ class GitlabContainerRunner extends constructs_1.Construct {
|
|
|
84
84
|
const spotOrOnDemand = runnerProps.spotFleet ?? false;
|
|
85
85
|
if (spotOrOnDemand) {
|
|
86
86
|
//throw new Error('yes new spotfleet');
|
|
87
|
-
const imageId = aws_ec2_1.MachineImage.
|
|
88
|
-
generation: aws_ec2_1.AmazonLinuxGeneration.AMAZON_LINUX_2,
|
|
89
|
-
}).getImage(this).imageId;
|
|
87
|
+
const imageId = aws_ec2_1.MachineImage.latestAmazonLinux2().getImage(this).imageId;
|
|
90
88
|
const lt = new aws_ec2_1.CfnLaunchTemplate(this, 'LaunchTemplate', {
|
|
91
89
|
launchTemplateData: {
|
|
92
90
|
imageId,
|
|
@@ -198,9 +196,7 @@ class GitlabContainerRunner extends constructs_1.Construct {
|
|
|
198
196
|
vpcSubnets: runnerProps.vpcSubnet ?? {
|
|
199
197
|
subnetType: aws_ec2_1.SubnetType.PUBLIC,
|
|
200
198
|
},
|
|
201
|
-
machineImage: aws_ec2_1.MachineImage.
|
|
202
|
-
generation: aws_ec2_1.AmazonLinuxGeneration.AMAZON_LINUX_2,
|
|
203
|
-
}),
|
|
199
|
+
machineImage: aws_ec2_1.MachineImage.latestAmazonLinux2(),
|
|
204
200
|
role: this.runnerRole,
|
|
205
201
|
userData: shell,
|
|
206
202
|
securityGroup: this.defaultRunnerSG,
|
|
@@ -287,5 +283,5 @@ class GitlabContainerRunner extends constructs_1.Construct {
|
|
|
287
283
|
}
|
|
288
284
|
exports.GitlabContainerRunner = GitlabContainerRunner;
|
|
289
285
|
_a = JSII_RTTI_SYMBOL_1;
|
|
290
|
-
GitlabContainerRunner[_a] = { fqn: "cdk-gitlab-runner.GitlabContainerRunner", version: "2.1.
|
|
291
|
-
//# 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  AmazonLinuxGeneration,\n  SubnetType,\n  Vpc,\n  IVpc,\n  IInstance,\n  SecurityGroup,\n  Port,\n  CfnLaunchTemplate,\n  CfnSpotFleet,\n  ISecurityGroup,\n  SubnetSelection,\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   *   cidr: '10.1.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        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.latestAmazonLinux({\n        generation: AmazonLinuxGeneration.AMAZON_LINUX_2,\n      }).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.latestAmazonLinux({\n          generation: AmazonLinuxGeneration.AMAZON_LINUX_2,\n        }),\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"]}
|
|
286
|
+
GitlabContainerRunner[_a] = { fqn: "cdk-gitlab-runner.GitlabContainerRunner", version: "2.1.183" };
|
|
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"]}
|
package/package.json
CHANGED
|
@@ -41,7 +41,7 @@
|
|
|
41
41
|
"@types/node": "^16",
|
|
42
42
|
"@typescript-eslint/eslint-plugin": "^5",
|
|
43
43
|
"@typescript-eslint/parser": "^5",
|
|
44
|
-
"aws-cdk-lib": "2.
|
|
44
|
+
"aws-cdk-lib": "2.76.0",
|
|
45
45
|
"constructs": "10.0.5",
|
|
46
46
|
"eslint": "^8",
|
|
47
47
|
"eslint-import-resolver-node": "^0.3.7",
|
|
@@ -60,7 +60,7 @@
|
|
|
60
60
|
"typescript": "^4.9"
|
|
61
61
|
},
|
|
62
62
|
"peerDependencies": {
|
|
63
|
-
"aws-cdk-lib": "^2.
|
|
63
|
+
"aws-cdk-lib": "^2.76.0",
|
|
64
64
|
"constructs": "^10.0.5"
|
|
65
65
|
},
|
|
66
66
|
"resolutions": {
|
|
@@ -75,7 +75,7 @@
|
|
|
75
75
|
],
|
|
76
76
|
"main": "lib/index.js",
|
|
77
77
|
"license": "Apache-2.0",
|
|
78
|
-
"version": "2.1.
|
|
78
|
+
"version": "2.1.183",
|
|
79
79
|
"jest": {
|
|
80
80
|
"testMatch": [
|
|
81
81
|
"<rootDir>/src/**/__tests__/**/*.ts?(x)",
|