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/.jsii +138 -5
- package/API.md +74 -1
- package/biome.jsonc +66 -0
- package/lib/lib/aws.d.ts +16 -1
- package/lib/lib/aws.js +275 -280
- package/lib/lib/azure.d.ts +1 -1
- package/lib/lib/azure.js +105 -130
- package/lib/lib/gcp.d.ts +1 -1
- package/lib/lib/gcp.js +46 -48
- package/lib/lib/variables.d.ts +3 -2
- package/lib/lib/variables.js +11 -5
- package/lib/tfModules.js +40 -10
- package/modules/azure-container-apps/README.md +19 -18
- package/modules/azure-container-apps/cdk.tf.json +11 -7
- package/modules/elastic-container-service/README.md +25 -24
- package/modules/elastic-container-service/cdk.tf.json +64 -74
- package/modules/google-cloud-run/README.md +18 -17
- package/modules/google-cloud-run/cdk.tf.json +10 -6
- package/package.json +17 -70
- package/renovate.json5 +42 -0
- package/vitest.config.ts +28 -0
- package/lib/__tests__/index-test.d.ts +0 -1
- package/lib/__tests__/index-test.js +0 -26
- package/main.tf +0 -26
- package/scripts/collect-variables.ts +0 -188
- package/variables.tf +0 -27
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
|
|
19
|
-
const
|
|
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
|
|
33
|
-
new
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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: [
|
|
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
|
-
|
|
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
|
-
|
|
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.
|
|
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"]}
|