@cloudsnorkel/cdk-github-runners
Version:
CDK construct to create GitHub Actions self-hosted runners. Creates ephemeral runners on demand. Easy to deploy and highly customizable.
115 lines • 16.4 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.increaseVersion = increaseVersion;
exports.handler = handler;
const client_imagebuilder_1 = require("@aws-sdk/client-imagebuilder");
const semver_1 = require("semver");
const lambda_helpers_1 = require("../../lambda-helpers");
const ib = new client_imagebuilder_1.ImagebuilderClient();
/**
* Exported for unit tests.
* @internal
*/
function increaseVersion(allVersions) {
let version = (0, semver_1.maxSatisfying)(allVersions, '>=0.0.0');
if (version === null) {
version = '1.0.0';
}
console.log(`Found versions ${allVersions} -- latest is ${version}`);
version = (0, semver_1.inc)(version, 'patch');
if (version === null) {
throw new Error('Unable to bump version');
}
return version;
}
async function handler(event, context) {
console.log({ ...event, ResponseURL: '...' });
try {
const objectType = event.ResourceProperties.ObjectType;
const objectName = event.ResourceProperties.ObjectName;
switch (event.RequestType) {
case 'Create':
case 'Update':
let allVersions = [];
try {
switch (objectType) {
case 'Component': {
let result = {};
do {
result = await ib.send(new client_imagebuilder_1.ListComponentsCommand({
filters: [{
name: 'name',
values: [objectName],
}],
nextToken: result.nextToken,
}));
allVersions = allVersions.concat(result.componentVersionList.map(i => i.version || '1.0.0'));
} while (result.nextToken);
break;
}
case 'ImageRecipe': {
let result = {};
do {
result = await ib.send(new client_imagebuilder_1.ListImageRecipesCommand({
filters: [{
name: 'name',
values: [objectName],
}],
nextToken: result.nextToken,
}));
allVersions = allVersions.concat(result.imageRecipeSummaryList.map(i => i.arn?.split('/').pop() || '1.0.0'));
} while (result.nextToken);
break;
}
case 'ContainerRecipe': {
let result = {};
do {
result = await ib.send(new client_imagebuilder_1.ListContainerRecipesCommand({
filters: [{
name: 'name',
values: [objectName],
}],
nextToken: result.nextToken,
}));
allVersions = allVersions.concat(result.containerRecipeSummaryList.map(i => i.arn?.split('/').pop() || '1.0.0'));
} while (result.nextToken);
break;
}
case 'Workflow': {
let result = {};
do {
result = await ib.send(new client_imagebuilder_1.ListWorkflowsCommand({
filters: [{
name: 'name',
values: [objectName],
}],
nextToken: result.nextToken,
}));
allVersions = allVersions.concat(result.workflowVersionList.map(i => i.arn?.split('/').pop() || '1.0.0'));
} while (result.nextToken);
break;
}
}
}
catch (e) {
if (e.code !== 'ResourceNotFoundException') {
throw e;
}
else {
console.log('Resource not found, assuming first version');
}
}
const version = increaseVersion(allVersions);
await (0, lambda_helpers_1.customResourceRespond)(event, 'SUCCESS', 'OK', version, {});
break;
case 'Delete':
await (0, lambda_helpers_1.customResourceRespond)(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});
break;
}
}
catch (e) {
console.log(e);
await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', e.message || 'Internal Error', context.logStreamName, {});
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"versioner.lambda.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/versioner.lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ImagebuilderClient,\n  ListComponentsCommand,\n  ListComponentsResponse,\n  ListContainerRecipesCommand,\n  ListContainerRecipesResponse,\n  ListImageRecipesCommand,\n  ListImageRecipesResponse,\n  ListWorkflowsCommand,\n  ListWorkflowsResponse,\n} from '@aws-sdk/client-imagebuilder';\nimport * as AWSLambda from 'aws-lambda';\nimport { inc, maxSatisfying } from 'semver';\nimport { customResourceRespond } from '../../lambda-helpers';\n\nconst ib = new ImagebuilderClient();\n\n/**\n * Exported for unit tests.\n * @internal\n */\nexport function increaseVersion(allVersions: string[]) {\n  let version = maxSatisfying(allVersions, '>=0.0.0');\n  if (version === null) {\n    version = '1.0.0';\n  }\n  console.log(`Found versions ${allVersions} -- latest is ${version}`);\n\n  version = inc(version, 'patch');\n  if (version === null) {\n    throw new Error('Unable to bump version');\n  }\n\n  return version;\n}\n\nexport async function handler(event: AWSLambda.CloudFormationCustomResourceEvent, context: AWSLambda.Context) {\n  console.log({ ...event, ResponseURL: '...' });\n\n  try {\n    const objectType = event.ResourceProperties.ObjectType;\n    const objectName = event.ResourceProperties.ObjectName;\n\n    switch (event.RequestType) {\n      case 'Create':\n      case 'Update':\n        let allVersions: string[] = [];\n        try {\n          switch (objectType) {\n            case 'Component': {\n              let result: ListComponentsResponse = {};\n              do {\n                result = await ib.send(new ListComponentsCommand({\n                  filters: [{\n                    name: 'name',\n                    values: [objectName],\n                  }],\n                  nextToken: result.nextToken,\n                }));\n                allVersions = allVersions.concat(result.componentVersionList!.map(i => i.version || '1.0.0'));\n              } while (result.nextToken);\n              break;\n            }\n            case 'ImageRecipe': {\n              let result: ListImageRecipesResponse = {};\n              do {\n                result = await ib.send(new ListImageRecipesCommand({\n                  filters: [{\n                    name: 'name',\n                    values: [objectName],\n                  }],\n                  nextToken: result.nextToken,\n                }));\n                allVersions = allVersions.concat(result.imageRecipeSummaryList!.map(i => i.arn?.split('/').pop() || '1.0.0'));\n              } while (result.nextToken);\n              break;\n            }\n            case 'ContainerRecipe': {\n              let result: ListContainerRecipesResponse = {};\n              do {\n                result = await ib.send(new ListContainerRecipesCommand({\n                  filters: [{\n                    name: 'name',\n                    values: [objectName],\n                  }],\n                  nextToken: result.nextToken,\n                }));\n                allVersions = allVersions.concat(result.containerRecipeSummaryList!.map(i => i.arn?.split('/').pop() || '1.0.0'));\n              } while (result.nextToken);\n              break;\n            }\n            case 'Workflow': {\n              let result: ListWorkflowsResponse = {};\n              do {\n                result = await ib.send(new ListWorkflowsCommand({\n                  filters: [{\n                    name: 'name',\n                    values: [objectName],\n                  }],\n                  nextToken: result.nextToken,\n                }));\n                allVersions = allVersions.concat(result.workflowVersionList!.map(i => i.arn?.split('/').pop() || '1.0.0'));\n              } while (result.nextToken);\n              break;\n            }\n          }\n        } catch (e) {\n          if ((e as any).code !== 'ResourceNotFoundException') {\n            throw e;\n          } else {\n            console.log('Resource not found, assuming first version');\n          }\n        }\n\n        const version = increaseVersion(allVersions);\n        await customResourceRespond(event, 'SUCCESS', 'OK', version, {});\n\n        break;\n      case 'Delete':\n        await customResourceRespond(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});\n        break;\n    }\n  } catch (e) {\n    console.log(e);\n    await customResourceRespond(event, 'FAILED', (e as Error).message || 'Internal Error', context.logStreamName, {});\n  }\n}\n"]}