terraform-cdk-serverless-github-actions-runner-controller 0.0.1 → 0.0.2

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 CHANGED
@@ -5231,6 +5231,44 @@
5231
5231
  }
5232
5232
  },
5233
5233
  "types": {
5234
+ "terraform-cdk-serverless-github-actions-runner-controller.Aws": {
5235
+ "assembly": "terraform-cdk-serverless-github-actions-runner-controller",
5236
+ "base": "constructs.Construct",
5237
+ "docs": {
5238
+ "stability": "stable"
5239
+ },
5240
+ "fqn": "terraform-cdk-serverless-github-actions-runner-controller.Aws",
5241
+ "initializer": {
5242
+ "docs": {
5243
+ "stability": "stable"
5244
+ },
5245
+ "locationInModule": {
5246
+ "filename": "src/lib/aws.ts",
5247
+ "line": 21
5248
+ },
5249
+ "parameters": [
5250
+ {
5251
+ "name": "scope",
5252
+ "type": {
5253
+ "fqn": "constructs.Construct"
5254
+ }
5255
+ },
5256
+ {
5257
+ "name": "id",
5258
+ "type": {
5259
+ "primitive": "string"
5260
+ }
5261
+ }
5262
+ ]
5263
+ },
5264
+ "kind": "class",
5265
+ "locationInModule": {
5266
+ "filename": "src/lib/aws.ts",
5267
+ "line": 20
5268
+ },
5269
+ "name": "Aws",
5270
+ "symbolId": "src/lib/aws:Aws"
5271
+ },
5234
5272
  "terraform-cdk-serverless-github-actions-runner-controller.Azure": {
5235
5273
  "assembly": "terraform-cdk-serverless-github-actions-runner-controller",
5236
5274
  "base": "constructs.Construct",
@@ -5268,8 +5306,46 @@
5268
5306
  },
5269
5307
  "name": "Azure",
5270
5308
  "symbolId": "src/lib/azure:Azure"
5309
+ },
5310
+ "terraform-cdk-serverless-github-actions-runner-controller.Gcp": {
5311
+ "assembly": "terraform-cdk-serverless-github-actions-runner-controller",
5312
+ "base": "constructs.Construct",
5313
+ "docs": {
5314
+ "stability": "stable"
5315
+ },
5316
+ "fqn": "terraform-cdk-serverless-github-actions-runner-controller.Gcp",
5317
+ "initializer": {
5318
+ "docs": {
5319
+ "stability": "stable"
5320
+ },
5321
+ "locationInModule": {
5322
+ "filename": "src/lib/gcp.ts",
5323
+ "line": 15
5324
+ },
5325
+ "parameters": [
5326
+ {
5327
+ "name": "scope",
5328
+ "type": {
5329
+ "fqn": "constructs.Construct"
5330
+ }
5331
+ },
5332
+ {
5333
+ "name": "id",
5334
+ "type": {
5335
+ "primitive": "string"
5336
+ }
5337
+ }
5338
+ ]
5339
+ },
5340
+ "kind": "class",
5341
+ "locationInModule": {
5342
+ "filename": "src/lib/gcp.ts",
5343
+ "line": 14
5344
+ },
5345
+ "name": "Gcp",
5346
+ "symbolId": "src/lib/gcp:Gcp"
5271
5347
  }
5272
5348
  },
5273
- "version": "0.0.1",
5274
- "fingerprint": "7VURbJz1fbL4OwzWPPLJFDN3EfYZmFSEwiqeBwP+fR8="
5349
+ "version": "0.0.2",
5350
+ "fingerprint": "dmsp36Ql8DxemrywVTnbflzIxuWX+rrQw/XANuN+5mM="
5275
5351
  }
package/API.md CHANGED
@@ -2,6 +2,112 @@
2
2
 
3
3
  ## Constructs <a name="Constructs" id="Constructs"></a>
4
4
 
5
+ ### Aws <a name="Aws" id="terraform-cdk-serverless-github-actions-runner-controller.Aws"></a>
6
+
7
+ #### Initializers <a name="Initializers" id="terraform-cdk-serverless-github-actions-runner-controller.Aws.Initializer"></a>
8
+
9
+ ```typescript
10
+ import { Aws } from 'terraform-cdk-serverless-github-actions-runner-controller'
11
+
12
+ new Aws(scope: Construct, id: string)
13
+ ```
14
+
15
+ | **Name** | **Type** | **Description** |
16
+ | --- | --- | --- |
17
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Aws.Initializer.parameter.scope">scope</a></code> | <code>constructs.Construct</code> | *No description.* |
18
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Aws.Initializer.parameter.id">id</a></code> | <code>string</code> | *No description.* |
19
+
20
+ ---
21
+
22
+ ##### `scope`<sup>Required</sup> <a name="scope" id="terraform-cdk-serverless-github-actions-runner-controller.Aws.Initializer.parameter.scope"></a>
23
+
24
+ - *Type:* constructs.Construct
25
+
26
+ ---
27
+
28
+ ##### `id`<sup>Required</sup> <a name="id" id="terraform-cdk-serverless-github-actions-runner-controller.Aws.Initializer.parameter.id"></a>
29
+
30
+ - *Type:* string
31
+
32
+ ---
33
+
34
+ #### Methods <a name="Methods" id="Methods"></a>
35
+
36
+ | **Name** | **Description** |
37
+ | --- | --- |
38
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Aws.toString">toString</a></code> | Returns a string representation of this construct. |
39
+
40
+ ---
41
+
42
+ ##### `toString` <a name="toString" id="terraform-cdk-serverless-github-actions-runner-controller.Aws.toString"></a>
43
+
44
+ ```typescript
45
+ public toString(): string
46
+ ```
47
+
48
+ Returns a string representation of this construct.
49
+
50
+ #### Static Functions <a name="Static Functions" id="Static Functions"></a>
51
+
52
+ | **Name** | **Description** |
53
+ | --- | --- |
54
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Aws.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
55
+
56
+ ---
57
+
58
+ ##### `isConstruct` <a name="isConstruct" id="terraform-cdk-serverless-github-actions-runner-controller.Aws.isConstruct"></a>
59
+
60
+ ```typescript
61
+ import { Aws } from 'terraform-cdk-serverless-github-actions-runner-controller'
62
+
63
+ Aws.isConstruct(x: any)
64
+ ```
65
+
66
+ Checks if `x` is a construct.
67
+
68
+ Use this method instead of `instanceof` to properly detect `Construct`
69
+ instances, even when the construct library is symlinked.
70
+
71
+ Explanation: in JavaScript, multiple copies of the `constructs` library on
72
+ disk are seen as independent, completely different libraries. As a
73
+ consequence, the class `Construct` in each copy of the `constructs` library
74
+ is seen as a different class, and an instance of one class will not test as
75
+ `instanceof` the other class. `npm install` will not create installations
76
+ like this, but users may manually symlink construct libraries together or
77
+ use a monorepo tool: in those cases, multiple copies of the `constructs`
78
+ library can be accidentally installed, and `instanceof` will behave
79
+ unpredictably. It is safest to avoid using `instanceof`, and using
80
+ this type-testing method instead.
81
+
82
+ ###### `x`<sup>Required</sup> <a name="x" id="terraform-cdk-serverless-github-actions-runner-controller.Aws.isConstruct.parameter.x"></a>
83
+
84
+ - *Type:* any
85
+
86
+ Any object.
87
+
88
+ ---
89
+
90
+ #### Properties <a name="Properties" id="Properties"></a>
91
+
92
+ | **Name** | **Type** | **Description** |
93
+ | --- | --- | --- |
94
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Aws.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
95
+
96
+ ---
97
+
98
+ ##### `node`<sup>Required</sup> <a name="node" id="terraform-cdk-serverless-github-actions-runner-controller.Aws.property.node"></a>
99
+
100
+ ```typescript
101
+ public readonly node: Node;
102
+ ```
103
+
104
+ - *Type:* constructs.Node
105
+
106
+ The tree node.
107
+
108
+ ---
109
+
110
+
5
111
  ### Azure <a name="Azure" id="terraform-cdk-serverless-github-actions-runner-controller.Azure"></a>
6
112
 
7
113
  #### Initializers <a name="Initializers" id="terraform-cdk-serverless-github-actions-runner-controller.Azure.Initializer"></a>
@@ -108,6 +214,112 @@ The tree node.
108
214
  ---
109
215
 
110
216
 
217
+ ### Gcp <a name="Gcp" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp"></a>
218
+
219
+ #### Initializers <a name="Initializers" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp.Initializer"></a>
220
+
221
+ ```typescript
222
+ import { Gcp } from 'terraform-cdk-serverless-github-actions-runner-controller'
223
+
224
+ new Gcp(scope: Construct, id: string)
225
+ ```
226
+
227
+ | **Name** | **Type** | **Description** |
228
+ | --- | --- | --- |
229
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Gcp.Initializer.parameter.scope">scope</a></code> | <code>constructs.Construct</code> | *No description.* |
230
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Gcp.Initializer.parameter.id">id</a></code> | <code>string</code> | *No description.* |
231
+
232
+ ---
233
+
234
+ ##### `scope`<sup>Required</sup> <a name="scope" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp.Initializer.parameter.scope"></a>
235
+
236
+ - *Type:* constructs.Construct
237
+
238
+ ---
239
+
240
+ ##### `id`<sup>Required</sup> <a name="id" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp.Initializer.parameter.id"></a>
241
+
242
+ - *Type:* string
243
+
244
+ ---
245
+
246
+ #### Methods <a name="Methods" id="Methods"></a>
247
+
248
+ | **Name** | **Description** |
249
+ | --- | --- |
250
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Gcp.toString">toString</a></code> | Returns a string representation of this construct. |
251
+
252
+ ---
253
+
254
+ ##### `toString` <a name="toString" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp.toString"></a>
255
+
256
+ ```typescript
257
+ public toString(): string
258
+ ```
259
+
260
+ Returns a string representation of this construct.
261
+
262
+ #### Static Functions <a name="Static Functions" id="Static Functions"></a>
263
+
264
+ | **Name** | **Description** |
265
+ | --- | --- |
266
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Gcp.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
267
+
268
+ ---
269
+
270
+ ##### `isConstruct` <a name="isConstruct" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp.isConstruct"></a>
271
+
272
+ ```typescript
273
+ import { Gcp } from 'terraform-cdk-serverless-github-actions-runner-controller'
274
+
275
+ Gcp.isConstruct(x: any)
276
+ ```
277
+
278
+ Checks if `x` is a construct.
279
+
280
+ Use this method instead of `instanceof` to properly detect `Construct`
281
+ instances, even when the construct library is symlinked.
282
+
283
+ Explanation: in JavaScript, multiple copies of the `constructs` library on
284
+ disk are seen as independent, completely different libraries. As a
285
+ consequence, the class `Construct` in each copy of the `constructs` library
286
+ is seen as a different class, and an instance of one class will not test as
287
+ `instanceof` the other class. `npm install` will not create installations
288
+ like this, but users may manually symlink construct libraries together or
289
+ use a monorepo tool: in those cases, multiple copies of the `constructs`
290
+ library can be accidentally installed, and `instanceof` will behave
291
+ unpredictably. It is safest to avoid using `instanceof`, and using
292
+ this type-testing method instead.
293
+
294
+ ###### `x`<sup>Required</sup> <a name="x" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp.isConstruct.parameter.x"></a>
295
+
296
+ - *Type:* any
297
+
298
+ Any object.
299
+
300
+ ---
301
+
302
+ #### Properties <a name="Properties" id="Properties"></a>
303
+
304
+ | **Name** | **Type** | **Description** |
305
+ | --- | --- | --- |
306
+ | <code><a href="#terraform-cdk-serverless-github-actions-runner-controller.Gcp.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
307
+
308
+ ---
309
+
310
+ ##### `node`<sup>Required</sup> <a name="node" id="terraform-cdk-serverless-github-actions-runner-controller.Gcp.property.node"></a>
311
+
312
+ ```typescript
313
+ public readonly node: Node;
314
+ ```
315
+
316
+ - *Type:* constructs.Node
317
+
318
+ The tree node.
319
+
320
+ ---
321
+
322
+
111
323
 
112
324
 
113
325
 
package/lib/index.d.ts CHANGED
@@ -1 +1,3 @@
1
+ export * from './lib/aws';
1
2
  export * from './lib/azure';
3
+ export * from './lib/gcp';
package/lib/index.js CHANGED
@@ -14,5 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./lib/aws"), exports);
17
18
  __exportStar(require("./lib/azure"), exports);
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDhDQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2F6dXJlJ1xuIl19
19
+ __exportStar(require("./lib/gcp"), exports);
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDRDQUF5QjtBQUN6Qiw4Q0FBMkI7QUFDM0IsNENBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYXdzJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXp1cmUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9nY3AnXG4iXX0=
package/lib/lib/aws.js CHANGED
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
+ var _a;
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  exports.Aws = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
4
6
  const cloudwatch_log_group_1 = require("@cdktf/provider-aws/lib/cloudwatch-log-group");
5
7
  const data_aws_caller_identity_1 = require("@cdktf/provider-aws/lib/data-aws-caller-identity");
6
8
  const data_aws_region_1 = require("@cdktf/provider-aws/lib/data-aws-region");
@@ -388,4 +390,6 @@ class Aws extends constructs_1.Construct {
388
390
  }
389
391
  }
390
392
  exports.Aws = Aws;
391
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws.js","sourceRoot":"","sources":["../../src/lib/aws.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudwatchLogGroup } from '@cdktf/provider-aws/lib/cloudwatch-log-group';\nimport { DataAwsCallerIdentity } from '@cdktf/provider-aws/lib/data-aws-caller-identity';\nimport { DataAwsRegion } from '@cdktf/provider-aws/lib/data-aws-region';\nimport { DataAwsSecurityGroups } from '@cdktf/provider-aws/lib/data-aws-security-groups';\nimport { DataAwsSubnets } from '@cdktf/provider-aws/lib/data-aws-subnets';\nimport { EcsCluster } from '@cdktf/provider-aws/lib/ecs-cluster';\nimport { EcsService } from '@cdktf/provider-aws/lib/ecs-service';\nimport { EcsTaskDefinition } from '@cdktf/provider-aws/lib/ecs-task-definition';\nimport { IamPolicy } from '@cdktf/provider-aws/lib/iam-policy';\nimport { IamRole } from '@cdktf/provider-aws/lib/iam-role';\nimport { IamRolePolicyAttachment } from '@cdktf/provider-aws/lib/iam-role-policy-attachment';\nimport { AwsProvider } from '@cdktf/provider-aws/lib/provider';\nimport { Fn, TerraformIterator } from 'cdktf';\nimport { Construct } from 'constructs';\nimport { commonVariables } from './variables';\nimport { EfsFileSystem } from '@cdktf/provider-aws/lib/efs-file-system';\nimport { type ContainerDefinition } from '@aws-sdk/client-ecs'\nimport { EfsMountTarget } from '@cdktf/provider-aws/lib/efs-mount-target';\n\nexport class Aws extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n\n        new AwsProvider(this, 'aws', {\n\n        });\n\n        const identity = new DataAwsCallerIdentity(this, 'Identity', {});\n\n        const region = new DataAwsRegion(this, 'Region', {})\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const cluster = new EcsCluster(this, 'Cluster', {\n            name: 'gha-runner-cluster',\n        });\n\n        const runnerRole = new IamRole(this, 'RunnerRole', {\n            assumeRolePolicy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Effect': 'Allow',\n                        'Principal': {\n                            'Service': 'ecs-tasks.amazonaws.com'\n                        },\n                        'Action': 'sts:AssumeRole'\n                    }\n                ]\n            })\n        })\n\n        const autoscalerRole = new IamRole(this, 'AutoscalerRole', {\n            assumeRolePolicy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Effect': 'Allow',\n                        'Principal': {\n                            'Service': 'ecs-tasks.amazonaws.com'\n                        },\n                        'Action': 'sts:AssumeRole'\n                    }\n                ]\n            })\n        })\n\n        const ecsTaskExecutionRole = new IamRole(this, 'TaskExecutionRole', {\n            assumeRolePolicy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Effect': 'Allow',\n                        'Principal': {\n                            'Service': 'ecs-tasks.amazonaws.com'\n                        },\n                        'Action': 'sts:AssumeRole'\n                    }\n                ]\n            }),\n            managedPolicyArns: [\n                'arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy'\n            ]\n        })\n\n        const runnerLogGroup = new CloudwatchLogGroup(this, 'RunnerLogGroup', {\n            name: '/ecs/GHA',\n        });\n\n        const autoscalerLogGroup = new CloudwatchLogGroup(this, 'AutoscalerLogGroup', {\n            name: '/ecs/Autoscaler',\n        });\n\n\n        const subnets = new DataAwsSubnets(this, 'Subnets', {});\n\n        const securityGroups = new DataAwsSecurityGroups(this, 'SecurityGroups');\n\n        // EFS volume to allow sharing data between tasks\n        const efs = new EfsFileSystem(this, 'efs', {\n            throughputMode: 'elastic',\n            tags: {\n                Name: 'work'\n            }\n        })\n\n        const externalsEfs = new EfsFileSystem(this, 'externalsEfs', {\n            throughputMode: 'elastic',\n            tags: {\n                Name: 'externals'\n            }\n        })\n\n        // Each subnet in VPC are on different AZs, so creating mountpoint to each\n        const iterator = TerraformIterator.fromList(subnets.ids)\n\n        new EfsMountTarget(this, 'EfsMountTarget', {\n            forEach: iterator,\n            fileSystemId: efs.id,\n            subnetId: iterator.value\n        });\n\n        new EfsMountTarget(this, 'ExternalsEfsMountTarget', {\n            forEach: iterator,\n            fileSystemId: externalsEfs.id,\n            subnetId: iterator.value\n        });\n\n        const runnerVolumeName = 'work';\n        const externalsVolumeName = 'externals';\n        const runnerContainerDefinitions: ContainerDefinition[] = [\n            {\n            name: 'runner',\n            image: 'ghcr.io/hi-fi/actions-runner:ecs',\n            command: ['/bin/sh', '-c', 'export EXECID=$(cat /proc/sys/kernel/random/uuid) && sudo mkdir -p /tmp/_work/$EXECID && sudo chown runner:runner /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && sudo chown runner:runner /tmp/externals && /home/runner/run.sh ; sudo rm -r /tmp/_work/$EXECID'],\n            essential: true,\n            environment: [\n                {\n                    name: 'EFS_ID',\n                    value: efs.id\n                },\n                {\n                    name: 'EXTERNALS_EFS_ID',\n                    value: externalsEfs.id\n                },\n                {\n                    name: 'ECS_CLUSTER_NAME',\n                    value: cluster.name\n                },\n                {\n                    name: 'ACTIONS_RUNNER_POD_NAME',\n                    value: 'gha-pod'\n                },\n                {\n                    name: 'ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER',\n                    value: 'false'\n                },\n                {\n                    name: 'ECS_SUBNETS',\n                    value: Fn.join(',', subnets.ids)\n                },\n                {\n                    name: 'ECS_SECURITY_GROUPS',\n                    value: Fn.join(',', securityGroups.ids)\n                },\n                {\n                    name: 'ECS_TASK_ROLE',\n                    value: runnerRole.arn\n                },\n                {\n                    name: 'ECS_EXECUTION_ROLE',\n                    value: ecsTaskExecutionRole.arn\n                }\n            ],\n            mountPoints: [\n                {\n                    sourceVolume: runnerVolumeName,\n                    containerPath: '/tmp/_work',\n                },\n                {\n                    sourceVolume: externalsVolumeName,\n                    containerPath: '/tmp/externals',\n                }\n            ],\n            logConfiguration: {\n                logDriver: 'awslogs',\n                options: {\n                    \"awslogs-group\": runnerLogGroup.name,\n                    \"awslogs-region\": region.name,\n                    \"awslogs-stream-prefix\": \"ecs\",\n                }\n            }\n        }]\n        // TODO: Images through caching: https://docs.aws.amazon.com/AmazonECR/latest/userguide/pull-through-cache.html (requires authentication)\n        // TODO: Pass Execution role to job task: https://www.ernestchiang.com/en/posts/2021/using-amazon-ecs-exec/#1-grant-permissions-ecs-task-iam-role\n        // TODO: Pass Task role to job task\n        const runnerTaskDefinition = new EcsTaskDefinition(this, 'RunnerTaskDefinition', {\n            family: 'GHA',\n            taskRoleArn: runnerRole.arn,\n            executionRoleArn: ecsTaskExecutionRole.arn,\n            containerDefinitions: Fn.jsonencode(runnerContainerDefinitions),\n            cpu: '1024',\n            memory: '2048',\n            requiresCompatibilities: [\n                'FARGATE'\n            ],\n            runtimePlatform: {\n                cpuArchitecture: 'X86_64',\n                operatingSystemFamily: 'LINUX'\n            },\n            networkMode: 'awsvpc',\n            volume: [\n                {\n                    name: runnerVolumeName,\n                    efsVolumeConfiguration: {\n                        fileSystemId: efs.id,\n                    },\n                },\n                // This doesn't work with same volume, as volume is initially empty so it can't map to it's \"externals\" directory\n                {\n                    name: externalsVolumeName,\n                    efsVolumeConfiguration: {\n                        fileSystemId: externalsEfs.id,\n                    }\n                }\n            ]\n        })\n\n        const autoscalerTaskDefinition = new EcsTaskDefinition(this, 'AutoscalerTaskDefinition', {\n            family: 'Autoscaler',\n            taskRoleArn: autoscalerRole.arn,\n            executionRoleArn: ecsTaskExecutionRole.arn,\n            containerDefinitions: Fn.jsonencode([\n                {\n                    name: 'autoscaler',\n                    image: 'ghcr.io/hi-fi/gha-runners-on-managed-env:test',\n                    essential: true,\n                    environment: [\n                        {\n                            name: 'PAT',\n                            value: pat.value\n                        },\n                        {\n                            name: 'GITHUB_CONFIG_URL',\n                            value: githubConfigUrl.value\n                        },\n                        {\n                            name: 'TASK_DEFINITION_ARN',\n                            value: runnerTaskDefinition.arn\n                        },\n                        {\n                            name: 'ECS_CLUSTER',\n                            value: cluster.arn\n                        },\n                        {\n                            name: 'ECS_SUBNETS',\n                            value: Fn.join(',', subnets.ids)\n                        },\n                        {\n                            name: 'ECS_SECURITY_GROUPS',\n                            value: Fn.join(',', securityGroups.ids)\n                        },\n                        {\n                            name: 'SCALE_SET_NAME',\n                            value: 'ecs-runner-set'\n                        },\n                    ],\n                    logConfiguration: {\n                        logDriver: 'awslogs',\n                        options: {\n                            \"awslogs-group\": autoscalerLogGroup.name,\n                            \"awslogs-region\": region.name,\n                            \"awslogs-stream-prefix\": \"ecs\",\n                        }\n                    }\n                }\n            ]),\n            cpu: '256',\n            memory: '512',\n            requiresCompatibilities: [\n                'FARGATE'\n            ],\n            runtimePlatform: {\n                cpuArchitecture: 'X86_64',\n                operatingSystemFamily: 'LINUX'\n            },\n            networkMode: 'awsvpc',\n        })\n\n        const runnerPolicy = new IamPolicy(this, 'RunnerPolicy', {\n            policy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Sid': 'StartandMonitorTask',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ecs:RunTask',\n                            'ecs:TagResource',\n                            'ecs:ListTaskDefinitions',\n                            'ecs:ListTasks',\n                            'ecs:StopTask',\n                            'ecs:RegisterTaskDefinition',\n                            'ecs:DescribeTaskDefinition',\n                            'ecs:DeregisterTaskDefinition',\n                            'ecs:DeleteTaskDefinitions',\n                            'ecs:ExecuteCommand',\n                            // Needed for waiting\n                            'ecs:DescribeTasks',\n                            'logs:GetLogEvents',\n                            'iam:PassRole',\n                            'logs:StartLiveTail',\n                            'logs:CreateLogStream',\n                        ],\n                        'Resource': [\n                            `arn:aws:ecs:${region.name}:${identity.accountId}:task-definition/gha-pod-workflow:*`,\n                            cluster.arn,\n                            // Triggerer has to be allowed to pass both task and task execution role\n                            ecsTaskExecutionRole.arn,\n                            runnerRole.arn,\n                            `arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n                            //TODO: reorder rights so that listing is only one with star\n                            '*'\n                        ]\n                    },\n                    {\n                        'Sid': 'GetVpcInfo',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ec2:DescribeSubnets',\n                            'ec2:DescribeSecurityGroups'\n                        ],\n                        'Resource': '*'\n                    },\n                    {\n                        'Sid': 'ExecCommands',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ssmmessages:CreateControlChannel',\n                            'ssmmessages:CreateDataChannel',\n                            'ssmmessages:OpenControlChannel',\n                            'ssmmessages:OpenDataChannel'\n                        ],\n                        'Resource': '*'\n                    }\n                ]\n            }\n\n            )\n        })\n\n        new IamRolePolicyAttachment(this, 'RunnerPolicyAttachment', {\n            policyArn: runnerPolicy.arn,\n            role: runnerRole.name\n        })\n\n        const autoscalerPolicy = new IamPolicy(this, 'AutoscalerPolicy', {\n            policy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Sid': 'StartandMonitorTask',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ecs:RunTask',\n                            // Needed for waiting\n                            'ecs:DescribeTasks',\n                            'logs:GetLogEvents',\n                            'iam:PassRole',\n                        ],\n                        'Resource': [\n                            `${runnerTaskDefinition.arnWithoutRevision}:*`,\n                            // Triggerer has to be allowed to pass both task and task execution role\n                            ecsTaskExecutionRole.arn,\n                            runnerRole.arn,\n                            `arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n                            `${runnerLogGroup.arn}:log-stream:*`,\n                        ]\n                    },\n                    {\n                        'Sid': 'GetVpcInfo',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ec2:DescribeSubnets',\n                            'ec2:DescribeSecurityGroups'\n                        ],\n                        'Resource': '*'\n                    }\n                ]\n            }\n\n            )\n        })\n        new IamRolePolicyAttachment(this, 'AutoscalerPolicyAttachment', {\n            policyArn: autoscalerPolicy.arn,\n            role: autoscalerRole.name\n        })\n\n        new EcsService(this, 'AutoscalerService', {\n            cluster: cluster.arn,\n            name: 'autoscaler-service',\n            desiredCount: 1,\n            launchType: 'FARGATE',\n            taskDefinition: autoscalerTaskDefinition.arnWithoutRevision,\n            networkConfiguration: {\n                assignPublicIp: true,\n                subnets: subnets.ids,\n                securityGroups: securityGroups.ids\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'desired_count'\n                ]\n            }\n        })\n    }\n}\n"]}
393
+ _a = JSII_RTTI_SYMBOL_1;
394
+ Aws[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Aws", version: "0.0.2" };
395
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws.js","sourceRoot":"","sources":["../../src/lib/aws.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudwatchLogGroup } from '@cdktf/provider-aws/lib/cloudwatch-log-group';\nimport { DataAwsCallerIdentity } from '@cdktf/provider-aws/lib/data-aws-caller-identity';\nimport { DataAwsRegion } from '@cdktf/provider-aws/lib/data-aws-region';\nimport { DataAwsSecurityGroups } from '@cdktf/provider-aws/lib/data-aws-security-groups';\nimport { DataAwsSubnets } from '@cdktf/provider-aws/lib/data-aws-subnets';\nimport { EcsCluster } from '@cdktf/provider-aws/lib/ecs-cluster';\nimport { EcsService } from '@cdktf/provider-aws/lib/ecs-service';\nimport { EcsTaskDefinition } from '@cdktf/provider-aws/lib/ecs-task-definition';\nimport { IamPolicy } from '@cdktf/provider-aws/lib/iam-policy';\nimport { IamRole } from '@cdktf/provider-aws/lib/iam-role';\nimport { IamRolePolicyAttachment } from '@cdktf/provider-aws/lib/iam-role-policy-attachment';\nimport { AwsProvider } from '@cdktf/provider-aws/lib/provider';\nimport { Fn, TerraformIterator } from 'cdktf';\nimport { Construct } from 'constructs';\nimport { commonVariables } from './variables';\nimport { EfsFileSystem } from '@cdktf/provider-aws/lib/efs-file-system';\nimport { type ContainerDefinition } from '@aws-sdk/client-ecs'\nimport { EfsMountTarget } from '@cdktf/provider-aws/lib/efs-mount-target';\n\nexport class Aws extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n\n        new AwsProvider(this, 'aws', {\n\n        });\n\n        const identity = new DataAwsCallerIdentity(this, 'Identity', {});\n\n        const region = new DataAwsRegion(this, 'Region', {})\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const cluster = new EcsCluster(this, 'Cluster', {\n            name: 'gha-runner-cluster',\n        });\n\n        const runnerRole = new IamRole(this, 'RunnerRole', {\n            assumeRolePolicy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Effect': 'Allow',\n                        'Principal': {\n                            'Service': 'ecs-tasks.amazonaws.com'\n                        },\n                        'Action': 'sts:AssumeRole'\n                    }\n                ]\n            })\n        })\n\n        const autoscalerRole = new IamRole(this, 'AutoscalerRole', {\n            assumeRolePolicy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Effect': 'Allow',\n                        'Principal': {\n                            'Service': 'ecs-tasks.amazonaws.com'\n                        },\n                        'Action': 'sts:AssumeRole'\n                    }\n                ]\n            })\n        })\n\n        const ecsTaskExecutionRole = new IamRole(this, 'TaskExecutionRole', {\n            assumeRolePolicy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Effect': 'Allow',\n                        'Principal': {\n                            'Service': 'ecs-tasks.amazonaws.com'\n                        },\n                        'Action': 'sts:AssumeRole'\n                    }\n                ]\n            }),\n            managedPolicyArns: [\n                'arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy'\n            ]\n        })\n\n        const runnerLogGroup = new CloudwatchLogGroup(this, 'RunnerLogGroup', {\n            name: '/ecs/GHA',\n        });\n\n        const autoscalerLogGroup = new CloudwatchLogGroup(this, 'AutoscalerLogGroup', {\n            name: '/ecs/Autoscaler',\n        });\n\n\n        const subnets = new DataAwsSubnets(this, 'Subnets', {});\n\n        const securityGroups = new DataAwsSecurityGroups(this, 'SecurityGroups');\n\n        // EFS volume to allow sharing data between tasks\n        const efs = new EfsFileSystem(this, 'efs', {\n            throughputMode: 'elastic',\n            tags: {\n                Name: 'work'\n            }\n        })\n\n        const externalsEfs = new EfsFileSystem(this, 'externalsEfs', {\n            throughputMode: 'elastic',\n            tags: {\n                Name: 'externals'\n            }\n        })\n\n        // Each subnet in VPC are on different AZs, so creating mountpoint to each\n        const iterator = TerraformIterator.fromList(subnets.ids)\n\n        new EfsMountTarget(this, 'EfsMountTarget', {\n            forEach: iterator,\n            fileSystemId: efs.id,\n            subnetId: iterator.value\n        });\n\n        new EfsMountTarget(this, 'ExternalsEfsMountTarget', {\n            forEach: iterator,\n            fileSystemId: externalsEfs.id,\n            subnetId: iterator.value\n        });\n\n        const runnerVolumeName = 'work';\n        const externalsVolumeName = 'externals';\n        const runnerContainerDefinitions: ContainerDefinition[] = [\n            {\n            name: 'runner',\n            image: 'ghcr.io/hi-fi/actions-runner:ecs',\n            command: ['/bin/sh', '-c', 'export EXECID=$(cat /proc/sys/kernel/random/uuid) && sudo mkdir -p /tmp/_work/$EXECID && sudo chown runner:runner /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && sudo chown runner:runner /tmp/externals && /home/runner/run.sh ; sudo rm -r /tmp/_work/$EXECID'],\n            essential: true,\n            environment: [\n                {\n                    name: 'EFS_ID',\n                    value: efs.id\n                },\n                {\n                    name: 'EXTERNALS_EFS_ID',\n                    value: externalsEfs.id\n                },\n                {\n                    name: 'ECS_CLUSTER_NAME',\n                    value: cluster.name\n                },\n                {\n                    name: 'ACTIONS_RUNNER_POD_NAME',\n                    value: 'gha-pod'\n                },\n                {\n                    name: 'ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER',\n                    value: 'false'\n                },\n                {\n                    name: 'ECS_SUBNETS',\n                    value: Fn.join(',', subnets.ids)\n                },\n                {\n                    name: 'ECS_SECURITY_GROUPS',\n                    value: Fn.join(',', securityGroups.ids)\n                },\n                {\n                    name: 'ECS_TASK_ROLE',\n                    value: runnerRole.arn\n                },\n                {\n                    name: 'ECS_EXECUTION_ROLE',\n                    value: ecsTaskExecutionRole.arn\n                }\n            ],\n            mountPoints: [\n                {\n                    sourceVolume: runnerVolumeName,\n                    containerPath: '/tmp/_work',\n                },\n                {\n                    sourceVolume: externalsVolumeName,\n                    containerPath: '/tmp/externals',\n                }\n            ],\n            logConfiguration: {\n                logDriver: 'awslogs',\n                options: {\n                    \"awslogs-group\": runnerLogGroup.name,\n                    \"awslogs-region\": region.name,\n                    \"awslogs-stream-prefix\": \"ecs\",\n                }\n            }\n        }]\n        // TODO: Images through caching: https://docs.aws.amazon.com/AmazonECR/latest/userguide/pull-through-cache.html (requires authentication)\n        // TODO: Pass Execution role to job task: https://www.ernestchiang.com/en/posts/2021/using-amazon-ecs-exec/#1-grant-permissions-ecs-task-iam-role\n        // TODO: Pass Task role to job task\n        const runnerTaskDefinition = new EcsTaskDefinition(this, 'RunnerTaskDefinition', {\n            family: 'GHA',\n            taskRoleArn: runnerRole.arn,\n            executionRoleArn: ecsTaskExecutionRole.arn,\n            containerDefinitions: Fn.jsonencode(runnerContainerDefinitions),\n            cpu: '1024',\n            memory: '2048',\n            requiresCompatibilities: [\n                'FARGATE'\n            ],\n            runtimePlatform: {\n                cpuArchitecture: 'X86_64',\n                operatingSystemFamily: 'LINUX'\n            },\n            networkMode: 'awsvpc',\n            volume: [\n                {\n                    name: runnerVolumeName,\n                    efsVolumeConfiguration: {\n                        fileSystemId: efs.id,\n                    },\n                },\n                // This doesn't work with same volume, as volume is initially empty so it can't map to it's \"externals\" directory\n                {\n                    name: externalsVolumeName,\n                    efsVolumeConfiguration: {\n                        fileSystemId: externalsEfs.id,\n                    }\n                }\n            ]\n        })\n\n        const autoscalerTaskDefinition = new EcsTaskDefinition(this, 'AutoscalerTaskDefinition', {\n            family: 'Autoscaler',\n            taskRoleArn: autoscalerRole.arn,\n            executionRoleArn: ecsTaskExecutionRole.arn,\n            containerDefinitions: Fn.jsonencode([\n                {\n                    name: 'autoscaler',\n                    image: 'ghcr.io/hi-fi/gha-runners-on-managed-env:test',\n                    essential: true,\n                    environment: [\n                        {\n                            name: 'PAT',\n                            value: pat.value\n                        },\n                        {\n                            name: 'GITHUB_CONFIG_URL',\n                            value: githubConfigUrl.value\n                        },\n                        {\n                            name: 'TASK_DEFINITION_ARN',\n                            value: runnerTaskDefinition.arn\n                        },\n                        {\n                            name: 'ECS_CLUSTER',\n                            value: cluster.arn\n                        },\n                        {\n                            name: 'ECS_SUBNETS',\n                            value: Fn.join(',', subnets.ids)\n                        },\n                        {\n                            name: 'ECS_SECURITY_GROUPS',\n                            value: Fn.join(',', securityGroups.ids)\n                        },\n                        {\n                            name: 'SCALE_SET_NAME',\n                            value: 'ecs-runner-set'\n                        },\n                    ],\n                    logConfiguration: {\n                        logDriver: 'awslogs',\n                        options: {\n                            \"awslogs-group\": autoscalerLogGroup.name,\n                            \"awslogs-region\": region.name,\n                            \"awslogs-stream-prefix\": \"ecs\",\n                        }\n                    }\n                }\n            ]),\n            cpu: '256',\n            memory: '512',\n            requiresCompatibilities: [\n                'FARGATE'\n            ],\n            runtimePlatform: {\n                cpuArchitecture: 'X86_64',\n                operatingSystemFamily: 'LINUX'\n            },\n            networkMode: 'awsvpc',\n        })\n\n        const runnerPolicy = new IamPolicy(this, 'RunnerPolicy', {\n            policy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Sid': 'StartandMonitorTask',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ecs:RunTask',\n                            'ecs:TagResource',\n                            'ecs:ListTaskDefinitions',\n                            'ecs:ListTasks',\n                            'ecs:StopTask',\n                            'ecs:RegisterTaskDefinition',\n                            'ecs:DescribeTaskDefinition',\n                            'ecs:DeregisterTaskDefinition',\n                            'ecs:DeleteTaskDefinitions',\n                            'ecs:ExecuteCommand',\n                            // Needed for waiting\n                            'ecs:DescribeTasks',\n                            'logs:GetLogEvents',\n                            'iam:PassRole',\n                            'logs:StartLiveTail',\n                            'logs:CreateLogStream',\n                        ],\n                        'Resource': [\n                            `arn:aws:ecs:${region.name}:${identity.accountId}:task-definition/gha-pod-workflow:*`,\n                            cluster.arn,\n                            // Triggerer has to be allowed to pass both task and task execution role\n                            ecsTaskExecutionRole.arn,\n                            runnerRole.arn,\n                            `arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n                            //TODO: reorder rights so that listing is only one with star\n                            '*'\n                        ]\n                    },\n                    {\n                        'Sid': 'GetVpcInfo',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ec2:DescribeSubnets',\n                            'ec2:DescribeSecurityGroups'\n                        ],\n                        'Resource': '*'\n                    },\n                    {\n                        'Sid': 'ExecCommands',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ssmmessages:CreateControlChannel',\n                            'ssmmessages:CreateDataChannel',\n                            'ssmmessages:OpenControlChannel',\n                            'ssmmessages:OpenDataChannel'\n                        ],\n                        'Resource': '*'\n                    }\n                ]\n            }\n\n            )\n        })\n\n        new IamRolePolicyAttachment(this, 'RunnerPolicyAttachment', {\n            policyArn: runnerPolicy.arn,\n            role: runnerRole.name\n        })\n\n        const autoscalerPolicy = new IamPolicy(this, 'AutoscalerPolicy', {\n            policy: Fn.jsonencode({\n                'Version': '2012-10-17',\n                'Statement': [\n                    {\n                        'Sid': 'StartandMonitorTask',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ecs:RunTask',\n                            // Needed for waiting\n                            'ecs:DescribeTasks',\n                            'logs:GetLogEvents',\n                            'iam:PassRole',\n                        ],\n                        'Resource': [\n                            `${runnerTaskDefinition.arnWithoutRevision}:*`,\n                            // Triggerer has to be allowed to pass both task and task execution role\n                            ecsTaskExecutionRole.arn,\n                            runnerRole.arn,\n                            `arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n                            `${runnerLogGroup.arn}:log-stream:*`,\n                        ]\n                    },\n                    {\n                        'Sid': 'GetVpcInfo',\n                        'Effect': 'Allow',\n                        'Action': [\n                            'ec2:DescribeSubnets',\n                            'ec2:DescribeSecurityGroups'\n                        ],\n                        'Resource': '*'\n                    }\n                ]\n            }\n\n            )\n        })\n        new IamRolePolicyAttachment(this, 'AutoscalerPolicyAttachment', {\n            policyArn: autoscalerPolicy.arn,\n            role: autoscalerRole.name\n        })\n\n        new EcsService(this, 'AutoscalerService', {\n            cluster: cluster.arn,\n            name: 'autoscaler-service',\n            desiredCount: 1,\n            launchType: 'FARGATE',\n            taskDefinition: autoscalerTaskDefinition.arnWithoutRevision,\n            networkConfiguration: {\n                assignPublicIp: true,\n                subnets: subnets.ids,\n                securityGroups: securityGroups.ids\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'desired_count'\n                ]\n            }\n        })\n    }\n}\n"]}
package/lib/lib/azure.js CHANGED
@@ -474,5 +474,5 @@ class Azure extends constructs_1.Construct {
474
474
  }
475
475
  exports.Azure = Azure;
476
476
  _a = JSII_RTTI_SYMBOL_1;
477
- Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.1" };
477
+ Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.2" };
478
478
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azure.js","sourceRoot":"","sources":["../../src/lib/azure.ts"],"names":[],"mappings":"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","sourcesContent":["import { AzurermProvider } from \"@cdktf/provider-azurerm/lib/provider\";\nimport { AzapiProvider } from '../.gen/providers/azapi/provider'\nimport { Resource } from '../.gen/providers/azapi/resource'\nimport { DataAzapiResourceAction } from '../.gen/providers/azapi/data-azapi-resource-action'\nimport { Fn, TerraformVariable } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { ContainerRegistry } from \"@cdktf/provider-azurerm/lib/container-registry\";\nimport { UserAssignedIdentity } from \"@cdktf/provider-azurerm/lib/user-assigned-identity\";\nimport { RoleAssignment } from \"@cdktf/provider-azurerm/lib/role-assignment\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { RoleDefinition } from \"@cdktf/provider-azurerm/lib/role-definition\";\nimport { DataAzurermSubscription } from \"@cdktf/provider-azurerm/lib/data-azurerm-subscription\";\nimport { ContainerApp } from \"@cdktf/provider-azurerm/lib/container-app\";\nimport { commonVariables } from \"./variables\";\nimport { ContainerAppEnvironmentStorage } from \"@cdktf/provider-azurerm/lib/container-app-environment-storage\";\nimport { RandomProvider } from \"@cdktf/provider-random/lib/provider\";\nimport { StringResource } from \"@cdktf/provider-random/lib/string-resource\";\n\nexport class Azure extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n        \n        new AzurermProvider(this, 'azurerm', {\n            features: [\n                {}\n            ]\n        })\n\n        new AzapiProvider(this, 'azapi', {\n        })\n\n        new RandomProvider(this, 'random')\n\n        const sub = new DataAzurermSubscription(this, 'sub', {});\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const location = new TerraformVariable(this, 'location', {\n            default: 'westeurope',\n            description: 'Location where to provision resources to',\n            type: 'string',\n            sensitive: false,\n            nullable: false\n        }).value;\n\n        const rg = new ResourceGroup(this, 'rg', {\n            location,\n            name: 'gha-runner-rg',\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const random = new StringResource(this, 'randomSuffix', {\n            length: 6,\n            special: false,\n            upper: false,\n        })\n\n        const acr = new ContainerRegistry(this, 'acr', {\n            location,\n            name: `runneracr${random.result}`,\n            resourceGroupName: rg.name,\n            sku: 'Basic',\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        // use caching for images\n        const runnerCache = new Resource(this, 'runnerCache', {\n            type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',\n            parentId: acr.id,\n            name: 'root-runner-cache',\n            body: {\n                properties: {\n                    sourceRepository: 'ghcr.io/hi-fi/root-actions-runner',\n                    targetRepository: 'root-actions-runner'\n                }\n            }\n        })\n\n        const autoscalerCache = new Resource(this, 'autoscalerCache', {\n            type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',\n            parentId: acr.id,\n            name: 'autoscaler-cache',\n            body: {\n                properties: {\n                    sourceRepository: 'ghcr.io/hi-fi/gha-runners-on-managed-env',\n                    targetRepository: 'autoscaler'\n                }\n            }\n        })\n\n        const identity = new UserAssignedIdentity(this, 'identity', {\n            location,\n            name: 'aca-acr-access',\n            resourceGroupName: rg.name,\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        new RoleAssignment(this, 'roleAssignment', {\n            principalId: identity.principalId,\n            scope: acr.id,\n            roleDefinitionName: 'AcrPull'\n        });\n\n        const log = new LogAnalyticsWorkspace(this, 'log', {\n            location,\n            name: 'gha-example-logs',\n            resourceGroupName: rg.name,\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        })\n\n        const storageAccount = new Resource(this, 'storageAccount', {\n            type: 'Microsoft.Storage/storageAccounts@2023-01-01',\n            parentId: rg.id,\n            location,\n            name: `ghastorageaccount${random.result}`,\n            body: {\n                properties: {\n                    largeFileSharesState: 'Enabled'\n                },\n                sku: {\n                    name: 'Standard_LRS'\n                },\n                kind: 'StorageV2',\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            },\n            responseExportValues: [\n\n            ]\n        });\n\n        const storageShare = new Resource(this, 'storageShare', {\n            type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',\n            name: 'ghaexampleshare',\n            parentId: `${storageAccount.id}/fileServices/default`,\n            body: {\n                properties: {\n                    enabledProtocols: 'SMB',\n                }\n            },\n        });\n\n        const externalsShare = new Resource(this, 'externalsShare', {\n            type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',\n            name: 'ghaexternalsshare',\n            parentId: `${storageAccount.id}/fileServices/default`,\n            body: {\n                properties: {\n                    enabledProtocols: 'SMB',\n                }\n            },\n        });\n\n        const environment = new Resource(this, 'acaenv', {\n            type: 'Microsoft.App/managedEnvironments@2024-03-01',\n            parentId: rg.id,\n            location,\n            name: 'gha-runner-environment',\n            body: {\n                properties: {\n                    appLogsConfiguration: {\n                        destination: 'log-analytics',\n                        logAnalyticsConfiguration: {\n                            customerId: log.workspaceId,\n                            sharedKey: log.primarySharedKey,\n                        }\n                    },\n                    infrastructureResourceGroup: 'managed-aca-rg',\n                    workloadProfiles: [\n                        {\n                            name: 'Consumption',\n                            workloadProfileType: 'Consumption'\n                        }\n                    ]\n                }\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const storageAccessKey = new DataAzapiResourceAction(this, 'storageAccessKeys', {\n            type: 'Microsoft.Storage/storageAccounts@2023-01-01',\n            action: 'listKeys',\n            resourceId: storageAccount.id,\n            responseExportValues: ['*'],\n            dependsOn: [\n                storageAccount\n            ]\n        });\n\n        // see https://github.com/hashicorp/terraform-cdk/issues/1641\n        // For older Azapi way to get key would be this when (default) data output was json. Witn 2.0.0-beta default was changed to HCL\n        // const accessKey = Fn.lookup(Fn.element(Fn.lookup(Fn.jsondecode(storageAccessKey.output as any), 'keys'), 0), 'value')\n\n        const accessKey = Fn.lookup(Fn.element(Fn.element(storageAccessKey.output.lookup('0'), 0), 0), 'value')\n\n        const acaEnvStorage = new ContainerAppEnvironmentStorage(this, 'acaenvstorage', {\n            name: 'gharunnerjobstorage',\n            accessKey,\n            accessMode: 'ReadWrite',\n            accountName: storageAccount.name,\n            containerAppEnvironmentId: environment.id,\n            shareName: storageShare.name,\n            dependsOn: [\n                // Name doesn't create dependsOn requirement, so adding that explicitly\n                storageShare\n            ] \n        });\n\n        const acaExternalStorage = new ContainerAppEnvironmentStorage(this, 'acaexternalstorage', {\n            name: 'gharunnerexternalstorage',\n            accessKey,\n            accessMode: 'ReadWrite',\n            accountName: storageAccount.name,\n            containerAppEnvironmentId: environment.id,\n            shareName: externalsShare.name,\n            dependsOn: [\n                // Name doesn't create dependsOn requirement, so adding that explicitly\n                externalsShare\n            ] \n        });\n\n        const runnerVolumeName = 'work'\n        const externalVolumeName = 'externals'\n\n        /**\n         * @see https://learn.microsoft.com/en-us/azure/templates/microsoft.app/jobs?pivots=deployment-language-terraform\n         */\n        const ghaRunnerJob = new Resource(this, 'ghaRunnerJob', {\n            type: 'Microsoft.App/jobs@2024-02-02-preview',\n            identity: [\n                {\n                    type: 'UserAssigned',\n                    identityIds: [\n                        identity.id\n                    ]\n                }\n            ],\n            name: 'gha-runner-job-01',\n            parentId: rg.id,\n            location,\n            body: {\n                properties: {\n                    configuration: {\n                        manualTriggerConfig: {\n                            parallelism: 1,\n                            replicaCompletionCount: 1,\n                        },\n                        triggerType: 'Manual',\n                        replicaTimeout: 1200,\n                        registries: [\n                            {\n                                identity: identity.id,\n                                server: acr.loginServer\n                            }\n                        ],\n                    },\n                    environmentId: environment.id,\n                    template: {\n                        containers: [\n                            {\n                                resources: {\n                                    cpu: 1,\n                                    memory: '2Gi',\n                                },\n                                // Have to use custom image as we want to run service as root to be able to install packages\n                                image: `${acr.loginServer}/root-actions-runner:latest`,\n                                name: 'main',\n                                command: ['/bin/sh', '-c', 'export EXECID=$(cat /proc/sys/kernel/random/uuid) && mkdir -p /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && /home/runner/run.sh ; rm -r /tmp/_work/$EXECID'],\n                                volumeMounts: [\n                                    {\n                                        mountPath: '/tmp/_work',\n                                        volumeName: runnerVolumeName,\n                                    },\n                                    {\n                                        mountPath: '/tmp/externals',\n                                        volumeName: externalVolumeName,\n                                    }\n                                ],\n                                env: [\n                                    // https://github.com/microsoft/azure-container-apps/issues/502#issuecomment-1340225438\n                                    {\n                                        name: 'APPSETTING_WEBSITE_SITE_NAME',\n                                        value: 'identity-workaround'\n                                    },\n                                    // https://github.com/microsoft/azure-container-apps/issues/442#issuecomment-1665621031\n                                    {\n                                        name: 'AZURE_CLIENT_ID',\n                                        value: identity.clientId\n                                    },\n                                    {\n                                        name: 'RG_NAME',\n                                        value: rg.name\n                                    },\n                                    {\n                                        name: 'LOG_ID',\n                                        value: log.workspaceId\n                                    },\n                                    {\n                                        name: 'STORAGE_NAME',\n                                        value: acaEnvStorage.name\n                                    },\n                                    {\n                                        name: 'EXTERNAL_STORAGE_NAME',\n                                        value: acaExternalStorage.name\n                                    },\n                                    {\n                                        name: 'SUBSCRIPTION_ID',\n                                        value: sub.subscriptionId\n                                    },\n                                    {\n                                        name: 'ACA_ENVIRONMENT_ID',\n                                        value: environment.id\n                                    }\n                                ],\n                            },\n                        ],\n                        volumes: [\n                            {\n                                name: runnerVolumeName,\n                                storageName: acaEnvStorage.name,\n                                storageType: 'AzureFile',\n                                mountOptions: 'mfsymlinks'\n                            },\n                            {\n                                name: externalVolumeName,\n                                storageName: acaExternalStorage.name,\n                                storageType: 'AzureFile',\n                                mountOptions: 'mfsymlinks'\n                            }\n                        ]\n                    }\n                }\n            },\n            dependsOn: [\n                runnerCache\n            ],\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const autoscalerApp = new ContainerApp(this, 'autoscalerApp', {\n            containerAppEnvironmentId: environment.id,\n            name: 'autoscaler-app-01',\n            resourceGroupName: rg.name,\n            revisionMode: 'Single',\n            identity: {\n                type: 'SystemAssigned, UserAssigned',\n                identityIds: [\n                    identity.id\n                ]\n            },\n            secret: [\n                {\n                    name: 'pat',\n                    value: pat.value\n                }\n            ],\n            registry: [\n                {\n                    identity: identity.id,\n                    server: acr.loginServer\n                }\n            ],\n            template: {\n                container: [\n                    {\n                        // CPU and Memory can be lower with workload profile\n                        cpu: 0.25,\n                        memory: '0.5Gi',\n                        image: `${acr.loginServer}/autoscaler:test`,\n                        name: 'autoscaler',\n                        env: [\n                            {\n                                name: 'PAT',\n                                secretName: 'pat',\n                            },\n                            {\n                                name: 'GITHUB_CONFIG_URL',\n                                value: githubConfigUrl.value\n                            },\n                            {\n                                name: 'AZURE_TENANT_ID',\n                                value: sub.tenantId,\n                            },\n                            {\n                                name: 'SUBSCRIPTION_ID',\n                                value: sub.subscriptionId\n                            },\n                            {\n                                name: 'RESOURCE_GROUP_NAME',\n                                value: rg.name\n                            },\n                            {\n                                name: 'JOB_NAME',\n                                value: ghaRunnerJob.name\n                            },\n                            {\n                                name: 'SCALE_SET_NAME',\n                                value: 'aca-runner-set'\n                            },\n                        ]\n                    }\n                ]\n            },\n            dependsOn: [\n                autoscalerCache\n            ],\n            lifecycle: {\n                ignoreChanges: [\n                    'tags',\n                    'workload_profile_name'\n                ]\n            }\n        });\n\n        /**\n         * @see https://github.com/microsoft/azure-container-apps/issues/1024\n         */\n        const role = new RoleDefinition(this, 'jobRole', {\n            name: `gha-example-revision-start-role-${random.result}`,\n            scope: sub.id,\n            permissions: [\n                {\n                    actions: [\n                        'microsoft.app/jobs/start/action',\n                        'microsoft.app/jobs/stop/action',\n                        'microsoft.app/jobs/read',\n                        'microsoft.app/jobs/executions/read',\n                    ],\n                }\n            ]\n        })\n\n        const jobCreationRole = new RoleDefinition(this, 'jobCreationRole', {\n            name: `gha-example-revision-create-role-${random.result}`,\n            scope: sub.id,\n            permissions: [\n                {\n                    actions: [\n                        'microsoft.app/jobs/start/action',\n                        'microsoft.app/jobs/stop/action',\n                        'microsoft.app/jobs/read',\n                        'microsoft.app/jobs/write',\n                        'microsoft.app/jobs/executions/read',\n                        'microsoft.app/managedEnvironments/join/action',\n                        'microsoft.app/jobs/delete' // cleanup for jobs\n                    ],\n                }\n            ]\n        })\n\n        // Allow autoscaler to create new revision of app\n        new RoleAssignment(this, 'scaleJobRoleAssignment', {\n            principalId: autoscalerApp.identity.principalId,\n            scope: ghaRunnerJob.id,\n            roleDefinitionId: role.roleDefinitionResourceId\n        })\n\n        // Allow runner to start the job. As each one created new job, have to give to RG level.\n        new RoleAssignment(this, 'actionContainerStartRoleAssignment', {\n            principalId: identity.principalId,\n            scope: rg.id,\n            roleDefinitionId: jobCreationRole.roleDefinitionResourceId\n        })\n\n        new RoleAssignment(this, 'imagePushRoleAssignment', {\n            principalId: identity.principalId,\n            scope: acr.id,\n            roleDefinitionName: 'AcrPush'\n        });\n\n        new RoleAssignment(this, 'jobLogReadAssignment', {\n            principalId: identity.principalId,\n            scope: log.id,\n            roleDefinitionName: 'Log Analytics Reader'\n        })\n    }\n}"]}
package/lib/lib/gcp.js CHANGED
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
+ var _a;
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  exports.Gcp = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
4
6
  const cdktf_1 = require("cdktf");
5
7
  const constructs_1 = require("constructs");
6
8
  const provider_1 = require("@cdktf/provider-google/lib/provider");
@@ -244,4 +246,6 @@ class Gcp extends constructs_1.Construct {
244
246
  }
245
247
  }
246
248
  exports.Gcp = Gcp;
247
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gcp.js","sourceRoot":"","sources":["../../src/lib/gcp.ts"],"names":[],"mappings":"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","sourcesContent":["import { TerraformLocal } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { GoogleProvider } from '@cdktf/provider-google/lib/provider'\nimport { ArtifactRegistryRepository } from \"@cdktf/provider-google/lib/artifact-registry-repository\";\nimport { CloudRunV2Job } from \"@cdktf/provider-google/lib/cloud-run-v2-job\";\nimport { ProjectIamCustomRole } from \"@cdktf/provider-google/lib/project-iam-custom-role\";\nimport { ServiceAccount } from \"@cdktf/provider-google/lib/service-account\";\nimport { ProjectIamMember } from \"@cdktf/provider-google/lib/project-iam-member\";\nimport { commonVariables } from \"./variables\";\nimport { CloudRunService } from \"@cdktf/provider-google/lib/cloud-run-service\";\nimport { NullProvider } from \"@cdktf/provider-null/lib/provider\";\nimport { Resource } from '@cdktf/provider-null/lib/resource'\n\nexport class Gcp extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n\n        const location = 'europe-north1';\n        const project = 'gha-runner-example';\n        \n        new GoogleProvider(this, 'google', {\n            project,\n            region: location\n        });\n\n        new NullProvider(this, 'null')\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const registry = new ArtifactRegistryRepository(this, 'registry', {\n            format: 'DOCKER',\n            mode: 'REMOTE_REPOSITORY',\n            repositoryId: 'gha-runner-test',\n            description: 'Repository to host run and resulting images from GHA runs',\n            remoteRepositoryConfig: {\n                dockerRepository: {\n                    customRepository: {\n                        uri: 'https://ghcr.io'\n                    }\n                }\n            }\n        });\n\n        const jobSa = new ServiceAccount(this, 'jobServiceAccount', {\n            accountId: 'gha-runner-job-sa',\n        });\n\n        const runnerRole = new ProjectIamCustomRole(this, 'runnerRole', {\n            roleId: 'ghaRunnerRole',\n            title: 'GHA Runner Role',\n            permissions: [\n                'artifactregistry.dockerimages.get',\n                'artifactregistry.dockerimages.list',\n                'run.jobs.run',\n                'run.jobs.create',\n                'run.jobs.delete',\n                'run.jobs.list',\n                // Needed for waiting\n                'run.executions.get',\n            ],\n        });\n\n        const jobPolicyMember = new TerraformLocal(this, 'ghaMember', `serviceAccount:${jobSa.email}`)\n\n        new ProjectIamMember(this, 'runnerRoleBinding', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: runnerRole.id,\n        })\n\n        new ProjectIamMember(this, 'runnerRoleBindingStorage', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: 'roles/storage.admin',\n        })\n\n        new ProjectIamMember(this, 'runnerRoleBindingRunServiceAgent', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: 'roles/run.serviceAgent',\n        })\n\n        new ProjectIamMember(this, 'runnerRoleBindingRunViewer', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: 'roles/run.viewer',\n        })\n\n        const storageName = 'gha-runner-job-externals';\n        const createBucket = new TerraformLocal(this, 'bucketModification', `CLOUDSDK_CORE_DISABLE_PROMPTS=1 gcloud alpha storage buckets create gs://${storageName} --project=${project} --location=${location} --uniform-bucket-level-access --enable-hierarchical-namespace`)\n\n        // Hierarchial namespaces can't be enabled with Terraform.\n        const bucketCreation = new Resource(this, 'gcloud', {\n            provisioners: [\n                {\n                    type: \"local-exec\",\n                    command: createBucket.fqn\n                },\n            ],\n            triggers: {\n                fqn: createBucket.fqn\n            },\n        });\n\n        // TODO: check caching https://cloud.google.com/artifact-registry/docs/pull-cached-dockerhub-images\n        const runnerJob = new CloudRunV2Job(this, 'ghaJob', {\n            deletionProtection: false,\n            name: 'gha-runner-job',\n            location,\n            template: {\n                template: {\n                    containers: [\n                        {\n                            image: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/actions-runner:cr`,\n                            env: [\n                                {\n                                    name: 'CLOUDSDK_RUN_REGION',\n                                    value: location,\n                                },\n                                {\n                                    name: 'GOOGLE_CLOUD_PROJECT',\n                                    value: project,\n                                },\n                                {\n                                    name: 'EXTERNAL_STORAGE_NAME',\n                                    value: storageName,\n                                },\n                                // FUSE mounts directory as root with 777 fo directories and 555 for other files. As path is owned always by root, utime or permission change is not possible. These options prevent tar to try those\n                                {\n                                    name: 'TAR_OPTIONS',\n                                    value: '--touch --no-overwrite-dir --no-same-owner'\n                                }\n                            ],\n                            volumeMounts: [\n                                {\n                                    name: 'externals',\n                                    mountPath: '/home/runner/_work/externals'\n                                }\n                            ],\n                            command: ['/home/runner/ephemeral_runner.sh'],\n                            resources: {\n                                limits: {\n                                    cpu: '1',\n                                    memory: '2Gi'\n                                }\n                            },\n                        }\n                    ],\n                    volumes: [\n                        {\n                            name: 'externals',\n                            gcs: {\n                                bucket: storageName\n                            }\n                        }\n                    ],\n                    maxRetries: 0,\n                    serviceAccount: jobSa.email\n                }\n            },\n            dependsOn: [\n                bucketCreation\n            ]\n        })\n\n        const autoscalerSa = new ServiceAccount(this, 'autoscalerServiceAccount', {\n            accountId: 'autoscaler-sa',\n        });\n\n        new ProjectIamCustomRole(this, 'autoscalerRole', {\n            roleId: 'ghaAutoscalerRole',\n            title: 'GHA Autoscaler Role',\n            permissions: [\n                'artifactregistry.dockerimages.get',\n                'artifactregistry.dockerimages.list',\n                'run.jobs.run',\n                'run.jobs.create',\n                'run.jobs.delete',\n            ],\n        });\n\n        const autoscalerPolicyMember = new TerraformLocal(this, 'autoscalerMember', `serviceAccount:${autoscalerSa.email}`)\n\n        // TODO: replace 2 following with more specific ones.\n        new ProjectIamMember(this, 'autoscalerRoleBindingRun', {\n            member: autoscalerPolicyMember.toString(),\n            project,\n            role: 'roles/run.developer',\n        })\n\n\n        new ProjectIamMember(this, 'autoscalerRoleBindingStorage', {\n            member: autoscalerPolicyMember.toString(),\n            project,\n            role: 'roles/storage.admin',\n        })\n\n        new ProjectIamMember(this, 'autoscalerRoleBindingRunServiceAgent', {\n            member: autoscalerPolicyMember.toString(),\n            project,\n            role: 'roles/run.serviceAgent',\n        })\n\n        new CloudRunService(this, 'autoscalerService', {\n            location,\n            name: 'gha-autoscaler',\n            metadata: {\n                annotations: {\n                    'run.googleapis.com/ingress': 'internal',\n                }\n            },\n            template: {\n                metadata: {\n                    annotations: {\n                        'autoscaling.knative.dev/maxScale': '1',\n                        'autoscaling.knative.dev/minScale': '1',\n                        'run.googleapis.com/cpu-throttling': 'false',\n                        'run.googleapis.com/startup-cpu-boost': 'false'\n                    }\n                },\n                spec: {\n                    containerConcurrency: 1,\n                    containers: [\n                        {\n                            image: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/gha-runners-on-managed-env:test`,\n                            env: [\n                                {\n                                    name: 'PAT',\n                                    value: pat.value\n                                },\n                                {\n                                    name: 'GITHUB_CONFIG_URL',\n                                    value: githubConfigUrl.value\n                                },\n                                {\n                                    name: 'JOB_NAME',\n                                    value: runnerJob.name\n                                },\n                                {\n                                    name: 'SCALE_SET_NAME',\n                                    value: 'cr-runner-set'\n                                },\n                                {\n                                    name: 'CLOUDSDK_RUN_REGION',\n                                    value: location\n                                },\n                                {\n                                    name: 'GOOGLE_CLOUD_PROJECT',\n                                    value: project\n                                }\n\n                            ],\n                            resources: {\n                                // Service would work for much lower, but these are minimum values for \"always on\" mode\n                                limits: {\n                                    cpu: '1000m',\n                                    memory: '512Mi'\n                                }\n                            }\n                        }\n                    ],\n                    serviceAccountName: autoscalerSa.email\n                }\n            }\n        })\n    }\n}\n"]}
249
+ _a = JSII_RTTI_SYMBOL_1;
250
+ Gcp[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Gcp", version: "0.0.2" };
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gcp.js","sourceRoot":"","sources":["../../src/lib/gcp.ts"],"names":[],"mappings":";;;;;AAAA,iCAAuC;AACvC,2CAAuC;AACvC,kEAAoE;AACpE,0GAAqG;AACrG,kFAA4E;AAC5E,gGAA0F;AAC1F,gFAA4E;AAC5E,sFAAiF;AACjF,2CAA8C;AAC9C,oFAA+E;AAC/E,gEAAiE;AACjE,gEAA4D;AAE5D,MAAa,GAAI,SAAQ,sBAAS;IAC9B,YAAY,KAAgB,EAAE,EAAU;QACpC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,QAAQ,GAAG,eAAe,CAAC;QACjC,MAAM,OAAO,GAAG,oBAAoB,CAAC;QAErC,IAAI,yBAAc,CAAC,IAAI,EAAE,QAAQ,EAAE;YAC/B,OAAO;YACP,MAAM,EAAE,QAAQ;SACnB,CAAC,CAAC;QAEH,IAAI,uBAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;QAE9B,MAAM,EAAE,GAAG,EAAE,eAAe,EAAE,GAAG,IAAA,2BAAe,EAAC,IAAI,CAAC,CAAC;QAEvD,MAAM,QAAQ,GAAG,IAAI,yDAA0B,CAAC,IAAI,EAAE,UAAU,EAAE;YAC9D,MAAM,EAAE,QAAQ;YAChB,IAAI,EAAE,mBAAmB;YACzB,YAAY,EAAE,iBAAiB;YAC/B,WAAW,EAAE,2DAA2D;YACxE,sBAAsB,EAAE;gBACpB,gBAAgB,EAAE;oBACd,gBAAgB,EAAE;wBACd,GAAG,EAAE,iBAAiB;qBACzB;iBACJ;aACJ;SACJ,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,IAAI,gCAAc,CAAC,IAAI,EAAE,mBAAmB,EAAE;YACxD,SAAS,EAAE,mBAAmB;SACjC,CAAC,CAAC;QAEH,MAAM,UAAU,GAAG,IAAI,8CAAoB,CAAC,IAAI,EAAE,YAAY,EAAE;YAC5D,MAAM,EAAE,eAAe;YACvB,KAAK,EAAE,iBAAiB;YACxB,WAAW,EAAE;gBACT,mCAAmC;gBACnC,oCAAoC;gBACpC,cAAc;gBACd,iBAAiB;gBACjB,iBAAiB;gBACjB,eAAe;gBACf,qBAAqB;gBACrB,oBAAoB;aACvB;SACJ,CAAC,CAAC;QAEH,MAAM,eAAe,GAAG,IAAI,sBAAc,CAAC,IAAI,EAAE,WAAW,EAAE,kBAAkB,KAAK,CAAC,KAAK,EAAE,CAAC,CAAA;QAE9F,IAAI,qCAAgB,CAAC,IAAI,EAAE,mBAAmB,EAAE;YAC5C,MAAM,EAAE,eAAe,CAAC,QAAQ,EAAE;YAClC,OAAO;YACP,IAAI,EAAE,UAAU,CAAC,EAAE;SACtB,CAAC,CAAA;QAEF,IAAI,qCAAgB,CAAC,IAAI,EAAE,0BAA0B,EAAE;YACnD,MAAM,EAAE,eAAe,CAAC,QAAQ,EAAE;YAClC,OAAO;YACP,IAAI,EAAE,qBAAqB;SAC9B,CAAC,CAAA;QAEF,IAAI,qCAAgB,CAAC,IAAI,EAAE,kCAAkC,EAAE;YAC3D,MAAM,EAAE,eAAe,CAAC,QAAQ,EAAE;YAClC,OAAO;YACP,IAAI,EAAE,wBAAwB;SACjC,CAAC,CAAA;QAEF,IAAI,qCAAgB,CAAC,IAAI,EAAE,4BAA4B,EAAE;YACrD,MAAM,EAAE,eAAe,CAAC,QAAQ,EAAE;YAClC,OAAO;YACP,IAAI,EAAE,kBAAkB;SAC3B,CAAC,CAAA;QAEF,MAAM,WAAW,GAAG,0BAA0B,CAAC;QAC/C,MAAM,YAAY,GAAG,IAAI,sBAAc,CAAC,IAAI,EAAE,oBAAoB,EAAE,4EAA4E,WAAW,cAAc,OAAO,eAAe,QAAQ,gEAAgE,CAAC,CAAA;QAExQ,0DAA0D;QAC1D,MAAM,cAAc,GAAG,IAAI,mBAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE;YAChD,YAAY,EAAE;gBACV;oBACI,IAAI,EAAE,YAAY;oBAClB,OAAO,EAAE,YAAY,CAAC,GAAG;iBAC5B;aACJ;YACD,QAAQ,EAAE;gBACN,GAAG,EAAE,YAAY,CAAC,GAAG;aACxB;SACJ,CAAC,CAAC;QAEH,mGAAmG;QACnG,MAAM,SAAS,GAAG,IAAI,gCAAa,CAAC,IAAI,EAAE,QAAQ,EAAE;YAChD,kBAAkB,EAAE,KAAK;YACzB,IAAI,EAAE,gBAAgB;YACtB,QAAQ;YACR,QAAQ,EAAE;gBACN,QAAQ,EAAE;oBACN,UAAU,EAAE;wBACR;4BACI,KAAK,EAAE,GAAG,QAAQ,CAAC,QAAQ,mBAAmB,OAAO,IAAI,QAAQ,CAAC,YAAY,0BAA0B;4BACxG,GAAG,EAAE;gCACD;oCACI,IAAI,EAAE,qBAAqB;oCAC3B,KAAK,EAAE,QAAQ;iCAClB;gCACD;oCACI,IAAI,EAAE,sBAAsB;oCAC5B,KAAK,EAAE,OAAO;iCACjB;gCACD;oCACI,IAAI,EAAE,uBAAuB;oCAC7B,KAAK,EAAE,WAAW;iCACrB;gCACD,qMAAqM;gCACrM;oCACI,IAAI,EAAE,aAAa;oCACnB,KAAK,EAAE,4CAA4C;iCACtD;6BACJ;4BACD,YAAY,EAAE;gCACV;oCACI,IAAI,EAAE,WAAW;oCACjB,SAAS,EAAE,8BAA8B;iCAC5C;6BACJ;4BACD,OAAO,EAAE,CAAC,kCAAkC,CAAC;4BAC7C,SAAS,EAAE;gCACP,MAAM,EAAE;oCACJ,GAAG,EAAE,GAAG;oCACR,MAAM,EAAE,KAAK;iCAChB;6BACJ;yBACJ;qBACJ;oBACD,OAAO,EAAE;wBACL;4BACI,IAAI,EAAE,WAAW;4BACjB,GAAG,EAAE;gCACD,MAAM,EAAE,WAAW;6BACtB;yBACJ;qBACJ;oBACD,UAAU,EAAE,CAAC;oBACb,cAAc,EAAE,KAAK,CAAC,KAAK;iBAC9B;aACJ;YACD,SAAS,EAAE;gBACP,cAAc;aACjB;SACJ,CAAC,CAAA;QAEF,MAAM,YAAY,GAAG,IAAI,gCAAc,CAAC,IAAI,EAAE,0BAA0B,EAAE;YACtE,SAAS,EAAE,eAAe;SAC7B,CAAC,CAAC;QAEH,IAAI,8CAAoB,CAAC,IAAI,EAAE,gBAAgB,EAAE;YAC7C,MAAM,EAAE,mBAAmB;YAC3B,KAAK,EAAE,qBAAqB;YAC5B,WAAW,EAAE;gBACT,mCAAmC;gBACnC,oCAAoC;gBACpC,cAAc;gBACd,iBAAiB;gBACjB,iBAAiB;aACpB;SACJ,CAAC,CAAC;QAEH,MAAM,sBAAsB,GAAG,IAAI,sBAAc,CAAC,IAAI,EAAE,kBAAkB,EAAE,kBAAkB,YAAY,CAAC,KAAK,EAAE,CAAC,CAAA;QAEnH,qDAAqD;QACrD,IAAI,qCAAgB,CAAC,IAAI,EAAE,0BAA0B,EAAE;YACnD,MAAM,EAAE,sBAAsB,CAAC,QAAQ,EAAE;YACzC,OAAO;YACP,IAAI,EAAE,qBAAqB;SAC9B,CAAC,CAAA;QAGF,IAAI,qCAAgB,CAAC,IAAI,EAAE,8BAA8B,EAAE;YACvD,MAAM,EAAE,sBAAsB,CAAC,QAAQ,EAAE;YACzC,OAAO;YACP,IAAI,EAAE,qBAAqB;SAC9B,CAAC,CAAA;QAEF,IAAI,qCAAgB,CAAC,IAAI,EAAE,sCAAsC,EAAE;YAC/D,MAAM,EAAE,sBAAsB,CAAC,QAAQ,EAAE;YACzC,OAAO;YACP,IAAI,EAAE,wBAAwB;SACjC,CAAC,CAAA;QAEF,IAAI,mCAAe,CAAC,IAAI,EAAE,mBAAmB,EAAE;YAC3C,QAAQ;YACR,IAAI,EAAE,gBAAgB;YACtB,QAAQ,EAAE;gBACN,WAAW,EAAE;oBACT,4BAA4B,EAAE,UAAU;iBAC3C;aACJ;YACD,QAAQ,EAAE;gBACN,QAAQ,EAAE;oBACN,WAAW,EAAE;wBACT,kCAAkC,EAAE,GAAG;wBACvC,kCAAkC,EAAE,GAAG;wBACvC,mCAAmC,EAAE,OAAO;wBAC5C,sCAAsC,EAAE,OAAO;qBAClD;iBACJ;gBACD,IAAI,EAAE;oBACF,oBAAoB,EAAE,CAAC;oBACvB,UAAU,EAAE;wBACR;4BACI,KAAK,EAAE,GAAG,QAAQ,CAAC,QAAQ,mBAAmB,OAAO,IAAI,QAAQ,CAAC,YAAY,wCAAwC;4BACtH,GAAG,EAAE;gCACD;oCACI,IAAI,EAAE,KAAK;oCACX,KAAK,EAAE,GAAG,CAAC,KAAK;iCACnB;gCACD;oCACI,IAAI,EAAE,mBAAmB;oCACzB,KAAK,EAAE,eAAe,CAAC,KAAK;iCAC/B;gCACD;oCACI,IAAI,EAAE,UAAU;oCAChB,KAAK,EAAE,SAAS,CAAC,IAAI;iCACxB;gCACD;oCACI,IAAI,EAAE,gBAAgB;oCACtB,KAAK,EAAE,eAAe;iCACzB;gCACD;oCACI,IAAI,EAAE,qBAAqB;oCAC3B,KAAK,EAAE,QAAQ;iCAClB;gCACD;oCACI,IAAI,EAAE,sBAAsB;oCAC5B,KAAK,EAAE,OAAO;iCACjB;6BAEJ;4BACD,SAAS,EAAE;gCACP,uFAAuF;gCACvF,MAAM,EAAE;oCACJ,GAAG,EAAE,OAAO;oCACZ,MAAM,EAAE,OAAO;iCAClB;6BACJ;yBACJ;qBACJ;oBACD,kBAAkB,EAAE,YAAY,CAAC,KAAK;iBACzC;aACJ;SACJ,CAAC,CAAA;IACN,CAAC;;AA5PL,kBA6PC","sourcesContent":["import { TerraformLocal } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { GoogleProvider } from '@cdktf/provider-google/lib/provider'\nimport { ArtifactRegistryRepository } from \"@cdktf/provider-google/lib/artifact-registry-repository\";\nimport { CloudRunV2Job } from \"@cdktf/provider-google/lib/cloud-run-v2-job\";\nimport { ProjectIamCustomRole } from \"@cdktf/provider-google/lib/project-iam-custom-role\";\nimport { ServiceAccount } from \"@cdktf/provider-google/lib/service-account\";\nimport { ProjectIamMember } from \"@cdktf/provider-google/lib/project-iam-member\";\nimport { commonVariables } from \"./variables\";\nimport { CloudRunService } from \"@cdktf/provider-google/lib/cloud-run-service\";\nimport { NullProvider } from \"@cdktf/provider-null/lib/provider\";\nimport { Resource } from '@cdktf/provider-null/lib/resource'\n\nexport class Gcp extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n\n        const location = 'europe-north1';\n        const project = 'gha-runner-example';\n        \n        new GoogleProvider(this, 'google', {\n            project,\n            region: location\n        });\n\n        new NullProvider(this, 'null')\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const registry = new ArtifactRegistryRepository(this, 'registry', {\n            format: 'DOCKER',\n            mode: 'REMOTE_REPOSITORY',\n            repositoryId: 'gha-runner-test',\n            description: 'Repository to host run and resulting images from GHA runs',\n            remoteRepositoryConfig: {\n                dockerRepository: {\n                    customRepository: {\n                        uri: 'https://ghcr.io'\n                    }\n                }\n            }\n        });\n\n        const jobSa = new ServiceAccount(this, 'jobServiceAccount', {\n            accountId: 'gha-runner-job-sa',\n        });\n\n        const runnerRole = new ProjectIamCustomRole(this, 'runnerRole', {\n            roleId: 'ghaRunnerRole',\n            title: 'GHA Runner Role',\n            permissions: [\n                'artifactregistry.dockerimages.get',\n                'artifactregistry.dockerimages.list',\n                'run.jobs.run',\n                'run.jobs.create',\n                'run.jobs.delete',\n                'run.jobs.list',\n                // Needed for waiting\n                'run.executions.get',\n            ],\n        });\n\n        const jobPolicyMember = new TerraformLocal(this, 'ghaMember', `serviceAccount:${jobSa.email}`)\n\n        new ProjectIamMember(this, 'runnerRoleBinding', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: runnerRole.id,\n        })\n\n        new ProjectIamMember(this, 'runnerRoleBindingStorage', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: 'roles/storage.admin',\n        })\n\n        new ProjectIamMember(this, 'runnerRoleBindingRunServiceAgent', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: 'roles/run.serviceAgent',\n        })\n\n        new ProjectIamMember(this, 'runnerRoleBindingRunViewer', {\n            member: jobPolicyMember.toString(),\n            project,\n            role: 'roles/run.viewer',\n        })\n\n        const storageName = 'gha-runner-job-externals';\n        const createBucket = new TerraformLocal(this, 'bucketModification', `CLOUDSDK_CORE_DISABLE_PROMPTS=1 gcloud alpha storage buckets create gs://${storageName} --project=${project} --location=${location} --uniform-bucket-level-access --enable-hierarchical-namespace`)\n\n        // Hierarchial namespaces can't be enabled with Terraform.\n        const bucketCreation = new Resource(this, 'gcloud', {\n            provisioners: [\n                {\n                    type: \"local-exec\",\n                    command: createBucket.fqn\n                },\n            ],\n            triggers: {\n                fqn: createBucket.fqn\n            },\n        });\n\n        // TODO: check caching https://cloud.google.com/artifact-registry/docs/pull-cached-dockerhub-images\n        const runnerJob = new CloudRunV2Job(this, 'ghaJob', {\n            deletionProtection: false,\n            name: 'gha-runner-job',\n            location,\n            template: {\n                template: {\n                    containers: [\n                        {\n                            image: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/actions-runner:cr`,\n                            env: [\n                                {\n                                    name: 'CLOUDSDK_RUN_REGION',\n                                    value: location,\n                                },\n                                {\n                                    name: 'GOOGLE_CLOUD_PROJECT',\n                                    value: project,\n                                },\n                                {\n                                    name: 'EXTERNAL_STORAGE_NAME',\n                                    value: storageName,\n                                },\n                                // FUSE mounts directory as root with 777 fo directories and 555 for other files. As path is owned always by root, utime or permission change is not possible. These options prevent tar to try those\n                                {\n                                    name: 'TAR_OPTIONS',\n                                    value: '--touch --no-overwrite-dir --no-same-owner'\n                                }\n                            ],\n                            volumeMounts: [\n                                {\n                                    name: 'externals',\n                                    mountPath: '/home/runner/_work/externals'\n                                }\n                            ],\n                            command: ['/home/runner/ephemeral_runner.sh'],\n                            resources: {\n                                limits: {\n                                    cpu: '1',\n                                    memory: '2Gi'\n                                }\n                            },\n                        }\n                    ],\n                    volumes: [\n                        {\n                            name: 'externals',\n                            gcs: {\n                                bucket: storageName\n                            }\n                        }\n                    ],\n                    maxRetries: 0,\n                    serviceAccount: jobSa.email\n                }\n            },\n            dependsOn: [\n                bucketCreation\n            ]\n        })\n\n        const autoscalerSa = new ServiceAccount(this, 'autoscalerServiceAccount', {\n            accountId: 'autoscaler-sa',\n        });\n\n        new ProjectIamCustomRole(this, 'autoscalerRole', {\n            roleId: 'ghaAutoscalerRole',\n            title: 'GHA Autoscaler Role',\n            permissions: [\n                'artifactregistry.dockerimages.get',\n                'artifactregistry.dockerimages.list',\n                'run.jobs.run',\n                'run.jobs.create',\n                'run.jobs.delete',\n            ],\n        });\n\n        const autoscalerPolicyMember = new TerraformLocal(this, 'autoscalerMember', `serviceAccount:${autoscalerSa.email}`)\n\n        // TODO: replace 2 following with more specific ones.\n        new ProjectIamMember(this, 'autoscalerRoleBindingRun', {\n            member: autoscalerPolicyMember.toString(),\n            project,\n            role: 'roles/run.developer',\n        })\n\n\n        new ProjectIamMember(this, 'autoscalerRoleBindingStorage', {\n            member: autoscalerPolicyMember.toString(),\n            project,\n            role: 'roles/storage.admin',\n        })\n\n        new ProjectIamMember(this, 'autoscalerRoleBindingRunServiceAgent', {\n            member: autoscalerPolicyMember.toString(),\n            project,\n            role: 'roles/run.serviceAgent',\n        })\n\n        new CloudRunService(this, 'autoscalerService', {\n            location,\n            name: 'gha-autoscaler',\n            metadata: {\n                annotations: {\n                    'run.googleapis.com/ingress': 'internal',\n                }\n            },\n            template: {\n                metadata: {\n                    annotations: {\n                        'autoscaling.knative.dev/maxScale': '1',\n                        'autoscaling.knative.dev/minScale': '1',\n                        'run.googleapis.com/cpu-throttling': 'false',\n                        'run.googleapis.com/startup-cpu-boost': 'false'\n                    }\n                },\n                spec: {\n                    containerConcurrency: 1,\n                    containers: [\n                        {\n                            image: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/gha-runners-on-managed-env:test`,\n                            env: [\n                                {\n                                    name: 'PAT',\n                                    value: pat.value\n                                },\n                                {\n                                    name: 'GITHUB_CONFIG_URL',\n                                    value: githubConfigUrl.value\n                                },\n                                {\n                                    name: 'JOB_NAME',\n                                    value: runnerJob.name\n                                },\n                                {\n                                    name: 'SCALE_SET_NAME',\n                                    value: 'cr-runner-set'\n                                },\n                                {\n                                    name: 'CLOUDSDK_RUN_REGION',\n                                    value: location\n                                },\n                                {\n                                    name: 'GOOGLE_CLOUD_PROJECT',\n                                    value: project\n                                }\n\n                            ],\n                            resources: {\n                                // Service would work for much lower, but these are minimum values for \"always on\" mode\n                                limits: {\n                                    cpu: '1000m',\n                                    memory: '512Mi'\n                                }\n                            }\n                        }\n                    ],\n                    serviceAccountName: autoscalerSa.email\n                }\n            }\n        })\n    }\n}\n"]}
@@ -8,13 +8,15 @@ function commonVariables(scope) {
8
8
  nullable: false,
9
9
  sensitive: true
10
10
  });
11
+ pat.overrideLogicalId('PAT');
11
12
  const githubConfigUrl = new cdktf_1.TerraformVariable(scope, 'github_config_url', {
12
13
  description: 'Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo>',
13
14
  nullable: false,
14
15
  });
16
+ githubConfigUrl.overrideLogicalId('github_config_url');
15
17
  return {
16
18
  pat,
17
19
  githubConfigUrl
18
20
  };
19
21
  }
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFibGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi92YXJpYWJsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFRQSwwQ0FnQkM7QUF4QkQsaUNBQTBDO0FBUTFDLFNBQWdCLGVBQWUsQ0FBQyxLQUFnQjtJQUM1QyxNQUFNLEdBQUcsR0FBRyxJQUFJLHlCQUFpQixDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUU7UUFDNUMsV0FBVyxFQUFFLDBEQUEwRDtRQUN2RSxRQUFRLEVBQUUsS0FBSztRQUNmLFNBQVMsRUFBRSxJQUFJO0tBQ2xCLENBQUMsQ0FBQTtJQUVGLE1BQU0sZUFBZSxHQUFHLElBQUkseUJBQWlCLENBQUMsS0FBSyxFQUFFLG1CQUFtQixFQUFFO1FBQ3RFLFdBQVcsRUFBRSxzR0FBc0c7UUFDbkgsUUFBUSxFQUFFLEtBQUs7S0FDbEIsQ0FBQyxDQUFBO0lBRUYsT0FBTztRQUNILEdBQUc7UUFDSCxlQUFlO0tBQ2xCLENBQUE7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVycmFmb3JtVmFyaWFibGUgfSBmcm9tIFwiY2RrdGZcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmFyaWFibGVzIHtcbiAgICBwYXQ6IFRlcnJhZm9ybVZhcmlhYmxlO1xuICAgIGdpdGh1YkNvbmZpZ1VybDogVGVycmFmb3JtVmFyaWFibGU7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjb21tb25WYXJpYWJsZXMoc2NvcGU6IENvbnN0cnVjdCk6IFZhcmlhYmxlcyB7XG4gICAgY29uc3QgcGF0ID0gbmV3IFRlcnJhZm9ybVZhcmlhYmxlKHNjb3BlLCAnUEFUJywge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ0dpdGh1YiBQQVQgd2l0aCBBY3Rpb25zOlJlYWQgYW5kIEFkbWluOlJlYWQrV3JpdGUgc2NvcGVzJyxcbiAgICAgICAgbnVsbGFibGU6IGZhbHNlLFxuICAgICAgICBzZW5zaXRpdmU6IHRydWVcbiAgICB9KVxuXG4gICAgY29uc3QgZ2l0aHViQ29uZmlnVXJsID0gbmV3IFRlcnJhZm9ybVZhcmlhYmxlKHNjb3BlLCAnZ2l0aHViX2NvbmZpZ191cmwnLCB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnR2l0aHViIFVSTCB3aGVyZSBydW5uZXJzIHNob3VsZCByZWdpc3RlciB0by4gRm9ybWF0IGh0dHBzOi8vPEdpdEh1YiBob3N0Pi88eW91cl9lbnRlcnByaXNlL29yZy9yZXBvPicsXG4gICAgICAgIG51bGxhYmxlOiBmYWxzZSxcbiAgICB9KVxuXG4gICAgcmV0dXJuIHtcbiAgICAgICAgcGF0LFxuICAgICAgICBnaXRodWJDb25maWdVcmxcbiAgICB9XG59XG4iXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFibGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi92YXJpYWJsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFRQSwwQ0FvQkM7QUE1QkQsaUNBQTBDO0FBUTFDLFNBQWdCLGVBQWUsQ0FBQyxLQUFnQjtJQUM1QyxNQUFNLEdBQUcsR0FBRyxJQUFJLHlCQUFpQixDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUU7UUFDNUMsV0FBVyxFQUFFLDBEQUEwRDtRQUN2RSxRQUFRLEVBQUUsS0FBSztRQUNmLFNBQVMsRUFBRSxJQUFJO0tBQ2xCLENBQUMsQ0FBQTtJQUVGLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUU3QixNQUFNLGVBQWUsR0FBRyxJQUFJLHlCQUFpQixDQUFDLEtBQUssRUFBRSxtQkFBbUIsRUFBRTtRQUN0RSxXQUFXLEVBQUUsc0dBQXNHO1FBQ25ILFFBQVEsRUFBRSxLQUFLO0tBQ2xCLENBQUMsQ0FBQTtJQUVGLGVBQWUsQ0FBQyxpQkFBaUIsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBRXZELE9BQU87UUFDSCxHQUFHO1FBQ0gsZUFBZTtLQUNsQixDQUFBO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlcnJhZm9ybVZhcmlhYmxlIH0gZnJvbSBcImNka3RmXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFZhcmlhYmxlcyB7XG4gICAgcGF0OiBUZXJyYWZvcm1WYXJpYWJsZTtcbiAgICBnaXRodWJDb25maWdVcmw6IFRlcnJhZm9ybVZhcmlhYmxlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY29tbW9uVmFyaWFibGVzKHNjb3BlOiBDb25zdHJ1Y3QpOiBWYXJpYWJsZXMge1xuICAgIGNvbnN0IHBhdCA9IG5ldyBUZXJyYWZvcm1WYXJpYWJsZShzY29wZSwgJ1BBVCcsIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdHaXRodWIgUEFUIHdpdGggQWN0aW9uczpSZWFkIGFuZCBBZG1pbjpSZWFkK1dyaXRlIHNjb3BlcycsXG4gICAgICAgIG51bGxhYmxlOiBmYWxzZSxcbiAgICAgICAgc2Vuc2l0aXZlOiB0cnVlXG4gICAgfSlcblxuICAgIHBhdC5vdmVycmlkZUxvZ2ljYWxJZCgnUEFUJyk7XG5cbiAgICBjb25zdCBnaXRodWJDb25maWdVcmwgPSBuZXcgVGVycmFmb3JtVmFyaWFibGUoc2NvcGUsICdnaXRodWJfY29uZmlnX3VybCcsIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdHaXRodWIgVVJMIHdoZXJlIHJ1bm5lcnMgc2hvdWxkIHJlZ2lzdGVyIHRvLiBGb3JtYXQgaHR0cHM6Ly88R2l0SHViIGhvc3Q+Lzx5b3VyX2VudGVycHJpc2Uvb3JnL3JlcG8+JyxcbiAgICAgICAgbnVsbGFibGU6IGZhbHNlLFxuICAgIH0pXG5cbiAgICBnaXRodWJDb25maWdVcmwub3ZlcnJpZGVMb2dpY2FsSWQoJ2dpdGh1Yl9jb25maWdfdXJsJyk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgICBwYXQsXG4gICAgICAgIGdpdGh1YkNvbmZpZ1VybFxuICAgIH1cbn1cbiJdfQ==
package/main.tf ADDED
@@ -0,0 +1,26 @@
1
+ locals {
2
+ is_ecs = upper(var.runner_platform) == "ECS" ? 1: 0
3
+ is_aca = upper(var.runner_platform) == "ACA" ? 1: 0
4
+ is_cr = upper(var.runner_platform) == "GCR" ? 1: 0
5
+ }
6
+
7
+ module "ecs" {
8
+ count = local.is_ecs
9
+ source = "./modules/elastic-container-service"
10
+ PAT = var.PAT
11
+ github_config_url = var.github_config_url
12
+ }
13
+
14
+ module "aca" {
15
+ count = local.is_aca
16
+ source = "./modules/azure-container-apps"
17
+ PAT = var.PAT
18
+ github_config_url = var.github_config_url
19
+ }
20
+
21
+ module "gcr" {
22
+ count = local.is_cr
23
+ source = "./modules/google-cloud-run"
24
+ PAT = var.PAT
25
+ github_config_url = var.github_config_url
26
+ }
@@ -64,9 +64,9 @@ No modules.
64
64
 
65
65
  | Name | Description | Type | Default | Required |
66
66
  |------|-------------|------|---------|:--------:|
67
- | <a name="input_aca_PAT_B54A3B25"></a> [aca\_PAT\_B54A3B25](#input\_aca\_PAT\_B54A3B25) | Github PAT with Actions:Read and Admin:Read+Write scopes | `any` | n/a | yes |
68
- | <a name="input_aca_github_config_url_7230B339"></a> [aca\_github\_config\_url\_7230B339](#input\_aca\_github\_config\_url\_7230B339) | Github URL where runners should register to. Format https://<GitHub host>/<your\_enterprise/org/repo> | `any` | n/a | yes |
67
+ | <a name="input_PAT"></a> [PAT](#input\_PAT) | Github PAT with Actions:Read and Admin:Read+Write scopes | `any` | n/a | yes |
69
68
  | <a name="input_aca_location_486B7D73"></a> [aca\_location\_486B7D73](#input\_aca\_location\_486B7D73) | Location where to provision resources to | `string` | `"westeurope"` | no |
69
+ | <a name="input_github_config_url"></a> [github\_config\_url](#input\_github\_config\_url) | Github URL where runners should register to. Format https://<GitHub host>/<your\_enterprise/org/repo> | `any` | n/a | yes |
70
70
 
71
71
  ## Outputs
72
72
 
@@ -329,7 +329,7 @@
329
329
  "secret": [
330
330
  {
331
331
  "name": "pat",
332
- "value": "${var.aca_PAT_B54A3B25}"
332
+ "value": "${var.PAT}"
333
333
  }
334
334
  ],
335
335
  "template": {
@@ -343,7 +343,7 @@
343
343
  },
344
344
  {
345
345
  "name": "GITHUB_CONFIG_URL",
346
- "value": "${var.aca_github_config_url_7230B339}"
346
+ "value": "${var.github_config_url}"
347
347
  },
348
348
  {
349
349
  "name": "AZURE_TENANT_ID",
@@ -615,21 +615,21 @@
615
615
  }
616
616
  },
617
617
  "variable": {
618
- "aca_PAT_B54A3B25": {
618
+ "PAT": {
619
619
  "description": "Github PAT with Actions:Read and Admin:Read+Write scopes",
620
620
  "nullable": false,
621
621
  "sensitive": true
622
622
  },
623
- "aca_github_config_url_7230B339": {
624
- "description": "Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo>",
625
- "nullable": false
626
- },
627
623
  "aca_location_486B7D73": {
628
624
  "default": "westeurope",
629
625
  "description": "Location where to provision resources to",
630
626
  "nullable": false,
631
627
  "sensitive": false,
632
628
  "type": "string"
629
+ },
630
+ "github_config_url": {
631
+ "description": "Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo>",
632
+ "nullable": false
633
633
  }
634
634
  }
635
635
  }
@@ -57,8 +57,8 @@ No modules.
57
57
 
58
58
  | Name | Description | Type | Default | Required |
59
59
  |------|-------------|------|---------|:--------:|
60
- | <a name="input_aws_PAT_4017AC3F"></a> [aws\_PAT\_4017AC3F](#input\_aws\_PAT\_4017AC3F) | Github PAT with Actions:Read and Admin:Read+Write scopes | `any` | n/a | yes |
61
- | <a name="input_aws_github_config_url_BFDD14B2"></a> [aws\_github\_config\_url\_BFDD14B2](#input\_aws\_github\_config\_url\_BFDD14B2) | Github URL where runners should register to. Format https://<GitHub host>/<your\_enterprise/org/repo> | `any` | n/a | yes |
60
+ | <a name="input_PAT"></a> [PAT](#input\_PAT) | Github PAT with Actions:Read and Admin:Read+Write scopes | `any` | n/a | yes |
61
+ | <a name="input_github_config_url"></a> [github\_config\_url](#input\_github\_config\_url) | Github URL where runners should register to. Format https://<GitHub host>/<your\_enterprise/org/repo> | `any` | n/a | yes |
62
62
 
63
63
  ## Outputs
64
64
 
@@ -115,7 +115,7 @@
115
115
  "uniqueId": "aws_AutoscalerTaskDefinition_24A76F67"
116
116
  }
117
117
  },
118
- "container_definitions": "${jsonencode([{\"name\" = \"autoscaler\", \"image\" = \"ghcr.io/hi-fi/gha-runners-on-managed-env:test\", \"essential\" = true, \"environment\" = [{\"name\" = \"PAT\", \"value\" = var.aws_PAT_4017AC3F}, {\"name\" = \"GITHUB_CONFIG_URL\", \"value\" = var.aws_github_config_url_BFDD14B2}, {\"name\" = \"TASK_DEFINITION_ARN\", \"value\" = aws_ecs_task_definition.aws_RunnerTaskDefinition_9C7563BE.arn}, {\"name\" = \"ECS_CLUSTER\", \"value\" = aws_ecs_cluster.aws_Cluster_BA268616.arn}, {\"name\" = \"ECS_SUBNETS\", \"value\" = join(\",\", data.aws_subnets.aws_Subnets_75E5377D.ids)}, {\"name\" = \"ECS_SECURITY_GROUPS\", \"value\" = join(\",\", data.aws_security_groups.aws_SecurityGroups_BAABB08D.ids)}, {\"name\" = \"SCALE_SET_NAME\", \"value\" = \"ecs-runner-set\"}], \"logConfiguration\" = {\"logDriver\" = \"awslogs\", \"options\" = {\"awslogs-group\" = aws_cloudwatch_log_group.aws_AutoscalerLogGroup_BFE58053.name, \"awslogs-region\" = data.aws_region.aws_Region_7477CA06.name, \"awslogs-stream-prefix\" = \"ecs\"}}}])}",
118
+ "container_definitions": "${jsonencode([{\"name\" = \"autoscaler\", \"image\" = \"ghcr.io/hi-fi/gha-runners-on-managed-env:test\", \"essential\" = true, \"environment\" = [{\"name\" = \"PAT\", \"value\" = var.PAT}, {\"name\" = \"GITHUB_CONFIG_URL\", \"value\" = var.github_config_url}, {\"name\" = \"TASK_DEFINITION_ARN\", \"value\" = aws_ecs_task_definition.aws_RunnerTaskDefinition_9C7563BE.arn}, {\"name\" = \"ECS_CLUSTER\", \"value\" = aws_ecs_cluster.aws_Cluster_BA268616.arn}, {\"name\" = \"ECS_SUBNETS\", \"value\" = join(\",\", data.aws_subnets.aws_Subnets_75E5377D.ids)}, {\"name\" = \"ECS_SECURITY_GROUPS\", \"value\" = join(\",\", data.aws_security_groups.aws_SecurityGroups_BAABB08D.ids)}, {\"name\" = \"SCALE_SET_NAME\", \"value\" = \"ecs-runner-set\"}], \"logConfiguration\" = {\"logDriver\" = \"awslogs\", \"options\" = {\"awslogs-group\" = aws_cloudwatch_log_group.aws_AutoscalerLogGroup_BFE58053.name, \"awslogs-region\" = data.aws_region.aws_Region_7477CA06.name, \"awslogs-stream-prefix\" = \"ecs\"}}}])}",
119
119
  "cpu": "256",
120
120
  "execution_role_arn": "${aws_iam_role.aws_TaskExecutionRole_FAB64402.arn}",
121
121
  "family": "Autoscaler",
@@ -301,12 +301,12 @@
301
301
  }
302
302
  },
303
303
  "variable": {
304
- "aws_PAT_4017AC3F": {
304
+ "PAT": {
305
305
  "description": "Github PAT with Actions:Read and Admin:Read+Write scopes",
306
306
  "nullable": false,
307
307
  "sensitive": true
308
308
  },
309
- "aws_github_config_url_BFDD14B2": {
309
+ "github_config_url": {
310
310
  "description": "Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo>",
311
311
  "nullable": false
312
312
  }
@@ -53,8 +53,8 @@ No modules.
53
53
 
54
54
  | Name | Description | Type | Default | Required |
55
55
  |------|-------------|------|---------|:--------:|
56
- | <a name="input_cr_PAT_DD795492"></a> [cr\_PAT\_DD795492](#input\_cr\_PAT\_DD795492) | Github PAT with Actions:Read and Admin:Read+Write scopes | `any` | n/a | yes |
57
- | <a name="input_cr_github_config_url_9957B21B"></a> [cr\_github\_config\_url\_9957B21B](#input\_cr\_github\_config\_url\_9957B21B) | Github URL where runners should register to. Format https://<GitHub host>/<your\_enterprise/org/repo> | `any` | n/a | yes |
56
+ | <a name="input_PAT"></a> [PAT](#input\_PAT) | Github PAT with Actions:Read and Admin:Read+Write scopes | `any` | n/a | yes |
57
+ | <a name="input_github_config_url"></a> [github\_config\_url](#input\_github\_config\_url) | Github URL where runners should register to. Format https://<GitHub host>/<your\_enterprise/org/repo> | `any` | n/a | yes |
58
58
 
59
59
  ## Outputs
60
60
 
@@ -66,11 +66,11 @@
66
66
  "env": [
67
67
  {
68
68
  "name": "PAT",
69
- "value": "${var.cr_PAT_DD795492}"
69
+ "value": "${var.PAT}"
70
70
  },
71
71
  {
72
72
  "name": "GITHUB_CONFIG_URL",
73
- "value": "${var.cr_github_config_url_9957B21B}"
73
+ "value": "${var.github_config_url}"
74
74
  },
75
75
  {
76
76
  "name": "JOB_NAME",
@@ -342,12 +342,12 @@
342
342
  }
343
343
  },
344
344
  "variable": {
345
- "cr_PAT_DD795492": {
345
+ "PAT": {
346
346
  "description": "Github PAT with Actions:Read and Admin:Read+Write scopes",
347
347
  "nullable": false,
348
348
  "sensitive": true
349
349
  },
350
- "cr_github_config_url_9957B21B": {
350
+ "github_config_url": {
351
351
  "description": "Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo>",
352
352
  "nullable": false
353
353
  }
package/package.json CHANGED
@@ -91,7 +91,7 @@
91
91
  "publishConfig": {
92
92
  "access": "public"
93
93
  },
94
- "version": "0.0.1",
94
+ "version": "0.0.2",
95
95
  "jest": {
96
96
  "coverageProvider": "v8",
97
97
  "testMatch": [
@@ -0,0 +1,188 @@
1
+ // Code generated with Gemini
2
+
3
+ import * as fs from 'fs';
4
+ import * as path from 'path';
5
+
6
+ interface VariableDefinition {
7
+ name: string;
8
+ description: string;
9
+ submodules: string[];
10
+ customInfo?: Record<string, any>;
11
+ }
12
+
13
+ interface SubmoduleVariables {
14
+ [submodulePath: string]: VariableDefinition[];
15
+ }
16
+
17
+ const ROOT_DIR = '.';
18
+ const OUTPUT_FILE = 'variables.tf';
19
+ const VARIABLE_FILE_NAME = 'cdk.tf.json';
20
+ const GENERATED_COMMENT_START = '# Variables generated by terraform-variable-collector start';
21
+ const GENERATED_COMMENT_END = '# Variables generated by terraform-variable-collector end';
22
+
23
+ /**
24
+ * Extracts variable definitions from a cdk.tf.json file.
25
+ */
26
+ function extractVariables(filePath: string): VariableDefinition[] {
27
+ try {
28
+ const fileContent = fs.readFileSync(filePath, 'utf-8');
29
+ const jsonData = JSON.parse(fileContent);
30
+
31
+ if (!jsonData.variable || typeof jsonData.variable !== 'object') {
32
+ return [];
33
+ }
34
+
35
+ const variables: VariableDefinition[] = [];
36
+ for (const varName in jsonData.variable) {
37
+ if (jsonData.variable.hasOwnProperty(varName)) {
38
+ const varConfig = jsonData.variable[varName];
39
+ if (typeof varConfig === 'object' && varConfig !== null) {
40
+ const description = typeof varConfig.description === 'string' ? varConfig.description : 'No description provided.';
41
+ const customInfo = varConfig.customInfo ? varConfig.customInfo : {};
42
+ variables.push({ name: varName, description, submodules: [], customInfo });
43
+ }
44
+ }
45
+ }
46
+ return variables;
47
+ } catch (error) {
48
+ console.error(`Error processing file: ${filePath}`, error);
49
+ return [];
50
+ }
51
+ }
52
+
53
+ /**
54
+ * Recursively searches for cdk.tf.json files within the "modules" subdirectory.
55
+ */
56
+ function findSubmoduleVariables(dir: string): SubmoduleVariables {
57
+ const submoduleVariables: SubmoduleVariables = {};
58
+ const modulesDir = path.join(dir, 'modules');
59
+
60
+ if (!fs.existsSync(modulesDir)) {
61
+ console.warn(`Warning: 'modules' directory not found at ${modulesDir}. No variables will be collected.`);
62
+ return {};
63
+ }
64
+
65
+ function walk(currentDir: string) {
66
+ const files = fs.readdirSync(currentDir);
67
+ for (const file of files) {
68
+ const filePath = path.join(currentDir, file);
69
+ const stat = fs.statSync(filePath);
70
+
71
+ if (stat.isDirectory()) {
72
+ walk(filePath);
73
+ } else if (file === VARIABLE_FILE_NAME) {
74
+ const submodulePath = path.relative(modulesDir, currentDir);
75
+ if (submodulePath) {
76
+ const variables = extractVariables(filePath);
77
+ if (variables.length > 0) {
78
+ submoduleVariables[submodulePath] = variables;
79
+ }
80
+ }
81
+ }
82
+ }
83
+ }
84
+
85
+ walk(modulesDir);
86
+ return submoduleVariables;
87
+ }
88
+
89
+ /**
90
+ * Generates the content for the root module's variables.tf file, combining
91
+ * similarly named variables. It uses the description from the first
92
+ * occurrence of the variable. It now updates an existing file, preserving
93
+ * content outside of the generated variable block.
94
+ */
95
+ function generateRootVariablesTf(collectedVariables: SubmoduleVariables): void {
96
+ let existingContent = '';
97
+ if (fs.existsSync(OUTPUT_FILE)) {
98
+ existingContent = fs.readFileSync(OUTPUT_FILE, 'utf-8');
99
+ }
100
+
101
+ let outputContent = `${GENERATED_COMMENT_START}\n`;
102
+ const combinedVariables: { [name: string]: VariableDefinition } = {};
103
+
104
+ for (const submodulePath in collectedVariables) {
105
+ if (collectedVariables.hasOwnProperty(submodulePath)) {
106
+ const variables = collectedVariables[submodulePath];
107
+ for (const variable of variables) {
108
+ if (combinedVariables[variable.name]) {
109
+ // Variable name already exists, so combine, but keep original description
110
+ combinedVariables[variable.name].submodules.push(`modules/${submodulePath}`);
111
+ } else {
112
+ // Variable name doesn't exist, so add it
113
+ combinedVariables[variable.name] = {
114
+ ...variable,
115
+ submodules: [`modules/${submodulePath}`],
116
+ };
117
+ }
118
+ }
119
+ }
120
+ }
121
+
122
+ for (const varName in combinedVariables) {
123
+ if (combinedVariables.hasOwnProperty(varName)) {
124
+ const variable = combinedVariables[varName];
125
+ const submoduleList = variable.submodules.join(', ');
126
+ outputContent += `variable "${varName}" {\n`;
127
+ outputContent += ` type = any\n`;
128
+ outputContent += ` description = "${variable.description} (Defined in: ${submoduleList})"\n`;
129
+ if (variable.customInfo && Object.keys(variable.customInfo).length > 0) {
130
+ outputContent += ` # Custom Information:\n`;
131
+ for (const key in variable.customInfo) {
132
+ if (variable.customInfo.hasOwnProperty(key)) {
133
+ const value = variable.customInfo[key];
134
+ outputContent += ` # ${key} = ${JSON.stringify(value)}\n`;
135
+ }
136
+ }
137
+ }
138
+ outputContent += `}\n\n`;
139
+ }
140
+ }
141
+ outputContent += `${GENERATED_COMMENT_END}\n`;
142
+
143
+ // Use regular expressions to find and replace the generated block
144
+ const startMarkerRegex = new RegExp(GENERATED_COMMENT_START.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'));
145
+ const endMarkerRegex = new RegExp(GENERATED_COMMENT_END.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'));
146
+ const existingGeneratedBlockRegex = new RegExp(
147
+ `${startMarkerRegex.source}[\\s\\S]*${endMarkerRegex.source}`,
148
+ 'g',
149
+ );
150
+
151
+ let updatedContent: string;
152
+ if (existingGeneratedBlockRegex.test(existingContent)) {
153
+ // Replace the existing generated block with the new content
154
+ updatedContent = existingContent.replace(existingGeneratedBlockRegex, outputContent);
155
+ } else {
156
+ // Append the generated block to the end of the file, or create a new file
157
+ updatedContent = existingContent + outputContent;
158
+ }
159
+
160
+ fs.writeFileSync(OUTPUT_FILE, updatedContent);
161
+ console.log(
162
+ `Generated (or updated) root module's ${OUTPUT_FILE} with combined variables, preserving existing content.`,
163
+ );
164
+ console.log('Review and adjust the types and other attributes as needed.');
165
+ }
166
+
167
+ function main(): void {
168
+ const collectedVars = findSubmoduleVariables(ROOT_DIR);
169
+
170
+ if (Object.keys(collectedVars).length > 0) {
171
+ console.log('Collected variables from submodules:');
172
+ for (const submodulePath in collectedVars) {
173
+ if (collectedVars.hasOwnProperty(submodulePath)) {
174
+ console.log(` Submodule: modules/${submodulePath}`);
175
+ const variables = collectedVars[submodulePath];
176
+ for (const varDef of variables) {
177
+ console.log(` - Name: ${varDef.name}, Description: ${varDef.description}`);
178
+ }
179
+ }
180
+ }
181
+ generateRootVariablesTf(collectedVars);
182
+ } else {
183
+ console.log('No submodules with cdk.tf.json files found in the "modules" directory.');
184
+ }
185
+ }
186
+
187
+ main();
188
+
package/variables.tf ADDED
@@ -0,0 +1,27 @@
1
+ variable "runner_platform" {
2
+ nullable = false
3
+ type = string
4
+ description = "Runner platform hosting ARC and runners. Possible values ACA (Azure Container Apps), ECS (Elastic Container Service) and GCR (Google Cloud Run)"
5
+ validation {
6
+ condition = can(regex("^(ACA|ECR|GCR)$", upper(var.runner_platform)))
7
+ error_message = "Runner platform has to be either ACA, ECR or GCR (case insensitive)."
8
+ }
9
+ }
10
+
11
+ # Variables generated by terraform-variable-collector start
12
+ variable "PAT" {
13
+ type = any
14
+ description = "Github PAT with Actions:Read and Admin:Read+Write scopes (Defined in: modules/azure-container-apps, modules/elastic-container-service, modules/google-cloud-run)"
15
+ }
16
+
17
+ variable "aca_location_486B7D73" {
18
+ type = any
19
+ description = "Location where to provision resources to (Defined in: modules/azure-container-apps)"
20
+ }
21
+
22
+ variable "github_config_url" {
23
+ type = any
24
+ description = "Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo> (Defined in: modules/azure-container-apps, modules/elastic-container-service, modules/google-cloud-run)"
25
+ }
26
+
27
+ # Variables generated by terraform-variable-collector end