Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-lambda

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-lambda - npm Package Compare versions

Comparing version 0.27.0 to 0.28.0

1

lib/alias.d.ts

@@ -72,2 +72,3 @@ import cloudwatch = require('@aws-cdk/aws-cloudwatch');

readonly role: import("@aws-cdk/aws-iam").IRole | undefined;
readonly grantPrincipal: import("@aws-cdk/aws-iam").IPrincipal;
metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;

@@ -74,0 +75,0 @@ export(): FunctionImportProps;

5

lib/alias.js

@@ -33,2 +33,5 @@ "use strict";

}
get grantPrincipal() {
return this.underlyingLambda.grantPrincipal;
}
metric(metricName, props = {}) {

@@ -81,2 +84,2 @@ // Metrics on Aliases need the "bare" function name, and the alias' ARN, this differes from the base behavior.

exports.Alias = Alias;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["alias.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport cdk = require('@aws-cdk/cdk');\nimport { FunctionBase, FunctionImportProps, IFunction } from './function-base';\nimport { Version } from './lambda-version';\nimport { CfnAlias } from './lambda.generated';\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  readonly 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  readonly version: Version;\n\n  /**\n   * Name of this alias\n   */\n  readonly 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  readonly 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  protected readonly canCreatePermissions: boolean = true;\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    // ARN parsing splits on `:`, so we can only get the function's name from the ARN as resourceName...\n    // And we're parsing it out (instead of using the underlying function directly) in order to have use of it incur\n    // an implicit dependency on the resource.\n    this.functionName = `${this.node.stack.parseArn(alias.aliasArn, \":\").resourceName!}:${props.aliasName}`;\n    this.functionArn = alias.aliasArn;\n  }\n\n  /**\n   * Role associated with this alias\n   */\n  public get role() {\n    return this.underlyingLambda.role;\n  }\n\n  public metric(metricName: string, props: cloudwatch.MetricCustomization = {}): cloudwatch.Metric {\n    // Metrics on Aliases need the \"bare\" function name, and the alias' ARN, this differes from the base behavior.\n    return super.metric(metricName, {\n      dimensions: {\n        FunctionName: this.underlyingLambda.functionName,\n        Resource: this.functionArn\n      },\n      ...props\n    });\n  }\n\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.CfnOutput(this, 'AliasArn', { value: this.functionArn }).makeImportValue().toString()\n    };\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"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["alias.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport cdk = require('@aws-cdk/cdk');\nimport { FunctionBase, FunctionImportProps, IFunction } from './function-base';\nimport { Version } from './lambda-version';\nimport { CfnAlias } from './lambda.generated';\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  readonly 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  readonly version: Version;\n\n  /**\n   * Name of this alias\n   */\n  readonly 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  readonly 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  protected readonly canCreatePermissions: boolean = true;\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    // ARN parsing splits on `:`, so we can only get the function's name from the ARN as resourceName...\n    // And we're parsing it out (instead of using the underlying function directly) in order to have use of it incur\n    // an implicit dependency on the resource.\n    this.functionName = `${this.node.stack.parseArn(alias.aliasArn, \":\").resourceName!}:${props.aliasName}`;\n    this.functionArn = alias.aliasArn;\n  }\n\n  /**\n   * Role associated with this alias\n   */\n  public get role() {\n    return this.underlyingLambda.role;\n  }\n\n  public get grantPrincipal() {\n    return this.underlyingLambda.grantPrincipal;\n  }\n\n  public metric(metricName: string, props: cloudwatch.MetricCustomization = {}): cloudwatch.Metric {\n    // Metrics on Aliases need the \"bare\" function name, and the alias' ARN, this differes from the base behavior.\n    return super.metric(metricName, {\n      dimensions: {\n        FunctionName: this.underlyingLambda.functionName,\n        Resource: this.functionArn\n      },\n      ...props\n    });\n  }\n\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.CfnOutput(this, 'AliasArn', { value: this.functionArn }).makeImportValue().toString()\n    };\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"]}

@@ -11,4 +11,3 @@ import cloudwatch = require('@aws-cdk/aws-cloudwatch');

import { Permission } from './permission';
import { CommonPipelineInvokeActionProps, PipelineInvokeAction } from './pipeline-action';
export interface IFunction extends cdk.IConstruct, events.IEventRuleTarget, logs.ILogSubscriptionDestination, s3n.IBucketNotificationDestination, ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource {
export interface IFunction extends cdk.IConstruct, events.IEventRuleTarget, logs.ILogSubscriptionDestination, s3n.IBucketNotificationDestination, ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource, iam.IGrantable {
/**

@@ -41,9 +40,2 @@ * Logical ID of this Function.

addPermission(id: string, permission: Permission): void;
/**
* Convenience method for creating a new {@link PipelineInvokeAction}.
*
* @param props the construction properties of the new Action
* @returns the newly created {@link PipelineInvokeAction}
*/
toCodePipelineInvokeAction(props: CommonPipelineInvokeActionProps): PipelineInvokeAction;
addToRolePolicy(statement: iam.PolicyStatement): void;

@@ -53,3 +45,3 @@ /**

*/
grantInvoke(identity?: iam.IPrincipal): void;
grantInvoke(identity: iam.IGrantable): iam.Grant;
/**

@@ -109,2 +101,6 @@ * Return the given named metric for this Lambda

/**
* The principal this Lambda Function is running as
*/
abstract readonly grantPrincipal: iam.IPrincipal;
/**
* The name of the function.

@@ -119,2 +115,4 @@ */

* The IAM role associated with this function.
*
* Undefined if the function was imported without a role.
*/

@@ -138,3 +136,2 @@ abstract readonly role?: iam.IRole;

readonly id: string;
toCodePipelineInvokeAction(props: CommonPipelineInvokeActionProps): PipelineInvokeAction;
addToRolePolicy(statement: iam.PolicyStatement): void;

@@ -161,3 +158,3 @@ /**

*/
grantInvoke(identity?: iam.IPrincipal): void;
grantInvoke(grantee: iam.IGrantable): iam.Grant;
logSubscriptionDestination(sourceLogGroup: logs.ILogGroup): logs.LogSubscriptionDestination;

@@ -164,0 +161,0 @@ /**

@@ -7,3 +7,2 @@ "use strict";

const lambda_generated_1 = require("./lambda.generated");
const pipeline_action_1 = require("./pipeline-action");
class FunctionBase extends cdk.Construct {

@@ -40,5 +39,2 @@ constructor() {

}
toCodePipelineInvokeAction(props) {
return new pipeline_action_1.PipelineInvokeAction(Object.assign({}, props, { lambda: this }));
}
addToRolePolicy(statement) {

@@ -91,8 +87,22 @@ if (!this.role) {

*/
grantInvoke(identity) {
if (identity) {
identity.addToPolicy(new iam.PolicyStatement()
.addAction('lambda:InvokeFunction')
.addResource(this.functionArn));
}
grantInvoke(grantee) {
return iam.Grant.addToPrincipalOrResource({
grantee,
actions: ['lambda:InvokeFunction'],
resourceArns: [this.functionArn],
// Fake resource-like object on which to call addToResourcePolicy(), which actually
// calls addPermission()
resource: {
addToResourcePolicy: (_statement) => {
// Couldn't add permissions to the principal, so add them locally.
const identifier = 'Invoke' + JSON.stringify(grantee.grantPrincipal.policyFragment.principalJson);
this.addPermission(identifier, {
principal: grantee.grantPrincipal,
action: 'lambda:InvokeFunction',
});
},
dependencyRoots: [],
node: this.node,
},
});
}

@@ -174,3 +184,3 @@ logSubscriptionDestination(sourceLogGroup) {

}
throw new Error(`Invalid principal type for Lambda permission statement: ${JSON.stringify(this.node.resolve(principal))}. ` +
throw new Error(`Invalid principal type for Lambda permission statement: ${this.node.resolve(principal.toString())}. ` +
'Supported: AccountPrincipal, ServicePrincipal');

@@ -180,2 +190,2 @@ }

exports.FunctionBase = FunctionBase;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function-base.js","sourceRoot":"","sources":["function-base.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\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   *\n   * @param props the construction properties of the new Action\n   * @returns the newly created {@link PipelineInvokeAction}\n   */\n  toCodePipelineInvokeAction(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 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  readonly 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  readonly 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  readonly 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   * @internal\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.functionArn,\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  public toCodePipelineInvokeAction(props: CommonPipelineInvokeActionProps): PipelineInvokeAction {\n    return new PipelineInvokeAction({\n      ...props,\n      lambda: this,\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  public logSubscriptionDestination(sourceLogGroup: logs.ILogGroup): 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(`logs.${this.node.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    if (!this.node.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        sourceAccount: this.node.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.CfnResource;\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"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function-base.js","sourceRoot":"","sources":["function-base.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\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';\n\nexport interface IFunction extends cdk.IConstruct, events.IEventRuleTarget, logs.ILogSubscriptionDestination,\n  s3n.IBucketNotificationDestination, ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource, iam.IGrantable {\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  addToRolePolicy(statement: iam.PolicyStatement): void;\n\n  /**\n   * Grant the given identity permissions to invoke this Lambda\n   */\n  grantInvoke(identity: iam.IGrantable): iam.Grant;\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 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  readonly 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  readonly 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  readonly securityGroupId?: string;\n}\n\nexport abstract class FunctionBase extends cdk.Construct implements IFunction  {\n  /**\n   * The principal this Lambda Function is running as\n   */\n  public abstract readonly grantPrincipal: iam.IPrincipal;\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   * Undefined if the function was imported without a role.\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   * @internal\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.functionArn,\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  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(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipalOrResource({\n      grantee,\n      actions: ['lambda:InvokeFunction'],\n      resourceArns: [this.functionArn],\n\n      // Fake resource-like object on which to call addToResourcePolicy(), which actually\n      // calls addPermission()\n      resource: {\n        addToResourcePolicy: (_statement) => {\n          // Couldn't add permissions to the principal, so add them locally.\n          const identifier = 'Invoke' + JSON.stringify(grantee!.grantPrincipal.policyFragment.principalJson);\n          this.addPermission(identifier, {\n            principal: grantee.grantPrincipal!,\n            action: 'lambda:InvokeFunction',\n          });\n        },\n        dependencyRoots: [],\n        node: this.node,\n      },\n    });\n  }\n\n  public logSubscriptionDestination(sourceLogGroup: logs.ILogGroup): 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(`logs.${this.node.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    if (!this.node.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        sourceAccount: this.node.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.CfnResource;\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.IPrincipal) {\n    if (!principal) {\n      return undefined;\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: ${this.node.resolve(principal.toString())}. ` +\n      'Supported: AccountPrincipal, ServicePrincipal');\n  }\n}\n"]}

@@ -275,2 +275,6 @@ import cloudwatch = require('@aws-cdk/aws-cloudwatch');

readonly handler: string;
/**
* The principal this Lambda Function is running as
*/
readonly grantPrincipal: iam.IPrincipal;
protected readonly canCreatePermissions = true;

@@ -319,2 +323,17 @@ private readonly layers;

addVersion(name: string, codeSha256?: string, description?: string): Version;
/**
* Add a new version for this Lambda, always with a different name.
*
* This is similar to the {@link addVersion} method,
* but useful when deploying this Lambda through CodePipeline with blue/green deployments.
* When using {@link addVersion},
* your Alias will not be updated until you change the name passed to {@link addVersion} in your CDK code.
* When deploying through a Pipeline,
* that might lead to a situation where a change to your Lambda application code will never be activated,
* even though it traveled through the entire Pipeline,
* because the Alias is still pointing to an old Version.
* This method creates a new, unique Version every time the CDK code is executed,
* and so prevents that from happening.
*/
newVersion(): Version;
private renderEnvironment;

@@ -333,2 +352,3 @@ /**

private readonly props;
readonly grantPrincipal: iam.IPrincipal;
readonly functionName: string;

@@ -335,0 +355,0 @@ readonly functionArn: string;

@@ -60,2 +60,3 @@ "use strict";

});
this.grantPrincipal = this.role;
for (const statement of (props.initialPolicy || [])) {

@@ -246,2 +247,20 @@ this.role.addToPolicy(statement);

}
/**
* Add a new version for this Lambda, always with a different name.
*
* This is similar to the {@link addVersion} method,
* but useful when deploying this Lambda through CodePipeline with blue/green deployments.
* When using {@link addVersion},
* your Alias will not be updated until you change the name passed to {@link addVersion} in your CDK code.
* When deploying through a Pipeline,
* that might lead to a situation where a change to your Lambda application code will never be activated,
* even though it traveled through the entire Pipeline,
* because the Alias is still pointing to an old Version.
* This method creates a new, unique Version every time the CDK code is executed,
* and so prevents that from happening.
*/
newVersion() {
const now = new Date();
return this.addVersion(now.toISOString());
}
renderEnvironment() {

@@ -334,2 +353,3 @@ if (!this.environment || Object.keys(this.environment).length === 0) {

this.role = props.role;
this.grantPrincipal = this.role || new iam.ImportedResourcePrincipal({ resource: this });
if (props.securityGroupId) {

@@ -364,2 +384,2 @@ this._connections = new ec2.Connections({

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function.js","sourceRoot":"","sources":["function.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 logs = require('@aws-cdk/aws-logs');\nimport sqs = require('@aws-cdk/aws-sqs');\nimport cdk = require('@aws-cdk/cdk');\nimport { Code } from './code';\nimport { IEventSource } from './event-source';\nimport { FunctionBase, FunctionImportProps, IFunction } from './function-base';\nimport { Version } from './lambda-version';\nimport { CfnFunction } from './lambda.generated';\nimport { ILayerVersion } from './layers';\nimport { LogRetention } from './log-retention';\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  readonly code: Code;\n\n  /**\n   * A description of the function.\n   */\n  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly vpcSubnets?: ec2.SubnetSelection;\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  readonly 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  readonly 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  readonly 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  readonly deadLetterQueue?: sqs.IQueue;\n\n  /**\n   * Enable AWS X-Ray Tracing for Lambda Function.\n   *\n   * @default undefined X-Ray tracing disabled\n   */\n  readonly tracing?: Tracing;\n\n  /**\n   * A list of layers to add to the function's execution environment. You can configure your Lambda function to pull in\n   * additional code during initialization in the form of layers. Layers are packages of libraries or other dependencies\n   * that can be used by mulitple functions.\n   *\n   * @default no layers\n   */\n  readonly layers?: ILayerVersion[];\n\n  /**\n   * The maximum of concurrent executions you want to reserve for the function.\n   *\n   * @default no specific limit - account limit\n   * @see https://docs.aws.amazon.com/lambda/latest/dg/concurrent-executions.html\n   */\n  readonly reservedConcurrentExecutions?: number;\n\n  /**\n   * Event sources for this function.\n   *\n   * You can also add event sources using `addEventSource`.\n   */\n  readonly events?: IEventSource[];\n\n  /**\n   * The number of days log events are kept in CloudWatch Logs. When updating\n   * this property, unsetting it doesn't remove the log retention policy. To\n   * remove the retention policy, set the value to `Infinity`.\n   *\n   * @default logs never expire\n   */\n  readonly logRetentionDays?: logs.RetentionDays;\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  private readonly layers: ILayerVersion[] = [];\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 isChina = this.node.stack.env.region && this.node.stack.env.region.startsWith('cn-');\n    if (isChina && props.environment && Object.keys(props.environment).length > 0) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error(`Environment variables are not supported in this region (${this.node.stack.env.region}); consider using tags or SSM parameters instead`);\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      layers: new cdk.Token(() => this.layers.length > 0 ? this.layers.map(layer => layer.layerVersionArn) : undefined).toList(),\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      reservedConcurrentExecutions: props.reservedConcurrentExecutions\n    });\n\n    resource.node.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    for (const layer of props.layers || []) {\n      this.addLayer(layer);\n    }\n\n    for (const event of props.events || []) {\n      this.addEventSource(event);\n    }\n\n    // Log retention\n    if (props.logRetentionDays) {\n      new LogRetention(this, 'LogRetention', {\n        logGroupName: `/aws/lambda/${this.functionName}`,\n        retentionDays: props.logRetentionDays\n      });\n    }\n  }\n\n  /**\n   * Export this Function (without the role)\n   */\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.CfnOutput(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(),\n      securityGroupId: this._connections && this._connections.securityGroups[0]\n          ? new cdk.CfnOutput(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): this {\n    if (!this.environment) {\n      // TODO: add metadata\n      return this;\n    }\n    this.environment[key] = value;\n    return this;\n  }\n\n  /**\n   * Adds a Lambda Layer to this Lambda function.\n   *\n   * @param layer the layer to be added.\n   *\n   * @throws if there are already 5 layers on this function, or the layer is incompatible with this function's runtime.\n   */\n  public addLayer(layer: ILayerVersion): this {\n    if (this.layers.length === 5) {\n      throw new Error('Unable to add layer: this lambda function already uses 5 layers.');\n    }\n    if (layer.compatibleRuntimes && layer.compatibleRuntimes.indexOf(this.runtime) === -1) {\n      const runtimes = layer.compatibleRuntimes.map(runtime => runtime.name).join(', ');\n      throw new Error(`This lambda function uses a runtime that is incompatible with this layer (${this.runtime.name} is not in [${runtimes}])`);\n    }\n    this.layers.push(layer);\n    return this;\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    // Why are we not simply forcing vpcSubnets? Because you might still be choosing\n    // Isolated networks or selecting among 2 sets of Private subnets by name.\n    const subnetIds = props.vpc.subnetIds(props.vpcSubnets);\n    const publicSubnetIds = new Set(props.vpc.publicSubnets.map(s => s.subnetId));\n    for (const subnetId of subnetIds) {\n      if (publicSubnetIds.has(subnetId)) {\n        throw new Error('Not possible to place Lambda Functions in a Public subnet');\n      }\n    }\n\n    // List can't be empty here, if we got this far you intended to put your Lambda\n    // in subnets. We're going to guarantee that we get the nice error message by\n    // making VpcNetwork do the selection again.\n\n    return {\n      subnetIds,\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}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function.js","sourceRoot":"","sources":["function.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 logs = require('@aws-cdk/aws-logs');\nimport sqs = require('@aws-cdk/aws-sqs');\nimport cdk = require('@aws-cdk/cdk');\nimport { Code } from './code';\nimport { IEventSource } from './event-source';\nimport { FunctionBase, FunctionImportProps, IFunction } from './function-base';\nimport { Version } from './lambda-version';\nimport { CfnFunction } from './lambda.generated';\nimport { ILayerVersion } from './layers';\nimport { LogRetention } from './log-retention';\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  readonly code: Code;\n\n  /**\n   * A description of the function.\n   */\n  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly 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  readonly vpcSubnets?: ec2.SubnetSelection;\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  readonly 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  readonly 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  readonly 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  readonly deadLetterQueue?: sqs.IQueue;\n\n  /**\n   * Enable AWS X-Ray Tracing for Lambda Function.\n   *\n   * @default undefined X-Ray tracing disabled\n   */\n  readonly tracing?: Tracing;\n\n  /**\n   * A list of layers to add to the function's execution environment. You can configure your Lambda function to pull in\n   * additional code during initialization in the form of layers. Layers are packages of libraries or other dependencies\n   * that can be used by mulitple functions.\n   *\n   * @default no layers\n   */\n  readonly layers?: ILayerVersion[];\n\n  /**\n   * The maximum of concurrent executions you want to reserve for the function.\n   *\n   * @default no specific limit - account limit\n   * @see https://docs.aws.amazon.com/lambda/latest/dg/concurrent-executions.html\n   */\n  readonly reservedConcurrentExecutions?: number;\n\n  /**\n   * Event sources for this function.\n   *\n   * You can also add event sources using `addEventSource`.\n   */\n  readonly events?: IEventSource[];\n\n  /**\n   * The number of days log events are kept in CloudWatch Logs. When updating\n   * this property, unsetting it doesn't remove the log retention policy. To\n   * remove the retention policy, set the value to `Infinity`.\n   *\n   * @default logs never expire\n   */\n  readonly logRetentionDays?: logs.RetentionDays;\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  /**\n   * The principal this Lambda Function is running as\n   */\n  public readonly grantPrincipal: iam.IPrincipal;\n\n  protected readonly canCreatePermissions = true;\n\n  private readonly layers: ILayerVersion[] = [];\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    this.grantPrincipal = this.role;\n\n    for (const statement of (props.initialPolicy || [])) {\n      this.role.addToPolicy(statement);\n    }\n\n    const isChina = this.node.stack.env.region && this.node.stack.env.region.startsWith('cn-');\n    if (isChina && props.environment && Object.keys(props.environment).length > 0) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error(`Environment variables are not supported in this region (${this.node.stack.env.region}); consider using tags or SSM parameters instead`);\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      layers: new cdk.Token(() => this.layers.length > 0 ? this.layers.map(layer => layer.layerVersionArn) : undefined).toList(),\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      reservedConcurrentExecutions: props.reservedConcurrentExecutions\n    });\n\n    resource.node.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    for (const layer of props.layers || []) {\n      this.addLayer(layer);\n    }\n\n    for (const event of props.events || []) {\n      this.addEventSource(event);\n    }\n\n    // Log retention\n    if (props.logRetentionDays) {\n      new LogRetention(this, 'LogRetention', {\n        logGroupName: `/aws/lambda/${this.functionName}`,\n        retentionDays: props.logRetentionDays\n      });\n    }\n  }\n\n  /**\n   * Export this Function (without the role)\n   */\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.CfnOutput(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(),\n      securityGroupId: this._connections && this._connections.securityGroups[0]\n          ? new cdk.CfnOutput(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): this {\n    if (!this.environment) {\n      // TODO: add metadata\n      return this;\n    }\n    this.environment[key] = value;\n    return this;\n  }\n\n  /**\n   * Adds a Lambda Layer to this Lambda function.\n   *\n   * @param layer the layer to be added.\n   *\n   * @throws if there are already 5 layers on this function, or the layer is incompatible with this function's runtime.\n   */\n  public addLayer(layer: ILayerVersion): this {\n    if (this.layers.length === 5) {\n      throw new Error('Unable to add layer: this lambda function already uses 5 layers.');\n    }\n    if (layer.compatibleRuntimes && layer.compatibleRuntimes.indexOf(this.runtime) === -1) {\n      const runtimes = layer.compatibleRuntimes.map(runtime => runtime.name).join(', ');\n      throw new Error(`This lambda function uses a runtime that is incompatible with this layer (${this.runtime.name} is not in [${runtimes}])`);\n    }\n    this.layers.push(layer);\n    return this;\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  /**\n   * Add a new version for this Lambda, always with a different name.\n   *\n   * This is similar to the {@link addVersion} method,\n   * but useful when deploying this Lambda through CodePipeline with blue/green deployments.\n   * When using {@link addVersion},\n   * your Alias will not be updated until you change the name passed to {@link addVersion} in your CDK code.\n   * When deploying through a Pipeline,\n   * that might lead to a situation where a change to your Lambda application code will never be activated,\n   * even though it traveled through the entire Pipeline,\n   * because the Alias is still pointing to an old Version.\n   * This method creates a new, unique Version every time the CDK code is executed,\n   * and so prevents that from happening.\n   */\n  public newVersion(): Version {\n    const now = new Date();\n    return this.addVersion(now.toISOString());\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    // Why are we not simply forcing vpcSubnets? Because you might still be choosing\n    // Isolated networks or selecting among 2 sets of Private subnets by name.\n    const subnetIds = props.vpc.subnetIds(props.vpcSubnets);\n    const publicSubnetIds = new Set(props.vpc.publicSubnets.map(s => s.subnetId));\n    for (const subnetId of subnetIds) {\n      if (publicSubnetIds.has(subnetId)) {\n        throw new Error('Not possible to place Lambda Functions in a Public subnet');\n      }\n    }\n\n    // List can't be empty here, if we got this far you intended to put your Lambda\n    // in subnets. We're going to guarantee that we get the nice error message by\n    // making VpcNetwork do the selection again.\n\n    return {\n      subnetIds,\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 grantPrincipal: iam.IPrincipal;\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    this.grantPrincipal = this.role || new iam.ImportedResourcePrincipal({ resource: this } );\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}\n"]}

@@ -6,3 +6,2 @@ export * from './alias';

export * from './permission';
export * from './pipeline-action';
export * from './runtime';

@@ -9,0 +8,0 @@ export * from './code';

@@ -10,3 +10,2 @@ "use strict";

__export(require("./layers"));
__export(require("./pipeline-action"));
__export(require("./runtime"));

@@ -21,2 +20,2 @@ __export(require("./code"));

require("./lambda-augmentations.generated");
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZCQUF3QjtBQUN4QixxQ0FBZ0M7QUFDaEMsZ0NBQTJCO0FBQzNCLDhCQUF5QjtBQUV6Qix1Q0FBa0M7QUFDbEMsK0JBQTBCO0FBQzFCLDRCQUF1QjtBQUN2QixzQ0FBaUM7QUFDakMsd0NBQW1DO0FBRW5DLDRDQUF1QztBQUN2QyxxQ0FBZ0M7QUFFaEMsd0NBQXdDO0FBQ3hDLHdDQUFtQztBQUVuQyw0Q0FBMEMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FsaWFzJztcbmV4cG9ydCAqIGZyb20gJy4vZnVuY3Rpb24tYmFzZSc7XG5leHBvcnQgKiBmcm9tICcuL2Z1bmN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vbGF5ZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vcGVybWlzc2lvbic7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVsaW5lLWFjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3J1bnRpbWUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2RlJztcbmV4cG9ydCAqIGZyb20gJy4vbGFtYmRhLXZlcnNpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9zaW5nbGV0b24tbGFtYmRhJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnQtc291cmNlJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnQtc291cmNlLW1hcHBpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2ctcmV0ZW50aW9uJztcblxuLy8gQVdTOjpMYW1iZGEgQ2xvdWRGb3JtYXRpb24gUmVzb3VyY2VzOlxuZXhwb3J0ICogZnJvbSAnLi9sYW1iZGEuZ2VuZXJhdGVkJztcblxuaW1wb3J0ICcuL2xhbWJkYS1hdWdtZW50YXRpb25zLmdlbmVyYXRlZCc7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZCQUF3QjtBQUN4QixxQ0FBZ0M7QUFDaEMsZ0NBQTJCO0FBQzNCLDhCQUF5QjtBQUV6QiwrQkFBMEI7QUFDMUIsNEJBQXVCO0FBQ3ZCLHNDQUFpQztBQUNqQyx3Q0FBbUM7QUFFbkMsNENBQXVDO0FBQ3ZDLHFDQUFnQztBQUVoQyx3Q0FBd0M7QUFDeEMsd0NBQW1DO0FBRW5DLDRDQUEwQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWxpYXMnO1xuZXhwb3J0ICogZnJvbSAnLi9mdW5jdGlvbi1iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vZnVuY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9sYXllcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9wZXJtaXNzaW9uJztcbmV4cG9ydCAqIGZyb20gJy4vcnVudGltZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvZGUnO1xuZXhwb3J0ICogZnJvbSAnLi9sYW1iZGEtdmVyc2lvbic7XG5leHBvcnQgKiBmcm9tICcuL3NpbmdsZXRvbi1sYW1iZGEnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudC1zb3VyY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudC1zb3VyY2UtbWFwcGluZyc7XG5leHBvcnQgKiBmcm9tICcuL2xvZy1yZXRlbnRpb24nO1xuXG4vLyBBV1M6OkxhbWJkYSBDbG91ZEZvcm1hdGlvbiBSZXNvdXJjZXM6XG5leHBvcnQgKiBmcm9tICcuL2xhbWJkYS5nZW5lcmF0ZWQnO1xuXG5pbXBvcnQgJy4vbGFtYmRhLWF1Z21lbnRhdGlvbnMuZ2VuZXJhdGVkJztcbiJdfQ==

@@ -1,2 +0,2 @@

import { PolicyPrincipal } from '@aws-cdk/aws-iam';
import iam = require('@aws-cdk/aws-iam');
/**

@@ -34,3 +34,3 @@ * Represents a permission statement that can be added to a Lambda's resource policy

*/
readonly principal: PolicyPrincipal;
readonly principal: iam.IPrincipal;
/**

@@ -37,0 +37,0 @@ * The AWS account ID (without hyphens) of the source owner. For example, if

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVybWlzc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInBlcm1pc3Npb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBvbGljeVByaW5jaXBhbCB9IGZyb20gJ0Bhd3MtY2RrL2F3cy1pYW0nO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBwZXJtaXNzaW9uIHN0YXRlbWVudCB0aGF0IGNhbiBiZSBhZGRlZCB0byBhIExhbWJkYSdzIHJlc291cmNlIHBvbGljeVxuICogdmlhIHRoZSBgYWRkVG9SZXNvdXJjZVBvbGljeWAgbWV0aG9kLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBlcm1pc3Npb24ge1xuICAvKipcbiAgICogVGhlIExhbWJkYSBhY3Rpb25zIHRoYXQgeW91IHdhbnQgdG8gYWxsb3cgaW4gdGhpcyBzdGF0ZW1lbnQuIEZvciBleGFtcGxlLFxuICAgKiB5b3UgY2FuIHNwZWNpZnkgbGFtYmRhOkNyZWF0ZUZ1bmN0aW9uIHRvIHNwZWNpZnkgYSBjZXJ0YWluIGFjdGlvbiwgb3IgdXNlXG4gICAqIGEgd2lsZGNhcmQgKGBgbGFtYmRhOipgYCkgdG8gZ3JhbnQgcGVybWlzc2lvbiB0byBhbGwgTGFtYmRhIGFjdGlvbnMuIEZvciBhXG4gICAqIGxpc3Qgb2YgYWN0aW9ucywgc2VlIEFjdGlvbnMgYW5kIENvbmRpdGlvbiBDb250ZXh0IEtleXMgZm9yIEFXUyBMYW1iZGEgaW5cbiAgICogdGhlIElBTSBVc2VyIEd1aWRlLlxuICAgKlxuICAgKiBAZGVmYXVsdCAnbGFtYmRhOkludm9rZUZ1bmN0aW9uJ1xuICAgKi9cbiAgcmVhZG9ubHkgYWN0aW9uPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBIHVuaXF1ZSB0b2tlbiB0aGF0IG11c3QgYmUgc3VwcGxpZWQgYnkgdGhlIHByaW5jaXBhbCBpbnZva2luZyB0aGVcbiAgICogZnVuY3Rpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0IFRoZSBjYWxsZXIgd291bGQgbm90IG5lZWQgdG8gcHJlc2VudCBhIHRva2VuLlxuICAgKi9cbiAgcmVhZG9ubHkgZXZlbnRTb3VyY2VUb2tlbj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIGVudGl0eSBmb3Igd2hpY2ggeW91IGFyZSBncmFudGluZyBwZXJtaXNzaW9uIHRvIGludm9rZSB0aGUgTGFtYmRhXG4gICAqIGZ1bmN0aW9uLiBUaGlzIGVudGl0eSBjYW4gYmUgYW55IHZhbGlkIEFXUyBzZXJ2aWNlIHByaW5jaXBhbCwgc3VjaCBhc1xuICAgKiBzMy5hbWF6b25hd3MuY29tIG9yIHNucy5hbWF6b25hd3MuY29tLCBvciwgaWYgeW91IGFyZSBncmFudGluZ1xuICAgKiBjcm9zcy1hY2NvdW50IHBlcm1pc3Npb24sIGFuIEFXUyBhY2NvdW50IElELiBGb3IgZXhhbXBsZSwgeW91IG1pZ2h0IHdhbnRcbiAgICogdG8gYWxsb3cgYSBjdXN0b20gYXBwbGljYXRpb24gaW4gYW5vdGhlciBBV1MgYWNjb3VudCB0byBwdXNoIGV2ZW50cyB0b1xuICAgKiBMYW1iZGEgYnkgaW52b2tpbmcgeW91ciBmdW5jdGlvbi5cbiAgICpcbiAgICogVGhlIHByaW5jaXBhbCBjYW4gYmUgZWl0aGVyIGFuIEFjY291bnRQcmluY2lwYWwgb3IgYSBTZXJ2aWNlUHJpbmNpcGFsLlxuICAgKi9cbiAgcmVhZG9ubHkgcHJpbmNpcGFsOiBQb2xpY3lQcmluY2lwYWw7XG5cbiAgLyoqXG4gICAqIFRoZSBBV1MgYWNjb3VudCBJRCAod2l0aG91dCBoeXBoZW5zKSBvZiB0aGUgc291cmNlIG93bmVyLiBGb3IgZXhhbXBsZSwgaWZcbiAgICogeW91IHNwZWNpZnkgYW4gUzMgYnVja2V0IGluIHRoZSBTb3VyY2VBcm4gcHJvcGVydHksIHRoaXMgdmFsdWUgaXMgdGhlXG4gICAqIGJ1Y2tldCBvd25lcidzIGFjY291bnQgSUQuIFlvdSBjYW4gdXNlIHRoaXMgcHJvcGVydHkgdG8gZW5zdXJlIHRoYXQgYWxsXG4gICAqIHNvdXJjZSBwcmluY2lwYWxzIGFyZSBvd25lZCBieSBhIHNwZWNpZmljIGFjY291bnQuXG4gICAqL1xuICByZWFkb25seSBzb3VyY2VBY2NvdW50Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQVJOIG9mIGEgcmVzb3VyY2UgdGhhdCBpcyBpbnZva2luZyB5b3VyIGZ1bmN0aW9uLiBXaGVuIGdyYW50aW5nXG4gICAqIEFtYXpvbiBTaW1wbGUgU3RvcmFnZSBTZXJ2aWNlIChBbWF6b24gUzMpIHBlcm1pc3Npb24gdG8gaW52b2tlIHlvdXJcbiAgICogZnVuY3Rpb24sIHNwZWNpZnkgdGhpcyBwcm9wZXJ0eSB3aXRoIHRoZSBidWNrZXQgQVJOIGFzIGl0cyB2YWx1ZS4gVGhpc1xuICAgKiBlbnN1cmVzIHRoYXQgZXZlbnRzIGdlbmVyYXRlZCBvbmx5IGZyb20gdGhlIHNwZWNpZmllZCBidWNrZXQsIG5vdCBqdXN0XG4gICAqIGFueSBidWNrZXQgZnJvbSBhbnkgQVdTIGFjY291bnQgdGhhdCBjcmVhdGVzIGEgbWFwcGluZyB0byB5b3VyIGZ1bmN0aW9uLFxuICAgKiBjYW4gaW52b2tlIHRoZSBmdW5jdGlvbi5cbiAgICovXG4gIHJlYWRvbmx5IHNvdXJjZUFybj86IHN0cmluZztcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVybWlzc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInBlcm1pc3Npb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBpYW0gPSByZXF1aXJlKCdAYXdzLWNkay9hd3MtaWFtJyk7XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHBlcm1pc3Npb24gc3RhdGVtZW50IHRoYXQgY2FuIGJlIGFkZGVkIHRvIGEgTGFtYmRhJ3MgcmVzb3VyY2UgcG9saWN5XG4gKiB2aWEgdGhlIGBhZGRUb1Jlc291cmNlUG9saWN5YCBtZXRob2QuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUGVybWlzc2lvbiB7XG4gIC8qKlxuICAgKiBUaGUgTGFtYmRhIGFjdGlvbnMgdGhhdCB5b3Ugd2FudCB0byBhbGxvdyBpbiB0aGlzIHN0YXRlbWVudC4gRm9yIGV4YW1wbGUsXG4gICAqIHlvdSBjYW4gc3BlY2lmeSBsYW1iZGE6Q3JlYXRlRnVuY3Rpb24gdG8gc3BlY2lmeSBhIGNlcnRhaW4gYWN0aW9uLCBvciB1c2VcbiAgICogYSB3aWxkY2FyZCAoYGBsYW1iZGE6KmBgKSB0byBncmFudCBwZXJtaXNzaW9uIHRvIGFsbCBMYW1iZGEgYWN0aW9ucy4gRm9yIGFcbiAgICogbGlzdCBvZiBhY3Rpb25zLCBzZWUgQWN0aW9ucyBhbmQgQ29uZGl0aW9uIENvbnRleHQgS2V5cyBmb3IgQVdTIExhbWJkYSBpblxuICAgKiB0aGUgSUFNIFVzZXIgR3VpZGUuXG4gICAqXG4gICAqIEBkZWZhdWx0ICdsYW1iZGE6SW52b2tlRnVuY3Rpb24nXG4gICAqL1xuICByZWFkb25seSBhY3Rpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgdW5pcXVlIHRva2VuIHRoYXQgbXVzdCBiZSBzdXBwbGllZCBieSB0aGUgcHJpbmNpcGFsIGludm9raW5nIHRoZVxuICAgKiBmdW5jdGlvbi5cbiAgICpcbiAgICogQGRlZmF1bHQgVGhlIGNhbGxlciB3b3VsZCBub3QgbmVlZCB0byBwcmVzZW50IGEgdG9rZW4uXG4gICAqL1xuICByZWFkb25seSBldmVudFNvdXJjZVRva2VuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgZW50aXR5IGZvciB3aGljaCB5b3UgYXJlIGdyYW50aW5nIHBlcm1pc3Npb24gdG8gaW52b2tlIHRoZSBMYW1iZGFcbiAgICogZnVuY3Rpb24uIFRoaXMgZW50aXR5IGNhbiBiZSBhbnkgdmFsaWQgQVdTIHNlcnZpY2UgcHJpbmNpcGFsLCBzdWNoIGFzXG4gICAqIHMzLmFtYXpvbmF3cy5jb20gb3Igc25zLmFtYXpvbmF3cy5jb20sIG9yLCBpZiB5b3UgYXJlIGdyYW50aW5nXG4gICAqIGNyb3NzLWFjY291bnQgcGVybWlzc2lvbiwgYW4gQVdTIGFjY291bnQgSUQuIEZvciBleGFtcGxlLCB5b3UgbWlnaHQgd2FudFxuICAgKiB0byBhbGxvdyBhIGN1c3RvbSBhcHBsaWNhdGlvbiBpbiBhbm90aGVyIEFXUyBhY2NvdW50IHRvIHB1c2ggZXZlbnRzIHRvXG4gICAqIExhbWJkYSBieSBpbnZva2luZyB5b3VyIGZ1bmN0aW9uLlxuICAgKlxuICAgKiBUaGUgcHJpbmNpcGFsIGNhbiBiZSBlaXRoZXIgYW4gQWNjb3VudFByaW5jaXBhbCBvciBhIFNlcnZpY2VQcmluY2lwYWwuXG4gICAqL1xuICByZWFkb25seSBwcmluY2lwYWw6IGlhbS5JUHJpbmNpcGFsO1xuXG4gIC8qKlxuICAgKiBUaGUgQVdTIGFjY291bnQgSUQgKHdpdGhvdXQgaHlwaGVucykgb2YgdGhlIHNvdXJjZSBvd25lci4gRm9yIGV4YW1wbGUsIGlmXG4gICAqIHlvdSBzcGVjaWZ5IGFuIFMzIGJ1Y2tldCBpbiB0aGUgU291cmNlQXJuIHByb3BlcnR5LCB0aGlzIHZhbHVlIGlzIHRoZVxuICAgKiBidWNrZXQgb3duZXIncyBhY2NvdW50IElELiBZb3UgY2FuIHVzZSB0aGlzIHByb3BlcnR5IHRvIGVuc3VyZSB0aGF0IGFsbFxuICAgKiBzb3VyY2UgcHJpbmNpcGFscyBhcmUgb3duZWQgYnkgYSBzcGVjaWZpYyBhY2NvdW50LlxuICAgKi9cbiAgcmVhZG9ubHkgc291cmNlQWNjb3VudD86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIEFSTiBvZiBhIHJlc291cmNlIHRoYXQgaXMgaW52b2tpbmcgeW91ciBmdW5jdGlvbi4gV2hlbiBncmFudGluZ1xuICAgKiBBbWF6b24gU2ltcGxlIFN0b3JhZ2UgU2VydmljZSAoQW1hem9uIFMzKSBwZXJtaXNzaW9uIHRvIGludm9rZSB5b3VyXG4gICAqIGZ1bmN0aW9uLCBzcGVjaWZ5IHRoaXMgcHJvcGVydHkgd2l0aCB0aGUgYnVja2V0IEFSTiBhcyBpdHMgdmFsdWUuIFRoaXNcbiAgICogZW5zdXJlcyB0aGF0IGV2ZW50cyBnZW5lcmF0ZWQgb25seSBmcm9tIHRoZSBzcGVjaWZpZWQgYnVja2V0LCBub3QganVzdFxuICAgKiBhbnkgYnVja2V0IGZyb20gYW55IEFXUyBhY2NvdW50IHRoYXQgY3JlYXRlcyBhIG1hcHBpbmcgdG8geW91ciBmdW5jdGlvbixcbiAgICogY2FuIGludm9rZSB0aGUgZnVuY3Rpb24uXG4gICAqL1xuICByZWFkb25seSBzb3VyY2VBcm4/OiBzdHJpbmc7XG59XG4iXX0=

@@ -35,5 +35,6 @@ import iam = require('@aws-cdk/aws-iam');

export declare class SingletonFunction extends FunctionBase {
readonly grantPrincipal: iam.IPrincipal;
readonly functionName: string;
readonly functionArn: string;
readonly role?: iam.IRole | undefined;
readonly role?: iam.IRole;
protected readonly canCreatePermissions: boolean;

@@ -40,0 +41,0 @@ private lambdaFunction;

@@ -18,2 +18,3 @@ "use strict";

this.role = this.lambdaFunction.role;
this.grantPrincipal = this.lambdaFunction.grantPrincipal;
this.canCreatePermissions = true; // Doesn't matter, addPermission is overriden anyway

@@ -41,2 +42,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xldG9uLWxhbWJkYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpbmdsZXRvbi1sYW1iZGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSx5Q0FBdUU7QUFDdkUsbURBQStFO0FBMkIvRTs7Ozs7R0FLRztBQUNILE1BQWEsaUJBQWtCLFNBQVEsNEJBQVk7SUFPakQsWUFBWSxLQUFvQixFQUFFLEVBQVUsRUFBRSxLQUE2QjtRQUN6RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUUvQyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO1FBQ25ELElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUM7UUFDckQsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztRQUVyQyxJQUFJLENBQUMsb0JBQW9CLEdBQUcsSUFBSSxDQUFDLENBQUMsb0RBQW9EO0lBQ3hGLENBQUM7SUFFTSxNQUFNO1FBQ1gsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ3RDLENBQUM7SUFFTSxhQUFhLENBQUMsSUFBWSxFQUFFLFVBQXNCO1FBQ3ZELE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFTyxZQUFZLENBQUMsS0FBNkI7UUFDaEQsTUFBTSxhQUFhLEdBQUcsQ0FBQyxLQUFLLENBQUMsYUFBYSxJQUFJLGlCQUFpQixDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN2RixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2xFLElBQUksUUFBUSxFQUFFO1lBQ1osMkJBQTJCO1lBQzNCLE9BQU8sUUFBd0IsQ0FBQztTQUNqQztRQUVELE9BQU8sSUFBSSxtQkFBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLGFBQWEsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNuRSxDQUFDO0NBQ0Y7QUFyQ0QsOENBcUNDO0FBRUQsU0FBUyxPQUFPLENBQUMsQ0FBUztJQUN4QixPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaWFtID0gcmVxdWlyZSgnQGF3cy1jZGsvYXdzLWlhbScpO1xuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IHsgRnVuY3Rpb24gYXMgTGFtYmRhRnVuY3Rpb24sIEZ1bmN0aW9uUHJvcHMgfSBmcm9tICcuL2Z1bmN0aW9uJztcbmltcG9ydCB7IEZ1bmN0aW9uQmFzZSwgRnVuY3Rpb25JbXBvcnRQcm9wcywgSUZ1bmN0aW9uIH0gZnJvbSAnLi9mdW5jdGlvbi1iYXNlJztcbmltcG9ydCB7IFBlcm1pc3Npb24gfSBmcm9tICcuL3Blcm1pc3Npb24nO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGEgbmV3bHkgY3JlYXRlZCBzaW5nbGV0b24gTGFtYmRhXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2luZ2xldG9uRnVuY3Rpb25Qcm9wcyBleHRlbmRzIEZ1bmN0aW9uUHJvcHMge1xuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciB0byBpZGVudGlmeSB0aGlzIGxhbWJkYVxuICAgKlxuICAgKiBUaGUgaWRlbnRpZmllciBzaG91bGQgYmUgdW5pcXVlIGFjcm9zcyBhbGwgY3VzdG9tIHJlc291cmNlIHByb3ZpZGVycy5cbiAgICogV2UgcmVjb21tZW5kIGdlbmVyYXRpbmcgYSBVVUlEIHBlciBwcm92aWRlci5cbiAgICovXG4gIHJlYWRvbmx5IHV1aWQ6IHN0cmluZztcblxuICAvKipcbiAgICogQSBkZXNjcmlwdGl2ZSBuYW1lIGZvciB0aGUgcHVycG9zZSBvZiB0aGlzIExhbWJkYS5cbiAgICpcbiAgICogSWYgdGhlIExhbWJkYSBkb2VzIG5vdCBoYXZlIGEgcGh5c2ljYWwgbmFtZSwgdGhpcyBzdHJpbmcgd2lsbCBiZVxuICAgKiByZWZsZWN0ZWQgaXRzIGdlbmVyYXRlZCBuYW1lLiBUaGUgY29tYmluYXRpb24gb2YgbGFtYmRhUHVycG9zZVxuICAgKiBhbmQgdXVpZCBtdXN0IGJlIHVuaXF1ZS5cbiAgICpcbiAgICogQGRlZmF1bHQgU2luZ2xldG9uTGFtYmRhXG4gICAqL1xuICByZWFkb25seSBsYW1iZGFQdXJwb3NlPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEEgTGFtYmRhIHRoYXQgd2lsbCBvbmx5IGV2ZXIgYmUgYWRkZWQgdG8gYSBzdGFjayBvbmNlLlxuICpcbiAqIFRoZSBsYW1iZGEgaXMgaWRlbnRpZmllZCB1c2luZyB0aGUgdmFsdWUgb2YgJ3V1aWQnLiBSdW4gJ3V1aWRnZW4nXG4gKiBmb3IgZXZlcnkgU2luZ2xldG9uTGFtYmRhIHlvdSBjcmVhdGUuXG4gKi9cbmV4cG9ydCBjbGFzcyBTaW5nbGV0b25GdW5jdGlvbiBleHRlbmRzIEZ1bmN0aW9uQmFzZSB7XG4gIHB1YmxpYyByZWFkb25seSBmdW5jdGlvbk5hbWU6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IGZ1bmN0aW9uQXJuOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSByb2xlPzogaWFtLklSb2xlIHwgdW5kZWZpbmVkO1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgY2FuQ3JlYXRlUGVybWlzc2lvbnM6IGJvb2xlYW47XG4gIHByaXZhdGUgbGFtYmRhRnVuY3Rpb246IElGdW5jdGlvbjtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5sYW1iZGFGdW5jdGlvbiA9IHRoaXMuZW5zdXJlTGFtYmRhKHByb3BzKTtcblxuICAgIHRoaXMuZnVuY3Rpb25Bcm4gPSB0aGlzLmxhbWJkYUZ1bmN0aW9uLmZ1bmN0aW9uQXJuO1xuICAgIHRoaXMuZnVuY3Rpb25OYW1lID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5mdW5jdGlvbk5hbWU7XG4gICAgdGhpcy5yb2xlID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5yb2xlO1xuXG4gICAgdGhpcy5jYW5DcmVhdGVQZXJtaXNzaW9ucyA9IHRydWU7IC8vIERvZXNuJ3QgbWF0dGVyLCBhZGRQZXJtaXNzaW9uIGlzIG92ZXJyaWRlbiBhbnl3YXlcbiAgfVxuXG4gIHB1YmxpYyBleHBvcnQoKTogRnVuY3Rpb25JbXBvcnRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMubGFtYmRhRnVuY3Rpb24uZXhwb3J0KCk7XG4gIH1cblxuICBwdWJsaWMgYWRkUGVybWlzc2lvbihuYW1lOiBzdHJpbmcsIHBlcm1pc3Npb246IFBlcm1pc3Npb24pIHtcbiAgICByZXR1cm4gdGhpcy5sYW1iZGFGdW5jdGlvbi5hZGRQZXJtaXNzaW9uKG5hbWUsIHBlcm1pc3Npb24pO1xuICB9XG5cbiAgcHJpdmF0ZSBlbnN1cmVMYW1iZGEocHJvcHM6IFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMpOiBJRnVuY3Rpb24ge1xuICAgIGNvbnN0IGNvbnN0cnVjdE5hbWUgPSAocHJvcHMubGFtYmRhUHVycG9zZSB8fCAnU2luZ2xldG9uTGFtYmRhJykgKyBzbHVnaWZ5KHByb3BzLnV1aWQpO1xuICAgIGNvbnN0IGV4aXN0aW5nID0gdGhpcy5ub2RlLnN0YWNrLm5vZGUudHJ5RmluZENoaWxkKGNvbnN0cnVjdE5hbWUpO1xuICAgIGlmIChleGlzdGluZykge1xuICAgICAgLy8gSnVzdCBhc3N1bWUgdGhpcyBpcyB0cnVlXG4gICAgICByZXR1cm4gZXhpc3RpbmcgYXMgRnVuY3Rpb25CYXNlO1xuICAgIH1cblxuICAgIHJldHVybiBuZXcgTGFtYmRhRnVuY3Rpb24odGhpcy5ub2RlLnN0YWNrLCBjb25zdHJ1Y3ROYW1lLCBwcm9wcyk7XG4gIH1cbn1cblxuZnVuY3Rpb24gc2x1Z2lmeSh4OiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4geC5yZXBsYWNlKC9bXmEtekEtWjAtOV0vZywgJycpO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xldG9uLWxhbWJkYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpbmdsZXRvbi1sYW1iZGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSx5Q0FBdUU7QUFDdkUsbURBQStFO0FBMkIvRTs7Ozs7R0FLRztBQUNILE1BQWEsaUJBQWtCLFNBQVEsNEJBQVk7SUFRakQsWUFBWSxLQUFvQixFQUFFLEVBQVUsRUFBRSxLQUE2QjtRQUN6RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUUvQyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO1FBQ25ELElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUM7UUFDckQsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztRQUNyQyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsY0FBYyxDQUFDO1FBRXpELElBQUksQ0FBQyxvQkFBb0IsR0FBRyxJQUFJLENBQUMsQ0FBQyxvREFBb0Q7SUFDeEYsQ0FBQztJQUVNLE1BQU07UUFDWCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDdEMsQ0FBQztJQUVNLGFBQWEsQ0FBQyxJQUFZLEVBQUUsVUFBc0I7UUFDdkQsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVPLFlBQVksQ0FBQyxLQUE2QjtRQUNoRCxNQUFNLGFBQWEsR0FBRyxDQUFDLEtBQUssQ0FBQyxhQUFhLElBQUksaUJBQWlCLENBQUMsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3ZGLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDbEUsSUFBSSxRQUFRLEVBQUU7WUFDWiwyQkFBMkI7WUFDM0IsT0FBTyxRQUF3QixDQUFDO1NBQ2pDO1FBRUQsT0FBTyxJQUFJLG1CQUFjLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsYUFBYSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ25FLENBQUM7Q0FDRjtBQXZDRCw4Q0F1Q0M7QUFFRCxTQUFTLE9BQU8sQ0FBQyxDQUFTO0lBQ3hCLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDeEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBpYW0gPSByZXF1aXJlKCdAYXdzLWNkay9hd3MtaWFtJyk7XG5pbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBGdW5jdGlvbiBhcyBMYW1iZGFGdW5jdGlvbiwgRnVuY3Rpb25Qcm9wcyB9IGZyb20gJy4vZnVuY3Rpb24nO1xuaW1wb3J0IHsgRnVuY3Rpb25CYXNlLCBGdW5jdGlvbkltcG9ydFByb3BzLCBJRnVuY3Rpb24gfSBmcm9tICcuL2Z1bmN0aW9uLWJhc2UnO1xuaW1wb3J0IHsgUGVybWlzc2lvbiB9IGZyb20gJy4vcGVybWlzc2lvbic7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgYSBuZXdseSBjcmVhdGVkIHNpbmdsZXRvbiBMYW1iZGFcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTaW5nbGV0b25GdW5jdGlvblByb3BzIGV4dGVuZHMgRnVuY3Rpb25Qcm9wcyB7XG4gIC8qKlxuICAgKiBBIHVuaXF1ZSBpZGVudGlmaWVyIHRvIGlkZW50aWZ5IHRoaXMgbGFtYmRhXG4gICAqXG4gICAqIFRoZSBpZGVudGlmaWVyIHNob3VsZCBiZSB1bmlxdWUgYWNyb3NzIGFsbCBjdXN0b20gcmVzb3VyY2UgcHJvdmlkZXJzLlxuICAgKiBXZSByZWNvbW1lbmQgZ2VuZXJhdGluZyBhIFVVSUQgcGVyIHByb3ZpZGVyLlxuICAgKi9cbiAgcmVhZG9ubHkgdXVpZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBIGRlc2NyaXB0aXZlIG5hbWUgZm9yIHRoZSBwdXJwb3NlIG9mIHRoaXMgTGFtYmRhLlxuICAgKlxuICAgKiBJZiB0aGUgTGFtYmRhIGRvZXMgbm90IGhhdmUgYSBwaHlzaWNhbCBuYW1lLCB0aGlzIHN0cmluZyB3aWxsIGJlXG4gICAqIHJlZmxlY3RlZCBpdHMgZ2VuZXJhdGVkIG5hbWUuIFRoZSBjb21iaW5hdGlvbiBvZiBsYW1iZGFQdXJwb3NlXG4gICAqIGFuZCB1dWlkIG11c3QgYmUgdW5pcXVlLlxuICAgKlxuICAgKiBAZGVmYXVsdCBTaW5nbGV0b25MYW1iZGFcbiAgICovXG4gIHJlYWRvbmx5IGxhbWJkYVB1cnBvc2U/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQSBMYW1iZGEgdGhhdCB3aWxsIG9ubHkgZXZlciBiZSBhZGRlZCB0byBhIHN0YWNrIG9uY2UuXG4gKlxuICogVGhlIGxhbWJkYSBpcyBpZGVudGlmaWVkIHVzaW5nIHRoZSB2YWx1ZSBvZiAndXVpZCcuIFJ1biAndXVpZGdlbidcbiAqIGZvciBldmVyeSBTaW5nbGV0b25MYW1iZGEgeW91IGNyZWF0ZS5cbiAqL1xuZXhwb3J0IGNsYXNzIFNpbmdsZXRvbkZ1bmN0aW9uIGV4dGVuZHMgRnVuY3Rpb25CYXNlIHtcbiAgcHVibGljIHJlYWRvbmx5IGdyYW50UHJpbmNpcGFsOiBpYW0uSVByaW5jaXBhbDtcbiAgcHVibGljIHJlYWRvbmx5IGZ1bmN0aW9uTmFtZTogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgZnVuY3Rpb25Bcm46IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IHJvbGU/OiBpYW0uSVJvbGU7XG4gIHByb3RlY3RlZCByZWFkb25seSBjYW5DcmVhdGVQZXJtaXNzaW9uczogYm9vbGVhbjtcbiAgcHJpdmF0ZSBsYW1iZGFGdW5jdGlvbjogSUZ1bmN0aW9uO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBjZGsuQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU2luZ2xldG9uRnVuY3Rpb25Qcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICB0aGlzLmxhbWJkYUZ1bmN0aW9uID0gdGhpcy5lbnN1cmVMYW1iZGEocHJvcHMpO1xuXG4gICAgdGhpcy5mdW5jdGlvbkFybiA9IHRoaXMubGFtYmRhRnVuY3Rpb24uZnVuY3Rpb25Bcm47XG4gICAgdGhpcy5mdW5jdGlvbk5hbWUgPSB0aGlzLmxhbWJkYUZ1bmN0aW9uLmZ1bmN0aW9uTmFtZTtcbiAgICB0aGlzLnJvbGUgPSB0aGlzLmxhbWJkYUZ1bmN0aW9uLnJvbGU7XG4gICAgdGhpcy5ncmFudFByaW5jaXBhbCA9IHRoaXMubGFtYmRhRnVuY3Rpb24uZ3JhbnRQcmluY2lwYWw7XG5cbiAgICB0aGlzLmNhbkNyZWF0ZVBlcm1pc3Npb25zID0gdHJ1ZTsgLy8gRG9lc24ndCBtYXR0ZXIsIGFkZFBlcm1pc3Npb24gaXMgb3ZlcnJpZGVuIGFueXdheVxuICB9XG5cbiAgcHVibGljIGV4cG9ydCgpOiBGdW5jdGlvbkltcG9ydFByb3BzIHtcbiAgICByZXR1cm4gdGhpcy5sYW1iZGFGdW5jdGlvbi5leHBvcnQoKTtcbiAgfVxuXG4gIHB1YmxpYyBhZGRQZXJtaXNzaW9uKG5hbWU6IHN0cmluZywgcGVybWlzc2lvbjogUGVybWlzc2lvbikge1xuICAgIHJldHVybiB0aGlzLmxhbWJkYUZ1bmN0aW9uLmFkZFBlcm1pc3Npb24obmFtZSwgcGVybWlzc2lvbik7XG4gIH1cblxuICBwcml2YXRlIGVuc3VyZUxhbWJkYShwcm9wczogU2luZ2xldG9uRnVuY3Rpb25Qcm9wcyk6IElGdW5jdGlvbiB7XG4gICAgY29uc3QgY29uc3RydWN0TmFtZSA9IChwcm9wcy5sYW1iZGFQdXJwb3NlIHx8ICdTaW5nbGV0b25MYW1iZGEnKSArIHNsdWdpZnkocHJvcHMudXVpZCk7XG4gICAgY29uc3QgZXhpc3RpbmcgPSB0aGlzLm5vZGUuc3RhY2subm9kZS50cnlGaW5kQ2hpbGQoY29uc3RydWN0TmFtZSk7XG4gICAgaWYgKGV4aXN0aW5nKSB7XG4gICAgICAvLyBKdXN0IGFzc3VtZSB0aGlzIGlzIHRydWVcbiAgICAgIHJldHVybiBleGlzdGluZyBhcyBGdW5jdGlvbkJhc2U7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBMYW1iZGFGdW5jdGlvbih0aGlzLm5vZGUuc3RhY2ssIGNvbnN0cnVjdE5hbWUsIHByb3BzKTtcbiAgfVxufVxuXG5mdW5jdGlvbiBzbHVnaWZ5KHg6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiB4LnJlcGxhY2UoL1teYS16QS1aMC05XS9nLCAnJyk7XG59XG4iXX0=
{
"name": "@aws-cdk/aws-lambda",
"version": "0.27.0",
"version": "0.28.0",
"description": "CDK Constructs for AWS Lambda",

@@ -65,3 +65,3 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^0.27.0",
"@aws-cdk/assert": "^0.28.0",
"@types/aws-lambda": "^8.10.23",

@@ -72,42 +72,45 @@ "@types/nock": "^9.3.1",

"aws-sdk-mock": "^4.3.1",
"cdk-build-tools": "^0.27.0",
"cdk-integ-tools": "^0.27.0",
"cfn2ts": "^0.27.0",
"cdk-build-tools": "^0.28.0",
"cdk-integ-tools": "^0.28.0",
"cfn2ts": "^0.28.0",
"nock": "^10.0.6",
"pkglint": "^0.27.0",
"pkglint": "^0.28.0",
"sinon": "^7.3.0"
},
"dependencies": {
"@aws-cdk/assets": "^0.27.0",
"@aws-cdk/aws-cloudwatch": "^0.27.0",
"@aws-cdk/aws-codepipeline-api": "^0.27.0",
"@aws-cdk/aws-ec2": "^0.27.0",
"@aws-cdk/aws-events": "^0.27.0",
"@aws-cdk/aws-iam": "^0.27.0",
"@aws-cdk/aws-logs": "^0.27.0",
"@aws-cdk/aws-s3": "^0.27.0",
"@aws-cdk/aws-s3-notifications": "^0.27.0",
"@aws-cdk/aws-sqs": "^0.27.0",
"@aws-cdk/aws-stepfunctions": "^0.27.0",
"@aws-cdk/cdk": "^0.27.0",
"@aws-cdk/cx-api": "^0.27.0"
"@aws-cdk/assets": "^0.28.0",
"@aws-cdk/aws-cloudwatch": "^0.28.0",
"@aws-cdk/aws-ec2": "^0.28.0",
"@aws-cdk/aws-events": "^0.28.0",
"@aws-cdk/aws-iam": "^0.28.0",
"@aws-cdk/aws-logs": "^0.28.0",
"@aws-cdk/aws-s3": "^0.28.0",
"@aws-cdk/aws-s3-notifications": "^0.28.0",
"@aws-cdk/aws-sqs": "^0.28.0",
"@aws-cdk/aws-stepfunctions": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0",
"@aws-cdk/cx-api": "^0.28.0"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/assets": "^0.27.0",
"@aws-cdk/aws-cloudwatch": "^0.27.0",
"@aws-cdk/aws-codepipeline-api": "^0.27.0",
"@aws-cdk/aws-ec2": "^0.27.0",
"@aws-cdk/aws-events": "^0.27.0",
"@aws-cdk/aws-iam": "^0.27.0",
"@aws-cdk/aws-logs": "^0.27.0",
"@aws-cdk/aws-s3": "^0.27.0",
"@aws-cdk/aws-s3-notifications": "^0.27.0",
"@aws-cdk/aws-sqs": "^0.27.0",
"@aws-cdk/aws-stepfunctions": "^0.27.0",
"@aws-cdk/cdk": "^0.27.0"
"@aws-cdk/assets": "^0.28.0",
"@aws-cdk/aws-cloudwatch": "^0.28.0",
"@aws-cdk/aws-ec2": "^0.28.0",
"@aws-cdk/aws-events": "^0.28.0",
"@aws-cdk/aws-iam": "^0.28.0",
"@aws-cdk/aws-logs": "^0.28.0",
"@aws-cdk/aws-s3": "^0.28.0",
"@aws-cdk/aws-s3-notifications": "^0.28.0",
"@aws-cdk/aws-sqs": "^0.28.0",
"@aws-cdk/aws-stepfunctions": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0"
},
"engines": {
"node": ">= 8.10.0"
},
"awslint": {
"exclude": [
"grant-result:@aws-cdk/aws-lambda.LayerVersionBase.grantUsage"
]
}
}

@@ -75,50 +75,2 @@ ## AWS Lambda Construct Library

### Lambda in CodePipeline
This module also contains an Action that allows you to invoke a Lambda function from CodePipeline:
```ts
import codepipeline = require('@aws-cdk/aws-codepipeline');
const pipeline = new codepipeline.Pipeline(this, 'MyPipeline');
const lambdaAction = new lambda.PipelineInvokeAction({
actionName: 'Lambda',
lambda: fn,
});
pipeline.addStage({
actionName: 'Lambda',
actions: [lambdaAction],
});
```
You can also create the action from the Lambda directly:
```ts
// equivalent to the code above:
const lambdaAction = fn.toCodePipelineInvokeAction({ actionName: 'Lambda' });
```
The Lambda Action can have up to 5 inputs,
and up to 5 outputs:
```typescript
const lambdaAction = fn.toCodePipelineInvokeAction({
actionName: '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)
on how to write a Lambda function invoked from CodePipeline.
### Lambda with DLQ

@@ -125,0 +77,0 @@

import { Test } from 'nodeunit';
declare const _default: {
'version and aliases'(test: Test): void;
'can use newVersion to create a new Version'(test: Test): void;
'can add additional versions to alias'(test: Test): void;

@@ -5,0 +6,0 @@ 'sanity checks on version weights'(test: Test): void;

"use strict";
const assert_1 = require("@aws-cdk/assert");
const cloudwatch = require("@aws-cdk/aws-cloudwatch");
const assert_1 = require("@aws-cdk/assert");
const cdk_1 = require("@aws-cdk/cdk");

@@ -37,2 +37,23 @@ const lambda = require("../lib");

},
'can use newVersion to create a new Version'(test) {
const stack = new cdk_1.Stack();
const fn = new lambda.Function(stack, 'MyLambda', {
code: new lambda.InlineCode('hello()'),
handler: 'index.hello',
runtime: lambda.Runtime.NodeJS610,
});
const version = fn.newVersion();
new lambda.Alias(stack, 'Alias', {
aliasName: 'prod',
version,
});
assert_1.expect(stack).to(assert_1.haveResourceLike('AWS::Lambda::Version', {
FunctionName: { Ref: "MyLambdaCCE802FB" },
}));
assert_1.expect(stack).to(assert_1.haveResourceLike('AWS::Lambda::Alias', {
FunctionName: { Ref: "MyLambdaCCE802FB" },
Name: "prod"
}));
test.done();
},
'can add additional versions to alias'(test) {

@@ -171,2 +192,2 @@ const stack = new cdk_1.Stack();

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.alias.js","sourceRoot":"","sources":["test.alias.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\n\nimport { beASupersetOfTemplate, expect, haveResource } from '@aws-cdk/assert';\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  'metric adds Resource: aliasArn to dimensions'(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    new cloudwatch.Alarm(stack, 'Alarm', {\n      metric: alias.metric('Test'),\n      alarmName: 'Test',\n      threshold: 1,\n      evaluationPeriods: 1\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Alarm', {\n      Dimensions: [{\n        Name: \"FunctionName\",\n        Value: {\n          Ref: \"MyLambdaCCE802FB\"\n        }\n      }, {\n        Name: \"Resource\",\n        Value: {\n          Ref: \"Alias325C5727\"\n        }\n      }]\n    }));\n\n    test.done();\n  },\n\n  'alias exposes real Lambdas role'(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    // THEN\n    test.equals(alias.role, fn.role);\n\n    test.done();\n  },\n\n  'functionName is derived from the aliasArn so that dependencies are sound'(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    test.deepEqual(stack.node.resolve(alias.functionName), {\n      \"Fn::Join\": [\n        \"\",\n        [\n          {\n            \"Fn::Select\": [\n              6,\n              {\n                \"Fn::Split\": [\n                  \":\",\n                  {\n                    Ref: \"Alias325C5727\"\n                  }\n                ]\n              }\n            ]\n          },\n          \":prod\"\n        ]\n      ]\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, haveResourceLike } from '@aws-cdk/assert';\nimport cloudwatch = require('@aws-cdk/aws-cloudwatch');\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 use newVersion to create a new Version'(test: Test) {\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.newVersion();\n\n    new lambda.Alias(stack, 'Alias', {\n      aliasName: 'prod',\n      version,\n    });\n\n    expect(stack).to(haveResourceLike('AWS::Lambda::Version', {\n      FunctionName: { Ref: \"MyLambdaCCE802FB\" },\n    }));\n\n    expect(stack).to(haveResourceLike('AWS::Lambda::Alias', {\n      FunctionName: { Ref: \"MyLambdaCCE802FB\" },\n      Name: \"prod\"\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  'metric adds Resource: aliasArn to dimensions'(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    new cloudwatch.Alarm(stack, 'Alarm', {\n      metric: alias.metric('Test'),\n      alarmName: 'Test',\n      threshold: 1,\n      evaluationPeriods: 1\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Alarm', {\n      Dimensions: [{\n        Name: \"FunctionName\",\n        Value: {\n          Ref: \"MyLambdaCCE802FB\"\n        }\n      }, {\n        Name: \"Resource\",\n        Value: {\n          Ref: \"Alias325C5727\"\n        }\n      }]\n    }));\n\n    test.done();\n  },\n\n  'alias exposes real Lambdas role'(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    // THEN\n    test.equals(alias.role, fn.role);\n\n    test.done();\n  },\n\n  'functionName is derived from the aliasArn so that dependencies are sound'(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    test.deepEqual(stack.node.resolve(alias.functionName), {\n      \"Fn::Join\": [\n        \"\",\n        [\n          {\n            \"Fn::Select\": [\n              6,\n              {\n                \"Fn::Split\": [\n                  \":\",\n                  {\n                    Ref: \"Alias325C5727\"\n                  }\n                ]\n              }\n            ]\n          },\n          \":prod\"\n        ]\n      ]\n    });\n\n    test.done();\n  }\n};\n"]}

@@ -43,5 +43,2 @@ {

{
"path": "../aws-codepipeline-api"
},
{
"path": "../aws-ec2"

@@ -48,0 +45,0 @@ },

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc