terraform-cdk-serverless-github-actions-runner-controller 0.0.7 → 0.0.9

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/lib/lib/gcp.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { Construct } from 'constructs';
1
+ import { Construct } from "constructs";
2
2
  export declare class Gcp extends Construct {
3
3
  constructor(scope: Construct, id: string);
4
4
  }
package/lib/lib/gcp.js CHANGED
@@ -18,72 +18,72 @@ const variables_1 = require("./variables");
18
18
  class Gcp extends constructs_1.Construct {
19
19
  constructor(scope, id) {
20
20
  super(scope, id);
21
- const location = 'europe-north1';
22
- const project = 'gha-runner-example';
23
- new provider_1.GoogleProvider(this, 'google', {
21
+ const location = "europe-north1";
22
+ const project = "gha-runner-example";
23
+ new provider_1.GoogleProvider(this, "google", {
24
24
  project,
25
25
  region: location,
26
26
  });
27
- new provider_2.NullProvider(this, 'null');
27
+ new provider_2.NullProvider(this, "null");
28
28
  const { pat, githubConfigUrl } = (0, variables_1.commonVariables)(this);
29
- const registry = new artifact_registry_repository_1.ArtifactRegistryRepository(this, 'registry', {
30
- format: 'DOCKER',
31
- mode: 'REMOTE_REPOSITORY',
32
- repositoryId: 'gha-runner-test',
33
- description: 'Repository to host run and resulting images from GHA runs',
29
+ const registry = new artifact_registry_repository_1.ArtifactRegistryRepository(this, "registry", {
30
+ format: "DOCKER",
31
+ mode: "REMOTE_REPOSITORY",
32
+ repositoryId: "gha-runner-test",
33
+ description: "Repository to host run and resulting images from GHA runs",
34
34
  remoteRepositoryConfig: {
35
35
  dockerRepository: {
36
36
  customRepository: {
37
- uri: 'https://ghcr.io',
37
+ uri: "https://ghcr.io",
38
38
  },
39
39
  },
40
40
  },
41
41
  });
42
- const jobSa = new service_account_1.ServiceAccount(this, 'jobServiceAccount', {
43
- accountId: 'gha-runner-job-sa',
42
+ const jobSa = new service_account_1.ServiceAccount(this, "jobServiceAccount", {
43
+ accountId: "gha-runner-job-sa",
44
44
  });
45
- const runnerRole = new project_iam_custom_role_1.ProjectIamCustomRole(this, 'runnerRole', {
46
- roleId: 'ghaRunnerRole',
47
- title: 'GHA Runner Role',
45
+ const runnerRole = new project_iam_custom_role_1.ProjectIamCustomRole(this, "runnerRole", {
46
+ roleId: "ghaRunnerRole",
47
+ title: "GHA Runner Role",
48
48
  permissions: [
49
- 'artifactregistry.dockerimages.get',
50
- 'artifactregistry.dockerimages.list',
51
- 'run.jobs.run',
52
- 'run.jobs.create',
53
- 'run.jobs.delete',
54
- 'run.jobs.list',
49
+ "artifactregistry.dockerimages.get",
50
+ "artifactregistry.dockerimages.list",
51
+ "run.jobs.run",
52
+ "run.jobs.create",
53
+ "run.jobs.delete",
54
+ "run.jobs.list",
55
55
  // Needed for waiting
56
- 'run.executions.get',
56
+ "run.executions.get",
57
57
  ],
58
58
  });
59
- const jobPolicyMember = new cdktf_1.TerraformLocal(this, 'ghaMember', `serviceAccount:${jobSa.email}`);
60
- new project_iam_member_1.ProjectIamMember(this, 'runnerRoleBinding', {
59
+ const jobPolicyMember = new cdktf_1.TerraformLocal(this, "ghaMember", `serviceAccount:${jobSa.email}`);
60
+ new project_iam_member_1.ProjectIamMember(this, "runnerRoleBinding", {
61
61
  member: jobPolicyMember.toString(),
62
62
  project,
63
63
  role: runnerRole.id,
64
64
  });
65
- new project_iam_member_1.ProjectIamMember(this, 'runnerRoleBindingStorage', {
65
+ new project_iam_member_1.ProjectIamMember(this, "runnerRoleBindingStorage", {
66
66
  member: jobPolicyMember.toString(),
67
67
  project,
68
- role: 'roles/storage.admin',
68
+ role: "roles/storage.admin",
69
69
  });
70
- new project_iam_member_1.ProjectIamMember(this, 'runnerRoleBindingRunServiceAgent', {
70
+ new project_iam_member_1.ProjectIamMember(this, "runnerRoleBindingRunServiceAgent", {
71
71
  member: jobPolicyMember.toString(),
72
72
  project,
73
- role: 'roles/run.serviceAgent',
73
+ role: "roles/run.serviceAgent",
74
74
  });
75
- new project_iam_member_1.ProjectIamMember(this, 'runnerRoleBindingRunViewer', {
75
+ new project_iam_member_1.ProjectIamMember(this, "runnerRoleBindingRunViewer", {
76
76
  member: jobPolicyMember.toString(),
77
77
  project,
78
- role: 'roles/run.viewer',
78
+ role: "roles/run.viewer",
79
79
  });
80
- const storageName = 'gha-runner-job-externals';
81
- const createBucket = new cdktf_1.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`);
80
+ const storageName = "gha-runner-job-externals";
81
+ const createBucket = new cdktf_1.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`);
82
82
  // Hierarchial namespaces can't be enabled with Terraform.
83
- const bucketCreation = new resource_1.Resource(this, 'gcloud', {
83
+ const bucketCreation = new resource_1.Resource(this, "gcloud", {
84
84
  provisioners: [
85
85
  {
86
- type: 'local-exec',
86
+ type: "local-exec",
87
87
  command: createBucket.fqn,
88
88
  },
89
89
  ],
@@ -92,9 +92,9 @@ class Gcp extends constructs_1.Construct {
92
92
  },
93
93
  });
94
94
  // TODO: check caching https://cloud.google.com/artifact-registry/docs/pull-cached-dockerhub-images
95
- const runnerJob = new cloud_run_v2_job_1.CloudRunV2Job(this, 'ghaJob', {
95
+ const runnerJob = new cloud_run_v2_job_1.CloudRunV2Job(this, "ghaJob", {
96
96
  deletionProtection: false,
97
- name: 'gha-runner-job',
97
+ name: "gha-runner-job",
98
98
  location,
99
99
  template: {
100
100
  template: {
@@ -103,41 +103,41 @@ class Gcp extends constructs_1.Construct {
103
103
  image: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/actions-runner:cr`,
104
104
  env: [
105
105
  {
106
- name: 'CLOUDSDK_RUN_REGION',
106
+ name: "CLOUDSDK_RUN_REGION",
107
107
  value: location,
108
108
  },
109
109
  {
110
- name: 'GOOGLE_CLOUD_PROJECT',
110
+ name: "GOOGLE_CLOUD_PROJECT",
111
111
  value: project,
112
112
  },
113
113
  {
114
- name: 'EXTERNAL_STORAGE_NAME',
114
+ name: "EXTERNAL_STORAGE_NAME",
115
115
  value: storageName,
116
116
  },
117
117
  // 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
118
118
  {
119
- name: 'TAR_OPTIONS',
120
- value: '--touch --no-overwrite-dir --no-same-owner',
119
+ name: "TAR_OPTIONS",
120
+ value: "--touch --no-overwrite-dir --no-same-owner",
121
121
  },
122
122
  ],
123
123
  volumeMounts: [
124
124
  {
125
- name: 'externals',
126
- mountPath: '/home/runner/_work/externals',
125
+ name: "externals",
126
+ mountPath: "/home/runner/_work/externals",
127
127
  },
128
128
  ],
129
- command: ['/home/runner/ephemeral_runner.sh'],
129
+ command: ["/home/runner/ephemeral_runner.sh"],
130
130
  resources: {
131
131
  limits: {
132
- cpu: '1',
133
- memory: '2Gi',
132
+ cpu: "1",
133
+ memory: "2Gi",
134
134
  },
135
135
  },
136
136
  },
137
137
  ],
138
138
  volumes: [
139
139
  {
140
- name: 'externals',
140
+ name: "externals",
141
141
  gcs: {
142
142
  bucket: storageName,
143
143
  },
@@ -149,52 +149,52 @@ class Gcp extends constructs_1.Construct {
149
149
  },
150
150
  dependsOn: [bucketCreation],
151
151
  });
152
- const autoscalerSa = new service_account_1.ServiceAccount(this, 'autoscalerServiceAccount', {
153
- accountId: 'autoscaler-sa',
152
+ const autoscalerSa = new service_account_1.ServiceAccount(this, "autoscalerServiceAccount", {
153
+ accountId: "autoscaler-sa",
154
154
  });
155
- new project_iam_custom_role_1.ProjectIamCustomRole(this, 'autoscalerRole', {
156
- roleId: 'ghaAutoscalerRole',
157
- title: 'GHA Autoscaler Role',
155
+ new project_iam_custom_role_1.ProjectIamCustomRole(this, "autoscalerRole", {
156
+ roleId: "ghaAutoscalerRole",
157
+ title: "GHA Autoscaler Role",
158
158
  permissions: [
159
- 'artifactregistry.dockerimages.get',
160
- 'artifactregistry.dockerimages.list',
161
- 'run.jobs.run',
162
- 'run.jobs.create',
163
- 'run.jobs.delete',
159
+ "artifactregistry.dockerimages.get",
160
+ "artifactregistry.dockerimages.list",
161
+ "run.jobs.run",
162
+ "run.jobs.create",
163
+ "run.jobs.delete",
164
164
  ],
165
165
  });
166
- const autoscalerPolicyMember = new cdktf_1.TerraformLocal(this, 'autoscalerMember', `serviceAccount:${autoscalerSa.email}`);
166
+ const autoscalerPolicyMember = new cdktf_1.TerraformLocal(this, "autoscalerMember", `serviceAccount:${autoscalerSa.email}`);
167
167
  // TODO: replace 2 following with more specific ones.
168
- new project_iam_member_1.ProjectIamMember(this, 'autoscalerRoleBindingRun', {
168
+ new project_iam_member_1.ProjectIamMember(this, "autoscalerRoleBindingRun", {
169
169
  member: autoscalerPolicyMember.toString(),
170
170
  project,
171
- role: 'roles/run.developer',
171
+ role: "roles/run.developer",
172
172
  });
173
- new project_iam_member_1.ProjectIamMember(this, 'autoscalerRoleBindingStorage', {
173
+ new project_iam_member_1.ProjectIamMember(this, "autoscalerRoleBindingStorage", {
174
174
  member: autoscalerPolicyMember.toString(),
175
175
  project,
176
- role: 'roles/storage.admin',
176
+ role: "roles/storage.admin",
177
177
  });
178
- new project_iam_member_1.ProjectIamMember(this, 'autoscalerRoleBindingRunServiceAgent', {
178
+ new project_iam_member_1.ProjectIamMember(this, "autoscalerRoleBindingRunServiceAgent", {
179
179
  member: autoscalerPolicyMember.toString(),
180
180
  project,
181
- role: 'roles/run.serviceAgent',
181
+ role: "roles/run.serviceAgent",
182
182
  });
183
- new cloud_run_service_1.CloudRunService(this, 'autoscalerService', {
183
+ new cloud_run_service_1.CloudRunService(this, "autoscalerService", {
184
184
  location,
185
- name: 'gha-autoscaler',
185
+ name: "gha-autoscaler",
186
186
  metadata: {
187
187
  annotations: {
188
- 'run.googleapis.com/ingress': 'internal',
188
+ "run.googleapis.com/ingress": "internal",
189
189
  },
190
190
  },
191
191
  template: {
192
192
  metadata: {
193
193
  annotations: {
194
- 'autoscaling.knative.dev/maxScale': '1',
195
- 'autoscaling.knative.dev/minScale': '1',
196
- 'run.googleapis.com/cpu-throttling': 'false',
197
- 'run.googleapis.com/startup-cpu-boost': 'false',
194
+ "autoscaling.knative.dev/maxScale": "1",
195
+ "autoscaling.knative.dev/minScale": "1",
196
+ "run.googleapis.com/cpu-throttling": "false",
197
+ "run.googleapis.com/startup-cpu-boost": "false",
198
198
  },
199
199
  },
200
200
  spec: {
@@ -204,35 +204,35 @@ class Gcp extends constructs_1.Construct {
204
204
  image: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/gha-runners-on-managed-env:test`,
205
205
  env: [
206
206
  {
207
- name: 'PAT',
207
+ name: "PAT",
208
208
  value: pat.value,
209
209
  },
210
210
  {
211
- name: 'GITHUB_CONFIG_URL',
211
+ name: "GITHUB_CONFIG_URL",
212
212
  value: githubConfigUrl.value,
213
213
  },
214
214
  {
215
- name: 'JOB_NAME',
215
+ name: "JOB_NAME",
216
216
  value: runnerJob.name,
217
217
  },
218
218
  {
219
- name: 'SCALE_SET_NAME',
220
- value: 'cr-runner-set',
219
+ name: "SCALE_SET_NAME",
220
+ value: "cr-runner-set",
221
221
  },
222
222
  {
223
- name: 'CLOUDSDK_RUN_REGION',
223
+ name: "CLOUDSDK_RUN_REGION",
224
224
  value: location,
225
225
  },
226
226
  {
227
- name: 'GOOGLE_CLOUD_PROJECT',
227
+ name: "GOOGLE_CLOUD_PROJECT",
228
228
  value: project,
229
229
  },
230
230
  ],
231
231
  resources: {
232
232
  // Service would work for much lower, but these are minimum values for "always on" mode
233
233
  limits: {
234
- cpu: '1000m',
235
- memory: '512Mi',
234
+ cpu: "1000m",
235
+ memory: "512Mi",
236
236
  },
237
237
  },
238
238
  },
@@ -245,5 +245,5 @@ class Gcp extends constructs_1.Construct {
245
245
  }
246
246
  exports.Gcp = Gcp;
247
247
  _a = JSII_RTTI_SYMBOL_1;
248
- Gcp[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Gcp", version: "0.0.7" };
249
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gcp.js","sourceRoot":"","sources":["../../src/lib/gcp.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArtifactRegistryRepository } from '@cdktf/provider-google/lib/artifact-registry-repository'\nimport { CloudRunService } from '@cdktf/provider-google/lib/cloud-run-service'\nimport { CloudRunV2Job } from '@cdktf/provider-google/lib/cloud-run-v2-job'\nimport { ProjectIamCustomRole } from '@cdktf/provider-google/lib/project-iam-custom-role'\nimport { ProjectIamMember } from '@cdktf/provider-google/lib/project-iam-member'\nimport { GoogleProvider } from '@cdktf/provider-google/lib/provider'\nimport { ServiceAccount } from '@cdktf/provider-google/lib/service-account'\nimport { NullProvider } from '@cdktf/provider-null/lib/provider'\nimport { Resource } from '@cdktf/provider-null/lib/resource'\nimport { TerraformLocal } from 'cdktf'\nimport { Construct } from 'constructs'\nimport { commonVariables } from './variables'\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(\n      this,\n      'ghaMember',\n      `serviceAccount:${jobSa.email}`,\n    )\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(\n      this,\n      'bucketModification',\n      `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\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: [bucketCreation],\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(\n      this,\n      'autoscalerMember',\n      `serviceAccount:${autoscalerSa.email}`,\n    )\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    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              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"]}
248
+ Gcp[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Gcp", version: "0.0.9" };
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gcp.js","sourceRoot":"","sources":["../../src/lib/gcp.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArtifactRegistryRepository } from \"@cdktf/provider-google/lib/artifact-registry-repository\";\nimport { CloudRunService } from \"@cdktf/provider-google/lib/cloud-run-service\";\nimport { CloudRunV2Job } from \"@cdktf/provider-google/lib/cloud-run-v2-job\";\nimport { ProjectIamCustomRole } from \"@cdktf/provider-google/lib/project-iam-custom-role\";\nimport { ProjectIamMember } from \"@cdktf/provider-google/lib/project-iam-member\";\nimport { GoogleProvider } from \"@cdktf/provider-google/lib/provider\";\nimport { ServiceAccount } from \"@cdktf/provider-google/lib/service-account\";\nimport { NullProvider } from \"@cdktf/provider-null/lib/provider\";\nimport { Resource } from \"@cdktf/provider-null/lib/resource\";\nimport { TerraformLocal } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { commonVariables } from \"./variables\";\n\nexport class Gcp extends Construct {\n\tconstructor(scope: Construct, id: string) {\n\t\tsuper(scope, id);\n\n\t\tconst location = \"europe-north1\";\n\t\tconst project = \"gha-runner-example\";\n\n\t\tnew GoogleProvider(this, \"google\", {\n\t\t\tproject,\n\t\t\tregion: location,\n\t\t});\n\n\t\tnew NullProvider(this, \"null\");\n\n\t\tconst { pat, githubConfigUrl } = commonVariables(this);\n\n\t\tconst registry = new ArtifactRegistryRepository(this, \"registry\", {\n\t\t\tformat: \"DOCKER\",\n\t\t\tmode: \"REMOTE_REPOSITORY\",\n\t\t\trepositoryId: \"gha-runner-test\",\n\t\t\tdescription: \"Repository to host run and resulting images from GHA runs\",\n\t\t\tremoteRepositoryConfig: {\n\t\t\t\tdockerRepository: {\n\t\t\t\t\tcustomRepository: {\n\t\t\t\t\t\turi: \"https://ghcr.io\",\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\n\t\tconst jobSa = new ServiceAccount(this, \"jobServiceAccount\", {\n\t\t\taccountId: \"gha-runner-job-sa\",\n\t\t});\n\n\t\tconst runnerRole = new ProjectIamCustomRole(this, \"runnerRole\", {\n\t\t\troleId: \"ghaRunnerRole\",\n\t\t\ttitle: \"GHA Runner Role\",\n\t\t\tpermissions: [\n\t\t\t\t\"artifactregistry.dockerimages.get\",\n\t\t\t\t\"artifactregistry.dockerimages.list\",\n\t\t\t\t\"run.jobs.run\",\n\t\t\t\t\"run.jobs.create\",\n\t\t\t\t\"run.jobs.delete\",\n\t\t\t\t\"run.jobs.list\",\n\t\t\t\t// Needed for waiting\n\t\t\t\t\"run.executions.get\",\n\t\t\t],\n\t\t});\n\n\t\tconst jobPolicyMember = new TerraformLocal(\n\t\t\tthis,\n\t\t\t\"ghaMember\",\n\t\t\t`serviceAccount:${jobSa.email}`,\n\t\t);\n\n\t\tnew ProjectIamMember(this, \"runnerRoleBinding\", {\n\t\t\tmember: jobPolicyMember.toString(),\n\t\t\tproject,\n\t\t\trole: runnerRole.id,\n\t\t});\n\n\t\tnew ProjectIamMember(this, \"runnerRoleBindingStorage\", {\n\t\t\tmember: jobPolicyMember.toString(),\n\t\t\tproject,\n\t\t\trole: \"roles/storage.admin\",\n\t\t});\n\n\t\tnew ProjectIamMember(this, \"runnerRoleBindingRunServiceAgent\", {\n\t\t\tmember: jobPolicyMember.toString(),\n\t\t\tproject,\n\t\t\trole: \"roles/run.serviceAgent\",\n\t\t});\n\n\t\tnew ProjectIamMember(this, \"runnerRoleBindingRunViewer\", {\n\t\t\tmember: jobPolicyMember.toString(),\n\t\t\tproject,\n\t\t\trole: \"roles/run.viewer\",\n\t\t});\n\n\t\tconst storageName = \"gha-runner-job-externals\";\n\t\tconst createBucket = new TerraformLocal(\n\t\t\tthis,\n\t\t\t\"bucketModification\",\n\t\t\t`CLOUDSDK_CORE_DISABLE_PROMPTS=1 gcloud alpha storage buckets create gs://${storageName} --project=${project} --location=${location} --uniform-bucket-level-access --enable-hierarchical-namespace`,\n\t\t);\n\n\t\t// Hierarchial namespaces can't be enabled with Terraform.\n\t\tconst bucketCreation = new Resource(this, \"gcloud\", {\n\t\t\tprovisioners: [\n\t\t\t\t{\n\t\t\t\t\ttype: \"local-exec\",\n\t\t\t\t\tcommand: createBucket.fqn,\n\t\t\t\t},\n\t\t\t],\n\t\t\ttriggers: {\n\t\t\t\tfqn: createBucket.fqn,\n\t\t\t},\n\t\t});\n\n\t\t// TODO: check caching https://cloud.google.com/artifact-registry/docs/pull-cached-dockerhub-images\n\t\tconst runnerJob = new CloudRunV2Job(this, \"ghaJob\", {\n\t\t\tdeletionProtection: false,\n\t\t\tname: \"gha-runner-job\",\n\t\t\tlocation,\n\t\t\ttemplate: {\n\t\t\t\ttemplate: {\n\t\t\t\t\tcontainers: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\timage: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/actions-runner:cr`,\n\t\t\t\t\t\t\tenv: [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"CLOUDSDK_RUN_REGION\",\n\t\t\t\t\t\t\t\t\tvalue: location,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"GOOGLE_CLOUD_PROJECT\",\n\t\t\t\t\t\t\t\t\tvalue: project,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"EXTERNAL_STORAGE_NAME\",\n\t\t\t\t\t\t\t\t\tvalue: storageName,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t// 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\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"TAR_OPTIONS\",\n\t\t\t\t\t\t\t\t\tvalue: \"--touch --no-overwrite-dir --no-same-owner\",\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\tvolumeMounts: [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"externals\",\n\t\t\t\t\t\t\t\t\tmountPath: \"/home/runner/_work/externals\",\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\tcommand: [\"/home/runner/ephemeral_runner.sh\"],\n\t\t\t\t\t\t\tresources: {\n\t\t\t\t\t\t\t\tlimits: {\n\t\t\t\t\t\t\t\t\tcpu: \"1\",\n\t\t\t\t\t\t\t\t\tmemory: \"2Gi\",\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t\tvolumes: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tname: \"externals\",\n\t\t\t\t\t\t\tgcs: {\n\t\t\t\t\t\t\t\tbucket: storageName,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t\tmaxRetries: 0,\n\t\t\t\t\tserviceAccount: jobSa.email,\n\t\t\t\t},\n\t\t\t},\n\t\t\tdependsOn: [bucketCreation],\n\t\t});\n\n\t\tconst autoscalerSa = new ServiceAccount(this, \"autoscalerServiceAccount\", {\n\t\t\taccountId: \"autoscaler-sa\",\n\t\t});\n\n\t\tnew ProjectIamCustomRole(this, \"autoscalerRole\", {\n\t\t\troleId: \"ghaAutoscalerRole\",\n\t\t\ttitle: \"GHA Autoscaler Role\",\n\t\t\tpermissions: [\n\t\t\t\t\"artifactregistry.dockerimages.get\",\n\t\t\t\t\"artifactregistry.dockerimages.list\",\n\t\t\t\t\"run.jobs.run\",\n\t\t\t\t\"run.jobs.create\",\n\t\t\t\t\"run.jobs.delete\",\n\t\t\t],\n\t\t});\n\n\t\tconst autoscalerPolicyMember = new TerraformLocal(\n\t\t\tthis,\n\t\t\t\"autoscalerMember\",\n\t\t\t`serviceAccount:${autoscalerSa.email}`,\n\t\t);\n\n\t\t// TODO: replace 2 following with more specific ones.\n\t\tnew ProjectIamMember(this, \"autoscalerRoleBindingRun\", {\n\t\t\tmember: autoscalerPolicyMember.toString(),\n\t\t\tproject,\n\t\t\trole: \"roles/run.developer\",\n\t\t});\n\n\t\tnew ProjectIamMember(this, \"autoscalerRoleBindingStorage\", {\n\t\t\tmember: autoscalerPolicyMember.toString(),\n\t\t\tproject,\n\t\t\trole: \"roles/storage.admin\",\n\t\t});\n\n\t\tnew ProjectIamMember(this, \"autoscalerRoleBindingRunServiceAgent\", {\n\t\t\tmember: autoscalerPolicyMember.toString(),\n\t\t\tproject,\n\t\t\trole: \"roles/run.serviceAgent\",\n\t\t});\n\n\t\tnew CloudRunService(this, \"autoscalerService\", {\n\t\t\tlocation,\n\t\t\tname: \"gha-autoscaler\",\n\t\t\tmetadata: {\n\t\t\t\tannotations: {\n\t\t\t\t\t\"run.googleapis.com/ingress\": \"internal\",\n\t\t\t\t},\n\t\t\t},\n\t\t\ttemplate: {\n\t\t\t\tmetadata: {\n\t\t\t\t\tannotations: {\n\t\t\t\t\t\t\"autoscaling.knative.dev/maxScale\": \"1\",\n\t\t\t\t\t\t\"autoscaling.knative.dev/minScale\": \"1\",\n\t\t\t\t\t\t\"run.googleapis.com/cpu-throttling\": \"false\",\n\t\t\t\t\t\t\"run.googleapis.com/startup-cpu-boost\": \"false\",\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t\tspec: {\n\t\t\t\t\tcontainerConcurrency: 1,\n\t\t\t\t\tcontainers: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\timage: `${registry.location}-docker.pkg.dev/${project}/${registry.repositoryId}/hi-fi/gha-runners-on-managed-env:test`,\n\t\t\t\t\t\t\tenv: [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"PAT\",\n\t\t\t\t\t\t\t\t\tvalue: pat.value,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"GITHUB_CONFIG_URL\",\n\t\t\t\t\t\t\t\t\tvalue: githubConfigUrl.value,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"JOB_NAME\",\n\t\t\t\t\t\t\t\t\tvalue: runnerJob.name,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"SCALE_SET_NAME\",\n\t\t\t\t\t\t\t\t\tvalue: \"cr-runner-set\",\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"CLOUDSDK_RUN_REGION\",\n\t\t\t\t\t\t\t\t\tvalue: location,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tname: \"GOOGLE_CLOUD_PROJECT\",\n\t\t\t\t\t\t\t\t\tvalue: project,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\tresources: {\n\t\t\t\t\t\t\t\t// Service would work for much lower, but these are minimum values for \"always on\" mode\n\t\t\t\t\t\t\t\tlimits: {\n\t\t\t\t\t\t\t\t\tcpu: \"1000m\",\n\t\t\t\t\t\t\t\t\tmemory: \"512Mi\",\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t\tserviceAccountName: autoscalerSa.email,\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\t}\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { TerraformVariable } from 'cdktf';
2
- import { Construct } from 'constructs';
1
+ import { TerraformVariable } from "cdktf";
2
+ import type { Construct } from "constructs";
3
3
  export interface Variables {
4
4
  pat: TerraformVariable;
5
5
  githubConfigUrl: TerraformVariable;
@@ -3,26 +3,26 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.commonVariables = commonVariables;
4
4
  const cdktf_1 = require("cdktf");
5
5
  function commonVariables(scope) {
6
- const pat = new cdktf_1.TerraformVariable(scope, 'personal_access_token', {
7
- description: 'Github PAT with Actions:Read and Admin:Read+Write scopes',
6
+ const pat = new cdktf_1.TerraformVariable(scope, "personal_access_token", {
7
+ description: "Github PAT with Actions:Read and Admin:Read+Write scopes",
8
8
  nullable: false,
9
9
  sensitive: true,
10
10
  });
11
- pat.overrideLogicalId('personal_access_token');
12
- const githubConfigUrl = new cdktf_1.TerraformVariable(scope, 'github_config_url', {
13
- description: 'Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo>',
11
+ pat.overrideLogicalId("personal_access_token");
12
+ const githubConfigUrl = new cdktf_1.TerraformVariable(scope, "github_config_url", {
13
+ description: "Github URL where runners should register to. Format https://<GitHub host>/<your_enterprise/org/repo>",
14
14
  nullable: false,
15
15
  });
16
- githubConfigUrl.overrideLogicalId('github_config_url');
17
- const autoscalerImage = new cdktf_1.TerraformVariable(scope, 'autoscaler_image', {
18
- description: 'Autoscaler image triggering runners',
19
- default: 'ghcr.io/hi-fi/gha-runners-on-managed-env:ebe559da0d51e04eff903f0a04de09da93f4614f',
16
+ githubConfigUrl.overrideLogicalId("github_config_url");
17
+ const autoscalerImage = new cdktf_1.TerraformVariable(scope, "autoscaler_image", {
18
+ description: "Autoscaler image triggering runners",
19
+ default: "ghcr.io/hi-fi/gha-runners-on-managed-env:ebe559da0d51e04eff903f0a04de09da93f4614f",
20
20
  });
21
- autoscalerImage.overrideLogicalId('autoscaler_image');
21
+ autoscalerImage.overrideLogicalId("autoscaler_image");
22
22
  return {
23
23
  pat,
24
24
  githubConfigUrl,
25
25
  autoscalerImage,
26
26
  };
27
27
  }
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFibGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi92YXJpYWJsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTQSwwQ0E4QkM7QUF2Q0QsaUNBQXlDO0FBU3pDLFNBQWdCLGVBQWUsQ0FBQyxLQUFnQjtJQUM5QyxNQUFNLEdBQUcsR0FBRyxJQUFJLHlCQUFpQixDQUFDLEtBQUssRUFBRSx1QkFBdUIsRUFBRTtRQUNoRSxXQUFXLEVBQUUsMERBQTBEO1FBQ3ZFLFFBQVEsRUFBRSxLQUFLO1FBQ2YsU0FBUyxFQUFFLElBQUk7S0FDaEIsQ0FBQyxDQUFBO0lBRUYsR0FBRyxDQUFDLGlCQUFpQixDQUFDLHVCQUF1QixDQUFDLENBQUE7SUFFOUMsTUFBTSxlQUFlLEdBQUcsSUFBSSx5QkFBaUIsQ0FBQyxLQUFLLEVBQUUsbUJBQW1CLEVBQUU7UUFDeEUsV0FBVyxFQUNULHNHQUFzRztRQUN4RyxRQUFRLEVBQUUsS0FBSztLQUNoQixDQUFDLENBQUE7SUFFRixlQUFlLENBQUMsaUJBQWlCLENBQUMsbUJBQW1CLENBQUMsQ0FBQTtJQUV0RCxNQUFNLGVBQWUsR0FBRyxJQUFJLHlCQUFpQixDQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRTtRQUN2RSxXQUFXLEVBQUUscUNBQXFDO1FBQ2xELE9BQU8sRUFDTCxtRkFBbUY7S0FDdEYsQ0FBQyxDQUFBO0lBRUYsZUFBZSxDQUFDLGlCQUFpQixDQUFDLGtCQUFrQixDQUFDLENBQUE7SUFFckQsT0FBTztRQUNMLEdBQUc7UUFDSCxlQUFlO1FBQ2YsZUFBZTtLQUNoQixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlcnJhZm9ybVZhcmlhYmxlIH0gZnJvbSAnY2RrdGYnXG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJ1xuXG5leHBvcnQgaW50ZXJmYWNlIFZhcmlhYmxlcyB7XG4gIHBhdDogVGVycmFmb3JtVmFyaWFibGVcbiAgZ2l0aHViQ29uZmlnVXJsOiBUZXJyYWZvcm1WYXJpYWJsZVxuICBhdXRvc2NhbGVySW1hZ2U6IFRlcnJhZm9ybVZhcmlhYmxlXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjb21tb25WYXJpYWJsZXMoc2NvcGU6IENvbnN0cnVjdCk6IFZhcmlhYmxlcyB7XG4gIGNvbnN0IHBhdCA9IG5ldyBUZXJyYWZvcm1WYXJpYWJsZShzY29wZSwgJ3BlcnNvbmFsX2FjY2Vzc190b2tlbicsIHtcbiAgICBkZXNjcmlwdGlvbjogJ0dpdGh1YiBQQVQgd2l0aCBBY3Rpb25zOlJlYWQgYW5kIEFkbWluOlJlYWQrV3JpdGUgc2NvcGVzJyxcbiAgICBudWxsYWJsZTogZmFsc2UsXG4gICAgc2Vuc2l0aXZlOiB0cnVlLFxuICB9KVxuXG4gIHBhdC5vdmVycmlkZUxvZ2ljYWxJZCgncGVyc29uYWxfYWNjZXNzX3Rva2VuJylcblxuICBjb25zdCBnaXRodWJDb25maWdVcmwgPSBuZXcgVGVycmFmb3JtVmFyaWFibGUoc2NvcGUsICdnaXRodWJfY29uZmlnX3VybCcsIHtcbiAgICBkZXNjcmlwdGlvbjpcbiAgICAgICdHaXRodWIgVVJMIHdoZXJlIHJ1bm5lcnMgc2hvdWxkIHJlZ2lzdGVyIHRvLiBGb3JtYXQgaHR0cHM6Ly88R2l0SHViIGhvc3Q+Lzx5b3VyX2VudGVycHJpc2Uvb3JnL3JlcG8+JyxcbiAgICBudWxsYWJsZTogZmFsc2UsXG4gIH0pXG5cbiAgZ2l0aHViQ29uZmlnVXJsLm92ZXJyaWRlTG9naWNhbElkKCdnaXRodWJfY29uZmlnX3VybCcpXG5cbiAgY29uc3QgYXV0b3NjYWxlckltYWdlID0gbmV3IFRlcnJhZm9ybVZhcmlhYmxlKHNjb3BlLCAnYXV0b3NjYWxlcl9pbWFnZScsIHtcbiAgICBkZXNjcmlwdGlvbjogJ0F1dG9zY2FsZXIgaW1hZ2UgdHJpZ2dlcmluZyBydW5uZXJzJyxcbiAgICBkZWZhdWx0OlxuICAgICAgJ2doY3IuaW8vaGktZmkvZ2hhLXJ1bm5lcnMtb24tbWFuYWdlZC1lbnY6ZWJlNTU5ZGEwZDUxZTA0ZWZmOTAzZjBhMDRkZTA5ZGE5M2Y0NjE0ZicsXG4gIH0pXG5cbiAgYXV0b3NjYWxlckltYWdlLm92ZXJyaWRlTG9naWNhbElkKCdhdXRvc2NhbGVyX2ltYWdlJylcblxuICByZXR1cm4ge1xuICAgIHBhdCxcbiAgICBnaXRodWJDb25maWdVcmwsXG4gICAgYXV0b3NjYWxlckltYWdlLFxuICB9XG59XG4iXX0=
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFibGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi92YXJpYWJsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTQSwwQ0E4QkM7QUF2Q0QsaUNBQTBDO0FBUzFDLFNBQWdCLGVBQWUsQ0FBQyxLQUFnQjtJQUMvQyxNQUFNLEdBQUcsR0FBRyxJQUFJLHlCQUFpQixDQUFDLEtBQUssRUFBRSx1QkFBdUIsRUFBRTtRQUNqRSxXQUFXLEVBQUUsMERBQTBEO1FBQ3ZFLFFBQVEsRUFBRSxLQUFLO1FBQ2YsU0FBUyxFQUFFLElBQUk7S0FDZixDQUFDLENBQUM7SUFFSCxHQUFHLENBQUMsaUJBQWlCLENBQUMsdUJBQXVCLENBQUMsQ0FBQztJQUUvQyxNQUFNLGVBQWUsR0FBRyxJQUFJLHlCQUFpQixDQUFDLEtBQUssRUFBRSxtQkFBbUIsRUFBRTtRQUN6RSxXQUFXLEVBQ1Ysc0dBQXNHO1FBQ3ZHLFFBQVEsRUFBRSxLQUFLO0tBQ2YsQ0FBQyxDQUFDO0lBRUgsZUFBZSxDQUFDLGlCQUFpQixDQUFDLG1CQUFtQixDQUFDLENBQUM7SUFFdkQsTUFBTSxlQUFlLEdBQUcsSUFBSSx5QkFBaUIsQ0FBQyxLQUFLLEVBQUUsa0JBQWtCLEVBQUU7UUFDeEUsV0FBVyxFQUFFLHFDQUFxQztRQUNsRCxPQUFPLEVBQ04sbUZBQW1GO0tBQ3BGLENBQUMsQ0FBQztJQUVILGVBQWUsQ0FBQyxpQkFBaUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBRXRELE9BQU87UUFDTixHQUFHO1FBQ0gsZUFBZTtRQUNmLGVBQWU7S0FDZixDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlcnJhZm9ybVZhcmlhYmxlIH0gZnJvbSBcImNka3RmXCI7XG5pbXBvcnQgdHlwZSB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmFyaWFibGVzIHtcblx0cGF0OiBUZXJyYWZvcm1WYXJpYWJsZTtcblx0Z2l0aHViQ29uZmlnVXJsOiBUZXJyYWZvcm1WYXJpYWJsZTtcblx0YXV0b3NjYWxlckltYWdlOiBUZXJyYWZvcm1WYXJpYWJsZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNvbW1vblZhcmlhYmxlcyhzY29wZTogQ29uc3RydWN0KTogVmFyaWFibGVzIHtcblx0Y29uc3QgcGF0ID0gbmV3IFRlcnJhZm9ybVZhcmlhYmxlKHNjb3BlLCBcInBlcnNvbmFsX2FjY2Vzc190b2tlblwiLCB7XG5cdFx0ZGVzY3JpcHRpb246IFwiR2l0aHViIFBBVCB3aXRoIEFjdGlvbnM6UmVhZCBhbmQgQWRtaW46UmVhZCtXcml0ZSBzY29wZXNcIixcblx0XHRudWxsYWJsZTogZmFsc2UsXG5cdFx0c2Vuc2l0aXZlOiB0cnVlLFxuXHR9KTtcblxuXHRwYXQub3ZlcnJpZGVMb2dpY2FsSWQoXCJwZXJzb25hbF9hY2Nlc3NfdG9rZW5cIik7XG5cblx0Y29uc3QgZ2l0aHViQ29uZmlnVXJsID0gbmV3IFRlcnJhZm9ybVZhcmlhYmxlKHNjb3BlLCBcImdpdGh1Yl9jb25maWdfdXJsXCIsIHtcblx0XHRkZXNjcmlwdGlvbjpcblx0XHRcdFwiR2l0aHViIFVSTCB3aGVyZSBydW5uZXJzIHNob3VsZCByZWdpc3RlciB0by4gRm9ybWF0IGh0dHBzOi8vPEdpdEh1YiBob3N0Pi88eW91cl9lbnRlcnByaXNlL29yZy9yZXBvPlwiLFxuXHRcdG51bGxhYmxlOiBmYWxzZSxcblx0fSk7XG5cblx0Z2l0aHViQ29uZmlnVXJsLm92ZXJyaWRlTG9naWNhbElkKFwiZ2l0aHViX2NvbmZpZ191cmxcIik7XG5cblx0Y29uc3QgYXV0b3NjYWxlckltYWdlID0gbmV3IFRlcnJhZm9ybVZhcmlhYmxlKHNjb3BlLCBcImF1dG9zY2FsZXJfaW1hZ2VcIiwge1xuXHRcdGRlc2NyaXB0aW9uOiBcIkF1dG9zY2FsZXIgaW1hZ2UgdHJpZ2dlcmluZyBydW5uZXJzXCIsXG5cdFx0ZGVmYXVsdDpcblx0XHRcdFwiZ2hjci5pby9oaS1maS9naGEtcnVubmVycy1vbi1tYW5hZ2VkLWVudjplYmU1NTlkYTBkNTFlMDRlZmY5MDNmMGEwNGRlMDlkYTkzZjQ2MTRmXCIsXG5cdH0pO1xuXG5cdGF1dG9zY2FsZXJJbWFnZS5vdmVycmlkZUxvZ2ljYWxJZChcImF1dG9zY2FsZXJfaW1hZ2VcIik7XG5cblx0cmV0dXJuIHtcblx0XHRwYXQsXG5cdFx0Z2l0aHViQ29uZmlnVXJsLFxuXHRcdGF1dG9zY2FsZXJJbWFnZSxcblx0fTtcbn1cbiJdfQ==
package/lib/tfModules.js CHANGED
@@ -8,41 +8,41 @@ const gcp_1 = require("./lib/gcp");
8
8
  class AzureContainerAppsArc extends tf_module_stack_1.TFModuleStack {
9
9
  constructor(scope, id) {
10
10
  super(scope, id);
11
- new azure_1.Azure(this, 'aca');
11
+ new azure_1.Azure(this, "aca");
12
12
  }
13
13
  }
14
14
  class ElasticContainerServiceArc extends tf_module_stack_1.TFModuleStack {
15
15
  constructor(scope, id) {
16
16
  super(scope, id);
17
- const clusterName = new tf_module_stack_1.TFModuleVariable(this, 'ecs_cluster_name', {
18
- description: 'Name of the ECS cluster to create',
17
+ const clusterName = new tf_module_stack_1.TFModuleVariable(this, "ecs_cluster_name", {
18
+ description: "Name of the ECS cluster to create",
19
19
  }).stringValue;
20
20
  const filterType = cdktf_1.VariableType.list(cdktf_1.VariableType.object({
21
21
  name: cdktf_1.VariableType.STRING,
22
22
  values: cdktf_1.VariableType.list(cdktf_1.VariableType.STRING),
23
23
  }));
24
- const securityGroupFilters = new tf_module_stack_1.TFModuleVariable(this, 'ecs_security_group_filters', {
24
+ const securityGroupFilters = new tf_module_stack_1.TFModuleVariable(this, "ecs_security_group_filters", {
25
25
  type: filterType,
26
- description: 'Filters for security groups',
26
+ description: "Filters for security groups",
27
27
  default: [],
28
28
  }).value;
29
- const subnetFilters = new tf_module_stack_1.TFModuleVariable(this, 'ecs_subnet_filters', {
29
+ const subnetFilters = new tf_module_stack_1.TFModuleVariable(this, "ecs_subnet_filters", {
30
30
  type: filterType,
31
- description: 'Filters for security groups',
31
+ description: "Filters for security groups",
32
32
  default: [],
33
33
  }).value;
34
34
  const securityGroupFiltersIterator = cdktf_1.DynamicListTerraformIterator.fromList(securityGroupFilters);
35
35
  const subnetFiltersIterator = cdktf_1.DynamicListTerraformIterator.fromList(subnetFilters);
36
- new aws_1.Aws(this, 'aws', {
36
+ new aws_1.Aws(this, "aws", {
37
37
  clusterName,
38
38
  containerSupport: false,
39
39
  securityGroupFilters: securityGroupFiltersIterator.dynamic({
40
- name: securityGroupFiltersIterator.getString('name'),
41
- values: securityGroupFiltersIterator.getList('values'),
40
+ name: securityGroupFiltersIterator.getString("name"),
41
+ values: securityGroupFiltersIterator.getList("values"),
42
42
  }),
43
43
  subnetFilters: subnetFiltersIterator.dynamic({
44
- name: subnetFiltersIterator.getString('name'),
45
- values: subnetFiltersIterator.getList('values'),
44
+ name: subnetFiltersIterator.getString("name"),
45
+ values: subnetFiltersIterator.getList("values"),
46
46
  }),
47
47
  });
48
48
  }
@@ -50,15 +50,15 @@ class ElasticContainerServiceArc extends tf_module_stack_1.TFModuleStack {
50
50
  class CloudRunArc extends tf_module_stack_1.TFModuleStack {
51
51
  constructor(scope, id) {
52
52
  super(scope, id);
53
- new gcp_1.Gcp(this, 'cr');
53
+ new gcp_1.Gcp(this, "cr");
54
54
  }
55
55
  }
56
56
  const app = new cdktf_1.App();
57
57
  // This is the name the module can be found under.
58
58
  // We expect a "my-awesome-module.md" file in this directory.
59
59
  // The README.md file will be generated from this file.
60
- new AzureContainerAppsArc(app, 'azure-container-apps');
61
- new ElasticContainerServiceArc(app, 'elastic-container-service');
62
- new CloudRunArc(app, 'google-cloud-run');
60
+ new AzureContainerAppsArc(app, "azure-container-apps");
61
+ new ElasticContainerServiceArc(app, "elastic-container-service");
62
+ new CloudRunArc(app, "google-cloud-run");
63
63
  app.synth();
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGZNb2R1bGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3RmTW9kdWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDREQUF3RTtBQUN4RSxpQ0FBdUU7QUFFdkUsbUNBQStCO0FBQy9CLHVDQUFtQztBQUNuQyxtQ0FBK0I7QUFFL0IsTUFBTSxxQkFBc0IsU0FBUSwrQkFBYTtJQUMvQyxZQUFZLEtBQWdCLEVBQUUsRUFBVTtRQUN0QyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFBO1FBRWhCLElBQUksYUFBSyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQTtJQUN4QixDQUFDO0NBQ0Y7QUFFRCxNQUFNLDBCQUEyQixTQUFRLCtCQUFhO0lBQ3BELFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3RDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUE7UUFFaEIsTUFBTSxXQUFXLEdBQUcsSUFBSSxrQ0FBZ0IsQ0FBQyxJQUFJLEVBQUUsa0JBQWtCLEVBQUU7WUFDakUsV0FBVyxFQUFFLG1DQUFtQztTQUNqRCxDQUFDLENBQUMsV0FBVyxDQUFBO1FBRWQsTUFBTSxVQUFVLEdBQUcsb0JBQVksQ0FBQyxJQUFJLENBQ2xDLG9CQUFZLENBQUMsTUFBTSxDQUFDO1lBQ2xCLElBQUksRUFBRSxvQkFBWSxDQUFDLE1BQU07WUFDekIsTUFBTSxFQUFFLG9CQUFZLENBQUMsSUFBSSxDQUFDLG9CQUFZLENBQUMsTUFBTSxDQUFDO1NBQy9DLENBQUMsQ0FDSCxDQUFBO1FBRUQsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLGtDQUFnQixDQUMvQyxJQUFJLEVBQ0osNEJBQTRCLEVBQzVCO1lBQ0UsSUFBSSxFQUFFLFVBQVU7WUFDaEIsV0FBVyxFQUFFLDZCQUE2QjtZQUMxQyxPQUFPLEVBQUUsRUFBRTtTQUNaLENBQ0YsQ0FBQyxLQUFLLENBQUE7UUFFUCxNQUFNLGFBQWEsR0FBRyxJQUFJLGtDQUFnQixDQUFDLElBQUksRUFBRSxvQkFBb0IsRUFBRTtZQUNyRSxJQUFJLEVBQUUsVUFBVTtZQUNoQixXQUFXLEVBQUUsNkJBQTZCO1lBQzFDLE9BQU8sRUFBRSxFQUFFO1NBQ1osQ0FBQyxDQUFDLEtBQUssQ0FBQTtRQUVSLE1BQU0sNEJBQTRCLEdBQ2hDLG9DQUE0QixDQUFDLFFBQVEsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFBO1FBQzdELE1BQU0scUJBQXFCLEdBQ3pCLG9DQUE0QixDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQTtRQUV0RCxJQUFJLFNBQUcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFO1lBQ25CLFdBQVc7WUFDWCxnQkFBZ0IsRUFBRSxLQUFLO1lBQ3ZCLG9CQUFvQixFQUFFLDRCQUE0QixDQUFDLE9BQU8sQ0FBQztnQkFDekQsSUFBSSxFQUFFLDRCQUE0QixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUM7Z0JBQ3BELE1BQU0sRUFBRSw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO2FBQ3ZELENBQUM7WUFDRixhQUFhLEVBQUUscUJBQXFCLENBQUMsT0FBTyxDQUFDO2dCQUMzQyxJQUFJLEVBQUUscUJBQXFCLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztnQkFDN0MsTUFBTSxFQUFFLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUM7YUFDaEQsQ0FBQztTQUNILENBQUMsQ0FBQTtJQUNKLENBQUM7Q0FDRjtBQUVELE1BQU0sV0FBWSxTQUFRLCtCQUFhO0lBQ3JDLFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3RDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUE7UUFFaEIsSUFBSSxTQUFHLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFBO0lBQ3JCLENBQUM7Q0FDRjtBQUVELE1BQU0sR0FBRyxHQUFHLElBQUksV0FBRyxFQUFFLENBQUE7QUFDckIsa0RBQWtEO0FBQ2xELDZEQUE2RDtBQUM3RCx1REFBdUQ7QUFDdkQsSUFBSSxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsc0JBQXNCLENBQUMsQ0FBQTtBQUN0RCxJQUFJLDBCQUEwQixDQUFDLEdBQUcsRUFBRSwyQkFBMkIsQ0FBQyxDQUFBO0FBQ2hFLElBQUksV0FBVyxDQUFDLEdBQUcsRUFBRSxrQkFBa0IsQ0FBQyxDQUFBO0FBRXhDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRGTW9kdWxlU3RhY2ssIFRGTW9kdWxlVmFyaWFibGUgfSBmcm9tICdAY2RrdGYvdGYtbW9kdWxlLXN0YWNrJ1xuaW1wb3J0IHsgQXBwLCBEeW5hbWljTGlzdFRlcnJhZm9ybUl0ZXJhdG9yLCBWYXJpYWJsZVR5cGUgfSBmcm9tICdjZGt0ZidcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnXG5pbXBvcnQgeyBBd3MgfSBmcm9tICcuL2xpYi9hd3MnXG5pbXBvcnQgeyBBenVyZSB9IGZyb20gJy4vbGliL2F6dXJlJ1xuaW1wb3J0IHsgR2NwIH0gZnJvbSAnLi9saWIvZ2NwJ1xuXG5jbGFzcyBBenVyZUNvbnRhaW5lckFwcHNBcmMgZXh0ZW5kcyBURk1vZHVsZVN0YWNrIHtcbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZClcblxuICAgIG5ldyBBenVyZSh0aGlzLCAnYWNhJylcbiAgfVxufVxuXG5jbGFzcyBFbGFzdGljQ29udGFpbmVyU2VydmljZUFyYyBleHRlbmRzIFRGTW9kdWxlU3RhY2sge1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKVxuXG4gICAgY29uc3QgY2x1c3Rlck5hbWUgPSBuZXcgVEZNb2R1bGVWYXJpYWJsZSh0aGlzLCAnZWNzX2NsdXN0ZXJfbmFtZScsIHtcbiAgICAgIGRlc2NyaXB0aW9uOiAnTmFtZSBvZiB0aGUgRUNTIGNsdXN0ZXIgdG8gY3JlYXRlJyxcbiAgICB9KS5zdHJpbmdWYWx1ZVxuXG4gICAgY29uc3QgZmlsdGVyVHlwZSA9IFZhcmlhYmxlVHlwZS5saXN0KFxuICAgICAgVmFyaWFibGVUeXBlLm9iamVjdCh7XG4gICAgICAgIG5hbWU6IFZhcmlhYmxlVHlwZS5TVFJJTkcsXG4gICAgICAgIHZhbHVlczogVmFyaWFibGVUeXBlLmxpc3QoVmFyaWFibGVUeXBlLlNUUklORyksXG4gICAgICB9KSxcbiAgICApXG5cbiAgICBjb25zdCBzZWN1cml0eUdyb3VwRmlsdGVycyA9IG5ldyBURk1vZHVsZVZhcmlhYmxlKFxuICAgICAgdGhpcyxcbiAgICAgICdlY3Nfc2VjdXJpdHlfZ3JvdXBfZmlsdGVycycsXG4gICAgICB7XG4gICAgICAgIHR5cGU6IGZpbHRlclR5cGUsXG4gICAgICAgIGRlc2NyaXB0aW9uOiAnRmlsdGVycyBmb3Igc2VjdXJpdHkgZ3JvdXBzJyxcbiAgICAgICAgZGVmYXVsdDogW10sXG4gICAgICB9LFxuICAgICkudmFsdWVcblxuICAgIGNvbnN0IHN1Ym5ldEZpbHRlcnMgPSBuZXcgVEZNb2R1bGVWYXJpYWJsZSh0aGlzLCAnZWNzX3N1Ym5ldF9maWx0ZXJzJywge1xuICAgICAgdHlwZTogZmlsdGVyVHlwZSxcbiAgICAgIGRlc2NyaXB0aW9uOiAnRmlsdGVycyBmb3Igc2VjdXJpdHkgZ3JvdXBzJyxcbiAgICAgIGRlZmF1bHQ6IFtdLFxuICAgIH0pLnZhbHVlXG5cbiAgICBjb25zdCBzZWN1cml0eUdyb3VwRmlsdGVyc0l0ZXJhdG9yID1cbiAgICAgIER5bmFtaWNMaXN0VGVycmFmb3JtSXRlcmF0b3IuZnJvbUxpc3Qoc2VjdXJpdHlHcm91cEZpbHRlcnMpXG4gICAgY29uc3Qgc3VibmV0RmlsdGVyc0l0ZXJhdG9yID1cbiAgICAgIER5bmFtaWNMaXN0VGVycmFmb3JtSXRlcmF0b3IuZnJvbUxpc3Qoc3VibmV0RmlsdGVycylcblxuICAgIG5ldyBBd3ModGhpcywgJ2F3cycsIHtcbiAgICAgIGNsdXN0ZXJOYW1lLFxuICAgICAgY29udGFpbmVyU3VwcG9ydDogZmFsc2UsXG4gICAgICBzZWN1cml0eUdyb3VwRmlsdGVyczogc2VjdXJpdHlHcm91cEZpbHRlcnNJdGVyYXRvci5keW5hbWljKHtcbiAgICAgICAgbmFtZTogc2VjdXJpdHlHcm91cEZpbHRlcnNJdGVyYXRvci5nZXRTdHJpbmcoJ25hbWUnKSxcbiAgICAgICAgdmFsdWVzOiBzZWN1cml0eUdyb3VwRmlsdGVyc0l0ZXJhdG9yLmdldExpc3QoJ3ZhbHVlcycpLFxuICAgICAgfSksXG4gICAgICBzdWJuZXRGaWx0ZXJzOiBzdWJuZXRGaWx0ZXJzSXRlcmF0b3IuZHluYW1pYyh7XG4gICAgICAgIG5hbWU6IHN1Ym5ldEZpbHRlcnNJdGVyYXRvci5nZXRTdHJpbmcoJ25hbWUnKSxcbiAgICAgICAgdmFsdWVzOiBzdWJuZXRGaWx0ZXJzSXRlcmF0b3IuZ2V0TGlzdCgndmFsdWVzJyksXG4gICAgICB9KSxcbiAgICB9KVxuICB9XG59XG5cbmNsYXNzIENsb3VkUnVuQXJjIGV4dGVuZHMgVEZNb2R1bGVTdGFjayB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpXG5cbiAgICBuZXcgR2NwKHRoaXMsICdjcicpXG4gIH1cbn1cblxuY29uc3QgYXBwID0gbmV3IEFwcCgpXG4vLyBUaGlzIGlzIHRoZSBuYW1lIHRoZSBtb2R1bGUgY2FuIGJlIGZvdW5kIHVuZGVyLlxuLy8gV2UgZXhwZWN0IGEgXCJteS1hd2Vzb21lLW1vZHVsZS5tZFwiIGZpbGUgaW4gdGhpcyBkaXJlY3RvcnkuXG4vLyBUaGUgUkVBRE1FLm1kIGZpbGUgd2lsbCBiZSBnZW5lcmF0ZWQgZnJvbSB0aGlzIGZpbGUuXG5uZXcgQXp1cmVDb250YWluZXJBcHBzQXJjKGFwcCwgJ2F6dXJlLWNvbnRhaW5lci1hcHBzJylcbm5ldyBFbGFzdGljQ29udGFpbmVyU2VydmljZUFyYyhhcHAsICdlbGFzdGljLWNvbnRhaW5lci1zZXJ2aWNlJylcbm5ldyBDbG91ZFJ1bkFyYyhhcHAsICdnb29nbGUtY2xvdWQtcnVuJylcblxuYXBwLnN5bnRoKClcbiJdfQ==
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGZNb2R1bGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3RmTW9kdWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDREQUF5RTtBQUN6RSxpQ0FBd0U7QUFFeEUsbUNBQWdDO0FBQ2hDLHVDQUFvQztBQUNwQyxtQ0FBZ0M7QUFFaEMsTUFBTSxxQkFBc0IsU0FBUSwrQkFBYTtJQUNoRCxZQUFZLEtBQWdCLEVBQUUsRUFBVTtRQUN2QyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLElBQUksYUFBSyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN4QixDQUFDO0NBQ0Q7QUFFRCxNQUFNLDBCQUEyQixTQUFRLCtCQUFhO0lBQ3JELFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3ZDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsTUFBTSxXQUFXLEdBQUcsSUFBSSxrQ0FBZ0IsQ0FBQyxJQUFJLEVBQUUsa0JBQWtCLEVBQUU7WUFDbEUsV0FBVyxFQUFFLG1DQUFtQztTQUNoRCxDQUFDLENBQUMsV0FBVyxDQUFDO1FBRWYsTUFBTSxVQUFVLEdBQUcsb0JBQVksQ0FBQyxJQUFJLENBQ25DLG9CQUFZLENBQUMsTUFBTSxDQUFDO1lBQ25CLElBQUksRUFBRSxvQkFBWSxDQUFDLE1BQU07WUFDekIsTUFBTSxFQUFFLG9CQUFZLENBQUMsSUFBSSxDQUFDLG9CQUFZLENBQUMsTUFBTSxDQUFDO1NBQzlDLENBQUMsQ0FDRixDQUFDO1FBRUYsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLGtDQUFnQixDQUNoRCxJQUFJLEVBQ0osNEJBQTRCLEVBQzVCO1lBQ0MsSUFBSSxFQUFFLFVBQVU7WUFDaEIsV0FBVyxFQUFFLDZCQUE2QjtZQUMxQyxPQUFPLEVBQUUsRUFBRTtTQUNYLENBQ0QsQ0FBQyxLQUFLLENBQUM7UUFFUixNQUFNLGFBQWEsR0FBRyxJQUFJLGtDQUFnQixDQUFDLElBQUksRUFBRSxvQkFBb0IsRUFBRTtZQUN0RSxJQUFJLEVBQUUsVUFBVTtZQUNoQixXQUFXLEVBQUUsNkJBQTZCO1lBQzFDLE9BQU8sRUFBRSxFQUFFO1NBQ1gsQ0FBQyxDQUFDLEtBQUssQ0FBQztRQUVULE1BQU0sNEJBQTRCLEdBQ2pDLG9DQUE0QixDQUFDLFFBQVEsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBQzdELE1BQU0scUJBQXFCLEdBQzFCLG9DQUE0QixDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUV0RCxJQUFJLFNBQUcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFO1lBQ3BCLFdBQVc7WUFDWCxnQkFBZ0IsRUFBRSxLQUFLO1lBQ3ZCLG9CQUFvQixFQUFFLDRCQUE0QixDQUFDLE9BQU8sQ0FBQztnQkFDMUQsSUFBSSxFQUFFLDRCQUE0QixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUM7Z0JBQ3BELE1BQU0sRUFBRSw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO2FBQ3RELENBQUM7WUFDRixhQUFhLEVBQUUscUJBQXFCLENBQUMsT0FBTyxDQUFDO2dCQUM1QyxJQUFJLEVBQUUscUJBQXFCLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztnQkFDN0MsTUFBTSxFQUFFLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUM7YUFDL0MsQ0FBQztTQUNGLENBQUMsQ0FBQztJQUNKLENBQUM7Q0FDRDtBQUVELE1BQU0sV0FBWSxTQUFRLCtCQUFhO0lBQ3RDLFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3ZDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxTQUFHLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ3JCLENBQUM7Q0FDRDtBQUVELE1BQU0sR0FBRyxHQUFHLElBQUksV0FBRyxFQUFFLENBQUM7QUFDdEIsa0RBQWtEO0FBQ2xELDZEQUE2RDtBQUM3RCx1REFBdUQ7QUFDdkQsSUFBSSxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsc0JBQXNCLENBQUMsQ0FBQztBQUN2RCxJQUFJLDBCQUEwQixDQUFDLEdBQUcsRUFBRSwyQkFBMkIsQ0FBQyxDQUFDO0FBQ2pFLElBQUksV0FBVyxDQUFDLEdBQUcsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO0FBRXpDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRGTW9kdWxlU3RhY2ssIFRGTW9kdWxlVmFyaWFibGUgfSBmcm9tIFwiQGNka3RmL3RmLW1vZHVsZS1zdGFja1wiO1xuaW1wb3J0IHsgQXBwLCBEeW5hbWljTGlzdFRlcnJhZm9ybUl0ZXJhdG9yLCBWYXJpYWJsZVR5cGUgfSBmcm9tIFwiY2RrdGZcIjtcbmltcG9ydCB0eXBlIHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IEF3cyB9IGZyb20gXCIuL2xpYi9hd3NcIjtcbmltcG9ydCB7IEF6dXJlIH0gZnJvbSBcIi4vbGliL2F6dXJlXCI7XG5pbXBvcnQgeyBHY3AgfSBmcm9tIFwiLi9saWIvZ2NwXCI7XG5cbmNsYXNzIEF6dXJlQ29udGFpbmVyQXBwc0FyYyBleHRlbmRzIFRGTW9kdWxlU3RhY2sge1xuXHRjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG5cdFx0c3VwZXIoc2NvcGUsIGlkKTtcblxuXHRcdG5ldyBBenVyZSh0aGlzLCBcImFjYVwiKTtcblx0fVxufVxuXG5jbGFzcyBFbGFzdGljQ29udGFpbmVyU2VydmljZUFyYyBleHRlbmRzIFRGTW9kdWxlU3RhY2sge1xuXHRjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG5cdFx0c3VwZXIoc2NvcGUsIGlkKTtcblxuXHRcdGNvbnN0IGNsdXN0ZXJOYW1lID0gbmV3IFRGTW9kdWxlVmFyaWFibGUodGhpcywgXCJlY3NfY2x1c3Rlcl9uYW1lXCIsIHtcblx0XHRcdGRlc2NyaXB0aW9uOiBcIk5hbWUgb2YgdGhlIEVDUyBjbHVzdGVyIHRvIGNyZWF0ZVwiLFxuXHRcdH0pLnN0cmluZ1ZhbHVlO1xuXG5cdFx0Y29uc3QgZmlsdGVyVHlwZSA9IFZhcmlhYmxlVHlwZS5saXN0KFxuXHRcdFx0VmFyaWFibGVUeXBlLm9iamVjdCh7XG5cdFx0XHRcdG5hbWU6IFZhcmlhYmxlVHlwZS5TVFJJTkcsXG5cdFx0XHRcdHZhbHVlczogVmFyaWFibGVUeXBlLmxpc3QoVmFyaWFibGVUeXBlLlNUUklORyksXG5cdFx0XHR9KSxcblx0XHQpO1xuXG5cdFx0Y29uc3Qgc2VjdXJpdHlHcm91cEZpbHRlcnMgPSBuZXcgVEZNb2R1bGVWYXJpYWJsZShcblx0XHRcdHRoaXMsXG5cdFx0XHRcImVjc19zZWN1cml0eV9ncm91cF9maWx0ZXJzXCIsXG5cdFx0XHR7XG5cdFx0XHRcdHR5cGU6IGZpbHRlclR5cGUsXG5cdFx0XHRcdGRlc2NyaXB0aW9uOiBcIkZpbHRlcnMgZm9yIHNlY3VyaXR5IGdyb3Vwc1wiLFxuXHRcdFx0XHRkZWZhdWx0OiBbXSxcblx0XHRcdH0sXG5cdFx0KS52YWx1ZTtcblxuXHRcdGNvbnN0IHN1Ym5ldEZpbHRlcnMgPSBuZXcgVEZNb2R1bGVWYXJpYWJsZSh0aGlzLCBcImVjc19zdWJuZXRfZmlsdGVyc1wiLCB7XG5cdFx0XHR0eXBlOiBmaWx0ZXJUeXBlLFxuXHRcdFx0ZGVzY3JpcHRpb246IFwiRmlsdGVycyBmb3Igc2VjdXJpdHkgZ3JvdXBzXCIsXG5cdFx0XHRkZWZhdWx0OiBbXSxcblx0XHR9KS52YWx1ZTtcblxuXHRcdGNvbnN0IHNlY3VyaXR5R3JvdXBGaWx0ZXJzSXRlcmF0b3IgPVxuXHRcdFx0RHluYW1pY0xpc3RUZXJyYWZvcm1JdGVyYXRvci5mcm9tTGlzdChzZWN1cml0eUdyb3VwRmlsdGVycyk7XG5cdFx0Y29uc3Qgc3VibmV0RmlsdGVyc0l0ZXJhdG9yID1cblx0XHRcdER5bmFtaWNMaXN0VGVycmFmb3JtSXRlcmF0b3IuZnJvbUxpc3Qoc3VibmV0RmlsdGVycyk7XG5cblx0XHRuZXcgQXdzKHRoaXMsIFwiYXdzXCIsIHtcblx0XHRcdGNsdXN0ZXJOYW1lLFxuXHRcdFx0Y29udGFpbmVyU3VwcG9ydDogZmFsc2UsXG5cdFx0XHRzZWN1cml0eUdyb3VwRmlsdGVyczogc2VjdXJpdHlHcm91cEZpbHRlcnNJdGVyYXRvci5keW5hbWljKHtcblx0XHRcdFx0bmFtZTogc2VjdXJpdHlHcm91cEZpbHRlcnNJdGVyYXRvci5nZXRTdHJpbmcoXCJuYW1lXCIpLFxuXHRcdFx0XHR2YWx1ZXM6IHNlY3VyaXR5R3JvdXBGaWx0ZXJzSXRlcmF0b3IuZ2V0TGlzdChcInZhbHVlc1wiKSxcblx0XHRcdH0pLFxuXHRcdFx0c3VibmV0RmlsdGVyczogc3VibmV0RmlsdGVyc0l0ZXJhdG9yLmR5bmFtaWMoe1xuXHRcdFx0XHRuYW1lOiBzdWJuZXRGaWx0ZXJzSXRlcmF0b3IuZ2V0U3RyaW5nKFwibmFtZVwiKSxcblx0XHRcdFx0dmFsdWVzOiBzdWJuZXRGaWx0ZXJzSXRlcmF0b3IuZ2V0TGlzdChcInZhbHVlc1wiKSxcblx0XHRcdH0pLFxuXHRcdH0pO1xuXHR9XG59XG5cbmNsYXNzIENsb3VkUnVuQXJjIGV4dGVuZHMgVEZNb2R1bGVTdGFjayB7XG5cdGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcblx0XHRzdXBlcihzY29wZSwgaWQpO1xuXG5cdFx0bmV3IEdjcCh0aGlzLCBcImNyXCIpO1xuXHR9XG59XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbi8vIFRoaXMgaXMgdGhlIG5hbWUgdGhlIG1vZHVsZSBjYW4gYmUgZm91bmQgdW5kZXIuXG4vLyBXZSBleHBlY3QgYSBcIm15LWF3ZXNvbWUtbW9kdWxlLm1kXCIgZmlsZSBpbiB0aGlzIGRpcmVjdG9yeS5cbi8vIFRoZSBSRUFETUUubWQgZmlsZSB3aWxsIGJlIGdlbmVyYXRlZCBmcm9tIHRoaXMgZmlsZS5cbm5ldyBBenVyZUNvbnRhaW5lckFwcHNBcmMoYXBwLCBcImF6dXJlLWNvbnRhaW5lci1hcHBzXCIpO1xubmV3IEVsYXN0aWNDb250YWluZXJTZXJ2aWNlQXJjKGFwcCwgXCJlbGFzdGljLWNvbnRhaW5lci1zZXJ2aWNlXCIpO1xubmV3IENsb3VkUnVuQXJjKGFwcCwgXCJnb29nbGUtY2xvdWQtcnVuXCIpO1xuXG5hcHAuc3ludGgoKTtcbiJdfQ==