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/.jsii +19 -2
- package/biome.jsonc +25 -52
- package/lib/index.d.ts +3 -3
- package/lib/index.js +1 -1
- package/lib/lib/aws.d.ts +4 -4
- package/lib/lib/aws.js +145 -145
- package/lib/lib/azure.d.ts +1 -1
- package/lib/lib/azure.js +132 -132
- package/lib/lib/gcp.d.ts +1 -1
- package/lib/lib/gcp.js +82 -82
- package/lib/lib/variables.d.ts +2 -2
- package/lib/lib/variables.js +11 -11
- package/lib/tfModules.js +17 -17
- package/modules/azure-container-apps/README.md +17 -17
- package/modules/azure-container-apps/cdk.tf.json +1 -1
- package/modules/google-cloud-run/README.md +16 -16
- package/modules/google-cloud-run/cdk.tf.json +1 -1
- package/package.json +11 -9
- package/renovate.json5 +2 -2
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,
|
|
27
|
+
new provider_1.AzurermProvider(this, "azurerm", {
|
|
28
28
|
features: [{}],
|
|
29
29
|
});
|
|
30
|
-
new provider_3.AzapiProvider(this,
|
|
31
|
-
new provider_2.RandomProvider(this,
|
|
32
|
-
const sub = new data_azurerm_subscription_1.DataAzurermSubscription(this,
|
|
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,
|
|
35
|
-
default:
|
|
36
|
-
description:
|
|
37
|
-
type:
|
|
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,
|
|
41
|
+
const rg = new resource_group_1.ResourceGroup(this, "rg", {
|
|
42
42
|
location,
|
|
43
|
-
name:
|
|
43
|
+
name: "gha-runner-rg",
|
|
44
44
|
lifecycle: {
|
|
45
|
-
ignoreChanges: [
|
|
45
|
+
ignoreChanges: ["tags"],
|
|
46
46
|
},
|
|
47
47
|
});
|
|
48
|
-
const random = new string_resource_1.StringResource(this,
|
|
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,
|
|
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:
|
|
57
|
+
sku: "Basic",
|
|
58
58
|
lifecycle: {
|
|
59
|
-
ignoreChanges: [
|
|
59
|
+
ignoreChanges: ["tags"],
|
|
60
60
|
},
|
|
61
61
|
});
|
|
62
62
|
// use caching for images
|
|
63
|
-
const runnerCache = new resource_1.Resource(this,
|
|
64
|
-
type:
|
|
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:
|
|
66
|
+
name: "root-runner-cache",
|
|
67
67
|
body: {
|
|
68
68
|
properties: {
|
|
69
|
-
sourceRepository:
|
|
70
|
-
targetRepository:
|
|
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,
|
|
75
|
-
type:
|
|
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:
|
|
77
|
+
name: "autoscaler-cache",
|
|
78
78
|
body: {
|
|
79
79
|
properties: {
|
|
80
|
-
sourceRepository:
|
|
81
|
-
targetRepository:
|
|
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,
|
|
85
|
+
const identity = new user_assigned_identity_1.UserAssignedIdentity(this, "identity", {
|
|
86
86
|
location,
|
|
87
|
-
name:
|
|
87
|
+
name: "aca-acr-access",
|
|
88
88
|
resourceGroupName: rg.name,
|
|
89
89
|
lifecycle: {
|
|
90
|
-
ignoreChanges: [
|
|
90
|
+
ignoreChanges: ["tags"],
|
|
91
91
|
},
|
|
92
92
|
});
|
|
93
|
-
new role_assignment_1.RoleAssignment(this,
|
|
93
|
+
new role_assignment_1.RoleAssignment(this, "roleAssignment", {
|
|
94
94
|
principalId: identity.principalId,
|
|
95
95
|
scope: acr.id,
|
|
96
|
-
roleDefinitionName:
|
|
96
|
+
roleDefinitionName: "AcrPull",
|
|
97
97
|
});
|
|
98
|
-
const log = new log_analytics_workspace_1.LogAnalyticsWorkspace(this,
|
|
98
|
+
const log = new log_analytics_workspace_1.LogAnalyticsWorkspace(this, "log", {
|
|
99
99
|
location,
|
|
100
|
-
name:
|
|
100
|
+
name: "gha-example-logs",
|
|
101
101
|
resourceGroupName: rg.name,
|
|
102
102
|
lifecycle: {
|
|
103
|
-
ignoreChanges: [
|
|
103
|
+
ignoreChanges: ["tags"],
|
|
104
104
|
},
|
|
105
105
|
});
|
|
106
|
-
const storageAccount = new resource_1.Resource(this,
|
|
107
|
-
type:
|
|
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:
|
|
113
|
+
largeFileSharesState: "Enabled",
|
|
114
114
|
},
|
|
115
115
|
sku: {
|
|
116
|
-
name:
|
|
116
|
+
name: "Standard_LRS",
|
|
117
117
|
},
|
|
118
|
-
kind:
|
|
118
|
+
kind: "StorageV2",
|
|
119
119
|
},
|
|
120
120
|
lifecycle: {
|
|
121
|
-
ignoreChanges: [
|
|
121
|
+
ignoreChanges: ["tags"],
|
|
122
122
|
},
|
|
123
123
|
responseExportValues: [],
|
|
124
124
|
});
|
|
125
|
-
const storageShare = new resource_1.Resource(this,
|
|
126
|
-
type:
|
|
127
|
-
name:
|
|
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:
|
|
131
|
+
enabledProtocols: "SMB",
|
|
132
132
|
},
|
|
133
133
|
},
|
|
134
134
|
});
|
|
135
|
-
const externalsShare = new resource_1.Resource(this,
|
|
136
|
-
type:
|
|
137
|
-
name:
|
|
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:
|
|
141
|
+
enabledProtocols: "SMB",
|
|
142
142
|
},
|
|
143
143
|
},
|
|
144
144
|
});
|
|
145
|
-
const environment = new resource_1.Resource(this,
|
|
146
|
-
type:
|
|
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:
|
|
149
|
+
name: "gha-runner-environment",
|
|
150
150
|
body: {
|
|
151
151
|
properties: {
|
|
152
152
|
appLogsConfiguration: {
|
|
153
|
-
destination:
|
|
153
|
+
destination: "log-analytics",
|
|
154
154
|
logAnalyticsConfiguration: {
|
|
155
155
|
customerId: log.workspaceId,
|
|
156
156
|
sharedKey: log.primarySharedKey,
|
|
157
157
|
},
|
|
158
158
|
},
|
|
159
|
-
infrastructureResourceGroup:
|
|
159
|
+
infrastructureResourceGroup: "managed-aca-rg",
|
|
160
160
|
workloadProfiles: [
|
|
161
161
|
{
|
|
162
|
-
name:
|
|
163
|
-
workloadProfileType:
|
|
162
|
+
name: "Consumption",
|
|
163
|
+
workloadProfileType: "Consumption",
|
|
164
164
|
},
|
|
165
165
|
],
|
|
166
166
|
},
|
|
167
167
|
},
|
|
168
168
|
lifecycle: {
|
|
169
|
-
ignoreChanges: [
|
|
169
|
+
ignoreChanges: ["tags"],
|
|
170
170
|
},
|
|
171
171
|
});
|
|
172
|
-
const storageAccessKey = new data_azapi_resource_action_1.DataAzapiResourceAction(this,
|
|
173
|
-
type:
|
|
174
|
-
action:
|
|
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(
|
|
183
|
-
const acaEnvStorage = new container_app_environment_storage_1.ContainerAppEnvironmentStorage(this,
|
|
184
|
-
name:
|
|
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:
|
|
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,
|
|
196
|
-
name:
|
|
195
|
+
const acaExternalStorage = new container_app_environment_storage_1.ContainerAppEnvironmentStorage(this, "acaexternalstorage", {
|
|
196
|
+
name: "gharunnerexternalstorage",
|
|
197
197
|
accessKey,
|
|
198
|
-
accessMode:
|
|
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 =
|
|
208
|
-
const externalVolumeName =
|
|
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,
|
|
213
|
-
type:
|
|
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:
|
|
216
|
+
type: "UserAssigned",
|
|
217
217
|
identityIds: [identity.id],
|
|
218
218
|
},
|
|
219
219
|
],
|
|
220
|
-
name:
|
|
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:
|
|
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:
|
|
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:
|
|
249
|
+
name: "main",
|
|
250
250
|
command: [
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
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:
|
|
257
|
+
mountPath: "/tmp/_work",
|
|
258
258
|
volumeName: runnerVolumeName,
|
|
259
259
|
},
|
|
260
260
|
{
|
|
261
|
-
mountPath:
|
|
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:
|
|
269
|
-
value:
|
|
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:
|
|
273
|
+
name: "AZURE_CLIENT_ID",
|
|
274
274
|
value: identity.clientId,
|
|
275
275
|
},
|
|
276
276
|
{
|
|
277
|
-
name:
|
|
277
|
+
name: "RG_NAME",
|
|
278
278
|
value: rg.name,
|
|
279
279
|
},
|
|
280
280
|
{
|
|
281
|
-
name:
|
|
281
|
+
name: "LOG_ID",
|
|
282
282
|
value: log.workspaceId,
|
|
283
283
|
},
|
|
284
284
|
{
|
|
285
|
-
name:
|
|
285
|
+
name: "STORAGE_NAME",
|
|
286
286
|
value: acaEnvStorage.name,
|
|
287
287
|
},
|
|
288
288
|
{
|
|
289
|
-
name:
|
|
289
|
+
name: "EXTERNAL_STORAGE_NAME",
|
|
290
290
|
value: acaExternalStorage.name,
|
|
291
291
|
},
|
|
292
292
|
{
|
|
293
|
-
name:
|
|
293
|
+
name: "SUBSCRIPTION_ID",
|
|
294
294
|
value: sub.subscriptionId,
|
|
295
295
|
},
|
|
296
296
|
{
|
|
297
|
-
name:
|
|
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:
|
|
308
|
-
mountOptions:
|
|
307
|
+
storageType: "AzureFile",
|
|
308
|
+
mountOptions: "mfsymlinks",
|
|
309
309
|
},
|
|
310
310
|
{
|
|
311
311
|
name: externalVolumeName,
|
|
312
312
|
storageName: acaExternalStorage.name,
|
|
313
|
-
storageType:
|
|
314
|
-
mountOptions:
|
|
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: [
|
|
322
|
+
ignoreChanges: ["tags"],
|
|
323
323
|
},
|
|
324
324
|
});
|
|
325
|
-
const autoscalerApp = new container_app_1.ContainerApp(this,
|
|
325
|
+
const autoscalerApp = new container_app_1.ContainerApp(this, "autoscalerApp", {
|
|
326
326
|
containerAppEnvironmentId: environment.id,
|
|
327
|
-
name:
|
|
327
|
+
name: "autoscaler-app-01",
|
|
328
328
|
resourceGroupName: rg.name,
|
|
329
|
-
revisionMode:
|
|
329
|
+
revisionMode: "Single",
|
|
330
330
|
identity: {
|
|
331
|
-
type:
|
|
331
|
+
type: "SystemAssigned, UserAssigned",
|
|
332
332
|
identityIds: [identity.id],
|
|
333
333
|
},
|
|
334
334
|
secret: [
|
|
335
335
|
{
|
|
336
|
-
name:
|
|
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:
|
|
351
|
+
memory: "0.5Gi",
|
|
352
352
|
image: `${acr.loginServer}/autoscaler:test`,
|
|
353
|
-
name:
|
|
353
|
+
name: "autoscaler",
|
|
354
354
|
env: [
|
|
355
355
|
{
|
|
356
|
-
name:
|
|
357
|
-
secretName:
|
|
356
|
+
name: "PAT",
|
|
357
|
+
secretName: "pat",
|
|
358
358
|
},
|
|
359
359
|
{
|
|
360
|
-
name:
|
|
360
|
+
name: "GITHUB_CONFIG_URL",
|
|
361
361
|
value: githubConfigUrl.value,
|
|
362
362
|
},
|
|
363
363
|
{
|
|
364
|
-
name:
|
|
364
|
+
name: "AZURE_TENANT_ID",
|
|
365
365
|
value: sub.tenantId,
|
|
366
366
|
},
|
|
367
367
|
{
|
|
368
|
-
name:
|
|
368
|
+
name: "SUBSCRIPTION_ID",
|
|
369
369
|
value: sub.subscriptionId,
|
|
370
370
|
},
|
|
371
371
|
{
|
|
372
|
-
name:
|
|
372
|
+
name: "RESOURCE_GROUP_NAME",
|
|
373
373
|
value: rg.name,
|
|
374
374
|
},
|
|
375
375
|
{
|
|
376
|
-
name:
|
|
376
|
+
name: "JOB_NAME",
|
|
377
377
|
value: ghaRunnerJob.name,
|
|
378
378
|
},
|
|
379
379
|
{
|
|
380
|
-
name:
|
|
381
|
-
value:
|
|
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: [
|
|
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,
|
|
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
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
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,
|
|
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
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
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,
|
|
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,
|
|
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,
|
|
438
|
+
new role_assignment_1.RoleAssignment(this, "imagePushRoleAssignment", {
|
|
439
439
|
principalId: identity.principalId,
|
|
440
440
|
scope: acr.id,
|
|
441
|
-
roleDefinitionName:
|
|
441
|
+
roleDefinitionName: "AcrPush",
|
|
442
442
|
});
|
|
443
|
-
new role_assignment_1.RoleAssignment(this,
|
|
443
|
+
new role_assignment_1.RoleAssignment(this, "jobLogReadAssignment", {
|
|
444
444
|
principalId: identity.principalId,
|
|
445
445
|
scope: log.id,
|
|
446
|
-
roleDefinitionName:
|
|
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.
|
|
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"]}
|