@aws-cdk/aws-lambda
Advanced tools
Comparing version 0.21.0 to 0.22.0
import iam = require('@aws-cdk/aws-iam'); | ||
import cdk = require('@aws-cdk/cdk'); | ||
import { FunctionRef } from './lambda-ref'; | ||
import { FunctionVersion } from './lambda-version'; | ||
import { FunctionBase, FunctionImportProps } from './lambda-ref'; | ||
import { Version } from './lambda-version'; | ||
import { Permission } from './permission'; | ||
@@ -21,3 +21,3 @@ /** | ||
*/ | ||
version: FunctionVersion; | ||
version: Version; | ||
/** | ||
@@ -49,3 +49,3 @@ * Name of this alias | ||
*/ | ||
export declare class Alias extends FunctionRef { | ||
export declare class Alias extends FunctionBase { | ||
/** | ||
@@ -68,3 +68,3 @@ * ARN of this alias | ||
*/ | ||
readonly role?: iam.Role | undefined; | ||
readonly role?: iam.IRole | undefined; | ||
protected readonly canCreatePermissions: boolean; | ||
@@ -75,3 +75,4 @@ /** | ||
private readonly underlyingLambda; | ||
constructor(parent: cdk.Construct, name: string, props: AliasProps); | ||
constructor(scope: cdk.Construct, id: string, props: AliasProps); | ||
export(): FunctionImportProps; | ||
addPermission(name: string, permission: Permission): void; | ||
@@ -96,3 +97,3 @@ /** | ||
*/ | ||
readonly version: FunctionVersion; | ||
readonly version: Version; | ||
/** | ||
@@ -99,0 +100,0 @@ * How much weight to assign to this version (0..1) |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const cdk = require("@aws-cdk/cdk"); | ||
const lambda_ref_1 = require("./lambda-ref"); | ||
@@ -8,5 +9,5 @@ const lambda_generated_1 = require("./lambda.generated"); | ||
*/ | ||
class Alias extends lambda_ref_1.FunctionRef { | ||
constructor(parent, name, props) { | ||
super(parent, name); | ||
class Alias extends lambda_ref_1.FunctionBase { | ||
constructor(scope, id, props) { | ||
super(scope, id); | ||
this.canCreatePermissions = true; // Not used anyway | ||
@@ -26,2 +27,7 @@ this.underlyingLambda = props.version.lambda; | ||
} | ||
export() { | ||
return { | ||
functionArn: new cdk.Output(this, 'AliasArn', { value: this.functionArn }).makeImportValue().toString() | ||
}; | ||
} | ||
addPermission(name, permission) { | ||
@@ -66,2 +72,2 @@ // Forward addPermission() to the underlying Lambda object | ||
exports.Alias = Alias; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["alias.ts"],"names":[],"mappings":";;AAEA,6CAA2C;AAE3C,yDAA8C;AA8C9C;;GAEG;AACH,MAAa,KAAM,SAAQ,wBAAW;IA6BpC,YAAY,MAAqB,EAAE,IAAY,EAAE,KAAiB;QAChE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QARH,yBAAoB,GAAY,IAAI,CAAC,CAAC,kBAAkB;QAUzE,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;QAE7C,MAAM,KAAK,GAAG,IAAI,2BAAQ,CAAC,IAAI,EAAE,UAAU,EAAE;YAC3C,IAAI,EAAE,KAAK,CAAC,SAAS;YACrB,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,YAAY;YAChD,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,eAAe;YAC9C,aAAa,EAAE,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC;SAClD,CAAC,CAAC;QAEH,8DAA8D;QAC9D,gEAAgE;QAChE,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,GAAG,CAAC;QAC9B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,QAAQ,CAAC;IACpC,CAAC;IAEM,aAAa,CAAC,IAAY,EAAE,UAAsB;QACvD,0DAA0D;QAC1D,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACK,sBAAsB,CAAC,KAAiB;QAC9C,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE;YACtE,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,CAAC,yBAAyB,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAEzD,OAAO;YACL,wBAAwB,EAAE,KAAK,CAAC,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBAC1D,OAAO;oBACL,eAAe,EAAE,EAAE,CAAC,OAAO,CAAC,eAAe;oBAC3C,cAAc,EAAE,EAAE,CAAC,MAAM;iBAC1B,CAAC;YACJ,CAAC,CAAC;SACH,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACK,yBAAyB,CAAC,OAAwB;QACxD,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC5B,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;gBAAE,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;aAAE;YAC7H,OAAO,CAAC,CAAC,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAE3B,IAAI,KAAK,GAAG,CAAC,EAAE;YACb,MAAM,IAAI,KAAK,CAAC,6DAA6D,KAAK,EAAE,CAAC,CAAC;SACvF;IACH,CAAC;CACF;AAxFD,sBAwFC","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/cdk');\nimport { FunctionRef } from './lambda-ref';\nimport { FunctionVersion } from './lambda-version';\nimport { CfnAlias } from './lambda.generated';\nimport { Permission } from './permission';\n\n/**\n * Properties for a new Lambda alias\n */\nexport interface AliasProps {\n  /**\n   * Description for the alias\n   *\n   * @default No description\n   */\n  description?: string;\n\n  /**\n   * Function version this alias refers to\n   *\n   * Use lambda.addVersion() to obtain a new lambda version to refer to.\n   */\n  version: FunctionVersion;\n\n  /**\n   * Name of this alias\n   */\n  aliasName: string;\n\n  /**\n   * Additional versions with individual weights this alias points to\n   *\n   * Individual additional version weights specified here should add up to\n   * (less than) one. All remaining weight is routed to the default\n   * version.\n   *\n   * For example, the config is\n   *\n   *    version: \"1\"\n   *    additionalVersions: [{ version: \"2\", weight: 0.05 }]\n   *\n   * Then 5% of traffic will be routed to function version 2, while\n   * the remaining 95% of traffic will be routed to function version 1.\n   *\n   * @default No additional versions\n   */\n  additionalVersions?: VersionWeight[];\n}\n\n/**\n * A new alias to a particular version of a Lambda function.\n */\nexport class Alias extends FunctionRef {\n  /**\n   * ARN of this alias\n   *\n   * Used to be able to use Alias in place of a regular Lambda. Lambda accepts\n   * ARNs everywhere it accepts function names.\n   */\n  public readonly functionName: string;\n\n  /**\n   * ARN of this alias\n   *\n   * Used to be able to use Alias in place of a regular Lambda. Lambda accepts\n   * ARNs everywhere it accepts function names.\n   */\n  public readonly functionArn: string;\n\n  /**\n   * Role associated with this alias\n   */\n  public readonly role?: iam.Role | undefined;\n\n  protected readonly canCreatePermissions: boolean = true; // Not used anyway\n\n  /**\n   * The actual Lambda function object that this Alias is pointing to\n   */\n  private readonly underlyingLambda: FunctionRef;\n\n  constructor(parent: cdk.Construct, name: string, props: AliasProps) {\n    super(parent, name);\n\n    this.underlyingLambda = props.version.lambda;\n\n    const alias = new CfnAlias(this, 'Resource', {\n      name: props.aliasName,\n      description: props.description,\n      functionName: this.underlyingLambda.functionName,\n      functionVersion: props.version.functionVersion,\n      routingConfig: this.determineRoutingConfig(props)\n    });\n\n    // Not actually the name, but an ARN can be used in all places\n    // where the name is expected, and an ARN can refer to an Alias.\n    this.functionName = alias.ref;\n    this.functionArn = alias.aliasArn;\n  }\n\n  public addPermission(name: string, permission: Permission) {\n    // Forward addPermission() to the underlying Lambda object\n    this.underlyingLambda.addPermission(name, permission);\n  }\n\n  /**\n   * Calculate the routingConfig parameter from the input props\n   */\n  private determineRoutingConfig(props: AliasProps) {\n    if (!props.additionalVersions || props.additionalVersions.length === 0) {\n      return undefined;\n    }\n\n    this.validateAdditionalWeights(props.additionalVersions);\n\n    return {\n      additionalVersionWeights: props.additionalVersions.map(vw => {\n        return {\n          functionVersion: vw.version.functionVersion,\n          functionWeight: vw.weight\n        };\n      })\n    };\n  }\n\n  /**\n   * Validate that the additional version weights make sense\n   *\n   * We validate that they are positive and add up to something <= 1.\n   */\n  private validateAdditionalWeights(weights: VersionWeight[]) {\n    const total = weights.map(w => {\n      if (w.weight < 0 || w.weight > 1) { throw new Error(`Additional version weight must be between 0 and 1, got: ${w.weight}`); }\n      return w.weight;\n    }).reduce((a, x) => a + x);\n\n    if (total > 1) {\n      throw new Error(`Sum of additional version weights must not exceed 1, got: ${total}`);\n    }\n  }\n}\n\n/**\n * A version/weight pair for routing traffic to Lambda functions\n */\nexport interface VersionWeight {\n  /**\n   * The version to route traffic to\n   */\n  readonly version: FunctionVersion;\n\n  /**\n   * How much weight to assign to this version (0..1)\n   */\n  readonly weight: number;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["alias.ts"],"names":[],"mappings":";;AACA,oCAAqC;AACrC,6CAA4E;AAE5E,yDAA8C;AA8C9C;;GAEG;AACH,MAAa,KAAM,SAAQ,yBAAY;IA6BrC,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAiB;QAC7D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QARA,yBAAoB,GAAY,IAAI,CAAC,CAAC,kBAAkB;QAUzE,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;QAE7C,MAAM,KAAK,GAAG,IAAI,2BAAQ,CAAC,IAAI,EAAE,UAAU,EAAE;YAC3C,IAAI,EAAE,KAAK,CAAC,SAAS;YACrB,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,YAAY;YAChD,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,eAAe;YAC9C,aAAa,EAAE,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC;SAClD,CAAC,CAAC;QAEH,8DAA8D;QAC9D,gEAAgE;QAChE,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,GAAG,CAAC;QAC9B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,QAAQ,CAAC;IACpC,CAAC;IAEM,MAAM;QACX,OAAO;YACL,WAAW,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,eAAe,EAAE,CAAC,QAAQ,EAAE;SACxG,CAAC;IACJ,CAAC;IAEM,aAAa,CAAC,IAAY,EAAE,UAAsB;QACvD,0DAA0D;QAC1D,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACK,sBAAsB,CAAC,KAAiB;QAC9C,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE;YACtE,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,CAAC,yBAAyB,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAEzD,OAAO;YACL,wBAAwB,EAAE,KAAK,CAAC,kBAAkB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBAC1D,OAAO;oBACL,eAAe,EAAE,EAAE,CAAC,OAAO,CAAC,eAAe;oBAC3C,cAAc,EAAE,EAAE,CAAC,MAAM;iBAC1B,CAAC;YACJ,CAAC,CAAC;SACH,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACK,yBAAyB,CAAC,OAAwB;QACxD,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC5B,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;gBAAE,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;aAAE;YAC7H,OAAO,CAAC,CAAC,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAE3B,IAAI,KAAK,GAAG,CAAC,EAAE;YACb,MAAM,IAAI,KAAK,CAAC,6DAA6D,KAAK,EAAE,CAAC,CAAC;SACvF;IACH,CAAC;CACF;AA9FD,sBA8FC","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/cdk');\nimport { FunctionBase, FunctionImportProps, IFunction } from './lambda-ref';\nimport { Version } from './lambda-version';\nimport { CfnAlias } from './lambda.generated';\nimport { Permission } from './permission';\n\n/**\n * Properties for a new Lambda alias\n */\nexport interface AliasProps {\n  /**\n   * Description for the alias\n   *\n   * @default No description\n   */\n  description?: string;\n\n  /**\n   * Function version this alias refers to\n   *\n   * Use lambda.addVersion() to obtain a new lambda version to refer to.\n   */\n  version: Version;\n\n  /**\n   * Name of this alias\n   */\n  aliasName: string;\n\n  /**\n   * Additional versions with individual weights this alias points to\n   *\n   * Individual additional version weights specified here should add up to\n   * (less than) one. All remaining weight is routed to the default\n   * version.\n   *\n   * For example, the config is\n   *\n   *    version: \"1\"\n   *    additionalVersions: [{ version: \"2\", weight: 0.05 }]\n   *\n   * Then 5% of traffic will be routed to function version 2, while\n   * the remaining 95% of traffic will be routed to function version 1.\n   *\n   * @default No additional versions\n   */\n  additionalVersions?: VersionWeight[];\n}\n\n/**\n * A new alias to a particular version of a Lambda function.\n */\nexport class Alias extends FunctionBase {\n  /**\n   * ARN of this alias\n   *\n   * Used to be able to use Alias in place of a regular Lambda. Lambda accepts\n   * ARNs everywhere it accepts function names.\n   */\n  public readonly functionName: string;\n\n  /**\n   * ARN of this alias\n   *\n   * Used to be able to use Alias in place of a regular Lambda. Lambda accepts\n   * ARNs everywhere it accepts function names.\n   */\n  public readonly functionArn: string;\n\n  /**\n   * Role associated with this alias\n   */\n  public readonly role?: iam.IRole | undefined;\n\n  protected readonly canCreatePermissions: boolean = true; // Not used anyway\n\n  /**\n   * The actual Lambda function object that this Alias is pointing to\n   */\n  private readonly underlyingLambda: IFunction;\n\n  constructor(scope: cdk.Construct, id: string, props: AliasProps) {\n    super(scope, id);\n\n    this.underlyingLambda = props.version.lambda;\n\n    const alias = new CfnAlias(this, 'Resource', {\n      name: props.aliasName,\n      description: props.description,\n      functionName: this.underlyingLambda.functionName,\n      functionVersion: props.version.functionVersion,\n      routingConfig: this.determineRoutingConfig(props)\n    });\n\n    // Not actually the name, but an ARN can be used in all places\n    // where the name is expected, and an ARN can refer to an Alias.\n    this.functionName = alias.ref;\n    this.functionArn = alias.aliasArn;\n  }\n\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.Output(this, 'AliasArn', { value: this.functionArn }).makeImportValue().toString()\n    };\n  }\n\n  public addPermission(name: string, permission: Permission) {\n    // Forward addPermission() to the underlying Lambda object\n    this.underlyingLambda.addPermission(name, permission);\n  }\n\n  /**\n   * Calculate the routingConfig parameter from the input props\n   */\n  private determineRoutingConfig(props: AliasProps) {\n    if (!props.additionalVersions || props.additionalVersions.length === 0) {\n      return undefined;\n    }\n\n    this.validateAdditionalWeights(props.additionalVersions);\n\n    return {\n      additionalVersionWeights: props.additionalVersions.map(vw => {\n        return {\n          functionVersion: vw.version.functionVersion,\n          functionWeight: vw.weight\n        };\n      })\n    };\n  }\n\n  /**\n   * Validate that the additional version weights make sense\n   *\n   * We validate that they are positive and add up to something <= 1.\n   */\n  private validateAdditionalWeights(weights: VersionWeight[]) {\n    const total = weights.map(w => {\n      if (w.weight < 0 || w.weight > 1) { throw new Error(`Additional version weight must be between 0 and 1, got: ${w.weight}`); }\n      return w.weight;\n    }).reduce((a, x) => a + x);\n\n    if (total > 1) {\n      throw new Error(`Sum of additional version weights must not exceed 1, got: ${total}`);\n    }\n  }\n}\n\n/**\n * A version/weight pair for routing traffic to Lambda functions\n */\nexport interface VersionWeight {\n  /**\n   * The version to route traffic to\n   */\n  readonly version: Version;\n\n  /**\n   * How much weight to assign to this version (0..1)\n   */\n  readonly weight: number;\n}\n"]} |
@@ -12,3 +12,3 @@ import assets = require('@aws-cdk/assets'); | ||
*/ | ||
static bucket(bucket: s3.BucketRef, key: string, objectVersion?: string): S3Code; | ||
static bucket(bucket: s3.IBucket, key: string, objectVersion?: string): S3Code; | ||
/** | ||
@@ -41,3 +41,3 @@ * @returns `LambdaInlineCode` with inline code. | ||
*/ | ||
abstract toJSON(): CfnFunction.CodeProperty; | ||
abstract toJSON(resource: CfnFunction): CfnFunction.CodeProperty; | ||
/** | ||
@@ -56,4 +56,4 @@ * Called when the lambda is initialized to allow this object to | ||
private bucketName; | ||
constructor(bucket: s3.BucketRef, key: string, objectVersion?: string | undefined); | ||
toJSON(): CfnFunction.CodeProperty; | ||
constructor(bucket: s3.IBucket, key: string, objectVersion?: string | undefined); | ||
toJSON(_: CfnFunction): CfnFunction.CodeProperty; | ||
} | ||
@@ -67,3 +67,3 @@ /** | ||
bind(lambda: Func): void; | ||
toJSON(): CfnFunction.CodeProperty; | ||
toJSON(_: CfnFunction): CfnFunction.CodeProperty; | ||
} | ||
@@ -86,3 +86,3 @@ /** | ||
bind(lambda: Func): void; | ||
toJSON(): CfnFunction.CodeProperty; | ||
toJSON(resource: CfnFunction): CfnFunction.CodeProperty; | ||
} |
@@ -68,3 +68,3 @@ "use strict"; | ||
} | ||
toJSON() { | ||
toJSON(_) { | ||
return { | ||
@@ -94,3 +94,3 @@ s3Bucket: this.bucketName, | ||
} | ||
toJSON() { | ||
toJSON(_) { | ||
return { | ||
@@ -134,3 +134,5 @@ zipFile: this.code | ||
} | ||
toJSON() { | ||
toJSON(resource) { | ||
// https://github.com/awslabs/aws-cdk/issues/1432 | ||
this.asset.addResourceMetadata(resource, 'Code'); | ||
return { | ||
@@ -143,2 +145,2 @@ s3Bucket: this.asset.s3BucketName, | ||
exports.AssetCode = AssetCode; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["code.ts"],"names":[],"mappings":"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","sourcesContent":["import assets = require('@aws-cdk/assets');\nimport s3 = require('@aws-cdk/aws-s3');\nimport fs = require('fs');\nimport { Function as Func } from './lambda';\nimport { CfnFunction } from './lambda.generated';\n\nexport abstract class Code {\n  /**\n   * @returns `LambdaS3Code` associated with the specified S3 object.\n   * @param bucket The S3 bucket\n   * @param key The object key\n   * @param objectVersion Optional S3 object version\n   */\n  public static bucket(bucket: s3.BucketRef, key: string, objectVersion?: string) {\n    return new S3Code(bucket, key, objectVersion);\n  }\n\n  /**\n   * @returns `LambdaInlineCode` with inline code.\n   * @param code The actual handler code (limited to 4KiB)\n   */\n  public static inline(code: string) {\n    return new InlineCode(code);\n  }\n\n  /**\n   * Loads the function code from a local disk asset.\n   * @param path Either a directory with the Lambda code bundle or a .zip file\n   */\n  public static asset(path: string) {\n    return new AssetCode(path);\n  }\n\n  /**\n   * @returns Zip archives the contents of a directory on disk and uses this\n   * as the lambda handler's code.\n   * @param directoryToZip The directory to zip\n   * @deprecated use `lambda.Code.asset(path)` (no need to specify if it's a file or a directory)\n   */\n  public static directory(directoryToZip: string) {\n    return new AssetCode(directoryToZip, assets.AssetPackaging.ZipDirectory);\n  }\n\n  /**\n   * @returns Uses a file on disk as a lambda handler's code.\n   * @param filePath The file path\n   * @deprecated use `lambda.Code.asset(path)` (no need to specify if it's a file or a directory)\n   */\n  public static file(filePath: string) {\n    return new AssetCode(filePath, assets.AssetPackaging.File);\n  }\n\n  /**\n   * Called during stack synthesis to render the CodePropery for the\n   * Lambda function.\n   */\n  public abstract toJSON(): CfnFunction.CodeProperty;\n\n  /**\n   * Called when the lambda is initialized to allow this object to\n   * bind to the stack, add resources and have fun.\n   */\n  public bind(_lambda: Func) {\n    return;\n  }\n}\n\n/**\n * Lambda code from an S3 archive.\n */\nexport class S3Code extends Code {\n  private bucketName: string;\n\n  constructor(bucket: s3.BucketRef, private key: string, private objectVersion?: string) {\n    super();\n\n    if (!bucket.bucketName) {\n      throw new Error('bucketName is undefined for the provided bucket');\n    }\n\n    this.bucketName = bucket.bucketName;\n  }\n\n  public toJSON(): CfnFunction.CodeProperty {\n    return {\n      s3Bucket: this.bucketName,\n      s3Key: this.key,\n      s3ObjectVersion: this.objectVersion\n    };\n  }\n}\n\n/**\n * Lambda code from an inline string (limited to 4KiB).\n */\nexport class InlineCode extends Code {\n  constructor(private code: string) {\n    super();\n\n    if (code.length > 4096) {\n      throw new Error(\"Lambda source is too large, must be <= 4096 but is \" + code.length);\n    }\n  }\n\n  public bind(lambda: Func) {\n    if (!lambda.runtime.supportsInlineCode) {\n      throw new Error(`Inline source not allowed for ${lambda.runtime.name}`);\n    }\n  }\n\n  public toJSON(): CfnFunction.CodeProperty {\n    return {\n      zipFile: this.code\n    };\n  }\n}\n\n/**\n * Lambda code from a local directory.\n */\nexport class AssetCode extends Code {\n  /**\n   * The asset packaging.\n   */\n  public readonly packaging: assets.AssetPackaging;\n\n  private asset?: assets.Asset;\n\n  /**\n   * @param path The path to the asset file or directory.\n   * @param packaging The asset packaging format (optional, determined automatically)\n   */\n  constructor(public readonly path: string, packaging?: assets.AssetPackaging) {\n    super();\n\n    if (packaging !== undefined) {\n      this.packaging = packaging;\n    } else {\n      this.packaging = fs.lstatSync(path).isDirectory()\n      ? assets.AssetPackaging.ZipDirectory\n      : assets.AssetPackaging.File;\n    }\n  }\n\n  public bind(lambda: Func) {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = new assets.Asset(lambda, 'Code', {\n        path: this.path,\n        packaging: this.packaging\n      });\n    }\n\n    if (!this.asset.isZipArchive) {\n      throw new Error(`Asset must be a .zip file or a directory (${this.path})`);\n    }\n  }\n\n  public toJSON(): CfnFunction.CodeProperty {\n    return  {\n      s3Bucket: this.asset!.s3BucketName,\n      s3Key: this.asset!.s3ObjectKey\n    };\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["code.ts"],"names":[],"mappings":"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","sourcesContent":["import assets = require('@aws-cdk/assets');\nimport s3 = require('@aws-cdk/aws-s3');\nimport fs = require('fs');\nimport { Function as Func } from './lambda';\nimport { CfnFunction } from './lambda.generated';\n\nexport abstract class Code {\n  /**\n   * @returns `LambdaS3Code` associated with the specified S3 object.\n   * @param bucket The S3 bucket\n   * @param key The object key\n   * @param objectVersion Optional S3 object version\n   */\n  public static bucket(bucket: s3.IBucket, key: string, objectVersion?: string) {\n    return new S3Code(bucket, key, objectVersion);\n  }\n\n  /**\n   * @returns `LambdaInlineCode` with inline code.\n   * @param code The actual handler code (limited to 4KiB)\n   */\n  public static inline(code: string) {\n    return new InlineCode(code);\n  }\n\n  /**\n   * Loads the function code from a local disk asset.\n   * @param path Either a directory with the Lambda code bundle or a .zip file\n   */\n  public static asset(path: string) {\n    return new AssetCode(path);\n  }\n\n  /**\n   * @returns Zip archives the contents of a directory on disk and uses this\n   * as the lambda handler's code.\n   * @param directoryToZip The directory to zip\n   * @deprecated use `lambda.Code.asset(path)` (no need to specify if it's a file or a directory)\n   */\n  public static directory(directoryToZip: string) {\n    return new AssetCode(directoryToZip, assets.AssetPackaging.ZipDirectory);\n  }\n\n  /**\n   * @returns Uses a file on disk as a lambda handler's code.\n   * @param filePath The file path\n   * @deprecated use `lambda.Code.asset(path)` (no need to specify if it's a file or a directory)\n   */\n  public static file(filePath: string) {\n    return new AssetCode(filePath, assets.AssetPackaging.File);\n  }\n\n  /**\n   * Called during stack synthesis to render the CodePropery for the\n   * Lambda function.\n   */\n  public abstract toJSON(resource: CfnFunction): CfnFunction.CodeProperty;\n\n  /**\n   * Called when the lambda is initialized to allow this object to\n   * bind to the stack, add resources and have fun.\n   */\n  public bind(_lambda: Func) {\n    return;\n  }\n}\n\n/**\n * Lambda code from an S3 archive.\n */\nexport class S3Code extends Code {\n  private bucketName: string;\n\n  constructor(bucket: s3.IBucket, private key: string, private objectVersion?: string) {\n    super();\n\n    if (!bucket.bucketName) {\n      throw new Error('bucketName is undefined for the provided bucket');\n    }\n\n    this.bucketName = bucket.bucketName;\n  }\n\n  public toJSON(_: CfnFunction): CfnFunction.CodeProperty {\n    return {\n      s3Bucket: this.bucketName,\n      s3Key: this.key,\n      s3ObjectVersion: this.objectVersion\n    };\n  }\n}\n\n/**\n * Lambda code from an inline string (limited to 4KiB).\n */\nexport class InlineCode extends Code {\n  constructor(private code: string) {\n    super();\n\n    if (code.length > 4096) {\n      throw new Error(\"Lambda source is too large, must be <= 4096 but is \" + code.length);\n    }\n  }\n\n  public bind(lambda: Func) {\n    if (!lambda.runtime.supportsInlineCode) {\n      throw new Error(`Inline source not allowed for ${lambda.runtime.name}`);\n    }\n  }\n\n  public toJSON(_: CfnFunction): CfnFunction.CodeProperty {\n    return {\n      zipFile: this.code\n    };\n  }\n}\n\n/**\n * Lambda code from a local directory.\n */\nexport class AssetCode extends Code {\n  /**\n   * The asset packaging.\n   */\n  public readonly packaging: assets.AssetPackaging;\n\n  private asset?: assets.Asset;\n\n  /**\n   * @param path The path to the asset file or directory.\n   * @param packaging The asset packaging format (optional, determined automatically)\n   */\n  constructor(public readonly path: string, packaging?: assets.AssetPackaging) {\n    super();\n\n    if (packaging !== undefined) {\n      this.packaging = packaging;\n    } else {\n      this.packaging = fs.lstatSync(path).isDirectory()\n      ? assets.AssetPackaging.ZipDirectory\n      : assets.AssetPackaging.File;\n    }\n  }\n\n  public bind(lambda: Func) {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = new assets.Asset(lambda, 'Code', {\n        path: this.path,\n        packaging: this.packaging\n      });\n    }\n\n    if (!this.asset.isZipArchive) {\n      throw new Error(`Asset must be a .zip file or a directory (${this.path})`);\n    }\n  }\n\n  public toJSON(resource: CfnFunction): CfnFunction.CodeProperty {\n    // https://github.com/awslabs/aws-cdk/issues/1432\n    this.asset!.addResourceMetadata(resource, 'Code');\n\n    return  {\n      s3Bucket: this.asset!.s3BucketName,\n      s3Key: this.asset!.s3ObjectKey\n    };\n  }\n}\n"]} |
import cdk = require('@aws-cdk/cdk'); | ||
import { FunctionRef } from './lambda-ref'; | ||
import { IFunction } from './lambda-ref'; | ||
export interface EventSourceMappingProps { | ||
@@ -12,3 +12,3 @@ /** | ||
*/ | ||
target: FunctionRef; | ||
target: IFunction; | ||
/** | ||
@@ -52,3 +52,3 @@ * The largest number of records that AWS Lambda will retrieve from your event | ||
export declare class EventSourceMapping extends cdk.Construct { | ||
constructor(parent: cdk.Construct, id: string, props: EventSourceMappingProps); | ||
constructor(scope: cdk.Construct, id: string, props: EventSourceMappingProps); | ||
} | ||
@@ -55,0 +55,0 @@ /** |
@@ -18,4 +18,4 @@ "use strict"; | ||
class EventSourceMapping extends cdk.Construct { | ||
constructor(parent, id, props) { | ||
super(parent, id); | ||
constructor(scope, id, props) { | ||
super(scope, id); | ||
new lambda_generated_1.CfnEventSourceMapping(this, 'Resource', { | ||
@@ -48,2 +48,2 @@ batchSize: props.batchSize, | ||
})(StartingPosition = exports.StartingPosition || (exports.StartingPosition = {})); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc291cmNlLW1hcHBpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJldmVudC1zb3VyY2UtbWFwcGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUVyQyx5REFBMkQ7QUEwQzNEOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBYSxrQkFBbUIsU0FBUSxHQUFHLENBQUMsU0FBUztJQUNuRCxZQUFZLE1BQXFCLEVBQUUsRUFBVSxFQUFFLEtBQThCO1FBQzNFLEtBQUssQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFbEIsSUFBSSx3Q0FBcUIsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQzFDLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztZQUMxQixPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87WUFDdEIsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ3BDLFlBQVksRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVk7WUFDdkMsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQjtTQUN6QyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFaRCxnREFZQztBQUVEOzs7R0FHRztBQUNILElBQVksZ0JBWVg7QUFaRCxXQUFZLGdCQUFnQjtJQUMxQjs7O09BR0c7SUFDSCxnREFBNEIsQ0FBQTtJQUU1Qjs7O09BR0c7SUFDSCxxQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBWlcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFZM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBGdW5jdGlvblJlZiB9IGZyb20gJy4vbGFtYmRhLXJlZic7XG5pbXBvcnQgeyBDZm5FdmVudFNvdXJjZU1hcHBpbmcgfSBmcm9tICcuL2xhbWJkYS5nZW5lcmF0ZWQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50U291cmNlTWFwcGluZ1Byb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBBbWF6b24gUmVzb3VyY2UgTmFtZSAoQVJOKSBvZiB0aGUgZXZlbnQgc291cmNlLiBBbnkgcmVjb3JkIGFkZGVkIHRvXG4gICAqIHRoaXMgc3RyZWFtIGNhbiBpbnZva2UgdGhlIExhbWJkYSBmdW5jdGlvbi5cbiAgICovXG4gIGV2ZW50U291cmNlQXJuOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSB0YXJnZXQgQVdTIExhbWJkYSBmdW5jdGlvbi5cbiAgICovXG4gIHRhcmdldDogRnVuY3Rpb25SZWY7XG5cbiAgLyoqXG4gICAqIFRoZSBsYXJnZXN0IG51bWJlciBvZiByZWNvcmRzIHRoYXQgQVdTIExhbWJkYSB3aWxsIHJldHJpZXZlIGZyb20geW91ciBldmVudFxuICAgKiBzb3VyY2UgYXQgdGhlIHRpbWUgb2YgaW52b2tpbmcgeW91ciBmdW5jdGlvbi4gWW91ciBmdW5jdGlvbiByZWNlaXZlcyBhblxuICAgKiBldmVudCB3aXRoIGFsbCB0aGUgcmV0cmlldmVkIHJlY29yZHMuXG4gICAqXG4gICAqIFZhbGlkIFJhbmdlOiBNaW5pbXVtIHZhbHVlIG9mIDEuIE1heGltdW0gdmFsdWUgb2YgMTAwMDAuXG4gICAqXG4gICAqIEBkZWZhdWx0IFRoZSBkZWZhdWx0IGZvciBBbWF6b24gS2luZXNpcyBhbmQgQW1hem9uIER5bmFtb0RCIGlzIDEwMCByZWNvcmRzLlxuICAgKiBCb3RoIHRoZSBkZWZhdWx0IGFuZCBtYXhpbXVtIGZvciBBbWF6b24gU1FTIGFyZSAxMCBtZXNzYWdlcy5cbiAgICovXG4gIGJhdGNoU2l6ZT86IG51bWJlcjtcblxuICAvKipcbiAgICogU2V0IHRvIGZhbHNlIHRvIGRpc2FibGUgdGhlIGV2ZW50IHNvdXJjZSB1cG9uIGNyZWF0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICBlbmFibGVkPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogVGhlIHBvc2l0aW9uIGluIHRoZSBEeW5hbW9EQiBvciBLaW5lc2lzIHN0cmVhbSB3aGVyZSBBV1MgTGFtYmRhIHNob3VsZFxuICAgKiBzdGFydCByZWFkaW5nLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9raW5lc2lzL2xhdGVzdC9BUElSZWZlcmVuY2UvQVBJX0dldFNoYXJkSXRlcmF0b3IuaHRtbCNLaW5lc2lzLUdldFNoYXJkSXRlcmF0b3ItcmVxdWVzdC1TaGFyZEl0ZXJhdG9yVHlwZVxuICAgKi9cbiAgc3RhcnRpbmdQb3NpdGlvbj86IFN0YXJ0aW5nUG9zaXRpb25cbn1cblxuLyoqXG4gKiBEZWZpbmVzIGEgTGFtYmRhIEV2ZW50U291cmNlTWFwcGluZyByZXNvdXJjZS5cbiAqXG4gKiBVc3VhbGx5LCB5b3Ugd29uJ3QgbmVlZCB0byBkZWZpbmUgdGhlIG1hcHBpbmcgeW91cnNlbGYuIFRoaXMgd2lsbCB1c3VhbGx5IGJlIGRvbmUgYnlcbiAqIGV2ZW50IHNvdXJjZXMuIEZvciBleGFtcGxlLCB0byBhZGQgYW4gU1FTIGV2ZW50IHNvdXJjZSB0byBhIGZ1bmN0aW9uOlxuICpcbiAqICAgIGltcG9ydCB7IFNxc0V2ZW50U291cmNlIH0gZnJvbSAnQGF3cy1jZGsvYXdzLWxhbWJkYS1ldmVudC1zb3VyY2VzJztcbiAqICAgIGxhbWJkYS5hZGRFdmVudFNvdXJjZShuZXcgU3FzRXZlbnRTb3VyY2Uoc3FzKSk7XG4gKlxuICogVGhlIGBTcXNFdmVudFNvdXJjZWAgY2xhc3Mgd2lsbCBhdXRvbWF0aWNhbGx5IGNyZWF0ZSB0aGUgbWFwcGluZywgYW5kIHdpbGwgYWxzb1xuICogbW9kaWZ5IHRoZSBMYW1iZGEncyBleGVjdXRpb24gcm9sZSBzbyBpdCBjYW4gY29uc3VtZSBtZXNzYWdlcyBmcm9tIHRoZSBxdWV1ZS5cbiAqL1xuZXhwb3J0IGNsYXNzIEV2ZW50U291cmNlTWFwcGluZyBleHRlbmRzIGNkay5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBFdmVudFNvdXJjZU1hcHBpbmdQcm9wcykge1xuICAgIHN1cGVyKHBhcmVudCwgaWQpO1xuXG4gICAgbmV3IENmbkV2ZW50U291cmNlTWFwcGluZyh0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBiYXRjaFNpemU6IHByb3BzLmJhdGNoU2l6ZSxcbiAgICAgIGVuYWJsZWQ6IHByb3BzLmVuYWJsZWQsXG4gICAgICBldmVudFNvdXJjZUFybjogcHJvcHMuZXZlbnRTb3VyY2VBcm4sXG4gICAgICBmdW5jdGlvbk5hbWU6IHByb3BzLnRhcmdldC5mdW5jdGlvbk5hbWUsXG4gICAgICBzdGFydGluZ1Bvc2l0aW9uOiBwcm9wcy5zdGFydGluZ1Bvc2l0aW9uLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogVGhlIHBvc2l0aW9uIGluIHRoZSBEeW5hbW9EQiBvciBLaW5lc2lzIHN0cmVhbSB3aGVyZSBBV1MgTGFtYmRhIHNob3VsZCBzdGFydFxuICogcmVhZGluZy5cbiAqL1xuZXhwb3J0IGVudW0gU3RhcnRpbmdQb3NpdGlvbiB7XG4gIC8qKlxuICAgKiBTdGFydCByZWFkaW5nIGF0IHRoZSBsYXN0IHVudHJpbW1lZCByZWNvcmQgaW4gdGhlIHNoYXJkIGluIHRoZSBzeXN0ZW0sXG4gICAqIHdoaWNoIGlzIHRoZSBvbGRlc3QgZGF0YSByZWNvcmQgaW4gdGhlIHNoYXJkLlxuICAgKi9cbiAgVHJpbUhvcml6b24gPSAnVFJJTV9IT1JJWk9OJyxcblxuICAvKipcbiAgICogU3RhcnQgcmVhZGluZyBqdXN0IGFmdGVyIHRoZSBtb3N0IHJlY2VudCByZWNvcmQgaW4gdGhlIHNoYXJkLCBzbyB0aGF0IHlvdVxuICAgKiBhbHdheXMgcmVhZCB0aGUgbW9zdCByZWNlbnQgZGF0YSBpbiB0aGUgc2hhcmRcbiAgICovXG4gIExhdGVzdCA9ICdMQVRFU1QnLFxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc291cmNlLW1hcHBpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJldmVudC1zb3VyY2UtbWFwcGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUVyQyx5REFBMkQ7QUEwQzNEOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBYSxrQkFBbUIsU0FBUSxHQUFHLENBQUMsU0FBUztJQUNuRCxZQUFZLEtBQW9CLEVBQUUsRUFBVSxFQUFFLEtBQThCO1FBQzFFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSx3Q0FBcUIsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQzFDLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztZQUMxQixPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87WUFDdEIsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ3BDLFlBQVksRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVk7WUFDdkMsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQjtTQUN6QyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFaRCxnREFZQztBQUVEOzs7R0FHRztBQUNILElBQVksZ0JBWVg7QUFaRCxXQUFZLGdCQUFnQjtJQUMxQjs7O09BR0c7SUFDSCxnREFBNEIsQ0FBQTtJQUU1Qjs7O09BR0c7SUFDSCxxQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBWlcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFZM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBJRnVuY3Rpb24gfSBmcm9tICcuL2xhbWJkYS1yZWYnO1xuaW1wb3J0IHsgQ2ZuRXZlbnRTb3VyY2VNYXBwaW5nIH0gZnJvbSAnLi9sYW1iZGEuZ2VuZXJhdGVkJztcblxuZXhwb3J0IGludGVyZmFjZSBFdmVudFNvdXJjZU1hcHBpbmdQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgQW1hem9uIFJlc291cmNlIE5hbWUgKEFSTikgb2YgdGhlIGV2ZW50IHNvdXJjZS4gQW55IHJlY29yZCBhZGRlZCB0b1xuICAgKiB0aGlzIHN0cmVhbSBjYW4gaW52b2tlIHRoZSBMYW1iZGEgZnVuY3Rpb24uXG4gICAqL1xuICBldmVudFNvdXJjZUFybjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgdGFyZ2V0IEFXUyBMYW1iZGEgZnVuY3Rpb24uXG4gICAqL1xuICB0YXJnZXQ6IElGdW5jdGlvbjtcblxuICAvKipcbiAgICogVGhlIGxhcmdlc3QgbnVtYmVyIG9mIHJlY29yZHMgdGhhdCBBV1MgTGFtYmRhIHdpbGwgcmV0cmlldmUgZnJvbSB5b3VyIGV2ZW50XG4gICAqIHNvdXJjZSBhdCB0aGUgdGltZSBvZiBpbnZva2luZyB5b3VyIGZ1bmN0aW9uLiBZb3VyIGZ1bmN0aW9uIHJlY2VpdmVzIGFuXG4gICAqIGV2ZW50IHdpdGggYWxsIHRoZSByZXRyaWV2ZWQgcmVjb3Jkcy5cbiAgICpcbiAgICogVmFsaWQgUmFuZ2U6IE1pbmltdW0gdmFsdWUgb2YgMS4gTWF4aW11bSB2YWx1ZSBvZiAxMDAwMC5cbiAgICpcbiAgICogQGRlZmF1bHQgVGhlIGRlZmF1bHQgZm9yIEFtYXpvbiBLaW5lc2lzIGFuZCBBbWF6b24gRHluYW1vREIgaXMgMTAwIHJlY29yZHMuXG4gICAqIEJvdGggdGhlIGRlZmF1bHQgYW5kIG1heGltdW0gZm9yIEFtYXpvbiBTUVMgYXJlIDEwIG1lc3NhZ2VzLlxuICAgKi9cbiAgYmF0Y2hTaXplPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBTZXQgdG8gZmFsc2UgdG8gZGlzYWJsZSB0aGUgZXZlbnQgc291cmNlIHVwb24gY3JlYXRpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0IHRydWVcbiAgICovXG4gIGVuYWJsZWQ/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBUaGUgcG9zaXRpb24gaW4gdGhlIER5bmFtb0RCIG9yIEtpbmVzaXMgc3RyZWFtIHdoZXJlIEFXUyBMYW1iZGEgc2hvdWxkXG4gICAqIHN0YXJ0IHJlYWRpbmcuXG4gICAqXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2tpbmVzaXMvbGF0ZXN0L0FQSVJlZmVyZW5jZS9BUElfR2V0U2hhcmRJdGVyYXRvci5odG1sI0tpbmVzaXMtR2V0U2hhcmRJdGVyYXRvci1yZXF1ZXN0LVNoYXJkSXRlcmF0b3JUeXBlXG4gICAqL1xuICBzdGFydGluZ1Bvc2l0aW9uPzogU3RhcnRpbmdQb3NpdGlvblxufVxuXG4vKipcbiAqIERlZmluZXMgYSBMYW1iZGEgRXZlbnRTb3VyY2VNYXBwaW5nIHJlc291cmNlLlxuICpcbiAqIFVzdWFsbHksIHlvdSB3b24ndCBuZWVkIHRvIGRlZmluZSB0aGUgbWFwcGluZyB5b3Vyc2VsZi4gVGhpcyB3aWxsIHVzdWFsbHkgYmUgZG9uZSBieVxuICogZXZlbnQgc291cmNlcy4gRm9yIGV4YW1wbGUsIHRvIGFkZCBhbiBTUVMgZXZlbnQgc291cmNlIHRvIGEgZnVuY3Rpb246XG4gKlxuICogICAgaW1wb3J0IHsgU3FzRXZlbnRTb3VyY2UgfSBmcm9tICdAYXdzLWNkay9hd3MtbGFtYmRhLWV2ZW50LXNvdXJjZXMnO1xuICogICAgbGFtYmRhLmFkZEV2ZW50U291cmNlKG5ldyBTcXNFdmVudFNvdXJjZShzcXMpKTtcbiAqXG4gKiBUaGUgYFNxc0V2ZW50U291cmNlYCBjbGFzcyB3aWxsIGF1dG9tYXRpY2FsbHkgY3JlYXRlIHRoZSBtYXBwaW5nLCBhbmQgd2lsbCBhbHNvXG4gKiBtb2RpZnkgdGhlIExhbWJkYSdzIGV4ZWN1dGlvbiByb2xlIHNvIGl0IGNhbiBjb25zdW1lIG1lc3NhZ2VzIGZyb20gdGhlIHF1ZXVlLlxuICovXG5leHBvcnQgY2xhc3MgRXZlbnRTb3VyY2VNYXBwaW5nIGV4dGVuZHMgY2RrLkNvbnN0cnVjdCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBjZGsuQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogRXZlbnRTb3VyY2VNYXBwaW5nUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgbmV3IENmbkV2ZW50U291cmNlTWFwcGluZyh0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBiYXRjaFNpemU6IHByb3BzLmJhdGNoU2l6ZSxcbiAgICAgIGVuYWJsZWQ6IHByb3BzLmVuYWJsZWQsXG4gICAgICBldmVudFNvdXJjZUFybjogcHJvcHMuZXZlbnRTb3VyY2VBcm4sXG4gICAgICBmdW5jdGlvbk5hbWU6IHByb3BzLnRhcmdldC5mdW5jdGlvbk5hbWUsXG4gICAgICBzdGFydGluZ1Bvc2l0aW9uOiBwcm9wcy5zdGFydGluZ1Bvc2l0aW9uLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogVGhlIHBvc2l0aW9uIGluIHRoZSBEeW5hbW9EQiBvciBLaW5lc2lzIHN0cmVhbSB3aGVyZSBBV1MgTGFtYmRhIHNob3VsZCBzdGFydFxuICogcmVhZGluZy5cbiAqL1xuZXhwb3J0IGVudW0gU3RhcnRpbmdQb3NpdGlvbiB7XG4gIC8qKlxuICAgKiBTdGFydCByZWFkaW5nIGF0IHRoZSBsYXN0IHVudHJpbW1lZCByZWNvcmQgaW4gdGhlIHNoYXJkIGluIHRoZSBzeXN0ZW0sXG4gICAqIHdoaWNoIGlzIHRoZSBvbGRlc3QgZGF0YSByZWNvcmQgaW4gdGhlIHNoYXJkLlxuICAgKi9cbiAgVHJpbUhvcml6b24gPSAnVFJJTV9IT1JJWk9OJyxcblxuICAvKipcbiAgICogU3RhcnQgcmVhZGluZyBqdXN0IGFmdGVyIHRoZSBtb3N0IHJlY2VudCByZWNvcmQgaW4gdGhlIHNoYXJkLCBzbyB0aGF0IHlvdVxuICAgKiBhbHdheXMgcmVhZCB0aGUgbW9zdCByZWNlbnQgZGF0YSBpbiB0aGUgc2hhcmRcbiAgICovXG4gIExhdGVzdCA9ICdMQVRFU1QnLFxufVxuIl19 |
@@ -1,2 +0,2 @@ | ||
import { FunctionRef } from './lambda-ref'; | ||
import { FunctionBase } from './lambda-ref'; | ||
/** | ||
@@ -11,3 +11,3 @@ * An abstract class which represents an AWS Lambda event source. | ||
*/ | ||
bind(target: FunctionRef): void; | ||
bind(target: FunctionBase): void; | ||
} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc291cmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXZlbnQtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGdW5jdGlvblJlZiB9IGZyb20gJy4vbGFtYmRhLXJlZic7XG5cbi8qKlxuICogQW4gYWJzdHJhY3QgY2xhc3Mgd2hpY2ggcmVwcmVzZW50cyBhbiBBV1MgTGFtYmRhIGV2ZW50IHNvdXJjZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJRXZlbnRTb3VyY2Uge1xuICAvKipcbiAgICogQ2FsbGVkIGJ5IGBsYW1iZGEuYWRkRXZlbnRTb3VyY2VgIHRvIGFsbG93IHRoZSBldmVudCBzb3VyY2UgdG8gYmluZCB0byB0aGlzXG4gICAqIGZ1bmN0aW9uLlxuICAgKiBAcGFyYW0gdGFyZ2V0IFRoYXQgbGFtYmRhIGZ1bmN0aW9uIHRvIGJpbmQgdG8uXG4gICAqL1xuICBiaW5kKHRhcmdldDogRnVuY3Rpb25SZWYpOiB2b2lkO1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc291cmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXZlbnQtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGdW5jdGlvbkJhc2UgfSBmcm9tICcuL2xhbWJkYS1yZWYnO1xuXG4vKipcbiAqIEFuIGFic3RyYWN0IGNsYXNzIHdoaWNoIHJlcHJlc2VudHMgYW4gQVdTIExhbWJkYSBldmVudCBzb3VyY2UuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSUV2ZW50U291cmNlIHtcbiAgLyoqXG4gICAqIENhbGxlZCBieSBgbGFtYmRhLmFkZEV2ZW50U291cmNlYCB0byBhbGxvdyB0aGUgZXZlbnQgc291cmNlIHRvIGJpbmQgdG8gdGhpc1xuICAgKiBmdW5jdGlvbi5cbiAgICogQHBhcmFtIHRhcmdldCBUaGF0IGxhbWJkYSBmdW5jdGlvbiB0byBiaW5kIHRvLlxuICAgKi9cbiAgYmluZCh0YXJnZXQ6IEZ1bmN0aW9uQmFzZSk6IHZvaWQ7XG59XG4iXX0= |
@@ -13,80 +13,105 @@ import cloudwatch = require('@aws-cdk/aws-cloudwatch'); | ||
import { CommonPipelineInvokeActionProps, PipelineInvokeAction } from './pipeline-action'; | ||
/** | ||
* Represents a Lambda function defined outside of this stack. | ||
*/ | ||
export interface FunctionRefProps { | ||
export interface IFunction extends cdk.IConstruct, events.IEventRuleTarget, logs.ILogSubscriptionDestination, s3n.IBucketNotificationDestination, ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource { | ||
/** | ||
* The ARN of the Lambda function. | ||
* | ||
* Format: arn:<partition>:lambda:<region>:<account-id>:function:<function-name> | ||
* Logical ID of this Function. | ||
*/ | ||
functionArn: string; | ||
readonly id: string; | ||
/** | ||
* The IAM execution role associated with this function. | ||
* | ||
* If the role is not specified, any role-related operations will no-op. | ||
* The name of the function. | ||
*/ | ||
role?: iam.Role; | ||
readonly functionName: string; | ||
/** | ||
* Id of the securityGroup for this Lambda, if in a VPC. | ||
* The ARN fo the function. | ||
*/ | ||
readonly functionArn: string; | ||
/** | ||
* The IAM role associated with this function. | ||
*/ | ||
readonly role?: iam.IRole; | ||
/** | ||
* Whether or not this Lambda function was bound to a VPC | ||
* | ||
* This needs to be given in order to support allowing connections | ||
* to this Lambda. | ||
* If this is is `false`, trying to access the `connections` object will fail. | ||
*/ | ||
securityGroupId?: string; | ||
} | ||
export declare abstract class FunctionRef extends cdk.Construct implements events.IEventRuleTarget, logs.ILogSubscriptionDestination, s3n.IBucketNotificationDestination, ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource { | ||
readonly isBoundToVpc: boolean; | ||
/** | ||
* Creates a Lambda function object which represents a function not defined | ||
* within this stack. | ||
* Adds a permission to the Lambda resource policy. | ||
* @param id The id ƒor the permission construct | ||
*/ | ||
addPermission(id: string, permission: Permission): void; | ||
/** | ||
* Convenience method for creating a new {@link PipelineInvokeAction}, | ||
* and adding it to the given Stage. | ||
* | ||
* Lambda.import(this, 'MyImportedFunction', { lambdaArn: new LambdaArn('arn:aws:...') }); | ||
* | ||
* @param parent The parent construct | ||
* @param name The name of the lambda construct | ||
* @param ref A reference to a Lambda function. Can be created manually (see | ||
* example above) or obtained through a call to `lambda.export()`. | ||
* @param stage the Pipeline Stage to add the new Action to | ||
* @param name the name of the newly created Action | ||
* @param props the properties of the new Action | ||
* @returns the newly created {@link PipelineInvokeAction} | ||
*/ | ||
static import(parent: cdk.Construct, name: string, ref: FunctionRefProps): FunctionRef; | ||
addToPipeline(stage: codepipeline.IStage, name: string, props?: CommonPipelineInvokeActionProps): PipelineInvokeAction; | ||
addToRolePolicy(statement: iam.PolicyStatement): void; | ||
/** | ||
* Grant the given identity permissions to invoke this Lambda | ||
*/ | ||
grantInvoke(identity?: iam.IPrincipal): void; | ||
/** | ||
* Return the given named metric for this Lambda | ||
*/ | ||
static metricAll(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of Errors executing all Lambdas | ||
* Metric for the Errors executing this Lambda | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
metricErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the Duration executing all Lambdas | ||
* Metric for the Duration of this Lambda | ||
* | ||
* @default average over 5 minutes | ||
*/ | ||
static metricAllDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
metricDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of invocations of all Lambdas | ||
* Metric for the number of invocations of this Lambda | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
metricInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of throttled invocations of all Lambdas | ||
* Metric for the number of throttled invocations of this Lambda | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
metricThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of concurrent executions across all Lambdas | ||
* Export this Function (without the role) | ||
*/ | ||
export(): FunctionImportProps; | ||
addEventSource(source: IEventSource): void; | ||
} | ||
/** | ||
* Represents a Lambda function defined outside of this stack. | ||
*/ | ||
export interface FunctionImportProps { | ||
/** | ||
* The ARN of the Lambda function. | ||
* | ||
* @default max over 5 minutes | ||
* Format: arn:<partition>:lambda:<region>:<account-id>:function:<function-name> | ||
*/ | ||
static metricAllConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
functionArn: string; | ||
/** | ||
* Metric for the number of unreserved concurrent executions across all Lambdas | ||
* The IAM execution role associated with this function. | ||
* | ||
* @default max over 5 minutes | ||
* If the role is not specified, any role-related operations will no-op. | ||
*/ | ||
static metricAllUnreservedConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
role?: iam.IRole; | ||
/** | ||
* Id of the securityGroup for this Lambda, if in a VPC. | ||
* | ||
* This needs to be given in order to support allowing connections | ||
* to this Lambda. | ||
*/ | ||
securityGroupId?: string; | ||
} | ||
export declare abstract class FunctionBase extends cdk.Construct implements IFunction { | ||
/** | ||
* The name of the function. | ||
@@ -102,3 +127,3 @@ */ | ||
*/ | ||
abstract readonly role?: iam.Role; | ||
abstract readonly role?: iam.IRole; | ||
/** | ||
@@ -125,2 +150,3 @@ * Whether the addPermission() call adds any permissions | ||
addPermission(id: string, permission: Permission): void; | ||
readonly id: string; | ||
/** | ||
@@ -186,7 +212,7 @@ * Convenience method for creating a new {@link PipelineInvokeAction}, | ||
metricThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
logSubscriptionDestination(sourceLogGroup: logs.LogGroupRef): logs.LogSubscriptionDestination; | ||
logSubscriptionDestination(sourceLogGroup: logs.ILogGroup): logs.LogSubscriptionDestination; | ||
/** | ||
* Export this Function (without the role) | ||
*/ | ||
export(): FunctionRefProps; | ||
abstract export(): FunctionImportProps; | ||
/** | ||
@@ -193,0 +219,0 @@ * Allows this Lambda to be used as a destination for bucket notifications. |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const cloudwatch = require("@aws-cdk/aws-cloudwatch"); | ||
const ec2 = require("@aws-cdk/aws-ec2"); | ||
const iam = require("@aws-cdk/aws-iam"); | ||
@@ -10,3 +9,3 @@ const s3n = require("@aws-cdk/aws-s3-notifications"); | ||
const pipeline_action_1 = require("./pipeline-action"); | ||
class FunctionRef extends cdk.Construct { | ||
class FunctionBase extends cdk.Construct { | ||
constructor() { | ||
@@ -20,76 +19,2 @@ super(...arguments); | ||
/** | ||
* Creates a Lambda function object which represents a function not defined | ||
* within this stack. | ||
* | ||
* Lambda.import(this, 'MyImportedFunction', { lambdaArn: new LambdaArn('arn:aws:...') }); | ||
* | ||
* @param parent The parent construct | ||
* @param name The name of the lambda construct | ||
* @param ref A reference to a Lambda function. Can be created manually (see | ||
* example above) or obtained through a call to `lambda.export()`. | ||
*/ | ||
static import(parent, name, ref) { | ||
return new LambdaRefImport(parent, name, ref); | ||
} | ||
/** | ||
* Return the given named metric for this Lambda | ||
*/ | ||
static metricAll(metricName, props) { | ||
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/Lambda', metricName }, props)); | ||
} | ||
/** | ||
* Metric for the number of Errors executing all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllErrors(props) { | ||
return FunctionRef.metricAll('Errors', Object.assign({ statistic: 'sum' }, props)); | ||
} | ||
/** | ||
* Metric for the Duration executing all Lambdas | ||
* | ||
* @default average over 5 minutes | ||
*/ | ||
static metricAllDuration(props) { | ||
return FunctionRef.metricAll('Duration', props); | ||
} | ||
/** | ||
* Metric for the number of invocations of all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllInvocations(props) { | ||
return FunctionRef.metricAll('Invocations', Object.assign({ statistic: 'sum' }, props)); | ||
} | ||
/** | ||
* Metric for the number of throttled invocations of all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllThrottles(props) { | ||
return FunctionRef.metricAll('Throttles', Object.assign({ statistic: 'sum' }, props)); | ||
} | ||
/** | ||
* Metric for the number of concurrent executions across all Lambdas | ||
* | ||
* @default max over 5 minutes | ||
*/ | ||
static metricAllConcurrentExecutions(props) { | ||
// Mini-FAQ: why max? This metric is a gauge that is emitted every | ||
// minute, so either max or avg or a percentile make sense (but sum | ||
// doesn't). Max is more sensitive to spiky load changes which is | ||
// probably what you're interested in if you're looking at this metric | ||
// (Load spikes may lead to concurrent execution errors that would | ||
// otherwise not be visible in the avg) | ||
return FunctionRef.metricAll('ConcurrentExecutions', Object.assign({ statistic: 'max' }, props)); | ||
} | ||
/** | ||
* Metric for the number of unreserved concurrent executions across all Lambdas | ||
* | ||
* @default max over 5 minutes | ||
*/ | ||
static metricAllUnreservedConcurrentExecutions(props) { | ||
return FunctionRef.metricAll('UnreservedConcurrentExecutions', Object.assign({ statistic: 'max' }, props)); | ||
} | ||
/** | ||
* Adds a permission to the Lambda resource policy. | ||
@@ -114,2 +39,5 @@ * @param id The id ƒor the permission construct | ||
} | ||
get id() { | ||
return this.node.id; | ||
} | ||
/** | ||
@@ -159,3 +87,3 @@ * Convenience method for creating a new {@link PipelineInvokeAction}, | ||
const permissionId = `AllowEventRule${ruleId}`; | ||
if (!this.tryFindChild(permissionId)) { | ||
if (!this.node.tryFindChild(permissionId)) { | ||
this.addPermission(permissionId, { | ||
@@ -168,3 +96,3 @@ action: 'lambda:InvokeFunction', | ||
return { | ||
id: this.id, | ||
id: this.node.id, | ||
arn: this.functionArn, | ||
@@ -224,2 +152,3 @@ }; | ||
if (this.logSubscriptionDestinationPolicyAddedFor.indexOf(arn) === -1) { | ||
const stack = cdk.Stack.find(this); | ||
// NOTE: the use of {AWS::Region} limits this to the same region, which shouldn't really be an issue, | ||
@@ -230,3 +159,3 @@ // since the Lambda must be in the same region as the SubscriptionFilter anyway. | ||
this.addPermission('InvokedByCloudWatchLogs', { | ||
principal: new iam.ServicePrincipal(new cdk.FnConcat('logs.', new cdk.AwsRegion(), '.amazonaws.com').toString()), | ||
principal: new iam.ServicePrincipal(`logs.${stack.region}.amazonaws.com`), | ||
sourceArn: arn | ||
@@ -239,13 +168,2 @@ }); | ||
/** | ||
* Export this Function (without the role) | ||
*/ | ||
export() { | ||
return { | ||
functionArn: new cdk.Output(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(), | ||
securityGroupId: this._connections && this._connections.securityGroups[0] | ||
? new cdk.Output(this, 'SecurityGroupId', { value: this._connections.securityGroups[0].securityGroupId }).makeImportValue().toString() | ||
: undefined | ||
}; | ||
} | ||
/** | ||
* Allows this Lambda to be used as a destination for bucket notifications. | ||
@@ -256,5 +174,6 @@ * Use `bucket.onEvent(lambda)` to subscribe. | ||
const permissionId = `AllowBucketNotificationsFrom${bucketId}`; | ||
if (!this.tryFindChild(permissionId)) { | ||
const stack = cdk.Stack.find(this); | ||
if (!this.node.tryFindChild(permissionId)) { | ||
this.addPermission(permissionId, { | ||
sourceAccount: new cdk.AwsAccountId().toString(), | ||
sourceAccount: stack.accountId, | ||
principal: new iam.ServicePrincipal('s3.amazonaws.com'), | ||
@@ -266,3 +185,3 @@ sourceArn: bucketArn, | ||
// to the bucket notifications resource, so it will be created first. | ||
const permission = this.tryFindChild(permissionId); | ||
const permission = this.node.tryFindChild(permissionId); | ||
return { | ||
@@ -312,39 +231,7 @@ type: s3n.BucketNotificationDestinationType.Lambda, | ||
} | ||
throw new Error(`Invalid principal type for Lambda permission statement: ${JSON.stringify(cdk.resolve(principal))}. ` + | ||
throw new Error(`Invalid principal type for Lambda permission statement: ${JSON.stringify(this.node.resolve(principal))}. ` + | ||
'Supported: AccountPrincipal, ServicePrincipal'); | ||
} | ||
} | ||
exports.FunctionRef = FunctionRef; | ||
class LambdaRefImport extends FunctionRef { | ||
constructor(parent, name, props) { | ||
super(parent, name); | ||
this.canCreatePermissions = false; | ||
this.functionArn = props.functionArn; | ||
this.functionName = this.extractNameFromArn(props.functionArn); | ||
this.role = props.role; | ||
if (props.securityGroupId) { | ||
this._connections = new ec2.Connections({ | ||
securityGroups: [ec2.SecurityGroupRef.import(this, 'SecurityGroup', { | ||
securityGroupId: props.securityGroupId | ||
})] | ||
}); | ||
} | ||
} | ||
/** | ||
* Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function | ||
* name from the ARN. | ||
* | ||
* Function ARNs look like this: | ||
* | ||
* arn:aws:lambda:region:account-id:function:function-name | ||
* | ||
* ..which means that in order to extract the `function-name` component from the ARN, we can | ||
* split the ARN using ":" and select the component in index 6. | ||
* | ||
* @returns `FnSelect(6, FnSplit(':', arn))` | ||
*/ | ||
extractNameFromArn(arn) { | ||
return new cdk.FnSelect(6, new cdk.FnSplit(':', arn)).toString(); | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-ref.js","sourceRoot":"","sources":["lambda-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport codepipeline = require('@aws-cdk/aws-codepipeline-api');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport events = require('@aws-cdk/aws-events');\nimport iam = require('@aws-cdk/aws-iam');\nimport logs = require('@aws-cdk/aws-logs');\nimport s3n = require('@aws-cdk/aws-s3-notifications');\nimport stepfunctions = require('@aws-cdk/aws-stepfunctions');\nimport cdk = require('@aws-cdk/cdk');\nimport { IEventSource } from './event-source';\nimport { CfnPermission } from './lambda.generated';\nimport { Permission } from './permission';\nimport { CommonPipelineInvokeActionProps, PipelineInvokeAction } from './pipeline-action';\n\n/**\n * Represents a Lambda function defined outside of this stack.\n */\nexport interface FunctionRefProps {\n  /**\n   * The ARN of the Lambda function.\n   *\n   * Format: arn:<partition>:lambda:<region>:<account-id>:function:<function-name>\n   */\n  functionArn: string;\n\n  /**\n   * The IAM execution role associated with this function.\n   *\n   * If the role is not specified, any role-related operations will no-op.\n   */\n  role?: iam.Role;\n\n  /**\n   * Id of the securityGroup for this Lambda, if in a VPC.\n   *\n   * This needs to be given in order to support allowing connections\n   * to this Lambda.\n   */\n  securityGroupId?: string;\n}\n\nexport abstract class FunctionRef extends cdk.Construct\n  implements events.IEventRuleTarget, logs.ILogSubscriptionDestination, s3n.IBucketNotificationDestination,\n         ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource  {\n\n  /**\n   * Creates a Lambda function object which represents a function not defined\n   * within this stack.\n   *\n   *    Lambda.import(this, 'MyImportedFunction', { lambdaArn: new LambdaArn('arn:aws:...') });\n   *\n   * @param parent The parent construct\n   * @param name The name of the lambda construct\n   * @param ref A reference to a Lambda function. Can be created manually (see\n   * example above) or obtained through a call to `lambda.export()`.\n   */\n  public static import(parent: cdk.Construct, name: string, ref: FunctionRefProps): FunctionRef {\n    return new LambdaRefImport(parent, name, ref);\n  }\n\n  /**\n   * Return the given named metric for this Lambda\n   */\n  public static metricAll(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/Lambda',\n      metricName,\n      ...props\n    });\n  }\n  /**\n   * Metric for the number of Errors executing all Lambdas\n   *\n   * @default sum over 5 minutes\n   */\n  public static metricAllErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return FunctionRef.metricAll('Errors', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the Duration executing all Lambdas\n   *\n   * @default average over 5 minutes\n   */\n  public static metricAllDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return FunctionRef.metricAll('Duration', props);\n  }\n\n  /**\n   * Metric for the number of invocations of all Lambdas\n   *\n   * @default sum over 5 minutes\n   */\n  public static metricAllInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return FunctionRef.metricAll('Invocations', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the number of throttled invocations of all Lambdas\n   *\n   * @default sum over 5 minutes\n   */\n  public static metricAllThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return FunctionRef.metricAll('Throttles', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the number of concurrent executions across all Lambdas\n   *\n   * @default max over 5 minutes\n   */\n  public static metricAllConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    // Mini-FAQ: why max? This metric is a gauge that is emitted every\n    // minute, so either max or avg or a percentile make sense (but sum\n    // doesn't). Max is more sensitive to spiky load changes which is\n    // probably what you're interested in if you're looking at this metric\n    // (Load spikes may lead to concurrent execution errors that would\n    // otherwise not be visible in the avg)\n    return FunctionRef.metricAll('ConcurrentExecutions', { statistic: 'max', ...props });\n  }\n\n  /**\n   * Metric for the number of unreserved concurrent executions across all Lambdas\n   *\n   * @default max over 5 minutes\n   */\n  public static metricAllUnreservedConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return FunctionRef.metricAll('UnreservedConcurrentExecutions', { statistic: 'max', ...props });\n  }\n\n  /**\n   * The name of the function.\n   */\n  public abstract readonly functionName: string;\n\n  /**\n   * The ARN fo the function.\n   */\n  public abstract readonly functionArn: string;\n\n  /**\n   * The IAM role associated with this function.\n   */\n  public abstract readonly role?: iam.Role;\n\n  /**\n   * Whether the addPermission() call adds any permissions\n   *\n   * True for new Lambdas, false for imported Lambdas (they might live in different accounts).\n   */\n  protected abstract readonly canCreatePermissions: boolean;\n\n  /**\n   * Actual connections object for this Lambda\n   *\n   * May be unset, in which case this Lambda is not configured use in a VPC.\n   */\n  protected _connections?: ec2.Connections;\n\n  /**\n   * Indicates if the policy that allows CloudWatch logs to publish to this lambda has been added.\n   */\n  private logSubscriptionDestinationPolicyAddedFor: string[] = [];\n\n  /**\n   * Adds a permission to the Lambda resource policy.\n   * @param id The id ƒor the permission construct\n   */\n  public addPermission(id: string, permission: Permission) {\n    if (!this.canCreatePermissions) {\n      // FIXME: Report metadata\n      return;\n    }\n\n    const principal = this.parsePermissionPrincipal(permission.principal);\n    const action = permission.action || 'lambda:InvokeFunction';\n\n    new CfnPermission(this, id, {\n      action,\n      principal,\n      functionName: this.functionName,\n      eventSourceToken: permission.eventSourceToken,\n      sourceAccount: permission.sourceAccount,\n      sourceArn: permission.sourceArn,\n    });\n  }\n\n  /**\n   * Convenience method for creating a new {@link PipelineInvokeAction},\n   * and adding it to the given Stage.\n   *\n   * @param stage the Pipeline Stage to add the new Action to\n   * @param name the name of the newly created Action\n   * @param props the properties of the new Action\n   * @returns the newly created {@link PipelineInvokeAction}\n   */\n  public addToPipeline(stage: codepipeline.IStage, name: string, props: CommonPipelineInvokeActionProps = {}): PipelineInvokeAction {\n    return new PipelineInvokeAction(this, name, {\n      stage,\n      lambda: this,\n      ...props,\n    });\n  }\n\n  public addToRolePolicy(statement: iam.PolicyStatement) {\n    if (!this.role) {\n      return;\n    }\n\n    this.role.addToPolicy(statement);\n  }\n\n  /**\n   * Access the Connections object\n   *\n   * Will fail if not a VPC-enabled Lambda Function\n   */\n  public get connections(): ec2.Connections {\n    if (!this._connections) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error('Only VPC-associated Lambda Functions have security groups to manage. Supply the \"vpc\" parameter when creating the Lambda, or \"securityGroupId\" when importing it.');\n    }\n    return this._connections;\n  }\n\n  /**\n   * Whether or not this Lambda function was bound to a VPC\n   *\n   * If this is is `false`, trying to access the `connections` object will fail.\n   */\n  public get isBoundToVpc(): boolean {\n    return !!this._connections;\n  }\n\n  /**\n   * Returns a RuleTarget that can be used to trigger this Lambda as a\n   * result from a CloudWatch event.\n   */\n  public asEventRuleTarget(ruleArn: string, ruleId: string): events.EventRuleTargetProps {\n    const permissionId = `AllowEventRule${ruleId}`;\n    if (!this.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        action: 'lambda:InvokeFunction',\n        principal: new iam.ServicePrincipal('events.amazonaws.com'),\n        sourceArn: ruleArn\n      });\n    }\n\n    return {\n      id: this.id,\n      arn: this.functionArn,\n    };\n  }\n\n  /**\n   * Grant the given identity permissions to invoke this Lambda\n   */\n  public grantInvoke(identity?: iam.IPrincipal) {\n    if (identity) {\n      identity.addToPolicy(new iam.PolicyStatement()\n        .addAction('lambda:InvokeFunction')\n        .addResource(this.functionArn));\n    }\n  }\n\n  /**\n   * Return the given named metric for this Lambda\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/Lambda',\n      metricName,\n      dimensions: { FunctionName: this.functionName },\n      ...props\n    });\n  }\n\n  /**\n   * Metric for the Errors executing this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  public metricErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Errors', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the Duration of this Lambda\n   *\n   * @default average over 5 minutes\n   */\n  public metricDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Duration', props);\n  }\n\n  /**\n   * Metric for the number of invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  public metricInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Invocations', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the number of throttled invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  public metricThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Throttles', { statistic: 'sum', ...props });\n  }\n\n  public logSubscriptionDestination(sourceLogGroup: logs.LogGroupRef): logs.LogSubscriptionDestination {\n    const arn = sourceLogGroup.logGroupArn;\n\n    if (this.logSubscriptionDestinationPolicyAddedFor.indexOf(arn) === -1) {\n      // NOTE: the use of {AWS::Region} limits this to the same region, which shouldn't really be an issue,\n      // since the Lambda must be in the same region as the SubscriptionFilter anyway.\n      //\n      // (Wildcards in principals are unfortunately not supported.\n      this.addPermission('InvokedByCloudWatchLogs', {\n        principal: new iam.ServicePrincipal(new cdk.FnConcat('logs.', new cdk.AwsRegion(), '.amazonaws.com').toString()),\n        sourceArn: arn\n      });\n      this.logSubscriptionDestinationPolicyAddedFor.push(arn);\n    }\n    return { arn: this.functionArn };\n  }\n\n  /**\n   * Export this Function (without the role)\n   */\n  public export(): FunctionRefProps {\n    return {\n      functionArn: new cdk.Output(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(),\n      securityGroupId: this._connections && this._connections.securityGroups[0]\n          ? new cdk.Output(this, 'SecurityGroupId', { value: this._connections.securityGroups[0].securityGroupId }).makeImportValue().toString()\n          : undefined\n    };\n  }\n\n  /**\n   * Allows this Lambda to be used as a destination for bucket notifications.\n   * Use `bucket.onEvent(lambda)` to subscribe.\n   */\n  public asBucketNotificationDestination(bucketArn: string, bucketId: string): s3n.BucketNotificationDestinationProps {\n    const permissionId = `AllowBucketNotificationsFrom${bucketId}`;\n    if (!this.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        sourceAccount: new cdk.AwsAccountId().toString(),\n        principal: new iam.ServicePrincipal('s3.amazonaws.com'),\n        sourceArn: bucketArn,\n      });\n    }\n\n    // if we have a permission resource for this relationship, add it as a dependency\n    // to the bucket notifications resource, so it will be created first.\n    const permission = this.tryFindChild(permissionId) as cdk.Resource;\n\n    return {\n      type: s3n.BucketNotificationDestinationType.Lambda,\n      arn: this.functionArn,\n      dependencies: permission ? [ permission ] : undefined\n    };\n  }\n\n  public asStepFunctionsTaskResource(_callingTask: stepfunctions.Task): stepfunctions.StepFunctionsTaskResourceProps {\n    return {\n      resourceArn: this.functionArn,\n      metricPrefixSingular: 'LambdaFunction',\n      metricPrefixPlural: 'LambdaFunctions',\n      metricDimensions: { LambdaFunctionArn: this.functionArn },\n      policyStatements: [new iam.PolicyStatement()\n        .addResource(this.functionArn)\n        .addActions(\"lambda:InvokeFunction\")\n      ]\n    };\n  }\n\n  /**\n   * Adds an event source to this function.\n   *\n   * Event sources are implemented in the @aws-cdk/aws-lambda-event-sources module.\n   *\n   * The following example adds an SQS Queue as an event source:\n   *\n   *     import { SqsEventSource } from '@aws-cdk/aws-lambda-event-sources';\n   *     myFunction.addEventSource(new SqsEventSource(myQueue));\n   *\n   * @param source The event source to bind to this function\n   */\n  public addEventSource(source: IEventSource) {\n    source.bind(this);\n  }\n\n  private parsePermissionPrincipal(principal?: iam.PolicyPrincipal) {\n    if (!principal) {\n      return undefined;\n    }\n\n    // use duck-typing, not instance of\n\n    if ('accountId' in principal) {\n      return (principal as iam.AccountPrincipal).accountId;\n    }\n\n    if (`service` in principal) {\n      return (principal as iam.ServicePrincipal).service;\n    }\n\n    throw new Error(`Invalid principal type for Lambda permission statement: ${JSON.stringify(cdk.resolve(principal))}. ` +\n      'Supported: AccountPrincipal, ServicePrincipal');\n  }\n}\n\nclass LambdaRefImport extends FunctionRef {\n  public readonly functionName: string;\n  public readonly functionArn: string;\n  public readonly role?: iam.Role;\n\n  protected readonly canCreatePermissions = false;\n\n  constructor(parent: cdk.Construct, name: string, props: FunctionRefProps) {\n    super(parent, name);\n\n    this.functionArn = props.functionArn;\n    this.functionName = this.extractNameFromArn(props.functionArn);\n    this.role = props.role;\n\n    if (props.securityGroupId) {\n      this._connections = new ec2.Connections({\n        securityGroups: [ec2.SecurityGroupRef.import(this, 'SecurityGroup', {\n          securityGroupId: props.securityGroupId\n        })]\n      });\n    }\n  }\n\n  /**\n   * Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function\n   * name from the ARN.\n   *\n   * Function ARNs look like this:\n   *\n   *   arn:aws:lambda:region:account-id:function:function-name\n   *\n   * ..which means that in order to extract the `function-name` component from the ARN, we can\n   * split the ARN using \":\" and select the component in index 6.\n   *\n   * @returns `FnSelect(6, FnSplit(':', arn))`\n   */\n  private extractNameFromArn(arn: string) {\n    return new cdk.FnSelect(6, new cdk.FnSplit(':', arn)).toString();\n  }\n}\n"]} | ||
exports.FunctionBase = FunctionBase; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-ref.js","sourceRoot":"","sources":["lambda-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport codepipeline = require('@aws-cdk/aws-codepipeline-api');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport events = require('@aws-cdk/aws-events');\nimport iam = require('@aws-cdk/aws-iam');\nimport logs = require('@aws-cdk/aws-logs');\nimport s3n = require('@aws-cdk/aws-s3-notifications');\nimport stepfunctions = require('@aws-cdk/aws-stepfunctions');\nimport cdk = require('@aws-cdk/cdk');\nimport { IEventSource } from './event-source';\nimport { CfnPermission } from './lambda.generated';\nimport { Permission } from './permission';\nimport { CommonPipelineInvokeActionProps, PipelineInvokeAction } from './pipeline-action';\n\nexport interface IFunction extends cdk.IConstruct, events.IEventRuleTarget, logs.ILogSubscriptionDestination,\n  s3n.IBucketNotificationDestination, ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource {\n\n  /**\n   * Logical ID of this Function.\n   */\n  readonly id: string;\n\n  /**\n   * The name of the function.\n   */\n  readonly functionName: string;\n\n  /**\n   * The ARN fo the function.\n   */\n  readonly functionArn: string;\n\n  /**\n   * The IAM role associated with this function.\n   */\n  readonly role?: iam.IRole;\n\n  /**\n   * Whether or not this Lambda function was bound to a VPC\n   *\n   * If this is is `false`, trying to access the `connections` object will fail.\n   */\n  readonly isBoundToVpc: boolean;\n\n  /**\n   * Adds a permission to the Lambda resource policy.\n   * @param id The id ƒor the permission construct\n   */\n  addPermission(id: string, permission: Permission): void;\n\n  /**\n   * Convenience method for creating a new {@link PipelineInvokeAction},\n   * and adding it to the given Stage.\n   *\n   * @param stage the Pipeline Stage to add the new Action to\n   * @param name the name of the newly created Action\n   * @param props the properties of the new Action\n   * @returns the newly created {@link PipelineInvokeAction}\n   */\n  addToPipeline(stage: codepipeline.IStage, name: string, props?: CommonPipelineInvokeActionProps): PipelineInvokeAction;\n\n  addToRolePolicy(statement: iam.PolicyStatement): void;\n\n  /**\n   * Grant the given identity permissions to invoke this Lambda\n   */\n  grantInvoke(identity?: iam.IPrincipal): void;\n\n  /**\n   * Return the given named metric for this Lambda\n   */\n  metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Metric for the Errors executing this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  metricErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Metric for the Duration of this Lambda\n   *\n   * @default average over 5 minutes\n   */\n  metricDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Metric for the number of invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  metricInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Metric for the number of throttled invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  metricThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Export this Function (without the role)\n   */\n  export(): FunctionImportProps;\n\n  addEventSource(source: IEventSource): void;\n}\n\n/**\n * Represents a Lambda function defined outside of this stack.\n */\nexport interface FunctionImportProps {\n  /**\n   * The ARN of the Lambda function.\n   *\n   * Format: arn:<partition>:lambda:<region>:<account-id>:function:<function-name>\n   */\n  functionArn: string;\n\n  /**\n   * The IAM execution role associated with this function.\n   *\n   * If the role is not specified, any role-related operations will no-op.\n   */\n  role?: iam.IRole;\n\n  /**\n   * Id of the securityGroup for this Lambda, if in a VPC.\n   *\n   * This needs to be given in order to support allowing connections\n   * to this Lambda.\n   */\n  securityGroupId?: string;\n}\n\nexport abstract class FunctionBase extends cdk.Construct implements IFunction  {\n\n  /**\n   * The name of the function.\n   */\n  public abstract readonly functionName: string;\n\n  /**\n   * The ARN fo the function.\n   */\n  public abstract readonly functionArn: string;\n\n  /**\n   * The IAM role associated with this function.\n   */\n  public abstract readonly role?: iam.IRole;\n\n  /**\n   * Whether the addPermission() call adds any permissions\n   *\n   * True for new Lambdas, false for imported Lambdas (they might live in different accounts).\n   */\n  protected abstract readonly canCreatePermissions: boolean;\n\n  /**\n   * Actual connections object for this Lambda\n   *\n   * May be unset, in which case this Lambda is not configured use in a VPC.\n   */\n  protected _connections?: ec2.Connections;\n\n  /**\n   * Indicates if the policy that allows CloudWatch logs to publish to this lambda has been added.\n   */\n  private logSubscriptionDestinationPolicyAddedFor: string[] = [];\n\n  /**\n   * Adds a permission to the Lambda resource policy.\n   * @param id The id ƒor the permission construct\n   */\n  public addPermission(id: string, permission: Permission) {\n    if (!this.canCreatePermissions) {\n      // FIXME: Report metadata\n      return;\n    }\n\n    const principal = this.parsePermissionPrincipal(permission.principal);\n    const action = permission.action || 'lambda:InvokeFunction';\n\n    new CfnPermission(this, id, {\n      action,\n      principal,\n      functionName: this.functionName,\n      eventSourceToken: permission.eventSourceToken,\n      sourceAccount: permission.sourceAccount,\n      sourceArn: permission.sourceArn,\n    });\n  }\n\n  public get id() {\n    return this.node.id;\n  }\n\n  /**\n   * Convenience method for creating a new {@link PipelineInvokeAction},\n   * and adding it to the given Stage.\n   *\n   * @param stage the Pipeline Stage to add the new Action to\n   * @param name the name of the newly created Action\n   * @param props the properties of the new Action\n   * @returns the newly created {@link PipelineInvokeAction}\n   */\n  public addToPipeline(stage: codepipeline.IStage, name: string, props: CommonPipelineInvokeActionProps = {}): PipelineInvokeAction {\n    return new PipelineInvokeAction(this, name, {\n      stage,\n      lambda: this,\n      ...props,\n    });\n  }\n\n  public addToRolePolicy(statement: iam.PolicyStatement) {\n    if (!this.role) {\n      return;\n    }\n\n    this.role.addToPolicy(statement);\n  }\n\n  /**\n   * Access the Connections object\n   *\n   * Will fail if not a VPC-enabled Lambda Function\n   */\n  public get connections(): ec2.Connections {\n    if (!this._connections) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error('Only VPC-associated Lambda Functions have security groups to manage. Supply the \"vpc\" parameter when creating the Lambda, or \"securityGroupId\" when importing it.');\n    }\n    return this._connections;\n  }\n\n  /**\n   * Whether or not this Lambda function was bound to a VPC\n   *\n   * If this is is `false`, trying to access the `connections` object will fail.\n   */\n  public get isBoundToVpc(): boolean {\n    return !!this._connections;\n  }\n\n  /**\n   * Returns a RuleTarget that can be used to trigger this Lambda as a\n   * result from a CloudWatch event.\n   */\n  public asEventRuleTarget(ruleArn: string, ruleId: string): events.EventRuleTargetProps {\n    const permissionId = `AllowEventRule${ruleId}`;\n    if (!this.node.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        action: 'lambda:InvokeFunction',\n        principal: new iam.ServicePrincipal('events.amazonaws.com'),\n        sourceArn: ruleArn\n      });\n    }\n\n    return {\n      id: this.node.id,\n      arn: this.functionArn,\n    };\n  }\n\n  /**\n   * Grant the given identity permissions to invoke this Lambda\n   */\n  public grantInvoke(identity?: iam.IPrincipal) {\n    if (identity) {\n      identity.addToPolicy(new iam.PolicyStatement()\n        .addAction('lambda:InvokeFunction')\n        .addResource(this.functionArn));\n    }\n  }\n\n  /**\n   * Return the given named metric for this Lambda\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/Lambda',\n      metricName,\n      dimensions: { FunctionName: this.functionName },\n      ...props\n    });\n  }\n\n  /**\n   * Metric for the Errors executing this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  public metricErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Errors', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the Duration of this Lambda\n   *\n   * @default average over 5 minutes\n   */\n  public metricDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Duration', props);\n  }\n\n  /**\n   * Metric for the number of invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  public metricInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Invocations', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the number of throttled invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  public metricThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metric('Throttles', { statistic: 'sum', ...props });\n  }\n\n  public logSubscriptionDestination(sourceLogGroup: logs.ILogGroup): logs.LogSubscriptionDestination {\n    const arn = sourceLogGroup.logGroupArn;\n\n    if (this.logSubscriptionDestinationPolicyAddedFor.indexOf(arn) === -1) {\n      const stack = cdk.Stack.find(this);\n      // NOTE: the use of {AWS::Region} limits this to the same region, which shouldn't really be an issue,\n      // since the Lambda must be in the same region as the SubscriptionFilter anyway.\n      //\n      // (Wildcards in principals are unfortunately not supported.\n      this.addPermission('InvokedByCloudWatchLogs', {\n        principal: new iam.ServicePrincipal(`logs.${stack.region}.amazonaws.com`),\n        sourceArn: arn\n      });\n      this.logSubscriptionDestinationPolicyAddedFor.push(arn);\n    }\n    return { arn: this.functionArn };\n  }\n\n  /**\n   * Export this Function (without the role)\n   */\n  public abstract export(): FunctionImportProps;\n\n  /**\n   * Allows this Lambda to be used as a destination for bucket notifications.\n   * Use `bucket.onEvent(lambda)` to subscribe.\n   */\n  public asBucketNotificationDestination(bucketArn: string, bucketId: string): s3n.BucketNotificationDestinationProps {\n    const permissionId = `AllowBucketNotificationsFrom${bucketId}`;\n    const stack = cdk.Stack.find(this);\n    if (!this.node.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        sourceAccount: stack.accountId,\n        principal: new iam.ServicePrincipal('s3.amazonaws.com'),\n        sourceArn: bucketArn,\n      });\n    }\n\n    // if we have a permission resource for this relationship, add it as a dependency\n    // to the bucket notifications resource, so it will be created first.\n    const permission = this.node.tryFindChild(permissionId) as cdk.Resource;\n\n    return {\n      type: s3n.BucketNotificationDestinationType.Lambda,\n      arn: this.functionArn,\n      dependencies: permission ? [ permission ] : undefined\n    };\n  }\n\n  public asStepFunctionsTaskResource(_callingTask: stepfunctions.Task): stepfunctions.StepFunctionsTaskResourceProps {\n    return {\n      resourceArn: this.functionArn,\n      metricPrefixSingular: 'LambdaFunction',\n      metricPrefixPlural: 'LambdaFunctions',\n      metricDimensions: { LambdaFunctionArn: this.functionArn },\n      policyStatements: [new iam.PolicyStatement()\n        .addResource(this.functionArn)\n        .addActions(\"lambda:InvokeFunction\")\n      ]\n    };\n  }\n\n  /**\n   * Adds an event source to this function.\n   *\n   * Event sources are implemented in the @aws-cdk/aws-lambda-event-sources module.\n   *\n   * The following example adds an SQS Queue as an event source:\n   *\n   *     import { SqsEventSource } from '@aws-cdk/aws-lambda-event-sources';\n   *     myFunction.addEventSource(new SqsEventSource(myQueue));\n   *\n   * @param source The event source to bind to this function\n   */\n  public addEventSource(source: IEventSource) {\n    source.bind(this);\n  }\n\n  private parsePermissionPrincipal(principal?: iam.PolicyPrincipal) {\n    if (!principal) {\n      return undefined;\n    }\n\n    // use duck-typing, not instance of\n\n    if ('accountId' in principal) {\n      return (principal as iam.AccountPrincipal).accountId;\n    }\n\n    if (`service` in principal) {\n      return (principal as iam.ServicePrincipal).service;\n    }\n\n    throw new Error(`Invalid principal type for Lambda permission statement: ${JSON.stringify(this.node.resolve(principal))}. ` +\n      'Supported: AccountPrincipal, ServicePrincipal');\n  }\n}\n"]} |
import { Construct } from '@aws-cdk/cdk'; | ||
import { FunctionRef } from './lambda-ref'; | ||
import { IFunction } from './lambda-ref'; | ||
/** | ||
* Properties for a new Lambda version | ||
*/ | ||
export interface FunctionVersionProps { | ||
export interface VersionProps { | ||
/** | ||
@@ -24,3 +24,3 @@ * SHA256 of the version of the Lambda source code | ||
*/ | ||
lambda: FunctionRef; | ||
lambda: IFunction; | ||
} | ||
@@ -43,3 +43,3 @@ /** | ||
*/ | ||
export declare class FunctionVersion extends Construct { | ||
export declare class Version extends Construct { | ||
/** | ||
@@ -52,4 +52,4 @@ * The most recently deployed version of this function. | ||
*/ | ||
readonly lambda: FunctionRef; | ||
constructor(parent: Construct, name: string, props: FunctionVersionProps); | ||
readonly lambda: IFunction; | ||
constructor(scope: Construct, id: string, props: VersionProps); | ||
} |
@@ -21,5 +21,5 @@ "use strict"; | ||
*/ | ||
class FunctionVersion extends cdk_1.Construct { | ||
constructor(parent, name, props) { | ||
super(parent, name); | ||
class Version extends cdk_1.Construct { | ||
constructor(scope, id, props) { | ||
super(scope, id); | ||
const version = new lambda_generated_1.CfnVersion(this, 'Resource', { | ||
@@ -34,3 +34,3 @@ codeSha256: props.codeSha256, | ||
} | ||
exports.FunctionVersion = FunctionVersion; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFtYmRhLXZlcnNpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJsYW1iZGEtdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5QztBQUV6Qyx5REFBZ0Q7QUE0QmhEOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILE1BQWEsZUFBZ0IsU0FBUSxlQUFTO0lBVzVDLFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBMkI7UUFDdEUsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVwQixNQUFNLE9BQU8sR0FBRyxJQUFJLDZCQUFVLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUMvQyxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7WUFDNUIsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1lBQzlCLFlBQVksRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVk7U0FDeEMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQztJQUM3QixDQUFDO0NBQ0Y7QUF2QkQsMENBdUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnQGF3cy1jZGsvY2RrJztcbmltcG9ydCB7IEZ1bmN0aW9uUmVmIH0gZnJvbSAnLi9sYW1iZGEtcmVmJztcbmltcG9ydCB7IENmblZlcnNpb24gfSBmcm9tICcuL2xhbWJkYS5nZW5lcmF0ZWQnO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGEgbmV3IExhbWJkYSB2ZXJzaW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRnVuY3Rpb25WZXJzaW9uUHJvcHMge1xuICAvKipcbiAgICogU0hBMjU2IG9mIHRoZSB2ZXJzaW9uIG9mIHRoZSBMYW1iZGEgc291cmNlIGNvZGVcbiAgICpcbiAgICogU3BlY2lmeSB0byB2YWxpZGF0ZSB0aGF0IHlvdSdyZSBkZXBsb3lpbmcgdGhlIHJpZ2h0IHZlcnNpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0IE5vIHZhbGlkYXRpb24gaXMgcGVyZm9ybWVkXG4gICAqL1xuICBjb2RlU2hhMjU2Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBEZXNjcmlwdGlvbiBvZiB0aGUgdmVyc2lvblxuICAgKlxuICAgKiBAZGVmYXVsdCBEZXNjcmlwdGlvbiBvZiB0aGUgTGFtYmRhXG4gICAqL1xuICBkZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAvKipcbiAgICogRnVuY3Rpb24gdG8gZ2V0IHRoZSB2YWx1ZSBvZlxuICAgKi9cbiAgbGFtYmRhOiBGdW5jdGlvblJlZjtcbn1cblxuLyoqXG4gKiBBIHNpbmdsZSBuZXdseS1kZXBsb3llZCB2ZXJzaW9uIG9mIGEgTGFtYmRhIGZ1bmN0aW9uLlxuICpcbiAqIFRoaXMgb2JqZWN0IGV4aXN0cyB0by0tYXQgZGVwbG95IHRpbWUtLXF1ZXJ5IHRoZSBcInRoZW4tY3VycmVudFwiIHZlcnNpb24gb2ZcbiAqIHRoZSBMYW1iZGEgZnVuY3Rpb24gdGhhdCBpdCByZWZlcnMgdG8uIFRoaXMgVmVyc2lvbiBvYmplY3QgY2FuIHRoZW4gYmVcbiAqIHVzZWQgaW4gYEFsaWFzYCB0byByZWZlciB0byBhIHBhcnRpY3VsYXIgZGVwbG95bWVudCBvZiBhIExhbWJkYS5cbiAqXG4gKiBUaGlzIG1lYW5zIHRoYXQgZm9yIGV2ZXJ5IG5ldyB1cGRhdGUgeW91IGRlcGxveSB0byB5b3VyIExhbWJkYSAodXNpbmcgdGhlXG4gKiBDREsgYW5kIEFsaWFzZXMpLCB5b3UgbXVzdCBhbHdheXMgY3JlYXRlIGEgbmV3IFZlcnNpb24gb2JqZWN0LiBJblxuICogcGFydGljdWxhciwgaXQgbXVzdCBoYXZlIGEgZGlmZmVyZW50IG5hbWUsIHNvIHRoYXQgYSBuZXcgcmVzb3VyY2UgaXNcbiAqIGNyZWF0ZWQuXG4gKlxuICogSWYgeW91IHdhbnQgdG8gZW5zdXJlIHRoYXQgeW91J3JlIGFzc29jaWF0aW5nIHRoZSByaWdodCB2ZXJzaW9uIHdpdGhcbiAqIHRoZSByaWdodCBkZXBsb3ltZW50LCBzcGVjaWZ5IHRoZSBgY29kZVNoYTI1NmAgcHJvcGVydHkgd2hpbGVcbiAqIGNyZWF0aW5nIHRoZSBgVmVyc2lvbi5cbiAqL1xuZXhwb3J0IGNsYXNzIEZ1bmN0aW9uVmVyc2lvbiBleHRlbmRzIENvbnN0cnVjdCB7XG4gIC8qKlxuICAgKiBUaGUgbW9zdCByZWNlbnRseSBkZXBsb3llZCB2ZXJzaW9uIG9mIHRoaXMgZnVuY3Rpb24uXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZnVuY3Rpb25WZXJzaW9uOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIExhbWJkYSBvYmplY3QgdGhpcyB2ZXJzaW9uIGlzIGFzc29jaWF0ZWQgd2l0aFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGxhbWJkYTogRnVuY3Rpb25SZWY7XG5cbiAgY29uc3RydWN0b3IocGFyZW50OiBDb25zdHJ1Y3QsIG5hbWU6IHN0cmluZywgcHJvcHM6IEZ1bmN0aW9uVmVyc2lvblByb3BzKSB7XG4gICAgc3VwZXIocGFyZW50LCBuYW1lKTtcblxuICAgIGNvbnN0IHZlcnNpb24gPSBuZXcgQ2ZuVmVyc2lvbih0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBjb2RlU2hhMjU2OiBwcm9wcy5jb2RlU2hhMjU2LFxuICAgICAgZGVzY3JpcHRpb246IHByb3BzLmRlc2NyaXB0aW9uLFxuICAgICAgZnVuY3Rpb25OYW1lOiBwcm9wcy5sYW1iZGEuZnVuY3Rpb25OYW1lXG4gICAgfSk7XG5cbiAgICB0aGlzLmZ1bmN0aW9uVmVyc2lvbiA9IHZlcnNpb24udmVyc2lvbjtcbiAgICB0aGlzLmxhbWJkYSA9IHByb3BzLmxhbWJkYTtcbiAgfVxufVxuIl19 | ||
exports.Version = Version; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFtYmRhLXZlcnNpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJsYW1iZGEtdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5QztBQUV6Qyx5REFBZ0Q7QUE0QmhEOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILE1BQWEsT0FBUSxTQUFRLGVBQVM7SUFXcEMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFtQjtRQUMzRCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sT0FBTyxHQUFHLElBQUksNkJBQVUsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQy9DLFVBQVUsRUFBRSxLQUFLLENBQUMsVUFBVTtZQUM1QixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsWUFBWSxFQUFFLEtBQUssQ0FBQyxNQUFNLENBQUMsWUFBWTtTQUN4QyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsZUFBZSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUM7UUFDdkMsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDO0lBQzdCLENBQUM7Q0FDRjtBQXZCRCwwQkF1QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdAYXdzLWNkay9jZGsnO1xuaW1wb3J0IHsgSUZ1bmN0aW9uIH0gZnJvbSAnLi9sYW1iZGEtcmVmJztcbmltcG9ydCB7IENmblZlcnNpb24gfSBmcm9tICcuL2xhbWJkYS5nZW5lcmF0ZWQnO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGEgbmV3IExhbWJkYSB2ZXJzaW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVmVyc2lvblByb3BzIHtcbiAgLyoqXG4gICAqIFNIQTI1NiBvZiB0aGUgdmVyc2lvbiBvZiB0aGUgTGFtYmRhIHNvdXJjZSBjb2RlXG4gICAqXG4gICAqIFNwZWNpZnkgdG8gdmFsaWRhdGUgdGhhdCB5b3UncmUgZGVwbG95aW5nIHRoZSByaWdodCB2ZXJzaW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCBObyB2YWxpZGF0aW9uIGlzIHBlcmZvcm1lZFxuICAgKi9cbiAgY29kZVNoYTI1Nj86IHN0cmluZztcblxuICAvKipcbiAgICogRGVzY3JpcHRpb24gb2YgdGhlIHZlcnNpb25cbiAgICpcbiAgICogQGRlZmF1bHQgRGVzY3JpcHRpb24gb2YgdGhlIExhbWJkYVxuICAgKi9cbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHRvIGdldCB0aGUgdmFsdWUgb2ZcbiAgICovXG4gIGxhbWJkYTogSUZ1bmN0aW9uO1xufVxuXG4vKipcbiAqIEEgc2luZ2xlIG5ld2x5LWRlcGxveWVkIHZlcnNpb24gb2YgYSBMYW1iZGEgZnVuY3Rpb24uXG4gKlxuICogVGhpcyBvYmplY3QgZXhpc3RzIHRvLS1hdCBkZXBsb3kgdGltZS0tcXVlcnkgdGhlIFwidGhlbi1jdXJyZW50XCIgdmVyc2lvbiBvZlxuICogdGhlIExhbWJkYSBmdW5jdGlvbiB0aGF0IGl0IHJlZmVycyB0by4gVGhpcyBWZXJzaW9uIG9iamVjdCBjYW4gdGhlbiBiZVxuICogdXNlZCBpbiBgQWxpYXNgIHRvIHJlZmVyIHRvIGEgcGFydGljdWxhciBkZXBsb3ltZW50IG9mIGEgTGFtYmRhLlxuICpcbiAqIFRoaXMgbWVhbnMgdGhhdCBmb3IgZXZlcnkgbmV3IHVwZGF0ZSB5b3UgZGVwbG95IHRvIHlvdXIgTGFtYmRhICh1c2luZyB0aGVcbiAqIENESyBhbmQgQWxpYXNlcyksIHlvdSBtdXN0IGFsd2F5cyBjcmVhdGUgYSBuZXcgVmVyc2lvbiBvYmplY3QuIEluXG4gKiBwYXJ0aWN1bGFyLCBpdCBtdXN0IGhhdmUgYSBkaWZmZXJlbnQgbmFtZSwgc28gdGhhdCBhIG5ldyByZXNvdXJjZSBpc1xuICogY3JlYXRlZC5cbiAqXG4gKiBJZiB5b3Ugd2FudCB0byBlbnN1cmUgdGhhdCB5b3UncmUgYXNzb2NpYXRpbmcgdGhlIHJpZ2h0IHZlcnNpb24gd2l0aFxuICogdGhlIHJpZ2h0IGRlcGxveW1lbnQsIHNwZWNpZnkgdGhlIGBjb2RlU2hhMjU2YCBwcm9wZXJ0eSB3aGlsZVxuICogY3JlYXRpbmcgdGhlIGBWZXJzaW9uLlxuICovXG5leHBvcnQgY2xhc3MgVmVyc2lvbiBleHRlbmRzIENvbnN0cnVjdCB7XG4gIC8qKlxuICAgKiBUaGUgbW9zdCByZWNlbnRseSBkZXBsb3llZCB2ZXJzaW9uIG9mIHRoaXMgZnVuY3Rpb24uXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZnVuY3Rpb25WZXJzaW9uOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIExhbWJkYSBvYmplY3QgdGhpcyB2ZXJzaW9uIGlzIGFzc29jaWF0ZWQgd2l0aFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGxhbWJkYTogSUZ1bmN0aW9uO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBWZXJzaW9uUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgdmVyc2lvbiA9IG5ldyBDZm5WZXJzaW9uKHRoaXMsICdSZXNvdXJjZScsIHtcbiAgICAgIGNvZGVTaGEyNTY6IHByb3BzLmNvZGVTaGEyNTYsXG4gICAgICBkZXNjcmlwdGlvbjogcHJvcHMuZGVzY3JpcHRpb24sXG4gICAgICBmdW5jdGlvbk5hbWU6IHByb3BzLmxhbWJkYS5mdW5jdGlvbk5hbWVcbiAgICB9KTtcblxuICAgIHRoaXMuZnVuY3Rpb25WZXJzaW9uID0gdmVyc2lvbi52ZXJzaW9uO1xuICAgIHRoaXMubGFtYmRhID0gcHJvcHMubGFtYmRhO1xuICB9XG59XG4iXX0= |
@@ -0,1 +1,2 @@ | ||
import cloudwatch = require('@aws-cdk/aws-cloudwatch'); | ||
import ec2 = require('@aws-cdk/aws-ec2'); | ||
@@ -6,4 +7,4 @@ import iam = require('@aws-cdk/aws-iam'); | ||
import { Code } from './code'; | ||
import { FunctionRef } from './lambda-ref'; | ||
import { FunctionVersion } from './lambda-version'; | ||
import { FunctionBase, FunctionImportProps, IFunction } from './lambda-ref'; | ||
import { Version } from './lambda-version'; | ||
import { Runtime } from './runtime'; | ||
@@ -104,3 +105,3 @@ /** | ||
*/ | ||
role?: iam.Role; | ||
role?: iam.IRole; | ||
/** | ||
@@ -111,3 +112,3 @@ * VPC network to place Lambda network interfaces | ||
*/ | ||
vpc?: ec2.VpcNetworkRef; | ||
vpc?: ec2.IVpcNetwork; | ||
/** | ||
@@ -131,3 +132,3 @@ * Where to place the network interfaces within the VPC. | ||
*/ | ||
securityGroup?: ec2.SecurityGroupRef; | ||
securityGroup?: ec2.ISecurityGroup; | ||
/** | ||
@@ -154,3 +155,3 @@ * Whether to allow the Lambda to send all network traffic | ||
*/ | ||
deadLetterQueue?: sqs.QueueRef; | ||
deadLetterQueue?: sqs.IQueue; | ||
/** | ||
@@ -174,4 +175,56 @@ * Enable AWS X-Ray Tracing for Lambda Function. | ||
*/ | ||
export declare class Function extends FunctionRef { | ||
export declare class Function extends FunctionBase { | ||
/** | ||
* Creates a Lambda function object which represents a function not defined | ||
* within this stack. | ||
* | ||
* Lambda.import(this, 'MyImportedFunction', { lambdaArn: new LambdaArn('arn:aws:...') }); | ||
* | ||
* @param parent The parent construct | ||
* @param id The name of the lambda construct | ||
* @param props A reference to a Lambda function. Can be created manually (see | ||
* example above) or obtained through a call to `lambda.export()`. | ||
*/ | ||
static import(scope: cdk.Construct, id: string, props: FunctionImportProps): IFunction; | ||
/** | ||
* Return the given named metric for this Lambda | ||
*/ | ||
static metricAll(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of Errors executing all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the Duration executing all Lambdas | ||
* | ||
* @default average over 5 minutes | ||
*/ | ||
static metricAllDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of invocations of all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of throttled invocations of all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of concurrent executions across all Lambdas | ||
* | ||
* @default max over 5 minutes | ||
*/ | ||
static metricAllConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Metric for the number of unreserved concurrent executions across all Lambdas | ||
* | ||
* @default max over 5 minutes | ||
*/ | ||
static metricAllUnreservedConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric; | ||
/** | ||
* Name of this function | ||
@@ -187,3 +240,3 @@ */ | ||
*/ | ||
readonly role?: iam.Role; | ||
readonly role?: iam.IRole; | ||
/** | ||
@@ -202,4 +255,8 @@ * The runtime configured for this lambda. | ||
private readonly environment?; | ||
constructor(parent: cdk.Construct, name: string, props: FunctionProps); | ||
constructor(scope: cdk.Construct, id: string, props: FunctionProps); | ||
/** | ||
* Export this Function (without the role) | ||
*/ | ||
export(): FunctionImportProps; | ||
/** | ||
* Adds an environment variable to this Lambda function. | ||
@@ -227,3 +284,3 @@ * If this is a ref to a Lambda function, this operation results in a no-op. | ||
*/ | ||
addVersion(name: string, codeSha256?: string, description?: string): FunctionVersion; | ||
addVersion(name: string, codeSha256?: string, description?: string): Version; | ||
private renderEnvironment; | ||
@@ -240,1 +297,10 @@ /** | ||
} | ||
export declare class ImportedFunction extends FunctionBase { | ||
private readonly props; | ||
readonly functionName: string; | ||
readonly functionArn: string; | ||
readonly role?: iam.IRole; | ||
protected readonly canCreatePermissions = false; | ||
constructor(scope: cdk.Construct, id: string, props: FunctionImportProps); | ||
export(): FunctionImportProps; | ||
} |
@@ -10,3 +10,3 @@ import cdk = require('@aws-cdk/cdk'); | ||
*/ | ||
functionName: string | cdk.Token; | ||
functionName: string; | ||
/** | ||
@@ -16,3 +16,3 @@ * ``AWS::Lambda::Alias.FunctionVersion`` | ||
*/ | ||
functionVersion: string | cdk.Token; | ||
functionVersion: string; | ||
/** | ||
@@ -22,3 +22,3 @@ * ``AWS::Lambda::Alias.Name`` | ||
*/ | ||
name: string | cdk.Token; | ||
name: string; | ||
/** | ||
@@ -28,3 +28,3 @@ * ``AWS::Lambda::Alias.Description`` | ||
*/ | ||
description?: string | cdk.Token; | ||
description?: string; | ||
/** | ||
@@ -48,7 +48,7 @@ * ``AWS::Lambda::Alias.RoutingConfig`` | ||
* | ||
* @param parent the ``cdk.Construct`` this ``CfnAlias`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``CfnAlias`` | ||
* @param scope scope in which this resource is defined | ||
* @param id scoped id of the resource | ||
* @param props resource properties | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: CfnAliasProps); | ||
constructor(scope: cdk.Construct, id: string, props: CfnAliasProps); | ||
readonly propertyOverrides: CfnAliasProps; | ||
@@ -80,3 +80,3 @@ protected renderProperties(properties: any): { | ||
*/ | ||
functionVersion: string | cdk.Token; | ||
functionVersion: string; | ||
/** | ||
@@ -89,86 +89,2 @@ * ``CfnAlias.VersionWeightProperty.FunctionWeight`` | ||
} | ||
export declare namespace cloudformation { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-alias.html | ||
*/ | ||
interface AliasResourceProps { | ||
/** | ||
* ``AWS::Lambda::Alias.FunctionName`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-alias.html#cfn-lambda-alias-functionname | ||
*/ | ||
functionName: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Alias.FunctionVersion`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-alias.html#cfn-lambda-alias-functionversion | ||
*/ | ||
functionVersion: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Alias.Name`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-alias.html#cfn-lambda-alias-name | ||
*/ | ||
name: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Alias.Description`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-alias.html#cfn-lambda-alias-description | ||
*/ | ||
description?: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Alias.RoutingConfig`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-alias.html#cfn-lambda-alias-routingconfig | ||
*/ | ||
routingConfig?: AliasResource.AliasRoutingConfigurationProperty | cdk.Token; | ||
} | ||
/** | ||
* @deprecated "cloudformation.AliasResource" will be deprecated in a future release in favor of "CfnAlias" (see https://github.com/awslabs/aws-cdk/issues/878) | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-alias.html | ||
*/ | ||
class AliasResource extends cdk.Resource { | ||
/** | ||
* The CloudFormation resource type name for this resource class. | ||
*/ | ||
static readonly resourceTypeName = "AWS::Lambda::Alias"; | ||
readonly aliasArn: string; | ||
/** | ||
* Creates a new ``AWS::Lambda::Alias``. | ||
* | ||
* @param parent the ``cdk.Construct`` this ``AliasResource`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``AliasResource`` | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: AliasResourceProps); | ||
readonly propertyOverrides: AliasResourceProps; | ||
protected renderProperties(properties: any): { | ||
[key: string]: any; | ||
}; | ||
} | ||
namespace AliasResource { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-alias-aliasroutingconfiguration.html | ||
*/ | ||
interface AliasRoutingConfigurationProperty { | ||
/** | ||
* ``AliasResource.AliasRoutingConfigurationProperty.AdditionalVersionWeights`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-alias-aliasroutingconfiguration.html#cfn-lambda-alias-aliasroutingconfiguration-additionalversionweights | ||
*/ | ||
additionalVersionWeights: Array<AliasResource.VersionWeightProperty | cdk.Token> | cdk.Token; | ||
} | ||
} | ||
namespace AliasResource { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-alias-versionweight.html | ||
*/ | ||
interface VersionWeightProperty { | ||
/** | ||
* ``AliasResource.VersionWeightProperty.FunctionVersion`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-alias-versionweight.html#cfn-lambda-alias-versionweight-functionversion | ||
*/ | ||
functionVersion: string | cdk.Token; | ||
/** | ||
* ``AliasResource.VersionWeightProperty.FunctionWeight`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-alias-versionweight.html#cfn-lambda-alias-versionweight-functionweight | ||
*/ | ||
functionWeight: number | cdk.Token; | ||
} | ||
} | ||
} | ||
/** | ||
@@ -182,3 +98,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html | ||
*/ | ||
eventSourceArn: string | cdk.Token; | ||
eventSourceArn: string; | ||
/** | ||
@@ -188,3 +104,3 @@ * ``AWS::Lambda::EventSourceMapping.FunctionName`` | ||
*/ | ||
functionName: string | cdk.Token; | ||
functionName: string; | ||
/** | ||
@@ -204,3 +120,3 @@ * ``AWS::Lambda::EventSourceMapping.BatchSize`` | ||
*/ | ||
startingPosition?: string | cdk.Token; | ||
startingPosition?: string; | ||
} | ||
@@ -219,7 +135,7 @@ /** | ||
* | ||
* @param parent the ``cdk.Construct`` this ``CfnEventSourceMapping`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``CfnEventSourceMapping`` | ||
* @param scope scope in which this resource is defined | ||
* @param id scoped id of the resource | ||
* @param props resource properties | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: CfnEventSourceMappingProps); | ||
constructor(scope: cdk.Construct, id: string, props: CfnEventSourceMappingProps); | ||
readonly propertyOverrides: CfnEventSourceMappingProps; | ||
@@ -230,57 +146,2 @@ protected renderProperties(properties: any): { | ||
} | ||
export declare namespace cloudformation { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html | ||
*/ | ||
interface EventSourceMappingResourceProps { | ||
/** | ||
* ``AWS::Lambda::EventSourceMapping.EventSourceArn`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html#cfn-lambda-eventsourcemapping-eventsourcearn | ||
*/ | ||
eventSourceArn: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::EventSourceMapping.FunctionName`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html#cfn-lambda-eventsourcemapping-functionname | ||
*/ | ||
functionName: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::EventSourceMapping.BatchSize`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html#cfn-lambda-eventsourcemapping-batchsize | ||
*/ | ||
batchSize?: number | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::EventSourceMapping.Enabled`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html#cfn-lambda-eventsourcemapping-enabled | ||
*/ | ||
enabled?: boolean | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::EventSourceMapping.StartingPosition`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html#cfn-lambda-eventsourcemapping-startingposition | ||
*/ | ||
startingPosition?: string | cdk.Token; | ||
} | ||
/** | ||
* @deprecated "cloudformation.EventSourceMappingResource" will be deprecated in a future release in favor of "CfnEventSourceMapping" (see https://github.com/awslabs/aws-cdk/issues/878) | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html | ||
*/ | ||
class EventSourceMappingResource extends cdk.Resource { | ||
/** | ||
* The CloudFormation resource type name for this resource class. | ||
*/ | ||
static readonly resourceTypeName = "AWS::Lambda::EventSourceMapping"; | ||
readonly eventSourceMappingName: string; | ||
/** | ||
* Creates a new ``AWS::Lambda::EventSourceMapping``. | ||
* | ||
* @param parent the ``cdk.Construct`` this ``EventSourceMappingResource`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``EventSourceMappingResource`` | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: EventSourceMappingResourceProps); | ||
readonly propertyOverrides: EventSourceMappingResourceProps; | ||
protected renderProperties(properties: any): { | ||
[key: string]: any; | ||
}; | ||
} | ||
} | ||
/** | ||
@@ -299,3 +160,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html | ||
*/ | ||
handler: string | cdk.Token; | ||
handler: string; | ||
/** | ||
@@ -305,3 +166,3 @@ * ``AWS::Lambda::Function.Role`` | ||
*/ | ||
role: string | cdk.Token; | ||
role: string; | ||
/** | ||
@@ -311,3 +172,3 @@ * ``AWS::Lambda::Function.Runtime`` | ||
*/ | ||
runtime: string | cdk.Token; | ||
runtime: string; | ||
/** | ||
@@ -322,3 +183,3 @@ * ``AWS::Lambda::Function.DeadLetterConfig`` | ||
*/ | ||
description?: string | cdk.Token; | ||
description?: string; | ||
/** | ||
@@ -333,3 +194,3 @@ * ``AWS::Lambda::Function.Environment`` | ||
*/ | ||
functionName?: string | cdk.Token; | ||
functionName?: string; | ||
/** | ||
@@ -339,3 +200,3 @@ * ``AWS::Lambda::Function.KmsKeyArn`` | ||
*/ | ||
kmsKeyArn?: string | cdk.Token; | ||
kmsKeyArn?: string; | ||
/** | ||
@@ -393,7 +254,7 @@ * ``AWS::Lambda::Function.Layers`` | ||
* | ||
* @param parent the ``cdk.Construct`` this ``CfnFunction`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``CfnFunction`` | ||
* @param scope scope in which this resource is defined | ||
* @param id scoped id of the resource | ||
* @param props resource properties | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: CfnFunctionProps); | ||
constructor(scope: cdk.Construct, id: string, props: CfnFunctionProps); | ||
readonly propertyOverrides: CfnFunctionProps; | ||
@@ -413,3 +274,3 @@ protected renderProperties(properties: any): { | ||
*/ | ||
s3Bucket?: string | cdk.Token; | ||
s3Bucket?: string; | ||
/** | ||
@@ -419,3 +280,3 @@ * ``CfnFunction.CodeProperty.S3Key`` | ||
*/ | ||
s3Key?: string | cdk.Token; | ||
s3Key?: string; | ||
/** | ||
@@ -425,3 +286,3 @@ * ``CfnFunction.CodeProperty.S3ObjectVersion`` | ||
*/ | ||
s3ObjectVersion?: string | cdk.Token; | ||
s3ObjectVersion?: string; | ||
/** | ||
@@ -431,3 +292,3 @@ * ``CfnFunction.CodeProperty.ZipFile`` | ||
*/ | ||
zipFile?: string | cdk.Token; | ||
zipFile?: string; | ||
} | ||
@@ -444,3 +305,3 @@ } | ||
*/ | ||
targetArn?: string | cdk.Token; | ||
targetArn?: string; | ||
} | ||
@@ -471,3 +332,3 @@ } | ||
*/ | ||
mode?: string | cdk.Token; | ||
mode?: string; | ||
} | ||
@@ -492,198 +353,2 @@ } | ||
} | ||
export declare namespace cloudformation { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html | ||
*/ | ||
interface FunctionResourceProps { | ||
/** | ||
* ``AWS::Lambda::Function.Code`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-code | ||
*/ | ||
code: FunctionResource.CodeProperty | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Handler`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-handler | ||
*/ | ||
handler: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Role`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-role | ||
*/ | ||
role: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Runtime`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-runtime | ||
*/ | ||
runtime: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.DeadLetterConfig`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-deadletterconfig | ||
*/ | ||
deadLetterConfig?: FunctionResource.DeadLetterConfigProperty | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Description`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-description | ||
*/ | ||
description?: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Environment`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-environment | ||
*/ | ||
environment?: FunctionResource.EnvironmentProperty | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.FunctionName`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-functionname | ||
*/ | ||
functionName?: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.KmsKeyArn`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-kmskeyarn | ||
*/ | ||
kmsKeyArn?: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Layers`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-layers | ||
*/ | ||
layers?: Array<string | cdk.Token> | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.MemorySize`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-memorysize | ||
*/ | ||
memorySize?: number | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.ReservedConcurrentExecutions`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-reservedconcurrentexecutions | ||
*/ | ||
reservedConcurrentExecutions?: number | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Tags`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-tags | ||
*/ | ||
tags?: Array<cdk.Tag | cdk.Token> | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.Timeout`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-timeout | ||
*/ | ||
timeout?: number | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.TracingConfig`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-tracingconfig | ||
*/ | ||
tracingConfig?: FunctionResource.TracingConfigProperty | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Function.VpcConfig`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html#cfn-lambda-function-vpcconfig | ||
*/ | ||
vpcConfig?: FunctionResource.VpcConfigProperty | cdk.Token; | ||
} | ||
/** | ||
* @deprecated "cloudformation.FunctionResource" will be deprecated in a future release in favor of "CfnFunction" (see https://github.com/awslabs/aws-cdk/issues/878) | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-function.html | ||
*/ | ||
class FunctionResource extends cdk.Resource { | ||
/** | ||
* The CloudFormation resource type name for this resource class. | ||
*/ | ||
static readonly resourceTypeName = "AWS::Lambda::Function"; | ||
/** | ||
* @cloudformation_attribute Arn | ||
*/ | ||
readonly functionArn: string; | ||
readonly functionName: string; | ||
/** | ||
* Creates a new ``AWS::Lambda::Function``. | ||
* | ||
* @param parent the ``cdk.Construct`` this ``FunctionResource`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``FunctionResource`` | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: FunctionResourceProps); | ||
readonly propertyOverrides: FunctionResourceProps; | ||
protected renderProperties(properties: any): { | ||
[key: string]: any; | ||
}; | ||
} | ||
namespace FunctionResource { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-code.html | ||
*/ | ||
interface CodeProperty { | ||
/** | ||
* ``FunctionResource.CodeProperty.S3Bucket`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-code.html#cfn-lambda-function-code-s3bucket | ||
*/ | ||
s3Bucket?: string | cdk.Token; | ||
/** | ||
* ``FunctionResource.CodeProperty.S3Key`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-code.html#cfn-lambda-function-code-s3key | ||
*/ | ||
s3Key?: string | cdk.Token; | ||
/** | ||
* ``FunctionResource.CodeProperty.S3ObjectVersion`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-code.html#cfn-lambda-function-code-s3objectversion | ||
*/ | ||
s3ObjectVersion?: string | cdk.Token; | ||
/** | ||
* ``FunctionResource.CodeProperty.ZipFile`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-code.html#cfn-lambda-function-code-zipfile | ||
*/ | ||
zipFile?: string | cdk.Token; | ||
} | ||
} | ||
namespace FunctionResource { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-deadletterconfig.html | ||
*/ | ||
interface DeadLetterConfigProperty { | ||
/** | ||
* ``FunctionResource.DeadLetterConfigProperty.TargetArn`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-deadletterconfig.html#cfn-lambda-function-deadletterconfig-targetarn | ||
*/ | ||
targetArn?: string | cdk.Token; | ||
} | ||
} | ||
namespace FunctionResource { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-environment.html | ||
*/ | ||
interface EnvironmentProperty { | ||
/** | ||
* ``FunctionResource.EnvironmentProperty.Variables`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-environment.html#cfn-lambda-function-environment-variables | ||
*/ | ||
variables?: { | ||
[key: string]: (string | cdk.Token); | ||
} | cdk.Token; | ||
} | ||
} | ||
namespace FunctionResource { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-tracingconfig.html | ||
*/ | ||
interface TracingConfigProperty { | ||
/** | ||
* ``FunctionResource.TracingConfigProperty.Mode`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-tracingconfig.html#cfn-lambda-function-tracingconfig-mode | ||
*/ | ||
mode?: string | cdk.Token; | ||
} | ||
} | ||
namespace FunctionResource { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-vpcconfig.html | ||
*/ | ||
interface VpcConfigProperty { | ||
/** | ||
* ``FunctionResource.VpcConfigProperty.SecurityGroupIds`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-vpcconfig.html#cfn-lambda-function-vpcconfig-securitygroupids | ||
*/ | ||
securityGroupIds: Array<string | cdk.Token> | cdk.Token; | ||
/** | ||
* ``FunctionResource.VpcConfigProperty.SubnetIds`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lambda-function-vpcconfig.html#cfn-lambda-function-vpcconfig-subnetids | ||
*/ | ||
subnetIds: Array<string | cdk.Token> | cdk.Token; | ||
} | ||
} | ||
} | ||
/** | ||
@@ -697,3 +362,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html | ||
*/ | ||
action: string | cdk.Token; | ||
action: string; | ||
/** | ||
@@ -703,3 +368,3 @@ * ``AWS::Lambda::Permission.FunctionName`` | ||
*/ | ||
functionName: string | cdk.Token; | ||
functionName: string; | ||
/** | ||
@@ -709,3 +374,3 @@ * ``AWS::Lambda::Permission.Principal`` | ||
*/ | ||
principal: string | cdk.Token; | ||
principal: string; | ||
/** | ||
@@ -715,3 +380,3 @@ * ``AWS::Lambda::Permission.EventSourceToken`` | ||
*/ | ||
eventSourceToken?: string | cdk.Token; | ||
eventSourceToken?: string; | ||
/** | ||
@@ -721,3 +386,3 @@ * ``AWS::Lambda::Permission.SourceAccount`` | ||
*/ | ||
sourceAccount?: string | cdk.Token; | ||
sourceAccount?: string; | ||
/** | ||
@@ -727,3 +392,3 @@ * ``AWS::Lambda::Permission.SourceArn`` | ||
*/ | ||
sourceArn?: string | cdk.Token; | ||
sourceArn?: string; | ||
} | ||
@@ -741,7 +406,7 @@ /** | ||
* | ||
* @param parent the ``cdk.Construct`` this ``CfnPermission`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``CfnPermission`` | ||
* @param scope scope in which this resource is defined | ||
* @param id scoped id of the resource | ||
* @param props resource properties | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: CfnPermissionProps); | ||
constructor(scope: cdk.Construct, id: string, props: CfnPermissionProps); | ||
readonly propertyOverrides: CfnPermissionProps; | ||
@@ -752,61 +417,2 @@ protected renderProperties(properties: any): { | ||
} | ||
export declare namespace cloudformation { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html | ||
*/ | ||
interface PermissionResourceProps { | ||
/** | ||
* ``AWS::Lambda::Permission.Action`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html#cfn-lambda-permission-action | ||
*/ | ||
action: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Permission.FunctionName`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html#cfn-lambda-permission-functionname | ||
*/ | ||
functionName: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Permission.Principal`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html#cfn-lambda-permission-principal | ||
*/ | ||
principal: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Permission.EventSourceToken`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html#cfn-lambda-permission-eventsourcetoken | ||
*/ | ||
eventSourceToken?: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Permission.SourceAccount`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html#cfn-lambda-permission-sourceaccount | ||
*/ | ||
sourceAccount?: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Permission.SourceArn`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html#cfn-lambda-permission-sourcearn | ||
*/ | ||
sourceArn?: string | cdk.Token; | ||
} | ||
/** | ||
* @deprecated "cloudformation.PermissionResource" will be deprecated in a future release in favor of "CfnPermission" (see https://github.com/awslabs/aws-cdk/issues/878) | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-permission.html | ||
*/ | ||
class PermissionResource extends cdk.Resource { | ||
/** | ||
* The CloudFormation resource type name for this resource class. | ||
*/ | ||
static readonly resourceTypeName = "AWS::Lambda::Permission"; | ||
/** | ||
* Creates a new ``AWS::Lambda::Permission``. | ||
* | ||
* @param parent the ``cdk.Construct`` this ``PermissionResource`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``PermissionResource`` | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: PermissionResourceProps); | ||
readonly propertyOverrides: PermissionResourceProps; | ||
protected renderProperties(properties: any): { | ||
[key: string]: any; | ||
}; | ||
} | ||
} | ||
/** | ||
@@ -820,3 +426,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-version.html | ||
*/ | ||
functionName: string | cdk.Token; | ||
functionName: string; | ||
/** | ||
@@ -826,3 +432,3 @@ * ``AWS::Lambda::Version.CodeSha256`` | ||
*/ | ||
codeSha256?: string | cdk.Token; | ||
codeSha256?: string; | ||
/** | ||
@@ -832,3 +438,3 @@ * ``AWS::Lambda::Version.Description`` | ||
*/ | ||
description?: string | cdk.Token; | ||
description?: string; | ||
} | ||
@@ -851,7 +457,7 @@ /** | ||
* | ||
* @param parent the ``cdk.Construct`` this ``CfnVersion`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``CfnVersion`` | ||
* @param scope scope in which this resource is defined | ||
* @param id scoped id of the resource | ||
* @param props resource properties | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: CfnVersionProps); | ||
constructor(scope: cdk.Construct, id: string, props: CfnVersionProps); | ||
readonly propertyOverrides: CfnVersionProps; | ||
@@ -862,50 +468,1 @@ protected renderProperties(properties: any): { | ||
} | ||
export declare namespace cloudformation { | ||
/** | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-version.html | ||
*/ | ||
interface VersionResourceProps { | ||
/** | ||
* ``AWS::Lambda::Version.FunctionName`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-version.html#cfn-lambda-version-functionname | ||
*/ | ||
functionName: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Version.CodeSha256`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-version.html#cfn-lambda-version-codesha256 | ||
*/ | ||
codeSha256?: string | cdk.Token; | ||
/** | ||
* ``AWS::Lambda::Version.Description`` | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-version.html#cfn-lambda-version-description | ||
*/ | ||
description?: string | cdk.Token; | ||
} | ||
/** | ||
* @deprecated "cloudformation.VersionResource" will be deprecated in a future release in favor of "CfnVersion" (see https://github.com/awslabs/aws-cdk/issues/878) | ||
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-version.html | ||
*/ | ||
class VersionResource extends cdk.Resource { | ||
/** | ||
* The CloudFormation resource type name for this resource class. | ||
*/ | ||
static readonly resourceTypeName = "AWS::Lambda::Version"; | ||
/** | ||
* @cloudformation_attribute Version | ||
*/ | ||
readonly version: string; | ||
readonly versionArn: string; | ||
/** | ||
* Creates a new ``AWS::Lambda::Version``. | ||
* | ||
* @param parent the ``cdk.Construct`` this ``VersionResource`` is a part of | ||
* @param name the name of the resource in the ``cdk.Construct`` tree | ||
* @param properties the properties of this ``VersionResource`` | ||
*/ | ||
constructor(parent: cdk.Construct, name: string, properties: VersionResourceProps); | ||
readonly propertyOverrides: VersionResourceProps; | ||
protected renderProperties(properties: any): { | ||
[key: string]: any; | ||
}; | ||
} | ||
} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const cloudwatch = require("@aws-cdk/aws-cloudwatch"); | ||
const ec2 = require("@aws-cdk/aws-ec2"); | ||
@@ -41,5 +42,5 @@ const iam = require("@aws-cdk/aws-iam"); | ||
*/ | ||
class Function extends lambda_ref_1.FunctionRef { | ||
constructor(parent, name, props) { | ||
super(parent, name); | ||
class Function extends lambda_ref_1.FunctionBase { | ||
constructor(scope, id, props) { | ||
super(scope, id); | ||
this.canCreatePermissions = true; | ||
@@ -49,6 +50,6 @@ this.environment = props.environment || {}; | ||
// the arn is in the form of - arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole | ||
managedPolicyArns.push(new iam.AwsManagedPolicy("service-role/AWSLambdaBasicExecutionRole").policyArn); | ||
managedPolicyArns.push(new iam.AwsManagedPolicy("service-role/AWSLambdaBasicExecutionRole", this).policyArn); | ||
if (props.vpc) { | ||
// Policy that will have ENI creation permissions | ||
managedPolicyArns.push(new iam.AwsManagedPolicy("service-role/AWSLambdaVPCAccessExecutionRole").policyArn); | ||
managedPolicyArns.push(new iam.AwsManagedPolicy("service-role/AWSLambdaVPCAccessExecutionRole", this).policyArn); | ||
} | ||
@@ -65,3 +66,3 @@ this.role = props.role || new iam.Role(this, 'ServiceRole', { | ||
description: props.description, | ||
code: new cdk.Token(() => props.code.toJSON()), | ||
code: new cdk.Token(() => props.code.toJSON(resource)), | ||
handler: props.handler, | ||
@@ -86,2 +87,87 @@ timeout: props.timeout, | ||
/** | ||
* Creates a Lambda function object which represents a function not defined | ||
* within this stack. | ||
* | ||
* Lambda.import(this, 'MyImportedFunction', { lambdaArn: new LambdaArn('arn:aws:...') }); | ||
* | ||
* @param parent The parent construct | ||
* @param id The name of the lambda construct | ||
* @param props A reference to a Lambda function. Can be created manually (see | ||
* example above) or obtained through a call to `lambda.export()`. | ||
*/ | ||
static import(scope, id, props) { | ||
return new ImportedFunction(scope, id, props); | ||
} | ||
/** | ||
* Return the given named metric for this Lambda | ||
*/ | ||
static metricAll(metricName, props) { | ||
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/Lambda', metricName }, props)); | ||
} | ||
/** | ||
* Metric for the number of Errors executing all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllErrors(props) { | ||
return this.metricAll('Errors', Object.assign({ statistic: 'sum' }, props)); | ||
} | ||
/** | ||
* Metric for the Duration executing all Lambdas | ||
* | ||
* @default average over 5 minutes | ||
*/ | ||
static metricAllDuration(props) { | ||
return this.metricAll('Duration', props); | ||
} | ||
/** | ||
* Metric for the number of invocations of all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllInvocations(props) { | ||
return this.metricAll('Invocations', Object.assign({ statistic: 'sum' }, props)); | ||
} | ||
/** | ||
* Metric for the number of throttled invocations of all Lambdas | ||
* | ||
* @default sum over 5 minutes | ||
*/ | ||
static metricAllThrottles(props) { | ||
return this.metricAll('Throttles', Object.assign({ statistic: 'sum' }, props)); | ||
} | ||
/** | ||
* Metric for the number of concurrent executions across all Lambdas | ||
* | ||
* @default max over 5 minutes | ||
*/ | ||
static metricAllConcurrentExecutions(props) { | ||
// Mini-FAQ: why max? This metric is a gauge that is emitted every | ||
// minute, so either max or avg or a percentile make sense (but sum | ||
// doesn't). Max is more sensitive to spiky load changes which is | ||
// probably what you're interested in if you're looking at this metric | ||
// (Load spikes may lead to concurrent execution errors that would | ||
// otherwise not be visible in the avg) | ||
return this.metricAll('ConcurrentExecutions', Object.assign({ statistic: 'max' }, props)); | ||
} | ||
/** | ||
* Metric for the number of unreserved concurrent executions across all Lambdas | ||
* | ||
* @default max over 5 minutes | ||
*/ | ||
static metricAllUnreservedConcurrentExecutions(props) { | ||
return this.metricAll('UnreservedConcurrentExecutions', Object.assign({ statistic: 'max' }, props)); | ||
} | ||
/** | ||
* Export this Function (without the role) | ||
*/ | ||
export() { | ||
return { | ||
functionArn: new cdk.Output(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(), | ||
securityGroupId: this._connections && this._connections.securityGroups[0] | ||
? new cdk.Output(this, 'SecurityGroupId', { value: this._connections.securityGroups[0].securityGroupId }).makeImportValue().toString() | ||
: undefined | ||
}; | ||
} | ||
/** | ||
* Adds an environment variable to this Lambda function. | ||
@@ -116,3 +202,3 @@ * If this is a ref to a Lambda function, this operation results in a no-op. | ||
addVersion(name, codeSha256, description) { | ||
return new lambda_version_1.FunctionVersion(this, 'Version' + name, { | ||
return new lambda_version_1.Version(this, 'Version' + name, { | ||
lambda: this, | ||
@@ -149,3 +235,3 @@ codeSha256, | ||
vpc: props.vpc, | ||
description: 'Automatic security group for Lambda Function ' + this.uniqueId, | ||
description: 'Automatic security group for Lambda Function ' + this.node.uniqueId, | ||
allowAllOutbound: props.allowAllOutbound | ||
@@ -197,2 +283,39 @@ }); | ||
exports.Function = Function; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda.js","sourceRoot":"","sources":["lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport iam = require('@aws-cdk/aws-iam');\nimport sqs = require('@aws-cdk/aws-sqs');\nimport cdk = require('@aws-cdk/cdk');\nimport { Code } from './code';\nimport { FunctionRef } from './lambda-ref';\nimport { FunctionVersion } from './lambda-version';\nimport { CfnFunction } from './lambda.generated';\nimport { Runtime } from './runtime';\n\n/**\n * X-Ray Tracing Modes (https://docs.aws.amazon.com/lambda/latest/dg/API_TracingConfig.html)\n */\nexport enum Tracing {\n  /**\n   * Lambda will respect any tracing header it receives from an upstream service.\n   * If no tracing header is received, Lambda will call X-Ray for a tracing decision.\n   */\n  Active,\n  /**\n   * Lambda will only trace the request from an upstream service\n   * if it contains a tracing header with \"sampled=1\"\n   */\n  PassThrough,\n  /**\n   * Lambda will not trace any request.\n   */\n  Disabled\n}\n\nexport interface FunctionProps {\n  /**\n   * The source code of your Lambda function. You can point to a file in an\n   * Amazon Simple Storage Service (Amazon S3) bucket or specify your source\n   * code as inline text.\n   */\n  code: Code;\n\n  /**\n   * A description of the function.\n   */\n  description?: string;\n\n  /**\n   * The name of the function (within your source code) that Lambda calls to\n   * start running your code. For more information, see the Handler property\n   * in the AWS Lambda Developer Guide.\n   *\n   * NOTE: If you specify your source code as inline text by specifying the\n   * ZipFile property within the Code property, specify index.function_name as\n   * the handler.\n   */\n  handler: string;\n\n  /**\n   * The function execution time (in seconds) after which Lambda terminates\n   * the function. Because the execution time affects cost, set this value\n   * based on the function's expected execution time.\n   *\n   * @default 3 seconds.\n   */\n  timeout?: number;\n\n  /**\n   * Key-value pairs that Lambda caches and makes available for your Lambda\n   * functions. Use environment variables to apply configuration changes, such\n   * as test and production environment configurations, without changing your\n   * Lambda function source code.\n   */\n  environment?: { [key: string]: any };\n\n  /**\n   * The runtime environment for the Lambda function that you are uploading.\n   * For valid values, see the Runtime property in the AWS Lambda Developer\n   * Guide.\n   */\n  runtime: Runtime;\n\n  /**\n   * A name for the function. If you don't specify a name, AWS CloudFormation\n   * generates a unique physical ID and uses that ID for the function's name.\n   * For more information, see Name Type.\n   */\n  functionName?: string;\n\n  /**\n   * The amount of memory, in MB, that is allocated to your Lambda function.\n   * Lambda uses this value to proportionally allocate the amount of CPU\n   * power. For more information, see Resource Model in the AWS Lambda\n   * Developer Guide.\n   *\n   * @default The default value is 128 MB\n   */\n  memorySize?: number;\n\n  /**\n   * Initial policy statements to add to the created Lambda Role.\n   *\n   * You can call `addToRolePolicy` to the created lambda to add statements post creation.\n   */\n  initialPolicy?: iam.PolicyStatement[];\n\n  /**\n   * Lambda execution role.\n   *\n   * This is the role that will be assumed by the function upon execution.\n   * It controls the permissions that the function will have. The Role must\n   * be assumable by the 'lambda.amazonaws.com' service principal.\n   *\n   * @default a unique role will be generated for this lambda function.\n   * Both supplied and generated roles can always be changed by calling `addToRolePolicy`.\n   */\n  role?: iam.Role;\n\n  /**\n   * VPC network to place Lambda network interfaces\n   *\n   * Specify this if the Lambda function needs to access resources in a VPC.\n   */\n  vpc?: ec2.VpcNetworkRef;\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * Only used if 'vpc' is supplied. Note: internet access for Lambdas\n   * requires a NAT gateway, so picking Public subnets is not allowed.\n   *\n   * @default All private subnets\n   */\n  vpcPlacement?: ec2.VpcPlacementStrategy;\n\n  /**\n   * What security group to associate with the Lambda's network interfaces.\n   *\n   * Only used if 'vpc' is supplied.\n   *\n   * @default If the function is placed within a VPC and a security group is\n   * not specified, a dedicated security group will be created for this\n   * function.\n   */\n  securityGroup?: ec2.SecurityGroupRef;\n\n  /**\n   * Whether to allow the Lambda to send all network traffic\n   *\n   * If set to false, you must individually add traffic rules to allow the\n   * Lambda to connect to network targets.\n   *\n   * @default true\n   */\n  allowAllOutbound?: boolean;\n\n  /**\n   * Enabled DLQ. If `deadLetterQueue` is undefined,\n   * an SQS queue with default options will be defined for your Function.\n   *\n   * @default false unless `deadLetterQueue` is set, which implies DLQ is enabled\n   */\n  deadLetterQueueEnabled?: boolean;\n\n  /**\n   * The SQS queue to use if DLQ is enabled.\n   *\n   * @default SQS queue with 14 day retention period if `deadLetterQueueEnabled` is `true`\n   */\n  deadLetterQueue?: sqs.QueueRef;\n\n  /**\n   * Enable AWS X-Ray Tracing for Lambda Function.\n   *\n   * @default undefined X-Ray tracing disabled\n   */\n  tracing?: Tracing;\n}\n\n/**\n * Deploys a file from from inside the construct library as a function.\n *\n * The supplied file is subject to the 4096 bytes limit of being embedded in a\n * CloudFormation template.\n *\n * The construct includes an associated role with the lambda.\n *\n * This construct does not yet reproduce all features from the underlying resource\n * library.\n */\nexport class Function extends FunctionRef {\n  /**\n   * Name of this function\n   */\n  public readonly functionName: string;\n\n  /**\n   * ARN of this function\n   */\n  public readonly functionArn: string;\n\n  /**\n   * Execution role associated with this function\n   */\n  public readonly role?: iam.Role;\n\n  /**\n   * The runtime configured for this lambda.\n   */\n  public readonly runtime: Runtime;\n\n  /**\n   * The name of the handler configured for this lambda.\n   */\n  public readonly handler: string;\n\n  protected readonly canCreatePermissions = true;\n\n  /**\n   * Environment variables for this function\n   */\n  private readonly environment?: { [key: string]: any };\n\n  constructor(parent: cdk.Construct, name: string, props: FunctionProps) {\n    super(parent, name);\n\n    this.environment = props.environment || { };\n\n    const managedPolicyArns = new Array<string>();\n\n    // the arn is in the form of - arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole\n    managedPolicyArns.push(new iam.AwsManagedPolicy(\"service-role/AWSLambdaBasicExecutionRole\").policyArn);\n\n    if (props.vpc) {\n      // Policy that will have ENI creation permissions\n      managedPolicyArns.push(new iam.AwsManagedPolicy(\"service-role/AWSLambdaVPCAccessExecutionRole\").policyArn);\n    }\n\n    this.role = props.role || new iam.Role(this, 'ServiceRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      managedPolicyArns,\n    });\n\n    for (const statement of (props.initialPolicy || [])) {\n      this.role.addToPolicy(statement);\n    }\n\n    const resource = new CfnFunction(this, 'Resource', {\n      functionName: props.functionName,\n      description: props.description,\n      code: new cdk.Token(() => props.code.toJSON()),\n      handler: props.handler,\n      timeout: props.timeout,\n      runtime: props.runtime.name,\n      role: this.role.roleArn,\n      environment: new cdk.Token(() => this.renderEnvironment()),\n      memorySize: props.memorySize,\n      vpcConfig: this.configureVpc(props),\n      deadLetterConfig: this.buildDeadLetterConfig(props),\n      tracingConfig: this.buildTracingConfig(props)\n    });\n\n    resource.addDependency(this.role);\n\n    this.functionName = resource.ref;\n    this.functionArn = resource.functionArn;\n    this.handler = props.handler;\n    this.runtime = props.runtime;\n\n    // allow code to bind to stack.\n    props.code.bind(this);\n  }\n\n  /**\n   * Adds an environment variable to this Lambda function.\n   * If this is a ref to a Lambda function, this operation results in a no-op.\n   * @param key The environment variable key.\n   * @param value The environment variable's value.\n   */\n  public addEnvironment(key: string, value: any) {\n    if (!this.environment) {\n      // TODO: add metadata\n      return;\n    }\n    this.environment[key] = value;\n  }\n\n  /**\n   * Add a new version for this Lambda\n   *\n   * If you want to deploy through CloudFormation and use aliases, you need to\n   * add a new version (with a new name) to your Lambda every time you want\n   * to deploy an update. An alias can then refer to the newly created Version.\n   *\n   * All versions should have distinct names, and you should not delete versions\n   * as long as your Alias needs to refer to them.\n   *\n   * @param name A unique name for this version\n   * @param codeSha256 The SHA-256 hash of the most recently deployed Lambda source code, or\n   *  omit to skip validation.\n   * @param description A description for this version.\n   * @returns A new Version object.\n   */\n  public addVersion(name: string, codeSha256?: string, description?: string): FunctionVersion {\n    return new FunctionVersion(this, 'Version' + name, {\n      lambda: this,\n      codeSha256,\n      description,\n    });\n  }\n\n  private renderEnvironment() {\n    if (!this.environment || Object.keys(this.environment).length === 0) {\n      return undefined;\n    }\n\n    return {\n      variables: this.environment\n    };\n  }\n\n  /**\n   * If configured, set up the VPC-related properties\n   *\n   * Returns the VpcConfig that should be added to the\n   * Lambda creation properties.\n   */\n  private configureVpc(props: FunctionProps): CfnFunction.VpcConfigProperty | undefined {\n    if ((props.securityGroup || props.allowAllOutbound !== undefined) && !props.vpc) {\n      throw new Error(`Cannot configure 'securityGroup' or 'allowAllOutbound' without configuring a VPC`);\n    }\n\n    if (!props.vpc) { return undefined; }\n\n    if (props.securityGroup && props.allowAllOutbound !== undefined) {\n      throw new Error(`Configure 'allowAllOutbound' directly on the supplied SecurityGroup.`);\n    }\n\n    const securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: 'Automatic security group for Lambda Function ' + this.uniqueId,\n      allowAllOutbound: props.allowAllOutbound\n    });\n\n    this._connections = new ec2.Connections({ securityGroups: [securityGroup] });\n\n    // Pick subnets, make sure they're not Public. Routing through an IGW\n    // won't work because the ENIs don't get a Public IP.\n    const subnets = props.vpc.subnets(props.vpcPlacement);\n    for (const subnet of subnets) {\n      if (props.vpc.isPublicSubnet(subnet)) {\n        throw new Error('Not possible to place Lambda Functions in a Public subnet');\n      }\n    }\n\n    return {\n      subnetIds: subnets.map(s => s.subnetId),\n      securityGroupIds: [securityGroup.securityGroupId]\n    };\n  }\n\n  private buildDeadLetterConfig(props: FunctionProps) {\n    if (props.deadLetterQueue && props.deadLetterQueueEnabled === false) {\n      throw Error('deadLetterQueue defined but deadLetterQueueEnabled explicitly set to false');\n    }\n\n    if (!props.deadLetterQueue && !props.deadLetterQueueEnabled) {\n      return undefined;\n    }\n\n    const deadLetterQueue = props.deadLetterQueue || new sqs.Queue(this, 'DeadLetterQueue', {\n      retentionPeriodSec: 1209600\n    });\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addAction('sqs:SendMessage')\n      .addResource(deadLetterQueue.queueArn));\n\n    return {\n      targetArn: deadLetterQueue.queueArn\n    };\n  }\n\n  private buildTracingConfig(props: FunctionProps) {\n    if (props.tracing === undefined || props.tracing === Tracing.Disabled) {\n      return undefined;\n    }\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addActions('xray:PutTraceSegments', 'xray:PutTelemetryRecords')\n      .addAllResources());\n\n    return {\n      mode: Tracing[props.tracing]\n    };\n  }\n\n}\n"]} | ||
class ImportedFunction extends lambda_ref_1.FunctionBase { | ||
constructor(scope, id, props) { | ||
super(scope, id); | ||
this.props = props; | ||
this.canCreatePermissions = false; | ||
this.functionArn = props.functionArn; | ||
this.functionName = extractNameFromArn(props.functionArn); | ||
this.role = props.role; | ||
if (props.securityGroupId) { | ||
this._connections = new ec2.Connections({ | ||
securityGroups: [ | ||
ec2.SecurityGroup.import(this, 'SecurityGroup', { securityGroupId: props.securityGroupId }) | ||
] | ||
}); | ||
} | ||
} | ||
export() { | ||
return this.props; | ||
} | ||
} | ||
exports.ImportedFunction = ImportedFunction; | ||
/** | ||
* Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function | ||
* name from the ARN. | ||
* | ||
* Function ARNs look like this: | ||
* | ||
* arn:aws:lambda:region:account-id:function:function-name | ||
* | ||
* ..which means that in order to extract the `function-name` component from the ARN, we can | ||
* split the ARN using ":" and select the component in index 6. | ||
* | ||
* @returns `FnSelect(6, FnSplit(':', arn))` | ||
*/ | ||
function extractNameFromArn(arn) { | ||
return cdk.Fn.select(6, cdk.Fn.split(':', arn)); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda.js","sourceRoot":"","sources":["lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport iam = require('@aws-cdk/aws-iam');\nimport sqs = require('@aws-cdk/aws-sqs');\nimport cdk = require('@aws-cdk/cdk');\nimport { Code } from './code';\nimport { FunctionBase, FunctionImportProps, IFunction } from './lambda-ref';\nimport { Version } from './lambda-version';\nimport { CfnFunction } from './lambda.generated';\nimport { Runtime } from './runtime';\n\n/**\n * X-Ray Tracing Modes (https://docs.aws.amazon.com/lambda/latest/dg/API_TracingConfig.html)\n */\nexport enum Tracing {\n  /**\n   * Lambda will respect any tracing header it receives from an upstream service.\n   * If no tracing header is received, Lambda will call X-Ray for a tracing decision.\n   */\n  Active,\n  /**\n   * Lambda will only trace the request from an upstream service\n   * if it contains a tracing header with \"sampled=1\"\n   */\n  PassThrough,\n  /**\n   * Lambda will not trace any request.\n   */\n  Disabled\n}\n\nexport interface FunctionProps {\n  /**\n   * The source code of your Lambda function. You can point to a file in an\n   * Amazon Simple Storage Service (Amazon S3) bucket or specify your source\n   * code as inline text.\n   */\n  code: Code;\n\n  /**\n   * A description of the function.\n   */\n  description?: string;\n\n  /**\n   * The name of the function (within your source code) that Lambda calls to\n   * start running your code. For more information, see the Handler property\n   * in the AWS Lambda Developer Guide.\n   *\n   * NOTE: If you specify your source code as inline text by specifying the\n   * ZipFile property within the Code property, specify index.function_name as\n   * the handler.\n   */\n  handler: string;\n\n  /**\n   * The function execution time (in seconds) after which Lambda terminates\n   * the function. Because the execution time affects cost, set this value\n   * based on the function's expected execution time.\n   *\n   * @default 3 seconds.\n   */\n  timeout?: number;\n\n  /**\n   * Key-value pairs that Lambda caches and makes available for your Lambda\n   * functions. Use environment variables to apply configuration changes, such\n   * as test and production environment configurations, without changing your\n   * Lambda function source code.\n   */\n  environment?: { [key: string]: any };\n\n  /**\n   * The runtime environment for the Lambda function that you are uploading.\n   * For valid values, see the Runtime property in the AWS Lambda Developer\n   * Guide.\n   */\n  runtime: Runtime;\n\n  /**\n   * A name for the function. If you don't specify a name, AWS CloudFormation\n   * generates a unique physical ID and uses that ID for the function's name.\n   * For more information, see Name Type.\n   */\n  functionName?: string;\n\n  /**\n   * The amount of memory, in MB, that is allocated to your Lambda function.\n   * Lambda uses this value to proportionally allocate the amount of CPU\n   * power. For more information, see Resource Model in the AWS Lambda\n   * Developer Guide.\n   *\n   * @default The default value is 128 MB\n   */\n  memorySize?: number;\n\n  /**\n   * Initial policy statements to add to the created Lambda Role.\n   *\n   * You can call `addToRolePolicy` to the created lambda to add statements post creation.\n   */\n  initialPolicy?: iam.PolicyStatement[];\n\n  /**\n   * Lambda execution role.\n   *\n   * This is the role that will be assumed by the function upon execution.\n   * It controls the permissions that the function will have. The Role must\n   * be assumable by the 'lambda.amazonaws.com' service principal.\n   *\n   * @default a unique role will be generated for this lambda function.\n   * Both supplied and generated roles can always be changed by calling `addToRolePolicy`.\n   */\n  role?: iam.IRole;\n\n  /**\n   * VPC network to place Lambda network interfaces\n   *\n   * Specify this if the Lambda function needs to access resources in a VPC.\n   */\n  vpc?: ec2.IVpcNetwork;\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * Only used if 'vpc' is supplied. Note: internet access for Lambdas\n   * requires a NAT gateway, so picking Public subnets is not allowed.\n   *\n   * @default All private subnets\n   */\n  vpcPlacement?: ec2.VpcPlacementStrategy;\n\n  /**\n   * What security group to associate with the Lambda's network interfaces.\n   *\n   * Only used if 'vpc' is supplied.\n   *\n   * @default If the function is placed within a VPC and a security group is\n   * not specified, a dedicated security group will be created for this\n   * function.\n   */\n  securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Whether to allow the Lambda to send all network traffic\n   *\n   * If set to false, you must individually add traffic rules to allow the\n   * Lambda to connect to network targets.\n   *\n   * @default true\n   */\n  allowAllOutbound?: boolean;\n\n  /**\n   * Enabled DLQ. If `deadLetterQueue` is undefined,\n   * an SQS queue with default options will be defined for your Function.\n   *\n   * @default false unless `deadLetterQueue` is set, which implies DLQ is enabled\n   */\n  deadLetterQueueEnabled?: boolean;\n\n  /**\n   * The SQS queue to use if DLQ is enabled.\n   *\n   * @default SQS queue with 14 day retention period if `deadLetterQueueEnabled` is `true`\n   */\n  deadLetterQueue?: sqs.IQueue;\n\n  /**\n   * Enable AWS X-Ray Tracing for Lambda Function.\n   *\n   * @default undefined X-Ray tracing disabled\n   */\n  tracing?: Tracing;\n}\n\n/**\n * Deploys a file from from inside the construct library as a function.\n *\n * The supplied file is subject to the 4096 bytes limit of being embedded in a\n * CloudFormation template.\n *\n * The construct includes an associated role with the lambda.\n *\n * This construct does not yet reproduce all features from the underlying resource\n * library.\n */\nexport class Function extends FunctionBase {\n  /**\n   * Creates a Lambda function object which represents a function not defined\n   * within this stack.\n   *\n   *    Lambda.import(this, 'MyImportedFunction', { lambdaArn: new LambdaArn('arn:aws:...') });\n   *\n   * @param parent The parent construct\n   * @param id The name of the lambda construct\n   * @param props A reference to a Lambda function. Can be created manually (see\n   * example above) or obtained through a call to `lambda.export()`.\n   */\n  public static import(scope: cdk.Construct, id: string, props: FunctionImportProps): IFunction {\n    return new ImportedFunction(scope, id, props);\n  }\n\n  /**\n   * Return the given named metric for this Lambda\n   */\n  public static metricAll(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/Lambda',\n      metricName,\n      ...props\n    });\n  }\n  /**\n   * Metric for the number of Errors executing all Lambdas\n   *\n   * @default sum over 5 minutes\n   */\n  public static metricAllErrors(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metricAll('Errors', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the Duration executing all Lambdas\n   *\n   * @default average over 5 minutes\n   */\n  public static metricAllDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metricAll('Duration', props);\n  }\n\n  /**\n   * Metric for the number of invocations of all Lambdas\n   *\n   * @default sum over 5 minutes\n   */\n  public static metricAllInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metricAll('Invocations', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the number of throttled invocations of all Lambdas\n   *\n   * @default sum over 5 minutes\n   */\n  public static metricAllThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metricAll('Throttles', { statistic: 'sum', ...props });\n  }\n\n  /**\n   * Metric for the number of concurrent executions across all Lambdas\n   *\n   * @default max over 5 minutes\n   */\n  public static metricAllConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    // Mini-FAQ: why max? This metric is a gauge that is emitted every\n    // minute, so either max or avg or a percentile make sense (but sum\n    // doesn't). Max is more sensitive to spiky load changes which is\n    // probably what you're interested in if you're looking at this metric\n    // (Load spikes may lead to concurrent execution errors that would\n    // otherwise not be visible in the avg)\n    return this.metricAll('ConcurrentExecutions', { statistic: 'max', ...props });\n  }\n\n  /**\n   * Metric for the number of unreserved concurrent executions across all Lambdas\n   *\n   * @default max over 5 minutes\n   */\n  public static metricAllUnreservedConcurrentExecutions(props?: cloudwatch.MetricCustomization): cloudwatch.Metric {\n    return this.metricAll('UnreservedConcurrentExecutions', { statistic: 'max', ...props });\n  }\n\n  /**\n   * Name of this function\n   */\n  public readonly functionName: string;\n\n  /**\n   * ARN of this function\n   */\n  public readonly functionArn: string;\n\n  /**\n   * Execution role associated with this function\n   */\n  public readonly role?: iam.IRole;\n\n  /**\n   * The runtime configured for this lambda.\n   */\n  public readonly runtime: Runtime;\n\n  /**\n   * The name of the handler configured for this lambda.\n   */\n  public readonly handler: string;\n\n  protected readonly canCreatePermissions = true;\n\n  /**\n   * Environment variables for this function\n   */\n  private readonly environment?: { [key: string]: any };\n\n  constructor(scope: cdk.Construct, id: string, props: FunctionProps) {\n    super(scope, id);\n\n    this.environment = props.environment || { };\n\n    const managedPolicyArns = new Array<string>();\n\n    // the arn is in the form of - arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole\n    managedPolicyArns.push(new iam.AwsManagedPolicy(\"service-role/AWSLambdaBasicExecutionRole\", this).policyArn);\n\n    if (props.vpc) {\n      // Policy that will have ENI creation permissions\n      managedPolicyArns.push(new iam.AwsManagedPolicy(\"service-role/AWSLambdaVPCAccessExecutionRole\", this).policyArn);\n    }\n\n    this.role = props.role || new iam.Role(this, 'ServiceRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      managedPolicyArns,\n    });\n\n    for (const statement of (props.initialPolicy || [])) {\n      this.role.addToPolicy(statement);\n    }\n\n    const resource = new CfnFunction(this, 'Resource', {\n      functionName: props.functionName,\n      description: props.description,\n      code: new cdk.Token(() => props.code.toJSON(resource)),\n      handler: props.handler,\n      timeout: props.timeout,\n      runtime: props.runtime.name,\n      role: this.role.roleArn,\n      environment: new cdk.Token(() => this.renderEnvironment()),\n      memorySize: props.memorySize,\n      vpcConfig: this.configureVpc(props),\n      deadLetterConfig: this.buildDeadLetterConfig(props),\n      tracingConfig: this.buildTracingConfig(props)\n    });\n\n    resource.addDependency(this.role);\n\n    this.functionName = resource.ref;\n    this.functionArn = resource.functionArn;\n    this.handler = props.handler;\n    this.runtime = props.runtime;\n\n    // allow code to bind to stack.\n    props.code.bind(this);\n  }\n\n  /**\n   * Export this Function (without the role)\n   */\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.Output(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(),\n      securityGroupId: this._connections && this._connections.securityGroups[0]\n          ? new cdk.Output(this, 'SecurityGroupId', { value: this._connections.securityGroups[0].securityGroupId }).makeImportValue().toString()\n          : undefined\n    };\n  }\n\n  /**\n   * Adds an environment variable to this Lambda function.\n   * If this is a ref to a Lambda function, this operation results in a no-op.\n   * @param key The environment variable key.\n   * @param value The environment variable's value.\n   */\n  public addEnvironment(key: string, value: any) {\n    if (!this.environment) {\n      // TODO: add metadata\n      return;\n    }\n    this.environment[key] = value;\n  }\n\n  /**\n   * Add a new version for this Lambda\n   *\n   * If you want to deploy through CloudFormation and use aliases, you need to\n   * add a new version (with a new name) to your Lambda every time you want\n   * to deploy an update. An alias can then refer to the newly created Version.\n   *\n   * All versions should have distinct names, and you should not delete versions\n   * as long as your Alias needs to refer to them.\n   *\n   * @param name A unique name for this version\n   * @param codeSha256 The SHA-256 hash of the most recently deployed Lambda source code, or\n   *  omit to skip validation.\n   * @param description A description for this version.\n   * @returns A new Version object.\n   */\n  public addVersion(name: string, codeSha256?: string, description?: string): Version {\n    return new Version(this, 'Version' + name, {\n      lambda: this,\n      codeSha256,\n      description,\n    });\n  }\n\n  private renderEnvironment() {\n    if (!this.environment || Object.keys(this.environment).length === 0) {\n      return undefined;\n    }\n\n    return {\n      variables: this.environment\n    };\n  }\n\n  /**\n   * If configured, set up the VPC-related properties\n   *\n   * Returns the VpcConfig that should be added to the\n   * Lambda creation properties.\n   */\n  private configureVpc(props: FunctionProps): CfnFunction.VpcConfigProperty | undefined {\n    if ((props.securityGroup || props.allowAllOutbound !== undefined) && !props.vpc) {\n      throw new Error(`Cannot configure 'securityGroup' or 'allowAllOutbound' without configuring a VPC`);\n    }\n\n    if (!props.vpc) { return undefined; }\n\n    if (props.securityGroup && props.allowAllOutbound !== undefined) {\n      throw new Error(`Configure 'allowAllOutbound' directly on the supplied SecurityGroup.`);\n    }\n\n    const securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: 'Automatic security group for Lambda Function ' + this.node.uniqueId,\n      allowAllOutbound: props.allowAllOutbound\n    });\n\n    this._connections = new ec2.Connections({ securityGroups: [securityGroup] });\n\n    // Pick subnets, make sure they're not Public. Routing through an IGW\n    // won't work because the ENIs don't get a Public IP.\n    const subnets = props.vpc.subnets(props.vpcPlacement);\n    for (const subnet of subnets) {\n      if (props.vpc.isPublicSubnet(subnet)) {\n        throw new Error('Not possible to place Lambda Functions in a Public subnet');\n      }\n    }\n\n    return {\n      subnetIds: subnets.map(s => s.subnetId),\n      securityGroupIds: [securityGroup.securityGroupId]\n    };\n  }\n\n  private buildDeadLetterConfig(props: FunctionProps) {\n    if (props.deadLetterQueue && props.deadLetterQueueEnabled === false) {\n      throw Error('deadLetterQueue defined but deadLetterQueueEnabled explicitly set to false');\n    }\n\n    if (!props.deadLetterQueue && !props.deadLetterQueueEnabled) {\n      return undefined;\n    }\n\n    const deadLetterQueue = props.deadLetterQueue || new sqs.Queue(this, 'DeadLetterQueue', {\n      retentionPeriodSec: 1209600\n    });\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addAction('sqs:SendMessage')\n      .addResource(deadLetterQueue.queueArn));\n\n    return {\n      targetArn: deadLetterQueue.queueArn\n    };\n  }\n\n  private buildTracingConfig(props: FunctionProps) {\n    if (props.tracing === undefined || props.tracing === Tracing.Disabled) {\n      return undefined;\n    }\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addActions('xray:PutTraceSegments', 'xray:PutTelemetryRecords')\n      .addAllResources());\n\n    return {\n      mode: Tracing[props.tracing]\n    };\n  }\n}\n\nexport class ImportedFunction extends FunctionBase {\n  public readonly functionName: string;\n  public readonly functionArn: string;\n  public readonly role?: iam.IRole;\n\n  protected readonly canCreatePermissions = false;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: FunctionImportProps) {\n    super(scope, id);\n\n    this.functionArn = props.functionArn;\n    this.functionName = extractNameFromArn(props.functionArn);\n    this.role = props.role;\n\n    if (props.securityGroupId) {\n      this._connections = new ec2.Connections({\n        securityGroups: [\n          ec2.SecurityGroup.import(this, 'SecurityGroup', { securityGroupId: props.securityGroupId })\n        ]\n      });\n    }\n  }\n\n  public export() {\n    return this.props;\n  }\n}\n\n/**\n * Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function\n * name from the ARN.\n *\n * Function ARNs look like this:\n *\n *   arn:aws:lambda:region:account-id:function:function-name\n *\n * ..which means that in order to extract the `function-name` component from the ARN, we can\n * split the ARN using \":\" and select the component in index 6.\n *\n * @returns `FnSelect(6, FnSplit(':', arn))`\n */\nfunction extractNameFromArn(arn: string) {\n  return cdk.Fn.select(6, cdk.Fn.split(':', arn));\n}"]} |
import codepipeline = require('@aws-cdk/aws-codepipeline-api'); | ||
import cdk = require('@aws-cdk/cdk'); | ||
import { FunctionRef } from './lambda-ref'; | ||
import { IFunction } from './lambda-ref'; | ||
/** | ||
* Common properties for creating a {@link PipelineInvokeAction} - | ||
* either directly, through its constructor, | ||
* or through {@link FunctionRef#addToPipeline}. | ||
* or through {@link IFunction#addToPipeline}. | ||
*/ | ||
export interface CommonPipelineInvokeActionProps extends codepipeline.CommonActionProps { | ||
/** | ||
* The optional input Artifacts of the Action. | ||
* A Lambda Action can have up to 5 inputs. | ||
* The inputs will appear in the event passed to the Lambda, | ||
* under the `'CodePipeline.job'.data.inputArtifacts` path. | ||
* | ||
* @default the Action will not have any inputs | ||
* @see https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-json-event-example | ||
*/ | ||
inputArtifacts?: codepipeline.Artifact[]; | ||
/** | ||
* The optional names of the output Artifacts of the Action. | ||
* A Lambda Action can have up to 5 outputs. | ||
* The outputs will appear in the event passed to the Lambda, | ||
* under the `'CodePipeline.job'.data.outputArtifacts` path. | ||
* It is the responsibility of the Lambda to upload ZIP files with the Artifact contents to the provided locations. | ||
* | ||
* @default the Action will not have any outputs | ||
*/ | ||
outputArtifactNames?: string[]; | ||
/** | ||
* String to be used in the event data parameter passed to the Lambda | ||
@@ -43,3 +63,3 @@ * function | ||
*/ | ||
lambda: FunctionRef; | ||
lambda: IFunction; | ||
} | ||
@@ -52,3 +72,5 @@ /** | ||
export declare class PipelineInvokeAction extends codepipeline.Action { | ||
constructor(parent: cdk.Construct, name: string, props: PipelineInvokeActionProps); | ||
constructor(scope: cdk.Construct, id: string, props: PipelineInvokeActionProps); | ||
outputArtifacts(): codepipeline.Artifact[]; | ||
outputArtifact(artifactName: string): codepipeline.Artifact; | ||
} |
@@ -11,4 +11,4 @@ "use strict"; | ||
class PipelineInvokeAction extends codepipeline.Action { | ||
constructor(parent, name, props) { | ||
super(parent, name, { | ||
constructor(scope, id, props) { | ||
super(scope, id, { | ||
stage: props.stage, | ||
@@ -24,2 +24,10 @@ runOrder: props.runOrder, | ||
}); | ||
// handle input artifacts | ||
for (const inputArtifact of props.inputArtifacts || []) { | ||
this.addInputArtifact(inputArtifact); | ||
} | ||
// handle output artifacts | ||
for (const outputArtifactName of props.outputArtifactNames || []) { | ||
this.addOutputArtifact(outputArtifactName); | ||
} | ||
// allow pipeline to list functions | ||
@@ -42,4 +50,16 @@ props.stage.pipeline.role.addToPolicy(new iam.PolicyStatement() | ||
} | ||
outputArtifacts() { | ||
return this._outputArtifacts; | ||
} | ||
outputArtifact(artifactName) { | ||
const result = this._outputArtifacts.find(a => (a.name === artifactName)); | ||
if (result === undefined) { | ||
throw new Error(`Could not find the output Artifact with name '${artifactName}'`); | ||
} | ||
else { | ||
return result; | ||
} | ||
} | ||
} | ||
exports.PipelineInvokeAction = PipelineInvokeAction; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlwZWxpbmUtYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicGlwZWxpbmUtYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsOERBQStEO0FBQy9ELHdDQUF5QztBQWlEekM7Ozs7R0FJRztBQUNILE1BQWEsb0JBQXFCLFNBQVEsWUFBWSxDQUFDLE1BQU07SUFDM0QsWUFBWSxNQUFxQixFQUFFLElBQVksRUFBRSxLQUFnQztRQUMvRSxLQUFLLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRTtZQUNsQixLQUFLLEVBQUUsS0FBSyxDQUFDLEtBQUs7WUFDbEIsUUFBUSxFQUFFLEtBQUssQ0FBQyxRQUFRO1lBQ3hCLFFBQVEsRUFBRSxZQUFZLENBQUMsY0FBYyxDQUFDLE1BQU07WUFDNUMsUUFBUSxFQUFFLFFBQVE7WUFDbEIsY0FBYyxFQUFFLFlBQVksQ0FBQyxhQUFhLEVBQUU7WUFDNUMsYUFBYSxFQUFFO2dCQUNiLFlBQVksRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVk7Z0JBQ3ZDLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYzthQUNyQztTQUNGLENBQUMsQ0FBQztRQUVILG1DQUFtQztRQUNuQyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksR0FBRyxDQUFDLGVBQWUsRUFBRTthQUM1RCxTQUFTLENBQUMsc0JBQXNCLENBQUM7YUFDakMsZUFBZSxFQUFFLENBQUMsQ0FBQztRQUV0QixpREFBaUQ7UUFDakQsS0FBSyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxlQUFlLEVBQUU7YUFDNUQsU0FBUyxDQUFDLHVCQUF1QixDQUFDO2FBQ2xDLFdBQVcsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7UUFFMUMscURBQXFEO1FBQ3JELE1BQU0sV0FBVyxHQUFHLEtBQUssQ0FBQyxxQkFBcUIsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQ25HLElBQUksV0FBVyxFQUFFO1lBQ2YsS0FBSyxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsSUFBSSxHQUFHLENBQUMsZUFBZSxFQUFFO2lCQUNuRCxlQUFlLEVBQUUsQ0FBQyw2QkFBNkI7aUJBQy9DLFNBQVMsQ0FBQyxrQ0FBa0MsQ0FBQztpQkFDN0MsU0FBUyxDQUFDLGtDQUFrQyxDQUFDLENBQUMsQ0FBQztTQUNuRDtJQUNILENBQUM7Q0FDRjtBQWpDRCxvREFpQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY29kZXBpcGVsaW5lID0gcmVxdWlyZSgnQGF3cy1jZGsvYXdzLWNvZGVwaXBlbGluZS1hcGknKTtcbmltcG9ydCBpYW0gPSByZXF1aXJlKCdAYXdzLWNkay9hd3MtaWFtJyk7XG5pbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBGdW5jdGlvblJlZiB9IGZyb20gJy4vbGFtYmRhLXJlZic7XG5cbi8qKlxuICogQ29tbW9uIHByb3BlcnRpZXMgZm9yIGNyZWF0aW5nIGEge0BsaW5rIFBpcGVsaW5lSW52b2tlQWN0aW9ufSAtXG4gKiBlaXRoZXIgZGlyZWN0bHksIHRocm91Z2ggaXRzIGNvbnN0cnVjdG9yLFxuICogb3IgdGhyb3VnaCB7QGxpbmsgRnVuY3Rpb25SZWYjYWRkVG9QaXBlbGluZX0uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29tbW9uUGlwZWxpbmVJbnZva2VBY3Rpb25Qcm9wcyBleHRlbmRzIGNvZGVwaXBlbGluZS5Db21tb25BY3Rpb25Qcm9wcyB7XG4gIC8qKlxuICAgKiBTdHJpbmcgdG8gYmUgdXNlZCBpbiB0aGUgZXZlbnQgZGF0YSBwYXJhbWV0ZXIgcGFzc2VkIHRvIHRoZSBMYW1iZGFcbiAgICogZnVuY3Rpb25cbiAgICpcbiAgICogU2VlIGFuIGV4YW1wbGUgSlNPTiBldmVudCBpbiB0aGUgQ29kZVBpcGVsaW5lIGRvY3VtZW50YXRpb24uXG4gICAqXG4gICAqIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9jb2RlcGlwZWxpbmUvbGF0ZXN0L3VzZXJndWlkZS9hY3Rpb25zLWludm9rZS1sYW1iZGEtZnVuY3Rpb24uaHRtbCNhY3Rpb25zLWludm9rZS1sYW1iZGEtZnVuY3Rpb24tanNvbi1ldmVudC1leGFtcGxlXG4gICAqL1xuICB1c2VyUGFyYW1ldGVycz86IGFueTtcblxuICAvKipcbiAgICogQWRkcyB0aGUgXCJjb2RlcGlwZWxpbmU6UHV0Sm9iU3VjY2Vzc1Jlc3VsdFwiIGFuZFxuICAgKiBcImNvZGVwaXBlbGluZTpQdXRKb2JGYWlsdXJlUmVzdWx0XCIgZm9yICcqJyByZXNvdXJjZSB0byB0aGUgTGFtYmRhXG4gICAqIGV4ZWN1dGlvbiByb2xlIHBvbGljeS5cbiAgICpcbiAgICogTk9URTogdGhlIHJlYXNvbiB3ZSBjYW4ndCBhZGQgdGhlIHNwZWNpZmljIHBpcGVsaW5lIEFSTiBhcyBhIHJlc291cmNlIGlzXG4gICAqIHRvIGF2b2lkIGEgY3ljbGljIGRlcGVuZGVuY3kgYmV0d2VlbiB0aGUgcGlwZWxpbmUgYW5kIHRoZSBMYW1iZGEgZnVuY3Rpb25cbiAgICogKHRoZSBwaXBlbGluZSByZWZlcmVuY2VzKSB0aGUgTGFtYmRhIGFuZCB0aGUgTGFtYmRhIG5lZWRzIHBlcm1pc3Npb25zIG9uXG4gICAqIHRoZSBwaXBlbGluZS5cbiAgICpcbiAgICogQHNlZVxuICAgKiBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vY29kZXBpcGVsaW5lL2xhdGVzdC91c2VyZ3VpZGUvYWN0aW9ucy1pbnZva2UtbGFtYmRhLWZ1bmN0aW9uLmh0bWwjYWN0aW9ucy1pbnZva2UtbGFtYmRhLWZ1bmN0aW9uLWNyZWF0ZS1mdW5jdGlvblxuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICBhZGRQdXRKb2JSZXN1bHRQb2xpY3k/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdGlvbiBwcm9wZXJ0aWVzIG9mIHRoZSB7QGxpbmsgUGlwZWxpbmVJbnZva2VBY3Rpb24gTGFtYmRhIGludm9rZSBDb2RlUGlwZWxpbmUgQWN0aW9ufS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQaXBlbGluZUludm9rZUFjdGlvblByb3BzIGV4dGVuZHMgQ29tbW9uUGlwZWxpbmVJbnZva2VBY3Rpb25Qcm9wcyxcbiAgICBjb2RlcGlwZWxpbmUuQ29tbW9uQWN0aW9uQ29uc3RydWN0UHJvcHMge1xuICAvKipcbiAgICogVGhlIGxhbWJkYSBmdW5jdGlvbiB0byBpbnZva2UuXG4gICAqL1xuICBsYW1iZGE6IEZ1bmN0aW9uUmVmO1xufVxuXG4vKipcbiAqIENvZGVQaXBlbGluZSBpbnZva2UgQWN0aW9uIHRoYXQgaXMgcHJvdmlkZWQgYnkgYW4gQVdTIExhbWJkYSBmdW5jdGlvbi5cbiAqXG4gKiBAc2VlIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9jb2RlcGlwZWxpbmUvbGF0ZXN0L3VzZXJndWlkZS9hY3Rpb25zLWludm9rZS1sYW1iZGEtZnVuY3Rpb24uaHRtbFxuICovXG5leHBvcnQgY2xhc3MgUGlwZWxpbmVJbnZva2VBY3Rpb24gZXh0ZW5kcyBjb2RlcGlwZWxpbmUuQWN0aW9uIHtcbiAgY29uc3RydWN0b3IocGFyZW50OiBjZGsuQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBQaXBlbGluZUludm9rZUFjdGlvblByb3BzKSB7XG4gICAgc3VwZXIocGFyZW50LCBuYW1lLCB7XG4gICAgICBzdGFnZTogcHJvcHMuc3RhZ2UsXG4gICAgICBydW5PcmRlcjogcHJvcHMucnVuT3JkZXIsXG4gICAgICBjYXRlZ29yeTogY29kZXBpcGVsaW5lLkFjdGlvbkNhdGVnb3J5Lkludm9rZSxcbiAgICAgIHByb3ZpZGVyOiAnTGFtYmRhJyxcbiAgICAgIGFydGlmYWN0Qm91bmRzOiBjb2RlcGlwZWxpbmUuZGVmYXVsdEJvdW5kcygpLFxuICAgICAgY29uZmlndXJhdGlvbjoge1xuICAgICAgICBGdW5jdGlvbk5hbWU6IHByb3BzLmxhbWJkYS5mdW5jdGlvbk5hbWUsXG4gICAgICAgIFVzZXJQYXJhbWV0ZXJzOiBwcm9wcy51c2VyUGFyYW1ldGVyc1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgLy8gYWxsb3cgcGlwZWxpbmUgdG8gbGlzdCBmdW5jdGlvbnNcbiAgICBwcm9wcy5zdGFnZS5waXBlbGluZS5yb2xlLmFkZFRvUG9saWN5KG5ldyBpYW0uUG9saWN5U3RhdGVtZW50KClcbiAgICAgIC5hZGRBY3Rpb24oJ2xhbWJkYTpMaXN0RnVuY3Rpb25zJylcbiAgICAgIC5hZGRBbGxSZXNvdXJjZXMoKSk7XG5cbiAgICAvLyBhbGxvdyBwaXBlbGluZSB0byBpbnZva2UgdGhpcyBsYW1iZGEgZnVuY3Rpb25uXG4gICAgcHJvcHMuc3RhZ2UucGlwZWxpbmUucm9sZS5hZGRUb1BvbGljeShuZXcgaWFtLlBvbGljeVN0YXRlbWVudCgpXG4gICAgICAuYWRkQWN0aW9uKCdsYW1iZGE6SW52b2tlRnVuY3Rpb24nKVxuICAgICAgLmFkZFJlc291cmNlKHByb3BzLmxhbWJkYS5mdW5jdGlvbkFybikpO1xuXG4gICAgLy8gYWxsb3cgbGFtYmRhIHRvIHB1dCBqb2IgcmVzdWx0cyBmb3IgdGhpcyBwaXBlbGluZS5cbiAgICBjb25zdCBhZGRUb1BvbGljeSA9IHByb3BzLmFkZFB1dEpvYlJlc3VsdFBvbGljeSAhPT0gdW5kZWZpbmVkID8gcHJvcHMuYWRkUHV0Sm9iUmVzdWx0UG9saWN5IDogdHJ1ZTtcbiAgICBpZiAoYWRkVG9Qb2xpY3kpIHtcbiAgICAgIHByb3BzLmxhbWJkYS5hZGRUb1JvbGVQb2xpY3kobmV3IGlhbS5Qb2xpY3lTdGF0ZW1lbnQoKVxuICAgICAgICAuYWRkQWxsUmVzb3VyY2VzKCkgLy8gdG8gYXZvaWQgY3ljbGVzIChzZWUgZG9jcylcbiAgICAgICAgLmFkZEFjdGlvbignY29kZXBpcGVsaW5lOlB1dEpvYlN1Y2Nlc3NSZXN1bHQnKVxuICAgICAgICAuYWRkQWN0aW9uKCdjb2RlcGlwZWxpbmU6UHV0Sm9iRmFpbHVyZVJlc3VsdCcpKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline-action.js","sourceRoot":"","sources":["pipeline-action.ts"],"names":[],"mappings":";;AAAA,8DAA+D;AAC/D,wCAAyC;AA4EzC;;;;GAIG;AACH,MAAa,oBAAqB,SAAQ,YAAY,CAAC,MAAM;IAC3D,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAgC;QAC5E,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,QAAQ,EAAE,YAAY,CAAC,cAAc,CAAC,MAAM;YAC5C,QAAQ,EAAE,QAAQ;YAClB,cAAc,EAAE,YAAY,CAAC,aAAa,EAAE;YAC5C,aAAa,EAAE;gBACb,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC,YAAY;gBACvC,cAAc,EAAE,KAAK,CAAC,cAAc;aACrC;SACF,CAAC,CAAC;QAEH,yBAAyB;QACzB,KAAK,MAAM,aAAa,IAAI,KAAK,CAAC,cAAc,IAAI,EAAE,EAAE;YACtD,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;SACtC;QAED,0BAA0B;QAC1B,KAAK,MAAM,kBAAkB,IAAI,KAAK,CAAC,mBAAmB,IAAI,EAAE,EAAE;YAChE,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC;SAC5C;QAED,mCAAmC;QACnC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;aAC5D,SAAS,CAAC,sBAAsB,CAAC;aACjC,eAAe,EAAE,CAAC,CAAC;QAEtB,iDAAiD;QACjD,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;aAC5D,SAAS,CAAC,uBAAuB,CAAC;aAClC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;QAE1C,qDAAqD;QACrD,MAAM,WAAW,GAAG,KAAK,CAAC,qBAAqB,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC;QACnG,IAAI,WAAW,EAAE;YACf,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;iBACnD,eAAe,EAAE,CAAC,6BAA6B;iBAC/C,SAAS,CAAC,kCAAkC,CAAC;iBAC7C,SAAS,CAAC,kCAAkC,CAAC,CAAC,CAAC;SACnD;IACH,CAAC;IAEM,eAAe;QACpB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAEM,cAAc,CAAC,YAAoB;QACxC,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC,CAAC;QAC1E,IAAI,MAAM,KAAK,SAAS,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,iDAAiD,YAAY,GAAG,CAAC,CAAC;SACnF;aAAM;YACL,OAAO,MAAM,CAAC;SACf;IACH,CAAC;CACF;AAxDD,oDAwDC","sourcesContent":["import codepipeline = require('@aws-cdk/aws-codepipeline-api');\nimport iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/cdk');\nimport { IFunction } from './lambda-ref';\n\n/**\n * Common properties for creating a {@link PipelineInvokeAction} -\n * either directly, through its constructor,\n * or through {@link IFunction#addToPipeline}.\n */\nexport interface CommonPipelineInvokeActionProps extends codepipeline.CommonActionProps {\n  // because of @see links\n  // tslint:disable:max-line-length\n\n  /**\n   * The optional input Artifacts of the Action.\n   * A Lambda Action can have up to 5 inputs.\n   * The inputs will appear in the event passed to the Lambda,\n   * under the `'CodePipeline.job'.data.inputArtifacts` path.\n   *\n   * @default the Action will not have any inputs\n   * @see https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-json-event-example\n   */\n  inputArtifacts?: codepipeline.Artifact[];\n\n  // tslint:enable:max-line-length\n\n  /**\n   * The optional names of the output Artifacts of the Action.\n   * A Lambda Action can have up to 5 outputs.\n   * The outputs will appear in the event passed to the Lambda,\n   * under the `'CodePipeline.job'.data.outputArtifacts` path.\n   * It is the responsibility of the Lambda to upload ZIP files with the Artifact contents to the provided locations.\n   *\n   * @default the Action will not have any outputs\n   */\n  outputArtifactNames?: string[];\n\n  /**\n   * String to be used in the event data parameter passed to the Lambda\n   * function\n   *\n   * See an example JSON event in the CodePipeline documentation.\n   *\n   * https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-json-event-example\n   */\n  userParameters?: any;\n\n  /**\n   * Adds the \"codepipeline:PutJobSuccessResult\" and\n   * \"codepipeline:PutJobFailureResult\" for '*' resource to the Lambda\n   * execution role policy.\n   *\n   * NOTE: the reason we can't add the specific pipeline ARN as a resource is\n   * to avoid a cyclic dependency between the pipeline and the Lambda function\n   * (the pipeline references) the Lambda and the Lambda needs permissions on\n   * the pipeline.\n   *\n   * @see\n   * https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-create-function\n   *\n   * @default true\n   */\n  addPutJobResultPolicy?: boolean;\n}\n\n/**\n * Construction properties of the {@link PipelineInvokeAction Lambda invoke CodePipeline Action}.\n */\nexport interface PipelineInvokeActionProps extends CommonPipelineInvokeActionProps,\n    codepipeline.CommonActionConstructProps {\n  /**\n   * The lambda function to invoke.\n   */\n  lambda: IFunction;\n}\n\n/**\n * CodePipeline invoke Action that is provided by an AWS Lambda function.\n *\n * @see https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html\n */\nexport class PipelineInvokeAction extends codepipeline.Action {\n  constructor(scope: cdk.Construct, id: string, props: PipelineInvokeActionProps) {\n    super(scope, id, {\n      stage: props.stage,\n      runOrder: props.runOrder,\n      category: codepipeline.ActionCategory.Invoke,\n      provider: 'Lambda',\n      artifactBounds: codepipeline.defaultBounds(),\n      configuration: {\n        FunctionName: props.lambda.functionName,\n        UserParameters: props.userParameters\n      }\n    });\n\n    // handle input artifacts\n    for (const inputArtifact of props.inputArtifacts || []) {\n      this.addInputArtifact(inputArtifact);\n    }\n\n    // handle output artifacts\n    for (const outputArtifactName of props.outputArtifactNames || []) {\n      this.addOutputArtifact(outputArtifactName);\n    }\n\n    // allow pipeline to list functions\n    props.stage.pipeline.role.addToPolicy(new iam.PolicyStatement()\n      .addAction('lambda:ListFunctions')\n      .addAllResources());\n\n    // allow pipeline to invoke this lambda functionn\n    props.stage.pipeline.role.addToPolicy(new iam.PolicyStatement()\n      .addAction('lambda:InvokeFunction')\n      .addResource(props.lambda.functionArn));\n\n    // allow lambda to put job results for this pipeline.\n    const addToPolicy = props.addPutJobResultPolicy !== undefined ? props.addPutJobResultPolicy : true;\n    if (addToPolicy) {\n      props.lambda.addToRolePolicy(new iam.PolicyStatement()\n        .addAllResources() // to avoid cycles (see docs)\n        .addAction('codepipeline:PutJobSuccessResult')\n        .addAction('codepipeline:PutJobFailureResult'));\n    }\n  }\n\n  public outputArtifacts(): codepipeline.Artifact[] {\n    return this._outputArtifacts;\n  }\n\n  public outputArtifact(artifactName: string): codepipeline.Artifact {\n    const result = this._outputArtifacts.find(a => (a.name === artifactName));\n    if (result === undefined) {\n      throw new Error(`Could not find the output Artifact with name '${artifactName}'`);\n    } else {\n      return result;\n    }\n  }\n}\n"]} |
import iam = require('@aws-cdk/aws-iam'); | ||
import cdk = require('@aws-cdk/cdk'); | ||
import { FunctionProps } from './lambda'; | ||
import { FunctionRef } from './lambda-ref'; | ||
import { FunctionBase, FunctionImportProps } from './lambda-ref'; | ||
import { Permission } from './permission'; | ||
@@ -34,11 +34,12 @@ /** | ||
*/ | ||
export declare class SingletonFunction extends FunctionRef { | ||
export declare class SingletonFunction extends FunctionBase { | ||
readonly functionName: string; | ||
readonly functionArn: string; | ||
readonly role?: iam.Role | undefined; | ||
readonly role?: iam.IRole | undefined; | ||
protected readonly canCreatePermissions: boolean; | ||
private lambdaFunction; | ||
constructor(parent: cdk.Construct, name: string, props: SingletonFunctionProps); | ||
constructor(scope: cdk.Construct, id: string, props: SingletonFunctionProps); | ||
export(): FunctionImportProps; | ||
addPermission(name: string, permission: Permission): void; | ||
private ensureLambda; | ||
} |
@@ -12,5 +12,5 @@ "use strict"; | ||
*/ | ||
class SingletonFunction extends lambda_ref_1.FunctionRef { | ||
constructor(parent, name, props) { | ||
super(parent, name); | ||
class SingletonFunction extends lambda_ref_1.FunctionBase { | ||
constructor(scope, id, props) { | ||
super(scope, id); | ||
this.lambdaFunction = this.ensureLambda(props); | ||
@@ -22,2 +22,5 @@ this.functionArn = this.lambdaFunction.functionArn; | ||
} | ||
export() { | ||
return this.lambdaFunction.export(); | ||
} | ||
addPermission(name, permission) { | ||
@@ -29,3 +32,3 @@ return this.lambdaFunction.addPermission(name, permission); | ||
const stack = cdk.Stack.find(this); | ||
const existing = stack.tryFindChild(constructName); | ||
const existing = stack.node.tryFindChild(constructName); | ||
if (existing) { | ||
@@ -42,2 +45,2 @@ // Just assume this is true | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xldG9uLWxhbWJkYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpbmdsZXRvbi1sYW1iZGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxvQ0FBcUM7QUFDckMscUNBQXFFO0FBQ3JFLDZDQUEyQztBQTJCM0M7Ozs7O0dBS0c7QUFDSCxNQUFhLGlCQUFrQixTQUFRLHdCQUFXO0lBT2hELFlBQVksTUFBcUIsRUFBRSxJQUFZLEVBQUUsS0FBNkI7UUFDNUUsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVwQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFL0MsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQztRQUNuRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDO1FBQ3JELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUM7UUFFckMsSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksQ0FBQyxDQUFDLG9EQUFvRDtJQUN4RixDQUFDO0lBRU0sYUFBYSxDQUFDLElBQVksRUFBRSxVQUFzQjtRQUN2RCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxVQUFVLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRU8sWUFBWSxDQUFDLEtBQTZCO1FBQ2hELE1BQU0sYUFBYSxHQUFHLENBQUMsS0FBSyxDQUFDLGFBQWEsSUFBSSxpQkFBaUIsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdkYsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkMsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNuRCxJQUFJLFFBQVEsRUFBRTtZQUNaLDJCQUEyQjtZQUMzQixPQUFPLFFBQXVCLENBQUM7U0FDaEM7UUFFRCxPQUFPLElBQUksaUJBQWMsQ0FBQyxLQUFLLEVBQUUsYUFBYSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3pELENBQUM7Q0FDRjtBQWxDRCw4Q0FrQ0M7QUFFRCxTQUFTLE9BQU8sQ0FBQyxDQUFTO0lBQ3hCLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDeEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBpYW0gPSByZXF1aXJlKCdAYXdzLWNkay9hd3MtaWFtJyk7XG5pbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBGdW5jdGlvbiBhcyBMYW1iZGFGdW5jdGlvbiwgRnVuY3Rpb25Qcm9wcyB9IGZyb20gJy4vbGFtYmRhJztcbmltcG9ydCB7IEZ1bmN0aW9uUmVmIH0gZnJvbSAnLi9sYW1iZGEtcmVmJztcbmltcG9ydCB7IFBlcm1pc3Npb24gfSBmcm9tICcuL3Blcm1pc3Npb24nO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGEgbmV3bHkgY3JlYXRlZCBzaW5nbGV0b24gTGFtYmRhXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2luZ2xldG9uRnVuY3Rpb25Qcm9wcyBleHRlbmRzIEZ1bmN0aW9uUHJvcHMge1xuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciB0byBpZGVudGlmeSB0aGlzIGxhbWJkYVxuICAgKlxuICAgKiBUaGUgaWRlbnRpZmllciBzaG91bGQgYmUgdW5pcXVlIGFjcm9zcyBhbGwgY3VzdG9tIHJlc291cmNlIHByb3ZpZGVycy5cbiAgICogV2UgcmVjb21tZW5kIGdlbmVyYXRpbmcgYSBVVUlEIHBlciBwcm92aWRlci5cbiAgICovXG4gIHV1aWQ6IHN0cmluZztcblxuICAvKipcbiAgICogQSBkZXNjcmlwdGl2ZSBuYW1lIGZvciB0aGUgcHVycG9zZSBvZiB0aGlzIExhbWJkYS5cbiAgICpcbiAgICogSWYgdGhlIExhbWJkYSBkb2VzIG5vdCBoYXZlIGEgcGh5c2ljYWwgbmFtZSwgdGhpcyBzdHJpbmcgd2lsbCBiZVxuICAgKiByZWZsZWN0ZWQgaXRzIGdlbmVyYXRlZCBuYW1lLiBUaGUgY29tYmluYXRpb24gb2YgbGFtYmRhUHVycG9zZVxuICAgKiBhbmQgdXVpZCBtdXN0IGJlIHVuaXF1ZS5cbiAgICpcbiAgICogQGRlZmF1bHQgU2luZ2xldG9uTGFtYmRhXG4gICAqL1xuICBsYW1iZGFQdXJwb3NlPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEEgTGFtYmRhIHRoYXQgd2lsbCBvbmx5IGV2ZXIgYmUgYWRkZWQgdG8gYSBzdGFjayBvbmNlLlxuICpcbiAqIFRoZSBsYW1iZGEgaXMgaWRlbnRpZmllZCB1c2luZyB0aGUgdmFsdWUgb2YgJ3V1aWQnLiBSdW4gJ3V1aWRnZW4nXG4gKiBmb3IgZXZlcnkgU2luZ2xldG9uTGFtYmRhIHlvdSBjcmVhdGUuXG4gKi9cbmV4cG9ydCBjbGFzcyBTaW5nbGV0b25GdW5jdGlvbiBleHRlbmRzIEZ1bmN0aW9uUmVmIHtcbiAgcHVibGljIHJlYWRvbmx5IGZ1bmN0aW9uTmFtZTogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgZnVuY3Rpb25Bcm46IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IHJvbGU/OiBpYW0uUm9sZSB8IHVuZGVmaW5lZDtcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGNhbkNyZWF0ZVBlcm1pc3Npb25zOiBib29sZWFuO1xuICBwcml2YXRlIGxhbWJkYUZ1bmN0aW9uOiBGdW5jdGlvblJlZjtcblxuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5Db25zdHJ1Y3QsIG5hbWU6IHN0cmluZywgcHJvcHM6IFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMpIHtcbiAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuXG4gICAgdGhpcy5sYW1iZGFGdW5jdGlvbiA9IHRoaXMuZW5zdXJlTGFtYmRhKHByb3BzKTtcblxuICAgIHRoaXMuZnVuY3Rpb25Bcm4gPSB0aGlzLmxhbWJkYUZ1bmN0aW9uLmZ1bmN0aW9uQXJuO1xuICAgIHRoaXMuZnVuY3Rpb25OYW1lID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5mdW5jdGlvbk5hbWU7XG4gICAgdGhpcy5yb2xlID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5yb2xlO1xuXG4gICAgdGhpcy5jYW5DcmVhdGVQZXJtaXNzaW9ucyA9IHRydWU7IC8vIERvZXNuJ3QgbWF0dGVyLCBhZGRQZXJtaXNzaW9uIGlzIG92ZXJyaWRlbiBhbnl3YXlcbiAgfVxuXG4gIHB1YmxpYyBhZGRQZXJtaXNzaW9uKG5hbWU6IHN0cmluZywgcGVybWlzc2lvbjogUGVybWlzc2lvbikge1xuICAgIHJldHVybiB0aGlzLmxhbWJkYUZ1bmN0aW9uLmFkZFBlcm1pc3Npb24obmFtZSwgcGVybWlzc2lvbik7XG4gIH1cblxuICBwcml2YXRlIGVuc3VyZUxhbWJkYShwcm9wczogU2luZ2xldG9uRnVuY3Rpb25Qcm9wcyk6IEZ1bmN0aW9uUmVmIHtcbiAgICBjb25zdCBjb25zdHJ1Y3ROYW1lID0gKHByb3BzLmxhbWJkYVB1cnBvc2UgfHwgJ1NpbmdsZXRvbkxhbWJkYScpICsgc2x1Z2lmeShwcm9wcy51dWlkKTtcbiAgICBjb25zdCBzdGFjayA9IGNkay5TdGFjay5maW5kKHRoaXMpO1xuICAgIGNvbnN0IGV4aXN0aW5nID0gc3RhY2sudHJ5RmluZENoaWxkKGNvbnN0cnVjdE5hbWUpO1xuICAgIGlmIChleGlzdGluZykge1xuICAgICAgLy8gSnVzdCBhc3N1bWUgdGhpcyBpcyB0cnVlXG4gICAgICByZXR1cm4gZXhpc3RpbmcgYXMgRnVuY3Rpb25SZWY7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBMYW1iZGFGdW5jdGlvbihzdGFjaywgY29uc3RydWN0TmFtZSwgcHJvcHMpO1xuICB9XG59XG5cbmZ1bmN0aW9uIHNsdWdpZnkoeDogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIHgucmVwbGFjZSgvW15hLXpBLVowLTldL2csICcnKTtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xldG9uLWxhbWJkYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpbmdsZXRvbi1sYW1iZGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxvQ0FBcUM7QUFDckMscUNBQXFFO0FBQ3JFLDZDQUE0RTtBQTJCNUU7Ozs7O0dBS0c7QUFDSCxNQUFhLGlCQUFrQixTQUFRLHlCQUFZO0lBT2pELFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQUUsS0FBNkI7UUFDekUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFL0MsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQztRQUNuRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDO1FBQ3JELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUM7UUFFckMsSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksQ0FBQyxDQUFDLG9EQUFvRDtJQUN4RixDQUFDO0lBRU0sTUFBTTtRQUNYLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUN0QyxDQUFDO0lBRU0sYUFBYSxDQUFDLElBQVksRUFBRSxVQUFzQjtRQUN2RCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxVQUFVLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRU8sWUFBWSxDQUFDLEtBQTZCO1FBQ2hELE1BQU0sYUFBYSxHQUFHLENBQUMsS0FBSyxDQUFDLGFBQWEsSUFBSSxpQkFBaUIsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdkYsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkMsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDeEQsSUFBSSxRQUFRLEVBQUU7WUFDWiwyQkFBMkI7WUFDM0IsT0FBTyxRQUF3QixDQUFDO1NBQ2pDO1FBRUQsT0FBTyxJQUFJLGlCQUFjLENBQUMsS0FBSyxFQUFFLGFBQWEsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN6RCxDQUFDO0NBQ0Y7QUF0Q0QsOENBc0NDO0FBRUQsU0FBUyxPQUFPLENBQUMsQ0FBUztJQUN4QixPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaWFtID0gcmVxdWlyZSgnQGF3cy1jZGsvYXdzLWlhbScpO1xuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IHsgRnVuY3Rpb24gYXMgTGFtYmRhRnVuY3Rpb24sIEZ1bmN0aW9uUHJvcHMgfSBmcm9tICcuL2xhbWJkYSc7XG5pbXBvcnQgeyBGdW5jdGlvbkJhc2UsIEZ1bmN0aW9uSW1wb3J0UHJvcHMsIElGdW5jdGlvbiB9IGZyb20gJy4vbGFtYmRhLXJlZic7XG5pbXBvcnQgeyBQZXJtaXNzaW9uIH0gZnJvbSAnLi9wZXJtaXNzaW9uJztcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBhIG5ld2x5IGNyZWF0ZWQgc2luZ2xldG9uIExhbWJkYVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMgZXh0ZW5kcyBGdW5jdGlvblByb3BzIHtcbiAgLyoqXG4gICAqIEEgdW5pcXVlIGlkZW50aWZpZXIgdG8gaWRlbnRpZnkgdGhpcyBsYW1iZGFcbiAgICpcbiAgICogVGhlIGlkZW50aWZpZXIgc2hvdWxkIGJlIHVuaXF1ZSBhY3Jvc3MgYWxsIGN1c3RvbSByZXNvdXJjZSBwcm92aWRlcnMuXG4gICAqIFdlIHJlY29tbWVuZCBnZW5lcmF0aW5nIGEgVVVJRCBwZXIgcHJvdmlkZXIuXG4gICAqL1xuICB1dWlkOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgZGVzY3JpcHRpdmUgbmFtZSBmb3IgdGhlIHB1cnBvc2Ugb2YgdGhpcyBMYW1iZGEuXG4gICAqXG4gICAqIElmIHRoZSBMYW1iZGEgZG9lcyBub3QgaGF2ZSBhIHBoeXNpY2FsIG5hbWUsIHRoaXMgc3RyaW5nIHdpbGwgYmVcbiAgICogcmVmbGVjdGVkIGl0cyBnZW5lcmF0ZWQgbmFtZS4gVGhlIGNvbWJpbmF0aW9uIG9mIGxhbWJkYVB1cnBvc2VcbiAgICogYW5kIHV1aWQgbXVzdCBiZSB1bmlxdWUuXG4gICAqXG4gICAqIEBkZWZhdWx0IFNpbmdsZXRvbkxhbWJkYVxuICAgKi9cbiAgbGFtYmRhUHVycG9zZT86IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIExhbWJkYSB0aGF0IHdpbGwgb25seSBldmVyIGJlIGFkZGVkIHRvIGEgc3RhY2sgb25jZS5cbiAqXG4gKiBUaGUgbGFtYmRhIGlzIGlkZW50aWZpZWQgdXNpbmcgdGhlIHZhbHVlIG9mICd1dWlkJy4gUnVuICd1dWlkZ2VuJ1xuICogZm9yIGV2ZXJ5IFNpbmdsZXRvbkxhbWJkYSB5b3UgY3JlYXRlLlxuICovXG5leHBvcnQgY2xhc3MgU2luZ2xldG9uRnVuY3Rpb24gZXh0ZW5kcyBGdW5jdGlvbkJhc2Uge1xuICBwdWJsaWMgcmVhZG9ubHkgZnVuY3Rpb25OYW1lOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBmdW5jdGlvbkFybjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgcm9sZT86IGlhbS5JUm9sZSB8IHVuZGVmaW5lZDtcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGNhbkNyZWF0ZVBlcm1pc3Npb25zOiBib29sZWFuO1xuICBwcml2YXRlIGxhbWJkYUZ1bmN0aW9uOiBJRnVuY3Rpb247XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTaW5nbGV0b25GdW5jdGlvblByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIHRoaXMubGFtYmRhRnVuY3Rpb24gPSB0aGlzLmVuc3VyZUxhbWJkYShwcm9wcyk7XG5cbiAgICB0aGlzLmZ1bmN0aW9uQXJuID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5mdW5jdGlvbkFybjtcbiAgICB0aGlzLmZ1bmN0aW9uTmFtZSA9IHRoaXMubGFtYmRhRnVuY3Rpb24uZnVuY3Rpb25OYW1lO1xuICAgIHRoaXMucm9sZSA9IHRoaXMubGFtYmRhRnVuY3Rpb24ucm9sZTtcblxuICAgIHRoaXMuY2FuQ3JlYXRlUGVybWlzc2lvbnMgPSB0cnVlOyAvLyBEb2Vzbid0IG1hdHRlciwgYWRkUGVybWlzc2lvbiBpcyBvdmVycmlkZW4gYW55d2F5XG4gIH1cblxuICBwdWJsaWMgZXhwb3J0KCk6IEZ1bmN0aW9uSW1wb3J0UHJvcHMge1xuICAgIHJldHVybiB0aGlzLmxhbWJkYUZ1bmN0aW9uLmV4cG9ydCgpO1xuICB9XG5cbiAgcHVibGljIGFkZFBlcm1pc3Npb24obmFtZTogc3RyaW5nLCBwZXJtaXNzaW9uOiBQZXJtaXNzaW9uKSB7XG4gICAgcmV0dXJuIHRoaXMubGFtYmRhRnVuY3Rpb24uYWRkUGVybWlzc2lvbihuYW1lLCBwZXJtaXNzaW9uKTtcbiAgfVxuXG4gIHByaXZhdGUgZW5zdXJlTGFtYmRhKHByb3BzOiBTaW5nbGV0b25GdW5jdGlvblByb3BzKTogSUZ1bmN0aW9uIHtcbiAgICBjb25zdCBjb25zdHJ1Y3ROYW1lID0gKHByb3BzLmxhbWJkYVB1cnBvc2UgfHwgJ1NpbmdsZXRvbkxhbWJkYScpICsgc2x1Z2lmeShwcm9wcy51dWlkKTtcbiAgICBjb25zdCBzdGFjayA9IGNkay5TdGFjay5maW5kKHRoaXMpO1xuICAgIGNvbnN0IGV4aXN0aW5nID0gc3RhY2subm9kZS50cnlGaW5kQ2hpbGQoY29uc3RydWN0TmFtZSk7XG4gICAgaWYgKGV4aXN0aW5nKSB7XG4gICAgICAvLyBKdXN0IGFzc3VtZSB0aGlzIGlzIHRydWVcbiAgICAgIHJldHVybiBleGlzdGluZyBhcyBGdW5jdGlvbkJhc2U7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBMYW1iZGFGdW5jdGlvbihzdGFjaywgY29uc3RydWN0TmFtZSwgcHJvcHMpO1xuICB9XG59XG5cbmZ1bmN0aW9uIHNsdWdpZnkoeDogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIHgucmVwbGFjZSgvW15hLXpBLVowLTldL2csICcnKTtcbn1cbiJdfQ== |
{ | ||
"name": "@aws-cdk/aws-lambda", | ||
"version": "0.21.0", | ||
"version": "0.22.0", | ||
"description": "CDK Constructs for AWS Lambda", | ||
@@ -37,3 +37,5 @@ "main": "lib/index.js", | ||
"pkglint": "pkglint -f", | ||
"package": "cdk-package" | ||
"package": "cdk-package", | ||
"awslint": "cdk-awslint", | ||
"cfn2ts": "cfn2ts" | ||
}, | ||
@@ -59,37 +61,37 @@ "cdk-build": { | ||
"devDependencies": { | ||
"@aws-cdk/assert": "^0.21.0", | ||
"cdk-build-tools": "^0.21.0", | ||
"cdk-integ-tools": "^0.21.0", | ||
"cfn2ts": "^0.21.0", | ||
"pkglint": "^0.21.0" | ||
"@aws-cdk/assert": "^0.22.0", | ||
"cdk-build-tools": "^0.22.0", | ||
"cdk-integ-tools": "^0.22.0", | ||
"cfn2ts": "^0.22.0", | ||
"pkglint": "^0.22.0" | ||
}, | ||
"dependencies": { | ||
"@aws-cdk/assets": "^0.21.0", | ||
"@aws-cdk/aws-cloudwatch": "^0.21.0", | ||
"@aws-cdk/aws-codepipeline-api": "^0.21.0", | ||
"@aws-cdk/aws-ec2": "^0.21.0", | ||
"@aws-cdk/aws-events": "^0.21.0", | ||
"@aws-cdk/aws-iam": "^0.21.0", | ||
"@aws-cdk/aws-logs": "^0.21.0", | ||
"@aws-cdk/aws-s3": "^0.21.0", | ||
"@aws-cdk/aws-s3-notifications": "^0.21.0", | ||
"@aws-cdk/aws-sqs": "^0.21.0", | ||
"@aws-cdk/aws-stepfunctions": "^0.21.0", | ||
"@aws-cdk/cdk": "^0.21.0", | ||
"@aws-cdk/cx-api": "^0.21.0" | ||
"@aws-cdk/assets": "^0.22.0", | ||
"@aws-cdk/aws-cloudwatch": "^0.22.0", | ||
"@aws-cdk/aws-codepipeline-api": "^0.22.0", | ||
"@aws-cdk/aws-ec2": "^0.22.0", | ||
"@aws-cdk/aws-events": "^0.22.0", | ||
"@aws-cdk/aws-iam": "^0.22.0", | ||
"@aws-cdk/aws-logs": "^0.22.0", | ||
"@aws-cdk/aws-s3": "^0.22.0", | ||
"@aws-cdk/aws-s3-notifications": "^0.22.0", | ||
"@aws-cdk/aws-sqs": "^0.22.0", | ||
"@aws-cdk/aws-stepfunctions": "^0.22.0", | ||
"@aws-cdk/cdk": "^0.22.0", | ||
"@aws-cdk/cx-api": "^0.22.0" | ||
}, | ||
"homepage": "https://github.com/awslabs/aws-cdk", | ||
"peerDependencies": { | ||
"@aws-cdk/assets": "^0.21.0", | ||
"@aws-cdk/aws-cloudwatch": "^0.21.0", | ||
"@aws-cdk/aws-codepipeline-api": "^0.21.0", | ||
"@aws-cdk/aws-ec2": "^0.21.0", | ||
"@aws-cdk/aws-events": "^0.21.0", | ||
"@aws-cdk/aws-iam": "^0.21.0", | ||
"@aws-cdk/aws-logs": "^0.21.0", | ||
"@aws-cdk/aws-s3": "^0.21.0", | ||
"@aws-cdk/aws-s3-notifications": "^0.21.0", | ||
"@aws-cdk/aws-sqs": "^0.21.0", | ||
"@aws-cdk/aws-stepfunctions": "^0.21.0", | ||
"@aws-cdk/cdk": "^0.21.0" | ||
"@aws-cdk/assets": "^0.22.0", | ||
"@aws-cdk/aws-cloudwatch": "^0.22.0", | ||
"@aws-cdk/aws-codepipeline-api": "^0.22.0", | ||
"@aws-cdk/aws-ec2": "^0.22.0", | ||
"@aws-cdk/aws-events": "^0.22.0", | ||
"@aws-cdk/aws-iam": "^0.22.0", | ||
"@aws-cdk/aws-logs": "^0.22.0", | ||
"@aws-cdk/aws-s3": "^0.22.0", | ||
"@aws-cdk/aws-s3-notifications": "^0.22.0", | ||
"@aws-cdk/aws-sqs": "^0.22.0", | ||
"@aws-cdk/aws-stepfunctions": "^0.22.0", | ||
"@aws-cdk/cdk": "^0.22.0" | ||
}, | ||
@@ -96,0 +98,0 @@ "engines": { |
@@ -90,2 +90,21 @@ ## AWS Lambda Construct Library | ||
The Lambda Action can have up to 5 inputs, | ||
and up to 5 outputs: | ||
```typescript | ||
const lambdaAction = fn.addToPipeline(lambdaStage, 'Lambda', { | ||
inputArtifacts: [ | ||
sourceAction.outputArtifact, | ||
buildAction.outputArtifact, | ||
], | ||
outputArtifactNames: [ | ||
'Out1', | ||
'Out2', | ||
], | ||
}); | ||
lambdaAction.outputArtifacts(); // returns the list of output Artifacts | ||
lambdaAction.outputArtifact('Out2'); // returns the named output Artifact, or throws an exception if not found | ||
``` | ||
See [the AWS documentation](https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html) | ||
@@ -92,0 +111,0 @@ on how to write a Lambda function invoked from CodePipeline. |
@@ -7,4 +7,4 @@ "use strict"; | ||
class TestStack extends cdk.Stack { | ||
constructor(parent, id) { | ||
super(parent, id); | ||
constructor(scope, id) { | ||
super(scope, id); | ||
/// !show | ||
@@ -22,2 +22,2 @@ new lambda.Function(this, 'MyLambda', { | ||
app.run(); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYXNzZXRzLmZpbGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5hc3NldHMuZmlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUNyQyw2QkFBOEI7QUFDOUIsaUNBQWtDO0FBRWxDLE1BQU0sU0FBVSxTQUFRLEdBQUcsQ0FBQyxLQUFLO0lBQy9CLFlBQVksTUFBZSxFQUFFLEVBQVU7UUFDckMsS0FBSyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVsQixTQUFTO1FBQ1QsSUFBSSxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDcEMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLGFBQWEsQ0FBQyxDQUFDO1lBQzNELE9BQU8sRUFBRSxZQUFZO1lBQ3JCLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFFBQVE7U0FDakMsQ0FBQyxDQUFDO1FBQ0gsU0FBUztJQUNYLENBQUM7Q0FDRjtBQUVELE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBRTFCLElBQUksU0FBUyxDQUFDLEdBQUcsRUFBRSx5QkFBeUIsQ0FBQyxDQUFDO0FBRTlDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCBwYXRoID0gcmVxdWlyZSgncGF0aCcpO1xuaW1wb3J0IGxhbWJkYSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jbGFzcyBUZXN0U3RhY2sgZXh0ZW5kcyBjZGsuU3RhY2sge1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5BcHAsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcblxuICAgIC8vLyAhc2hvd1xuICAgIG5ldyBsYW1iZGEuRnVuY3Rpb24odGhpcywgJ015TGFtYmRhJywge1xuICAgICAgY29kZTogbGFtYmRhLkNvZGUuZmlsZShwYXRoLmpvaW4oX19kaXJuYW1lLCAnaGFuZGxlci56aXAnKSksXG4gICAgICBoYW5kbGVyOiAnaW5kZXgubWFpbicsXG4gICAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5QeXRob24zNlxuICAgIH0pO1xuICAgIC8vLyAhaGlkZVxuICB9XG59XG5cbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XG5cbm5ldyBUZXN0U3RhY2soYXBwLCAnbGFtYmRhLXRlc3QtYXNzZXRzLWZpbGUnKTtcblxuYXBwLnJ1bigpO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYXNzZXRzLmZpbGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5hc3NldHMuZmlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUNyQyw2QkFBOEI7QUFDOUIsaUNBQWtDO0FBRWxDLE1BQU0sU0FBVSxTQUFRLEdBQUcsQ0FBQyxLQUFLO0lBQy9CLFlBQVksS0FBYyxFQUFFLEVBQVU7UUFDcEMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixTQUFTO1FBQ1QsSUFBSSxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDcEMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLGFBQWEsQ0FBQyxDQUFDO1lBQzNELE9BQU8sRUFBRSxZQUFZO1lBQ3JCLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFFBQVE7U0FDakMsQ0FBQyxDQUFDO1FBQ0gsU0FBUztJQUNYLENBQUM7Q0FDRjtBQUVELE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBRTFCLElBQUksU0FBUyxDQUFDLEdBQUcsRUFBRSx5QkFBeUIsQ0FBQyxDQUFDO0FBRTlDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCBwYXRoID0gcmVxdWlyZSgncGF0aCcpO1xuaW1wb3J0IGxhbWJkYSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jbGFzcyBUZXN0U3RhY2sgZXh0ZW5kcyBjZGsuU3RhY2sge1xuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkFwcCwgaWQ6IHN0cmluZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICAvLy8gIXNob3dcbiAgICBuZXcgbGFtYmRhLkZ1bmN0aW9uKHRoaXMsICdNeUxhbWJkYScsIHtcbiAgICAgIGNvZGU6IGxhbWJkYS5Db2RlLmZpbGUocGF0aC5qb2luKF9fZGlybmFtZSwgJ2hhbmRsZXIuemlwJykpLFxuICAgICAgaGFuZGxlcjogJ2luZGV4Lm1haW4nLFxuICAgICAgcnVudGltZTogbGFtYmRhLlJ1bnRpbWUuUHl0aG9uMzZcbiAgICB9KTtcbiAgICAvLy8gIWhpZGVcbiAgfVxufVxuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xuXG5uZXcgVGVzdFN0YWNrKGFwcCwgJ2xhbWJkYS10ZXN0LWFzc2V0cy1maWxlJyk7XG5cbmFwcC5ydW4oKTtcbiJdfQ== |
@@ -7,4 +7,4 @@ "use strict"; | ||
class TestStack extends cdk.Stack { | ||
constructor(parent, id) { | ||
super(parent, id); | ||
constructor(scope, id) { | ||
super(scope, id); | ||
/// !show | ||
@@ -22,2 +22,2 @@ new lambda.Function(this, 'MyLambda', { | ||
app.run(); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYXNzZXRzLmxpdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmFzc2V0cy5saXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsNkJBQThCO0FBQzlCLGlDQUFrQztBQUVsQyxNQUFNLFNBQVUsU0FBUSxHQUFHLENBQUMsS0FBSztJQUMvQixZQUFZLE1BQWUsRUFBRSxFQUFVO1FBQ3JDLEtBQUssQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFbEIsU0FBUztRQUNULElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ3BDLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO1lBQ2xFLE9BQU8sRUFBRSxZQUFZO1lBQ3JCLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFFBQVE7U0FDakMsQ0FBQyxDQUFDO1FBQ0gsU0FBUztJQUNYLENBQUM7Q0FDRjtBQUVELE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBRTFCLElBQUksU0FBUyxDQUFDLEdBQUcsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO0FBRXpDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCBwYXRoID0gcmVxdWlyZSgncGF0aCcpO1xuaW1wb3J0IGxhbWJkYSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jbGFzcyBUZXN0U3RhY2sgZXh0ZW5kcyBjZGsuU3RhY2sge1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5BcHAsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcblxuICAgIC8vLyAhc2hvd1xuICAgIG5ldyBsYW1iZGEuRnVuY3Rpb24odGhpcywgJ015TGFtYmRhJywge1xuICAgICAgY29kZTogbGFtYmRhLkNvZGUuYXNzZXQocGF0aC5qb2luKF9fZGlybmFtZSwgJ215LWxhbWJkYS1oYW5kbGVyJykpLFxuICAgICAgaGFuZGxlcjogJ2luZGV4Lm1haW4nLFxuICAgICAgcnVudGltZTogbGFtYmRhLlJ1bnRpbWUuUHl0aG9uMzZcbiAgICB9KTtcbiAgICAvLy8gIWhpZGVcbiAgfVxufVxuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xuXG5uZXcgVGVzdFN0YWNrKGFwcCwgJ2xhbWJkYS10ZXN0LWFzc2V0cycpO1xuXG5hcHAucnVuKCk7XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYXNzZXRzLmxpdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmFzc2V0cy5saXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsNkJBQThCO0FBQzlCLGlDQUFrQztBQUVsQyxNQUFNLFNBQVUsU0FBUSxHQUFHLENBQUMsS0FBSztJQUMvQixZQUFZLEtBQWMsRUFBRSxFQUFVO1FBQ3BDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsU0FBUztRQUNULElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ3BDLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO1lBQ2xFLE9BQU8sRUFBRSxZQUFZO1lBQ3JCLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFFBQVE7U0FDakMsQ0FBQyxDQUFDO1FBQ0gsU0FBUztJQUNYLENBQUM7Q0FDRjtBQUVELE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBRTFCLElBQUksU0FBUyxDQUFDLEdBQUcsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO0FBRXpDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCBwYXRoID0gcmVxdWlyZSgncGF0aCcpO1xuaW1wb3J0IGxhbWJkYSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jbGFzcyBUZXN0U3RhY2sgZXh0ZW5kcyBjZGsuU3RhY2sge1xuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkFwcCwgaWQ6IHN0cmluZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICAvLy8gIXNob3dcbiAgICBuZXcgbGFtYmRhLkZ1bmN0aW9uKHRoaXMsICdNeUxhbWJkYScsIHtcbiAgICAgIGNvZGU6IGxhbWJkYS5Db2RlLmFzc2V0KHBhdGguam9pbihfX2Rpcm5hbWUsICdteS1sYW1iZGEtaGFuZGxlcicpKSxcbiAgICAgIGhhbmRsZXI6ICdpbmRleC5tYWluJyxcbiAgICAgIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLlB5dGhvbjM2XG4gICAgfSk7XG4gICAgLy8vICFoaWRlXG4gIH1cbn1cblxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcblxubmV3IFRlc3RTdGFjayhhcHAsICdsYW1iZGEtdGVzdC1hc3NldHMnKTtcblxuYXBwLnJ1bigpO1xuIl19 |
@@ -30,3 +30,3 @@ "use strict"; | ||
FunctionName: { Ref: "MyLambdaCCE802FB" }, | ||
FunctionVersion: cdk_1.resolve(version.functionVersion), | ||
FunctionVersion: stack.node.resolve(version.functionVersion), | ||
Name: "prod" | ||
@@ -53,7 +53,7 @@ } | ||
assert_1.expect(stack).to(assert_1.haveResource('AWS::Lambda::Alias', { | ||
FunctionVersion: cdk_1.resolve(version1.functionVersion), | ||
FunctionVersion: stack.node.resolve(version1.functionVersion), | ||
RoutingConfig: { | ||
AdditionalVersionWeights: [ | ||
{ | ||
FunctionVersion: cdk_1.resolve(version2.functionVersion), | ||
FunctionVersion: stack.node.resolve(version2.functionVersion), | ||
FunctionWeight: 0.1 | ||
@@ -106,3 +106,3 @@ } | ||
assert_1.expect(stack).to(assert_1.haveResource('AWS::Lambda::Permission', { | ||
FunctionName: cdk_1.resolve(fn.functionName), | ||
FunctionName: stack.node.resolve(fn.functionName), | ||
Principal: "123456" | ||
@@ -113,2 +113,2 @@ })); | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.alias.js","sourceRoot":"","sources":["test.alias.ts"],"names":[],"mappings":"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","sourcesContent":["import { beASupersetOfTemplate, expect, haveResource } from '@aws-cdk/assert';\nimport { AccountPrincipal } from '@aws-cdk/aws-iam';\nimport { resolve, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport lambda = require('../lib');\n\nexport = {\n  'version and aliases'(test: Test): void {\n    const stack = new Stack();\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version = fn.addVersion('1');\n\n    new lambda.Alias(stack, 'Alias', {\n      aliasName: 'prod',\n      version,\n    });\n\n    expect(stack).to(beASupersetOfTemplate({\n      MyLambdaVersion16CDE3C40: {\n        Type: \"AWS::Lambda::Version\",\n        Properties: {\n          FunctionName: { Ref: \"MyLambdaCCE802FB\" }\n        }\n        },\n        Alias325C5727: {\n        Type: \"AWS::Lambda::Alias\",\n        Properties: {\n          FunctionName: { Ref: \"MyLambdaCCE802FB\" },\n          FunctionVersion: resolve(version.functionVersion),\n          Name: \"prod\"\n        }\n        }\n    }));\n\n    test.done();\n  },\n\n  'can add additional versions to alias'(test: Test) {\n    const stack = new Stack();\n\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version1 = fn.addVersion('1');\n    const version2 = fn.addVersion('2');\n\n    new lambda.Alias(stack, 'Alias', {\n      aliasName: 'prod',\n      version: version1,\n      additionalVersions: [{ version: version2, weight: 0.1 }]\n    });\n\n    expect(stack).to(haveResource('AWS::Lambda::Alias', {\n      FunctionVersion: resolve(version1.functionVersion),\n      RoutingConfig: {\n        AdditionalVersionWeights: [\n          {\n          FunctionVersion: resolve(version2.functionVersion),\n          FunctionWeight: 0.1\n          }\n        ]\n        }\n    }));\n\n    test.done();\n  },\n\n  'sanity checks on version weights'(test: Test) {\n    const stack = new Stack();\n\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version = fn.addVersion('1');\n\n    // WHEN: Individual weight too high\n    test.throws(() => {\n      new lambda.Alias(stack, 'Alias1', {\n        aliasName: 'prod', version,\n        additionalVersions: [{ version, weight: 5 }]\n      });\n    });\n\n    // WHEN: Sum too high\n    test.throws(() => {\n      new lambda.Alias(stack, 'Alias2', {\n        aliasName: 'prod', version,\n        additionalVersions: [{ version, weight: 0.5 }, { version, weight: 0.6 }]\n      });\n    });\n\n    test.done();\n  },\n\n  'addPermission() on alias forward to real Lambda'(test: Test) {\n    const stack = new Stack();\n\n    // GIVEN\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version = fn.addVersion('1');\n    const alias = new lambda.Alias(stack, 'Alias', { aliasName: 'prod', version });\n\n    // WHEN\n    alias.addPermission('Perm', {\n      principal: new AccountPrincipal('123456')\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::Lambda::Permission', {\n      FunctionName: resolve(fn.functionName),\n      Principal: \"123456\"\n    }));\n\n    test.done();\n  }\n};\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.alias.js","sourceRoot":"","sources":["test.alias.ts"],"names":[],"mappings":"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","sourcesContent":["import { beASupersetOfTemplate, expect, haveResource } from '@aws-cdk/assert';\nimport { AccountPrincipal } from '@aws-cdk/aws-iam';\nimport { Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport lambda = require('../lib');\n\nexport = {\n  'version and aliases'(test: Test): void {\n    const stack = new Stack();\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version = fn.addVersion('1');\n\n    new lambda.Alias(stack, 'Alias', {\n      aliasName: 'prod',\n      version,\n    });\n\n    expect(stack).to(beASupersetOfTemplate({\n      MyLambdaVersion16CDE3C40: {\n        Type: \"AWS::Lambda::Version\",\n        Properties: {\n          FunctionName: { Ref: \"MyLambdaCCE802FB\" }\n        }\n        },\n        Alias325C5727: {\n        Type: \"AWS::Lambda::Alias\",\n        Properties: {\n          FunctionName: { Ref: \"MyLambdaCCE802FB\" },\n          FunctionVersion: stack.node.resolve(version.functionVersion),\n          Name: \"prod\"\n        }\n        }\n    }));\n\n    test.done();\n  },\n\n  'can add additional versions to alias'(test: Test) {\n    const stack = new Stack();\n\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version1 = fn.addVersion('1');\n    const version2 = fn.addVersion('2');\n\n    new lambda.Alias(stack, 'Alias', {\n      aliasName: 'prod',\n      version: version1,\n      additionalVersions: [{ version: version2, weight: 0.1 }]\n    });\n\n    expect(stack).to(haveResource('AWS::Lambda::Alias', {\n      FunctionVersion: stack.node.resolve(version1.functionVersion),\n      RoutingConfig: {\n        AdditionalVersionWeights: [\n          {\n          FunctionVersion: stack.node.resolve(version2.functionVersion),\n          FunctionWeight: 0.1\n          }\n        ]\n        }\n    }));\n\n    test.done();\n  },\n\n  'sanity checks on version weights'(test: Test) {\n    const stack = new Stack();\n\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version = fn.addVersion('1');\n\n    // WHEN: Individual weight too high\n    test.throws(() => {\n      new lambda.Alias(stack, 'Alias1', {\n        aliasName: 'prod', version,\n        additionalVersions: [{ version, weight: 5 }]\n      });\n    });\n\n    // WHEN: Sum too high\n    test.throws(() => {\n      new lambda.Alias(stack, 'Alias2', {\n        aliasName: 'prod', version,\n        additionalVersions: [{ version, weight: 0.5 }, { version, weight: 0.6 }]\n      });\n    });\n\n    test.done();\n  },\n\n  'addPermission() on alias forward to real Lambda'(test: Test) {\n    const stack = new Stack();\n\n    // GIVEN\n    const fn = new lambda.Function(stack, 'MyLambda', {\n      code: new lambda.InlineCode('hello()'),\n      handler: 'index.hello',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    const version = fn.addVersion('1');\n    const alias = new lambda.Alias(stack, 'Alias', { aliasName: 'prod', version });\n\n    // WHEN\n    alias.addPermission('Perm', {\n      principal: new AccountPrincipal('123456')\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::Lambda::Permission', {\n      FunctionName: stack.node.resolve(fn.functionName),\n      Principal: \"123456\"\n    }));\n\n    test.done();\n  }\n};\n"]} |
@@ -11,4 +11,5 @@ import { Test } from 'nodeunit'; | ||
'only one Asset object gets created even if multiple functions use the same AssetCode'(test: Test): void; | ||
'adds code asset metadata'(test: Test): void; | ||
}; | ||
}; | ||
export = _default; |
"use strict"; | ||
const assert_1 = require("@aws-cdk/assert"); | ||
const assets = require("@aws-cdk/assets"); | ||
const cdk = require("@aws-cdk/cdk"); | ||
const cxapi = require("@aws-cdk/cx-api"); | ||
const path = require("path"); | ||
@@ -71,5 +73,25 @@ const lambda = require("../lib"); | ||
test.done(); | ||
}, | ||
'adds code asset metadata'(test) { | ||
// GIVEN | ||
const stack = new cdk.Stack(); | ||
stack.node.setContext(cxapi.ASSET_RESOURCE_METADATA_ENABLED_CONTEXT, true); | ||
const location = path.join(__dirname, 'my-lambda-handler'); | ||
// WHEN | ||
new lambda.Function(stack, 'Func1', { | ||
code: lambda.Code.asset(location), | ||
runtime: lambda.Runtime.NodeJS810, | ||
handler: 'foom', | ||
}); | ||
// THEN | ||
assert_1.expect(stack).to(assert_1.haveResource('AWS::Lambda::Function', { | ||
Metadata: { | ||
[cxapi.ASSET_RESOURCE_METADATA_PATH_KEY]: location, | ||
[cxapi.ASSET_RESOURCE_METADATA_PROPERTY_KEY]: 'Code' | ||
} | ||
}, assert_1.ResourcePart.CompleteDefinition)); | ||
test.done(); | ||
} | ||
} | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5jb2RlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC5jb2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSwwQ0FBMkM7QUFDM0Msb0NBQXFDO0FBRXJDLDZCQUE4QjtBQUM5QixpQ0FBa0M7QUFvRWxDLFNBQVMsY0FBYyxDQUFDLElBQWlCLEVBQUUsVUFBMEIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTO0lBQzNGLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzlCLE9BQU8sSUFBSSxNQUFNLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7UUFDeEMsT0FBTyxFQUFFLE1BQU07UUFDZixJQUFJLEVBQUUsT0FBTztLQUNkLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxTQUFTLG9CQUFvQixDQUFDLEtBQWE7SUFDekMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ1gsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUssRUFBRSxFQUFFLENBQUMsRUFBRTtRQUM5QixDQUFDLElBQUksTUFBTSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDO0tBQzNEO0lBQ0QsT0FBTyxDQUFDLENBQUM7QUFDWCxDQUFDO0FBaEZELGlCQUFTO0lBQ1Asb0JBQW9CLEVBQUU7UUFDcEIseUNBQXlDLENBQUMsSUFBVTtZQUNsRCxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLHNDQUFzQyxDQUFDLENBQUM7WUFDM0gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxjQUFj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QVcsQ0FBQyxRQUFRLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsZUFBZSxDQUFDLENBQUM7WUFDckYsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLHFCQUFxQixDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUM7WUFFdkUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ2QsQ0FBQztLQUNGO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBhc3NldHMgPSByZXF1aXJlKCdAYXdzLWNkay9hc3NldHMnKTtcbmltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgcGF0aCA9IHJlcXVpcmUoJ3BhdGgnKTtcbmltcG9ydCBsYW1iZGEgPSByZXF1aXJlKCcuLi9saWInKTtcblxuZXhwb3J0ID0ge1xuICAnbGFtYmRhLkNvZGUuaW5saW5lJzoge1xuICAgICdmYWlscyBpZiB1c2VkIHdpdGggdW5zdXBwb3J0ZWQgcnVudGltZXMnKHRlc3Q6IFRlc3QpIHtcbiAgICAgIHRlc3QudGhyb3dzKCgpID0+IGRlZmluZUZ1bmN0aW9uKGxhbWJkYS5Db2RlLmlubGluZSgnYm9vbScpLCBsYW1iZGEuUnVudGltZS5HbzF4KSwgL0lubGluZSBzb3VyY2Ugbm90IGFsbG93ZWQgZm9yIGdvMVxcLngvKTtcbiAgICAgIHRlc3QudGhyb3dzKCgpID0+IGRlZmluZUZ1bmN0aW9uKGxhbWJkYS5Db2RlLmlubGluZSgnYm9vbScpLCBsYW1iZGEuUnVudGltZS5KYXZhOCksIC9JbmxpbmUgc291cmNlIG5vdCBhbGxvd2VkIGZvciBqYXZhOC8pO1xuICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcbiAgICAnZmFpbHMgaWYgbGFyZ2VyIHRoYW4gNDA5NiBieXRlcycodGVzdDogVGVzdCkge1xuICAgICAgdGVzdC50aHJvd3MoXG4gICAgICAgICgpID0+IGRlZmluZUZ1bmN0aW9uKGxhbWJkYS5Db2RlLmlubGluZShnZW5lcmF0ZVJhbmRvbVN0cmluZyg0MDk3KSksIGxhbWJkYS5SdW50aW1lLk5vZGVKUzYxMCksXG4gICAgICAgIC9MYW1iZGEgc291cmNlIGlzIHRvbyBsYXJnZSwgbXVzdCBiZSA8PSA0MDk2IGJ1dCBpcyA0MDk3Lyk7XG4gICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9XG4gIH0sXG4gICdsYW1iZGEuQ29kZS5hc3NldCc6IHtcbiAgICAnZGV0ZXJtaW5lcyBwYWNrYWdpbmcgdHlwZSBmcm9tIGZpbGUgdHlwZScodGVzdDogVGVzdCkge1xuICAgICAgLy8gV0hFTlxuICAgICAgY29uc3QgZmlsZUFzc2V0ID0gbGFtYmRhLkNvZGUuYXNzZXQocGF0aC5qb2luKF9fZGlybmFtZSwgJ2hhbmRsZXIuemlwJykpO1xuICAgICAgY29uc3QgZGlyZWN0b3J5QXNzZXQgPSBsYW1iZGEuQ29kZS5hc3NldChwYXRoLmpvaW4oX19kaXJuYW1lLCAnbXktbGFtYmRhLWhhbmRsZXInKSk7XG5cbiAgICAgIC8vIFRIRU5cbiAgICAgIHRlc3QuZGVlcEVxdWFsKGZpbGVBc3NldC5wYWNrYWdpbmcsIGFzc2V0cy5Bc3NldFBhY2thZ2luZy5GaWxlKTtcbiAgICAgIHRlc3QuZGVlcEVxdWFsKGRpcmVjdG9yeUFzc2V0LnBhY2thZ2luZywgYXNzZXRzLkFzc2V0UGFja2FnaW5nLlppcERpcmVjdG9yeSk7XG4gICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ2ZhaWxzIGlmIGEgbm9uLXppcCBhc3NldCBpcyB1c2VkJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAvLyBHSVZFTlxuICAgICAgY29uc3QgZmlsZUFzc2V0ID0gbGFtYmRhLkNvZGUuYXNzZXQocGF0aC5qb2luKF9fZGlybmFtZSwgJ215LWxhbWJkYS1oYW5kbGVyJywgJ2luZGV4LnB5JykpO1xuXG4gICAgICAvLyBUSEVOXG4gICAgICB0ZXN0LnRocm93cygoKSA9PiBkZWZpbmVGdW5jdGlvbihmaWxlQXNzZXQpLCAvQXNzZXQgbXVzdCBiZSBhIFxcLnppcCBmaWxlIG9yIGEgZGlyZWN0b3J5Lyk7XG4gICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ29ubHkgb25lIEFzc2V0IG9iamVjdCBnZXRzIGNyZWF0ZWQgZXZlbiBpZiBtdWx0aXBsZSBmdW5jdGlvbnMgdXNlIHRoZSBzYW1lIEFzc2V0Q29kZScodGVzdDogVGVzdCkge1xuICAgICAgLy8gR0lWRU5cbiAgICAgIGNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XG4gICAgICBjb25zdCBzdGFjayA9IG5ldyBjZGsuU3RhY2soYXBwLCAnTXlTdGFjaycpO1xuICAgICAgY29uc3QgZGlyZWN0b3J5QXNzZXQgPSBsYW1iZGEuQ29kZS5hc3NldChwYXRoLmpvaW4oX19kaXJuYW1lLCAnbXktbGFtYmRhLWhhbmRsZXInKSk7XG5cbiAgICAgIC8vIFdIRU5cbiAgICAgIG5ldyBsYW1iZGEuRnVuY3Rpb24oc3RhY2ssICdGdW5jMScsIHtcbiAgICAgICAgaGFuZGxlcjogJ2Zvb20nLFxuICAgICAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5Ob2RlSlM4MTAsXG4gICAgICAgIGNvZGU6IGRpcmVjdG9yeUFzc2V0XG4gICAgICB9KTtcblxuICAgICAgbmV3IGxhbWJkYS5GdW5jdGlvbihzdGFjaywgJ0Z1bmMyJywge1xuICAgICAgICBoYW5kbGVyOiAnZm9vbScsXG4gICAgICAgIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLk5vZGVKUzgxMCxcbiAgICAgICAgY29kZTogZGlyZWN0b3J5QXNzZXRcbiAgICAgIH0pO1xuXG4gICAgICAvLyBUSEVOXG4gICAgICBjb25zdCBzeW50aGVzaXplZCA9IGFwcC5zeW50aGVzaXplU3RhY2soJ015U3RhY2snKTtcblxuICAgICAgLy8gRnVuYzEgaGFzIGFuIGFzc2V0LCBGdW5jMiBkb2VzIG5vdFxuICAgICAgdGVzdC5kZWVwRXF1YWwoc3ludGhlc2l6ZWQubWV0YWRhdGFbJy9NeVN0YWNrL0Z1bmMxL0NvZGUnXVswXS50eXBlLCAnYXdzOmNkazphc3NldCcpO1xuICAgICAgdGVzdC5kZWVwRXF1YWwoc3ludGhlc2l6ZWQubWV0YWRhdGFbJy9NeVN0YWNrL0Z1bmMyL0NvZGUnXSwgdW5kZWZpbmVkKTtcblxuICAgICAgdGVzdC5kb25lKCk7XG4gICAgfVxuICB9XG59O1xuXG5mdW5jdGlvbiBkZWZpbmVGdW5jdGlvbihjb2RlOiBsYW1iZGEuQ29kZSwgcnVudGltZTogbGFtYmRhLlJ1bnRpbWUgPSBsYW1iZGEuUnVudGltZS5Ob2RlSlM4MTApIHtcbiAgY29uc3Qgc3RhY2sgPSBuZXcgY2RrLlN0YWNrKCk7XG4gIHJldHVybiBuZXcgbGFtYmRhLkZ1bmN0aW9uKHN0YWNrLCAnRnVuYycsIHtcbiAgICBoYW5kbGVyOiAnZm9vbScsXG4gICAgY29kZSwgcnVudGltZVxuICB9KTtcbn1cblxuZnVuY3Rpb24gZ2VuZXJhdGVSYW5kb21TdHJpbmcoYnl0ZXM6IG51bWJlcikge1xuICBsZXQgcyA9ICcnO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGJ5dGVzOyArK2kpIHtcbiAgICBzICs9IFN0cmluZy5mcm9tQ2hhckNvZGUoTWF0aC5yb3VuZChNYXRoLnJhbmRvbSgpICogMjU2KSk7XG4gIH1cbiAgcmV0dXJuIHM7XG59Il19 | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.code.js","sourceRoot":"","sources":["test.code.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, ResourcePart } from '@aws-cdk/assert';\nimport assets = require('@aws-cdk/assets');\nimport cdk = require('@aws-cdk/cdk');\nimport cxapi = require('@aws-cdk/cx-api');\nimport { Test } from 'nodeunit';\nimport path = require('path');\nimport lambda = require('../lib');\n\nexport = {\n  'lambda.Code.inline': {\n    'fails if used with unsupported runtimes'(test: Test) {\n      test.throws(() => defineFunction(lambda.Code.inline('boom'), lambda.Runtime.Go1x), /Inline source not allowed for go1\\.x/);\n      test.throws(() => defineFunction(lambda.Code.inline('boom'), lambda.Runtime.Java8), /Inline source not allowed for java8/);\n      test.done();\n    },\n    'fails if larger than 4096 bytes'(test: Test) {\n      test.throws(\n        () => defineFunction(lambda.Code.inline(generateRandomString(4097)), lambda.Runtime.NodeJS610),\n        /Lambda source is too large, must be <= 4096 but is 4097/);\n      test.done();\n    }\n  },\n  'lambda.Code.asset': {\n    'determines packaging type from file type'(test: Test) {\n      // WHEN\n      const fileAsset = lambda.Code.asset(path.join(__dirname, 'handler.zip'));\n      const directoryAsset = lambda.Code.asset(path.join(__dirname, 'my-lambda-handler'));\n\n      // THEN\n      test.deepEqual(fileAsset.packaging, assets.AssetPackaging.File);\n      test.deepEqual(directoryAsset.packaging, assets.AssetPackaging.ZipDirectory);\n      test.done();\n    },\n\n    'fails if a non-zip asset is used'(test: Test) {\n      // GIVEN\n      const fileAsset = lambda.Code.asset(path.join(__dirname, 'my-lambda-handler', 'index.py'));\n\n      // THEN\n      test.throws(() => defineFunction(fileAsset), /Asset must be a \\.zip file or a directory/);\n      test.done();\n    },\n\n    'only one Asset object gets created even if multiple functions use the same AssetCode'(test: Test) {\n      // GIVEN\n      const app = new cdk.App();\n      const stack = new cdk.Stack(app, 'MyStack');\n      const directoryAsset = lambda.Code.asset(path.join(__dirname, 'my-lambda-handler'));\n\n      // WHEN\n      new lambda.Function(stack, 'Func1', {\n        handler: 'foom',\n        runtime: lambda.Runtime.NodeJS810,\n        code: directoryAsset\n      });\n\n      new lambda.Function(stack, 'Func2', {\n        handler: 'foom',\n        runtime: lambda.Runtime.NodeJS810,\n        code: directoryAsset\n      });\n\n      // THEN\n      const synthesized = app.synthesizeStack('MyStack');\n\n      // Func1 has an asset, Func2 does not\n      test.deepEqual(synthesized.metadata['/MyStack/Func1/Code'][0].type, 'aws:cdk:asset');\n      test.deepEqual(synthesized.metadata['/MyStack/Func2/Code'], undefined);\n\n      test.done();\n    },\n\n    'adds code asset metadata'(test: Test) {\n      // GIVEN\n      const stack = new cdk.Stack();\n      stack.node.setContext(cxapi.ASSET_RESOURCE_METADATA_ENABLED_CONTEXT, true);\n\n      const location = path.join(__dirname, 'my-lambda-handler');\n\n      // WHEN\n      new lambda.Function(stack, 'Func1', {\n        code: lambda.Code.asset(location),\n        runtime: lambda.Runtime.NodeJS810,\n        handler: 'foom',\n      });\n\n      // THEN\n      expect(stack).to(haveResource('AWS::Lambda::Function', {\n        Metadata: {\n          [cxapi.ASSET_RESOURCE_METADATA_PATH_KEY]: location,\n          [cxapi.ASSET_RESOURCE_METADATA_PROPERTY_KEY]: 'Code'\n        }\n      }, ResourcePart.CompleteDefinition));\n      test.done();\n    }\n  }\n};\n\nfunction defineFunction(code: lambda.Code, runtime: lambda.Runtime = lambda.Runtime.NodeJS810) {\n  const stack = new cdk.Stack();\n  return new lambda.Function(stack, 'Func', {\n    handler: 'foom',\n    code, runtime\n  });\n}\n\nfunction generateRandomString(bytes: number) {\n  let s = '';\n  for (let i = 0; i < bytes; ++i) {\n    s += String.fromCharCode(Math.round(Math.random() * 256));\n  }\n  return s;\n}\n"]} |
@@ -12,3 +12,3 @@ import { Test } from 'nodeunit'; | ||
'import/export': { | ||
'lambda.export() can be used to add Outputs to the stack and returns a LambdaRef object'(test: Test): void; | ||
'lambda.export() can be used to add Outputs to the stack and returns an IFunction object'(test: Test): void; | ||
}; | ||
@@ -15,0 +15,0 @@ 'Lambda can serve as EventRule target, permission gets added'(test: Test): void; |
@@ -101,3 +101,3 @@ "use strict"; | ||
// WHEN | ||
const importedLambda = lambda.FunctionRef.import(stack2, 'Lambda', this.lambda.export()); | ||
const importedLambda = lambda.Function.import(stack2, 'Lambda', this.lambda.export()); | ||
importedLambda.connections.allowTo(somethingConnectable, new ec2.TcpAllPorts(), 'Lambda can call connectable'); | ||
@@ -156,2 +156,2 @@ // THEN: SomeSecurityGroup accepts connections from Lambda | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.vpc-lambda.js","sourceRoot":"","sources":["test.vpc-lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { ICallbackFunction, Test } from 'nodeunit';\nimport lambda = require('../lib');\n\nexport = {\n  'lambda in a VPC': classFixture(class Henk {\n    private readonly stack: cdk.Stack;\n    private readonly vpc: ec2.VpcNetwork;\n    private readonly lambda: lambda.Function;\n\n    constructor() {\n      // GIVEN\n      this.stack = new cdk.Stack();\n      this.vpc = new ec2.VpcNetwork(this.stack, 'VPC');\n\n      // WHEN\n      this.lambda = new lambda.Function(this.stack, 'Lambda', {\n        code: new lambda.InlineCode('foo'),\n        handler: 'index.handler',\n        runtime: lambda.Runtime.NodeJS610,\n        vpc: this.vpc,\n        allowAllOutbound: false\n      });\n    }\n\n    public 'has subnet and securitygroup'(test: Test) {\n      // THEN\n      expect(this.stack).to(haveResource('AWS::Lambda::Function', {\n        VpcConfig: {\n          SecurityGroupIds: [\n            {\"Fn::GetAtt\": [ \"LambdaSecurityGroupE74659A1\", \"GroupId\" ]}\n          ],\n          SubnetIds: [\n            {Ref: \"VPCPrivateSubnet1Subnet8BCA10E0\"},\n            {Ref: \"VPCPrivateSubnet2SubnetCFCDAA7A\"},\n            {Ref: \"VPCPrivateSubnet3Subnet3EDCD457\"}\n          ]\n        }\n      }));\n\n      test.done();\n    }\n\n    public 'participates in Connections objects'(test: Test) {\n      // GIVEN\n      const securityGroup = new ec2.SecurityGroup(this.stack, 'SomeSecurityGroup', { vpc: this.vpc });\n      const somethingConnectable = new SomethingConnectable(new ec2.Connections({ securityGroups: [securityGroup] }));\n\n      // WHEN\n      this.lambda.connections.allowTo(somethingConnectable, new ec2.TcpAllPorts(), 'Lambda can call connectable');\n\n      // THEN: Lambda can connect to SomeSecurityGroup\n      expect(this.stack).to(haveResource(\"AWS::EC2::SecurityGroupEgress\", {\n        GroupId: {\"Fn::GetAtt\": [\"LambdaSecurityGroupE74659A1\", \"GroupId\"]},\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        DestinationSecurityGroupId: {\"Fn::GetAtt\": [ \"SomeSecurityGroupEF219AD6\", \"GroupId\" ]},\n        FromPort: 0,\n        ToPort: 65535\n      }));\n\n      // THEN: SomeSecurityGroup accepts connections from Lambda\n      expect(this.stack).to(haveResource(\"AWS::EC2::SecurityGroupIngress\", {\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        FromPort: 0,\n        GroupId: { \"Fn::GetAtt\": [\"SomeSecurityGroupEF219AD6\", \"GroupId\"] },\n        SourceSecurityGroupId: {\"Fn::GetAtt\": [\"LambdaSecurityGroupE74659A1\", \"GroupId\" ]},\n        ToPort: 65535\n      }));\n\n      test.done();\n    }\n\n    public 'can still make Connections after export/import'(test: Test) {\n      // GIVEN\n      const stack2 = new cdk.Stack();\n      const securityGroup = new ec2.SecurityGroup(stack2, 'SomeSecurityGroup', { vpc: this.vpc });\n      const somethingConnectable = new SomethingConnectable(new ec2.Connections({ securityGroups: [securityGroup] }));\n\n      // WHEN\n      const importedLambda = lambda.FunctionRef.import(stack2, 'Lambda', this.lambda.export());\n      importedLambda.connections.allowTo(somethingConnectable, new ec2.TcpAllPorts(), 'Lambda can call connectable');\n\n      // THEN: SomeSecurityGroup accepts connections from Lambda\n      expect(stack2).to(haveResource(\"AWS::EC2::SecurityGroupEgress\", {\n        GroupId: { \"Fn::ImportValue\": \"LambdaSecurityGroupId9A2717B3\" },\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        DestinationSecurityGroupId: { \"Fn::GetAtt\": [ \"SomeSecurityGroupEF219AD6\", \"GroupId\" ] },\n        FromPort: 0,\n        ToPort: 65535\n      }));\n\n      // THEN: Lambda can connect to SomeSecurityGroup\n      expect(stack2).to(haveResource(\"AWS::EC2::SecurityGroupIngress\", {\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        FromPort: 0,\n        GroupId: { \"Fn::GetAtt\": [ \"SomeSecurityGroupEF219AD6\", \"GroupId\" ] },\n        SourceSecurityGroupId: { \"Fn::ImportValue\": \"LambdaSecurityGroupId9A2717B3\" },\n        ToPort: 65535\n      }));\n\n      test.done();\n    }\n  }),\n\n  'lambda without VPC throws Error upon accessing connections'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const lambdaFn = new lambda.Function(stack, 'Lambda', {\n      code: new lambda.InlineCode('foo'),\n      handler: 'index.handler',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    // WHEN\n    test.throws(() => {\n      lambdaFn.connections.allowToAnyIPv4(new ec2.TcpAllPorts(), 'Reach for the world Lambda!');\n    });\n\n    test.done();\n  },\n\n  'picking public subnets is not allowed'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'VPC');\n\n    // WHEN\n    test.throws(() => {\n      new lambda.Function(stack, 'Lambda', {\n        code: new lambda.InlineCode('foo'),\n        handler: 'index.handler',\n        runtime: lambda.Runtime.NodeJS610,\n        vpc,\n        vpcPlacement: { subnetsToUse: ec2.SubnetType.Public }\n      });\n    });\n\n    test.done();\n  }\n};\n\n/**\n * Use a class as test fixture\n *\n * setUp() will be mapped to the (synchronous) constructor. tearDown(cb) will be called if available.\n */\nfunction classFixture(klass: any) {\n  let fixture: any;\n\n  const ret: any = {\n    setUp(cb: ICallbackFunction) {\n      fixture = new klass();\n      cb();\n    },\n\n    tearDown(cb: ICallbackFunction) {\n      if (fixture.tearDown) {\n        fixture.tearDown(cb);\n      } else {\n        cb();\n      }\n    }\n  };\n\n  const testNames = Reflect.ownKeys(klass.prototype).filter(m => m !== 'tearDown' && m !== 'constructor');\n  for (const testName of testNames) {\n    ret[testName] = (test: Test) => fixture[testName](test);\n  }\n\n  return ret;\n}\n\nclass SomethingConnectable implements ec2.IConnectable {\n  constructor(public readonly connections: ec2.Connections) {\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.vpc-lambda.js","sourceRoot":"","sources":["test.vpc-lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { ICallbackFunction, Test } from 'nodeunit';\nimport lambda = require('../lib');\n\nexport = {\n  'lambda in a VPC': classFixture(class Henk {\n    private readonly stack: cdk.Stack;\n    private readonly vpc: ec2.VpcNetwork;\n    private readonly lambda: lambda.Function;\n\n    constructor() {\n      // GIVEN\n      this.stack = new cdk.Stack();\n      this.vpc = new ec2.VpcNetwork(this.stack, 'VPC');\n\n      // WHEN\n      this.lambda = new lambda.Function(this.stack, 'Lambda', {\n        code: new lambda.InlineCode('foo'),\n        handler: 'index.handler',\n        runtime: lambda.Runtime.NodeJS610,\n        vpc: this.vpc,\n        allowAllOutbound: false\n      });\n    }\n\n    public 'has subnet and securitygroup'(test: Test) {\n      // THEN\n      expect(this.stack).to(haveResource('AWS::Lambda::Function', {\n        VpcConfig: {\n          SecurityGroupIds: [\n            {\"Fn::GetAtt\": [ \"LambdaSecurityGroupE74659A1\", \"GroupId\" ]}\n          ],\n          SubnetIds: [\n            {Ref: \"VPCPrivateSubnet1Subnet8BCA10E0\"},\n            {Ref: \"VPCPrivateSubnet2SubnetCFCDAA7A\"},\n            {Ref: \"VPCPrivateSubnet3Subnet3EDCD457\"}\n          ]\n        }\n      }));\n\n      test.done();\n    }\n\n    public 'participates in Connections objects'(test: Test) {\n      // GIVEN\n      const securityGroup = new ec2.SecurityGroup(this.stack, 'SomeSecurityGroup', { vpc: this.vpc });\n      const somethingConnectable = new SomethingConnectable(new ec2.Connections({ securityGroups: [securityGroup] }));\n\n      // WHEN\n      this.lambda.connections.allowTo(somethingConnectable, new ec2.TcpAllPorts(), 'Lambda can call connectable');\n\n      // THEN: Lambda can connect to SomeSecurityGroup\n      expect(this.stack).to(haveResource(\"AWS::EC2::SecurityGroupEgress\", {\n        GroupId: {\"Fn::GetAtt\": [\"LambdaSecurityGroupE74659A1\", \"GroupId\"]},\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        DestinationSecurityGroupId: {\"Fn::GetAtt\": [ \"SomeSecurityGroupEF219AD6\", \"GroupId\" ]},\n        FromPort: 0,\n        ToPort: 65535\n      }));\n\n      // THEN: SomeSecurityGroup accepts connections from Lambda\n      expect(this.stack).to(haveResource(\"AWS::EC2::SecurityGroupIngress\", {\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        FromPort: 0,\n        GroupId: { \"Fn::GetAtt\": [\"SomeSecurityGroupEF219AD6\", \"GroupId\"] },\n        SourceSecurityGroupId: {\"Fn::GetAtt\": [\"LambdaSecurityGroupE74659A1\", \"GroupId\" ]},\n        ToPort: 65535\n      }));\n\n      test.done();\n    }\n\n    public 'can still make Connections after export/import'(test: Test) {\n      // GIVEN\n      const stack2 = new cdk.Stack();\n      const securityGroup = new ec2.SecurityGroup(stack2, 'SomeSecurityGroup', { vpc: this.vpc });\n      const somethingConnectable = new SomethingConnectable(new ec2.Connections({ securityGroups: [securityGroup] }));\n\n      // WHEN\n      const importedLambda = lambda.Function.import(stack2, 'Lambda', this.lambda.export());\n      importedLambda.connections.allowTo(somethingConnectable, new ec2.TcpAllPorts(), 'Lambda can call connectable');\n\n      // THEN: SomeSecurityGroup accepts connections from Lambda\n      expect(stack2).to(haveResource(\"AWS::EC2::SecurityGroupEgress\", {\n        GroupId: { \"Fn::ImportValue\": \"LambdaSecurityGroupId9A2717B3\" },\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        DestinationSecurityGroupId: { \"Fn::GetAtt\": [ \"SomeSecurityGroupEF219AD6\", \"GroupId\" ] },\n        FromPort: 0,\n        ToPort: 65535\n      }));\n\n      // THEN: Lambda can connect to SomeSecurityGroup\n      expect(stack2).to(haveResource(\"AWS::EC2::SecurityGroupIngress\", {\n        IpProtocol: \"tcp\",\n        Description: \"Lambda can call connectable\",\n        FromPort: 0,\n        GroupId: { \"Fn::GetAtt\": [ \"SomeSecurityGroupEF219AD6\", \"GroupId\" ] },\n        SourceSecurityGroupId: { \"Fn::ImportValue\": \"LambdaSecurityGroupId9A2717B3\" },\n        ToPort: 65535\n      }));\n\n      test.done();\n    }\n  }),\n\n  'lambda without VPC throws Error upon accessing connections'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const lambdaFn = new lambda.Function(stack, 'Lambda', {\n      code: new lambda.InlineCode('foo'),\n      handler: 'index.handler',\n      runtime: lambda.Runtime.NodeJS610,\n    });\n\n    // WHEN\n    test.throws(() => {\n      lambdaFn.connections.allowToAnyIPv4(new ec2.TcpAllPorts(), 'Reach for the world Lambda!');\n    });\n\n    test.done();\n  },\n\n  'picking public subnets is not allowed'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'VPC');\n\n    // WHEN\n    test.throws(() => {\n      new lambda.Function(stack, 'Lambda', {\n        code: new lambda.InlineCode('foo'),\n        handler: 'index.handler',\n        runtime: lambda.Runtime.NodeJS610,\n        vpc,\n        vpcPlacement: { subnetsToUse: ec2.SubnetType.Public }\n      });\n    });\n\n    test.done();\n  }\n};\n\n/**\n * Use a class as test fixture\n *\n * setUp() will be mapped to the (synchronous) constructor. tearDown(cb) will be called if available.\n */\nfunction classFixture(klass: any) {\n  let fixture: any;\n\n  const ret: any = {\n    setUp(cb: ICallbackFunction) {\n      fixture = new klass();\n      cb();\n    },\n\n    tearDown(cb: ICallbackFunction) {\n      if (fixture.tearDown) {\n        fixture.tearDown(cb);\n      } else {\n        cb();\n      }\n    }\n  };\n\n  const testNames = Reflect.ownKeys(klass.prototype).filter(m => m !== 'tearDown' && m !== 'constructor');\n  for (const testName of testNames) {\n    ret[testName] = (test: Test) => fixture[testName](test);\n  }\n\n  return ret;\n}\n\nclass SomethingConnectable implements ec2.IConnectable {\n  constructor(public readonly connections: ec2.Connections) {\n  }\n}\n"]} |
@@ -25,5 +25,56 @@ { | ||
"strictNullChecks": true, | ||
"target": "ES2018" | ||
"target": "ES2018", | ||
"composite": true | ||
}, | ||
"include": [ | ||
"**/*.ts" | ||
], | ||
"exclude": [ | ||
"node_modules" | ||
], | ||
"references": [ | ||
{ | ||
"path": "../assets" | ||
}, | ||
{ | ||
"path": "../aws-cloudwatch" | ||
}, | ||
{ | ||
"path": "../aws-codepipeline-api" | ||
}, | ||
{ | ||
"path": "../aws-ec2" | ||
}, | ||
{ | ||
"path": "../aws-events" | ||
}, | ||
{ | ||
"path": "../aws-iam" | ||
}, | ||
{ | ||
"path": "../aws-logs" | ||
}, | ||
{ | ||
"path": "../aws-s3" | ||
}, | ||
{ | ||
"path": "../aws-s3-notifications" | ||
}, | ||
{ | ||
"path": "../aws-sqs" | ||
}, | ||
{ | ||
"path": "../aws-stepfunctions" | ||
}, | ||
{ | ||
"path": "../cdk" | ||
}, | ||
{ | ||
"path": "../cx-api" | ||
}, | ||
{ | ||
"path": "../assert" | ||
} | ||
], | ||
"_generated_by_jsii_": "Generated by jsii - safe to delete, and ideally should be in .gitignore" | ||
} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
141
834240
6061
+ Added@aws-cdk/assets@0.22.0(transitive)
+ Added@aws-cdk/aws-autoscaling-api@0.22.0(transitive)
+ Added@aws-cdk/aws-cloudwatch@0.22.0(transitive)
+ Added@aws-cdk/aws-codepipeline-api@0.22.0(transitive)
+ Added@aws-cdk/aws-ec2@0.22.0(transitive)
+ Added@aws-cdk/aws-events@0.22.0(transitive)
+ Added@aws-cdk/aws-iam@0.22.0(transitive)
+ Added@aws-cdk/aws-kms@0.22.0(transitive)
+ Added@aws-cdk/aws-logs@0.22.0(transitive)
+ Added@aws-cdk/aws-s3@0.22.0(transitive)
+ Added@aws-cdk/aws-s3-notifications@0.22.0(transitive)
+ Added@aws-cdk/aws-sqs@0.22.0(transitive)
+ Added@aws-cdk/aws-stepfunctions@0.22.0(transitive)
+ Added@aws-cdk/cdk@0.22.0(transitive)
+ Added@aws-cdk/cx-api@0.22.0(transitive)
- Removed@aws-cdk/assets@0.21.0(transitive)
- Removed@aws-cdk/aws-autoscaling-api@0.21.0(transitive)
- Removed@aws-cdk/aws-cloudwatch@0.21.0(transitive)
- Removed@aws-cdk/aws-codepipeline-api@0.21.0(transitive)
- Removed@aws-cdk/aws-ec2@0.21.0(transitive)
- Removed@aws-cdk/aws-events@0.21.0(transitive)
- Removed@aws-cdk/aws-iam@0.21.0(transitive)
- Removed@aws-cdk/aws-kms@0.21.0(transitive)
- Removed@aws-cdk/aws-logs@0.21.0(transitive)
- Removed@aws-cdk/aws-s3@0.21.0(transitive)
- Removed@aws-cdk/aws-s3-notifications@0.21.0(transitive)
- Removed@aws-cdk/aws-sqs@0.21.0(transitive)
- Removed@aws-cdk/aws-stepfunctions@0.21.0(transitive)
- Removed@aws-cdk/cdk@0.21.0(transitive)
- Removed@aws-cdk/cx-api@0.21.0(transitive)
Updated@aws-cdk/assets@^0.22.0
Updated@aws-cdk/aws-ec2@^0.22.0
Updated@aws-cdk/aws-events@^0.22.0
Updated@aws-cdk/aws-iam@^0.22.0
Updated@aws-cdk/aws-logs@^0.22.0
Updated@aws-cdk/aws-s3@^0.22.0
Updated@aws-cdk/aws-sqs@^0.22.0
Updated@aws-cdk/cdk@^0.22.0
Updated@aws-cdk/cx-api@^0.22.0