@cloudsnorkel/cdk-github-runners 0.7.5 → 0.7.6
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 +91 -35
- package/API.md +30 -1
- package/lib/lambdas/delete-runner/index.js +80 -4
- package/lib/lambdas/setup/index.html +4 -4
- package/lib/lambdas/setup/index.js +61 -2
- package/lib/lambdas/status/index.js +80 -4
- package/lib/lambdas/token-retriever/index.js +80 -4
- package/lib/lambdas/update-lambda/index.js +54 -19
- package/lib/providers/codebuild.js +1 -1
- package/lib/providers/common.d.ts +3 -3
- package/lib/providers/common.js +4 -4
- package/lib/providers/ec2.d.ts +1 -1
- package/lib/providers/ec2.js +71 -44
- package/lib/providers/fargate.js +1 -1
- package/lib/providers/image-builders/ami.d.ts +7 -1
- package/lib/providers/image-builders/ami.js +25 -21
- package/lib/providers/image-builders/codebuild.js +1 -1
- package/lib/providers/image-builders/common.js +1 -1
- package/lib/providers/image-builders/container.d.ts +1 -1
- package/lib/providers/image-builders/container.js +11 -11
- package/lib/providers/image-builders/linux-components.d.ts +1 -1
- package/lib/providers/image-builders/linux-components.js +19 -19
- package/lib/providers/image-builders/static.js +6 -6
- package/lib/providers/image-builders/windows-components.d.ts +1 -1
- package/lib/providers/image-builders/windows-components.js +12 -12
- package/lib/providers/lambda.js +3 -3
- package/lib/runner.d.ts +1 -0
- package/lib/runner.js +19 -2
- package/lib/secrets.js +1 -1
- package/package.json +7 -7
|
@@ -2022,9 +2022,10 @@ var require_models_0 = __commonJS({
|
|
|
2022
2022
|
"use strict";
|
|
2023
2023
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
2024
2024
|
exports.KMSNotFoundException = exports.KMSInvalidStateException = exports.KMSDisabledException = exports.KMSAccessDeniedException = exports.LogType = exports.InvocationType = exports.InvalidZipFileException = exports.InvalidSubnetIDException = exports.InvalidSecurityGroupIDException = exports.InvalidRuntimeException = exports.InvalidRequestContentException = exports.ENILimitReachedException = exports.EFSMountTimeoutException = exports.EFSMountFailureException = exports.EFSMountConnectivityException = exports.EFSIOException = exports.EC2UnexpectedException = exports.EC2ThrottledException = exports.EC2AccessDeniedException = exports.ProvisionedConcurrencyConfigNotFoundException = exports.ProvisionedConcurrencyStatusEnum = exports.ResourceInUseException = exports.InvalidCodeSignatureException = exports.StateReasonCode = exports.State = exports.SnapStartOptimizationStatus = exports.LastUpdateStatusReasonCode = exports.LastUpdateStatus = exports.TracingMode = exports.SnapStartApplyOn = exports.Runtime = exports.PackageType = exports.CodeVerificationFailedException = exports.CodeStorageExceededException = exports.CodeSigningConfigNotFoundException = exports.EventSourcePosition = exports.SourceAccessType = exports.EndPointType = exports.FunctionResponseType = exports.CodeSigningPolicy = exports.Architecture = exports.FunctionUrlAuthType = exports.TooManyRequestsException = exports.ThrottleReason = exports.ServiceException = exports.ResourceNotFoundException = exports.ResourceConflictException = exports.PreconditionFailedException = exports.PolicyLengthExceededException = exports.InvalidParameterValueException = void 0;
|
|
2025
|
-
exports.
|
|
2026
|
-
exports.
|
|
2027
|
-
exports.
|
|
2025
|
+
exports.SnapStartResponseFilterSensitiveLog = exports.LayerFilterSensitiveLog = exports.ImageConfigResponseFilterSensitiveLog = exports.ImageConfigErrorFilterSensitiveLog = exports.EnvironmentResponseFilterSensitiveLog = exports.EnvironmentErrorFilterSensitiveLog = exports.CreateFunctionRequestFilterSensitiveLog = exports.VpcConfigFilterSensitiveLog = exports.TracingConfigFilterSensitiveLog = exports.SnapStartFilterSensitiveLog = exports.ImageConfigFilterSensitiveLog = exports.FileSystemConfigFilterSensitiveLog = exports.EphemeralStorageFilterSensitiveLog = exports.EnvironmentFilterSensitiveLog = exports.DeadLetterConfigFilterSensitiveLog = exports.FunctionCodeFilterSensitiveLog = exports.EventSourceMappingConfigurationFilterSensitiveLog = exports.CreateEventSourceMappingRequestFilterSensitiveLog = exports.SourceAccessConfigurationFilterSensitiveLog = exports.SelfManagedKafkaEventSourceConfigFilterSensitiveLog = exports.SelfManagedEventSourceFilterSensitiveLog = exports.ScalingConfigFilterSensitiveLog = exports.FilterCriteriaFilterSensitiveLog = exports.FilterFilterSensitiveLog = exports.DestinationConfigFilterSensitiveLog = exports.OnSuccessFilterSensitiveLog = exports.OnFailureFilterSensitiveLog = exports.CreateCodeSigningConfigResponseFilterSensitiveLog = exports.CodeSigningConfigFilterSensitiveLog = exports.CreateCodeSigningConfigRequestFilterSensitiveLog = exports.CodeSigningPoliciesFilterSensitiveLog = exports.CreateAliasRequestFilterSensitiveLog = exports.AmazonManagedKafkaEventSourceConfigFilterSensitiveLog = exports.AllowedPublishersFilterSensitiveLog = exports.AliasConfigurationFilterSensitiveLog = exports.AliasRoutingConfigurationFilterSensitiveLog = exports.AddPermissionResponseFilterSensitiveLog = exports.AddPermissionRequestFilterSensitiveLog = exports.AddLayerVersionPermissionResponseFilterSensitiveLog = exports.AddLayerVersionPermissionRequestFilterSensitiveLog = exports.AccountUsageFilterSensitiveLog = exports.AccountLimitFilterSensitiveLog = exports.FunctionVersion = exports.UnsupportedMediaTypeException = exports.SubnetIPAddressLimitReachedException = exports.SnapStartTimeoutException = exports.SnapStartNotReadyException = exports.SnapStartException = exports.ResourceNotReadyException = exports.RequestTooLargeException = void 0;
|
|
2026
|
+
exports.InvokeAsyncResponseFilterSensitiveLog = exports.InvokeAsyncRequestFilterSensitiveLog = exports.InvocationResponseFilterSensitiveLog = exports.InvocationRequestFilterSensitiveLog = exports.GetProvisionedConcurrencyConfigResponseFilterSensitiveLog = exports.GetProvisionedConcurrencyConfigRequestFilterSensitiveLog = exports.GetPolicyResponseFilterSensitiveLog = exports.GetPolicyRequestFilterSensitiveLog = exports.GetLayerVersionPolicyResponseFilterSensitiveLog = exports.GetLayerVersionPolicyRequestFilterSensitiveLog = exports.GetLayerVersionByArnRequestFilterSensitiveLog = exports.GetLayerVersionResponseFilterSensitiveLog = exports.LayerVersionContentOutputFilterSensitiveLog = exports.GetLayerVersionRequestFilterSensitiveLog = exports.GetFunctionUrlConfigResponseFilterSensitiveLog = exports.GetFunctionUrlConfigRequestFilterSensitiveLog = exports.GetFunctionEventInvokeConfigRequestFilterSensitiveLog = exports.FunctionEventInvokeConfigFilterSensitiveLog = exports.GetFunctionConfigurationRequestFilterSensitiveLog = exports.GetFunctionConcurrencyResponseFilterSensitiveLog = exports.GetFunctionConcurrencyRequestFilterSensitiveLog = exports.GetFunctionCodeSigningConfigResponseFilterSensitiveLog = exports.GetFunctionCodeSigningConfigRequestFilterSensitiveLog = exports.GetFunctionResponseFilterSensitiveLog = exports.ConcurrencyFilterSensitiveLog = exports.FunctionCodeLocationFilterSensitiveLog = exports.GetFunctionRequestFilterSensitiveLog = exports.GetEventSourceMappingRequestFilterSensitiveLog = exports.GetCodeSigningConfigResponseFilterSensitiveLog = exports.GetCodeSigningConfigRequestFilterSensitiveLog = exports.GetAliasRequestFilterSensitiveLog = exports.GetAccountSettingsResponseFilterSensitiveLog = exports.GetAccountSettingsRequestFilterSensitiveLog = exports.DeleteProvisionedConcurrencyConfigRequestFilterSensitiveLog = exports.DeleteLayerVersionRequestFilterSensitiveLog = exports.DeleteFunctionUrlConfigRequestFilterSensitiveLog = exports.DeleteFunctionEventInvokeConfigRequestFilterSensitiveLog = exports.DeleteFunctionConcurrencyRequestFilterSensitiveLog = exports.DeleteFunctionCodeSigningConfigRequestFilterSensitiveLog = exports.DeleteFunctionRequestFilterSensitiveLog = exports.DeleteEventSourceMappingRequestFilterSensitiveLog = exports.DeleteCodeSigningConfigResponseFilterSensitiveLog = exports.DeleteCodeSigningConfigRequestFilterSensitiveLog = exports.DeleteAliasRequestFilterSensitiveLog = exports.CreateFunctionUrlConfigResponseFilterSensitiveLog = exports.CreateFunctionUrlConfigRequestFilterSensitiveLog = exports.CorsFilterSensitiveLog = exports.FunctionConfigurationFilterSensitiveLog = exports.VpcConfigResponseFilterSensitiveLog = exports.TracingConfigResponseFilterSensitiveLog = void 0;
|
|
2027
|
+
exports.UpdateFunctionUrlConfigRequestFilterSensitiveLog = exports.UpdateFunctionEventInvokeConfigRequestFilterSensitiveLog = exports.UpdateFunctionConfigurationRequestFilterSensitiveLog = exports.UpdateFunctionCodeRequestFilterSensitiveLog = exports.UpdateEventSourceMappingRequestFilterSensitiveLog = exports.UpdateCodeSigningConfigResponseFilterSensitiveLog = exports.UpdateCodeSigningConfigRequestFilterSensitiveLog = exports.UpdateAliasRequestFilterSensitiveLog = exports.UntagResourceRequestFilterSensitiveLog = exports.TagResourceRequestFilterSensitiveLog = exports.RemovePermissionRequestFilterSensitiveLog = exports.RemoveLayerVersionPermissionRequestFilterSensitiveLog = exports.PutProvisionedConcurrencyConfigResponseFilterSensitiveLog = exports.PutProvisionedConcurrencyConfigRequestFilterSensitiveLog = exports.PutFunctionEventInvokeConfigRequestFilterSensitiveLog = exports.PutFunctionConcurrencyRequestFilterSensitiveLog = exports.PutFunctionCodeSigningConfigResponseFilterSensitiveLog = exports.PutFunctionCodeSigningConfigRequestFilterSensitiveLog = exports.PublishVersionRequestFilterSensitiveLog = exports.PublishLayerVersionResponseFilterSensitiveLog = exports.PublishLayerVersionRequestFilterSensitiveLog = exports.LayerVersionContentInputFilterSensitiveLog = exports.ListVersionsByFunctionResponseFilterSensitiveLog = exports.ListVersionsByFunctionRequestFilterSensitiveLog = exports.ListTagsResponseFilterSensitiveLog = exports.ListTagsRequestFilterSensitiveLog = exports.ListProvisionedConcurrencyConfigsResponseFilterSensitiveLog = exports.ProvisionedConcurrencyConfigListItemFilterSensitiveLog = exports.ListProvisionedConcurrencyConfigsRequestFilterSensitiveLog = exports.ListLayerVersionsResponseFilterSensitiveLog = exports.ListLayerVersionsRequestFilterSensitiveLog = exports.ListLayersResponseFilterSensitiveLog = exports.LayersListItemFilterSensitiveLog = exports.LayerVersionsListItemFilterSensitiveLog = exports.ListLayersRequestFilterSensitiveLog = exports.ListFunctionUrlConfigsResponseFilterSensitiveLog = exports.FunctionUrlConfigFilterSensitiveLog = exports.ListFunctionUrlConfigsRequestFilterSensitiveLog = exports.ListFunctionsByCodeSigningConfigResponseFilterSensitiveLog = exports.ListFunctionsByCodeSigningConfigRequestFilterSensitiveLog = exports.ListFunctionsResponseFilterSensitiveLog = exports.ListFunctionsRequestFilterSensitiveLog = exports.ListFunctionEventInvokeConfigsResponseFilterSensitiveLog = exports.ListFunctionEventInvokeConfigsRequestFilterSensitiveLog = exports.ListEventSourceMappingsResponseFilterSensitiveLog = exports.ListEventSourceMappingsRequestFilterSensitiveLog = exports.ListCodeSigningConfigsResponseFilterSensitiveLog = exports.ListCodeSigningConfigsRequestFilterSensitiveLog = exports.ListAliasesResponseFilterSensitiveLog = exports.ListAliasesRequestFilterSensitiveLog = void 0;
|
|
2028
|
+
exports.UpdateFunctionUrlConfigResponseFilterSensitiveLog = void 0;
|
|
2028
2029
|
var smithy_client_1 = require_dist_cjs7();
|
|
2029
2030
|
var LambdaServiceException_1 = require_LambdaServiceException();
|
|
2030
2031
|
var InvalidParameterValueException = class extends LambdaServiceException_1.LambdaServiceException {
|
|
@@ -2839,6 +2840,10 @@ var require_models_0 = __commonJS({
|
|
|
2839
2840
|
...obj
|
|
2840
2841
|
});
|
|
2841
2842
|
exports.FilterCriteriaFilterSensitiveLog = FilterCriteriaFilterSensitiveLog;
|
|
2843
|
+
var ScalingConfigFilterSensitiveLog = (obj) => ({
|
|
2844
|
+
...obj
|
|
2845
|
+
});
|
|
2846
|
+
exports.ScalingConfigFilterSensitiveLog = ScalingConfigFilterSensitiveLog;
|
|
2842
2847
|
var SelfManagedEventSourceFilterSensitiveLog = (obj) => ({
|
|
2843
2848
|
...obj
|
|
2844
2849
|
});
|
|
@@ -3618,6 +3623,9 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
3618
3623
|
...input.MaximumRetryAttempts != null && { MaximumRetryAttempts: input.MaximumRetryAttempts },
|
|
3619
3624
|
...input.ParallelizationFactor != null && { ParallelizationFactor: input.ParallelizationFactor },
|
|
3620
3625
|
...input.Queues != null && { Queues: serializeAws_restJson1Queues(input.Queues, context) },
|
|
3626
|
+
...input.ScalingConfig != null && {
|
|
3627
|
+
ScalingConfig: serializeAws_restJson1ScalingConfig(input.ScalingConfig, context)
|
|
3628
|
+
},
|
|
3621
3629
|
...input.SelfManagedEventSource != null && {
|
|
3622
3630
|
SelfManagedEventSource: serializeAws_restJson1SelfManagedEventSource(input.SelfManagedEventSource, context)
|
|
3623
3631
|
},
|
|
@@ -3629,7 +3637,7 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
3629
3637
|
},
|
|
3630
3638
|
...input.StartingPosition != null && { StartingPosition: input.StartingPosition },
|
|
3631
3639
|
...input.StartingPositionTimestamp != null && {
|
|
3632
|
-
StartingPositionTimestamp: Math.round(input.StartingPositionTimestamp.getTime() / 1e3)
|
|
3640
|
+
StartingPositionTimestamp: Math.round(input.StartingPositionTimestamp.getTime() / 1e3).toString()
|
|
3633
3641
|
},
|
|
3634
3642
|
...input.Topics != null && { Topics: serializeAws_restJson1Topics(input.Topics, context) },
|
|
3635
3643
|
...input.TumblingWindowInSeconds != null && { TumblingWindowInSeconds: input.TumblingWindowInSeconds }
|
|
@@ -4851,6 +4859,9 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
4851
4859
|
...input.MaximumRecordAgeInSeconds != null && { MaximumRecordAgeInSeconds: input.MaximumRecordAgeInSeconds },
|
|
4852
4860
|
...input.MaximumRetryAttempts != null && { MaximumRetryAttempts: input.MaximumRetryAttempts },
|
|
4853
4861
|
...input.ParallelizationFactor != null && { ParallelizationFactor: input.ParallelizationFactor },
|
|
4862
|
+
...input.ScalingConfig != null && {
|
|
4863
|
+
ScalingConfig: serializeAws_restJson1ScalingConfig(input.ScalingConfig, context)
|
|
4864
|
+
},
|
|
4854
4865
|
...input.SourceAccessConfigurations != null && {
|
|
4855
4866
|
SourceAccessConfigurations: serializeAws_restJson1SourceAccessConfigurations(input.SourceAccessConfigurations, context)
|
|
4856
4867
|
},
|
|
@@ -5260,6 +5271,9 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
5260
5271
|
if (data.Queues != null) {
|
|
5261
5272
|
contents.Queues = deserializeAws_restJson1Queues(data.Queues, context);
|
|
5262
5273
|
}
|
|
5274
|
+
if (data.ScalingConfig != null) {
|
|
5275
|
+
contents.ScalingConfig = deserializeAws_restJson1ScalingConfig(data.ScalingConfig, context);
|
|
5276
|
+
}
|
|
5263
5277
|
if (data.SelfManagedEventSource != null) {
|
|
5264
5278
|
contents.SelfManagedEventSource = deserializeAws_restJson1SelfManagedEventSource(data.SelfManagedEventSource, context);
|
|
5265
5279
|
}
|
|
@@ -5673,6 +5687,9 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
5673
5687
|
if (data.Queues != null) {
|
|
5674
5688
|
contents.Queues = deserializeAws_restJson1Queues(data.Queues, context);
|
|
5675
5689
|
}
|
|
5690
|
+
if (data.ScalingConfig != null) {
|
|
5691
|
+
contents.ScalingConfig = deserializeAws_restJson1ScalingConfig(data.ScalingConfig, context);
|
|
5692
|
+
}
|
|
5676
5693
|
if (data.SelfManagedEventSource != null) {
|
|
5677
5694
|
contents.SelfManagedEventSource = deserializeAws_restJson1SelfManagedEventSource(data.SelfManagedEventSource, context);
|
|
5678
5695
|
}
|
|
@@ -6221,6 +6238,9 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
6221
6238
|
if (data.Queues != null) {
|
|
6222
6239
|
contents.Queues = deserializeAws_restJson1Queues(data.Queues, context);
|
|
6223
6240
|
}
|
|
6241
|
+
if (data.ScalingConfig != null) {
|
|
6242
|
+
contents.ScalingConfig = deserializeAws_restJson1ScalingConfig(data.ScalingConfig, context);
|
|
6243
|
+
}
|
|
6224
6244
|
if (data.SelfManagedEventSource != null) {
|
|
6225
6245
|
contents.SelfManagedEventSource = deserializeAws_restJson1SelfManagedEventSource(data.SelfManagedEventSource, context);
|
|
6226
6246
|
}
|
|
@@ -8435,6 +8455,9 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
8435
8455
|
if (data.Queues != null) {
|
|
8436
8456
|
contents.Queues = deserializeAws_restJson1Queues(data.Queues, context);
|
|
8437
8457
|
}
|
|
8458
|
+
if (data.ScalingConfig != null) {
|
|
8459
|
+
contents.ScalingConfig = deserializeAws_restJson1ScalingConfig(data.ScalingConfig, context);
|
|
8460
|
+
}
|
|
8438
8461
|
if (data.SelfManagedEventSource != null) {
|
|
8439
8462
|
contents.SelfManagedEventSource = deserializeAws_restJson1SelfManagedEventSource(data.SelfManagedEventSource, context);
|
|
8440
8463
|
}
|
|
@@ -9703,6 +9726,11 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
9703
9726
|
return entry;
|
|
9704
9727
|
});
|
|
9705
9728
|
};
|
|
9729
|
+
var serializeAws_restJson1ScalingConfig = (input, context) => {
|
|
9730
|
+
return {
|
|
9731
|
+
...input.MaximumConcurrency != null && { MaximumConcurrency: input.MaximumConcurrency }
|
|
9732
|
+
};
|
|
9733
|
+
};
|
|
9706
9734
|
var serializeAws_restJson1SecurityGroupIds = (input, context) => {
|
|
9707
9735
|
return input.filter((e) => e != null).map((entry) => {
|
|
9708
9736
|
return entry;
|
|
@@ -9990,6 +10018,7 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
9990
10018
|
MaximumRetryAttempts: (0, smithy_client_1.expectInt32)(output.MaximumRetryAttempts),
|
|
9991
10019
|
ParallelizationFactor: (0, smithy_client_1.expectInt32)(output.ParallelizationFactor),
|
|
9992
10020
|
Queues: output.Queues != null ? deserializeAws_restJson1Queues(output.Queues, context) : void 0,
|
|
10021
|
+
ScalingConfig: output.ScalingConfig != null ? deserializeAws_restJson1ScalingConfig(output.ScalingConfig, context) : void 0,
|
|
9993
10022
|
SelfManagedEventSource: output.SelfManagedEventSource != null ? deserializeAws_restJson1SelfManagedEventSource(output.SelfManagedEventSource, context) : void 0,
|
|
9994
10023
|
SelfManagedKafkaEventSourceConfig: output.SelfManagedKafkaEventSourceConfig != null ? deserializeAws_restJson1SelfManagedKafkaEventSourceConfig(output.SelfManagedKafkaEventSourceConfig, context) : void 0,
|
|
9995
10024
|
SourceAccessConfigurations: output.SourceAccessConfigurations != null ? deserializeAws_restJson1SourceAccessConfigurations(output.SourceAccessConfigurations, context) : void 0,
|
|
@@ -10284,6 +10313,11 @@ var require_Aws_restJson1 = __commonJS({
|
|
|
10284
10313
|
});
|
|
10285
10314
|
return retVal;
|
|
10286
10315
|
};
|
|
10316
|
+
var deserializeAws_restJson1ScalingConfig = (output, context) => {
|
|
10317
|
+
return {
|
|
10318
|
+
MaximumConcurrency: (0, smithy_client_1.expectInt32)(output.MaximumConcurrency)
|
|
10319
|
+
};
|
|
10320
|
+
};
|
|
10287
10321
|
var deserializeAws_restJson1SecurityGroupIds = (output, context) => {
|
|
10288
10322
|
const retVal = (output || []).filter((e) => e != null).map((entry) => {
|
|
10289
10323
|
if (entry === null) {
|
|
@@ -16567,7 +16601,7 @@ var require_package = __commonJS({
|
|
|
16567
16601
|
module2.exports = {
|
|
16568
16602
|
name: "@aws-sdk/client-lambda",
|
|
16569
16603
|
description: "AWS SDK for JavaScript Lambda Client for Node.js, Browser and React Native",
|
|
16570
|
-
version: "3.
|
|
16604
|
+
version: "3.250.0",
|
|
16571
16605
|
scripts: {
|
|
16572
16606
|
build: "concurrently 'yarn:build:cjs' 'yarn:build:es' 'yarn:build:types'",
|
|
16573
16607
|
"build:cjs": "tsc -p tsconfig.cjs.json",
|
|
@@ -17352,8 +17386,10 @@ var require_DocTypeReader = __commonJS({
|
|
|
17352
17386
|
i += 8;
|
|
17353
17387
|
} else if (hasBody && xmlData[i + 1] === "!" && xmlData[i + 2] === "N" && xmlData[i + 3] === "O" && xmlData[i + 4] === "T" && xmlData[i + 5] === "A" && xmlData[i + 6] === "T" && xmlData[i + 7] === "I" && xmlData[i + 8] === "O" && xmlData[i + 9] === "N") {
|
|
17354
17388
|
i += 9;
|
|
17355
|
-
} else if (
|
|
17356
|
-
|
|
17389
|
+
} else if (
|
|
17390
|
+
//comment
|
|
17391
|
+
xmlData[i + 1] === "!" && xmlData[i + 2] === "-" && xmlData[i + 3] === "-"
|
|
17392
|
+
) {
|
|
17357
17393
|
comment = true;
|
|
17358
17394
|
} else {
|
|
17359
17395
|
throw new Error("Invalid DOCTYPE");
|
|
@@ -26989,9 +27025,9 @@ var require_ruleset4 = __commonJS({
|
|
|
26989
27025
|
"use strict";
|
|
26990
27026
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26991
27027
|
exports.ruleSet = void 0;
|
|
26992
|
-
var
|
|
26993
|
-
var
|
|
26994
|
-
var
|
|
27028
|
+
var q = "fn";
|
|
27029
|
+
var r = "argv";
|
|
27030
|
+
var s = "ref";
|
|
26995
27031
|
var a = true;
|
|
26996
27032
|
var b = false;
|
|
26997
27033
|
var c = "String";
|
|
@@ -27000,16 +27036,15 @@ var require_ruleset4 = __commonJS({
|
|
|
27000
27036
|
var f = "error";
|
|
27001
27037
|
var g = "endpoint";
|
|
27002
27038
|
var h = { "required": true, "default": false, "type": "Boolean" };
|
|
27003
|
-
var i = { [
|
|
27004
|
-
var j = { [
|
|
27005
|
-
var k = { [
|
|
27039
|
+
var i = { [s]: "Endpoint" };
|
|
27040
|
+
var j = { [q]: "booleanEquals", [r]: [{ [s]: "UseFIPS" }, true] };
|
|
27041
|
+
var k = { [q]: "booleanEquals", [r]: [{ [s]: "UseDualStack" }, true] };
|
|
27006
27042
|
var l = {};
|
|
27007
|
-
var m = { [
|
|
27008
|
-
var n = { [
|
|
27009
|
-
var o = [
|
|
27010
|
-
var p = [
|
|
27011
|
-
var
|
|
27012
|
-
var _data = { version: "1.0", parameters: { Region: { required: a, type: c }, UseDualStack: h, UseFIPS: h, Endpoint: { required: b, type: c } }, rules: [{ conditions: [{ [r]: "aws.partition", [s]: [{ [t]: "Region" }], assign: d }], type: e, rules: [{ conditions: [{ [r]: "isSet", [s]: o }, { [r]: "parseURL", [s]: o, assign: "url" }], type: e, rules: [{ conditions: p, error: "Invalid Configuration: FIPS and custom endpoint are not supported", type: f }, { type: e, rules: [{ conditions: q, error: "Invalid Configuration: Dualstack and custom endpoint are not supported", type: f }, { endpoint: { url: i, properties: l, headers: l }, type: g }] }] }, { conditions: [j, k], type: e, rules: [{ conditions: [m, n], type: e, rules: [{ endpoint: { url: "https://lambda-fips.{Region}.{PartitionResult#dualStackDnsSuffix}", properties: l, headers: l }, type: g }] }, { error: "FIPS and DualStack are enabled, but this partition does not support one or both", type: f }] }, { conditions: p, type: e, rules: [{ conditions: [m], type: e, rules: [{ type: e, rules: [{ endpoint: { url: "https://lambda-fips.{Region}.{PartitionResult#dnsSuffix}", properties: l, headers: l }, type: g }] }] }, { error: "FIPS is enabled but this partition does not support FIPS", type: f }] }, { conditions: q, type: e, rules: [{ conditions: [n], type: e, rules: [{ endpoint: { url: "https://lambda.{Region}.{PartitionResult#dualStackDnsSuffix}", properties: l, headers: l }, type: g }] }, { error: "DualStack is enabled but this partition does not support DualStack", type: f }] }, { endpoint: { url: "https://lambda.{Region}.{PartitionResult#dnsSuffix}", properties: l, headers: l }, type: g }] }] };
|
|
27043
|
+
var m = { [q]: "booleanEquals", [r]: [true, { [q]: "getAttr", [r]: [{ [s]: d }, "supportsFIPS"] }] };
|
|
27044
|
+
var n = { [q]: "booleanEquals", [r]: [true, { [q]: "getAttr", [r]: [{ [s]: d }, "supportsDualStack"] }] };
|
|
27045
|
+
var o = [j];
|
|
27046
|
+
var p = [k];
|
|
27047
|
+
var _data = { version: "1.0", parameters: { Region: { required: a, type: c }, UseDualStack: h, UseFIPS: h, Endpoint: { required: b, type: c } }, rules: [{ conditions: [{ [q]: "aws.partition", [r]: [{ [s]: "Region" }], assign: d }], type: e, rules: [{ conditions: [{ [q]: "isSet", [r]: [i] }], type: e, rules: [{ conditions: o, error: "Invalid Configuration: FIPS and custom endpoint are not supported", type: f }, { type: e, rules: [{ conditions: p, error: "Invalid Configuration: Dualstack and custom endpoint are not supported", type: f }, { endpoint: { url: i, properties: l, headers: l }, type: g }] }] }, { conditions: [j, k], type: e, rules: [{ conditions: [m, n], type: e, rules: [{ endpoint: { url: "https://lambda-fips.{Region}.{PartitionResult#dualStackDnsSuffix}", properties: l, headers: l }, type: g }] }, { error: "FIPS and DualStack are enabled, but this partition does not support one or both", type: f }] }, { conditions: o, type: e, rules: [{ conditions: [m], type: e, rules: [{ type: e, rules: [{ endpoint: { url: "https://lambda-fips.{Region}.{PartitionResult#dnsSuffix}", properties: l, headers: l }, type: g }] }] }, { error: "FIPS is enabled but this partition does not support FIPS", type: f }] }, { conditions: p, type: e, rules: [{ conditions: [n], type: e, rules: [{ endpoint: { url: "https://lambda.{Region}.{PartitionResult#dualStackDnsSuffix}", properties: l, headers: l }, type: g }] }, { error: "DualStack is enabled but this partition does not support DualStack", type: f }] }, { endpoint: { url: "https://lambda.{Region}.{PartitionResult#dnsSuffix}", properties: l, headers: l }, type: g }] }] };
|
|
27013
27048
|
exports.ruleSet = _data;
|
|
27014
27049
|
}
|
|
27015
27050
|
});
|
|
@@ -188,7 +188,7 @@ class CodeBuildRunner extends common_1.BaseProvider {
|
|
|
188
188
|
}
|
|
189
189
|
exports.CodeBuildRunner = CodeBuildRunner;
|
|
190
190
|
_a = JSII_RTTI_SYMBOL_1;
|
|
191
|
-
CodeBuildRunner[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.7.
|
|
191
|
+
CodeBuildRunner[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.7.6" };
|
|
192
192
|
/**
|
|
193
193
|
* Path to Dockerfile for Linux x64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
|
|
194
194
|
*
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { aws_ec2 as ec2, aws_ecr as ecr, aws_iam as iam, aws_logs as logs, aws_stepfunctions as stepfunctions, Duration } from 'aws-cdk-lib';
|
|
2
|
-
import { Construct } from 'constructs';
|
|
2
|
+
import { Construct, IConstruct } from 'constructs';
|
|
3
3
|
/**
|
|
4
4
|
* Defines desired GitHub Actions runner version.
|
|
5
5
|
*/
|
|
@@ -322,7 +322,7 @@ export interface IRunnerProviderStatus {
|
|
|
322
322
|
/**
|
|
323
323
|
* Interface for all runner providers. Implementations create all required resources and return a step function task that starts those resources from {@link getStepFunctionTask}.
|
|
324
324
|
*/
|
|
325
|
-
export interface IRunnerProvider extends ec2.IConnectable, iam.IGrantable {
|
|
325
|
+
export interface IRunnerProvider extends ec2.IConnectable, iam.IGrantable, IConstruct {
|
|
326
326
|
/**
|
|
327
327
|
* GitHub Actions labels used for this provider.
|
|
328
328
|
*
|
|
@@ -362,5 +362,5 @@ export declare abstract class BaseProvider extends Construct {
|
|
|
362
362
|
private readonly retryOptions?;
|
|
363
363
|
protected constructor(scope: Construct, id: string, props?: RunnerProviderProps);
|
|
364
364
|
protected labelsFromProperties(defaultLabel: string, propsLabel: string | undefined, propsLabels: string[] | undefined): string[];
|
|
365
|
-
protected addRetry(task: stepfunctions.TaskStateBase, errors: string[]): void;
|
|
365
|
+
protected addRetry(task: stepfunctions.TaskStateBase | stepfunctions.Parallel, errors: string[]): void;
|
|
366
366
|
}
|
package/lib/providers/common.js
CHANGED
|
@@ -39,7 +39,7 @@ class RunnerVersion {
|
|
|
39
39
|
}
|
|
40
40
|
exports.RunnerVersion = RunnerVersion;
|
|
41
41
|
_a = JSII_RTTI_SYMBOL_1;
|
|
42
|
-
RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.7.
|
|
42
|
+
RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.7.6" };
|
|
43
43
|
/**
|
|
44
44
|
* CPU architecture enum for an image.
|
|
45
45
|
*/
|
|
@@ -88,7 +88,7 @@ class Architecture {
|
|
|
88
88
|
}
|
|
89
89
|
exports.Architecture = Architecture;
|
|
90
90
|
_b = JSII_RTTI_SYMBOL_1;
|
|
91
|
-
Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.7.
|
|
91
|
+
Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.7.6" };
|
|
92
92
|
/**
|
|
93
93
|
* ARM64
|
|
94
94
|
*/
|
|
@@ -131,7 +131,7 @@ class Os {
|
|
|
131
131
|
}
|
|
132
132
|
exports.Os = Os;
|
|
133
133
|
_c = JSII_RTTI_SYMBOL_1;
|
|
134
|
-
Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.7.
|
|
134
|
+
Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.7.6" };
|
|
135
135
|
/**
|
|
136
136
|
* Linux
|
|
137
137
|
*/
|
|
@@ -174,4 +174,4 @@ class BaseProvider extends constructs_1.Construct {
|
|
|
174
174
|
}
|
|
175
175
|
}
|
|
176
176
|
exports.BaseProvider = BaseProvider;
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/providers/common.ts"],"names":[],"mappings":"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","sourcesContent":["import { aws_ec2 as ec2, aws_ecr as ecr, aws_iam as iam, aws_logs as logs, aws_stepfunctions as stepfunctions, Duration } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\n\n/**\n * Defines desired GitHub Actions runner version.\n */\nexport class RunnerVersion {\n  /**\n   * Use the latest version available at the time the runner provider image is built.\n   */\n  public static latest(): RunnerVersion {\n    return new RunnerVersion('latest');\n  }\n\n  /**\n   * Use a specific version.\n   *\n   * @see https://github.com/actions/runner/releases\n   *\n   * @param version GitHub Runner version\n   */\n  public static specific(version: string) {\n    return new RunnerVersion(version);\n  }\n\n  protected constructor(readonly version: string) {\n  }\n\n  /**\n   * Check if two versions are the same.\n   *\n   * @param other version to compare\n   */\n  public is(other: RunnerVersion) {\n    return this.version == other.version;\n  }\n}\n\n/**\n * CPU architecture enum for an image.\n */\nexport class Architecture {\n  /**\n   * ARM64\n   */\n  public static readonly ARM64 = Architecture.of('ARM64');\n\n  /**\n   * X86_64\n   */\n  public static readonly X86_64 = Architecture.of('X86_64');\n\n  private static of(architecture: string) {\n    return new Architecture(architecture);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given architecture is the same as this one.\n  *\n  * @param arch architecture to compare\n  */\n  public is(arch: Architecture): boolean {\n    return arch.name == this.name;\n  }\n\n  /**\n   * Checks if this architecture is in a given list.\n   *\n   * @param arches architectures to check\n   */\n  public isIn(arches: Architecture[]): boolean {\n    for (const arch of arches) {\n      if (this.is(arch)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Checks if a given EC2 instance type matches this architecture.\n   *\n   * @param instanceType instance type to check\n   */\n  public instanceTypeMatch(instanceType: ec2.InstanceType): boolean {\n    if (instanceType.architecture == ec2.InstanceArchitecture.X86_64) {\n      return this.is(Architecture.X86_64);\n    }\n    if (instanceType.architecture == ec2.InstanceArchitecture.ARM_64) {\n      return this.is(Architecture.ARM64);\n    }\n    throw new Error('Unknown instance type architecture');\n  }\n}\n\n/**\n * OS enum for an image.\n */\nexport class Os {\n  /**\n  * Linux\n  */\n  public static readonly LINUX = Os.of('Linux');\n\n  /**\n  * Windows\n  */\n  public static readonly WINDOWS = Os.of('Windows');\n\n  private static of(os: string) {\n    return new Os(os);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given OS is the same as this one.\n  *\n  * @param os OS to compare\n  */\n  public is(os: Os) {\n    return os.name == this.name;\n  }\n\n  /**\n   * Checks if this OS is in a given list.\n   *\n   * @param oses list of OS to check\n   */\n  public isIn(oses: Os[]): boolean {\n    for (const os of oses) {\n      if (this.is(os)) {\n        return true;\n      }\n    }\n    return false;\n  }\n}\n\n/**\n * Description of a Docker image built by {@link IImageBuilder}.\n */\nexport interface RunnerImage {\n  /**\n   * ECR repository containing the image.\n   */\n  readonly imageRepository: ecr.IRepository;\n\n  /**\n   * Static image tag where the image will be pushed.\n   */\n  readonly imageTag: string;\n\n  /**\n   * Architecture of the image.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * OS type of the image.\n   */\n  readonly os: Os;\n\n  /**\n   * Log group where image builds are logged.\n   */\n  readonly logGroup?: logs.LogGroup;\n\n  /**\n   * Installed runner version.\n   */\n  readonly runnerVersion: RunnerVersion;\n}\n\n/**\n * Interface for constructs that build an image that can be used in {@link IRunnerProvider}.\n *\n * Anything that ends up with an ECR repository containing a Docker image that runs GitHub self-hosted runners can be used. A simple implementation could even point to an existing image and nothing else.\n *\n * It's important that the specified image tag be available at the time the repository is available. Providers usually assume the image is ready and will fail if it's not.\n *\n * The image can be further updated over time manually or using a schedule as long as it is always written to the same tag.\n */\nexport interface IImageBuilder {\n  /**\n   * Finalize and return all required information about the Docker image built by this builder.\n   *\n   * This method can be called multiple times if the image is bound to multiple providers. Make sure you cache the image when implementing or return an error if this builder doesn't support reusing images.\n   *\n   * @return image\n   */\n  bind(): RunnerImage;\n}\n\n/**\n * Description of a AMI built by {@link IAmiBuilder}.\n */\nexport interface RunnerAmi {\n  /**\n   * Launch template pointing to the latest AMI.\n   */\n  readonly launchTemplate: ec2.ILaunchTemplate;\n\n  /**\n   * Architecture of the image.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * OS type of the image.\n   */\n  readonly os: Os;\n\n  /**\n   * Log group where image builds are logged.\n   */\n  readonly logGroup?: logs.LogGroup;\n\n  /**\n   * Installed runner version.\n   */\n  readonly runnerVersion: RunnerVersion;\n}\n\n/**\n * Interface for constructs that build an AMI that can be used in {@link IRunnerProvider}.\n *\n * Anything that ends up with a launch template pointing to an AMI that runs GitHub self-hosted runners can be used. A simple implementation could even point to an existing AMI and nothing else.\n *\n * The AMI can be further updated over time manually or using a schedule as long as it is always written to the same launch template.\n */\nexport interface IAmiBuilder {\n  /**\n   * Finalize and return all required information about the AMI built by this builder.\n   *\n   * This method can be called multiple times if the image is bound to multiple providers. Make sure you cache the image when implementing or return an error if this builder doesn't support reusing images.\n   *\n   * @return ami\n   */\n  bind(): RunnerAmi;\n}\n\n/**\n * Retry options for providers. The default is to retry 10 times for about 45 minutes with increasing interval.\n */\nexport interface ProviderRetryOptions {\n  /**\n   * Set to true to retry provider on supported failures. Which failures generate a retry depends on the specific provider.\n   *\n   * @default true\n   */\n  readonly retry?: boolean;\n\n  /**\n   * How much time to wait after first retryable failure. This interval will be multiplied by {@link backoffRate} each retry.\n   *\n   * @default 1 minute\n   */\n  readonly interval?: Duration;\n\n  /**\n   * How many times to retry.\n   *\n   * @default 10\n   */\n  readonly maxAttempts?: number;\n\n  /**\n   * Multiplication for how much longer the wait interval gets on every retry.\n   *\n   * @default 1.3\n   */\n  readonly backoffRate?: number;\n}\n\n/**\n * Common properties for all runner providers.\n */\nexport interface RunnerProviderProps {\n  /**\n   * The number of days log events are kept in CloudWatch Logs. When updating\n   * this property, unsetting it doesn't remove the log retention policy. To\n   * remove the retention policy, set the value to `INFINITE`.\n   *\n   * @default logs.RetentionDays.ONE_MONTH\n   */\n  readonly logRetention?: logs.RetentionDays;\n\n  /**\n   * Options to retry operation in case of failure like missing capacity, or API quota issues.\n   *\n   * @default retry 10 times up to about 45 minutes\n   */\n  readonly retryOptions?: ProviderRetryOptions;\n}\n\n/**\n * Workflow job parameters as parsed from the webhook event. Pass these into your runner executor and run something like:\n *\n * ```sh\n * ./config.sh --unattended --url \"https://${GITHUB_DOMAIN}/${OWNER}/${REPO}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL}\" --name \"${RUNNER_NAME}\" --disableupdate\n * ```\n *\n * All parameters are specified as step function paths and therefore must be used only in step function task parameters.\n */\nexport interface RunnerRuntimeParameters {\n  /**\n   * Path to runner token used to register token.\n   */\n  readonly runnerTokenPath: string;\n\n  /**\n   * Path to desired runner name. We specifically set the name to make troubleshooting easier.\n   */\n  readonly runnerNamePath: string;\n\n  /**\n   * Path to GitHub domain. Most of the time this will be github.com but for self-hosted GitHub instances, this will be different.\n   */\n  readonly githubDomainPath: string;\n\n  /**\n   * Path to repostiroy owner name.\n   */\n  readonly ownerPath: string;\n\n  /**\n   * Path to repository name.\n   */\n  readonly repoPath: string;\n}\n\n/**\n * Image status returned from runner providers to be displayed in status.json.\n */\nexport interface IRunnerImageStatus {\n  /**\n   * Image repository where image builder pushes runner images.\n   */\n  readonly imageRepository: string;\n\n  /**\n   * Tag of image that should be used.\n   */\n  readonly imageTag: string;\n\n  /**\n   * Log group name for the image builder where history of image builds can be analyzed.\n   */\n  readonly imageBuilderLogGroup?: string;\n}\n\n/**\n * AMI status returned from runner providers to be displayed as output of status function.\n */\nexport interface IRunnerAmiStatus {\n  /**\n   * Id of launch template pointing to the latest AMI built by the AMI builder.\n   */\n  readonly launchTemplate: string;\n\n  /**\n   * Log group name for the AMI builder where history of builds can be analyzed.\n   */\n  readonly amiBuilderLogGroup?: string;\n}\n\n/**\n * Interface for runner image status used by status.json.\n */\nexport interface IRunnerProviderStatus {\n  /**\n   * Runner provider type.\n   */\n  readonly type: string;\n\n  /**\n   * Labels associated with provider.\n   */\n  readonly labels: string[];\n\n  /**\n   * VPC where runners will be launched.\n   */\n  readonly vpcArn?: string;\n\n  /**\n   * Security groups attached to runners.\n   */\n  readonly securityGroups?: string[];\n\n  /**\n   * Role attached to runners.\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Details about Docker image used by this runner provider.\n   */\n  readonly image?: IRunnerImageStatus;\n\n  /**\n   * Details about AMI used by this runner provider.\n   */\n  readonly ami?: IRunnerAmiStatus;\n}\n\n/**\n * Interface for all runner providers. Implementations create all required resources and return a step function task that starts those resources from {@link getStepFunctionTask}.\n */\nexport interface IRunnerProvider extends ec2.IConnectable, iam.IGrantable {\n  /**\n   * GitHub Actions labels used for this provider.\n   *\n   * These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for\n   * based on runs-on. We use match the labels from the webhook with the labels specified here. If all the labels specified here are present in the\n   * job's labels, this provider will be chosen and spawn a new runner.\n   */\n  readonly labels: string[];\n\n  /**\n   * Generate step function tasks that execute the runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters specific build parameters\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable;\n\n  /**\n   * An optional method that modifies the role of the state machine after all the tasks have been generated. This can be used to add additional policy\n   * statements to the state machine role that are not automatically added by the task returned from {@link getStepFunctionTask}.\n   *\n   * @param stateMachineRole role for the state machine that executes the task returned from {@link getStepFunctionTask}.\n   */\n  grantStateMachine(stateMachineRole: iam.IGrantable): void;\n\n  /**\n   * Return status of the runner provider to be used in the main status function. Also gives the status function any needed permissions to query the Docker image or AMI.\n   *\n   * @param statusFunctionRole grantable for the status function\n   */\n  status(statusFunctionRole: iam.IGrantable): IRunnerProviderStatus;\n}\n\n/**\n * Base class for all providers with common methods used by all providers.\n *\n * @internal\n */\nexport abstract class BaseProvider extends Construct {\n  private readonly retryOptions?: ProviderRetryOptions;\n\n  protected constructor(scope: Construct, id: string, props?: RunnerProviderProps) {\n    super(scope, id);\n    this.retryOptions = props?.retryOptions;\n  }\n\n  protected labelsFromProperties(defaultLabel: string, propsLabel: string | undefined, propsLabels: string[] | undefined): string[] {\n    if (propsLabels && propsLabel) {\n      throw new Error('Must supply either `label` or `labels` in runner properties, but not both. Try removing the `label` property.');\n    }\n\n    if (propsLabels) {\n      return propsLabels;\n    }\n    if (propsLabel) {\n      return [propsLabel];\n    }\n    return [defaultLabel];\n  }\n\n  protected addRetry(task: stepfunctions.TaskStateBase, errors: string[]) {\n    if (this.retryOptions?.retry ?? true) {\n      task.addRetry({\n        errors,\n        interval: this.retryOptions?.interval ?? Duration.minutes(1),\n        maxAttempts: this.retryOptions?.maxAttempts ?? 10,\n        backoffRate: this.retryOptions?.backoffRate ?? 1.3,\n      });\n    }\n  }\n}\n"]}
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/providers/common.ts"],"names":[],"mappings":"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","sourcesContent":["import { aws_ec2 as ec2, aws_ecr as ecr, aws_iam as iam, aws_logs as logs, aws_stepfunctions as stepfunctions, Duration } from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\n\n/**\n * Defines desired GitHub Actions runner version.\n */\nexport class RunnerVersion {\n  /**\n   * Use the latest version available at the time the runner provider image is built.\n   */\n  public static latest(): RunnerVersion {\n    return new RunnerVersion('latest');\n  }\n\n  /**\n   * Use a specific version.\n   *\n   * @see https://github.com/actions/runner/releases\n   *\n   * @param version GitHub Runner version\n   */\n  public static specific(version: string) {\n    return new RunnerVersion(version);\n  }\n\n  protected constructor(readonly version: string) {\n  }\n\n  /**\n   * Check if two versions are the same.\n   *\n   * @param other version to compare\n   */\n  public is(other: RunnerVersion) {\n    return this.version == other.version;\n  }\n}\n\n/**\n * CPU architecture enum for an image.\n */\nexport class Architecture {\n  /**\n   * ARM64\n   */\n  public static readonly ARM64 = Architecture.of('ARM64');\n\n  /**\n   * X86_64\n   */\n  public static readonly X86_64 = Architecture.of('X86_64');\n\n  private static of(architecture: string) {\n    return new Architecture(architecture);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given architecture is the same as this one.\n  *\n  * @param arch architecture to compare\n  */\n  public is(arch: Architecture): boolean {\n    return arch.name == this.name;\n  }\n\n  /**\n   * Checks if this architecture is in a given list.\n   *\n   * @param arches architectures to check\n   */\n  public isIn(arches: Architecture[]): boolean {\n    for (const arch of arches) {\n      if (this.is(arch)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Checks if a given EC2 instance type matches this architecture.\n   *\n   * @param instanceType instance type to check\n   */\n  public instanceTypeMatch(instanceType: ec2.InstanceType): boolean {\n    if (instanceType.architecture == ec2.InstanceArchitecture.X86_64) {\n      return this.is(Architecture.X86_64);\n    }\n    if (instanceType.architecture == ec2.InstanceArchitecture.ARM_64) {\n      return this.is(Architecture.ARM64);\n    }\n    throw new Error('Unknown instance type architecture');\n  }\n}\n\n/**\n * OS enum for an image.\n */\nexport class Os {\n  /**\n  * Linux\n  */\n  public static readonly LINUX = Os.of('Linux');\n\n  /**\n  * Windows\n  */\n  public static readonly WINDOWS = Os.of('Windows');\n\n  private static of(os: string) {\n    return new Os(os);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given OS is the same as this one.\n  *\n  * @param os OS to compare\n  */\n  public is(os: Os) {\n    return os.name == this.name;\n  }\n\n  /**\n   * Checks if this OS is in a given list.\n   *\n   * @param oses list of OS to check\n   */\n  public isIn(oses: Os[]): boolean {\n    for (const os of oses) {\n      if (this.is(os)) {\n        return true;\n      }\n    }\n    return false;\n  }\n}\n\n/**\n * Description of a Docker image built by {@link IImageBuilder}.\n */\nexport interface RunnerImage {\n  /**\n   * ECR repository containing the image.\n   */\n  readonly imageRepository: ecr.IRepository;\n\n  /**\n   * Static image tag where the image will be pushed.\n   */\n  readonly imageTag: string;\n\n  /**\n   * Architecture of the image.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * OS type of the image.\n   */\n  readonly os: Os;\n\n  /**\n   * Log group where image builds are logged.\n   */\n  readonly logGroup?: logs.LogGroup;\n\n  /**\n   * Installed runner version.\n   */\n  readonly runnerVersion: RunnerVersion;\n}\n\n/**\n * Interface for constructs that build an image that can be used in {@link IRunnerProvider}.\n *\n * Anything that ends up with an ECR repository containing a Docker image that runs GitHub self-hosted runners can be used. A simple implementation could even point to an existing image and nothing else.\n *\n * It's important that the specified image tag be available at the time the repository is available. Providers usually assume the image is ready and will fail if it's not.\n *\n * The image can be further updated over time manually or using a schedule as long as it is always written to the same tag.\n */\nexport interface IImageBuilder {\n  /**\n   * Finalize and return all required information about the Docker image built by this builder.\n   *\n   * This method can be called multiple times if the image is bound to multiple providers. Make sure you cache the image when implementing or return an error if this builder doesn't support reusing images.\n   *\n   * @return image\n   */\n  bind(): RunnerImage;\n}\n\n/**\n * Description of a AMI built by {@link IAmiBuilder}.\n */\nexport interface RunnerAmi {\n  /**\n   * Launch template pointing to the latest AMI.\n   */\n  readonly launchTemplate: ec2.ILaunchTemplate;\n\n  /**\n   * Architecture of the image.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * OS type of the image.\n   */\n  readonly os: Os;\n\n  /**\n   * Log group where image builds are logged.\n   */\n  readonly logGroup?: logs.LogGroup;\n\n  /**\n   * Installed runner version.\n   */\n  readonly runnerVersion: RunnerVersion;\n}\n\n/**\n * Interface for constructs that build an AMI that can be used in {@link IRunnerProvider}.\n *\n * Anything that ends up with a launch template pointing to an AMI that runs GitHub self-hosted runners can be used. A simple implementation could even point to an existing AMI and nothing else.\n *\n * The AMI can be further updated over time manually or using a schedule as long as it is always written to the same launch template.\n */\nexport interface IAmiBuilder {\n  /**\n   * Finalize and return all required information about the AMI built by this builder.\n   *\n   * This method can be called multiple times if the image is bound to multiple providers. Make sure you cache the image when implementing or return an error if this builder doesn't support reusing images.\n   *\n   * @return ami\n   */\n  bind(): RunnerAmi;\n}\n\n/**\n * Retry options for providers. The default is to retry 10 times for about 45 minutes with increasing interval.\n */\nexport interface ProviderRetryOptions {\n  /**\n   * Set to true to retry provider on supported failures. Which failures generate a retry depends on the specific provider.\n   *\n   * @default true\n   */\n  readonly retry?: boolean;\n\n  /**\n   * How much time to wait after first retryable failure. This interval will be multiplied by {@link backoffRate} each retry.\n   *\n   * @default 1 minute\n   */\n  readonly interval?: Duration;\n\n  /**\n   * How many times to retry.\n   *\n   * @default 10\n   */\n  readonly maxAttempts?: number;\n\n  /**\n   * Multiplication for how much longer the wait interval gets on every retry.\n   *\n   * @default 1.3\n   */\n  readonly backoffRate?: number;\n}\n\n/**\n * Common properties for all runner providers.\n */\nexport interface RunnerProviderProps {\n  /**\n   * The number of days log events are kept in CloudWatch Logs. When updating\n   * this property, unsetting it doesn't remove the log retention policy. To\n   * remove the retention policy, set the value to `INFINITE`.\n   *\n   * @default logs.RetentionDays.ONE_MONTH\n   */\n  readonly logRetention?: logs.RetentionDays;\n\n  /**\n   * Options to retry operation in case of failure like missing capacity, or API quota issues.\n   *\n   * @default retry 10 times up to about 45 minutes\n   */\n  readonly retryOptions?: ProviderRetryOptions;\n}\n\n/**\n * Workflow job parameters as parsed from the webhook event. Pass these into your runner executor and run something like:\n *\n * ```sh\n * ./config.sh --unattended --url \"https://${GITHUB_DOMAIN}/${OWNER}/${REPO}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL}\" --name \"${RUNNER_NAME}\" --disableupdate\n * ```\n *\n * All parameters are specified as step function paths and therefore must be used only in step function task parameters.\n */\nexport interface RunnerRuntimeParameters {\n  /**\n   * Path to runner token used to register token.\n   */\n  readonly runnerTokenPath: string;\n\n  /**\n   * Path to desired runner name. We specifically set the name to make troubleshooting easier.\n   */\n  readonly runnerNamePath: string;\n\n  /**\n   * Path to GitHub domain. Most of the time this will be github.com but for self-hosted GitHub instances, this will be different.\n   */\n  readonly githubDomainPath: string;\n\n  /**\n   * Path to repostiroy owner name.\n   */\n  readonly ownerPath: string;\n\n  /**\n   * Path to repository name.\n   */\n  readonly repoPath: string;\n}\n\n/**\n * Image status returned from runner providers to be displayed in status.json.\n */\nexport interface IRunnerImageStatus {\n  /**\n   * Image repository where image builder pushes runner images.\n   */\n  readonly imageRepository: string;\n\n  /**\n   * Tag of image that should be used.\n   */\n  readonly imageTag: string;\n\n  /**\n   * Log group name for the image builder where history of image builds can be analyzed.\n   */\n  readonly imageBuilderLogGroup?: string;\n}\n\n/**\n * AMI status returned from runner providers to be displayed as output of status function.\n */\nexport interface IRunnerAmiStatus {\n  /**\n   * Id of launch template pointing to the latest AMI built by the AMI builder.\n   */\n  readonly launchTemplate: string;\n\n  /**\n   * Log group name for the AMI builder where history of builds can be analyzed.\n   */\n  readonly amiBuilderLogGroup?: string;\n}\n\n/**\n * Interface for runner image status used by status.json.\n */\nexport interface IRunnerProviderStatus {\n  /**\n   * Runner provider type.\n   */\n  readonly type: string;\n\n  /**\n   * Labels associated with provider.\n   */\n  readonly labels: string[];\n\n  /**\n   * VPC where runners will be launched.\n   */\n  readonly vpcArn?: string;\n\n  /**\n   * Security groups attached to runners.\n   */\n  readonly securityGroups?: string[];\n\n  /**\n   * Role attached to runners.\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Details about Docker image used by this runner provider.\n   */\n  readonly image?: IRunnerImageStatus;\n\n  /**\n   * Details about AMI used by this runner provider.\n   */\n  readonly ami?: IRunnerAmiStatus;\n}\n\n/**\n * Interface for all runner providers. Implementations create all required resources and return a step function task that starts those resources from {@link getStepFunctionTask}.\n */\nexport interface IRunnerProvider extends ec2.IConnectable, iam.IGrantable, IConstruct {\n  /**\n   * GitHub Actions labels used for this provider.\n   *\n   * These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for\n   * based on runs-on. We use match the labels from the webhook with the labels specified here. If all the labels specified here are present in the\n   * job's labels, this provider will be chosen and spawn a new runner.\n   */\n  readonly labels: string[];\n\n  /**\n   * Generate step function tasks that execute the runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters specific build parameters\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable;\n\n  /**\n   * An optional method that modifies the role of the state machine after all the tasks have been generated. This can be used to add additional policy\n   * statements to the state machine role that are not automatically added by the task returned from {@link getStepFunctionTask}.\n   *\n   * @param stateMachineRole role for the state machine that executes the task returned from {@link getStepFunctionTask}.\n   */\n  grantStateMachine(stateMachineRole: iam.IGrantable): void;\n\n  /**\n   * Return status of the runner provider to be used in the main status function. Also gives the status function any needed permissions to query the Docker image or AMI.\n   *\n   * @param statusFunctionRole grantable for the status function\n   */\n  status(statusFunctionRole: iam.IGrantable): IRunnerProviderStatus;\n}\n\n/**\n * Base class for all providers with common methods used by all providers.\n *\n * @internal\n */\nexport abstract class BaseProvider extends Construct {\n  private readonly retryOptions?: ProviderRetryOptions;\n\n  protected constructor(scope: Construct, id: string, props?: RunnerProviderProps) {\n    super(scope, id);\n    this.retryOptions = props?.retryOptions;\n  }\n\n  protected labelsFromProperties(defaultLabel: string, propsLabel: string | undefined, propsLabels: string[] | undefined): string[] {\n    if (propsLabels && propsLabel) {\n      throw new Error('Must supply either `label` or `labels` in runner properties, but not both. Try removing the `label` property.');\n    }\n\n    if (propsLabels) {\n      return propsLabels;\n    }\n    if (propsLabel) {\n      return [propsLabel];\n    }\n    return [defaultLabel];\n  }\n\n  protected addRetry(task: stepfunctions.TaskStateBase | stepfunctions.Parallel, errors: string[]) {\n    if (this.retryOptions?.retry ?? true) {\n      task.addRetry({\n        errors,\n        interval: this.retryOptions?.interval ?? Duration.minutes(1),\n        maxAttempts: this.retryOptions?.maxAttempts ?? 10,\n        backoffRate: this.retryOptions?.backoffRate ?? 1.3,\n      });\n    }\n  }\n}\n"]}
|
package/lib/providers/ec2.d.ts
CHANGED
|
@@ -103,7 +103,7 @@ export declare class Ec2Runner extends BaseProvider implements IRunnerProvider {
|
|
|
103
103
|
private readonly spot;
|
|
104
104
|
private readonly spotMaxPrice;
|
|
105
105
|
private readonly vpc;
|
|
106
|
-
private readonly
|
|
106
|
+
private readonly subnets;
|
|
107
107
|
private readonly securityGroups;
|
|
108
108
|
constructor(scope: Construct, id: string, props?: Ec2RunnerProps);
|
|
109
109
|
/**
|