UNPKG

@aws-cdk/core

Version:

AWS Cloud Development Kit Core Library

102 lines 15.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CustomResource = void 0; const cfn_resource_1 = require("./cfn-resource"); const removal_policy_1 = require("./removal-policy"); const resource_1 = require("./resource"); const token_1 = require("./token"); /** * Custom resource that is implemented using a Lambda. * * As a custom resource author, you should be publishing a subclass of this class * that hides the choice of provider, and accepts a strongly-typed properties * object with the properties your provider accepts. * * @resource AWS::CloudFormation::CustomResource */ class CustomResource extends resource_1.Resource { /** * */ constructor(scope, id, props) { var _a; super(scope, id); const type = renderResourceType(props.resourceType); const pascalCaseProperties = (_a = props.pascalCaseProperties) !== null && _a !== void 0 ? _a : false; const properties = pascalCaseProperties ? uppercaseProperties(props.properties || {}) : (props.properties || {}); this.resource = new cfn_resource_1.CfnResource(this, 'Default', { type, properties: { ServiceToken: props.serviceToken, ...properties, }, }); this.resource.applyRemovalPolicy(props.removalPolicy, { default: removal_policy_1.RemovalPolicy.DESTROY, }); } /** * The physical name of this custom resource. */ get ref() { return this.resource.ref; } /** * Returns the value of an attribute of the custom resource of an arbitrary type. * * Attributes are returned from the custom resource provider through the * `Data` map where the key is the attribute name. * * @param attributeName the name of the attribute. * @returns a token for `Fn::GetAtt`. Use `Token.asXxx` to encode the returned `Reference` as a specific type or * use the convenience `getAttString` for string attributes. */ getAtt(attributeName) { return this.resource.getAtt(attributeName); } /** * Returns the value of an attribute of the custom resource of type string. * * Attributes are returned from the custom resource provider through the * `Data` map where the key is the attribute name. * * @param attributeName the name of the attribute. * @returns a token for `Fn::GetAtt` encoded as a string. */ getAttString(attributeName) { return token_1.Token.asString(this.getAtt(attributeName)); } } exports.CustomResource = CustomResource; /** * Uppercase the first letter of every property name * * It's customary for CloudFormation properties to start with capitals, and our * properties to start with lowercase, so this function translates from one * to the other */ function uppercaseProperties(props) { const ret = {}; Object.keys(props).forEach(key => { const upper = key.substr(0, 1).toUpperCase() + key.substr(1); ret[upper] = props[key]; }); return ret; } function renderResourceType(resourceType) { if (!resourceType) { return 'AWS::CloudFormation::CustomResource'; } if (!resourceType.startsWith('Custom::')) { throw new Error(`Custom resource type must begin with "Custom::" (${resourceType})`); } const typeName = resourceType.substr(resourceType.indexOf('::') + 2); if (typeName.length > 60) { throw new Error(`Custom resource type length > 60 (${resourceType})`); } if (!/^[a-z0-9_@-]+$/i.test(typeName)) { throw new Error(`Custom resource type name can only include alphanumeric characters and _@- (${typeName})`); } return resourceType; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-resource.js","sourceRoot":"","sources":["custom-resource.ts"],"names":[],"mappings":";;;AACA,iDAA6C;AAC7C,qDAAiD;AACjD,yCAAsC;AACtC,mCAAgC;;;;;;;;;;AAoGhC,MAAa,cAAe,SAAQ,mBAAQ;;;;IAG1C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,IAAI,GAAG,kBAAkB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACpD,MAAM,oBAAoB,SAAG,KAAK,CAAC,oBAAoB,mCAAI,KAAK,CAAC;QACjE,MAAM,UAAU,GAAG,oBAAoB,CAAC,CAAC,CAAC,mBAAmB,CAAC,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;QAEjH,IAAI,CAAC,QAAQ,GAAG,IAAI,0BAAW,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,IAAI;YACJ,UAAU,EAAE;gBACV,YAAY,EAAE,KAAK,CAAC,YAAY;gBAChC,GAAG,UAAU;aACd;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,KAAK,CAAC,aAAa,EAAE;YACpD,OAAO,EAAE,8BAAa,CAAC,OAAO;SAC/B,CAAC,CAAC;IACL,CAAC;;;;IAKD,IAAW,GAAG;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC;IAC3B,CAAC;;;;;;;;;;;IAWM,MAAM,CAAC,aAAqB;QACjC,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC7C,CAAC;;;;;;;;;;IAUM,YAAY,CAAC,aAAqB;QACvC,OAAO,aAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;IACpD,CAAC;CACF;AAtDD,wCAsDC;AAED;;;;;;GAMG;AACH,SAAS,mBAAmB,CAAC,KAA6B;IACxD,MAAM,GAAG,GAA2B,EAAE,CAAC;IACvC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QAC/B,MAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAC7D,GAAG,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC,CAAC,CAAC;IACH,OAAO,GAAG,CAAC;AACb,CAAC;AAED,SAAS,kBAAkB,CAAC,YAAqB;IAC/C,IAAI,CAAC,YAAY,EAAE;QACjB,OAAO,qCAAqC,CAAC;KAC9C;IAED,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QACxC,MAAM,IAAI,KAAK,CAAC,oDAAoD,YAAY,GAAG,CAAC,CAAC;KACtF;IAED,MAAM,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IACrE,IAAI,QAAQ,CAAC,MAAM,GAAG,EAAE,EAAE;QACxB,MAAM,IAAI,KAAK,CAAC,qCAAqC,YAAY,GAAG,CAAC,CAAC;KACvE;IAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;QACrC,MAAM,IAAI,KAAK,CAAC,+EAA+E,QAAQ,GAAG,CAAC,CAAC;KAC7G;IAED,OAAO,YAAY,CAAC;AACtB,CAAC","sourcesContent":["import { Construct } from 'constructs';\nimport { CfnResource } from './cfn-resource';\nimport { RemovalPolicy } from './removal-policy';\nimport { Resource } from './resource';\nimport { Token } from './token';\n\n                                                                \nexport interface CustomResourceProps {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             \n  readonly serviceToken: string;\n\n                                                                                     \n  readonly properties?: { [key: string]: any };\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   \n  readonly resourceType?: string;\n\n                                                                                                                                     \n  readonly removalPolicy?: RemovalPolicy;\n\n                                                                                   \n  readonly pascalCaseProperties?: boolean;\n}\n\n                                                                                                                                                                                                                                                                                                                                         \nexport class CustomResource extends Resource {\n  private readonly resource: CfnResource;\n\n  constructor(scope: Construct, id: string, props: CustomResourceProps) {\n    super(scope, id);\n\n    const type = renderResourceType(props.resourceType);\n    const pascalCaseProperties = props.pascalCaseProperties ?? false;\n    const properties = pascalCaseProperties ? uppercaseProperties(props.properties || {}) : (props.properties || {});\n\n    this.resource = new CfnResource(this, 'Default', {\n      type,\n      properties: {\n        ServiceToken: props.serviceToken,\n        ...properties,\n      },\n    });\n\n    this.resource.applyRemovalPolicy(props.removalPolicy, {\n      default: RemovalPolicy.DESTROY,\n    });\n  }\n\n                                                           \n  public get ref() {\n    return this.resource.ref;\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                          \n  public getAtt(attributeName: string) {\n    return this.resource.getAtt(attributeName);\n  }\n\n                                                                                                                                                                                                                                                                                                                                              \n  public getAttString(attributeName: string): string {\n    return Token.asString(this.getAtt(attributeName));\n  }\n}\n\n/**\n * Uppercase the first letter of every property name\n *\n * It's customary for CloudFormation properties to start with capitals, and our\n * properties to start with lowercase, so this function translates from one\n * to the other\n */\nfunction uppercaseProperties(props: { [key: string]: any }) {\n  const ret: { [key: string]: any } = {};\n  Object.keys(props).forEach(key => {\n    const upper = key.substr(0, 1).toUpperCase() + key.substr(1);\n    ret[upper] = props[key];\n  });\n  return ret;\n}\n\nfunction renderResourceType(resourceType?: string) {\n  if (!resourceType) {\n    return 'AWS::CloudFormation::CustomResource';\n  }\n\n  if (!resourceType.startsWith('Custom::')) {\n    throw new Error(`Custom resource type must begin with \"Custom::\" (${resourceType})`);\n  }\n\n  const typeName = resourceType.substr(resourceType.indexOf('::') + 2);\n  if (typeName.length > 60) {\n    throw new Error(`Custom resource type length > 60 (${resourceType})`);\n  }\n\n  if (!/^[a-z0-9_@-]+$/i.test(typeName)) {\n    throw new Error(`Custom resource type name can only include alphanumeric characters and _@- (${typeName})`);\n  }\n\n  return resourceType;\n}\n"]}