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

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/azure.js CHANGED
@@ -24,166 +24,166 @@ const variables_1 = require("./variables");
24
24
  class Azure extends constructs_1.Construct {
25
25
  constructor(scope, id) {
26
26
  super(scope, id);
27
- new provider_1.AzurermProvider(this, 'azurerm', {
27
+ new provider_1.AzurermProvider(this, "azurerm", {
28
28
  features: [{}],
29
29
  });
30
- new provider_3.AzapiProvider(this, 'azapi', {});
31
- new provider_2.RandomProvider(this, 'random');
32
- const sub = new data_azurerm_subscription_1.DataAzurermSubscription(this, 'sub', {});
30
+ new provider_3.AzapiProvider(this, "azapi", {});
31
+ new provider_2.RandomProvider(this, "random");
32
+ const sub = new data_azurerm_subscription_1.DataAzurermSubscription(this, "sub", {});
33
33
  const { pat, githubConfigUrl } = (0, variables_1.commonVariables)(this);
34
- const location = new cdktf_1.TerraformVariable(this, 'location', {
35
- default: 'westeurope',
36
- description: 'Location where to provision resources to',
37
- type: 'string',
34
+ const location = new cdktf_1.TerraformVariable(this, "location", {
35
+ default: "westeurope",
36
+ description: "Location where to provision resources to",
37
+ type: "string",
38
38
  sensitive: false,
39
39
  nullable: false,
40
40
  }).value;
41
- const rg = new resource_group_1.ResourceGroup(this, 'rg', {
41
+ const rg = new resource_group_1.ResourceGroup(this, "rg", {
42
42
  location,
43
- name: 'gha-runner-rg',
43
+ name: "gha-runner-rg",
44
44
  lifecycle: {
45
- ignoreChanges: ['tags'],
45
+ ignoreChanges: ["tags"],
46
46
  },
47
47
  });
48
- const random = new string_resource_1.StringResource(this, 'randomSuffix', {
48
+ const random = new string_resource_1.StringResource(this, "randomSuffix", {
49
49
  length: 6,
50
50
  special: false,
51
51
  upper: false,
52
52
  });
53
- const acr = new container_registry_1.ContainerRegistry(this, 'acr', {
53
+ const acr = new container_registry_1.ContainerRegistry(this, "acr", {
54
54
  location,
55
55
  name: `runneracr${random.result}`,
56
56
  resourceGroupName: rg.name,
57
- sku: 'Basic',
57
+ sku: "Basic",
58
58
  lifecycle: {
59
- ignoreChanges: ['tags'],
59
+ ignoreChanges: ["tags"],
60
60
  },
61
61
  });
62
62
  // use caching for images
63
- const runnerCache = new resource_1.Resource(this, 'runnerCache', {
64
- type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',
63
+ const runnerCache = new resource_1.Resource(this, "runnerCache", {
64
+ type: "Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview",
65
65
  parentId: acr.id,
66
- name: 'root-runner-cache',
66
+ name: "root-runner-cache",
67
67
  body: {
68
68
  properties: {
69
- sourceRepository: 'ghcr.io/hi-fi/root-actions-runner',
70
- targetRepository: 'root-actions-runner',
69
+ sourceRepository: "ghcr.io/hi-fi/root-actions-runner",
70
+ targetRepository: "root-actions-runner",
71
71
  },
72
72
  },
73
73
  });
74
- const autoscalerCache = new resource_1.Resource(this, 'autoscalerCache', {
75
- type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',
74
+ const autoscalerCache = new resource_1.Resource(this, "autoscalerCache", {
75
+ type: "Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview",
76
76
  parentId: acr.id,
77
- name: 'autoscaler-cache',
77
+ name: "autoscaler-cache",
78
78
  body: {
79
79
  properties: {
80
- sourceRepository: 'ghcr.io/hi-fi/gha-runners-on-managed-env',
81
- targetRepository: 'autoscaler',
80
+ sourceRepository: "ghcr.io/hi-fi/gha-runners-on-managed-env",
81
+ targetRepository: "autoscaler",
82
82
  },
83
83
  },
84
84
  });
85
- const identity = new user_assigned_identity_1.UserAssignedIdentity(this, 'identity', {
85
+ const identity = new user_assigned_identity_1.UserAssignedIdentity(this, "identity", {
86
86
  location,
87
- name: 'aca-acr-access',
87
+ name: "aca-acr-access",
88
88
  resourceGroupName: rg.name,
89
89
  lifecycle: {
90
- ignoreChanges: ['tags'],
90
+ ignoreChanges: ["tags"],
91
91
  },
92
92
  });
93
- new role_assignment_1.RoleAssignment(this, 'roleAssignment', {
93
+ new role_assignment_1.RoleAssignment(this, "roleAssignment", {
94
94
  principalId: identity.principalId,
95
95
  scope: acr.id,
96
- roleDefinitionName: 'AcrPull',
96
+ roleDefinitionName: "AcrPull",
97
97
  });
98
- const log = new log_analytics_workspace_1.LogAnalyticsWorkspace(this, 'log', {
98
+ const log = new log_analytics_workspace_1.LogAnalyticsWorkspace(this, "log", {
99
99
  location,
100
- name: 'gha-example-logs',
100
+ name: "gha-example-logs",
101
101
  resourceGroupName: rg.name,
102
102
  lifecycle: {
103
- ignoreChanges: ['tags'],
103
+ ignoreChanges: ["tags"],
104
104
  },
105
105
  });
106
- const storageAccount = new resource_1.Resource(this, 'storageAccount', {
107
- type: 'Microsoft.Storage/storageAccounts@2023-01-01',
106
+ const storageAccount = new resource_1.Resource(this, "storageAccount", {
107
+ type: "Microsoft.Storage/storageAccounts@2023-01-01",
108
108
  parentId: rg.id,
109
109
  location,
110
110
  name: `ghastorageaccount${random.result}`,
111
111
  body: {
112
112
  properties: {
113
- largeFileSharesState: 'Enabled',
113
+ largeFileSharesState: "Enabled",
114
114
  },
115
115
  sku: {
116
- name: 'Standard_LRS',
116
+ name: "Standard_LRS",
117
117
  },
118
- kind: 'StorageV2',
118
+ kind: "StorageV2",
119
119
  },
120
120
  lifecycle: {
121
- ignoreChanges: ['tags'],
121
+ ignoreChanges: ["tags"],
122
122
  },
123
123
  responseExportValues: [],
124
124
  });
125
- const storageShare = new resource_1.Resource(this, 'storageShare', {
126
- type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',
127
- name: 'ghaexampleshare',
125
+ const storageShare = new resource_1.Resource(this, "storageShare", {
126
+ type: "Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01",
127
+ name: "ghaexampleshare",
128
128
  parentId: `${storageAccount.id}/fileServices/default`,
129
129
  body: {
130
130
  properties: {
131
- enabledProtocols: 'SMB',
131
+ enabledProtocols: "SMB",
132
132
  },
133
133
  },
134
134
  });
135
- const externalsShare = new resource_1.Resource(this, 'externalsShare', {
136
- type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',
137
- name: 'ghaexternalsshare',
135
+ const externalsShare = new resource_1.Resource(this, "externalsShare", {
136
+ type: "Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01",
137
+ name: "ghaexternalsshare",
138
138
  parentId: `${storageAccount.id}/fileServices/default`,
139
139
  body: {
140
140
  properties: {
141
- enabledProtocols: 'SMB',
141
+ enabledProtocols: "SMB",
142
142
  },
143
143
  },
144
144
  });
145
- const environment = new resource_1.Resource(this, 'acaenv', {
146
- type: 'Microsoft.App/managedEnvironments@2024-03-01',
145
+ const environment = new resource_1.Resource(this, "acaenv", {
146
+ type: "Microsoft.App/managedEnvironments@2024-03-01",
147
147
  parentId: rg.id,
148
148
  location,
149
- name: 'gha-runner-environment',
149
+ name: "gha-runner-environment",
150
150
  body: {
151
151
  properties: {
152
152
  appLogsConfiguration: {
153
- destination: 'log-analytics',
153
+ destination: "log-analytics",
154
154
  logAnalyticsConfiguration: {
155
155
  customerId: log.workspaceId,
156
156
  sharedKey: log.primarySharedKey,
157
157
  },
158
158
  },
159
- infrastructureResourceGroup: 'managed-aca-rg',
159
+ infrastructureResourceGroup: "managed-aca-rg",
160
160
  workloadProfiles: [
161
161
  {
162
- name: 'Consumption',
163
- workloadProfileType: 'Consumption',
162
+ name: "Consumption",
163
+ workloadProfileType: "Consumption",
164
164
  },
165
165
  ],
166
166
  },
167
167
  },
168
168
  lifecycle: {
169
- ignoreChanges: ['tags'],
169
+ ignoreChanges: ["tags"],
170
170
  },
171
171
  });
172
- const storageAccessKey = new data_azapi_resource_action_1.DataAzapiResourceAction(this, 'storageAccessKeys', {
173
- type: 'Microsoft.Storage/storageAccounts@2023-01-01',
174
- action: 'listKeys',
172
+ const storageAccessKey = new data_azapi_resource_action_1.DataAzapiResourceAction(this, "storageAccessKeys", {
173
+ type: "Microsoft.Storage/storageAccounts@2023-01-01",
174
+ action: "listKeys",
175
175
  resourceId: storageAccount.id,
176
- responseExportValues: ['*'],
176
+ responseExportValues: ["*"],
177
177
  dependsOn: [storageAccount],
178
178
  });
179
179
  // see https://github.com/hashicorp/terraform-cdk/issues/1641
180
180
  // 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
181
181
  // const accessKey = Fn.lookup(Fn.element(Fn.lookup(Fn.jsondecode(storageAccessKey.output as any), 'keys'), 0), 'value')
182
- const accessKey = cdktf_1.Fn.lookup(cdktf_1.Fn.element(cdktf_1.Fn.element(storageAccessKey.output.lookup('0'), 0), 0), 'value');
183
- const acaEnvStorage = new container_app_environment_storage_1.ContainerAppEnvironmentStorage(this, 'acaenvstorage', {
184
- name: 'gharunnerjobstorage',
182
+ const accessKey = cdktf_1.Fn.lookup(cdktf_1.Fn.element(cdktf_1.Fn.element(storageAccessKey.output.lookup("0"), 0), 0), "value");
183
+ const acaEnvStorage = new container_app_environment_storage_1.ContainerAppEnvironmentStorage(this, "acaenvstorage", {
184
+ name: "gharunnerjobstorage",
185
185
  accessKey,
186
- accessMode: 'ReadWrite',
186
+ accessMode: "ReadWrite",
187
187
  accountName: storageAccount.name,
188
188
  containerAppEnvironmentId: environment.id,
189
189
  shareName: storageShare.name,
@@ -192,10 +192,10 @@ class Azure extends constructs_1.Construct {
192
192
  storageShare,
193
193
  ],
194
194
  });
195
- const acaExternalStorage = new container_app_environment_storage_1.ContainerAppEnvironmentStorage(this, 'acaexternalstorage', {
196
- name: 'gharunnerexternalstorage',
195
+ const acaExternalStorage = new container_app_environment_storage_1.ContainerAppEnvironmentStorage(this, "acaexternalstorage", {
196
+ name: "gharunnerexternalstorage",
197
197
  accessKey,
198
- accessMode: 'ReadWrite',
198
+ accessMode: "ReadWrite",
199
199
  accountName: storageAccount.name,
200
200
  containerAppEnvironmentId: environment.id,
201
201
  shareName: externalsShare.name,
@@ -204,20 +204,20 @@ class Azure extends constructs_1.Construct {
204
204
  externalsShare,
205
205
  ],
206
206
  });
207
- const runnerVolumeName = 'work';
208
- const externalVolumeName = 'externals';
207
+ const runnerVolumeName = "work";
208
+ const externalVolumeName = "externals";
209
209
  /**
210
210
  * @see https://learn.microsoft.com/en-us/azure/templates/microsoft.app/jobs?pivots=deployment-language-terraform
211
211
  */
212
- const ghaRunnerJob = new resource_1.Resource(this, 'ghaRunnerJob', {
213
- type: 'Microsoft.App/jobs@2024-02-02-preview',
212
+ const ghaRunnerJob = new resource_1.Resource(this, "ghaRunnerJob", {
213
+ type: "Microsoft.App/jobs@2024-02-02-preview",
214
214
  identity: [
215
215
  {
216
- type: 'UserAssigned',
216
+ type: "UserAssigned",
217
217
  identityIds: [identity.id],
218
218
  },
219
219
  ],
220
- name: 'gha-runner-job-01',
220
+ name: "gha-runner-job-01",
221
221
  parentId: rg.id,
222
222
  location,
223
223
  body: {
@@ -227,7 +227,7 @@ class Azure extends constructs_1.Construct {
227
227
  parallelism: 1,
228
228
  replicaCompletionCount: 1,
229
229
  },
230
- triggerType: 'Manual',
230
+ triggerType: "Manual",
231
231
  replicaTimeout: 1200,
232
232
  registries: [
233
233
  {
@@ -242,59 +242,59 @@ class Azure extends constructs_1.Construct {
242
242
  {
243
243
  resources: {
244
244
  cpu: 1,
245
- memory: '2Gi',
245
+ memory: "2Gi",
246
246
  },
247
247
  // Have to use custom image as we want to run service as root to be able to install packages
248
248
  image: `${acr.loginServer}/root-actions-runner:latest`,
249
- name: 'main',
249
+ name: "main",
250
250
  command: [
251
- '/bin/sh',
252
- '-c',
253
- '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',
251
+ "/bin/sh",
252
+ "-c",
253
+ "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",
254
254
  ],
255
255
  volumeMounts: [
256
256
  {
257
- mountPath: '/tmp/_work',
257
+ mountPath: "/tmp/_work",
258
258
  volumeName: runnerVolumeName,
259
259
  },
260
260
  {
261
- mountPath: '/tmp/externals',
261
+ mountPath: "/tmp/externals",
262
262
  volumeName: externalVolumeName,
263
263
  },
264
264
  ],
265
265
  env: [
266
266
  // https://github.com/microsoft/azure-container-apps/issues/502#issuecomment-1340225438
267
267
  {
268
- name: 'APPSETTING_WEBSITE_SITE_NAME',
269
- value: 'identity-workaround',
268
+ name: "APPSETTING_WEBSITE_SITE_NAME",
269
+ value: "identity-workaround",
270
270
  },
271
271
  // https://github.com/microsoft/azure-container-apps/issues/442#issuecomment-1665621031
272
272
  {
273
- name: 'AZURE_CLIENT_ID',
273
+ name: "AZURE_CLIENT_ID",
274
274
  value: identity.clientId,
275
275
  },
276
276
  {
277
- name: 'RG_NAME',
277
+ name: "RG_NAME",
278
278
  value: rg.name,
279
279
  },
280
280
  {
281
- name: 'LOG_ID',
281
+ name: "LOG_ID",
282
282
  value: log.workspaceId,
283
283
  },
284
284
  {
285
- name: 'STORAGE_NAME',
285
+ name: "STORAGE_NAME",
286
286
  value: acaEnvStorage.name,
287
287
  },
288
288
  {
289
- name: 'EXTERNAL_STORAGE_NAME',
289
+ name: "EXTERNAL_STORAGE_NAME",
290
290
  value: acaExternalStorage.name,
291
291
  },
292
292
  {
293
- name: 'SUBSCRIPTION_ID',
293
+ name: "SUBSCRIPTION_ID",
294
294
  value: sub.subscriptionId,
295
295
  },
296
296
  {
297
- name: 'ACA_ENVIRONMENT_ID',
297
+ name: "ACA_ENVIRONMENT_ID",
298
298
  value: environment.id,
299
299
  },
300
300
  ],
@@ -304,14 +304,14 @@ class Azure extends constructs_1.Construct {
304
304
  {
305
305
  name: runnerVolumeName,
306
306
  storageName: acaEnvStorage.name,
307
- storageType: 'AzureFile',
308
- mountOptions: 'mfsymlinks',
307
+ storageType: "AzureFile",
308
+ mountOptions: "mfsymlinks",
309
309
  },
310
310
  {
311
311
  name: externalVolumeName,
312
312
  storageName: acaExternalStorage.name,
313
- storageType: 'AzureFile',
314
- mountOptions: 'mfsymlinks',
313
+ storageType: "AzureFile",
314
+ mountOptions: "mfsymlinks",
315
315
  },
316
316
  ],
317
317
  },
@@ -319,21 +319,21 @@ class Azure extends constructs_1.Construct {
319
319
  },
320
320
  dependsOn: [runnerCache],
321
321
  lifecycle: {
322
- ignoreChanges: ['tags'],
322
+ ignoreChanges: ["tags"],
323
323
  },
324
324
  });
325
- const autoscalerApp = new container_app_1.ContainerApp(this, 'autoscalerApp', {
325
+ const autoscalerApp = new container_app_1.ContainerApp(this, "autoscalerApp", {
326
326
  containerAppEnvironmentId: environment.id,
327
- name: 'autoscaler-app-01',
327
+ name: "autoscaler-app-01",
328
328
  resourceGroupName: rg.name,
329
- revisionMode: 'Single',
329
+ revisionMode: "Single",
330
330
  identity: {
331
- type: 'SystemAssigned, UserAssigned',
331
+ type: "SystemAssigned, UserAssigned",
332
332
  identityIds: [identity.id],
333
333
  },
334
334
  secret: [
335
335
  {
336
- name: 'pat',
336
+ name: "pat",
337
337
  value: pat.value,
338
338
  },
339
339
  ],
@@ -348,37 +348,37 @@ class Azure extends constructs_1.Construct {
348
348
  {
349
349
  // CPU and Memory can be lower with workload profile
350
350
  cpu: 0.25,
351
- memory: '0.5Gi',
351
+ memory: "0.5Gi",
352
352
  image: `${acr.loginServer}/autoscaler:test`,
353
- name: 'autoscaler',
353
+ name: "autoscaler",
354
354
  env: [
355
355
  {
356
- name: 'PAT',
357
- secretName: 'pat',
356
+ name: "PAT",
357
+ secretName: "pat",
358
358
  },
359
359
  {
360
- name: 'GITHUB_CONFIG_URL',
360
+ name: "GITHUB_CONFIG_URL",
361
361
  value: githubConfigUrl.value,
362
362
  },
363
363
  {
364
- name: 'AZURE_TENANT_ID',
364
+ name: "AZURE_TENANT_ID",
365
365
  value: sub.tenantId,
366
366
  },
367
367
  {
368
- name: 'SUBSCRIPTION_ID',
368
+ name: "SUBSCRIPTION_ID",
369
369
  value: sub.subscriptionId,
370
370
  },
371
371
  {
372
- name: 'RESOURCE_GROUP_NAME',
372
+ name: "RESOURCE_GROUP_NAME",
373
373
  value: rg.name,
374
374
  },
375
375
  {
376
- name: 'JOB_NAME',
376
+ name: "JOB_NAME",
377
377
  value: ghaRunnerJob.name,
378
378
  },
379
379
  {
380
- name: 'SCALE_SET_NAME',
381
- value: 'aca-runner-set',
380
+ name: "SCALE_SET_NAME",
381
+ value: "aca-runner-set",
382
382
  },
383
383
  ],
384
384
  },
@@ -386,68 +386,68 @@ class Azure extends constructs_1.Construct {
386
386
  },
387
387
  dependsOn: [autoscalerCache],
388
388
  lifecycle: {
389
- ignoreChanges: ['tags', 'workload_profile_name'],
389
+ ignoreChanges: ["tags", "workload_profile_name"],
390
390
  },
391
391
  });
392
392
  /**
393
393
  * @see https://github.com/microsoft/azure-container-apps/issues/1024
394
394
  */
395
- const role = new role_definition_1.RoleDefinition(this, 'jobRole', {
395
+ const role = new role_definition_1.RoleDefinition(this, "jobRole", {
396
396
  name: `gha-example-revision-start-role-${random.result}`,
397
397
  scope: sub.id,
398
398
  permissions: [
399
399
  {
400
400
  actions: [
401
- 'microsoft.app/jobs/start/action',
402
- 'microsoft.app/jobs/stop/action',
403
- 'microsoft.app/jobs/read',
404
- 'microsoft.app/jobs/executions/read',
401
+ "microsoft.app/jobs/start/action",
402
+ "microsoft.app/jobs/stop/action",
403
+ "microsoft.app/jobs/read",
404
+ "microsoft.app/jobs/executions/read",
405
405
  ],
406
406
  },
407
407
  ],
408
408
  });
409
- const jobCreationRole = new role_definition_1.RoleDefinition(this, 'jobCreationRole', {
409
+ const jobCreationRole = new role_definition_1.RoleDefinition(this, "jobCreationRole", {
410
410
  name: `gha-example-revision-create-role-${random.result}`,
411
411
  scope: sub.id,
412
412
  permissions: [
413
413
  {
414
414
  actions: [
415
- 'microsoft.app/jobs/start/action',
416
- 'microsoft.app/jobs/stop/action',
417
- 'microsoft.app/jobs/read',
418
- 'microsoft.app/jobs/write',
419
- 'microsoft.app/jobs/executions/read',
420
- 'microsoft.app/managedEnvironments/join/action',
421
- 'microsoft.app/jobs/delete', // cleanup for jobs
415
+ "microsoft.app/jobs/start/action",
416
+ "microsoft.app/jobs/stop/action",
417
+ "microsoft.app/jobs/read",
418
+ "microsoft.app/jobs/write",
419
+ "microsoft.app/jobs/executions/read",
420
+ "microsoft.app/managedEnvironments/join/action",
421
+ "microsoft.app/jobs/delete", // cleanup for jobs
422
422
  ],
423
423
  },
424
424
  ],
425
425
  });
426
426
  // Allow autoscaler to create new revision of app
427
- new role_assignment_1.RoleAssignment(this, 'scaleJobRoleAssignment', {
427
+ new role_assignment_1.RoleAssignment(this, "scaleJobRoleAssignment", {
428
428
  principalId: autoscalerApp.identity.principalId,
429
429
  scope: ghaRunnerJob.id,
430
430
  roleDefinitionId: role.roleDefinitionResourceId,
431
431
  });
432
432
  // Allow runner to start the job. As each one created new job, have to give to RG level.
433
- new role_assignment_1.RoleAssignment(this, 'actionContainerStartRoleAssignment', {
433
+ new role_assignment_1.RoleAssignment(this, "actionContainerStartRoleAssignment", {
434
434
  principalId: identity.principalId,
435
435
  scope: rg.id,
436
436
  roleDefinitionId: jobCreationRole.roleDefinitionResourceId,
437
437
  });
438
- new role_assignment_1.RoleAssignment(this, 'imagePushRoleAssignment', {
438
+ new role_assignment_1.RoleAssignment(this, "imagePushRoleAssignment", {
439
439
  principalId: identity.principalId,
440
440
  scope: acr.id,
441
- roleDefinitionName: 'AcrPush',
441
+ roleDefinitionName: "AcrPush",
442
442
  });
443
- new role_assignment_1.RoleAssignment(this, 'jobLogReadAssignment', {
443
+ new role_assignment_1.RoleAssignment(this, "jobLogReadAssignment", {
444
444
  principalId: identity.principalId,
445
445
  scope: log.id,
446
- roleDefinitionName: 'Log Analytics Reader',
446
+ roleDefinitionName: "Log Analytics Reader",
447
447
  });
448
448
  }
449
449
  }
450
450
  exports.Azure = Azure;
451
451
  _a = JSII_RTTI_SYMBOL_1;
452
- Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.7" };
453
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azure.js","sourceRoot":"","sources":["../../src/lib/azure.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContainerApp } from '@cdktf/provider-azurerm/lib/container-app'\nimport { ContainerAppEnvironmentStorage } from '@cdktf/provider-azurerm/lib/container-app-environment-storage'\nimport { ContainerRegistry } from '@cdktf/provider-azurerm/lib/container-registry'\nimport { DataAzurermSubscription } from '@cdktf/provider-azurerm/lib/data-azurerm-subscription'\nimport { LogAnalyticsWorkspace } from '@cdktf/provider-azurerm/lib/log-analytics-workspace'\nimport { AzurermProvider } from '@cdktf/provider-azurerm/lib/provider'\nimport { ResourceGroup } from '@cdktf/provider-azurerm/lib/resource-group'\nimport { RoleAssignment } from '@cdktf/provider-azurerm/lib/role-assignment'\nimport { RoleDefinition } from '@cdktf/provider-azurerm/lib/role-definition'\nimport { UserAssignedIdentity } from '@cdktf/provider-azurerm/lib/user-assigned-identity'\nimport { RandomProvider } from '@cdktf/provider-random/lib/provider'\nimport { StringResource } from '@cdktf/provider-random/lib/string-resource'\nimport { Fn, TerraformVariable } from 'cdktf'\nimport { Construct } from 'constructs'\nimport { DataAzapiResourceAction } from '../.gen/providers/azapi/data-azapi-resource-action'\nimport { AzapiProvider } from '../.gen/providers/azapi/provider'\nimport { Resource } from '../.gen/providers/azapi/resource'\nimport { commonVariables } from './variables'\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    new AzapiProvider(this, 'azapi', {})\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: ['tags'],\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: ['tags'],\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: ['tags'],\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: ['tags'],\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: ['tags'],\n      },\n      responseExportValues: [],\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: ['tags'],\n      },\n    })\n\n    const storageAccessKey = new DataAzapiResourceAction(\n      this,\n      'storageAccessKeys',\n      {\n        type: 'Microsoft.Storage/storageAccounts@2023-01-01',\n        action: 'listKeys',\n        resourceId: storageAccount.id,\n        responseExportValues: ['*'],\n        dependsOn: [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(\n      Fn.element(Fn.element(storageAccessKey.output.lookup('0'), 0), 0),\n      'value',\n    )\n\n    const acaEnvStorage = new ContainerAppEnvironmentStorage(\n      this,\n      'acaenvstorage',\n      {\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\n    const acaExternalStorage = new ContainerAppEnvironmentStorage(\n      this,\n      'acaexternalstorage',\n      {\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\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: [identity.id],\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: [\n                  '/bin/sh',\n                  '-c',\n                  '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                ],\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: [runnerCache],\n      lifecycle: {\n        ignoreChanges: ['tags'],\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: [identity.id],\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: [autoscalerCache],\n      lifecycle: {\n        ignoreChanges: ['tags', 'workload_profile_name'],\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}\n"]}
452
+ Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.8" };
453
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azure.js","sourceRoot":"","sources":["../../src/lib/azure.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContainerApp } from \"@cdktf/provider-azurerm/lib/container-app\";\nimport { ContainerAppEnvironmentStorage } from \"@cdktf/provider-azurerm/lib/container-app-environment-storage\";\nimport { ContainerRegistry } from \"@cdktf/provider-azurerm/lib/container-registry\";\nimport { DataAzurermSubscription } from \"@cdktf/provider-azurerm/lib/data-azurerm-subscription\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { AzurermProvider } from \"@cdktf/provider-azurerm/lib/provider\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { RoleAssignment } from \"@cdktf/provider-azurerm/lib/role-assignment\";\nimport { RoleDefinition } from \"@cdktf/provider-azurerm/lib/role-definition\";\nimport { UserAssignedIdentity } from \"@cdktf/provider-azurerm/lib/user-assigned-identity\";\nimport { RandomProvider } from \"@cdktf/provider-random/lib/provider\";\nimport { StringResource } from \"@cdktf/provider-random/lib/string-resource\";\nimport { Fn, TerraformVariable } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { DataAzapiResourceAction } from \"../.gen/providers/azapi/data-azapi-resource-action\";\nimport { AzapiProvider } from \"../.gen/providers/azapi/provider\";\nimport { Resource } from \"../.gen/providers/azapi/resource\";\nimport { commonVariables } from \"./variables\";\n\nexport class Azure extends Construct {\n\tconstructor(scope: Construct, id: string) {\n\t\tsuper(scope, id);\n\n\t\tnew AzurermProvider(this, \"azurerm\", {\n\t\t\tfeatures: [{}],\n\t\t});\n\n\t\tnew AzapiProvider(this, \"azapi\", {});\n\n\t\tnew RandomProvider(this, \"random\");\n\n\t\tconst sub = new DataAzurermSubscription(this, \"sub\", {});\n\n\t\tconst { pat, githubConfigUrl } = commonVariables(this);\n\n\t\tconst location = new TerraformVariable(this, \"location\", {\n\t\t\tdefault: \"westeurope\",\n\t\t\tdescription: \"Location where to provision resources to\",\n\t\t\ttype: \"string\",\n\t\t\tsensitive: false,\n\t\t\tnullable: false,\n\t\t}).value;\n\n\t\tconst rg = new ResourceGroup(this, \"rg\", {\n\t\t\tlocation,\n\t\t\tname: \"gha-runner-rg\",\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\"],\n\t\t\t},\n\t\t});\n\n\t\tconst random = new StringResource(this, \"randomSuffix\", {\n\t\t\tlength: 6,\n\t\t\tspecial: false,\n\t\t\tupper: false,\n\t\t});\n\n\t\tconst acr = new ContainerRegistry(this, \"acr\", {\n\t\t\tlocation,\n\t\t\tname: `runneracr${random.result}`,\n\t\t\tresourceGroupName: rg.name,\n\t\t\tsku: \"Basic\",\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\"],\n\t\t\t},\n\t\t});\n\n\t\t// use caching for images\n\t\tconst runnerCache = new Resource(this, \"runnerCache\", {\n\t\t\ttype: \"Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview\",\n\t\t\tparentId: acr.id,\n\t\t\tname: \"root-runner-cache\",\n\t\t\tbody: {\n\t\t\t\tproperties: {\n\t\t\t\t\tsourceRepository: \"ghcr.io/hi-fi/root-actions-runner\",\n\t\t\t\t\ttargetRepository: \"root-actions-runner\",\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\n\t\tconst autoscalerCache = new Resource(this, \"autoscalerCache\", {\n\t\t\ttype: \"Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview\",\n\t\t\tparentId: acr.id,\n\t\t\tname: \"autoscaler-cache\",\n\t\t\tbody: {\n\t\t\t\tproperties: {\n\t\t\t\t\tsourceRepository: \"ghcr.io/hi-fi/gha-runners-on-managed-env\",\n\t\t\t\t\ttargetRepository: \"autoscaler\",\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\n\t\tconst identity = new UserAssignedIdentity(this, \"identity\", {\n\t\t\tlocation,\n\t\t\tname: \"aca-acr-access\",\n\t\t\tresourceGroupName: rg.name,\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\"],\n\t\t\t},\n\t\t});\n\n\t\tnew RoleAssignment(this, \"roleAssignment\", {\n\t\t\tprincipalId: identity.principalId,\n\t\t\tscope: acr.id,\n\t\t\troleDefinitionName: \"AcrPull\",\n\t\t});\n\n\t\tconst log = new LogAnalyticsWorkspace(this, \"log\", {\n\t\t\tlocation,\n\t\t\tname: \"gha-example-logs\",\n\t\t\tresourceGroupName: rg.name,\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\"],\n\t\t\t},\n\t\t});\n\n\t\tconst storageAccount = new Resource(this, \"storageAccount\", {\n\t\t\ttype: \"Microsoft.Storage/storageAccounts@2023-01-01\",\n\t\t\tparentId: rg.id,\n\t\t\tlocation,\n\t\t\tname: `ghastorageaccount${random.result}`,\n\t\t\tbody: {\n\t\t\t\tproperties: {\n\t\t\t\t\tlargeFileSharesState: \"Enabled\",\n\t\t\t\t},\n\t\t\t\tsku: {\n\t\t\t\t\tname: \"Standard_LRS\",\n\t\t\t\t},\n\t\t\t\tkind: \"StorageV2\",\n\t\t\t},\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\"],\n\t\t\t},\n\t\t\tresponseExportValues: [],\n\t\t});\n\n\t\tconst storageShare = new Resource(this, \"storageShare\", {\n\t\t\ttype: \"Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01\",\n\t\t\tname: \"ghaexampleshare\",\n\t\t\tparentId: `${storageAccount.id}/fileServices/default`,\n\t\t\tbody: {\n\t\t\t\tproperties: {\n\t\t\t\t\tenabledProtocols: \"SMB\",\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\n\t\tconst externalsShare = new Resource(this, \"externalsShare\", {\n\t\t\ttype: \"Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01\",\n\t\t\tname: \"ghaexternalsshare\",\n\t\t\tparentId: `${storageAccount.id}/fileServices/default`,\n\t\t\tbody: {\n\t\t\t\tproperties: {\n\t\t\t\t\tenabledProtocols: \"SMB\",\n\t\t\t\t},\n\t\t\t},\n\t\t});\n\n\t\tconst environment = new Resource(this, \"acaenv\", {\n\t\t\ttype: \"Microsoft.App/managedEnvironments@2024-03-01\",\n\t\t\tparentId: rg.id,\n\t\t\tlocation,\n\t\t\tname: \"gha-runner-environment\",\n\t\t\tbody: {\n\t\t\t\tproperties: {\n\t\t\t\t\tappLogsConfiguration: {\n\t\t\t\t\t\tdestination: \"log-analytics\",\n\t\t\t\t\t\tlogAnalyticsConfiguration: {\n\t\t\t\t\t\t\tcustomerId: log.workspaceId,\n\t\t\t\t\t\t\tsharedKey: log.primarySharedKey,\n\t\t\t\t\t\t},\n\t\t\t\t\t},\n\t\t\t\t\tinfrastructureResourceGroup: \"managed-aca-rg\",\n\t\t\t\t\tworkloadProfiles: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tname: \"Consumption\",\n\t\t\t\t\t\t\tworkloadProfileType: \"Consumption\",\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t},\n\t\t\t},\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\"],\n\t\t\t},\n\t\t});\n\n\t\tconst storageAccessKey = new DataAzapiResourceAction(\n\t\t\tthis,\n\t\t\t\"storageAccessKeys\",\n\t\t\t{\n\t\t\t\ttype: \"Microsoft.Storage/storageAccounts@2023-01-01\",\n\t\t\t\taction: \"listKeys\",\n\t\t\t\tresourceId: storageAccount.id,\n\t\t\t\tresponseExportValues: [\"*\"],\n\t\t\t\tdependsOn: [storageAccount],\n\t\t\t},\n\t\t);\n\n\t\t// see https://github.com/hashicorp/terraform-cdk/issues/1641\n\t\t// 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\t\t// const accessKey = Fn.lookup(Fn.element(Fn.lookup(Fn.jsondecode(storageAccessKey.output as any), 'keys'), 0), 'value')\n\n\t\tconst accessKey = Fn.lookup(\n\t\t\tFn.element(Fn.element(storageAccessKey.output.lookup(\"0\"), 0), 0),\n\t\t\t\"value\",\n\t\t);\n\n\t\tconst acaEnvStorage = new ContainerAppEnvironmentStorage(\n\t\t\tthis,\n\t\t\t\"acaenvstorage\",\n\t\t\t{\n\t\t\t\tname: \"gharunnerjobstorage\",\n\t\t\t\taccessKey,\n\t\t\t\taccessMode: \"ReadWrite\",\n\t\t\t\taccountName: storageAccount.name,\n\t\t\t\tcontainerAppEnvironmentId: environment.id,\n\t\t\t\tshareName: storageShare.name,\n\t\t\t\tdependsOn: [\n\t\t\t\t\t// Name doesn't create dependsOn requirement, so adding that explicitly\n\t\t\t\t\tstorageShare,\n\t\t\t\t],\n\t\t\t},\n\t\t);\n\n\t\tconst acaExternalStorage = new ContainerAppEnvironmentStorage(\n\t\t\tthis,\n\t\t\t\"acaexternalstorage\",\n\t\t\t{\n\t\t\t\tname: \"gharunnerexternalstorage\",\n\t\t\t\taccessKey,\n\t\t\t\taccessMode: \"ReadWrite\",\n\t\t\t\taccountName: storageAccount.name,\n\t\t\t\tcontainerAppEnvironmentId: environment.id,\n\t\t\t\tshareName: externalsShare.name,\n\t\t\t\tdependsOn: [\n\t\t\t\t\t// Name doesn't create dependsOn requirement, so adding that explicitly\n\t\t\t\t\texternalsShare,\n\t\t\t\t],\n\t\t\t},\n\t\t);\n\n\t\tconst runnerVolumeName = \"work\";\n\t\tconst externalVolumeName = \"externals\";\n\n\t\t/**\n\t\t * @see https://learn.microsoft.com/en-us/azure/templates/microsoft.app/jobs?pivots=deployment-language-terraform\n\t\t */\n\t\tconst ghaRunnerJob = new Resource(this, \"ghaRunnerJob\", {\n\t\t\ttype: \"Microsoft.App/jobs@2024-02-02-preview\",\n\t\t\tidentity: [\n\t\t\t\t{\n\t\t\t\t\ttype: \"UserAssigned\",\n\t\t\t\t\tidentityIds: [identity.id],\n\t\t\t\t},\n\t\t\t],\n\t\t\tname: \"gha-runner-job-01\",\n\t\t\tparentId: rg.id,\n\t\t\tlocation,\n\t\t\tbody: {\n\t\t\t\tproperties: {\n\t\t\t\t\tconfiguration: {\n\t\t\t\t\t\tmanualTriggerConfig: {\n\t\t\t\t\t\t\tparallelism: 1,\n\t\t\t\t\t\t\treplicaCompletionCount: 1,\n\t\t\t\t\t\t},\n\t\t\t\t\t\ttriggerType: \"Manual\",\n\t\t\t\t\t\treplicaTimeout: 1200,\n\t\t\t\t\t\tregistries: [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tidentity: identity.id,\n\t\t\t\t\t\t\t\tserver: acr.loginServer,\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\tenvironmentId: environment.id,\n\t\t\t\t\ttemplate: {\n\t\t\t\t\t\tcontainers: [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tresources: {\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\t// Have to use custom image as we want to run service as root to be able to install packages\n\t\t\t\t\t\t\t\timage: `${acr.loginServer}/root-actions-runner:latest`,\n\t\t\t\t\t\t\t\tname: \"main\",\n\t\t\t\t\t\t\t\tcommand: [\n\t\t\t\t\t\t\t\t\t\"/bin/sh\",\n\t\t\t\t\t\t\t\t\t\"-c\",\n\t\t\t\t\t\t\t\t\t\"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\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\tvolumeMounts: [\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tmountPath: \"/tmp/_work\",\n\t\t\t\t\t\t\t\t\t\tvolumeName: runnerVolumeName,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tmountPath: \"/tmp/externals\",\n\t\t\t\t\t\t\t\t\t\tvolumeName: externalVolumeName,\n\t\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\tenv: [\n\t\t\t\t\t\t\t\t\t// https://github.com/microsoft/azure-container-apps/issues/502#issuecomment-1340225438\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"APPSETTING_WEBSITE_SITE_NAME\",\n\t\t\t\t\t\t\t\t\t\tvalue: \"identity-workaround\",\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t// https://github.com/microsoft/azure-container-apps/issues/442#issuecomment-1665621031\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"AZURE_CLIENT_ID\",\n\t\t\t\t\t\t\t\t\t\tvalue: identity.clientId,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"RG_NAME\",\n\t\t\t\t\t\t\t\t\t\tvalue: rg.name,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"LOG_ID\",\n\t\t\t\t\t\t\t\t\t\tvalue: log.workspaceId,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"STORAGE_NAME\",\n\t\t\t\t\t\t\t\t\t\tvalue: acaEnvStorage.name,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"EXTERNAL_STORAGE_NAME\",\n\t\t\t\t\t\t\t\t\t\tvalue: acaExternalStorage.name,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"SUBSCRIPTION_ID\",\n\t\t\t\t\t\t\t\t\t\tvalue: sub.subscriptionId,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tname: \"ACA_ENVIRONMENT_ID\",\n\t\t\t\t\t\t\t\t\t\tvalue: environment.id,\n\t\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},\n\t\t\t\t\t\t],\n\t\t\t\t\t\tvolumes: [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: runnerVolumeName,\n\t\t\t\t\t\t\t\tstorageName: acaEnvStorage.name,\n\t\t\t\t\t\t\t\tstorageType: \"AzureFile\",\n\t\t\t\t\t\t\t\tmountOptions: \"mfsymlinks\",\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: externalVolumeName,\n\t\t\t\t\t\t\t\tstorageName: acaExternalStorage.name,\n\t\t\t\t\t\t\t\tstorageType: \"AzureFile\",\n\t\t\t\t\t\t\t\tmountOptions: \"mfsymlinks\",\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},\n\t\t\t},\n\t\t\tdependsOn: [runnerCache],\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\"],\n\t\t\t},\n\t\t});\n\n\t\tconst autoscalerApp = new ContainerApp(this, \"autoscalerApp\", {\n\t\t\tcontainerAppEnvironmentId: environment.id,\n\t\t\tname: \"autoscaler-app-01\",\n\t\t\tresourceGroupName: rg.name,\n\t\t\trevisionMode: \"Single\",\n\t\t\tidentity: {\n\t\t\t\ttype: \"SystemAssigned, UserAssigned\",\n\t\t\t\tidentityIds: [identity.id],\n\t\t\t},\n\t\t\tsecret: [\n\t\t\t\t{\n\t\t\t\t\tname: \"pat\",\n\t\t\t\t\tvalue: pat.value,\n\t\t\t\t},\n\t\t\t],\n\t\t\tregistry: [\n\t\t\t\t{\n\t\t\t\t\tidentity: identity.id,\n\t\t\t\t\tserver: acr.loginServer,\n\t\t\t\t},\n\t\t\t],\n\t\t\ttemplate: {\n\t\t\t\tcontainer: [\n\t\t\t\t\t{\n\t\t\t\t\t\t// CPU and Memory can be lower with workload profile\n\t\t\t\t\t\tcpu: 0.25,\n\t\t\t\t\t\tmemory: \"0.5Gi\",\n\t\t\t\t\t\timage: `${acr.loginServer}/autoscaler:test`,\n\t\t\t\t\t\tname: \"autoscaler\",\n\t\t\t\t\t\tenv: [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: \"PAT\",\n\t\t\t\t\t\t\t\tsecretName: \"pat\",\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: \"GITHUB_CONFIG_URL\",\n\t\t\t\t\t\t\t\tvalue: githubConfigUrl.value,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: \"AZURE_TENANT_ID\",\n\t\t\t\t\t\t\t\tvalue: sub.tenantId,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: \"SUBSCRIPTION_ID\",\n\t\t\t\t\t\t\t\tvalue: sub.subscriptionId,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: \"RESOURCE_GROUP_NAME\",\n\t\t\t\t\t\t\t\tvalue: rg.name,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: \"JOB_NAME\",\n\t\t\t\t\t\t\t\tvalue: ghaRunnerJob.name,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tname: \"SCALE_SET_NAME\",\n\t\t\t\t\t\t\t\tvalue: \"aca-runner-set\",\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],\n\t\t\t},\n\t\t\tdependsOn: [autoscalerCache],\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"tags\", \"workload_profile_name\"],\n\t\t\t},\n\t\t});\n\n\t\t/**\n\t\t * @see https://github.com/microsoft/azure-container-apps/issues/1024\n\t\t */\n\t\tconst role = new RoleDefinition(this, \"jobRole\", {\n\t\t\tname: `gha-example-revision-start-role-${random.result}`,\n\t\t\tscope: sub.id,\n\t\t\tpermissions: [\n\t\t\t\t{\n\t\t\t\t\tactions: [\n\t\t\t\t\t\t\"microsoft.app/jobs/start/action\",\n\t\t\t\t\t\t\"microsoft.app/jobs/stop/action\",\n\t\t\t\t\t\t\"microsoft.app/jobs/read\",\n\t\t\t\t\t\t\"microsoft.app/jobs/executions/read\",\n\t\t\t\t\t],\n\t\t\t\t},\n\t\t\t],\n\t\t});\n\n\t\tconst jobCreationRole = new RoleDefinition(this, \"jobCreationRole\", {\n\t\t\tname: `gha-example-revision-create-role-${random.result}`,\n\t\t\tscope: sub.id,\n\t\t\tpermissions: [\n\t\t\t\t{\n\t\t\t\t\tactions: [\n\t\t\t\t\t\t\"microsoft.app/jobs/start/action\",\n\t\t\t\t\t\t\"microsoft.app/jobs/stop/action\",\n\t\t\t\t\t\t\"microsoft.app/jobs/read\",\n\t\t\t\t\t\t\"microsoft.app/jobs/write\",\n\t\t\t\t\t\t\"microsoft.app/jobs/executions/read\",\n\t\t\t\t\t\t\"microsoft.app/managedEnvironments/join/action\",\n\t\t\t\t\t\t\"microsoft.app/jobs/delete\", // cleanup for jobs\n\t\t\t\t\t],\n\t\t\t\t},\n\t\t\t],\n\t\t});\n\n\t\t// Allow autoscaler to create new revision of app\n\t\tnew RoleAssignment(this, \"scaleJobRoleAssignment\", {\n\t\t\tprincipalId: autoscalerApp.identity.principalId,\n\t\t\tscope: ghaRunnerJob.id,\n\t\t\troleDefinitionId: role.roleDefinitionResourceId,\n\t\t});\n\n\t\t// Allow runner to start the job. As each one created new job, have to give to RG level.\n\t\tnew RoleAssignment(this, \"actionContainerStartRoleAssignment\", {\n\t\t\tprincipalId: identity.principalId,\n\t\t\tscope: rg.id,\n\t\t\troleDefinitionId: jobCreationRole.roleDefinitionResourceId,\n\t\t});\n\n\t\tnew RoleAssignment(this, \"imagePushRoleAssignment\", {\n\t\t\tprincipalId: identity.principalId,\n\t\t\tscope: acr.id,\n\t\t\troleDefinitionName: \"AcrPush\",\n\t\t});\n\n\t\tnew RoleAssignment(this, \"jobLogReadAssignment\", {\n\t\t\tprincipalId: identity.principalId,\n\t\t\tscope: log.id,\n\t\t\troleDefinitionName: \"Log Analytics Reader\",\n\t\t});\n\t}\n}\n"]}