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

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
@@ -3,34 +3,32 @@ var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.Azure = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const container_app_1 = require("@cdktf/provider-azurerm/lib/container-app");
7
+ const container_app_environment_storage_1 = require("@cdktf/provider-azurerm/lib/container-app-environment-storage");
8
+ const container_registry_1 = require("@cdktf/provider-azurerm/lib/container-registry");
9
+ const data_azurerm_subscription_1 = require("@cdktf/provider-azurerm/lib/data-azurerm-subscription");
10
+ const log_analytics_workspace_1 = require("@cdktf/provider-azurerm/lib/log-analytics-workspace");
6
11
  const provider_1 = require("@cdktf/provider-azurerm/lib/provider");
7
- const provider_2 = require("../.gen/providers/azapi/provider");
8
- const resource_1 = require("../.gen/providers/azapi/resource");
9
- const data_azapi_resource_action_1 = require("../.gen/providers/azapi/data-azapi-resource-action");
10
- const cdktf_1 = require("cdktf");
11
- const constructs_1 = require("constructs");
12
12
  const resource_group_1 = require("@cdktf/provider-azurerm/lib/resource-group");
13
- const container_registry_1 = require("@cdktf/provider-azurerm/lib/container-registry");
14
- const user_assigned_identity_1 = require("@cdktf/provider-azurerm/lib/user-assigned-identity");
15
13
  const role_assignment_1 = require("@cdktf/provider-azurerm/lib/role-assignment");
16
- const log_analytics_workspace_1 = require("@cdktf/provider-azurerm/lib/log-analytics-workspace");
17
14
  const role_definition_1 = require("@cdktf/provider-azurerm/lib/role-definition");
18
- const data_azurerm_subscription_1 = require("@cdktf/provider-azurerm/lib/data-azurerm-subscription");
19
- const container_app_1 = require("@cdktf/provider-azurerm/lib/container-app");
20
- const variables_1 = require("./variables");
21
- const container_app_environment_storage_1 = require("@cdktf/provider-azurerm/lib/container-app-environment-storage");
22
- const provider_3 = require("@cdktf/provider-random/lib/provider");
15
+ const user_assigned_identity_1 = require("@cdktf/provider-azurerm/lib/user-assigned-identity");
16
+ const provider_2 = require("@cdktf/provider-random/lib/provider");
23
17
  const string_resource_1 = require("@cdktf/provider-random/lib/string-resource");
18
+ const cdktf_1 = require("cdktf");
19
+ const constructs_1 = require("constructs");
20
+ const data_azapi_resource_action_1 = require("../.gen/providers/azapi/data-azapi-resource-action");
21
+ const provider_3 = require("../.gen/providers/azapi/provider");
22
+ const resource_1 = require("../.gen/providers/azapi/resource");
23
+ const variables_1 = require("./variables");
24
24
  class Azure extends constructs_1.Construct {
25
25
  constructor(scope, id) {
26
26
  super(scope, id);
27
27
  new provider_1.AzurermProvider(this, 'azurerm', {
28
- features: [
29
- {}
30
- ]
28
+ features: [{}],
31
29
  });
32
- new provider_2.AzapiProvider(this, 'azapi', {});
33
- new provider_3.RandomProvider(this, 'random');
30
+ new provider_3.AzapiProvider(this, 'azapi', {});
31
+ new provider_2.RandomProvider(this, 'random');
34
32
  const sub = new data_azurerm_subscription_1.DataAzurermSubscription(this, 'sub', {});
35
33
  const { pat, githubConfigUrl } = (0, variables_1.commonVariables)(this);
36
34
  const location = new cdktf_1.TerraformVariable(this, 'location', {
@@ -38,16 +36,14 @@ class Azure extends constructs_1.Construct {
38
36
  description: 'Location where to provision resources to',
39
37
  type: 'string',
40
38
  sensitive: false,
41
- nullable: false
39
+ nullable: false,
42
40
  }).value;
43
41
  const rg = new resource_group_1.ResourceGroup(this, 'rg', {
44
42
  location,
45
43
  name: 'gha-runner-rg',
46
44
  lifecycle: {
47
- ignoreChanges: [
48
- 'tags'
49
- ]
50
- }
45
+ ignoreChanges: ['tags'],
46
+ },
51
47
  });
52
48
  const random = new string_resource_1.StringResource(this, 'randomSuffix', {
53
49
  length: 6,
@@ -60,10 +56,8 @@ class Azure extends constructs_1.Construct {
60
56
  resourceGroupName: rg.name,
61
57
  sku: 'Basic',
62
58
  lifecycle: {
63
- ignoreChanges: [
64
- 'tags'
65
- ]
66
- }
59
+ ignoreChanges: ['tags'],
60
+ },
67
61
  });
68
62
  // use caching for images
69
63
  const runnerCache = new resource_1.Resource(this, 'runnerCache', {
@@ -73,9 +67,9 @@ class Azure extends constructs_1.Construct {
73
67
  body: {
74
68
  properties: {
75
69
  sourceRepository: 'ghcr.io/hi-fi/root-actions-runner',
76
- targetRepository: 'root-actions-runner'
77
- }
78
- }
70
+ targetRepository: 'root-actions-runner',
71
+ },
72
+ },
79
73
  });
80
74
  const autoscalerCache = new resource_1.Resource(this, 'autoscalerCache', {
81
75
  type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',
@@ -84,34 +78,30 @@ class Azure extends constructs_1.Construct {
84
78
  body: {
85
79
  properties: {
86
80
  sourceRepository: 'ghcr.io/hi-fi/gha-runners-on-managed-env',
87
- targetRepository: 'autoscaler'
88
- }
89
- }
81
+ targetRepository: 'autoscaler',
82
+ },
83
+ },
90
84
  });
91
85
  const identity = new user_assigned_identity_1.UserAssignedIdentity(this, 'identity', {
92
86
  location,
93
87
  name: 'aca-acr-access',
94
88
  resourceGroupName: rg.name,
95
89
  lifecycle: {
96
- ignoreChanges: [
97
- 'tags'
98
- ]
99
- }
90
+ ignoreChanges: ['tags'],
91
+ },
100
92
  });
101
93
  new role_assignment_1.RoleAssignment(this, 'roleAssignment', {
102
94
  principalId: identity.principalId,
103
95
  scope: acr.id,
104
- roleDefinitionName: 'AcrPull'
96
+ roleDefinitionName: 'AcrPull',
105
97
  });
106
98
  const log = new log_analytics_workspace_1.LogAnalyticsWorkspace(this, 'log', {
107
99
  location,
108
100
  name: 'gha-example-logs',
109
101
  resourceGroupName: rg.name,
110
102
  lifecycle: {
111
- ignoreChanges: [
112
- 'tags'
113
- ]
114
- }
103
+ ignoreChanges: ['tags'],
104
+ },
115
105
  });
116
106
  const storageAccount = new resource_1.Resource(this, 'storageAccount', {
117
107
  type: 'Microsoft.Storage/storageAccounts@2023-01-01',
@@ -120,19 +110,17 @@ class Azure extends constructs_1.Construct {
120
110
  name: `ghastorageaccount${random.result}`,
121
111
  body: {
122
112
  properties: {
123
- largeFileSharesState: 'Enabled'
113
+ largeFileSharesState: 'Enabled',
124
114
  },
125
115
  sku: {
126
- name: 'Standard_LRS'
116
+ name: 'Standard_LRS',
127
117
  },
128
118
  kind: 'StorageV2',
129
119
  },
130
120
  lifecycle: {
131
- ignoreChanges: [
132
- 'tags'
133
- ]
121
+ ignoreChanges: ['tags'],
134
122
  },
135
- responseExportValues: []
123
+ responseExportValues: [],
136
124
  });
137
125
  const storageShare = new resource_1.Resource(this, 'storageShare', {
138
126
  type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',
@@ -141,7 +129,7 @@ class Azure extends constructs_1.Construct {
141
129
  body: {
142
130
  properties: {
143
131
  enabledProtocols: 'SMB',
144
- }
132
+ },
145
133
  },
146
134
  });
147
135
  const externalsShare = new resource_1.Resource(this, 'externalsShare', {
@@ -151,7 +139,7 @@ class Azure extends constructs_1.Construct {
151
139
  body: {
152
140
  properties: {
153
141
  enabledProtocols: 'SMB',
154
- }
142
+ },
155
143
  },
156
144
  });
157
145
  const environment = new resource_1.Resource(this, 'acaenv', {
@@ -166,31 +154,27 @@ class Azure extends constructs_1.Construct {
166
154
  logAnalyticsConfiguration: {
167
155
  customerId: log.workspaceId,
168
156
  sharedKey: log.primarySharedKey,
169
- }
157
+ },
170
158
  },
171
159
  infrastructureResourceGroup: 'managed-aca-rg',
172
160
  workloadProfiles: [
173
161
  {
174
162
  name: 'Consumption',
175
- workloadProfileType: 'Consumption'
176
- }
177
- ]
178
- }
163
+ workloadProfileType: 'Consumption',
164
+ },
165
+ ],
166
+ },
179
167
  },
180
168
  lifecycle: {
181
- ignoreChanges: [
182
- 'tags'
183
- ]
184
- }
169
+ ignoreChanges: ['tags'],
170
+ },
185
171
  });
186
172
  const storageAccessKey = new data_azapi_resource_action_1.DataAzapiResourceAction(this, 'storageAccessKeys', {
187
173
  type: 'Microsoft.Storage/storageAccounts@2023-01-01',
188
174
  action: 'listKeys',
189
175
  resourceId: storageAccount.id,
190
176
  responseExportValues: ['*'],
191
- dependsOn: [
192
- storageAccount
193
- ]
177
+ dependsOn: [storageAccount],
194
178
  });
195
179
  // see https://github.com/hashicorp/terraform-cdk/issues/1641
196
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
@@ -205,8 +189,8 @@ class Azure extends constructs_1.Construct {
205
189
  shareName: storageShare.name,
206
190
  dependsOn: [
207
191
  // Name doesn't create dependsOn requirement, so adding that explicitly
208
- storageShare
209
- ]
192
+ storageShare,
193
+ ],
210
194
  });
211
195
  const acaExternalStorage = new container_app_environment_storage_1.ContainerAppEnvironmentStorage(this, 'acaexternalstorage', {
212
196
  name: 'gharunnerexternalstorage',
@@ -217,8 +201,8 @@ class Azure extends constructs_1.Construct {
217
201
  shareName: externalsShare.name,
218
202
  dependsOn: [
219
203
  // Name doesn't create dependsOn requirement, so adding that explicitly
220
- externalsShare
221
- ]
204
+ externalsShare,
205
+ ],
222
206
  });
223
207
  const runnerVolumeName = 'work';
224
208
  const externalVolumeName = 'externals';
@@ -230,10 +214,8 @@ class Azure extends constructs_1.Construct {
230
214
  identity: [
231
215
  {
232
216
  type: 'UserAssigned',
233
- identityIds: [
234
- identity.id
235
- ]
236
- }
217
+ identityIds: [identity.id],
218
+ },
237
219
  ],
238
220
  name: 'gha-runner-job-01',
239
221
  parentId: rg.id,
@@ -250,8 +232,8 @@ class Azure extends constructs_1.Construct {
250
232
  registries: [
251
233
  {
252
234
  identity: identity.id,
253
- server: acr.loginServer
254
- }
235
+ server: acr.loginServer,
236
+ },
255
237
  ],
256
238
  },
257
239
  environmentId: environment.id,
@@ -265,7 +247,11 @@ class Azure extends constructs_1.Construct {
265
247
  // Have to use custom image as we want to run service as root to be able to install packages
266
248
  image: `${acr.loginServer}/root-actions-runner:latest`,
267
249
  name: 'main',
268
- command: ['/bin/sh', '-c', 'export EXECID=$(cat /proc/sys/kernel/random/uuid) && mkdir -p /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && /home/runner/run.sh ; rm -r /tmp/_work/$EXECID'],
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',
254
+ ],
269
255
  volumeMounts: [
270
256
  {
271
257
  mountPath: '/tmp/_work',
@@ -274,43 +260,43 @@ class Azure extends constructs_1.Construct {
274
260
  {
275
261
  mountPath: '/tmp/externals',
276
262
  volumeName: externalVolumeName,
277
- }
263
+ },
278
264
  ],
279
265
  env: [
280
266
  // https://github.com/microsoft/azure-container-apps/issues/502#issuecomment-1340225438
281
267
  {
282
268
  name: 'APPSETTING_WEBSITE_SITE_NAME',
283
- value: 'identity-workaround'
269
+ value: 'identity-workaround',
284
270
  },
285
271
  // https://github.com/microsoft/azure-container-apps/issues/442#issuecomment-1665621031
286
272
  {
287
273
  name: 'AZURE_CLIENT_ID',
288
- value: identity.clientId
274
+ value: identity.clientId,
289
275
  },
290
276
  {
291
277
  name: 'RG_NAME',
292
- value: rg.name
278
+ value: rg.name,
293
279
  },
294
280
  {
295
281
  name: 'LOG_ID',
296
- value: log.workspaceId
282
+ value: log.workspaceId,
297
283
  },
298
284
  {
299
285
  name: 'STORAGE_NAME',
300
- value: acaEnvStorage.name
286
+ value: acaEnvStorage.name,
301
287
  },
302
288
  {
303
289
  name: 'EXTERNAL_STORAGE_NAME',
304
- value: acaExternalStorage.name
290
+ value: acaExternalStorage.name,
305
291
  },
306
292
  {
307
293
  name: 'SUBSCRIPTION_ID',
308
- value: sub.subscriptionId
294
+ value: sub.subscriptionId,
309
295
  },
310
296
  {
311
297
  name: 'ACA_ENVIRONMENT_ID',
312
- value: environment.id
313
- }
298
+ value: environment.id,
299
+ },
314
300
  ],
315
301
  },
316
302
  ],
@@ -319,26 +305,22 @@ class Azure extends constructs_1.Construct {
319
305
  name: runnerVolumeName,
320
306
  storageName: acaEnvStorage.name,
321
307
  storageType: 'AzureFile',
322
- mountOptions: 'mfsymlinks'
308
+ mountOptions: 'mfsymlinks',
323
309
  },
324
310
  {
325
311
  name: externalVolumeName,
326
312
  storageName: acaExternalStorage.name,
327
313
  storageType: 'AzureFile',
328
- mountOptions: 'mfsymlinks'
329
- }
330
- ]
331
- }
332
- }
314
+ mountOptions: 'mfsymlinks',
315
+ },
316
+ ],
317
+ },
318
+ },
333
319
  },
334
- dependsOn: [
335
- runnerCache
336
- ],
320
+ dependsOn: [runnerCache],
337
321
  lifecycle: {
338
- ignoreChanges: [
339
- 'tags'
340
- ]
341
- }
322
+ ignoreChanges: ['tags'],
323
+ },
342
324
  });
343
325
  const autoscalerApp = new container_app_1.ContainerApp(this, 'autoscalerApp', {
344
326
  containerAppEnvironmentId: environment.id,
@@ -347,21 +329,19 @@ class Azure extends constructs_1.Construct {
347
329
  revisionMode: 'Single',
348
330
  identity: {
349
331
  type: 'SystemAssigned, UserAssigned',
350
- identityIds: [
351
- identity.id
352
- ]
332
+ identityIds: [identity.id],
353
333
  },
354
334
  secret: [
355
335
  {
356
336
  name: 'pat',
357
- value: pat.value
358
- }
337
+ value: pat.value,
338
+ },
359
339
  ],
360
340
  registry: [
361
341
  {
362
342
  identity: identity.id,
363
- server: acr.loginServer
364
- }
343
+ server: acr.loginServer,
344
+ },
365
345
  ],
366
346
  template: {
367
347
  container: [
@@ -378,7 +358,7 @@ class Azure extends constructs_1.Construct {
378
358
  },
379
359
  {
380
360
  name: 'GITHUB_CONFIG_URL',
381
- value: githubConfigUrl.value
361
+ value: githubConfigUrl.value,
382
362
  },
383
363
  {
384
364
  name: 'AZURE_TENANT_ID',
@@ -386,33 +366,28 @@ class Azure extends constructs_1.Construct {
386
366
  },
387
367
  {
388
368
  name: 'SUBSCRIPTION_ID',
389
- value: sub.subscriptionId
369
+ value: sub.subscriptionId,
390
370
  },
391
371
  {
392
372
  name: 'RESOURCE_GROUP_NAME',
393
- value: rg.name
373
+ value: rg.name,
394
374
  },
395
375
  {
396
376
  name: 'JOB_NAME',
397
- value: ghaRunnerJob.name
377
+ value: ghaRunnerJob.name,
398
378
  },
399
379
  {
400
380
  name: 'SCALE_SET_NAME',
401
- value: 'aca-runner-set'
381
+ value: 'aca-runner-set',
402
382
  },
403
- ]
404
- }
405
- ]
383
+ ],
384
+ },
385
+ ],
406
386
  },
407
- dependsOn: [
408
- autoscalerCache
409
- ],
387
+ dependsOn: [autoscalerCache],
410
388
  lifecycle: {
411
- ignoreChanges: [
412
- 'tags',
413
- 'workload_profile_name'
414
- ]
415
- }
389
+ ignoreChanges: ['tags', 'workload_profile_name'],
390
+ },
416
391
  });
417
392
  /**
418
393
  * @see https://github.com/microsoft/azure-container-apps/issues/1024
@@ -428,8 +403,8 @@ class Azure extends constructs_1.Construct {
428
403
  'microsoft.app/jobs/read',
429
404
  'microsoft.app/jobs/executions/read',
430
405
  ],
431
- }
432
- ]
406
+ },
407
+ ],
433
408
  });
434
409
  const jobCreationRole = new role_definition_1.RoleDefinition(this, 'jobCreationRole', {
435
410
  name: `gha-example-revision-create-role-${random.result}`,
@@ -443,36 +418,36 @@ class Azure extends constructs_1.Construct {
443
418
  'microsoft.app/jobs/write',
444
419
  'microsoft.app/jobs/executions/read',
445
420
  'microsoft.app/managedEnvironments/join/action',
446
- 'microsoft.app/jobs/delete' // cleanup for jobs
421
+ 'microsoft.app/jobs/delete', // cleanup for jobs
447
422
  ],
448
- }
449
- ]
423
+ },
424
+ ],
450
425
  });
451
426
  // Allow autoscaler to create new revision of app
452
427
  new role_assignment_1.RoleAssignment(this, 'scaleJobRoleAssignment', {
453
428
  principalId: autoscalerApp.identity.principalId,
454
429
  scope: ghaRunnerJob.id,
455
- roleDefinitionId: role.roleDefinitionResourceId
430
+ roleDefinitionId: role.roleDefinitionResourceId,
456
431
  });
457
432
  // Allow runner to start the job. As each one created new job, have to give to RG level.
458
433
  new role_assignment_1.RoleAssignment(this, 'actionContainerStartRoleAssignment', {
459
434
  principalId: identity.principalId,
460
435
  scope: rg.id,
461
- roleDefinitionId: jobCreationRole.roleDefinitionResourceId
436
+ roleDefinitionId: jobCreationRole.roleDefinitionResourceId,
462
437
  });
463
438
  new role_assignment_1.RoleAssignment(this, 'imagePushRoleAssignment', {
464
439
  principalId: identity.principalId,
465
440
  scope: acr.id,
466
- roleDefinitionName: 'AcrPush'
441
+ roleDefinitionName: 'AcrPush',
467
442
  });
468
443
  new role_assignment_1.RoleAssignment(this, 'jobLogReadAssignment', {
469
444
  principalId: identity.principalId,
470
445
  scope: log.id,
471
- roleDefinitionName: 'Log Analytics Reader'
446
+ roleDefinitionName: 'Log Analytics Reader',
472
447
  });
473
448
  }
474
449
  }
475
450
  exports.Azure = Azure;
476
451
  _a = JSII_RTTI_SYMBOL_1;
477
- Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.2" };
478
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azure.js","sourceRoot":"","sources":["../../src/lib/azure.ts"],"names":[],"mappings":"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","sourcesContent":["import { AzurermProvider } from \"@cdktf/provider-azurerm/lib/provider\";\nimport { AzapiProvider } from '../.gen/providers/azapi/provider'\nimport { Resource } from '../.gen/providers/azapi/resource'\nimport { DataAzapiResourceAction } from '../.gen/providers/azapi/data-azapi-resource-action'\nimport { Fn, TerraformVariable } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { ContainerRegistry } from \"@cdktf/provider-azurerm/lib/container-registry\";\nimport { UserAssignedIdentity } from \"@cdktf/provider-azurerm/lib/user-assigned-identity\";\nimport { RoleAssignment } from \"@cdktf/provider-azurerm/lib/role-assignment\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { RoleDefinition } from \"@cdktf/provider-azurerm/lib/role-definition\";\nimport { DataAzurermSubscription } from \"@cdktf/provider-azurerm/lib/data-azurerm-subscription\";\nimport { ContainerApp } from \"@cdktf/provider-azurerm/lib/container-app\";\nimport { commonVariables } from \"./variables\";\nimport { ContainerAppEnvironmentStorage } from \"@cdktf/provider-azurerm/lib/container-app-environment-storage\";\nimport { RandomProvider } from \"@cdktf/provider-random/lib/provider\";\nimport { StringResource } from \"@cdktf/provider-random/lib/string-resource\";\n\nexport class Azure extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n        \n        new AzurermProvider(this, 'azurerm', {\n            features: [\n                {}\n            ]\n        })\n\n        new AzapiProvider(this, 'azapi', {\n        })\n\n        new RandomProvider(this, 'random')\n\n        const sub = new DataAzurermSubscription(this, 'sub', {});\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const location = new TerraformVariable(this, 'location', {\n            default: 'westeurope',\n            description: 'Location where to provision resources to',\n            type: 'string',\n            sensitive: false,\n            nullable: false\n        }).value;\n\n        const rg = new ResourceGroup(this, 'rg', {\n            location,\n            name: 'gha-runner-rg',\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const random = new StringResource(this, 'randomSuffix', {\n            length: 6,\n            special: false,\n            upper: false,\n        })\n\n        const acr = new ContainerRegistry(this, 'acr', {\n            location,\n            name: `runneracr${random.result}`,\n            resourceGroupName: rg.name,\n            sku: 'Basic',\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        // use caching for images\n        const runnerCache = new Resource(this, 'runnerCache', {\n            type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',\n            parentId: acr.id,\n            name: 'root-runner-cache',\n            body: {\n                properties: {\n                    sourceRepository: 'ghcr.io/hi-fi/root-actions-runner',\n                    targetRepository: 'root-actions-runner'\n                }\n            }\n        })\n\n        const autoscalerCache = new Resource(this, 'autoscalerCache', {\n            type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',\n            parentId: acr.id,\n            name: 'autoscaler-cache',\n            body: {\n                properties: {\n                    sourceRepository: 'ghcr.io/hi-fi/gha-runners-on-managed-env',\n                    targetRepository: 'autoscaler'\n                }\n            }\n        })\n\n        const identity = new UserAssignedIdentity(this, 'identity', {\n            location,\n            name: 'aca-acr-access',\n            resourceGroupName: rg.name,\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        new RoleAssignment(this, 'roleAssignment', {\n            principalId: identity.principalId,\n            scope: acr.id,\n            roleDefinitionName: 'AcrPull'\n        });\n\n        const log = new LogAnalyticsWorkspace(this, 'log', {\n            location,\n            name: 'gha-example-logs',\n            resourceGroupName: rg.name,\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        })\n\n        const storageAccount = new Resource(this, 'storageAccount', {\n            type: 'Microsoft.Storage/storageAccounts@2023-01-01',\n            parentId: rg.id,\n            location,\n            name: `ghastorageaccount${random.result}`,\n            body: {\n                properties: {\n                    largeFileSharesState: 'Enabled'\n                },\n                sku: {\n                    name: 'Standard_LRS'\n                },\n                kind: 'StorageV2',\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            },\n            responseExportValues: [\n\n            ]\n        });\n\n        const storageShare = new Resource(this, 'storageShare', {\n            type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',\n            name: 'ghaexampleshare',\n            parentId: `${storageAccount.id}/fileServices/default`,\n            body: {\n                properties: {\n                    enabledProtocols: 'SMB',\n                }\n            },\n        });\n\n        const externalsShare = new Resource(this, 'externalsShare', {\n            type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',\n            name: 'ghaexternalsshare',\n            parentId: `${storageAccount.id}/fileServices/default`,\n            body: {\n                properties: {\n                    enabledProtocols: 'SMB',\n                }\n            },\n        });\n\n        const environment = new Resource(this, 'acaenv', {\n            type: 'Microsoft.App/managedEnvironments@2024-03-01',\n            parentId: rg.id,\n            location,\n            name: 'gha-runner-environment',\n            body: {\n                properties: {\n                    appLogsConfiguration: {\n                        destination: 'log-analytics',\n                        logAnalyticsConfiguration: {\n                            customerId: log.workspaceId,\n                            sharedKey: log.primarySharedKey,\n                        }\n                    },\n                    infrastructureResourceGroup: 'managed-aca-rg',\n                    workloadProfiles: [\n                        {\n                            name: 'Consumption',\n                            workloadProfileType: 'Consumption'\n                        }\n                    ]\n                }\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const storageAccessKey = new DataAzapiResourceAction(this, 'storageAccessKeys', {\n            type: 'Microsoft.Storage/storageAccounts@2023-01-01',\n            action: 'listKeys',\n            resourceId: storageAccount.id,\n            responseExportValues: ['*'],\n            dependsOn: [\n                storageAccount\n            ]\n        });\n\n        // see https://github.com/hashicorp/terraform-cdk/issues/1641\n        // For older Azapi way to get key would be this when (default) data output was json. Witn 2.0.0-beta default was changed to HCL\n        // const accessKey = Fn.lookup(Fn.element(Fn.lookup(Fn.jsondecode(storageAccessKey.output as any), 'keys'), 0), 'value')\n\n        const accessKey = Fn.lookup(Fn.element(Fn.element(storageAccessKey.output.lookup('0'), 0), 0), 'value')\n\n        const acaEnvStorage = new ContainerAppEnvironmentStorage(this, 'acaenvstorage', {\n            name: 'gharunnerjobstorage',\n            accessKey,\n            accessMode: 'ReadWrite',\n            accountName: storageAccount.name,\n            containerAppEnvironmentId: environment.id,\n            shareName: storageShare.name,\n            dependsOn: [\n                // Name doesn't create dependsOn requirement, so adding that explicitly\n                storageShare\n            ] \n        });\n\n        const acaExternalStorage = new ContainerAppEnvironmentStorage(this, 'acaexternalstorage', {\n            name: 'gharunnerexternalstorage',\n            accessKey,\n            accessMode: 'ReadWrite',\n            accountName: storageAccount.name,\n            containerAppEnvironmentId: environment.id,\n            shareName: externalsShare.name,\n            dependsOn: [\n                // Name doesn't create dependsOn requirement, so adding that explicitly\n                externalsShare\n            ] \n        });\n\n        const runnerVolumeName = 'work'\n        const externalVolumeName = 'externals'\n\n        /**\n         * @see https://learn.microsoft.com/en-us/azure/templates/microsoft.app/jobs?pivots=deployment-language-terraform\n         */\n        const ghaRunnerJob = new Resource(this, 'ghaRunnerJob', {\n            type: 'Microsoft.App/jobs@2024-02-02-preview',\n            identity: [\n                {\n                    type: 'UserAssigned',\n                    identityIds: [\n                        identity.id\n                    ]\n                }\n            ],\n            name: 'gha-runner-job-01',\n            parentId: rg.id,\n            location,\n            body: {\n                properties: {\n                    configuration: {\n                        manualTriggerConfig: {\n                            parallelism: 1,\n                            replicaCompletionCount: 1,\n                        },\n                        triggerType: 'Manual',\n                        replicaTimeout: 1200,\n                        registries: [\n                            {\n                                identity: identity.id,\n                                server: acr.loginServer\n                            }\n                        ],\n                    },\n                    environmentId: environment.id,\n                    template: {\n                        containers: [\n                            {\n                                resources: {\n                                    cpu: 1,\n                                    memory: '2Gi',\n                                },\n                                // Have to use custom image as we want to run service as root to be able to install packages\n                                image: `${acr.loginServer}/root-actions-runner:latest`,\n                                name: 'main',\n                                command: ['/bin/sh', '-c', 'export EXECID=$(cat /proc/sys/kernel/random/uuid) && mkdir -p /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && /home/runner/run.sh ; rm -r /tmp/_work/$EXECID'],\n                                volumeMounts: [\n                                    {\n                                        mountPath: '/tmp/_work',\n                                        volumeName: runnerVolumeName,\n                                    },\n                                    {\n                                        mountPath: '/tmp/externals',\n                                        volumeName: externalVolumeName,\n                                    }\n                                ],\n                                env: [\n                                    // https://github.com/microsoft/azure-container-apps/issues/502#issuecomment-1340225438\n                                    {\n                                        name: 'APPSETTING_WEBSITE_SITE_NAME',\n                                        value: 'identity-workaround'\n                                    },\n                                    // https://github.com/microsoft/azure-container-apps/issues/442#issuecomment-1665621031\n                                    {\n                                        name: 'AZURE_CLIENT_ID',\n                                        value: identity.clientId\n                                    },\n                                    {\n                                        name: 'RG_NAME',\n                                        value: rg.name\n                                    },\n                                    {\n                                        name: 'LOG_ID',\n                                        value: log.workspaceId\n                                    },\n                                    {\n                                        name: 'STORAGE_NAME',\n                                        value: acaEnvStorage.name\n                                    },\n                                    {\n                                        name: 'EXTERNAL_STORAGE_NAME',\n                                        value: acaExternalStorage.name\n                                    },\n                                    {\n                                        name: 'SUBSCRIPTION_ID',\n                                        value: sub.subscriptionId\n                                    },\n                                    {\n                                        name: 'ACA_ENVIRONMENT_ID',\n                                        value: environment.id\n                                    }\n                                ],\n                            },\n                        ],\n                        volumes: [\n                            {\n                                name: runnerVolumeName,\n                                storageName: acaEnvStorage.name,\n                                storageType: 'AzureFile',\n                                mountOptions: 'mfsymlinks'\n                            },\n                            {\n                                name: externalVolumeName,\n                                storageName: acaExternalStorage.name,\n                                storageType: 'AzureFile',\n                                mountOptions: 'mfsymlinks'\n                            }\n                        ]\n                    }\n                }\n            },\n            dependsOn: [\n                runnerCache\n            ],\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const autoscalerApp = new ContainerApp(this, 'autoscalerApp', {\n            containerAppEnvironmentId: environment.id,\n            name: 'autoscaler-app-01',\n            resourceGroupName: rg.name,\n            revisionMode: 'Single',\n            identity: {\n                type: 'SystemAssigned, UserAssigned',\n                identityIds: [\n                    identity.id\n                ]\n            },\n            secret: [\n                {\n                    name: 'pat',\n                    value: pat.value\n                }\n            ],\n            registry: [\n                {\n                    identity: identity.id,\n                    server: acr.loginServer\n                }\n            ],\n            template: {\n                container: [\n                    {\n                        // CPU and Memory can be lower with workload profile\n                        cpu: 0.25,\n                        memory: '0.5Gi',\n                        image: `${acr.loginServer}/autoscaler:test`,\n                        name: 'autoscaler',\n                        env: [\n                            {\n                                name: 'PAT',\n                                secretName: 'pat',\n                            },\n                            {\n                                name: 'GITHUB_CONFIG_URL',\n                                value: githubConfigUrl.value\n                            },\n                            {\n                                name: 'AZURE_TENANT_ID',\n                                value: sub.tenantId,\n                            },\n                            {\n                                name: 'SUBSCRIPTION_ID',\n                                value: sub.subscriptionId\n                            },\n                            {\n                                name: 'RESOURCE_GROUP_NAME',\n                                value: rg.name\n                            },\n                            {\n                                name: 'JOB_NAME',\n                                value: ghaRunnerJob.name\n                            },\n                            {\n                                name: 'SCALE_SET_NAME',\n                                value: 'aca-runner-set'\n                            },\n                        ]\n                    }\n                ]\n            },\n            dependsOn: [\n                autoscalerCache\n            ],\n            lifecycle: {\n                ignoreChanges: [\n                    'tags',\n                    'workload_profile_name'\n                ]\n            }\n        });\n\n        /**\n         * @see https://github.com/microsoft/azure-container-apps/issues/1024\n         */\n        const role = new RoleDefinition(this, 'jobRole', {\n            name: `gha-example-revision-start-role-${random.result}`,\n            scope: sub.id,\n            permissions: [\n                {\n                    actions: [\n                        'microsoft.app/jobs/start/action',\n                        'microsoft.app/jobs/stop/action',\n                        'microsoft.app/jobs/read',\n                        'microsoft.app/jobs/executions/read',\n                    ],\n                }\n            ]\n        })\n\n        const jobCreationRole = new RoleDefinition(this, 'jobCreationRole', {\n            name: `gha-example-revision-create-role-${random.result}`,\n            scope: sub.id,\n            permissions: [\n                {\n                    actions: [\n                        'microsoft.app/jobs/start/action',\n                        'microsoft.app/jobs/stop/action',\n                        'microsoft.app/jobs/read',\n                        'microsoft.app/jobs/write',\n                        'microsoft.app/jobs/executions/read',\n                        'microsoft.app/managedEnvironments/join/action',\n                        'microsoft.app/jobs/delete' // cleanup for jobs\n                    ],\n                }\n            ]\n        })\n\n        // Allow autoscaler to create new revision of app\n        new RoleAssignment(this, 'scaleJobRoleAssignment', {\n            principalId: autoscalerApp.identity.principalId,\n            scope: ghaRunnerJob.id,\n            roleDefinitionId: role.roleDefinitionResourceId\n        })\n\n        // Allow runner to start the job. As each one created new job, have to give to RG level.\n        new RoleAssignment(this, 'actionContainerStartRoleAssignment', {\n            principalId: identity.principalId,\n            scope: rg.id,\n            roleDefinitionId: jobCreationRole.roleDefinitionResourceId\n        })\n\n        new RoleAssignment(this, 'imagePushRoleAssignment', {\n            principalId: identity.principalId,\n            scope: acr.id,\n            roleDefinitionName: 'AcrPush'\n        });\n\n        new RoleAssignment(this, 'jobLogReadAssignment', {\n            principalId: identity.principalId,\n            scope: log.id,\n            roleDefinitionName: 'Log Analytics Reader'\n        })\n    }\n}"]}
452
+ Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.4" };
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"]}