@cloudsnorkel/cdk-github-runners 0.14.19 → 0.14.21

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.
Files changed (58) hide show
  1. package/.jsii +125 -100
  2. package/API.md +73 -24
  3. package/README.md +3 -2
  4. package/assets/delete-failed-runner.lambda/index.js +3248 -11227
  5. package/assets/idle-runner-repear.lambda/index.js +3224 -11221
  6. package/assets/image-builders/aws-image-builder/delete-resources.lambda/index.js +12 -2
  7. package/assets/image-builders/aws-image-builder/filter-failed-builds.lambda/index.js +4 -1
  8. package/assets/image-builders/build-image.lambda/index.js +21 -4
  9. package/assets/providers/ami-root-device.lambda/index.js +45 -10
  10. package/assets/providers/update-lambda.lambda/index.js +6 -1
  11. package/assets/setup.lambda/index.js +1762 -4645
  12. package/assets/status.lambda/index.js +2412 -10615
  13. package/assets/token-retriever.lambda/index.js +3228 -11221
  14. package/assets/webhook-handler.lambda/index.js +3264 -11236
  15. package/assets/webhook-redelivery.lambda/index.js +3220 -11221
  16. package/lib/access.js +1 -1
  17. package/lib/delete-failed-runner.lambda.js +22 -4
  18. package/lib/idle-runner-repear.lambda.js +1 -1
  19. package/lib/image-builders/api.js +1 -1
  20. package/lib/image-builders/aws-image-builder/base-image.js +2 -2
  21. package/lib/image-builders/aws-image-builder/builder.js +3 -3
  22. package/lib/image-builders/aws-image-builder/delete-resources.lambda.js +6 -2
  23. package/lib/image-builders/aws-image-builder/deprecated/ami.js +1 -1
  24. package/lib/image-builders/aws-image-builder/deprecated/container.js +1 -1
  25. package/lib/image-builders/aws-image-builder/deprecated/linux-components.js +1 -1
  26. package/lib/image-builders/aws-image-builder/deprecated/windows-components.js +1 -1
  27. package/lib/image-builders/aws-image-builder/filter-failed-builds.lambda.js +5 -2
  28. package/lib/image-builders/build-image.lambda.js +15 -4
  29. package/lib/image-builders/codebuild-deprecated.js +1 -1
  30. package/lib/image-builders/codebuild.d.ts +10 -0
  31. package/lib/image-builders/codebuild.js +1 -1
  32. package/lib/image-builders/components.d.ts +12 -1
  33. package/lib/image-builders/components.js +48 -10
  34. package/lib/image-builders/static.js +1 -1
  35. package/lib/lambda-github.d.ts +14 -7
  36. package/lib/lambda-github.js +34 -8
  37. package/lib/lambda-helpers.js +8 -2
  38. package/lib/providers/ami-root-device.lambda.js +39 -10
  39. package/lib/providers/codebuild.d.ts +12 -0
  40. package/lib/providers/codebuild.js +3 -3
  41. package/lib/providers/common.js +3 -3
  42. package/lib/providers/composite.js +16 -31
  43. package/lib/providers/ec2.js +2 -2
  44. package/lib/providers/ecs.d.ts +3 -1
  45. package/lib/providers/ecs.js +2 -2
  46. package/lib/providers/fargate.d.ts +14 -0
  47. package/lib/providers/fargate.js +3 -3
  48. package/lib/providers/lambda.d.ts +2 -0
  49. package/lib/providers/lambda.js +3 -3
  50. package/lib/providers/update-lambda.lambda.js +7 -2
  51. package/lib/runner.js +1 -1
  52. package/lib/secrets.js +1 -1
  53. package/lib/setup.lambda.js +7 -4
  54. package/lib/status.lambda.js +17 -8
  55. package/lib/token-retriever.lambda.js +8 -2
  56. package/lib/webhook-handler.lambda.js +39 -12
  57. package/lib/webhook-redelivery.lambda.js +1 -1
  58. package/package.json +5 -5
@@ -1,5 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.loadOctokitRest = loadOctokitRest;
4
+ exports.loadOctokitCore = loadOctokitCore;
5
+ exports.loadOctokitAuthApp = loadOctokitAuthApp;
3
6
  exports.baseUrlFromDomain = baseUrlFromDomain;
4
7
  exports.getOctokit = getOctokit;
5
8
  exports.getAppOctokit = getAppOctokit;
@@ -7,9 +10,20 @@ exports.getRunner = getRunner;
7
10
  exports.deleteRunner = deleteRunner;
8
11
  exports.redeliver = redeliver;
9
12
  const crypto_1 = require("crypto");
10
- const auth_app_1 = require("@octokit/auth-app");
11
- const rest_1 = require("@octokit/rest");
12
13
  const lambda_helpers_1 = require("./lambda-helpers");
14
+ let restModulePromise;
15
+ let coreModulePromise;
16
+ let authAppModulePromise;
17
+ function loadOctokitRest() {
18
+ return (restModulePromise ?? (restModulePromise = Promise.resolve().then(() => require('@octokit/rest'))));
19
+ }
20
+ function loadOctokitCore() {
21
+ return (coreModulePromise ?? (coreModulePromise = Promise.resolve().then(() => require('@octokit/core'))));
22
+ }
23
+ function loadOctokitAuthApp() {
24
+ return (authAppModulePromise ?? (authAppModulePromise = Promise.resolve().then(() => require('@octokit/auth-app'))));
25
+ }
26
+ // ---- Other helpers ----
13
27
  function baseUrlFromDomain(domain) {
14
28
  if (domain == 'github.com') {
15
29
  return 'https://api.github.com';
@@ -21,6 +35,10 @@ async function getOctokit(installationId) {
21
35
  if (!process.env.GITHUB_SECRET_ARN || !process.env.GITHUB_PRIVATE_KEY_SECRET_ARN) {
22
36
  throw new Error('Missing environment variables');
23
37
  }
38
+ const [{ Octokit }, { createAppAuth }] = await Promise.all([
39
+ loadOctokitRest(),
40
+ loadOctokitAuthApp(),
41
+ ]);
24
42
  const githubSecrets = await (0, lambda_helpers_1.getSecretJsonValue)(process.env.GITHUB_SECRET_ARN);
25
43
  // Create cache key from installation ID and secrets (hash to avoid exposing sensitive data by accident)
26
44
  const cacheKey = (0, crypto_1.createHash)('sha256').update(`${installationId || 'no-install'}-${githubSecrets.domain}-${githubSecrets.appId}-${githubSecrets.personalAuthToken}`).digest('hex');
@@ -52,9 +70,9 @@ async function getOctokit(installationId) {
52
70
  }
53
71
  else {
54
72
  const privateKey = await (0, lambda_helpers_1.getSecretValue)(process.env.GITHUB_PRIVATE_KEY_SECRET_ARN);
55
- const appOctokit = new rest_1.Octokit({
73
+ const appOctokit = new Octokit({
56
74
  baseUrl,
57
- authStrategy: auth_app_1.createAppAuth,
75
+ authStrategy: createAppAuth,
58
76
  auth: {
59
77
  appId: githubSecrets.appId,
60
78
  privateKey: privateKey,
@@ -65,7 +83,7 @@ async function getOctokit(installationId) {
65
83
  installationId: installationId,
66
84
  })).token;
67
85
  }
68
- const octokit = new rest_1.Octokit({
86
+ const octokit = new Octokit({
69
87
  baseUrl,
70
88
  auth: token,
71
89
  });
@@ -82,15 +100,19 @@ async function getAppOctokit() {
82
100
  if (!process.env.GITHUB_SECRET_ARN || !process.env.GITHUB_PRIVATE_KEY_SECRET_ARN) {
83
101
  throw new Error('Missing environment variables');
84
102
  }
103
+ const [{ Octokit }, { createAppAuth }] = await Promise.all([
104
+ loadOctokitRest(),
105
+ loadOctokitAuthApp(),
106
+ ]);
85
107
  const githubSecrets = await (0, lambda_helpers_1.getSecretJsonValue)(process.env.GITHUB_SECRET_ARN);
86
108
  const baseUrl = baseUrlFromDomain(githubSecrets.domain);
87
109
  if (githubSecrets.personalAuthToken || !githubSecrets.appId) {
88
110
  return undefined;
89
111
  }
90
112
  const privateKey = await (0, lambda_helpers_1.getSecretValue)(process.env.GITHUB_PRIVATE_KEY_SECRET_ARN);
91
- return new rest_1.Octokit({
113
+ return new Octokit({
92
114
  baseUrl,
93
- authStrategy: auth_app_1.createAppAuth,
115
+ authStrategy: createAppAuth,
94
116
  auth: {
95
117
  appId: githubSecrets.appId,
96
118
  privateKey: privateKey,
@@ -103,6 +125,7 @@ async function getRunner(octokit, runnerLevel, owner, repo, name) {
103
125
  let runners;
104
126
  if ((runnerLevel ?? 'repo') === 'repo') {
105
127
  runners = await octokit.rest.actions.listSelfHostedRunnersForRepo({
128
+ name: name,
106
129
  page: page,
107
130
  owner: owner,
108
131
  repo: repo,
@@ -110,6 +133,7 @@ async function getRunner(octokit, runnerLevel, owner, repo, name) {
110
133
  }
111
134
  else {
112
135
  runners = await octokit.rest.actions.listSelfHostedRunnersForOrg({
136
+ name: name,
113
137
  page: page,
114
138
  org: owner,
115
139
  });
@@ -118,6 +142,8 @@ async function getRunner(octokit, runnerLevel, owner, repo, name) {
118
142
  return;
119
143
  }
120
144
  for (const runner of runners.data.runners) {
145
+ // we filter by name in the API call, but still double-check here
146
+ // this is for backward compatibility with old GHES instances that may not support the name filter
121
147
  if (runner.name == name) {
122
148
  return runner;
123
149
  }
@@ -152,4 +178,4 @@ async function redeliver(octokit, deliveryId) {
152
178
  deliveryId,
153
179
  });
154
180
  }
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-github.js","sourceRoot":"","sources":["../src/lambda-github.ts"],"names":[],"mappings":"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","sourcesContent":["import { createHash } from 'crypto';\nimport { createAppAuth } from '@octokit/auth-app';\nimport { Octokit } from '@octokit/rest';\nimport { getSecretJsonValue, getSecretValue } from './lambda-helpers';\n\nexport function baseUrlFromDomain(domain: string): string {\n  if (domain == 'github.com') {\n    return 'https://api.github.com';\n  }\n  return `https://${domain}/api/v3`;\n}\n\ntype RunnerLevel = 'repo' | 'org' | undefined; // undefined is for backwards compatibility and should be treated as 'repo'\n\nexport interface GitHubSecrets {\n  domain: string;\n  appId: number;\n  personalAuthToken: string;\n  runnerLevel: RunnerLevel;\n}\n\nconst octokitCache = new Map<string, Octokit>();\n\nexport async function getOctokit(installationId?: number): Promise<{ octokit: Octokit; githubSecrets: GitHubSecrets }> {\n  if (!process.env.GITHUB_SECRET_ARN || !process.env.GITHUB_PRIVATE_KEY_SECRET_ARN) {\n    throw new Error('Missing environment variables');\n  }\n\n  const githubSecrets: GitHubSecrets = await getSecretJsonValue(process.env.GITHUB_SECRET_ARN);\n\n  // Create cache key from installation ID and secrets (hash to avoid exposing sensitive data by accident)\n  const cacheKey = createHash('sha256').update(`${installationId || 'no-install'}-${githubSecrets.domain}-${githubSecrets.appId}-${githubSecrets.personalAuthToken}`).digest('hex');\n\n  const cached = octokitCache.get(cacheKey);\n  if (cached) {\n    try {\n      // Test if the cached octokit is still valid\n      await cached.rest.meta.getOctocat();\n      console.log({\n        notice: 'Using cached octokit',\n      });\n      return {\n        octokit: cached,\n        githubSecrets,\n      };\n    } catch (e) {\n      console.log({\n        notice: 'Octokit cache is invalid',\n        error: e,\n      });\n      octokitCache.delete(cacheKey);\n    }\n  }\n\n  const baseUrl = baseUrlFromDomain(githubSecrets.domain);\n\n  let token;\n  if (githubSecrets.personalAuthToken) {\n    token = githubSecrets.personalAuthToken;\n  } else {\n    const privateKey = await getSecretValue(process.env.GITHUB_PRIVATE_KEY_SECRET_ARN);\n\n    const appOctokit = new Octokit({\n      baseUrl,\n      authStrategy: createAppAuth,\n      auth: {\n        appId: githubSecrets.appId,\n        privateKey: privateKey,\n      },\n    });\n\n    token = (await appOctokit.auth({\n      type: 'installation',\n      installationId: installationId,\n    }) as any).token;\n  }\n\n  const octokit = new Octokit({\n    baseUrl,\n    auth: token,\n  });\n\n  // Store in cache\n  octokitCache.set(cacheKey, octokit);\n\n  return {\n    octokit,\n    githubSecrets,\n  };\n}\n\n// This function is used to get the Octokit instance for the app itself, not for a specific installation.\n// With PAT authentication, it returns undefined.\nexport async function getAppOctokit() {\n  if (!process.env.GITHUB_SECRET_ARN || !process.env.GITHUB_PRIVATE_KEY_SECRET_ARN) {\n    throw new Error('Missing environment variables');\n  }\n\n  const githubSecrets: GitHubSecrets = await getSecretJsonValue(process.env.GITHUB_SECRET_ARN);\n  const baseUrl = baseUrlFromDomain(githubSecrets.domain);\n\n  if (githubSecrets.personalAuthToken || !githubSecrets.appId) {\n    return undefined;\n  }\n\n  const privateKey = await getSecretValue(process.env.GITHUB_PRIVATE_KEY_SECRET_ARN);\n\n  return new Octokit({\n    baseUrl,\n    authStrategy: createAppAuth,\n    auth: {\n      appId: githubSecrets.appId,\n      privateKey: privateKey,\n    },\n  });\n}\n\nexport async function getRunner(octokit: Octokit, runnerLevel: RunnerLevel, owner: string, repo: string, name: string) {\n  let page = 1;\n  while (true) {\n    let runners;\n\n    if ((runnerLevel ?? 'repo') === 'repo') {\n      runners = await octokit.rest.actions.listSelfHostedRunnersForRepo({\n        page: page,\n        owner: owner,\n        repo: repo,\n      });\n    } else {\n      runners = await octokit.rest.actions.listSelfHostedRunnersForOrg({\n        page: page,\n        org: owner,\n      });\n    }\n\n    if (runners.data.runners.length == 0) {\n      return;\n    }\n\n    for (const runner of runners.data.runners) {\n      if (runner.name == name) {\n        return runner;\n      }\n    }\n\n    page++;\n  }\n}\n\nexport async function deleteRunner(octokit: Octokit, runnerLevel: RunnerLevel, owner: string, repo: string, runnerId: number) {\n  if ((runnerLevel ?? 'repo') === 'repo') {\n    await octokit.rest.actions.deleteSelfHostedRunnerFromRepo({\n      owner: owner,\n      repo: repo,\n      runner_id: runnerId,\n    });\n  } else {\n    await octokit.rest.actions.deleteSelfHostedRunnerFromOrg({\n      org: owner,\n      runner_id: runnerId,\n    });\n  }\n}\n\nexport async function redeliver(octokit: Octokit, deliveryId: number) {\n  const response = await octokit.rest.apps.redeliverWebhookDelivery({\n    delivery_id: deliveryId,\n  });\n\n  if (response.status !== 202) {\n    throw new Error(`Failed to redeliver webhook delivery with ID ${deliveryId}`);\n  }\n  console.log({\n    notice: 'Successfully redelivered webhook delivery',\n    deliveryId,\n  });\n}\n"]}
181
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-github.js","sourceRoot":"","sources":["../src/lambda-github.ts"],"names":[],"mappings":"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","sourcesContent":["import { createHash } from 'crypto';\nimport type { Octokit as RestOctokit } from '@octokit/rest';\nimport { getSecretJsonValue, getSecretValue } from './lambda-helpers';\n\n// ---- Octokit ESM loader helpers (inlined) ----\n// Octokit packages are ESM, but our Lambda assets are bundled into CJS.\n// Using dynamic `import()` here lets esbuild include Octokit in the bundle.\ntype OctokitRestModule = typeof import('@octokit/rest');\ntype OctokitCoreModule = typeof import('@octokit/core');\ntype OctokitAuthAppModule = typeof import('@octokit/auth-app');\n\nlet restModulePromise: Promise<OctokitRestModule> | undefined;\nlet coreModulePromise: Promise<OctokitCoreModule> | undefined;\nlet authAppModulePromise: Promise<OctokitAuthAppModule> | undefined;\n\nexport function loadOctokitRest(): Promise<OctokitRestModule> {\n  return (restModulePromise ??= import('@octokit/rest') as Promise<OctokitRestModule>);\n}\n\nexport function loadOctokitCore(): Promise<OctokitCoreModule> {\n  return (coreModulePromise ??= import('@octokit/core') as Promise<OctokitCoreModule>);\n}\n\nexport function loadOctokitAuthApp(): Promise<OctokitAuthAppModule> {\n  return (authAppModulePromise ??= import('@octokit/auth-app') as Promise<OctokitAuthAppModule>);\n}\n\n// ---- Other helpers ----\n\nexport function baseUrlFromDomain(domain: string): string {\n  if (domain == 'github.com') {\n    return 'https://api.github.com';\n  }\n  return `https://${domain}/api/v3`;\n}\n\ntype RunnerLevel = 'repo' | 'org' | undefined; // undefined is for backwards compatibility and should be treated as 'repo'\n\nexport interface GitHubSecrets {\n  domain: string;\n  appId: number;\n  personalAuthToken: string;\n  runnerLevel: RunnerLevel;\n}\n\nconst octokitCache = new Map<string, RestOctokit>();\n\nexport async function getOctokit(installationId?: number): Promise<{ octokit: RestOctokit; githubSecrets: GitHubSecrets }> {\n  if (!process.env.GITHUB_SECRET_ARN || !process.env.GITHUB_PRIVATE_KEY_SECRET_ARN) {\n    throw new Error('Missing environment variables');\n  }\n\n  const [{ Octokit }, { createAppAuth }] = await Promise.all([\n    loadOctokitRest(),\n    loadOctokitAuthApp(),\n  ]);\n\n  const githubSecrets: GitHubSecrets = await getSecretJsonValue(process.env.GITHUB_SECRET_ARN);\n\n  // Create cache key from installation ID and secrets (hash to avoid exposing sensitive data by accident)\n  const cacheKey = createHash('sha256').update(`${installationId || 'no-install'}-${githubSecrets.domain}-${githubSecrets.appId}-${githubSecrets.personalAuthToken}`).digest('hex');\n\n  const cached = octokitCache.get(cacheKey);\n  if (cached) {\n    try {\n      // Test if the cached octokit is still valid\n      await cached.rest.meta.getOctocat();\n      console.log({\n        notice: 'Using cached octokit',\n      });\n      return {\n        octokit: cached,\n        githubSecrets,\n      };\n    } catch (e) {\n      console.log({\n        notice: 'Octokit cache is invalid',\n        error: e,\n      });\n      octokitCache.delete(cacheKey);\n    }\n  }\n\n  const baseUrl = baseUrlFromDomain(githubSecrets.domain);\n\n  let token;\n  if (githubSecrets.personalAuthToken) {\n    token = githubSecrets.personalAuthToken;\n  } else {\n    const privateKey = await getSecretValue(process.env.GITHUB_PRIVATE_KEY_SECRET_ARN);\n\n    const appOctokit = new Octokit({\n      baseUrl,\n      authStrategy: createAppAuth,\n      auth: {\n        appId: githubSecrets.appId,\n        privateKey: privateKey,\n      },\n    });\n\n    token = (await appOctokit.auth({\n      type: 'installation',\n      installationId: installationId,\n    }) as any).token;\n  }\n\n  const octokit = new Octokit({\n    baseUrl,\n    auth: token,\n  });\n\n  // Store in cache\n  octokitCache.set(cacheKey, octokit);\n\n  return {\n    octokit,\n    githubSecrets,\n  };\n}\n\n// This function is used to get the Octokit instance for the app itself, not for a specific installation.\n// With PAT authentication, it returns undefined.\nexport async function getAppOctokit() {\n  if (!process.env.GITHUB_SECRET_ARN || !process.env.GITHUB_PRIVATE_KEY_SECRET_ARN) {\n    throw new Error('Missing environment variables');\n  }\n\n  const [{ Octokit }, { createAppAuth }] = await Promise.all([\n    loadOctokitRest(),\n    loadOctokitAuthApp(),\n  ]);\n\n  const githubSecrets: GitHubSecrets = await getSecretJsonValue(process.env.GITHUB_SECRET_ARN);\n  const baseUrl = baseUrlFromDomain(githubSecrets.domain);\n\n  if (githubSecrets.personalAuthToken || !githubSecrets.appId) {\n    return undefined;\n  }\n\n  const privateKey = await getSecretValue(process.env.GITHUB_PRIVATE_KEY_SECRET_ARN);\n\n  return new Octokit({\n    baseUrl,\n    authStrategy: createAppAuth,\n    auth: {\n      appId: githubSecrets.appId,\n      privateKey: privateKey,\n    },\n  });\n}\n\nexport async function getRunner(octokit: RestOctokit, runnerLevel: RunnerLevel, owner: string, repo: string, name: string) {\n  let page = 1;\n  while (true) {\n    let runners;\n\n    if ((runnerLevel ?? 'repo') === 'repo') {\n      runners = await octokit.rest.actions.listSelfHostedRunnersForRepo({\n        name: name,\n        page: page,\n        owner: owner,\n        repo: repo,\n      });\n    } else {\n      runners = await octokit.rest.actions.listSelfHostedRunnersForOrg({\n        name: name,\n        page: page,\n        org: owner,\n      });\n    }\n\n    if (runners.data.runners.length == 0) {\n      return;\n    }\n\n    for (const runner of runners.data.runners) {\n      // we filter by name in the API call, but still double-check here\n      // this is for backward compatibility with old GHES instances that may not support the name filter\n      if (runner.name == name) {\n        return runner;\n      }\n    }\n\n    page++;\n  }\n}\n\nexport async function deleteRunner(octokit: RestOctokit, runnerLevel: RunnerLevel, owner: string, repo: string, runnerId: number) {\n  if ((runnerLevel ?? 'repo') === 'repo') {\n    await octokit.rest.actions.deleteSelfHostedRunnerFromRepo({\n      owner: owner,\n      repo: repo,\n      runner_id: runnerId,\n    });\n  } else {\n    await octokit.rest.actions.deleteSelfHostedRunnerFromOrg({\n      org: owner,\n      runner_id: runnerId,\n    });\n  }\n}\n\nexport async function redeliver(octokit: RestOctokit, deliveryId: number) {\n  const response = await octokit.rest.apps.redeliverWebhookDelivery({\n    delivery_id: deliveryId,\n  });\n\n  if (response.status !== 202) {\n    throw new Error(`Failed to redeliver webhook delivery with ID ${deliveryId}`);\n  }\n  console.log({\n    notice: 'Successfully redelivered webhook delivery',\n    deliveryId,\n  });\n}\n"]}
@@ -36,7 +36,13 @@ async function customResourceRespond(event, responseStatus, reason, physicalReso
36
36
  NoEcho: false,
37
37
  Data: data,
38
38
  });
39
- console.log('Responding', responseBody);
39
+ console.log({
40
+ notice: 'Responding to CloudFormation custom resource',
41
+ status: responseStatus,
42
+ reason,
43
+ physicalResourceId,
44
+ responseBody,
45
+ });
40
46
  // eslint-disable-next-line @typescript-eslint/no-require-imports
41
47
  const parsedUrl = require('url').parse(event.ResponseURL);
42
48
  const requestOptions = {
@@ -61,4 +67,4 @@ async function customResourceRespond(event, responseStatus, reason, physicalReso
61
67
  }
62
68
  });
63
69
  }
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFtYmRhLWhlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvbGFtYmRhLWhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFnQkEsd0NBWUM7QUFFRCxnREFFQztBQUVELDhDQU1DO0FBRUQsc0RBc0NDO0FBaEZELDRFQUFtSDtBQWNuSCxNQUFNLEVBQUUsR0FBRyxJQUFJLDZDQUFvQixFQUFFLENBQUM7QUFFL0IsS0FBSyxVQUFVLGNBQWMsQ0FBQyxHQUF1QjtJQUMxRCxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDVCxNQUFNLElBQUksS0FBSyxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELE1BQU0sTUFBTSxHQUFHLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLDhDQUFxQixDQUFDLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUUzRSxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELE9BQU8sTUFBTSxDQUFDLFlBQVksQ0FBQztBQUM3QixDQUFDO0FBRU0sS0FBSyxVQUFVLGtCQUFrQixDQUFDLEdBQXVCO0lBQzlELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFFTSxLQUFLLFVBQVUsaUJBQWlCLENBQUMsR0FBdUIsRUFBRSxLQUFhO0lBQzVFLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNULE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksNENBQW1CLENBQUMsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDakYsQ0FBQztBQUVNLEtBQUssVUFBVSxxQkFBcUIsQ0FBQyxLQUFrRCxFQUFFLGNBQXNCLEVBQ3BILE1BQWMsRUFBRSxrQkFBMEIsRUFBRSxJQUFTO0lBQ3JELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDbEMsTUFBTSxFQUFFLGNBQWM7UUFDdEIsTUFBTSxFQUFFLE1BQU07UUFDZCxrQkFBa0IsRUFBRSxrQkFBa0I7UUFDdEMsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO1FBQ3RCLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztRQUMxQixpQkFBaUIsRUFBRSxLQUFLLENBQUMsaUJBQWlCO1FBQzFDLE1BQU0sRUFBRSxLQUFLO1FBQ2IsSUFBSSxFQUFFLElBQUk7S0FDWCxDQUFDLENBQUM7SUFFSCxPQUFPLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxZQUFZLENBQUMsQ0FBQztJQUV4QyxpRUFBaUU7SUFDakUsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDMUQsTUFBTSxjQUFjLEdBQUc7UUFDckIsUUFBUSxFQUFFLFNBQVMsQ0FBQyxRQUFRO1FBQzVCLElBQUksRUFBRSxTQUFTLENBQUMsSUFBSTtRQUNwQixNQUFNLEVBQUUsS0FBSztRQUNiLE9BQU8sRUFBRTtZQUNQLGNBQWMsRUFBRSxFQUFFO1lBQ2xCLGdCQUFnQixFQUFFLFlBQVksQ0FBQyxNQUFNO1NBQ3RDO0tBQ0YsQ0FBQztJQUVGLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7UUFDckMsSUFBSSxDQUFDO1lBQ0gsaUVBQWlFO1lBQ2pFLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQ2xFLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQzVCLE9BQU8sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDNUIsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLENBQUM7UUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ1gsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ1osQ0FBQztJQUNILENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdldFNlY3JldFZhbHVlQ29tbWFuZCwgU2VjcmV0c01hbmFnZXJDbGllbnQsIFVwZGF0ZVNlY3JldENvbW1hbmQgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtc2VjcmV0cy1tYW5hZ2VyJztcblxuZXhwb3J0IGludGVyZmFjZSBTdGVwRnVuY3Rpb25MYW1iZGFJbnB1dCB7XG4gIHJlYWRvbmx5IG93bmVyOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHJlcG86IHN0cmluZztcbiAgcmVhZG9ubHkgcnVubmVyTmFtZTogc3RyaW5nO1xuICByZWFkb25seSBpbnN0YWxsYXRpb25JZD86IG51bWJlcjtcbiAgcmVhZG9ubHkgbGFiZWxzOiBzdHJpbmdbXTtcbiAgcmVhZG9ubHkgZXJyb3I/OiB7XG4gICAgcmVhZG9ubHkgRXJyb3I6IHN0cmluZztcbiAgICByZWFkb25seSBDYXVzZTogc3RyaW5nO1xuICB9O1xufVxuXG5jb25zdCBzbSA9IG5ldyBTZWNyZXRzTWFuYWdlckNsaWVudCgpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0U2VjcmV0VmFsdWUoYXJuOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgaWYgKCFhcm4pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01pc3Npbmcgc2VjcmV0IEFSTicpO1xuICB9XG5cbiAgY29uc3Qgc2VjcmV0ID0gYXdhaXQgc20uc2VuZChuZXcgR2V0U2VjcmV0VmFsdWVDb21tYW5kKHsgU2VjcmV0SWQ6IGFybiB9KSk7XG5cbiAgaWYgKCFzZWNyZXQuU2VjcmV0U3RyaW5nKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBObyBTZWNyZXRTdHJpbmcgaW4gJHthcm59YCk7XG4gIH1cblxuICByZXR1cm4gc2VjcmV0LlNlY3JldFN0cmluZztcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldFNlY3JldEpzb25WYWx1ZShhcm46IHN0cmluZyB8IHVuZGVmaW5lZCkge1xuICByZXR1cm4gSlNPTi5wYXJzZShhd2FpdCBnZXRTZWNyZXRWYWx1ZShhcm4pKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHVwZGF0ZVNlY3JldFZhbHVlKGFybjogc3RyaW5nIHwgdW5kZWZpbmVkLCB2YWx1ZTogc3RyaW5nKSB7XG4gIGlmICghYXJuKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHNlY3JldCBBUk4nKTtcbiAgfVxuXG4gIGF3YWl0IHNtLnNlbmQobmV3IFVwZGF0ZVNlY3JldENvbW1hbmQoeyBTZWNyZXRJZDogYXJuLCBTZWNyZXRTdHJpbmc6IHZhbHVlIH0pKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGN1c3RvbVJlc291cmNlUmVzcG9uZChldmVudDogQVdTTGFtYmRhLkNsb3VkRm9ybWF0aW9uQ3VzdG9tUmVzb3VyY2VFdmVudCwgcmVzcG9uc2VTdGF0dXM6IHN0cmluZyxcbiAgcmVhc29uOiBzdHJpbmcsIHBoeXNpY2FsUmVzb3VyY2VJZDogc3RyaW5nLCBkYXRhOiBhbnkpIHtcbiAgY29uc3QgcmVzcG9uc2VCb2R5ID0gSlNPTi5zdHJpbmdpZnkoe1xuICAgIFN0YXR1czogcmVzcG9uc2VTdGF0dXMsXG4gICAgUmVhc29uOiByZWFzb24sXG4gICAgUGh5c2ljYWxSZXNvdXJjZUlkOiBwaHlzaWNhbFJlc291cmNlSWQsXG4gICAgU3RhY2tJZDogZXZlbnQuU3RhY2tJZCxcbiAgICBSZXF1ZXN0SWQ6IGV2ZW50LlJlcXVlc3RJZCxcbiAgICBMb2dpY2FsUmVzb3VyY2VJZDogZXZlbnQuTG9naWNhbFJlc291cmNlSWQsXG4gICAgTm9FY2hvOiBmYWxzZSxcbiAgICBEYXRhOiBkYXRhLFxuICB9KTtcblxuICBjb25zb2xlLmxvZygnUmVzcG9uZGluZycsIHJlc3BvbnNlQm9keSk7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1yZXF1aXJlLWltcG9ydHNcbiAgY29uc3QgcGFyc2VkVXJsID0gcmVxdWlyZSgndXJsJykucGFyc2UoZXZlbnQuUmVzcG9uc2VVUkwpO1xuICBjb25zdCByZXF1ZXN0T3B0aW9ucyA9IHtcbiAgICBob3N0bmFtZTogcGFyc2VkVXJsLmhvc3RuYW1lLFxuICAgIHBhdGg6IHBhcnNlZFVybC5wYXRoLFxuICAgIG1ldGhvZDogJ1BVVCcsXG4gICAgaGVhZGVyczoge1xuICAgICAgJ2NvbnRlbnQtdHlwZSc6ICcnLFxuICAgICAgJ2NvbnRlbnQtbGVuZ3RoJzogcmVzcG9uc2VCb2R5Lmxlbmd0aCxcbiAgICB9LFxuICB9O1xuXG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tcmVxdWlyZS1pbXBvcnRzXG4gICAgICBjb25zdCByZXF1ZXN0ID0gcmVxdWlyZSgnaHR0cHMnKS5yZXF1ZXN0KHJlcXVlc3RPcHRpb25zLCByZXNvbHZlKTtcbiAgICAgIHJlcXVlc3Qub24oJ2Vycm9yJywgcmVqZWN0KTtcbiAgICAgIHJlcXVlc3Qud3JpdGUocmVzcG9uc2VCb2R5KTtcbiAgICAgIHJlcXVlc3QuZW5kKCk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgcmVqZWN0KGUpO1xuICAgIH1cbiAgfSk7XG59XG4iXX0=
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFtYmRhLWhlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvbGFtYmRhLWhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFnQkEsd0NBWUM7QUFFRCxnREFFQztBQUVELDhDQU1DO0FBRUQsc0RBNENDO0FBdEZELDRFQUFtSDtBQWNuSCxNQUFNLEVBQUUsR0FBRyxJQUFJLDZDQUFvQixFQUFFLENBQUM7QUFFL0IsS0FBSyxVQUFVLGNBQWMsQ0FBQyxHQUF1QjtJQUMxRCxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDVCxNQUFNLElBQUksS0FBSyxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELE1BQU0sTUFBTSxHQUFHLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLDhDQUFxQixDQUFDLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUUzRSxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELE9BQU8sTUFBTSxDQUFDLFlBQVksQ0FBQztBQUM3QixDQUFDO0FBRU0sS0FBSyxVQUFVLGtCQUFrQixDQUFDLEdBQXVCO0lBQzlELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFFTSxLQUFLLFVBQVUsaUJBQWlCLENBQUMsR0FBdUIsRUFBRSxLQUFhO0lBQzVFLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNULE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksNENBQW1CLENBQUMsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDakYsQ0FBQztBQUVNLEtBQUssVUFBVSxxQkFBcUIsQ0FBQyxLQUFrRCxFQUFFLGNBQXNCLEVBQ3BILE1BQWMsRUFBRSxrQkFBMEIsRUFBRSxJQUFTO0lBQ3JELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDbEMsTUFBTSxFQUFFLGNBQWM7UUFDdEIsTUFBTSxFQUFFLE1BQU07UUFDZCxrQkFBa0IsRUFBRSxrQkFBa0I7UUFDdEMsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO1FBQ3RCLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztRQUMxQixpQkFBaUIsRUFBRSxLQUFLLENBQUMsaUJBQWlCO1FBQzFDLE1BQU0sRUFBRSxLQUFLO1FBQ2IsSUFBSSxFQUFFLElBQUk7S0FDWCxDQUFDLENBQUM7SUFFSCxPQUFPLENBQUMsR0FBRyxDQUFDO1FBQ1YsTUFBTSxFQUFFLDhDQUE4QztRQUN0RCxNQUFNLEVBQUUsY0FBYztRQUN0QixNQUFNO1FBQ04sa0JBQWtCO1FBQ2xCLFlBQVk7S0FDYixDQUFDLENBQUM7SUFFSCxpRUFBaUU7SUFDakUsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDMUQsTUFBTSxjQUFjLEdBQUc7UUFDckIsUUFBUSxFQUFFLFNBQVMsQ0FBQyxRQUFRO1FBQzVCLElBQUksRUFBRSxTQUFTLENBQUMsSUFBSTtRQUNwQixNQUFNLEVBQUUsS0FBSztRQUNiLE9BQU8sRUFBRTtZQUNQLGNBQWMsRUFBRSxFQUFFO1lBQ2xCLGdCQUFnQixFQUFFLFlBQVksQ0FBQyxNQUFNO1NBQ3RDO0tBQ0YsQ0FBQztJQUVGLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7UUFDckMsSUFBSSxDQUFDO1lBQ0gsaUVBQWlFO1lBQ2pFLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQ2xFLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQzVCLE9BQU8sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDNUIsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLENBQUM7UUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ1gsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ1osQ0FBQztJQUNILENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdldFNlY3JldFZhbHVlQ29tbWFuZCwgU2VjcmV0c01hbmFnZXJDbGllbnQsIFVwZGF0ZVNlY3JldENvbW1hbmQgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtc2VjcmV0cy1tYW5hZ2VyJztcblxuZXhwb3J0IGludGVyZmFjZSBTdGVwRnVuY3Rpb25MYW1iZGFJbnB1dCB7XG4gIHJlYWRvbmx5IG93bmVyOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHJlcG86IHN0cmluZztcbiAgcmVhZG9ubHkgcnVubmVyTmFtZTogc3RyaW5nO1xuICByZWFkb25seSBpbnN0YWxsYXRpb25JZD86IG51bWJlcjtcbiAgcmVhZG9ubHkgbGFiZWxzOiBzdHJpbmdbXTtcbiAgcmVhZG9ubHkgZXJyb3I/OiB7XG4gICAgcmVhZG9ubHkgRXJyb3I6IHN0cmluZztcbiAgICByZWFkb25seSBDYXVzZTogc3RyaW5nO1xuICB9O1xufVxuXG5jb25zdCBzbSA9IG5ldyBTZWNyZXRzTWFuYWdlckNsaWVudCgpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0U2VjcmV0VmFsdWUoYXJuOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgaWYgKCFhcm4pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01pc3Npbmcgc2VjcmV0IEFSTicpO1xuICB9XG5cbiAgY29uc3Qgc2VjcmV0ID0gYXdhaXQgc20uc2VuZChuZXcgR2V0U2VjcmV0VmFsdWVDb21tYW5kKHsgU2VjcmV0SWQ6IGFybiB9KSk7XG5cbiAgaWYgKCFzZWNyZXQuU2VjcmV0U3RyaW5nKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBObyBTZWNyZXRTdHJpbmcgaW4gJHthcm59YCk7XG4gIH1cblxuICByZXR1cm4gc2VjcmV0LlNlY3JldFN0cmluZztcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldFNlY3JldEpzb25WYWx1ZShhcm46IHN0cmluZyB8IHVuZGVmaW5lZCkge1xuICByZXR1cm4gSlNPTi5wYXJzZShhd2FpdCBnZXRTZWNyZXRWYWx1ZShhcm4pKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHVwZGF0ZVNlY3JldFZhbHVlKGFybjogc3RyaW5nIHwgdW5kZWZpbmVkLCB2YWx1ZTogc3RyaW5nKSB7XG4gIGlmICghYXJuKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHNlY3JldCBBUk4nKTtcbiAgfVxuXG4gIGF3YWl0IHNtLnNlbmQobmV3IFVwZGF0ZVNlY3JldENvbW1hbmQoeyBTZWNyZXRJZDogYXJuLCBTZWNyZXRTdHJpbmc6IHZhbHVlIH0pKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGN1c3RvbVJlc291cmNlUmVzcG9uZChldmVudDogQVdTTGFtYmRhLkNsb3VkRm9ybWF0aW9uQ3VzdG9tUmVzb3VyY2VFdmVudCwgcmVzcG9uc2VTdGF0dXM6IHN0cmluZyxcbiAgcmVhc29uOiBzdHJpbmcsIHBoeXNpY2FsUmVzb3VyY2VJZDogc3RyaW5nLCBkYXRhOiBhbnkpIHtcbiAgY29uc3QgcmVzcG9uc2VCb2R5ID0gSlNPTi5zdHJpbmdpZnkoe1xuICAgIFN0YXR1czogcmVzcG9uc2VTdGF0dXMsXG4gICAgUmVhc29uOiByZWFzb24sXG4gICAgUGh5c2ljYWxSZXNvdXJjZUlkOiBwaHlzaWNhbFJlc291cmNlSWQsXG4gICAgU3RhY2tJZDogZXZlbnQuU3RhY2tJZCxcbiAgICBSZXF1ZXN0SWQ6IGV2ZW50LlJlcXVlc3RJZCxcbiAgICBMb2dpY2FsUmVzb3VyY2VJZDogZXZlbnQuTG9naWNhbFJlc291cmNlSWQsXG4gICAgTm9FY2hvOiBmYWxzZSxcbiAgICBEYXRhOiBkYXRhLFxuICB9KTtcblxuICBjb25zb2xlLmxvZyh7XG4gICAgbm90aWNlOiAnUmVzcG9uZGluZyB0byBDbG91ZEZvcm1hdGlvbiBjdXN0b20gcmVzb3VyY2UnLFxuICAgIHN0YXR1czogcmVzcG9uc2VTdGF0dXMsXG4gICAgcmVhc29uLFxuICAgIHBoeXNpY2FsUmVzb3VyY2VJZCxcbiAgICByZXNwb25zZUJvZHksXG4gIH0pO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tcmVxdWlyZS1pbXBvcnRzXG4gIGNvbnN0IHBhcnNlZFVybCA9IHJlcXVpcmUoJ3VybCcpLnBhcnNlKGV2ZW50LlJlc3BvbnNlVVJMKTtcbiAgY29uc3QgcmVxdWVzdE9wdGlvbnMgPSB7XG4gICAgaG9zdG5hbWU6IHBhcnNlZFVybC5ob3N0bmFtZSxcbiAgICBwYXRoOiBwYXJzZWRVcmwucGF0aCxcbiAgICBtZXRob2Q6ICdQVVQnLFxuICAgIGhlYWRlcnM6IHtcbiAgICAgICdjb250ZW50LXR5cGUnOiAnJyxcbiAgICAgICdjb250ZW50LWxlbmd0aCc6IHJlc3BvbnNlQm9keS5sZW5ndGgsXG4gICAgfSxcbiAgfTtcblxuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHRyeSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXJlcXVpcmUtaW1wb3J0c1xuICAgICAgY29uc3QgcmVxdWVzdCA9IHJlcXVpcmUoJ2h0dHBzJykucmVxdWVzdChyZXF1ZXN0T3B0aW9ucywgcmVzb2x2ZSk7XG4gICAgICByZXF1ZXN0Lm9uKCdlcnJvcicsIHJlamVjdCk7XG4gICAgICByZXF1ZXN0LndyaXRlKHJlc3BvbnNlQm9keSk7XG4gICAgICByZXF1ZXN0LmVuZCgpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHJlamVjdChlKTtcbiAgICB9XG4gIH0pO1xufVxuIl19
@@ -19,25 +19,39 @@ async function handleAmi(event, ami) {
19
19
  await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} has no root device`, 'ERROR', {});
20
20
  return;
21
21
  }
22
- console.log(`Root device for ${ami} is ${rootDevice}`);
22
+ console.log({
23
+ notice: 'Resolved AMI root device',
24
+ ami,
25
+ rootDevice,
26
+ });
23
27
  await (0, lambda_helpers_1.customResourceRespond)(event, 'SUCCESS', 'OK', rootDevice, {});
24
28
  return;
25
29
  }
26
30
  async function handler(event, context) {
27
31
  try {
28
- console.log({ ...event, ResponseURL: '...' });
32
+ console.log({
33
+ notice: 'CloudFormation custom resource request',
34
+ ...event,
35
+ ResponseURL: '...',
36
+ });
29
37
  const ami = event.ResourceProperties.Ami;
30
38
  switch (event.RequestType) {
31
39
  case 'Create':
32
40
  case 'Update':
33
41
  if (ami.startsWith('ami-')) {
34
- console.log(`Checking AMI ${ami}`);
42
+ console.log({
43
+ notice: 'Checking AMI',
44
+ ami,
45
+ });
35
46
  await handleAmi(event, ami);
36
47
  break;
37
48
  }
38
49
  if (ami.startsWith('resolve:ssm:')) {
39
50
  const ssmParam = ami.substring('resolve:ssm:'.length);
40
- console.log(`Checking SSM ${ssmParam}`);
51
+ console.log({
52
+ notice: 'Checking SSM',
53
+ ssmParam,
54
+ });
41
55
  const ssmValue = (await ssm.send(new client_ssm_1.GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;
42
56
  if (!ssmValue) {
43
57
  await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} has no value`, 'ERROR', {});
@@ -48,7 +62,10 @@ async function handler(event, context) {
48
62
  }
49
63
  if (ami.startsWith('ssm:')) {
50
64
  const ssmParam = ami.substring('ssm:'.length);
51
- console.log(`Checking SSM ${ssmParam}`);
65
+ console.log({
66
+ notice: 'Checking SSM',
67
+ ssmParam,
68
+ });
52
69
  const ssmValue = (await ssm.send(new client_ssm_1.GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;
53
70
  if (!ssmValue) {
54
71
  await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} has no value`, 'ERROR', {});
@@ -58,7 +75,10 @@ async function handler(event, context) {
58
75
  break;
59
76
  }
60
77
  if (ami.startsWith('lt-')) {
61
- console.log(`Checking Launch Template ${ami}`);
78
+ console.log({
79
+ notice: 'Checking Launch Template',
80
+ launchTemplateId: ami,
81
+ });
62
82
  const lts = await ec2.send(new client_ec2_1.DescribeLaunchTemplateVersionsCommand({ LaunchTemplateId: ami, Versions: ['$Latest'] }));
63
83
  if (lts.LaunchTemplateVersions?.length !== 1) {
64
84
  await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});
@@ -72,7 +92,10 @@ async function handler(event, context) {
72
92
  break;
73
93
  }
74
94
  if (ami.match('^arn:aws[^:]*:imagebuilder:[^:]+:[^:]+:image/.*$')) {
75
- console.log(`Checking Image Builder ${ami}`);
95
+ console.log({
96
+ notice: 'Checking Image Builder',
97
+ imageBuildVersionArn: ami,
98
+ });
76
99
  const img = await ib.send(new client_imagebuilder_1.GetImageCommand({ imageBuildVersionArn: ami }));
77
100
  const actualAmi = img.image?.outputResources?.amis?.[0]?.image;
78
101
  if (!actualAmi) {
@@ -85,14 +108,20 @@ async function handler(event, context) {
85
108
  await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `Unknown type of AMI ${ami}`, 'ERROR', {});
86
109
  break;
87
110
  case 'Delete':
88
- console.log('Nothing to delete');
111
+ console.log({
112
+ notice: 'Nothing to delete',
113
+ ami,
114
+ });
89
115
  await (0, lambda_helpers_1.customResourceRespond)(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});
90
116
  break;
91
117
  }
92
118
  }
93
119
  catch (e) {
94
- console.error(e);
120
+ console.error({
121
+ notice: 'Failed to resolve AMI root device',
122
+ error: `${e}`,
123
+ });
95
124
  await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', e.message || 'Internal Error', context.logStreamName, {});
96
125
  }
97
126
  }
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami-root-device.lambda.js","sourceRoot":"","sources":["../../src/providers/ami-root-device.lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { DescribeImagesCommand, DescribeLaunchTemplateVersionsCommand, EC2Client } from '@aws-sdk/client-ec2';\nimport { GetImageCommand, ImagebuilderClient } from '@aws-sdk/client-imagebuilder';\nimport { GetParameterCommand, SSMClient } from '@aws-sdk/client-ssm';\nimport * as AWSLambda from 'aws-lambda';\nimport { customResourceRespond } from '../lambda-helpers';\n\nconst ssm = new SSMClient();\nconst ec2 = new EC2Client();\nconst ib = new ImagebuilderClient();\n\n\nasync function handleAmi(event: AWSLambda.CloudFormationCustomResourceEvent, ami: string) {\n  const imageDescs = (await ec2.send(new DescribeImagesCommand({ ImageIds: [ami] })));\n  if (imageDescs.Images?.length !== 1) {\n    await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n    return;\n  }\n\n  const rootDevice = imageDescs.Images[0].RootDeviceName;\n  if (!rootDevice) {\n    await customResourceRespond(event, 'FAILED', `${ami} has no root device`, 'ERROR', {});\n    return;\n  }\n\n  console.log(`Root device for ${ami} is ${rootDevice}`);\n\n  await customResourceRespond(event, 'SUCCESS', 'OK', rootDevice, {});\n  return;\n}\n\n\nexport async function handler(event: AWSLambda.CloudFormationCustomResourceEvent, context: AWSLambda.Context) {\n  try {\n    console.log({ ...event, ResponseURL: '...' });\n\n    const ami = event.ResourceProperties.Ami as string;\n\n    switch (event.RequestType) {\n      case 'Create':\n      case 'Update':\n        if (ami.startsWith('ami-')) {\n          console.log(`Checking AMI ${ami}`);\n\n          await handleAmi(event, ami);\n          break;\n        }\n\n        if (ami.startsWith('resolve:ssm:')) {\n          const ssmParam = ami.substring('resolve:ssm:'.length);\n          console.log(`Checking SSM ${ssmParam}`);\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('ssm:')) {\n          const ssmParam = ami.substring('ssm:'.length);\n          console.log(`Checking SSM ${ssmParam}`);\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('lt-')) {\n          console.log(`Checking Launch Template ${ami}`);\n\n          const lts = await ec2.send(new DescribeLaunchTemplateVersionsCommand({ LaunchTemplateId: ami, Versions: ['$Latest'] }));\n          if (lts.LaunchTemplateVersions?.length !== 1) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n            break;\n          }\n\n          if (!lts.LaunchTemplateVersions[0].LaunchTemplateData?.ImageId) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, lts.LaunchTemplateVersions[0].LaunchTemplateData.ImageId);\n          break;\n        }\n\n        if (ami.match('^arn:aws[^:]*:imagebuilder:[^:]+:[^:]+:image/.*$')) {\n          console.log(`Checking Image Builder ${ami}`);\n\n          const img = await ib.send(new GetImageCommand({ imageBuildVersionArn: ami }));\n          const actualAmi = img.image?.outputResources?.amis?.[0]?.image;\n          if (!actualAmi) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, actualAmi);\n          break;\n        }\n\n        await customResourceRespond(event, 'FAILED', `Unknown type of AMI ${ami}`, 'ERROR', {});\n        break;\n      case 'Delete':\n        console.log('Nothing to delete');\n        await customResourceRespond(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});\n        break;\n    }\n  } catch (e) {\n    console.error(e);\n    await customResourceRespond(event, 'FAILED', (e as Error).message || 'Internal Error', context.logStreamName, {});\n  }\n}\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami-root-device.lambda.js","sourceRoot":"","sources":["../../src/providers/ami-root-device.lambda.ts"],"names":[],"mappings":";;AAmCA,0BAgHC;AAnJD,oDAA8G;AAC9G,sEAAmF;AACnF,oDAAqE;AAErE,sDAA0D;AAE1D,MAAM,GAAG,GAAG,IAAI,sBAAS,EAAE,CAAC;AAC5B,MAAM,GAAG,GAAG,IAAI,sBAAS,EAAE,CAAC;AAC5B,MAAM,EAAE,GAAG,IAAI,wCAAkB,EAAE,CAAC;AAGpC,KAAK,UAAU,SAAS,CAAC,KAAkD,EAAE,GAAW;IACtF,MAAM,UAAU,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,kCAAqB,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACpF,IAAI,UAAU,CAAC,MAAM,EAAE,MAAM,KAAK,CAAC,EAAE,CAAC;QACpC,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,GAAG,gBAAgB,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;QAClF,OAAO;IACT,CAAC;IAED,MAAM,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC;IACvD,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,GAAG,qBAAqB,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;QACvF,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC;QACV,MAAM,EAAE,0BAA0B;QAClC,GAAG;QACH,UAAU;KACX,CAAC,CAAC;IAEH,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IACpE,OAAO;AACT,CAAC;AAGM,KAAK,UAAU,OAAO,CAAC,KAAkD,EAAE,OAA0B;IAC1G,IAAI,CAAC;QACH,OAAO,CAAC,GAAG,CAAC;YACV,MAAM,EAAE,wCAAwC;YAChD,GAAG,KAAK;YACR,WAAW,EAAE,KAAK;SACnB,CAAC,CAAC;QAEH,MAAM,GAAG,GAAG,KAAK,CAAC,kBAAkB,CAAC,GAAa,CAAC;QAEnD,QAAQ,KAAK,CAAC,WAAW,EAAE,CAAC;YAC1B,KAAK,QAAQ,CAAC;YACd,KAAK,QAAQ;gBACX,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC3B,OAAO,CAAC,GAAG,CAAC;wBACV,MAAM,EAAE,cAAc;wBACtB,GAAG;qBACJ,CAAC,CAAC;oBAEH,MAAM,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;oBAC5B,MAAM;gBACR,CAAC;gBAED,IAAI,GAAG,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC;oBACnC,MAAM,QAAQ,GAAG,GAAG,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;oBACtD,OAAO,CAAC,GAAG,CAAC;wBACV,MAAM,EAAE,cAAc;wBACtB,QAAQ;qBACT,CAAC,CAAC;oBAEH,MAAM,QAAQ,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,gCAAmB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC;oBAChG,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACd,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,GAAG,eAAe,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;wBACjF,MAAM;oBACR,CAAC;oBAED,MAAM,SAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;oBACjC,MAAM;gBACR,CAAC;gBAED,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC3B,MAAM,QAAQ,GAAG,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;oBAC9C,OAAO,CAAC,GAAG,CAAC;wBACV,MAAM,EAAE,cAAc;wBACtB,QAAQ;qBACT,CAAC,CAAC;oBAEH,MAAM,QAAQ,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,gCAAmB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC;oBAChG,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACd,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,GAAG,eAAe,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;wBACjF,MAAM;oBACR,CAAC;oBAED,MAAM,SAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;oBACjC,MAAM;gBACR,CAAC;gBAED,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC1B,OAAO,CAAC,GAAG,CAAC;wBACV,MAAM,EAAE,0BAA0B;wBAClC,gBAAgB,EAAE,GAAG;qBACtB,CAAC,CAAC;oBAEH,MAAM,GAAG,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,kDAAqC,CAAC,EAAE,gBAAgB,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;oBACxH,IAAI,GAAG,CAAC,sBAAsB,EAAE,MAAM,KAAK,CAAC,EAAE,CAAC;wBAC7C,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,GAAG,gBAAgB,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;wBAClF,MAAM;oBACR,CAAC;oBAED,IAAI,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,kBAAkB,EAAE,OAAO,EAAE,CAAC;wBAC/D,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,GAAG,sBAAsB,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;wBACxF,MAAM;oBACR,CAAC;oBAED,MAAM,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;oBACjF,MAAM;gBACR,CAAC;gBAED,IAAI,GAAG,CAAC,KAAK,CAAC,kDAAkD,CAAC,EAAE,CAAC;oBAClE,OAAO,CAAC,GAAG,CAAC;wBACV,MAAM,EAAE,wBAAwB;wBAChC,oBAAoB,EAAE,GAAG;qBAC1B,CAAC,CAAC;oBAEH,MAAM,GAAG,GAAG,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,qCAAe,CAAC,EAAE,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;oBAC9E,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC;oBAC/D,IAAI,CAAC,SAAS,EAAE,CAAC;wBACf,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,GAAG,sBAAsB,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;wBACxF,MAAM;oBACR,CAAC;oBAED,MAAM,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;oBAClC,MAAM;gBACR,CAAC;gBAED,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,uBAAuB,GAAG,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;gBACxF,MAAM;YACR,KAAK,QAAQ;gBACX,OAAO,CAAC,GAAG,CAAC;oBACV,MAAM,EAAE,mBAAmB;oBAC3B,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;gBAClF,MAAM;QACV,CAAC;IACH,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,CAAC,KAAK,CAAC;YACZ,MAAM,EAAE,mCAAmC;YAC3C,KAAK,EAAE,GAAG,CAAC,EAAE;SACd,CAAC,CAAC;QACH,MAAM,IAAA,sCAAqB,EAAC,KAAK,EAAE,QAAQ,EAAG,CAAW,CAAC,OAAO,IAAI,gBAAgB,EAAE,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;IACpH,CAAC;AACH,CAAC","sourcesContent":["import { DescribeImagesCommand, DescribeLaunchTemplateVersionsCommand, EC2Client } from '@aws-sdk/client-ec2';\nimport { GetImageCommand, ImagebuilderClient } from '@aws-sdk/client-imagebuilder';\nimport { GetParameterCommand, SSMClient } from '@aws-sdk/client-ssm';\nimport * as AWSLambda from 'aws-lambda';\nimport { customResourceRespond } from '../lambda-helpers';\n\nconst ssm = new SSMClient();\nconst ec2 = new EC2Client();\nconst ib = new ImagebuilderClient();\n\n\nasync function handleAmi(event: AWSLambda.CloudFormationCustomResourceEvent, ami: string) {\n  const imageDescs = (await ec2.send(new DescribeImagesCommand({ ImageIds: [ami] })));\n  if (imageDescs.Images?.length !== 1) {\n    await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n    return;\n  }\n\n  const rootDevice = imageDescs.Images[0].RootDeviceName;\n  if (!rootDevice) {\n    await customResourceRespond(event, 'FAILED', `${ami} has no root device`, 'ERROR', {});\n    return;\n  }\n\n  console.log({\n    notice: 'Resolved AMI root device',\n    ami,\n    rootDevice,\n  });\n\n  await customResourceRespond(event, 'SUCCESS', 'OK', rootDevice, {});\n  return;\n}\n\n\nexport async function handler(event: AWSLambda.CloudFormationCustomResourceEvent, context: AWSLambda.Context) {\n  try {\n    console.log({\n      notice: 'CloudFormation custom resource request',\n      ...event,\n      ResponseURL: '...',\n    });\n\n    const ami = event.ResourceProperties.Ami as string;\n\n    switch (event.RequestType) {\n      case 'Create':\n      case 'Update':\n        if (ami.startsWith('ami-')) {\n          console.log({\n            notice: 'Checking AMI',\n            ami,\n          });\n\n          await handleAmi(event, ami);\n          break;\n        }\n\n        if (ami.startsWith('resolve:ssm:')) {\n          const ssmParam = ami.substring('resolve:ssm:'.length);\n          console.log({\n            notice: 'Checking SSM',\n            ssmParam,\n          });\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('ssm:')) {\n          const ssmParam = ami.substring('ssm:'.length);\n          console.log({\n            notice: 'Checking SSM',\n            ssmParam,\n          });\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('lt-')) {\n          console.log({\n            notice: 'Checking Launch Template',\n            launchTemplateId: ami,\n          });\n\n          const lts = await ec2.send(new DescribeLaunchTemplateVersionsCommand({ LaunchTemplateId: ami, Versions: ['$Latest'] }));\n          if (lts.LaunchTemplateVersions?.length !== 1) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n            break;\n          }\n\n          if (!lts.LaunchTemplateVersions[0].LaunchTemplateData?.ImageId) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, lts.LaunchTemplateVersions[0].LaunchTemplateData.ImageId);\n          break;\n        }\n\n        if (ami.match('^arn:aws[^:]*:imagebuilder:[^:]+:[^:]+:image/.*$')) {\n          console.log({\n            notice: 'Checking Image Builder',\n            imageBuildVersionArn: ami,\n          });\n\n          const img = await ib.send(new GetImageCommand({ imageBuildVersionArn: ami }));\n          const actualAmi = img.image?.outputResources?.amis?.[0]?.image;\n          if (!actualAmi) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, actualAmi);\n          break;\n        }\n\n        await customResourceRespond(event, 'FAILED', `Unknown type of AMI ${ami}`, 'ERROR', {});\n        break;\n      case 'Delete':\n        console.log({\n          notice: 'Nothing to delete',\n          ami,\n        });\n        await customResourceRespond(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});\n        break;\n    }\n  } catch (e) {\n    console.error({\n      notice: 'Failed to resolve AMI root device',\n      error: `${e}`,\n    });\n    await customResourceRespond(event, 'FAILED', (e as Error).message || 'Internal Error', context.logStreamName, {});\n  }\n}\n"]}
@@ -73,6 +73,16 @@ export interface CodeBuildRunnerProviderProps extends RunnerProviderProps {
73
73
  * The type of compute to use for this build.
74
74
  * See the {@link ComputeType} enum for the possible values.
75
75
  *
76
+ * The compute type determines CPU, memory, and disk space:
77
+ * - SMALL: 2 vCPU, 3 GB RAM, 64 GB disk
78
+ * - MEDIUM: 4 vCPU, 7 GB RAM, 128 GB disk
79
+ * - LARGE: 8 vCPU, 15 GB RAM, 128 GB disk
80
+ * - X2_LARGE: 72 vCPU, 145 GB RAM, 256 GB disk (Linux) or 824 GB disk (Windows)
81
+ *
82
+ * Use a larger compute type when you need more disk space for building larger Docker images.
83
+ *
84
+ * For more details, see https://docs.aws.amazon.com/codebuild/latest/userguide/build-env-ref-compute-types.html#environment.types
85
+ *
76
86
  * @default {@link ComputeType#SMALL}
77
87
  */
78
88
  readonly computeType?: codebuild.ComputeType;
@@ -161,6 +171,8 @@ export declare class CodeBuildRunnerProvider extends BaseProvider implements IRu
161
171
  readonly grantPrincipal: iam.IPrincipal;
162
172
  /**
163
173
  * Docker image loaded with GitHub Actions Runner and its prerequisites. The image is built by an image builder and is specific to CodeBuild.
174
+ *
175
+ * @deprecated This field is internal and should not be accessed directly.
164
176
  */
165
177
  readonly image: RunnerImage;
166
178
  /**
@@ -265,7 +265,7 @@ class CodeBuildRunnerProvider extends common_1.BaseProvider {
265
265
  }
266
266
  exports.CodeBuildRunnerProvider = CodeBuildRunnerProvider;
267
267
  _a = JSII_RTTI_SYMBOL_1;
268
- CodeBuildRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunnerProvider", version: "0.14.19" };
268
+ CodeBuildRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunnerProvider", version: "0.14.21" };
269
269
  /**
270
270
  * Path to Dockerfile for Linux x64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
271
271
  *
@@ -301,5 +301,5 @@ class CodeBuildRunner extends CodeBuildRunnerProvider {
301
301
  }
302
302
  exports.CodeBuildRunner = CodeBuildRunner;
303
303
  _b = JSII_RTTI_SYMBOL_1;
304
- CodeBuildRunner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.14.19" };
305
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codebuild.js","sourceRoot":"","sources":["../../src/providers/codebuild.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Annotations,\n  aws_codebuild as codebuild,\n  aws_ec2 as ec2,\n  aws_iam as iam,\n  aws_logs as logs,\n  aws_stepfunctions as stepfunctions,\n  aws_stepfunctions_tasks as stepfunctions_tasks,\n  Duration,\n  RemovalPolicy,\n} from 'aws-cdk-lib';\nimport { ComputeType } from 'aws-cdk-lib/aws-codebuild';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { IntegrationPattern } from 'aws-cdk-lib/aws-stepfunctions';\nimport { Construct } from 'constructs';\nimport {\n  Architecture,\n  BaseProvider,\n  IRunnerProvider,\n  IRunnerProviderStatus,\n  Os,\n  RunnerImage,\n  RunnerProviderProps,\n  RunnerRuntimeParameters,\n  RunnerVersion,\n  generateStateName,\n} from './common';\nimport { IRunnerImageBuilder, RunnerImageBuilder, RunnerImageBuilderProps, RunnerImageComponent } from '../image-builders';\n\n\nexport interface CodeBuildRunnerProviderProps extends RunnerProviderProps {\n  /**\n   * Runner image builder used to build Docker images containing GitHub Runner and all requirements.\n   *\n   * The image builder must contain the {@link RunnerImageComponent.docker} component unless `dockerInDocker` is set to false.\n   *\n   * The image builder determines the OS and architecture of the runner.\n   *\n   * @default CodeBuildRunnerProvider.imageBuilder()\n   */\n  readonly imageBuilder?: IRunnerImageBuilder;\n\n  /**\n   * GitHub Actions label used for this provider.\n   *\n   * @default undefined\n   * @deprecated use {@link labels} instead\n   */\n  readonly label?: string;\n\n  /**\n   * GitHub Actions labels used for this provider.\n   *\n   * These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for\n   * based on runs-on. We match the labels from the webhook with the labels specified here. If all the labels specified here are present in the\n   * job's labels, this provider will be chosen and spawn a new runner.\n   *\n   * @default ['codebuild']\n   */\n  readonly labels?: string[];\n\n  /**\n   * GitHub Actions runner group name.\n   *\n   * If specified, the runner will be registered with this group name. Setting a runner group can help managing access to self-hosted runners. It\n   * requires a paid GitHub account.\n   *\n   * The group must exist or the runner will not start.\n   *\n   * Users will still be able to trigger this runner with the correct labels. But the runner will only be able to run jobs from repos allowed to use the group.\n   *\n   * @default undefined\n   */\n  readonly group?: string;\n\n  /**\n   * VPC to launch the runners in.\n   *\n   * @default no VPC\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group to assign to this instance.\n   *\n   * @default public project with no security group\n   *\n   * @deprecated use {@link securityGroups}\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Security groups to assign to this instance.\n   *\n   * @default a new security group, if {@link vpc} is used\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * @default no subnet\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * The type of compute to use for this build.\n   * See the {@link ComputeType} enum for the possible values.\n   *\n   * @default {@link ComputeType#SMALL}\n   */\n  readonly computeType?: codebuild.ComputeType;\n\n  /**\n   * The number of minutes after which AWS CodeBuild stops the build if it's\n   * not complete. For valid values, see the timeoutInMinutes field in the AWS\n   * CodeBuild User Guide.\n   *\n   * @default Duration.hours(1)\n   */\n  readonly timeout?: Duration;\n\n  /**\n   * Support building and running Docker images by enabling Docker-in-Docker (dind) and the required CodeBuild privileged mode. Disabling this can\n   * speed up provisioning of CodeBuild runners. If you don't intend on running or building Docker images, disable this for faster start-up times.\n   *\n   * @default true\n   */\n  readonly dockerInDocker?: boolean;\n}\n\n/**\n * GitHub Actions runner provider using CodeBuild to execute jobs.\n *\n * Creates a project that gets started for each job.\n *\n * This construct is not meant to be used by itself. It should be passed in the providers property for GitHubRunners.\n */\nexport class CodeBuildRunnerProvider extends BaseProvider implements IRunnerProvider {\n  /**\n   * Path to Dockerfile for Linux x64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.\n   *\n   * Available build arguments that can be set in the image builder:\n   * * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   * * `DOCKER_CHANNEL` overrides the channel from which Docker will be downloaded. Defaults to `\"stable\"`.\n   * * `DIND_COMMIT` overrides the commit where dind is found.\n   * * `DOCKER_VERSION` overrides the installed Docker version.\n   * * `DOCKER_COMPOSE_VERSION` overrides the installed docker-compose version.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'codebuild', 'linux-x64');\n\n  /**\n   * Path to Dockerfile for Linux ARM64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.\n   *\n   * Available build arguments that can be set in the image builder:\n   * * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   * * `DOCKER_CHANNEL` overrides the channel from which Docker will be downloaded. Defaults to `\"stable\"`.\n   * * `DIND_COMMIT` overrides the commit where dind is found.\n   * * `DOCKER_VERSION` overrides the installed Docker version.\n   * * `DOCKER_COMPOSE_VERSION` overrides the installed docker-compose version.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'codebuild', 'linux-arm64');\n\n  /**\n   * Create new image builder that builds CodeBuild specific runner images.\n   *\n   * You can customize the OS, architecture, VPC, subnet, security groups, etc. by passing in props.\n   *\n   * You can add components to the image builder by calling `imageBuilder.addComponent()`.\n   *\n   * The default OS is Ubuntu running on x64 architecture.\n   *\n   * Included components:\n   *  * `RunnerImageComponent.requiredPackages()`\n   *  * `RunnerImageComponent.runnerUser()`\n   *  * `RunnerImageComponent.git()`\n   *  * `RunnerImageComponent.githubCli()`\n   *  * `RunnerImageComponent.awsCli()`\n   *  * `RunnerImageComponent.docker()`\n   *  * `RunnerImageComponent.githubRunner()`\n   */\n  public static imageBuilder(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    return RunnerImageBuilder.new(scope, id, {\n      os: Os.LINUX_UBUNTU,\n      architecture: Architecture.X86_64,\n      components: [\n        RunnerImageComponent.requiredPackages(),\n        RunnerImageComponent.runnerUser(),\n        RunnerImageComponent.git(),\n        RunnerImageComponent.githubCli(),\n        RunnerImageComponent.awsCli(),\n        RunnerImageComponent.docker(),\n        RunnerImageComponent.githubRunner(props?.runnerVersion ?? RunnerVersion.latest()),\n      ],\n      ...props,\n    });\n  }\n\n  /**\n   * CodeBuild project hosting the runner.\n   */\n  readonly project: codebuild.Project;\n\n  /**\n   * Labels associated with this provider.\n   */\n  readonly labels: string[];\n\n  /**\n   * Grant principal used to add permissions to the runner role.\n   */\n  readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * Docker image loaded with GitHub Actions Runner and its prerequisites. The image is built by an image builder and is specific to CodeBuild.\n   */\n  readonly image: RunnerImage;\n\n  /**\n   * Log group where provided runners will save their logs.\n   *\n   * Note that this is not the job log, but the runner itself. It will not contain output from the GitHub Action but only metadata on its execution.\n   */\n  readonly logGroup: logs.ILogGroup;\n\n  readonly retryableErrors = [\n    'CodeBuild.CodeBuildException',\n    'CodeBuild.AccountLimitExceededException',\n  ];\n\n  private readonly group?: string;\n  private readonly vpc?: ec2.IVpc;\n  private readonly securityGroups?: ec2.ISecurityGroup[];\n  private readonly dind: boolean;\n  private readonly defaultLabels: boolean;\n\n  constructor(scope: Construct, id: string, props?: CodeBuildRunnerProviderProps) {\n    super(scope, id, props);\n\n    // warn against isolated networks\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PRIVATE_ISOLATED) {\n      Annotations.of(this).addWarning('Private isolated subnets cannot pull from public ECR and VPC endpoint is not supported yet. ' +\n        'See https://github.com/aws/containers-roadmap/issues/1160');\n    }\n\n    // error out on no-nat networks because the build will hang\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PUBLIC) {\n      Annotations.of(this).addError('Public subnets do not work with CodeBuild as it cannot be assigned an IP. ' +\n        'See https://docs.aws.amazon.com/codebuild/latest/userguide/vpc-support.html#best-practices-for-vpcs');\n    }\n\n    this.labels = this.labelsFromProperties('codebuild', props?.label, props?.labels);\n    this.group = props?.group;\n    this.vpc = props?.vpc;\n    if (props?.securityGroup) {\n      this.securityGroups = [props.securityGroup];\n    } else {\n      if (props?.securityGroups) {\n        this.securityGroups = props.securityGroups;\n      } else {\n        if (this.vpc) {\n          this.securityGroups = [new ec2.SecurityGroup(this, 'SG', { vpc: this.vpc })];\n        }\n      }\n    }\n\n    this.dind = props?.dockerInDocker ?? true;\n    this.defaultLabels = props?.defaultLabels ?? true;\n\n    let buildSpec = {\n      version: 0.2,\n      env: {\n        variables: {\n          RUNNER_TOKEN: 'unspecified',\n          RUNNER_NAME: 'unspecified',\n          RUNNER_LABEL: 'unspecified',\n          OWNER: 'unspecified',\n          REPO: 'unspecified',\n          GITHUB_DOMAIN: 'github.com',\n          REGISTRATION_URL: 'unspecified',\n          RUNNER_GROUP1: '',\n          RUNNER_GROUP2: '',\n          DEFAULT_LABELS: '',\n        },\n      },\n      phases: {\n        install: {\n          commands: [\n            this.dind ? 'nohup dockerd --host=unix:///var/run/docker.sock --host=tcp://127.0.0.1:2375 --storage-driver=overlay2 &' : '',\n            this.dind ? 'timeout 15 sh -c \"until docker info; do echo .; sleep 1; done\"' : '',\n            'if [ \"${RUNNER_VERSION}\" = \"latest\" ]; then RUNNER_FLAGS=\"\"; else RUNNER_FLAGS=\"--disableupdate\"; fi',\n            'sudo -Hu runner /home/runner/config.sh --unattended --url \"${REGISTRATION_URL}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL},cdkghr:started:`date +%s`\" ${RUNNER_FLAGS} --name \"${RUNNER_NAME}\" ${RUNNER_GROUP1} ${RUNNER_GROUP2} ${DEFAULT_LABELS}',\n          ],\n        },\n        build: {\n          commands: [\n            'sudo --preserve-env=AWS_CONTAINER_CREDENTIALS_RELATIVE_URI,AWS_DEFAULT_REGION,AWS_REGION -Hu runner /home/runner/run.sh',\n            'STATUS=$(grep -Phors \"finish job request for job [0-9a-f\\\\-]+ with result: \\\\K.*\" /home/runner/_diag/ | tail -n1)',\n            '[ -n \"$STATUS\" ] && echo CDKGHA JOB DONE \"$RUNNER_LABEL\" \"$STATUS\"',\n          ],\n        },\n      },\n    };\n\n    const imageBuilder = props?.imageBuilder ?? CodeBuildRunnerProvider.imageBuilder(this, 'Image Builder');\n    const image = this.image = imageBuilder.bindDockerImage();\n\n    if (image.os.is(Os.WINDOWS)) {\n      buildSpec.phases.install.commands = [\n        'cd \\\\actions',\n        'if (${Env:RUNNER_VERSION} -eq \"latest\") { $RunnerFlags = \"\" } else { $RunnerFlags = \"--disableupdate\" }',\n        './config.cmd --unattended --url \"${Env:REGISTRATION_URL}\" --token \"${Env:RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${Env:RUNNER_LABEL},cdkghr:started:$(Get-Date -UFormat %s)\" ${RunnerFlags} --name \"${Env:RUNNER_NAME}\" ${Env:RUNNER_GROUP1} ${Env:RUNNER_GROUP2} ${Env:DEFAULT_LABELS}',\n      ];\n      buildSpec.phases.build.commands = [\n        'cd \\\\actions',\n        './run.cmd',\n        '$STATUS = Select-String -Path \\'./_diag/*.log\\' -Pattern \\'finish job request for job [0-9a-f\\\\-]+ with result: (.*)\\' | %{$_.Matches.Groups[1].Value} | Select-Object -Last 1',\n        'if ($STATUS) { echo \"CDKGHA JOB DONE $\\{Env:RUNNER_LABEL\\} $STATUS\" }',\n      ];\n    }\n\n    // choose build image\n    let buildImage: codebuild.IBuildImage | undefined;\n    if (image.os.isIn(Os._ALL_LINUX_VERSIONS)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        buildImage = codebuild.LinuxBuildImage.fromEcrRepository(image.imageRepository, image.imageTag);\n      } else if (image.architecture.is(Architecture.ARM64)) {\n        buildImage = codebuild.LinuxArmBuildImage.fromEcrRepository(image.imageRepository, image.imageTag);\n      }\n    }\n    if (image.os.is(Os.WINDOWS)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        buildImage = codebuild.WindowsBuildImage.fromEcrRepository(image.imageRepository, image.imageTag, codebuild.WindowsImageType.SERVER_2019);\n      }\n    }\n\n    if (buildImage === undefined) {\n      throw new Error(`Unable to find supported CodeBuild image for ${image.os.name}/${image.architecture.name}`);\n    }\n\n    // create project\n    this.logGroup = new logs.LogGroup(\n      this,\n      'Logs',\n      {\n        retention: props?.logRetention ?? RetentionDays.ONE_MONTH,\n        removalPolicy: RemovalPolicy.DESTROY,\n      },\n    );\n    this.project = new codebuild.Project(\n      this,\n      'CodeBuild',\n      {\n        description: `GitHub Actions self-hosted runner for labels ${this.labels}`,\n        buildSpec: codebuild.BuildSpec.fromObject(buildSpec),\n        vpc: this.vpc,\n        securityGroups: this.securityGroups,\n        subnetSelection: props?.subnetSelection,\n        timeout: props?.timeout ?? Duration.hours(1),\n        environment: {\n          buildImage,\n          computeType: props?.computeType ?? ComputeType.SMALL,\n          privileged: this.dind && !image.os.is(Os.WINDOWS),\n        },\n        logging: {\n          cloudWatch: {\n            logGroup: this.logGroup,\n          },\n        },\n      },\n    );\n\n    this.grantPrincipal = this.project.grantPrincipal;\n\n    // allow SSM Session Manager access\n    // this.project.role?.addToPrincipalPolicy(MINIMAL_SSM_SESSION_MANAGER_POLICY_STATEMENT);\n    // step function won't let us pass `debugSessionEnabled: true` unless we use batch, so we can't use this\n  }\n\n  /**\n   * Generate step function task(s) to start a new runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters workflow job details\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable {\n    return new stepfunctions_tasks.CodeBuildStartBuild(\n      this,\n      'State',\n      {\n        stateName: generateStateName(this),\n        integrationPattern: IntegrationPattern.RUN_JOB, // sync\n        project: this.project,\n        environmentVariablesOverride: {\n          RUNNER_TOKEN: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.runnerTokenPath,\n          },\n          RUNNER_NAME: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.runnerNamePath,\n          },\n          RUNNER_LABEL: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.labelsPath,\n          },\n          RUNNER_GROUP1: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.group ? '--runnergroup' : '',\n          },\n          RUNNER_GROUP2: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.group ? this.group : '',\n          },\n          DEFAULT_LABELS: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.defaultLabels ? '' : '--no-default-labels',\n          },\n          GITHUB_DOMAIN: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.githubDomainPath,\n          },\n          OWNER: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.ownerPath,\n          },\n          REPO: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.repoPath,\n          },\n          REGISTRATION_URL: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.registrationUrl,\n          },\n        },\n      },\n    );\n  }\n\n  grantStateMachine(_: iam.IGrantable) {\n  }\n\n  status(statusFunctionRole: iam.IGrantable): IRunnerProviderStatus {\n    this.image.imageRepository.grant(statusFunctionRole, 'ecr:DescribeImages');\n\n    return {\n      type: this.constructor.name,\n      labels: this.labels,\n      constructPath: this.node.path,\n      vpcArn: this.vpc?.vpcArn,\n      securityGroups: this.securityGroups?.map(sg => sg.securityGroupId),\n      roleArn: this.project.role?.roleArn,\n      logGroup: this.logGroup.logGroupName,\n      image: {\n        imageRepository: this.image.imageRepository.repositoryUri,\n        imageTag: this.image.imageTag,\n        imageBuilderLogGroup: this.image.logGroup?.logGroupName,\n      },\n    };\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return this.project.connections;\n  }\n}\n\n/**\n * @deprecated use {@link CodeBuildRunnerProvider}\n */\nexport class CodeBuildRunner extends CodeBuildRunnerProvider {\n}\n"]}
304
+ CodeBuildRunner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.14.21" };
305
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codebuild.js","sourceRoot":"","sources":["../../src/providers/codebuild.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Annotations,\n  aws_codebuild as codebuild,\n  aws_ec2 as ec2,\n  aws_iam as iam,\n  aws_logs as logs,\n  aws_stepfunctions as stepfunctions,\n  aws_stepfunctions_tasks as stepfunctions_tasks,\n  Duration,\n  RemovalPolicy,\n} from 'aws-cdk-lib';\nimport { ComputeType } from 'aws-cdk-lib/aws-codebuild';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { IntegrationPattern } from 'aws-cdk-lib/aws-stepfunctions';\nimport { Construct } from 'constructs';\nimport {\n  Architecture,\n  BaseProvider,\n  IRunnerProvider,\n  IRunnerProviderStatus,\n  Os,\n  RunnerImage,\n  RunnerProviderProps,\n  RunnerRuntimeParameters,\n  RunnerVersion,\n  generateStateName,\n} from './common';\nimport { IRunnerImageBuilder, RunnerImageBuilder, RunnerImageBuilderProps, RunnerImageComponent } from '../image-builders';\n\n\nexport interface CodeBuildRunnerProviderProps extends RunnerProviderProps {\n  /**\n   * Runner image builder used to build Docker images containing GitHub Runner and all requirements.\n   *\n   * The image builder must contain the {@link RunnerImageComponent.docker} component unless `dockerInDocker` is set to false.\n   *\n   * The image builder determines the OS and architecture of the runner.\n   *\n   * @default CodeBuildRunnerProvider.imageBuilder()\n   */\n  readonly imageBuilder?: IRunnerImageBuilder;\n\n  /**\n   * GitHub Actions label used for this provider.\n   *\n   * @default undefined\n   * @deprecated use {@link labels} instead\n   */\n  readonly label?: string;\n\n  /**\n   * GitHub Actions labels used for this provider.\n   *\n   * These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for\n   * based on runs-on. We match the labels from the webhook with the labels specified here. If all the labels specified here are present in the\n   * job's labels, this provider will be chosen and spawn a new runner.\n   *\n   * @default ['codebuild']\n   */\n  readonly labels?: string[];\n\n  /**\n   * GitHub Actions runner group name.\n   *\n   * If specified, the runner will be registered with this group name. Setting a runner group can help managing access to self-hosted runners. It\n   * requires a paid GitHub account.\n   *\n   * The group must exist or the runner will not start.\n   *\n   * Users will still be able to trigger this runner with the correct labels. But the runner will only be able to run jobs from repos allowed to use the group.\n   *\n   * @default undefined\n   */\n  readonly group?: string;\n\n  /**\n   * VPC to launch the runners in.\n   *\n   * @default no VPC\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group to assign to this instance.\n   *\n   * @default public project with no security group\n   *\n   * @deprecated use {@link securityGroups}\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Security groups to assign to this instance.\n   *\n   * @default a new security group, if {@link vpc} is used\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * @default no subnet\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * The type of compute to use for this build.\n   * See the {@link ComputeType} enum for the possible values.\n   *\n   * The compute type determines CPU, memory, and disk space:\n   * - SMALL: 2 vCPU, 3 GB RAM, 64 GB disk\n   * - MEDIUM: 4 vCPU, 7 GB RAM, 128 GB disk\n   * - LARGE: 8 vCPU, 15 GB RAM, 128 GB disk\n   * - X2_LARGE: 72 vCPU, 145 GB RAM, 256 GB disk (Linux) or 824 GB disk (Windows)\n   *\n   * Use a larger compute type when you need more disk space for building larger Docker images.\n   *\n   * For more details, see https://docs.aws.amazon.com/codebuild/latest/userguide/build-env-ref-compute-types.html#environment.types\n   *\n   * @default {@link ComputeType#SMALL}\n   */\n  readonly computeType?: codebuild.ComputeType;\n\n  /**\n   * The number of minutes after which AWS CodeBuild stops the build if it's\n   * not complete. For valid values, see the timeoutInMinutes field in the AWS\n   * CodeBuild User Guide.\n   *\n   * @default Duration.hours(1)\n   */\n  readonly timeout?: Duration;\n\n  /**\n   * Support building and running Docker images by enabling Docker-in-Docker (dind) and the required CodeBuild privileged mode. Disabling this can\n   * speed up provisioning of CodeBuild runners. If you don't intend on running or building Docker images, disable this for faster start-up times.\n   *\n   * @default true\n   */\n  readonly dockerInDocker?: boolean;\n}\n\n/**\n * GitHub Actions runner provider using CodeBuild to execute jobs.\n *\n * Creates a project that gets started for each job.\n *\n * This construct is not meant to be used by itself. It should be passed in the providers property for GitHubRunners.\n */\nexport class CodeBuildRunnerProvider extends BaseProvider implements IRunnerProvider {\n  /**\n   * Path to Dockerfile for Linux x64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.\n   *\n   * Available build arguments that can be set in the image builder:\n   * * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   * * `DOCKER_CHANNEL` overrides the channel from which Docker will be downloaded. Defaults to `\"stable\"`.\n   * * `DIND_COMMIT` overrides the commit where dind is found.\n   * * `DOCKER_VERSION` overrides the installed Docker version.\n   * * `DOCKER_COMPOSE_VERSION` overrides the installed docker-compose version.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'codebuild', 'linux-x64');\n\n  /**\n   * Path to Dockerfile for Linux ARM64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.\n   *\n   * Available build arguments that can be set in the image builder:\n   * * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   * * `DOCKER_CHANNEL` overrides the channel from which Docker will be downloaded. Defaults to `\"stable\"`.\n   * * `DIND_COMMIT` overrides the commit where dind is found.\n   * * `DOCKER_VERSION` overrides the installed Docker version.\n   * * `DOCKER_COMPOSE_VERSION` overrides the installed docker-compose version.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'codebuild', 'linux-arm64');\n\n  /**\n   * Create new image builder that builds CodeBuild specific runner images.\n   *\n   * You can customize the OS, architecture, VPC, subnet, security groups, etc. by passing in props.\n   *\n   * You can add components to the image builder by calling `imageBuilder.addComponent()`.\n   *\n   * The default OS is Ubuntu running on x64 architecture.\n   *\n   * Included components:\n   *  * `RunnerImageComponent.requiredPackages()`\n   *  * `RunnerImageComponent.runnerUser()`\n   *  * `RunnerImageComponent.git()`\n   *  * `RunnerImageComponent.githubCli()`\n   *  * `RunnerImageComponent.awsCli()`\n   *  * `RunnerImageComponent.docker()`\n   *  * `RunnerImageComponent.githubRunner()`\n   */\n  public static imageBuilder(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    return RunnerImageBuilder.new(scope, id, {\n      os: Os.LINUX_UBUNTU,\n      architecture: Architecture.X86_64,\n      components: [\n        RunnerImageComponent.requiredPackages(),\n        RunnerImageComponent.runnerUser(),\n        RunnerImageComponent.git(),\n        RunnerImageComponent.githubCli(),\n        RunnerImageComponent.awsCli(),\n        RunnerImageComponent.docker(),\n        RunnerImageComponent.githubRunner(props?.runnerVersion ?? RunnerVersion.latest()),\n      ],\n      ...props,\n    });\n  }\n\n  /**\n   * CodeBuild project hosting the runner.\n   */\n  readonly project: codebuild.Project;\n\n  /**\n   * Labels associated with this provider.\n   */\n  readonly labels: string[];\n\n  /**\n   * Grant principal used to add permissions to the runner role.\n   */\n  readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * Docker image loaded with GitHub Actions Runner and its prerequisites. The image is built by an image builder and is specific to CodeBuild.\n   *\n   * @deprecated This field is internal and should not be accessed directly.\n   */\n  readonly image: RunnerImage;\n\n  /**\n   * Log group where provided runners will save their logs.\n   *\n   * Note that this is not the job log, but the runner itself. It will not contain output from the GitHub Action but only metadata on its execution.\n   */\n  readonly logGroup: logs.ILogGroup;\n\n  readonly retryableErrors = [\n    'CodeBuild.CodeBuildException',\n    'CodeBuild.AccountLimitExceededException',\n  ];\n\n  private readonly group?: string;\n  private readonly vpc?: ec2.IVpc;\n  private readonly securityGroups?: ec2.ISecurityGroup[];\n  private readonly dind: boolean;\n  private readonly defaultLabels: boolean;\n\n  constructor(scope: Construct, id: string, props?: CodeBuildRunnerProviderProps) {\n    super(scope, id, props);\n\n    // warn against isolated networks\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PRIVATE_ISOLATED) {\n      Annotations.of(this).addWarning('Private isolated subnets cannot pull from public ECR and VPC endpoint is not supported yet. ' +\n        'See https://github.com/aws/containers-roadmap/issues/1160');\n    }\n\n    // error out on no-nat networks because the build will hang\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PUBLIC) {\n      Annotations.of(this).addError('Public subnets do not work with CodeBuild as it cannot be assigned an IP. ' +\n        'See https://docs.aws.amazon.com/codebuild/latest/userguide/vpc-support.html#best-practices-for-vpcs');\n    }\n\n    this.labels = this.labelsFromProperties('codebuild', props?.label, props?.labels);\n    this.group = props?.group;\n    this.vpc = props?.vpc;\n    if (props?.securityGroup) {\n      this.securityGroups = [props.securityGroup];\n    } else {\n      if (props?.securityGroups) {\n        this.securityGroups = props.securityGroups;\n      } else {\n        if (this.vpc) {\n          this.securityGroups = [new ec2.SecurityGroup(this, 'SG', { vpc: this.vpc })];\n        }\n      }\n    }\n\n    this.dind = props?.dockerInDocker ?? true;\n    this.defaultLabels = props?.defaultLabels ?? true;\n\n    let buildSpec = {\n      version: 0.2,\n      env: {\n        variables: {\n          RUNNER_TOKEN: 'unspecified',\n          RUNNER_NAME: 'unspecified',\n          RUNNER_LABEL: 'unspecified',\n          OWNER: 'unspecified',\n          REPO: 'unspecified',\n          GITHUB_DOMAIN: 'github.com',\n          REGISTRATION_URL: 'unspecified',\n          RUNNER_GROUP1: '',\n          RUNNER_GROUP2: '',\n          DEFAULT_LABELS: '',\n        },\n      },\n      phases: {\n        install: {\n          commands: [\n            this.dind ? 'nohup dockerd --host=unix:///var/run/docker.sock --host=tcp://127.0.0.1:2375 --storage-driver=overlay2 &' : '',\n            this.dind ? 'timeout 15 sh -c \"until docker info; do echo .; sleep 1; done\"' : '',\n            'if [ \"${RUNNER_VERSION}\" = \"latest\" ]; then RUNNER_FLAGS=\"\"; else RUNNER_FLAGS=\"--disableupdate\"; fi',\n            'sudo -Hu runner /home/runner/config.sh --unattended --url \"${REGISTRATION_URL}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL},cdkghr:started:`date +%s`\" ${RUNNER_FLAGS} --name \"${RUNNER_NAME}\" ${RUNNER_GROUP1} ${RUNNER_GROUP2} ${DEFAULT_LABELS}',\n          ],\n        },\n        build: {\n          commands: [\n            'sudo --preserve-env=AWS_CONTAINER_CREDENTIALS_RELATIVE_URI,AWS_DEFAULT_REGION,AWS_REGION -Hu runner /home/runner/run.sh',\n            'STATUS=$(grep -Phors \"finish job request for job [0-9a-f\\\\-]+ with result: \\\\K.*\" /home/runner/_diag/ | tail -n1)',\n            '[ -n \"$STATUS\" ] && echo CDKGHA JOB DONE \"$RUNNER_LABEL\" \"$STATUS\"',\n          ],\n        },\n      },\n    };\n\n    const imageBuilder = props?.imageBuilder ?? CodeBuildRunnerProvider.imageBuilder(this, 'Image Builder');\n    const image = this.image = imageBuilder.bindDockerImage();\n\n    if (image.os.is(Os.WINDOWS)) {\n      buildSpec.phases.install.commands = [\n        'cd \\\\actions',\n        'if (${Env:RUNNER_VERSION} -eq \"latest\") { $RunnerFlags = \"\" } else { $RunnerFlags = \"--disableupdate\" }',\n        './config.cmd --unattended --url \"${Env:REGISTRATION_URL}\" --token \"${Env:RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${Env:RUNNER_LABEL},cdkghr:started:$(Get-Date -UFormat %s)\" ${RunnerFlags} --name \"${Env:RUNNER_NAME}\" ${Env:RUNNER_GROUP1} ${Env:RUNNER_GROUP2} ${Env:DEFAULT_LABELS}',\n      ];\n      buildSpec.phases.build.commands = [\n        'cd \\\\actions',\n        './run.cmd',\n        '$STATUS = Select-String -Path \\'./_diag/*.log\\' -Pattern \\'finish job request for job [0-9a-f\\\\-]+ with result: (.*)\\' | %{$_.Matches.Groups[1].Value} | Select-Object -Last 1',\n        'if ($STATUS) { echo \"CDKGHA JOB DONE $\\{Env:RUNNER_LABEL\\} $STATUS\" }',\n      ];\n    }\n\n    // choose build image\n    let buildImage: codebuild.IBuildImage | undefined;\n    if (image.os.isIn(Os._ALL_LINUX_VERSIONS)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        buildImage = codebuild.LinuxBuildImage.fromEcrRepository(image.imageRepository, image.imageTag);\n      } else if (image.architecture.is(Architecture.ARM64)) {\n        buildImage = codebuild.LinuxArmBuildImage.fromEcrRepository(image.imageRepository, image.imageTag);\n      }\n    }\n    if (image.os.is(Os.WINDOWS)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        buildImage = codebuild.WindowsBuildImage.fromEcrRepository(image.imageRepository, image.imageTag, codebuild.WindowsImageType.SERVER_2019);\n      }\n    }\n\n    if (buildImage === undefined) {\n      throw new Error(`Unable to find supported CodeBuild image for ${image.os.name}/${image.architecture.name}`);\n    }\n\n    // create project\n    this.logGroup = new logs.LogGroup(\n      this,\n      'Logs',\n      {\n        retention: props?.logRetention ?? RetentionDays.ONE_MONTH,\n        removalPolicy: RemovalPolicy.DESTROY,\n      },\n    );\n    this.project = new codebuild.Project(\n      this,\n      'CodeBuild',\n      {\n        description: `GitHub Actions self-hosted runner for labels ${this.labels}`,\n        buildSpec: codebuild.BuildSpec.fromObject(buildSpec),\n        vpc: this.vpc,\n        securityGroups: this.securityGroups,\n        subnetSelection: props?.subnetSelection,\n        timeout: props?.timeout ?? Duration.hours(1),\n        environment: {\n          buildImage,\n          computeType: props?.computeType ?? ComputeType.SMALL,\n          privileged: this.dind && !image.os.is(Os.WINDOWS),\n        },\n        logging: {\n          cloudWatch: {\n            logGroup: this.logGroup,\n          },\n        },\n      },\n    );\n\n    this.grantPrincipal = this.project.grantPrincipal;\n\n    // allow SSM Session Manager access\n    // this.project.role?.addToPrincipalPolicy(MINIMAL_SSM_SESSION_MANAGER_POLICY_STATEMENT);\n    // step function won't let us pass `debugSessionEnabled: true` unless we use batch, so we can't use this\n  }\n\n  /**\n   * Generate step function task(s) to start a new runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters workflow job details\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable {\n    return new stepfunctions_tasks.CodeBuildStartBuild(\n      this,\n      'State',\n      {\n        stateName: generateStateName(this),\n        integrationPattern: IntegrationPattern.RUN_JOB, // sync\n        project: this.project,\n        environmentVariablesOverride: {\n          RUNNER_TOKEN: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.runnerTokenPath,\n          },\n          RUNNER_NAME: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.runnerNamePath,\n          },\n          RUNNER_LABEL: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.labelsPath,\n          },\n          RUNNER_GROUP1: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.group ? '--runnergroup' : '',\n          },\n          RUNNER_GROUP2: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.group ? this.group : '',\n          },\n          DEFAULT_LABELS: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.defaultLabels ? '' : '--no-default-labels',\n          },\n          GITHUB_DOMAIN: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.githubDomainPath,\n          },\n          OWNER: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.ownerPath,\n          },\n          REPO: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.repoPath,\n          },\n          REGISTRATION_URL: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.registrationUrl,\n          },\n        },\n      },\n    );\n  }\n\n  grantStateMachine(_: iam.IGrantable) {\n  }\n\n  status(statusFunctionRole: iam.IGrantable): IRunnerProviderStatus {\n    this.image.imageRepository.grant(statusFunctionRole, 'ecr:DescribeImages');\n\n    return {\n      type: this.constructor.name,\n      labels: this.labels,\n      constructPath: this.node.path,\n      vpcArn: this.vpc?.vpcArn,\n      securityGroups: this.securityGroups?.map(sg => sg.securityGroupId),\n      roleArn: this.project.role?.roleArn,\n      logGroup: this.logGroup.logGroupName,\n      image: {\n        imageRepository: this.image.imageRepository.repositoryUri,\n        imageTag: this.image.imageTag,\n        imageBuilderLogGroup: this.image.logGroup?.logGroupName,\n      },\n    };\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return this.project.connections;\n  }\n}\n\n/**\n * @deprecated use {@link CodeBuildRunnerProvider}\n */\nexport class CodeBuildRunner extends CodeBuildRunnerProvider {\n}\n"]}
@@ -45,7 +45,7 @@ class RunnerVersion {
45
45
  }
46
46
  exports.RunnerVersion = RunnerVersion;
47
47
  _a = JSII_RTTI_SYMBOL_1;
48
- RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.14.19" };
48
+ RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.14.21" };
49
49
  /**
50
50
  * CPU architecture enum for an image.
51
51
  */
@@ -94,7 +94,7 @@ class Architecture {
94
94
  }
95
95
  exports.Architecture = Architecture;
96
96
  _b = JSII_RTTI_SYMBOL_1;
97
- Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.14.19" };
97
+ Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.14.21" };
98
98
  /**
99
99
  * ARM64
100
100
  */
@@ -137,7 +137,7 @@ class Os {
137
137
  }
138
138
  exports.Os = Os;
139
139
  _c = JSII_RTTI_SYMBOL_1;
140
- Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.14.19" };
140
+ Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.14.21" };
141
141
  /**
142
142
  * Linux
143
143
  *