@aws-cdk/aws-lambda
Advanced tools
Comparing version 0.24.1 to 0.25.0
import cloudwatch = require('@aws-cdk/aws-cloudwatch'); | ||
import codepipeline = require('@aws-cdk/aws-codepipeline-api'); | ||
import ec2 = require('@aws-cdk/aws-ec2'); | ||
@@ -42,11 +41,8 @@ import events = require('@aws-cdk/aws-events'); | ||
/** | ||
* Convenience method for creating a new {@link PipelineInvokeAction}, | ||
* and adding it to the given Stage. | ||
* Convenience method for creating a new {@link PipelineInvokeAction}. | ||
* | ||
* @param stage the Pipeline Stage to add the new Action to | ||
* @param name the name of the newly created Action | ||
* @param props the properties of the new Action | ||
* @param props the construction properties of the new Action | ||
* @returns the newly created {@link PipelineInvokeAction} | ||
*/ | ||
addToPipeline(stage: codepipeline.IStage, name: string, props?: CommonPipelineInvokeActionProps): PipelineInvokeAction; | ||
toCodePipelineInvokeAction(props: CommonPipelineInvokeActionProps): PipelineInvokeAction; | ||
addToRolePolicy(statement: iam.PolicyStatement): void; | ||
@@ -144,12 +140,3 @@ /** | ||
readonly id: string; | ||
/** | ||
* Convenience method for creating a new {@link PipelineInvokeAction}, | ||
* and adding it to the given Stage. | ||
* | ||
* @param stage the Pipeline Stage to add the new Action to | ||
* @param name the name of the newly created Action | ||
* @param props the properties of the new Action | ||
* @returns the newly created {@link PipelineInvokeAction} | ||
*/ | ||
addToPipeline(stage: codepipeline.IStage, name: string, props?: CommonPipelineInvokeActionProps): PipelineInvokeAction; | ||
toCodePipelineInvokeAction(props: CommonPipelineInvokeActionProps): PipelineInvokeAction; | ||
addToRolePolicy(statement: iam.PolicyStatement): void; | ||
@@ -156,0 +143,0 @@ /** |
@@ -39,13 +39,4 @@ "use strict"; | ||
} | ||
/** | ||
* Convenience method for creating a new {@link PipelineInvokeAction}, | ||
* and adding it to the given Stage. | ||
* | ||
* @param stage the Pipeline Stage to add the new Action to | ||
* @param name the name of the newly created Action | ||
* @param props the properties of the new Action | ||
* @returns the newly created {@link PipelineInvokeAction} | ||
*/ | ||
addToPipeline(stage, name, props = {}) { | ||
return new pipeline_action_1.PipelineInvokeAction(this, name, Object.assign({ stage, lambda: this }, props)); | ||
toCodePipelineInvokeAction(props) { | ||
return new pipeline_action_1.PipelineInvokeAction(Object.assign({}, props, { lambda: this })); | ||
} | ||
@@ -109,3 +100,2 @@ addToRolePolicy(statement) { | ||
if (this.logSubscriptionDestinationPolicyAddedFor.indexOf(arn) === -1) { | ||
const stack = cdk.Stack.find(this); | ||
// NOTE: the use of {AWS::Region} limits this to the same region, which shouldn't really be an issue, | ||
@@ -116,3 +106,3 @@ // since the Lambda must be in the same region as the SubscriptionFilter anyway. | ||
this.addPermission('InvokedByCloudWatchLogs', { | ||
principal: new iam.ServicePrincipal(`logs.${stack.region}.amazonaws.com`), | ||
principal: new iam.ServicePrincipal(`logs.${this.node.stack.region}.amazonaws.com`), | ||
sourceArn: arn | ||
@@ -130,6 +120,5 @@ }); | ||
const permissionId = `AllowBucketNotificationsFrom${bucketId}`; | ||
const stack = cdk.Stack.find(this); | ||
if (!this.node.tryFindChild(permissionId)) { | ||
this.addPermission(permissionId, { | ||
sourceAccount: stack.accountId, | ||
sourceAccount: this.node.stack.accountId, | ||
principal: new iam.ServicePrincipal('s3.amazonaws.com'), | ||
@@ -191,2 +180,2 @@ sourceArn: bucketArn, | ||
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 codepipeline = require('@aws-cdk/aws-codepipeline-api');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport events = require('@aws-cdk/aws-events');\nimport iam = require('@aws-cdk/aws-iam');\nimport logs = require('@aws-cdk/aws-logs');\nimport s3n = require('@aws-cdk/aws-s3-notifications');\nimport stepfunctions = require('@aws-cdk/aws-stepfunctions');\nimport cdk = require('@aws-cdk/cdk');\nimport { IEventSource } from './event-source';\nimport { CfnPermission } from './lambda.generated';\nimport { Permission } from './permission';\nimport { CommonPipelineInvokeActionProps, PipelineInvokeAction } from './pipeline-action';\n\nexport interface IFunction extends cdk.IConstruct, events.IEventRuleTarget, logs.ILogSubscriptionDestination,\n  s3n.IBucketNotificationDestination, ec2.IConnectable, stepfunctions.IStepFunctionsTaskResource {\n\n  /**\n   * Logical ID of this Function.\n   */\n  readonly id: string;\n\n  /**\n   * The name of the function.\n   */\n  readonly functionName: string;\n\n  /**\n   * The ARN fo the function.\n   */\n  readonly functionArn: string;\n\n  /**\n   * The IAM role associated with this function.\n   */\n  readonly role?: iam.IRole;\n\n  /**\n   * Whether or not this Lambda function was bound to a VPC\n   *\n   * If this is is `false`, trying to access the `connections` object will fail.\n   */\n  readonly isBoundToVpc: boolean;\n\n  /**\n   * Adds a permission to the Lambda resource policy.\n   * @param id The id ƒor the permission construct\n   */\n  addPermission(id: string, permission: Permission): void;\n\n  /**\n   * Convenience method for creating a new {@link PipelineInvokeAction},\n   * and adding it to the given Stage.\n   *\n   * @param stage the Pipeline Stage to add the new Action to\n   * @param name the name of the newly created Action\n   * @param props the properties of the new Action\n   * @returns the newly created {@link PipelineInvokeAction}\n   */\n  addToPipeline(stage: codepipeline.IStage, name: string, props?: CommonPipelineInvokeActionProps): PipelineInvokeAction;\n\n  addToRolePolicy(statement: iam.PolicyStatement): void;\n\n  /**\n   * Grant the given identity permissions to invoke this Lambda\n   */\n  grantInvoke(identity?: iam.IPrincipal): void;\n\n  /**\n   * Return the given named metric for this Lambda\n   */\n  metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Metric for the Duration of this Lambda\n   *\n   * @default average over 5 minutes\n   */\n  metricDuration(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Metric for the number of invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  metricInvocations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Metric for the number of throttled invocations of this Lambda\n   *\n   * @default sum over 5 minutes\n   */\n  metricThrottles(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;\n\n  /**\n   * Export this Function (without the role)\n   */\n  export(): FunctionImportProps;\n\n  addEventSource(source: IEventSource): void;\n}\n\n/**\n * Represents a Lambda function defined outside of this stack.\n */\nexport interface FunctionImportProps {\n  /**\n   * The ARN of the Lambda function.\n   *\n   * Format: arn:<partition>:lambda:<region>:<account-id>:function:<function-name>\n   */\n  functionArn: string;\n\n  /**\n   * The IAM execution role associated with this function.\n   *\n   * If the role is not specified, any role-related operations will no-op.\n   */\n  role?: iam.IRole;\n\n  /**\n   * Id of the securityGroup for this Lambda, if in a VPC.\n   *\n   * This needs to be given in order to support allowing connections\n   * to this Lambda.\n   */\n  securityGroupId?: string;\n}\n\nexport abstract class FunctionBase extends cdk.Construct implements IFunction  {\n\n  /**\n   * The name of the function.\n   */\n  public abstract readonly functionName: string;\n\n  /**\n   * The ARN fo the function.\n   */\n  public abstract readonly functionArn: string;\n\n  /**\n   * The IAM role associated with this function.\n   */\n  public abstract readonly role?: iam.IRole;\n\n  /**\n   * Whether the addPermission() call adds any permissions\n   *\n   * True for new Lambdas, false for imported Lambdas (they might live in different accounts).\n   */\n  protected abstract readonly canCreatePermissions: boolean;\n\n  /**\n   * Actual connections object for this Lambda\n   *\n   * May be unset, in which case this Lambda is not configured use in a VPC.\n   */\n  protected _connections?: ec2.Connections;\n\n  /**\n   * Indicates if the policy that allows CloudWatch logs to publish to this lambda has been added.\n   */\n  private logSubscriptionDestinationPolicyAddedFor: string[] = [];\n\n  /**\n   * Adds a permission to the Lambda resource policy.\n   * @param id The id ƒor the permission construct\n   */\n  public addPermission(id: string, permission: Permission) {\n    if (!this.canCreatePermissions) {\n      // FIXME: Report metadata\n      return;\n    }\n\n    const principal = this.parsePermissionPrincipal(permission.principal);\n    const action = permission.action || 'lambda:InvokeFunction';\n\n    new CfnPermission(this, id, {\n      action,\n      principal,\n      functionName: this.functionName,\n      eventSourceToken: permission.eventSourceToken,\n      sourceAccount: permission.sourceAccount,\n      sourceArn: permission.sourceArn,\n    });\n  }\n\n  public get id() {\n    return this.node.id;\n  }\n\n  /**\n   * Convenience method for creating a new {@link PipelineInvokeAction},\n   * and adding it to the given Stage.\n   *\n   * @param stage the Pipeline Stage to add the new Action to\n   * @param name the name of the newly created Action\n   * @param props the properties of the new Action\n   * @returns the newly created {@link PipelineInvokeAction}\n   */\n  public addToPipeline(stage: codepipeline.IStage, name: string, props: CommonPipelineInvokeActionProps = {}): PipelineInvokeAction {\n    return new PipelineInvokeAction(this, name, {\n      stage,\n      lambda: this,\n      ...props,\n    });\n  }\n\n  public addToRolePolicy(statement: iam.PolicyStatement) {\n    if (!this.role) {\n      return;\n    }\n\n    this.role.addToPolicy(statement);\n  }\n\n  /**\n   * Access the Connections object\n   *\n   * Will fail if not a VPC-enabled Lambda Function\n   */\n  public get connections(): ec2.Connections {\n    if (!this._connections) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error('Only VPC-associated Lambda Functions have security groups to manage. Supply the \"vpc\" parameter when creating the Lambda, or \"securityGroupId\" when importing it.');\n    }\n    return this._connections;\n  }\n\n  /**\n   * Whether or not this Lambda function was bound to a VPC\n   *\n   * If this is is `false`, trying to access the `connections` object will fail.\n   */\n  public get isBoundToVpc(): boolean {\n    return !!this._connections;\n  }\n\n  /**\n   * Returns a RuleTarget that can be used to trigger this Lambda as a\n   * result from a CloudWatch event.\n   */\n  public asEventRuleTarget(ruleArn: string, ruleId: string): events.EventRuleTargetProps {\n    const permissionId = `AllowEventRule${ruleId}`;\n    if (!this.node.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        action: 'lambda:InvokeFunction',\n        principal: new iam.ServicePrincipal('events.amazonaws.com'),\n        sourceArn: ruleArn\n      });\n    }\n\n    return {\n      id: this.node.id,\n      arn: this.functionArn,\n    };\n  }\n\n  /**\n   * Grant the given identity permissions to invoke this Lambda\n   */\n  public grantInvoke(identity?: iam.IPrincipal) {\n    if (identity) {\n      identity.addToPolicy(new iam.PolicyStatement()\n        .addAction('lambda:InvokeFunction')\n        .addResource(this.functionArn));\n    }\n  }\n\n  public logSubscriptionDestination(sourceLogGroup: logs.ILogGroup): logs.LogSubscriptionDestination {\n    const arn = sourceLogGroup.logGroupArn;\n\n    if (this.logSubscriptionDestinationPolicyAddedFor.indexOf(arn) === -1) {\n      const stack = cdk.Stack.find(this);\n      // NOTE: the use of {AWS::Region} limits this to the same region, which shouldn't really be an issue,\n      // since the Lambda must be in the same region as the SubscriptionFilter anyway.\n      //\n      // (Wildcards in principals are unfortunately not supported.\n      this.addPermission('InvokedByCloudWatchLogs', {\n        principal: new iam.ServicePrincipal(`logs.${stack.region}.amazonaws.com`),\n        sourceArn: arn\n      });\n      this.logSubscriptionDestinationPolicyAddedFor.push(arn);\n    }\n    return { arn: this.functionArn };\n  }\n\n  /**\n   * Export this Function (without the role)\n   */\n  public abstract export(): FunctionImportProps;\n\n  /**\n   * Allows this Lambda to be used as a destination for bucket notifications.\n   * Use `bucket.onEvent(lambda)` to subscribe.\n   */\n  public asBucketNotificationDestination(bucketArn: string, bucketId: string): s3n.BucketNotificationDestinationProps {\n    const permissionId = `AllowBucketNotificationsFrom${bucketId}`;\n    const stack = cdk.Stack.find(this);\n    if (!this.node.tryFindChild(permissionId)) {\n      this.addPermission(permissionId, {\n        sourceAccount: stack.accountId,\n        principal: new iam.ServicePrincipal('s3.amazonaws.com'),\n        sourceArn: bucketArn,\n      });\n    }\n\n    // if we have a permission resource for this relationship, add it as a dependency\n    // to the bucket notifications resource, so it will be created first.\n    const permission = this.node.tryFindChild(permissionId) as cdk.Resource;\n\n    return {\n      type: s3n.BucketNotificationDestinationType.Lambda,\n      arn: this.functionArn,\n      dependencies: permission ? [ permission ] : undefined\n    };\n  }\n\n  public asStepFunctionsTaskResource(_callingTask: stepfunctions.Task): stepfunctions.StepFunctionsTaskResourceProps {\n    return {\n      resourceArn: this.functionArn,\n      metricPrefixSingular: 'LambdaFunction',\n      metricPrefixPlural: 'LambdaFunctions',\n      metricDimensions: { LambdaFunctionArn: this.functionArn },\n      policyStatements: [new iam.PolicyStatement()\n        .addResource(this.functionArn)\n        .addActions(\"lambda:InvokeFunction\")\n      ]\n    };\n  }\n\n  /**\n   * Adds an event source to this function.\n   *\n   * Event sources are implemented in the @aws-cdk/aws-lambda-event-sources module.\n   *\n   * The following example adds an SQS Queue as an event source:\n   *\n   *     import { SqsEventSource } from '@aws-cdk/aws-lambda-event-sources';\n   *     myFunction.addEventSource(new SqsEventSource(myQueue));\n   *\n   * @param source The event source to bind to this function\n   */\n  public addEventSource(source: IEventSource) {\n    source.bind(this);\n  }\n\n  private parsePermissionPrincipal(principal?: iam.PolicyPrincipal) {\n    if (!principal) {\n      return undefined;\n    }\n\n    // use duck-typing, not instance of\n\n    if ('accountId' in principal) {\n      return (principal as iam.AccountPrincipal).accountId;\n    }\n\n    if (`service` in principal) {\n      return (principal as iam.ServicePrincipal).service;\n    }\n\n    throw new Error(`Invalid principal type for Lambda permission statement: ${JSON.stringify(this.node.resolve(principal))}. ` +\n      'Supported: AccountPrincipal, ServicePrincipal');\n  }\n}"]} | ||
//# 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  functionArn: string;\n\n  /**\n   * The IAM execution role associated with this function.\n   *\n   * If the role is not specified, any role-related operations will no-op.\n   */\n  role?: iam.IRole;\n\n  /**\n   * Id of the securityGroup for this Lambda, if in a VPC.\n   *\n   * This needs to be given in order to support allowing connections\n   * to this Lambda.\n   */\n  securityGroupId?: string;\n}\n\nexport abstract class FunctionBase extends cdk.Construct implements IFunction  {\n\n  /**\n   * The name of the function.\n   */\n  public abstract readonly functionName: string;\n\n  /**\n   * The ARN fo the function.\n   */\n  public abstract readonly functionArn: string;\n\n  /**\n   * The IAM role associated with this function.\n   */\n  public abstract readonly role?: iam.IRole;\n\n  /**\n   * Whether the addPermission() call adds any permissions\n   *\n   * True for new Lambdas, false for imported Lambdas (they might live in different accounts).\n   */\n  protected abstract readonly canCreatePermissions: boolean;\n\n  /**\n   * Actual connections object for this Lambda\n   *\n   * May be unset, in which case this Lambda is not configured use in a VPC.\n   */\n  protected _connections?: ec2.Connections;\n\n  /**\n   * Indicates if the policy that allows CloudWatch logs to publish to this lambda has been added.\n   */\n  private logSubscriptionDestinationPolicyAddedFor: string[] = [];\n\n  /**\n   * Adds a permission to the Lambda resource policy.\n   * @param id The id ƒor the permission construct\n   */\n  public addPermission(id: string, permission: Permission) {\n    if (!this.canCreatePermissions) {\n      // FIXME: Report metadata\n      return;\n    }\n\n    const principal = this.parsePermissionPrincipal(permission.principal);\n    const action = permission.action || 'lambda:InvokeFunction';\n\n    new CfnPermission(this, id, {\n      action,\n      principal,\n      functionName: this.functionName,\n      eventSourceToken: permission.eventSourceToken,\n      sourceAccount: permission.sourceAccount,\n      sourceArn: permission.sourceArn,\n    });\n  }\n\n  public get id() {\n    return this.node.id;\n  }\n\n  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.Resource;\n\n    return {\n      type: s3n.BucketNotificationDestinationType.Lambda,\n      arn: this.functionArn,\n      dependencies: permission ? [ permission ] : undefined\n    };\n  }\n\n  public asStepFunctionsTaskResource(_callingTask: stepfunctions.Task): stepfunctions.StepFunctionsTaskResourceProps {\n    return {\n      resourceArn: this.functionArn,\n      metricPrefixSingular: 'LambdaFunction',\n      metricPrefixPlural: 'LambdaFunctions',\n      metricDimensions: { LambdaFunctionArn: this.functionArn },\n      policyStatements: [new iam.PolicyStatement()\n        .addResource(this.functionArn)\n        .addActions(\"lambda:InvokeFunction\")\n      ]\n    };\n  }\n\n  /**\n   * Adds an event source to this function.\n   *\n   * Event sources are implemented in the @aws-cdk/aws-lambda-event-sources module.\n   *\n   * The following example adds an SQS Queue as an event source:\n   *\n   *     import { SqsEventSource } from '@aws-cdk/aws-lambda-event-sources';\n   *     myFunction.addEventSource(new SqsEventSource(myQueue));\n   *\n   * @param source The event source to bind to this function\n   */\n  public addEventSource(source: IEventSource) {\n    source.bind(this);\n  }\n\n  private parsePermissionPrincipal(principal?: iam.PolicyPrincipal) {\n    if (!principal) {\n      return undefined;\n    }\n\n    // use duck-typing, not instance of\n\n    if ('accountId' in principal) {\n      return (principal as iam.AccountPrincipal).accountId;\n    }\n\n    if (`service` in principal) {\n      return (principal as iam.ServicePrincipal).service;\n    }\n\n    throw new Error(`Invalid principal type for Lambda permission statement: ${JSON.stringify(this.node.resolve(principal))}. ` +\n      'Supported: AccountPrincipal, ServicePrincipal');\n  }\n}\n"]} |
@@ -7,2 +7,3 @@ import cloudwatch = require('@aws-cdk/aws-cloudwatch'); | ||
import { Code } from './code'; | ||
import { IEventSource } from './event-source'; | ||
import { FunctionBase, FunctionImportProps, IFunction } from './function-base'; | ||
@@ -175,2 +176,8 @@ import { Version } from './lambda-version'; | ||
reservedConcurrentExecutions?: number; | ||
/** | ||
* Event sources for this function. | ||
* | ||
* You can also add event sources using `addEventSource`. | ||
*/ | ||
events?: IEventSource[]; | ||
} | ||
@@ -177,0 +184,0 @@ /** |
@@ -62,2 +62,7 @@ "use strict"; | ||
} | ||
const isChina = this.node.stack.env.region && this.node.stack.env.region.startsWith('cn-'); | ||
if (isChina && props.environment && Object.keys(props.environment).length > 0) { | ||
// tslint:disable-next-line:max-line-length | ||
throw new Error(`Environment variables are not supported in this region (${this.node.stack.env.region}); consider using tags or SSM parameters instead`); | ||
} | ||
const resource = new lambda_generated_1.CfnFunction(this, 'Resource', { | ||
@@ -89,2 +94,5 @@ functionName: props.functionName, | ||
} | ||
for (const event of props.events || []) { | ||
this.addEventSource(event); | ||
} | ||
} | ||
@@ -341,2 +349,2 @@ /** | ||
} | ||
//# 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 sqs = require('@aws-cdk/aws-sqs');\nimport cdk = require('@aws-cdk/cdk');\nimport { Code } from './code';\nimport { FunctionBase, FunctionImportProps, IFunction } from './function-base';\nimport { Version } from './lambda-version';\nimport { CfnFunction } from './lambda.generated';\nimport { ILayerVersion } from './layers';\nimport { Runtime } from './runtime';\n\n/**\n * X-Ray Tracing Modes (https://docs.aws.amazon.com/lambda/latest/dg/API_TracingConfig.html)\n */\nexport enum Tracing {\n  /**\n   * Lambda will respect any tracing header it receives from an upstream service.\n   * If no tracing header is received, Lambda will call X-Ray for a tracing decision.\n   */\n  Active,\n  /**\n   * Lambda will only trace the request from an upstream service\n   * if it contains a tracing header with \"sampled=1\"\n   */\n  PassThrough,\n  /**\n   * Lambda will not trace any request.\n   */\n  Disabled\n}\n\nexport interface FunctionProps {\n  /**\n   * The source code of your Lambda function. You can point to a file in an\n   * Amazon Simple Storage Service (Amazon S3) bucket or specify your source\n   * code as inline text.\n   */\n  code: Code;\n\n  /**\n   * A description of the function.\n   */\n  description?: string;\n\n  /**\n   * The name of the function (within your source code) that Lambda calls to\n   * start running your code. For more information, see the Handler property\n   * in the AWS Lambda Developer Guide.\n   *\n   * NOTE: If you specify your source code as inline text by specifying the\n   * ZipFile property within the Code property, specify index.function_name as\n   * the handler.\n   */\n  handler: string;\n\n  /**\n   * The function execution time (in seconds) after which Lambda terminates\n   * the function. Because the execution time affects cost, set this value\n   * based on the function's expected execution time.\n   *\n   * @default 3 seconds.\n   */\n  timeout?: number;\n\n  /**\n   * Key-value pairs that Lambda caches and makes available for your Lambda\n   * functions. Use environment variables to apply configuration changes, such\n   * as test and production environment configurations, without changing your\n   * Lambda function source code.\n   */\n  environment?: { [key: string]: any };\n\n  /**\n   * The runtime environment for the Lambda function that you are uploading.\n   * For valid values, see the Runtime property in the AWS Lambda Developer\n   * Guide.\n   */\n  runtime: Runtime;\n\n  /**\n   * A name for the function. If you don't specify a name, AWS CloudFormation\n   * generates a unique physical ID and uses that ID for the function's name.\n   * For more information, see Name Type.\n   */\n  functionName?: string;\n\n  /**\n   * The amount of memory, in MB, that is allocated to your Lambda function.\n   * Lambda uses this value to proportionally allocate the amount of CPU\n   * power. For more information, see Resource Model in the AWS Lambda\n   * Developer Guide.\n   *\n   * @default The default value is 128 MB\n   */\n  memorySize?: number;\n\n  /**\n   * Initial policy statements to add to the created Lambda Role.\n   *\n   * You can call `addToRolePolicy` to the created lambda to add statements post creation.\n   */\n  initialPolicy?: iam.PolicyStatement[];\n\n  /**\n   * Lambda execution role.\n   *\n   * This is the role that will be assumed by the function upon execution.\n   * It controls the permissions that the function will have. The Role must\n   * be assumable by the 'lambda.amazonaws.com' service principal.\n   *\n   * @default a unique role will be generated for this lambda function.\n   * Both supplied and generated roles can always be changed by calling `addToRolePolicy`.\n   */\n  role?: iam.IRole;\n\n  /**\n   * VPC network to place Lambda network interfaces\n   *\n   * Specify this if the Lambda function needs to access resources in a VPC.\n   */\n  vpc?: ec2.IVpcNetwork;\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * Only used if 'vpc' is supplied. Note: internet access for Lambdas\n   * requires a NAT gateway, so picking Public subnets is not allowed.\n   *\n   * @default All private subnets\n   */\n  vpcPlacement?: ec2.VpcPlacementStrategy;\n\n  /**\n   * What security group to associate with the Lambda's network interfaces.\n   *\n   * Only used if 'vpc' is supplied.\n   *\n   * @default If the function is placed within a VPC and a security group is\n   * not specified, a dedicated security group will be created for this\n   * function.\n   */\n  securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Whether to allow the Lambda to send all network traffic\n   *\n   * If set to false, you must individually add traffic rules to allow the\n   * Lambda to connect to network targets.\n   *\n   * @default true\n   */\n  allowAllOutbound?: boolean;\n\n  /**\n   * Enabled DLQ. If `deadLetterQueue` is undefined,\n   * an SQS queue with default options will be defined for your Function.\n   *\n   * @default false unless `deadLetterQueue` is set, which implies DLQ is enabled\n   */\n  deadLetterQueueEnabled?: boolean;\n\n  /**\n   * The SQS queue to use if DLQ is enabled.\n   *\n   * @default SQS queue with 14 day retention period if `deadLetterQueueEnabled` is `true`\n   */\n  deadLetterQueue?: sqs.IQueue;\n\n  /**\n   * Enable AWS X-Ray Tracing for Lambda Function.\n   *\n   * @default undefined X-Ray tracing disabled\n   */\n  tracing?: Tracing;\n\n  /**\n   * 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  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  reservedConcurrentExecutions?: number;\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 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),\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\n  /**\n   * Export this Function (without the role)\n   */\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.Output(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(),\n      securityGroupId: this._connections && this._connections.securityGroups[0]\n          ? new cdk.Output(this, 'SecurityGroupId', { value: this._connections.securityGroups[0].securityGroupId }).makeImportValue().toString()\n          : undefined\n    };\n  }\n\n  /**\n   * Adds an environment variable to this Lambda function.\n   * If this is a ref to a Lambda function, this operation results in a no-op.\n   * @param key The environment variable key.\n   * @param value The environment variable's value.\n   */\n  public addEnvironment(key: string, value: any): 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    const subnets = props.vpc.subnets(props.vpcPlacement);\n    for (const subnet of subnets) {\n      if (props.vpc.isPublicSubnet(subnet)) {\n        throw new Error('Not possible to place Lambda Functions in a Public subnet');\n      }\n    }\n\n    return {\n      subnetIds: subnets.map(s => s.subnetId),\n      securityGroupIds: [securityGroup.securityGroupId]\n    };\n  }\n\n  private buildDeadLetterConfig(props: FunctionProps) {\n    if (props.deadLetterQueue && props.deadLetterQueueEnabled === false) {\n      throw Error('deadLetterQueue defined but deadLetterQueueEnabled explicitly set to false');\n    }\n\n    if (!props.deadLetterQueue && !props.deadLetterQueueEnabled) {\n      return undefined;\n    }\n\n    const deadLetterQueue = props.deadLetterQueue || new sqs.Queue(this, 'DeadLetterQueue', {\n      retentionPeriodSec: 1209600\n    });\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addAction('sqs:SendMessage')\n      .addResource(deadLetterQueue.queueArn));\n\n    return {\n      targetArn: deadLetterQueue.queueArn\n    };\n  }\n\n  private buildTracingConfig(props: FunctionProps) {\n    if (props.tracing === undefined || props.tracing === Tracing.Disabled) {\n      return undefined;\n    }\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addActions('xray:PutTraceSegments', 'xray:PutTelemetryRecords')\n      .addAllResources());\n\n    return {\n      mode: Tracing[props.tracing]\n    };\n  }\n}\n\nexport class ImportedFunction extends FunctionBase {\n  public readonly functionName: string;\n  public readonly functionArn: string;\n  public readonly role?: iam.IRole;\n\n  protected readonly canCreatePermissions = false;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: FunctionImportProps) {\n    super(scope, id);\n\n    this.functionArn = props.functionArn;\n    this.functionName = extractNameFromArn(props.functionArn);\n    this.role = props.role;\n\n    if (props.securityGroupId) {\n      this._connections = new ec2.Connections({\n        securityGroups: [\n          ec2.SecurityGroup.import(this, 'SecurityGroup', { securityGroupId: props.securityGroupId })\n        ]\n      });\n    }\n  }\n\n  public export() {\n    return this.props;\n  }\n}\n\n/**\n * Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function\n * name from the ARN.\n *\n * Function ARNs look like this:\n *\n *   arn:aws:lambda:region:account-id:function:function-name\n *\n * ..which means that in order to extract the `function-name` component from the ARN, we can\n * split the ARN using \":\" and select the component in index 6.\n *\n * @returns `FnSelect(6, FnSplit(':', arn))`\n */\nfunction extractNameFromArn(arn: string) {\n  return cdk.Fn.select(6, cdk.Fn.split(':', arn));\n}\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 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 { Runtime } from './runtime';\n\n/**\n * X-Ray Tracing Modes (https://docs.aws.amazon.com/lambda/latest/dg/API_TracingConfig.html)\n */\nexport enum Tracing {\n  /**\n   * Lambda will respect any tracing header it receives from an upstream service.\n   * If no tracing header is received, Lambda will call X-Ray for a tracing decision.\n   */\n  Active,\n  /**\n   * Lambda will only trace the request from an upstream service\n   * if it contains a tracing header with \"sampled=1\"\n   */\n  PassThrough,\n  /**\n   * Lambda will not trace any request.\n   */\n  Disabled\n}\n\nexport interface FunctionProps {\n  /**\n   * The source code of your Lambda function. You can point to a file in an\n   * Amazon Simple Storage Service (Amazon S3) bucket or specify your source\n   * code as inline text.\n   */\n  code: Code;\n\n  /**\n   * A description of the function.\n   */\n  description?: string;\n\n  /**\n   * The name of the function (within your source code) that Lambda calls to\n   * start running your code. For more information, see the Handler property\n   * in the AWS Lambda Developer Guide.\n   *\n   * NOTE: If you specify your source code as inline text by specifying the\n   * ZipFile property within the Code property, specify index.function_name as\n   * the handler.\n   */\n  handler: string;\n\n  /**\n   * The function execution time (in seconds) after which Lambda terminates\n   * the function. Because the execution time affects cost, set this value\n   * based on the function's expected execution time.\n   *\n   * @default 3 seconds.\n   */\n  timeout?: number;\n\n  /**\n   * Key-value pairs that Lambda caches and makes available for your Lambda\n   * functions. Use environment variables to apply configuration changes, such\n   * as test and production environment configurations, without changing your\n   * Lambda function source code.\n   */\n  environment?: { [key: string]: any };\n\n  /**\n   * The runtime environment for the Lambda function that you are uploading.\n   * For valid values, see the Runtime property in the AWS Lambda Developer\n   * Guide.\n   */\n  runtime: Runtime;\n\n  /**\n   * A name for the function. If you don't specify a name, AWS CloudFormation\n   * generates a unique physical ID and uses that ID for the function's name.\n   * For more information, see Name Type.\n   */\n  functionName?: string;\n\n  /**\n   * The amount of memory, in MB, that is allocated to your Lambda function.\n   * Lambda uses this value to proportionally allocate the amount of CPU\n   * power. For more information, see Resource Model in the AWS Lambda\n   * Developer Guide.\n   *\n   * @default The default value is 128 MB\n   */\n  memorySize?: number;\n\n  /**\n   * Initial policy statements to add to the created Lambda Role.\n   *\n   * You can call `addToRolePolicy` to the created lambda to add statements post creation.\n   */\n  initialPolicy?: iam.PolicyStatement[];\n\n  /**\n   * Lambda execution role.\n   *\n   * This is the role that will be assumed by the function upon execution.\n   * It controls the permissions that the function will have. The Role must\n   * be assumable by the 'lambda.amazonaws.com' service principal.\n   *\n   * @default a unique role will be generated for this lambda function.\n   * Both supplied and generated roles can always be changed by calling `addToRolePolicy`.\n   */\n  role?: iam.IRole;\n\n  /**\n   * VPC network to place Lambda network interfaces\n   *\n   * Specify this if the Lambda function needs to access resources in a VPC.\n   */\n  vpc?: ec2.IVpcNetwork;\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * Only used if 'vpc' is supplied. Note: internet access for Lambdas\n   * requires a NAT gateway, so picking Public subnets is not allowed.\n   *\n   * @default All private subnets\n   */\n  vpcPlacement?: ec2.VpcPlacementStrategy;\n\n  /**\n   * What security group to associate with the Lambda's network interfaces.\n   *\n   * Only used if 'vpc' is supplied.\n   *\n   * @default If the function is placed within a VPC and a security group is\n   * not specified, a dedicated security group will be created for this\n   * function.\n   */\n  securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Whether to allow the Lambda to send all network traffic\n   *\n   * If set to false, you must individually add traffic rules to allow the\n   * Lambda to connect to network targets.\n   *\n   * @default true\n   */\n  allowAllOutbound?: boolean;\n\n  /**\n   * Enabled DLQ. If `deadLetterQueue` is undefined,\n   * an SQS queue with default options will be defined for your Function.\n   *\n   * @default false unless `deadLetterQueue` is set, which implies DLQ is enabled\n   */\n  deadLetterQueueEnabled?: boolean;\n\n  /**\n   * The SQS queue to use if DLQ is enabled.\n   *\n   * @default SQS queue with 14 day retention period if `deadLetterQueueEnabled` is `true`\n   */\n  deadLetterQueue?: sqs.IQueue;\n\n  /**\n   * Enable AWS X-Ray Tracing for Lambda Function.\n   *\n   * @default undefined X-Ray tracing disabled\n   */\n  tracing?: Tracing;\n\n  /**\n   * 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  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  reservedConcurrentExecutions?: number;\n\n  /**\n   * Event sources for this function.\n   *\n   * You can also add event sources using `addEventSource`.\n   */\n  events?: IEventSource[];\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),\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\n  /**\n   * Export this Function (without the role)\n   */\n  public export(): FunctionImportProps {\n    return {\n      functionArn: new cdk.Output(this, 'FunctionArn', { value: this.functionArn }).makeImportValue().toString(),\n      securityGroupId: this._connections && this._connections.securityGroups[0]\n          ? new cdk.Output(this, 'SecurityGroupId', { value: this._connections.securityGroups[0].securityGroupId }).makeImportValue().toString()\n          : undefined\n    };\n  }\n\n  /**\n   * Adds an environment variable to this Lambda function.\n   * If this is a ref to a Lambda function, this operation results in a no-op.\n   * @param key The environment variable key.\n   * @param value The environment variable's value.\n   */\n  public addEnvironment(key: string, value: any): 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    const subnets = props.vpc.subnets(props.vpcPlacement);\n    for (const subnet of subnets) {\n      if (props.vpc.isPublicSubnet(subnet)) {\n        throw new Error('Not possible to place Lambda Functions in a Public subnet');\n      }\n    }\n\n    return {\n      subnetIds: subnets.map(s => s.subnetId),\n      securityGroupIds: [securityGroup.securityGroupId]\n    };\n  }\n\n  private buildDeadLetterConfig(props: FunctionProps) {\n    if (props.deadLetterQueue && props.deadLetterQueueEnabled === false) {\n      throw Error('deadLetterQueue defined but deadLetterQueueEnabled explicitly set to false');\n    }\n\n    if (!props.deadLetterQueue && !props.deadLetterQueueEnabled) {\n      return undefined;\n    }\n\n    const deadLetterQueue = props.deadLetterQueue || new sqs.Queue(this, 'DeadLetterQueue', {\n      retentionPeriodSec: 1209600\n    });\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addAction('sqs:SendMessage')\n      .addResource(deadLetterQueue.queueArn));\n\n    return {\n      targetArn: deadLetterQueue.queueArn\n    };\n  }\n\n  private buildTracingConfig(props: FunctionProps) {\n    if (props.tracing === undefined || props.tracing === Tracing.Disabled) {\n      return undefined;\n    }\n\n    this.addToRolePolicy(new iam.PolicyStatement()\n      .addActions('xray:PutTraceSegments', 'xray:PutTelemetryRecords')\n      .addAllResources());\n\n    return {\n      mode: Tracing[props.tracing]\n    };\n  }\n}\n\nexport class ImportedFunction extends FunctionBase {\n  public readonly functionName: string;\n  public readonly functionArn: string;\n  public readonly role?: iam.IRole;\n\n  protected readonly canCreatePermissions = false;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: FunctionImportProps) {\n    super(scope, id);\n\n    this.functionArn = props.functionArn;\n    this.functionName = extractNameFromArn(props.functionArn);\n    this.role = props.role;\n\n    if (props.securityGroupId) {\n      this._connections = new ec2.Connections({\n        securityGroups: [\n          ec2.SecurityGroup.import(this, 'SecurityGroup', { securityGroupId: props.securityGroupId })\n        ]\n      });\n    }\n  }\n\n  public export() {\n    return this.props;\n  }\n}\n\n/**\n * Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function\n * name from the ARN.\n *\n * Function ARNs look like this:\n *\n *   arn:aws:lambda:region:account-id:function:function-name\n *\n * ..which means that in order to extract the `function-name` component from the ARN, we can\n * split the ARN using \":\" and select the component in index 6.\n *\n * @returns `FnSelect(6, FnSplit(':', arn))`\n */\nfunction extractNameFromArn(arn: string) {\n  return cdk.Fn.select(6, cdk.Fn.split(':', arn));\n}\n"]} |
@@ -103,11 +103,10 @@ "use strict"; | ||
const singletonId = `SingletonLayer-${props.uuid}`; | ||
const stack = cdk.Stack.find(this); | ||
const existing = stack.node.tryFindChild(singletonId); | ||
const existing = this.node.stack.node.tryFindChild(singletonId); | ||
if (existing) { | ||
return existing; | ||
} | ||
return new LayerVersion(stack, singletonId, props); | ||
return new LayerVersion(this.node.stack, singletonId, props); | ||
} | ||
} | ||
exports.SingletonLayerVersion = SingletonLayerVersion; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layers.js","sourceRoot":"","sources":["layers.ts"],"names":[],"mappings":";;AAAA,oCAAqC;AAErC,yDAAgF;AAgEhF;;GAEG;AACH,MAAsB,gBAAiB,SAAQ,GAAG,CAAC,SAAS;IAInD,UAAU,CAAC,EAAU,EAAE,OAAiC;QAC7D,IAAI,OAAO,CAAC,cAAc,IAAI,IAAI,IAAI,OAAO,CAAC,SAAS,KAAK,GAAG,EAAE;YAC/D,MAAM,IAAI,KAAK,CAAC,0EAA0E,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;SAChH;QAED,IAAI,4CAAyB,CAAC,IAAI,EAAE,EAAE,EAAE;YACtC,MAAM,EAAE,wBAAwB;YAChC,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,cAAc,EAAE,OAAO,CAAC,cAAc;SACvC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,MAAM;QACX,OAAO;YACL,eAAe,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,iBAAiB,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,eAAe,EAAE,CAAC,QAAQ,EAAE;YACtH,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;SAC5C,CAAC;IACJ,CAAC;CACF;AAxBD,4CAwBC;AAmCD;;GAEG;AACH,MAAa,YAAa,SAAQ,gBAAgB;IAChD;;;;;;OAMG;IACI,MAAM,CAAC,MAAM,CAAC,KAAoB,EAAE,EAAU,EAAE,KAA8B;QACnF,OAAO,IAAI,oBAAoB,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;IACpD,CAAC;IAKD,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAwB;QACpE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,IAAI,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE;YACrE,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;SACjF;QACD,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE;YACvB,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;SACrE;QACD,6CAA6C;QAC7C,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEtB,MAAM,QAAQ,GAAG,IAAI,kCAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YACrD,kBAAkB,EAAE,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YACzF,OAAO,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAC1D,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,SAAS,EAAE,KAAK,CAAC,IAAI;YACrB,WAAW,EAAE,KAAK,CAAC,OAAO;SAC3B,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,eAAe,CAAC;QAChD,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,kBAAkB,CAAC;IACrD,CAAC;CACF;AArCD,oCAqCC;AAED,MAAM,oBAAqB,SAAQ,gBAAgB;IAIjD,YAAmB,MAAqB,EAAE,EAAU,EAAE,KAA8B;QAClF,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAElB,IAAI,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE;YACrE,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;SACjF;QAED,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,eAAe,CAAC;QAC7C,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,kBAAkB,CAAC;IACrD,CAAC;CACF;AAeD;;;;GAIG;AACH,MAAa,qBAAsB,SAAQ,GAAG,CAAC,SAAS;IAGtD,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAiC;QAC7E,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC;IAC3C,CAAC;IAED,IAAW,kBAAkB;QAC3B,OAAO,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC;IAC9C,CAAC;IAEM,MAAM;QACX,OAAO;YACL,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;SAC5C,CAAC;IACJ,CAAC;IAEM,UAAU,CAAC,EAAU,EAAE,OAAiC;QAC7D,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,kBAAkB,CAAC,KAAiC;QAC1D,MAAM,WAAW,GAAG,kBAAkB,KAAK,CAAC,IAAI,EAAE,CAAC;QACnD,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnC,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QACtD,IAAI,QAAQ,EAAE;YACZ,OAAO,QAAoC,CAAC;SAC7C;QACD,OAAO,IAAI,YAAY,CAAC,KAAK,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;IACrD,CAAC;CACF;AAtCD,sDAsCC","sourcesContent":["import cdk = require('@aws-cdk/cdk');\nimport { Code } from './code';\nimport { CfnLayerVersion, CfnLayerVersionPermission } from './lambda.generated';\nimport { Runtime } from './runtime';\n\nexport interface LayerVersionProps {\n  /**\n   * The runtimes that this layer is compatible with.\n   *\n   * @default All runtimes are supported\n   */\n  compatibleRuntimes?: Runtime[];\n\n  /**\n   * The content of this Layer. Using *inline* (per ``code.isInline``) code is not permitted.\n   */\n  code: Code;\n\n  /**\n   * The description the this Lambda Layer.\n   */\n  description?: string;\n\n  /**\n   * The SPDX licence identifier or URL to the license file for this layer.\n   *\n   * @default no license information will be recorded.\n   */\n  license?: string;\n\n  /**\n   * The name of the layer.\n   * @default a name will be generated.\n   */\n  name?: string;\n}\n\nexport interface ILayerVersion extends cdk.IConstruct {\n  /**\n   * The ARN of the Lambda Layer version that this Layer defines.\n   */\n  readonly layerVersionArn: string;\n\n  /**\n   * The runtimes compatible with this Layer.\n   */\n  readonly compatibleRuntimes?: Runtime[];\n\n  /**\n   * Exports this layer for use in another Stack. The resulting object can be passed to the ``LayerVersion.import``\n   * function to obtain an ``ILayerVersion`` in the user stack.\n   */\n  export(): LayerVersionImportProps;\n\n  /**\n   * Grants usage of this layer to specific entities. Usage within the same account where the layer is defined is always\n   * allowed and does not require calling this method. Note that the principal that creates the Lambda function using\n   * the layer (for example, a CloudFormation changeset execution role) also needs to have the\n   * ``lambda:GetLayerVersion`` permission on the layer version.\n   *\n   * @param id the ID of the grant in the construct tree.\n   * @param grantee the identification of the grantee.\n   */\n  grantUsage(id: string, grantee: LayerVersionUsageGrantee): ILayerVersion\n}\n\n/**\n * A reference to a Lambda Layer version.\n */\nexport abstract class LayerVersionBase extends cdk.Construct implements ILayerVersion {\n  public abstract readonly layerVersionArn: string;\n  public abstract readonly compatibleRuntimes?: Runtime[];\n\n  public grantUsage(id: string, grantee: LayerVersionUsageGrantee): ILayerVersion {\n    if (grantee.organizationId != null && grantee.accountId !== '*') {\n      throw new Error(`OrganizationId can only be specified if AwsAccountId is '*', but it is ${grantee.accountId}`);\n    }\n\n    new CfnLayerVersionPermission(this, id, {\n      action: 'lambda:GetLayerVersion',\n      layerVersionArn: this.layerVersionArn,\n      principal: grantee.accountId,\n      organizationId: grantee.organizationId,\n    });\n    return this;\n  }\n\n  public export(): LayerVersionImportProps {\n    return {\n      layerVersionArn: new cdk.Output(this, 'LayerVersionArn', { value: this.layerVersionArn }).makeImportValue().toString(),\n      compatibleRuntimes: this.compatibleRuntimes,\n    };\n  }\n}\n\n/**\n * Identification of an account (or organization) that is allowed to access a Lambda Layer Version.\n */\nexport interface LayerVersionUsageGrantee {\n  /**\n   * The AWS Account id of the account that is authorized to use a Lambda Layer Version. The wild-card ``'*'`` can be\n   * used to grant access to \"any\" account (or any account in an organization when ``organizationId`` is specified).\n   */\n  accountId: string;\n\n  /**\n   * The ID of the AWS Organization to hwich the grant is restricted.\n   *\n   * Can only be specified if ``accountId`` is ``'*'``\n   */\n  organizationId?: string;\n}\n\n/**\n * Properties necessary to import a LayerVersion.\n */\nexport interface LayerVersionImportProps {\n  /**\n   * The ARN of the LayerVersion.\n   */\n  layerVersionArn: string;\n\n  /**\n   * The list of compatible runtimes with this Layer.\n   */\n  compatibleRuntimes?: Runtime[];\n}\n\n/**\n * Defines a new Lambda Layer version.\n */\nexport class LayerVersion extends LayerVersionBase {\n  /**\n   * Imports a Layer that has been defined externally.\n   *\n   * @param scope the parent Construct that will use the imported layer.\n   * @param id    the id of the imported layer in the construct tree.\n   * @param props the properties of the imported layer.\n   */\n  public static import(scope: cdk.Construct, id: string, props: LayerVersionImportProps): ILayerVersion {\n    return new ImportedLayerVersion(scope, id, props);\n  }\n\n  public readonly layerVersionArn: string;\n  public readonly compatibleRuntimes?: Runtime[];\n\n  constructor(scope: cdk.Construct, id: string, props: LayerVersionProps) {\n    super(scope, id);\n    if (props.compatibleRuntimes && props.compatibleRuntimes.length === 0) {\n      throw new Error('Attempted to define a Lambda layer that supports no runtime!');\n    }\n    if (props.code.isInline) {\n      throw new Error('Lambda layers cannot be created from inline code');\n    }\n    // Allow usage of the code in this context...\n    props.code.bind(this);\n\n    const resource = new CfnLayerVersion(this, 'Resource', {\n      compatibleRuntimes: props.compatibleRuntimes && props.compatibleRuntimes.map(r => r.name),\n      content: new cdk.Token(() => props.code._toJSON(resource)),\n      description: props.description,\n      layerName: props.name,\n      licenseInfo: props.license,\n    });\n\n    this.layerVersionArn = resource.layerVersionArn;\n    this.compatibleRuntimes = props.compatibleRuntimes;\n  }\n}\n\nclass ImportedLayerVersion extends LayerVersionBase {\n  public readonly layerVersionArn: string;\n  public readonly compatibleRuntimes?: Runtime[];\n\n  public constructor(parent: cdk.Construct, id: string, props: LayerVersionImportProps) {\n    super(parent, id);\n\n    if (props.compatibleRuntimes && props.compatibleRuntimes.length === 0) {\n      throw new Error('Attempted to import a Lambda layer that supports no runtime!');\n    }\n\n    this.layerVersionArn = props.layerVersionArn;\n    this.compatibleRuntimes = props.compatibleRuntimes;\n  }\n}\n\n/**\n * Properties of a Singleton Lambda Layer Version.\n */\nexport interface SingletonLayerVersionProps extends LayerVersionProps {\n  /**\n   * A unique identifier to identify this lambda layer version.\n   *\n   * The identifier should be unique across all layer providers.\n   * We recommend generating a UUID per provider.\n   */\n  uuid: string;\n}\n\n/**\n * A Singleton Lambda Layer Version. The construct gurantees exactly one LayerVersion will be created in a given Stack\n * for the provided ``uuid``. It is recommended to use ``uuidgen`` to create a new ``uuid`` each time a new singleton\n * layer is created.\n */\nexport class SingletonLayerVersion extends cdk.Construct implements ILayerVersion {\n  private readonly layerVersion: ILayerVersion;\n\n  constructor(scope: cdk.Construct, id: string, props: SingletonLayerVersionProps) {\n    super(scope, id);\n\n    this.layerVersion = this.ensureLayerVersion(props);\n  }\n\n  public get layerVersionArn(): string {\n    return this.layerVersion.layerVersionArn;\n  }\n\n  public get compatibleRuntimes(): Runtime[] | undefined {\n    return this.layerVersion.compatibleRuntimes;\n  }\n\n  public export(): LayerVersionImportProps {\n    return {\n      layerVersionArn: this.layerVersionArn,\n      compatibleRuntimes: this.compatibleRuntimes,\n    };\n  }\n\n  public grantUsage(id: string, grantee: LayerVersionUsageGrantee): ILayerVersion {\n    this.layerVersion.grantUsage(id, grantee);\n    return this;\n  }\n\n  private ensureLayerVersion(props: SingletonLayerVersionProps): ILayerVersion {\n    const singletonId = `SingletonLayer-${props.uuid}`;\n    const stack = cdk.Stack.find(this);\n    const existing = stack.node.tryFindChild(singletonId);\n    if (existing) {\n      return existing as unknown as ILayerVersion;\n    }\n    return new LayerVersion(stack, singletonId, props);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layers.js","sourceRoot":"","sources":["layers.ts"],"names":[],"mappings":"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","sourcesContent":["import cdk = require('@aws-cdk/cdk');\nimport { Code } from './code';\nimport { CfnLayerVersion, CfnLayerVersionPermission } from './lambda.generated';\nimport { Runtime } from './runtime';\n\nexport interface LayerVersionProps {\n  /**\n   * The runtimes that this layer is compatible with.\n   *\n   * @default All runtimes are supported\n   */\n  compatibleRuntimes?: Runtime[];\n\n  /**\n   * The content of this Layer. Using *inline* (per ``code.isInline``) code is not permitted.\n   */\n  code: Code;\n\n  /**\n   * The description the this Lambda Layer.\n   */\n  description?: string;\n\n  /**\n   * The SPDX licence identifier or URL to the license file for this layer.\n   *\n   * @default no license information will be recorded.\n   */\n  license?: string;\n\n  /**\n   * The name of the layer.\n   * @default a name will be generated.\n   */\n  name?: string;\n}\n\nexport interface ILayerVersion extends cdk.IConstruct {\n  /**\n   * The ARN of the Lambda Layer version that this Layer defines.\n   */\n  readonly layerVersionArn: string;\n\n  /**\n   * The runtimes compatible with this Layer.\n   */\n  readonly compatibleRuntimes?: Runtime[];\n\n  /**\n   * Exports this layer for use in another Stack. The resulting object can be passed to the ``LayerVersion.import``\n   * function to obtain an ``ILayerVersion`` in the user stack.\n   */\n  export(): LayerVersionImportProps;\n\n  /**\n   * Grants usage of this layer to specific entities. Usage within the same account where the layer is defined is always\n   * allowed and does not require calling this method. Note that the principal that creates the Lambda function using\n   * the layer (for example, a CloudFormation changeset execution role) also needs to have the\n   * ``lambda:GetLayerVersion`` permission on the layer version.\n   *\n   * @param id the ID of the grant in the construct tree.\n   * @param grantee the identification of the grantee.\n   */\n  grantUsage(id: string, grantee: LayerVersionUsageGrantee): ILayerVersion\n}\n\n/**\n * A reference to a Lambda Layer version.\n */\nexport abstract class LayerVersionBase extends cdk.Construct implements ILayerVersion {\n  public abstract readonly layerVersionArn: string;\n  public abstract readonly compatibleRuntimes?: Runtime[];\n\n  public grantUsage(id: string, grantee: LayerVersionUsageGrantee): ILayerVersion {\n    if (grantee.organizationId != null && grantee.accountId !== '*') {\n      throw new Error(`OrganizationId can only be specified if AwsAccountId is '*', but it is ${grantee.accountId}`);\n    }\n\n    new CfnLayerVersionPermission(this, id, {\n      action: 'lambda:GetLayerVersion',\n      layerVersionArn: this.layerVersionArn,\n      principal: grantee.accountId,\n      organizationId: grantee.organizationId,\n    });\n    return this;\n  }\n\n  public export(): LayerVersionImportProps {\n    return {\n      layerVersionArn: new cdk.Output(this, 'LayerVersionArn', { value: this.layerVersionArn }).makeImportValue().toString(),\n      compatibleRuntimes: this.compatibleRuntimes,\n    };\n  }\n}\n\n/**\n * Identification of an account (or organization) that is allowed to access a Lambda Layer Version.\n */\nexport interface LayerVersionUsageGrantee {\n  /**\n   * The AWS Account id of the account that is authorized to use a Lambda Layer Version. The wild-card ``'*'`` can be\n   * used to grant access to \"any\" account (or any account in an organization when ``organizationId`` is specified).\n   */\n  accountId: string;\n\n  /**\n   * The ID of the AWS Organization to hwich the grant is restricted.\n   *\n   * Can only be specified if ``accountId`` is ``'*'``\n   */\n  organizationId?: string;\n}\n\n/**\n * Properties necessary to import a LayerVersion.\n */\nexport interface LayerVersionImportProps {\n  /**\n   * The ARN of the LayerVersion.\n   */\n  layerVersionArn: string;\n\n  /**\n   * The list of compatible runtimes with this Layer.\n   */\n  compatibleRuntimes?: Runtime[];\n}\n\n/**\n * Defines a new Lambda Layer version.\n */\nexport class LayerVersion extends LayerVersionBase {\n  /**\n   * Imports a Layer that has been defined externally.\n   *\n   * @param scope the parent Construct that will use the imported layer.\n   * @param id    the id of the imported layer in the construct tree.\n   * @param props the properties of the imported layer.\n   */\n  public static import(scope: cdk.Construct, id: string, props: LayerVersionImportProps): ILayerVersion {\n    return new ImportedLayerVersion(scope, id, props);\n  }\n\n  public readonly layerVersionArn: string;\n  public readonly compatibleRuntimes?: Runtime[];\n\n  constructor(scope: cdk.Construct, id: string, props: LayerVersionProps) {\n    super(scope, id);\n    if (props.compatibleRuntimes && props.compatibleRuntimes.length === 0) {\n      throw new Error('Attempted to define a Lambda layer that supports no runtime!');\n    }\n    if (props.code.isInline) {\n      throw new Error('Lambda layers cannot be created from inline code');\n    }\n    // Allow usage of the code in this context...\n    props.code.bind(this);\n\n    const resource = new CfnLayerVersion(this, 'Resource', {\n      compatibleRuntimes: props.compatibleRuntimes && props.compatibleRuntimes.map(r => r.name),\n      content: new cdk.Token(() => props.code._toJSON(resource)),\n      description: props.description,\n      layerName: props.name,\n      licenseInfo: props.license,\n    });\n\n    this.layerVersionArn = resource.layerVersionArn;\n    this.compatibleRuntimes = props.compatibleRuntimes;\n  }\n}\n\nclass ImportedLayerVersion extends LayerVersionBase {\n  public readonly layerVersionArn: string;\n  public readonly compatibleRuntimes?: Runtime[];\n\n  public constructor(parent: cdk.Construct, id: string, props: LayerVersionImportProps) {\n    super(parent, id);\n\n    if (props.compatibleRuntimes && props.compatibleRuntimes.length === 0) {\n      throw new Error('Attempted to import a Lambda layer that supports no runtime!');\n    }\n\n    this.layerVersionArn = props.layerVersionArn;\n    this.compatibleRuntimes = props.compatibleRuntimes;\n  }\n}\n\n/**\n * Properties of a Singleton Lambda Layer Version.\n */\nexport interface SingletonLayerVersionProps extends LayerVersionProps {\n  /**\n   * A unique identifier to identify this lambda layer version.\n   *\n   * The identifier should be unique across all layer providers.\n   * We recommend generating a UUID per provider.\n   */\n  uuid: string;\n}\n\n/**\n * A Singleton Lambda Layer Version. The construct gurantees exactly one LayerVersion will be created in a given Stack\n * for the provided ``uuid``. It is recommended to use ``uuidgen`` to create a new ``uuid`` each time a new singleton\n * layer is created.\n */\nexport class SingletonLayerVersion extends cdk.Construct implements ILayerVersion {\n  private readonly layerVersion: ILayerVersion;\n\n  constructor(scope: cdk.Construct, id: string, props: SingletonLayerVersionProps) {\n    super(scope, id);\n\n    this.layerVersion = this.ensureLayerVersion(props);\n  }\n\n  public get layerVersionArn(): string {\n    return this.layerVersion.layerVersionArn;\n  }\n\n  public get compatibleRuntimes(): Runtime[] | undefined {\n    return this.layerVersion.compatibleRuntimes;\n  }\n\n  public export(): LayerVersionImportProps {\n    return {\n      layerVersionArn: this.layerVersionArn,\n      compatibleRuntimes: this.compatibleRuntimes,\n    };\n  }\n\n  public grantUsage(id: string, grantee: LayerVersionUsageGrantee): ILayerVersion {\n    this.layerVersion.grantUsage(id, grantee);\n    return this;\n  }\n\n  private ensureLayerVersion(props: SingletonLayerVersionProps): ILayerVersion {\n    const singletonId = `SingletonLayer-${props.uuid}`;\n    const existing = this.node.stack.node.tryFindChild(singletonId);\n    if (existing) {\n      return existing as unknown as ILayerVersion;\n    }\n    return new LayerVersion(this.node.stack, singletonId, props);\n  }\n}\n"]} |
@@ -7,3 +7,3 @@ import codepipeline = require('@aws-cdk/aws-codepipeline-api'); | ||
* either directly, through its constructor, | ||
* or through {@link IFunction#addToPipeline}. | ||
* or through {@link IFunction#toCodePipelineInvokeAction}. | ||
*/ | ||
@@ -60,3 +60,3 @@ export interface CommonPipelineInvokeActionProps extends codepipeline.CommonActionProps { | ||
*/ | ||
export interface PipelineInvokeActionProps extends CommonPipelineInvokeActionProps, codepipeline.CommonActionConstructProps { | ||
export interface PipelineInvokeActionProps extends CommonPipelineInvokeActionProps { | ||
/** | ||
@@ -73,5 +73,7 @@ * The lambda function to invoke. | ||
export declare class PipelineInvokeAction extends codepipeline.Action { | ||
constructor(scope: cdk.Construct, id: string, props: PipelineInvokeActionProps); | ||
private readonly props; | ||
constructor(props: PipelineInvokeActionProps); | ||
outputArtifacts(): codepipeline.Artifact[]; | ||
outputArtifact(artifactName: string): codepipeline.Artifact; | ||
protected bind(stage: codepipeline.IStage, _scope: cdk.Construct): void; | ||
} |
@@ -11,4 +11,4 @@ "use strict"; | ||
class PipelineInvokeAction extends codepipeline.Action { | ||
constructor(scope, id, props) { | ||
super(scope, id, Object.assign({}, props, { category: codepipeline.ActionCategory.Invoke, provider: 'Lambda', artifactBounds: codepipeline.defaultBounds(), configuration: { | ||
constructor(props) { | ||
super(Object.assign({}, props, { category: codepipeline.ActionCategory.Invoke, provider: 'Lambda', artifactBounds: codepipeline.defaultBounds(), configuration: { | ||
FunctionName: props.lambda.functionName, | ||
@@ -25,14 +25,29 @@ UserParameters: props.userParameters | ||
} | ||
this.props = props; | ||
} | ||
outputArtifacts() { | ||
return this._outputArtifacts; | ||
} | ||
outputArtifact(artifactName) { | ||
const result = this._outputArtifacts.find(a => (a.artifactName === artifactName)); | ||
if (result === undefined) { | ||
throw new Error(`Could not find the output Artifact with name '${artifactName}'`); | ||
} | ||
else { | ||
return result; | ||
} | ||
} | ||
bind(stage, _scope) { | ||
// allow pipeline to list functions | ||
props.stage.pipeline.role.addToPolicy(new iam.PolicyStatement() | ||
stage.pipeline.role.addToPolicy(new iam.PolicyStatement() | ||
.addAction('lambda:ListFunctions') | ||
.addAllResources()); | ||
// allow pipeline to invoke this lambda functionn | ||
props.stage.pipeline.role.addToPolicy(new iam.PolicyStatement() | ||
stage.pipeline.role.addToPolicy(new iam.PolicyStatement() | ||
.addAction('lambda:InvokeFunction') | ||
.addResource(props.lambda.functionArn)); | ||
.addResource(this.props.lambda.functionArn)); | ||
// allow lambda to put job results for this pipeline. | ||
const addToPolicy = props.addPutJobResultPolicy !== undefined ? props.addPutJobResultPolicy : true; | ||
const addToPolicy = this.props.addPutJobResultPolicy !== undefined ? this.props.addPutJobResultPolicy : true; | ||
if (addToPolicy) { | ||
props.lambda.addToRolePolicy(new iam.PolicyStatement() | ||
this.props.lambda.addToRolePolicy(new iam.PolicyStatement() | ||
.addAllResources() // to avoid cycles (see docs) | ||
@@ -43,16 +58,4 @@ .addAction('codepipeline:PutJobSuccessResult') | ||
} | ||
outputArtifacts() { | ||
return this._outputArtifacts; | ||
} | ||
outputArtifact(artifactName) { | ||
const result = this._outputArtifacts.find(a => (a.name === artifactName)); | ||
if (result === undefined) { | ||
throw new Error(`Could not find the output Artifact with name '${artifactName}'`); | ||
} | ||
else { | ||
return result; | ||
} | ||
} | ||
} | ||
exports.PipelineInvokeAction = PipelineInvokeAction; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline-action.js","sourceRoot":"","sources":["pipeline-action.ts"],"names":[],"mappings":";;AAAA,8DAA+D;AAC/D,wCAAyC;AA4EzC;;;;GAIG;AACH,MAAa,oBAAqB,SAAQ,YAAY,CAAC,MAAM;IAC3D,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAgC;QAC5E,KAAK,CAAC,KAAK,EAAE,EAAE,oBACV,KAAK,IACR,QAAQ,EAAE,YAAY,CAAC,cAAc,CAAC,MAAM,EAC5C,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE,YAAY,CAAC,aAAa,EAAE,EAC5C,aAAa,EAAE;gBACb,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC,YAAY;gBACvC,cAAc,EAAE,KAAK,CAAC,cAAc;aACrC,IACD,CAAC;QAEH,yBAAyB;QACzB,KAAK,MAAM,aAAa,IAAI,KAAK,CAAC,cAAc,IAAI,EAAE,EAAE;YACtD,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;SACtC;QAED,0BAA0B;QAC1B,KAAK,MAAM,kBAAkB,IAAI,KAAK,CAAC,mBAAmB,IAAI,EAAE,EAAE;YAChE,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC;SAC5C;QAED,mCAAmC;QACnC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;aAC5D,SAAS,CAAC,sBAAsB,CAAC;aACjC,eAAe,EAAE,CAAC,CAAC;QAEtB,iDAAiD;QACjD,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;aAC5D,SAAS,CAAC,uBAAuB,CAAC;aAClC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;QAE1C,qDAAqD;QACrD,MAAM,WAAW,GAAG,KAAK,CAAC,qBAAqB,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC;QACnG,IAAI,WAAW,EAAE;YACf,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;iBACnD,eAAe,EAAE,CAAC,6BAA6B;iBAC/C,SAAS,CAAC,kCAAkC,CAAC;iBAC7C,SAAS,CAAC,kCAAkC,CAAC,CAAC,CAAC;SACnD;IACH,CAAC;IAEM,eAAe;QACpB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAEM,cAAc,CAAC,YAAoB;QACxC,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC,CAAC;QAC1E,IAAI,MAAM,KAAK,SAAS,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,iDAAiD,YAAY,GAAG,CAAC,CAAC;SACnF;aAAM;YACL,OAAO,MAAM,CAAC;SACf;IACH,CAAC;CACF;AAvDD,oDAuDC","sourcesContent":["import codepipeline = require('@aws-cdk/aws-codepipeline-api');\nimport iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/cdk');\nimport { IFunction } from './function-base';\n\n/**\n * Common properties for creating a {@link PipelineInvokeAction} -\n * either directly, through its constructor,\n * or through {@link IFunction#addToPipeline}.\n */\nexport interface CommonPipelineInvokeActionProps extends codepipeline.CommonActionProps {\n  // because of @see links\n  // tslint:disable:max-line-length\n\n  /**\n   * The optional input Artifacts of the Action.\n   * A Lambda Action can have up to 5 inputs.\n   * The inputs will appear in the event passed to the Lambda,\n   * under the `'CodePipeline.job'.data.inputArtifacts` path.\n   *\n   * @default the Action will not have any inputs\n   * @see https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-json-event-example\n   */\n  inputArtifacts?: codepipeline.Artifact[];\n\n  // tslint:enable:max-line-length\n\n  /**\n   * The optional names of the output Artifacts of the Action.\n   * A Lambda Action can have up to 5 outputs.\n   * The outputs will appear in the event passed to the Lambda,\n   * under the `'CodePipeline.job'.data.outputArtifacts` path.\n   * It is the responsibility of the Lambda to upload ZIP files with the Artifact contents to the provided locations.\n   *\n   * @default the Action will not have any outputs\n   */\n  outputArtifactNames?: string[];\n\n  /**\n   * String to be used in the event data parameter passed to the Lambda\n   * function\n   *\n   * See an example JSON event in the CodePipeline documentation.\n   *\n   * https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-json-event-example\n   */\n  userParameters?: any;\n\n  /**\n   * Adds the \"codepipeline:PutJobSuccessResult\" and\n   * \"codepipeline:PutJobFailureResult\" for '*' resource to the Lambda\n   * execution role policy.\n   *\n   * NOTE: the reason we can't add the specific pipeline ARN as a resource is\n   * to avoid a cyclic dependency between the pipeline and the Lambda function\n   * (the pipeline references) the Lambda and the Lambda needs permissions on\n   * the pipeline.\n   *\n   * @see\n   * https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-create-function\n   *\n   * @default true\n   */\n  addPutJobResultPolicy?: boolean;\n}\n\n/**\n * Construction properties of the {@link PipelineInvokeAction Lambda invoke CodePipeline Action}.\n */\nexport interface PipelineInvokeActionProps extends CommonPipelineInvokeActionProps,\n    codepipeline.CommonActionConstructProps {\n  /**\n   * The lambda function to invoke.\n   */\n  lambda: IFunction;\n}\n\n/**\n * CodePipeline invoke Action that is provided by an AWS Lambda function.\n *\n * @see https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html\n */\nexport class PipelineInvokeAction extends codepipeline.Action {\n  constructor(scope: cdk.Construct, id: string, props: PipelineInvokeActionProps) {\n    super(scope, id, {\n      ...props,\n      category: codepipeline.ActionCategory.Invoke,\n      provider: 'Lambda',\n      artifactBounds: codepipeline.defaultBounds(),\n      configuration: {\n        FunctionName: props.lambda.functionName,\n        UserParameters: props.userParameters\n      }\n    });\n\n    // handle input artifacts\n    for (const inputArtifact of props.inputArtifacts || []) {\n      this.addInputArtifact(inputArtifact);\n    }\n\n    // handle output artifacts\n    for (const outputArtifactName of props.outputArtifactNames || []) {\n      this.addOutputArtifact(outputArtifactName);\n    }\n\n    // allow pipeline to list functions\n    props.stage.pipeline.role.addToPolicy(new iam.PolicyStatement()\n      .addAction('lambda:ListFunctions')\n      .addAllResources());\n\n    // allow pipeline to invoke this lambda functionn\n    props.stage.pipeline.role.addToPolicy(new iam.PolicyStatement()\n      .addAction('lambda:InvokeFunction')\n      .addResource(props.lambda.functionArn));\n\n    // allow lambda to put job results for this pipeline.\n    const addToPolicy = props.addPutJobResultPolicy !== undefined ? props.addPutJobResultPolicy : true;\n    if (addToPolicy) {\n      props.lambda.addToRolePolicy(new iam.PolicyStatement()\n        .addAllResources() // to avoid cycles (see docs)\n        .addAction('codepipeline:PutJobSuccessResult')\n        .addAction('codepipeline:PutJobFailureResult'));\n    }\n  }\n\n  public outputArtifacts(): codepipeline.Artifact[] {\n    return this._outputArtifacts;\n  }\n\n  public outputArtifact(artifactName: string): codepipeline.Artifact {\n    const result = this._outputArtifacts.find(a => (a.name === artifactName));\n    if (result === undefined) {\n      throw new Error(`Could not find the output Artifact with name '${artifactName}'`);\n    } else {\n      return result;\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline-action.js","sourceRoot":"","sources":["pipeline-action.ts"],"names":[],"mappings":";;AAAA,8DAA+D;AAC/D,wCAAyC;AA2EzC;;;;GAIG;AACH,MAAa,oBAAqB,SAAQ,YAAY,CAAC,MAAM;IAG3D,YAAY,KAAgC;QAC1C,KAAK,mBACA,KAAK,IACR,QAAQ,EAAE,YAAY,CAAC,cAAc,CAAC,MAAM,EAC5C,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE,YAAY,CAAC,aAAa,EAAE,EAC5C,aAAa,EAAE;gBACb,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC,YAAY;gBACvC,cAAc,EAAE,KAAK,CAAC,cAAc;aACrC,IACD,CAAC;QAEH,yBAAyB;QACzB,KAAK,MAAM,aAAa,IAAI,KAAK,CAAC,cAAc,IAAI,EAAE,EAAE;YACtD,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;SACtC;QAED,0BAA0B;QAC1B,KAAK,MAAM,kBAAkB,IAAI,KAAK,CAAC,mBAAmB,IAAI,EAAE,EAAE;YAChE,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC;SAC5C;QAED,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAEM,eAAe;QACpB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAEM,cAAc,CAAC,YAAoB;QACxC,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,KAAK,YAAY,CAAC,CAAC,CAAC;QAClF,IAAI,MAAM,KAAK,SAAS,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,iDAAiD,YAAY,GAAG,CAAC,CAAC;SACnF;aAAM;YACL,OAAO,MAAM,CAAC;SACf;IACH,CAAC;IAES,IAAI,CAAC,KAA0B,EAAE,MAAqB;QAC9D,mCAAmC;QACnC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;aACtD,SAAS,CAAC,sBAAsB,CAAC;aACjC,eAAe,EAAE,CAAC,CAAC;QAEtB,iDAAiD;QACjD,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;aACtD,SAAS,CAAC,uBAAuB,CAAC;aAClC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;QAE/C,qDAAqD;QACrD,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,qBAAqB,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC;QAC7G,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;iBACxD,eAAe,EAAE,CAAC,6BAA6B;iBAC/C,SAAS,CAAC,kCAAkC,CAAC;iBAC7C,SAAS,CAAC,kCAAkC,CAAC,CAAC,CAAC;SACnD;IACH,CAAC;CACF;AA7DD,oDA6DC","sourcesContent":["import codepipeline = require('@aws-cdk/aws-codepipeline-api');\nimport iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/cdk');\nimport { IFunction } from './function-base';\n\n/**\n * Common properties for creating a {@link PipelineInvokeAction} -\n * either directly, through its constructor,\n * or through {@link IFunction#toCodePipelineInvokeAction}.\n */\nexport interface CommonPipelineInvokeActionProps extends codepipeline.CommonActionProps {\n  // because of @see links\n  // tslint:disable:max-line-length\n\n  /**\n   * The optional input Artifacts of the Action.\n   * A Lambda Action can have up to 5 inputs.\n   * The inputs will appear in the event passed to the Lambda,\n   * under the `'CodePipeline.job'.data.inputArtifacts` path.\n   *\n   * @default the Action will not have any inputs\n   * @see https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-json-event-example\n   */\n  inputArtifacts?: codepipeline.Artifact[];\n\n  // tslint:enable:max-line-length\n\n  /**\n   * The optional names of the output Artifacts of the Action.\n   * A Lambda Action can have up to 5 outputs.\n   * The outputs will appear in the event passed to the Lambda,\n   * under the `'CodePipeline.job'.data.outputArtifacts` path.\n   * It is the responsibility of the Lambda to upload ZIP files with the Artifact contents to the provided locations.\n   *\n   * @default the Action will not have any outputs\n   */\n  outputArtifactNames?: string[];\n\n  /**\n   * String to be used in the event data parameter passed to the Lambda\n   * function\n   *\n   * See an example JSON event in the CodePipeline documentation.\n   *\n   * https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-json-event-example\n   */\n  userParameters?: any;\n\n  /**\n   * Adds the \"codepipeline:PutJobSuccessResult\" and\n   * \"codepipeline:PutJobFailureResult\" for '*' resource to the Lambda\n   * execution role policy.\n   *\n   * NOTE: the reason we can't add the specific pipeline ARN as a resource is\n   * to avoid a cyclic dependency between the pipeline and the Lambda function\n   * (the pipeline references) the Lambda and the Lambda needs permissions on\n   * the pipeline.\n   *\n   * @see\n   * https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html#actions-invoke-lambda-function-create-function\n   *\n   * @default true\n   */\n  addPutJobResultPolicy?: boolean;\n}\n\n/**\n * Construction properties of the {@link PipelineInvokeAction Lambda invoke CodePipeline Action}.\n */\nexport interface PipelineInvokeActionProps extends CommonPipelineInvokeActionProps {\n  /**\n   * The lambda function to invoke.\n   */\n  lambda: IFunction;\n}\n\n/**\n * CodePipeline invoke Action that is provided by an AWS Lambda function.\n *\n * @see https://docs.aws.amazon.com/codepipeline/latest/userguide/actions-invoke-lambda-function.html\n */\nexport class PipelineInvokeAction extends codepipeline.Action {\n  private readonly props: PipelineInvokeActionProps;\n\n  constructor(props: PipelineInvokeActionProps) {\n    super({\n      ...props,\n      category: codepipeline.ActionCategory.Invoke,\n      provider: 'Lambda',\n      artifactBounds: codepipeline.defaultBounds(),\n      configuration: {\n        FunctionName: props.lambda.functionName,\n        UserParameters: props.userParameters\n      }\n    });\n\n    // handle input artifacts\n    for (const inputArtifact of props.inputArtifacts || []) {\n      this.addInputArtifact(inputArtifact);\n    }\n\n    // handle output artifacts\n    for (const outputArtifactName of props.outputArtifactNames || []) {\n      this.addOutputArtifact(outputArtifactName);\n    }\n\n    this.props = props;\n  }\n\n  public outputArtifacts(): codepipeline.Artifact[] {\n    return this._outputArtifacts;\n  }\n\n  public outputArtifact(artifactName: string): codepipeline.Artifact {\n    const result = this._outputArtifacts.find(a => (a.artifactName === artifactName));\n    if (result === undefined) {\n      throw new Error(`Could not find the output Artifact with name '${artifactName}'`);\n    } else {\n      return result;\n    }\n  }\n\n  protected bind(stage: codepipeline.IStage, _scope: cdk.Construct): void {\n    // allow pipeline to list functions\n    stage.pipeline.role.addToPolicy(new iam.PolicyStatement()\n      .addAction('lambda:ListFunctions')\n      .addAllResources());\n\n    // allow pipeline to invoke this lambda functionn\n    stage.pipeline.role.addToPolicy(new iam.PolicyStatement()\n      .addAction('lambda:InvokeFunction')\n      .addResource(this.props.lambda.functionArn));\n\n    // allow lambda to put job results for this pipeline.\n    const addToPolicy = this.props.addPutJobResultPolicy !== undefined ? this.props.addPutJobResultPolicy : true;\n    if (addToPolicy) {\n      this.props.lambda.addToRolePolicy(new iam.PolicyStatement()\n        .addAllResources() // to avoid cycles (see docs)\n        .addAction('codepipeline:PutJobSuccessResult')\n        .addAction('codepipeline:PutJobFailureResult'));\n    }\n  }\n}\n"]} |
@@ -14,3 +14,4 @@ export interface LambdaRuntimeProps { | ||
Go = 4, | ||
Ruby = 5 | ||
Ruby = 5, | ||
Other = 6 | ||
} | ||
@@ -39,2 +40,3 @@ /** | ||
static readonly Ruby25: Runtime; | ||
static readonly Provided: Runtime; | ||
/** | ||
@@ -41,0 +43,0 @@ * The name of this runtime, as expected by the Lambda resource. |
@@ -11,2 +11,3 @@ "use strict"; | ||
RuntimeFamily[RuntimeFamily["Ruby"] = 5] = "Ruby"; | ||
RuntimeFamily[RuntimeFamily["Other"] = 6] = "Other"; | ||
})(RuntimeFamily = exports.RuntimeFamily || (exports.RuntimeFamily = {})); | ||
@@ -45,3 +46,4 @@ /** | ||
Runtime.Ruby25 = new Runtime('ruby2.5', RuntimeFamily.Ruby, { supportsInlineCode: true }); | ||
Runtime.Provided = new Runtime('provided', RuntimeFamily.Other); | ||
exports.Runtime = Runtime; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInJ1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFRQSxJQUFZLGFBT1g7QUFQRCxXQUFZLGFBQWE7SUFDdkIscURBQU0sQ0FBQTtJQUNOLGlEQUFJLENBQUE7SUFDSixxREFBTSxDQUFBO0lBQ04sNkRBQVUsQ0FBQTtJQUNWLDZDQUFFLENBQUE7SUFDRixpREFBSSxDQUFBO0FBQ04sQ0FBQyxFQVBXLGFBQWEsR0FBYixxQkFBYSxLQUFiLHFCQUFhLFFBT3hCO0FBRUQ7Ozs7O0dBS0c7QUFDSCxNQUFhLE9BQU87SUFrQ2xCLFlBQVksSUFBWSxFQUFFLE1BQXNCLEVBQUUsUUFBNEIsRUFBRztRQUMvRSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLENBQUMsa0JBQWtCLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQztRQUNyRCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUVyQixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBRU0sUUFBUTtRQUNiLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDOztBQTNDRCwyQ0FBMkM7QUFDcEIsV0FBRyxHQUFHLElBQUksS0FBSyxFQUFXLENBQUM7QUFFM0IsY0FBTSxHQUFTLElBQUksT0FBTyxDQUFDLFFBQVEsRUFBVSxhQUFhLENBQUMsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRyxnQkFBUSxHQUFPLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBTyxhQUFhLENBQUMsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRyxpQkFBUyxHQUFNLElBQUksT0FBTyxDQUFDLFlBQVksRUFBTSxhQUFhLENBQUMsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRyxpQkFBUyxHQUFNLElBQUksT0FBTyxDQUFDLFlBQVksRUFBTSxhQUFhLENBQUMsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRyxnQkFBUSxHQUFPLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBTyxhQUFhLENBQUMsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRyxnQkFBUSxHQUFPLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBTyxhQUFhLENBQUMsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRyxnQkFBUSxHQUFPLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBTyxhQUFhLENBQUMsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRyxhQUFLLEdBQVUsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFXLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUNqRSxtQkFBVyxHQUFJLElBQUksT0FBTyxDQUFDLGVBQWUsRUFBRyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7QUFDdkUsbUJBQVcsR0FBSSxJQUFJLE9BQU8sQ0FBQyxlQUFlLEVBQUcsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQ3ZFLG9CQUFZLEdBQUcsSUFBSSxPQUFPLENBQUMsZUFBZSxFQUFHLGFBQWEsQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUN2RSxZQUFJLEdBQVcsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFXLGFBQWEsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUMvRCxjQUFNLEdBQVMsSUFBSSxPQUFPLENBQUMsU0FBUyxFQUFTLGFBQWEsQ0FBQyxJQUFJLEVBQUUsRUFBRSxrQkFBa0IsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0FBaEJ4SCwwQkE2Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIExhbWJkYVJ1bnRpbWVQcm9wcyB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBgYFppcEZpbGVgYCAoYWthIGlubGluZSBjb2RlKSBwcm9wZXJ0eSBjYW4gYmUgdXNlZCB3aXRoIHRoaXMgcnVudGltZS5cbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHN1cHBvcnRzSW5saW5lQ29kZT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBlbnVtIFJ1bnRpbWVGYW1pbHkge1xuICBOb2RlSlMsXG4gIEphdmEsXG4gIFB5dGhvbixcbiAgRG90TmV0Q29yZSxcbiAgR28sXG4gIFJ1Ynlcbn1cblxuLyoqXG4gKiBMYW1iZGEgZnVuY3Rpb24gcnVudGltZSBlbnZpcm9ubWVudC5cbiAqXG4gKiBJZiB5b3UgbmVlZCB0byB1c2UgYSBydW50aW1lIG5hbWUgdGhhdCBkb2Vzbid0IGV4aXN0IGFzIGEgc3RhdGljIG1lbWJlciwgeW91XG4gKiBjYW4gaW5zdGFudGlhdGUgYSBgUnVudGltZWAgb2JqZWN0LCBlLmc6IGBuZXcgUnVudGltZSgnbm9kZWpzOTkuOTknKWAuXG4gKi9cbmV4cG9ydCBjbGFzcyBSdW50aW1lIHtcbiAgLyoqIEEgbGlzdCBvZiBhbGwgdGhlIGtub3cgYGBSdW50aW1lYGBzLiAqL1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IEFsbCA9IG5ldyBBcnJheTxSdW50aW1lPigpO1xuXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgTm9kZUpTID0gICAgICAgbmV3IFJ1bnRpbWUoJ25vZGVqcycsICAgICAgICAgUnVudGltZUZhbWlseS5Ob2RlSlMsIHsgc3VwcG9ydHNJbmxpbmVDb2RlOiB0cnVlIH0pO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IE5vZGVKUzQzID0gICAgIG5ldyBSdW50aW1lKCdub2RlanM0LjMnLCAgICAgIFJ1bnRpbWVGYW1pbHkuTm9kZUpTLCB7IHN1cHBvcnRzSW5saW5lQ29kZTogdHJ1ZSB9KTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBOb2RlSlM2MTAgPSAgICBuZXcgUnVudGltZSgnbm9kZWpzNi4xMCcsICAgICBSdW50aW1lRmFtaWx5Lk5vZGVKUywgeyBzdXBwb3J0c0lubGluZUNvZGU6IHRydWUgfSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgTm9kZUpTODEwID0gICAgbmV3IFJ1bnRpbWUoJ25vZGVqczguMTAnLCAgICAgUnVudGltZUZhbWlseS5Ob2RlSlMsIHsgc3VwcG9ydHNJbmxpbmVDb2RlOiB0cnVlIH0pO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IFB5dGhvbjI3ID0gICAgIG5ldyBSdW50aW1lKCdweXRob24yLjcnLCAgICAgIFJ1bnRpbWVGYW1pbHkuUHl0aG9uLCB7IHN1cHBvcnRzSW5saW5lQ29kZTogdHJ1ZSB9KTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBQeXRob24zNiA9ICAgICBuZXcgUnVudGltZSgncHl0aG9uMy42JywgICAgICBSdW50aW1lRmFtaWx5LlB5dGhvbiwgeyBzdXBwb3J0c0lubGluZUNvZGU6IHRydWUgfSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgUHl0aG9uMzcgPSAgICAgbmV3IFJ1bnRpbWUoJ3B5dGhvbjMuNycsICAgICAgUnVudGltZUZhbWlseS5QeXRob24sIHsgc3VwcG9ydHNJbmxpbmVDb2RlOiB0cnVlIH0pO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IEphdmE4ID0gICAgICAgIG5ldyBSdW50aW1lKCdqYXZhOCcsICAgICAgICAgIFJ1bnRpbWVGYW1pbHkuSmF2YSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgRG90TmV0Q29yZTEgPSAgbmV3IFJ1bnRpbWUoJ2RvdG5ldGNvcmUxLjAnLCAgUnVudGltZUZhbWlseS5Eb3ROZXRDb3JlKTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBEb3ROZXRDb3JlMiA9ICBuZXcgUnVudGltZSgnZG90bmV0Y29yZTIuMCcsICBSdW50aW1lRmFtaWx5LkRvdE5ldENvcmUpO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IERvdE5ldENvcmUyMSA9IG5ldyBSdW50aW1lKCdkb3RuZXRjb3JlMi4xJywgIFJ1bnRpbWVGYW1pbHkuRG90TmV0Q29yZSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgR28xeCA9ICAgICAgICAgbmV3IFJ1bnRpbWUoJ2dvMS54JywgICAgICAgICAgUnVudGltZUZhbWlseS5Hbyk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgUnVieTI1ID0gICAgICAgbmV3IFJ1bnRpbWUoJ3J1YnkyLjUnLCAgICAgICAgUnVudGltZUZhbWlseS5SdWJ5LCB7IHN1cHBvcnRzSW5saW5lQ29kZTogdHJ1ZSB9KTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhpcyBydW50aW1lLCBhcyBleHBlY3RlZCBieSB0aGUgTGFtYmRhIHJlc291cmNlLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgYGBaaXBGaWxlYGAgKGFrYSBpbmxpbmUgY29kZSkgcHJvcGVydHkgY2FuIGJlIHVzZWQgd2l0aCB0aGlzXG4gICAqIHJ1bnRpbWUuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgc3VwcG9ydHNJbmxpbmVDb2RlOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBUaGUgcnVudGltZSBmYW1pbHkuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZmFtaWx5PzogUnVudGltZUZhbWlseTtcblxuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcsIGZhbWlseT86IFJ1bnRpbWVGYW1pbHksIHByb3BzOiBMYW1iZGFSdW50aW1lUHJvcHMgPSB7IH0pIHtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICAgIHRoaXMuc3VwcG9ydHNJbmxpbmVDb2RlID0gISFwcm9wcy5zdXBwb3J0c0lubGluZUNvZGU7XG4gICAgdGhpcy5mYW1pbHkgPSBmYW1pbHk7XG5cbiAgICBSdW50aW1lLkFsbC5wdXNoKHRoaXMpO1xuICB9XG5cbiAgcHVibGljIHRvU3RyaW5nKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubmFtZTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInJ1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFRQSxJQUFZLGFBUVg7QUFSRCxXQUFZLGFBQWE7SUFDdkIscURBQU0sQ0FBQTtJQUNOLGlEQUFJLENBQUE7SUFDSixxREFBTSxDQUFBO0lBQ04sNkRBQVUsQ0FBQTtJQUNWLDZDQUFFLENBQUE7SUFDRixpREFBSSxDQUFBO0lBQ0osbURBQUssQ0FBQTtBQUNQLENBQUMsRUFSVyxhQUFhLEdBQWIscUJBQWEsS0FBYixxQkFBYSxRQVF4QjtBQUVEOzs7OztHQUtHO0FBQ0gsTUFBYSxPQUFPO0lBbUNsQixZQUFZLElBQVksRUFBRSxNQUFzQixFQUFFLFFBQTRCLEVBQUc7UUFDL0UsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLGtCQUFrQixHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUM7UUFDckQsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFFckIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVNLFFBQVE7UUFDYixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQzs7QUE1Q0QsMkNBQTJDO0FBQ3BCLFdBQUcsR0FBRyxJQUFJLEtBQUssRUFBVyxDQUFDO0FBRTNCLGNBQU0sR0FBUyxJQUFJLE9BQU8sQ0FBQyxRQUFRLEVBQVUsYUFBYSxDQUFDLE1BQU0sRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDakcsZ0JBQVEsR0FBTyxJQUFJLE9BQU8sQ0FBQyxXQUFXLEVBQU8sYUFBYSxDQUFDLE1BQU0sRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDakcsaUJBQVMsR0FBTSxJQUFJLE9BQU8sQ0FBQyxZQUFZLEVBQU0sYUFBYSxDQUFDLE1BQU0sRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDakcsaUJBQVMsR0FBTSxJQUFJLE9BQU8sQ0FBQyxZQUFZLEVBQU0sYUFBYSxDQUFDLE1BQU0sRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDakcsZ0JBQVEsR0FBTyxJQUFJLE9BQU8sQ0FBQyxXQUFXLEVBQU8sYUFBYSxDQUFDLE1BQU0sRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDakcsZ0JBQVEsR0FBTyxJQUFJLE9BQU8sQ0FBQyxXQUFXLEVBQU8sYUFBYSxDQUFDLE1BQU0sRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDakcsZ0JBQVEsR0FBTyxJQUFJLE9BQU8sQ0FBQyxXQUFXLEVBQU8sYUFBYSxDQUFDLE1BQU0sRUFBRSxFQUFFLGtCQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDakcsYUFBSyxHQUFVLElBQUksT0FBTyxDQUFDLE9BQU8sRUFBVyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7QUFDakUsbUJBQVcsR0FBSSxJQUFJLE9BQU8sQ0FBQyxlQUFlLEVBQUcsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQ3ZFLG1CQUFXLEdBQUksSUFBSSxPQUFPLENBQUMsZUFBZSxFQUFHLGFBQWEsQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUN2RSxvQkFBWSxHQUFHLElBQUksT0FBTyxDQUFDLGVBQWUsRUFBRyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7QUFDdkUsWUFBSSxHQUFXLElBQUksT0FBTyxDQUFDLE9BQU8sRUFBVyxhQUFhLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDL0QsY0FBTSxHQUFTLElBQUksT0FBTyxDQUFDLFNBQVMsRUFBUyxhQUFhLENBQUMsSUFBSSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUMvRixnQkFBUSxHQUFPLElBQUksT0FBTyxDQUFDLFVBQVUsRUFBUSxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7QUFqQjNGLDBCQThDQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgTGFtYmRhUnVudGltZVByb3BzIHtcbiAgLyoqXG4gICAqIFdoZXRoZXIgdGhlIGBgWmlwRmlsZWBgIChha2EgaW5saW5lIGNvZGUpIHByb3BlcnR5IGNhbiBiZSB1c2VkIHdpdGggdGhpcyBydW50aW1lLlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgc3VwcG9ydHNJbmxpbmVDb2RlPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGVudW0gUnVudGltZUZhbWlseSB7XG4gIE5vZGVKUyxcbiAgSmF2YSxcbiAgUHl0aG9uLFxuICBEb3ROZXRDb3JlLFxuICBHbyxcbiAgUnVieSxcbiAgT3RoZXJcbn1cblxuLyoqXG4gKiBMYW1iZGEgZnVuY3Rpb24gcnVudGltZSBlbnZpcm9ubWVudC5cbiAqXG4gKiBJZiB5b3UgbmVlZCB0byB1c2UgYSBydW50aW1lIG5hbWUgdGhhdCBkb2Vzbid0IGV4aXN0IGFzIGEgc3RhdGljIG1lbWJlciwgeW91XG4gKiBjYW4gaW5zdGFudGlhdGUgYSBgUnVudGltZWAgb2JqZWN0LCBlLmc6IGBuZXcgUnVudGltZSgnbm9kZWpzOTkuOTknKWAuXG4gKi9cbmV4cG9ydCBjbGFzcyBSdW50aW1lIHtcbiAgLyoqIEEgbGlzdCBvZiBhbGwgdGhlIGtub3cgYGBSdW50aW1lYGBzLiAqL1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IEFsbCA9IG5ldyBBcnJheTxSdW50aW1lPigpO1xuXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgTm9kZUpTID0gICAgICAgbmV3IFJ1bnRpbWUoJ25vZGVqcycsICAgICAgICAgUnVudGltZUZhbWlseS5Ob2RlSlMsIHsgc3VwcG9ydHNJbmxpbmVDb2RlOiB0cnVlIH0pO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IE5vZGVKUzQzID0gICAgIG5ldyBSdW50aW1lKCdub2RlanM0LjMnLCAgICAgIFJ1bnRpbWVGYW1pbHkuTm9kZUpTLCB7IHN1cHBvcnRzSW5saW5lQ29kZTogdHJ1ZSB9KTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBOb2RlSlM2MTAgPSAgICBuZXcgUnVudGltZSgnbm9kZWpzNi4xMCcsICAgICBSdW50aW1lRmFtaWx5Lk5vZGVKUywgeyBzdXBwb3J0c0lubGluZUNvZGU6IHRydWUgfSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgTm9kZUpTODEwID0gICAgbmV3IFJ1bnRpbWUoJ25vZGVqczguMTAnLCAgICAgUnVudGltZUZhbWlseS5Ob2RlSlMsIHsgc3VwcG9ydHNJbmxpbmVDb2RlOiB0cnVlIH0pO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IFB5dGhvbjI3ID0gICAgIG5ldyBSdW50aW1lKCdweXRob24yLjcnLCAgICAgIFJ1bnRpbWVGYW1pbHkuUHl0aG9uLCB7IHN1cHBvcnRzSW5saW5lQ29kZTogdHJ1ZSB9KTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBQeXRob24zNiA9ICAgICBuZXcgUnVudGltZSgncHl0aG9uMy42JywgICAgICBSdW50aW1lRmFtaWx5LlB5dGhvbiwgeyBzdXBwb3J0c0lubGluZUNvZGU6IHRydWUgfSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgUHl0aG9uMzcgPSAgICAgbmV3IFJ1bnRpbWUoJ3B5dGhvbjMuNycsICAgICAgUnVudGltZUZhbWlseS5QeXRob24sIHsgc3VwcG9ydHNJbmxpbmVDb2RlOiB0cnVlIH0pO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IEphdmE4ID0gICAgICAgIG5ldyBSdW50aW1lKCdqYXZhOCcsICAgICAgICAgIFJ1bnRpbWVGYW1pbHkuSmF2YSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgRG90TmV0Q29yZTEgPSAgbmV3IFJ1bnRpbWUoJ2RvdG5ldGNvcmUxLjAnLCAgUnVudGltZUZhbWlseS5Eb3ROZXRDb3JlKTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBEb3ROZXRDb3JlMiA9ICBuZXcgUnVudGltZSgnZG90bmV0Y29yZTIuMCcsICBSdW50aW1lRmFtaWx5LkRvdE5ldENvcmUpO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IERvdE5ldENvcmUyMSA9IG5ldyBSdW50aW1lKCdkb3RuZXRjb3JlMi4xJywgIFJ1bnRpbWVGYW1pbHkuRG90TmV0Q29yZSk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgR28xeCA9ICAgICAgICAgbmV3IFJ1bnRpbWUoJ2dvMS54JywgICAgICAgICAgUnVudGltZUZhbWlseS5Hbyk7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgUnVieTI1ID0gICAgICAgbmV3IFJ1bnRpbWUoJ3J1YnkyLjUnLCAgICAgICAgUnVudGltZUZhbWlseS5SdWJ5LCB7IHN1cHBvcnRzSW5saW5lQ29kZTogdHJ1ZSB9KTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBQcm92aWRlZCA9ICAgICBuZXcgUnVudGltZSgncHJvdmlkZWQnLCAgICAgICBSdW50aW1lRmFtaWx5Lk90aGVyKTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhpcyBydW50aW1lLCBhcyBleHBlY3RlZCBieSB0aGUgTGFtYmRhIHJlc291cmNlLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgYGBaaXBGaWxlYGAgKGFrYSBpbmxpbmUgY29kZSkgcHJvcGVydHkgY2FuIGJlIHVzZWQgd2l0aCB0aGlzXG4gICAqIHJ1bnRpbWUuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgc3VwcG9ydHNJbmxpbmVDb2RlOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBUaGUgcnVudGltZSBmYW1pbHkuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZmFtaWx5PzogUnVudGltZUZhbWlseTtcblxuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcsIGZhbWlseT86IFJ1bnRpbWVGYW1pbHksIHByb3BzOiBMYW1iZGFSdW50aW1lUHJvcHMgPSB7IH0pIHtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICAgIHRoaXMuc3VwcG9ydHNJbmxpbmVDb2RlID0gISFwcm9wcy5zdXBwb3J0c0lubGluZUNvZGU7XG4gICAgdGhpcy5mYW1pbHkgPSBmYW1pbHk7XG5cbiAgICBSdW50aW1lLkFsbC5wdXNoKHRoaXMpO1xuICB9XG5cbiAgcHVibGljIHRvU3RyaW5nKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubmFtZTtcbiAgfVxufVxuIl19 |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const cdk = require("@aws-cdk/cdk"); | ||
const function_1 = require("./function"); | ||
@@ -29,4 +28,3 @@ const function_base_1 = require("./function-base"); | ||
const constructName = (props.lambdaPurpose || 'SingletonLambda') + slugify(props.uuid); | ||
const stack = cdk.Stack.find(this); | ||
const existing = stack.node.tryFindChild(constructName); | ||
const existing = this.node.stack.node.tryFindChild(constructName); | ||
if (existing) { | ||
@@ -36,3 +34,3 @@ // Just assume this is true | ||
} | ||
return new function_1.Function(stack, constructName, props); | ||
return new function_1.Function(this.node.stack, constructName, props); | ||
} | ||
@@ -44,2 +42,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xldG9uLWxhbWJkYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpbmdsZXRvbi1sYW1iZGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxvQ0FBcUM7QUFDckMseUNBQXVFO0FBQ3ZFLG1EQUErRTtBQTJCL0U7Ozs7O0dBS0c7QUFDSCxNQUFhLGlCQUFrQixTQUFRLDRCQUFZO0lBT2pELFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQUUsS0FBNkI7UUFDekUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFL0MsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQztRQUNuRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDO1FBQ3JELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUM7UUFFckMsSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksQ0FBQyxDQUFDLG9EQUFvRDtJQUN4RixDQUFDO0lBRU0sTUFBTTtRQUNYLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUN0QyxDQUFDO0lBRU0sYUFBYSxDQUFDLElBQVksRUFBRSxVQUFzQjtRQUN2RCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxVQUFVLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRU8sWUFBWSxDQUFDLEtBQTZCO1FBQ2hELE1BQU0sYUFBYSxHQUFHLENBQUMsS0FBSyxDQUFDLGFBQWEsSUFBSSxpQkFBaUIsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdkYsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkMsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDeEQsSUFBSSxRQUFRLEVBQUU7WUFDWiwyQkFBMkI7WUFDM0IsT0FBTyxRQUF3QixDQUFDO1NBQ2pDO1FBRUQsT0FBTyxJQUFJLG1CQUFjLENBQUMsS0FBSyxFQUFFLGFBQWEsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN6RCxDQUFDO0NBQ0Y7QUF0Q0QsOENBc0NDO0FBRUQsU0FBUyxPQUFPLENBQUMsQ0FBUztJQUN4QixPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaWFtID0gcmVxdWlyZSgnQGF3cy1jZGsvYXdzLWlhbScpO1xuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IHsgRnVuY3Rpb24gYXMgTGFtYmRhRnVuY3Rpb24sIEZ1bmN0aW9uUHJvcHMgfSBmcm9tICcuL2Z1bmN0aW9uJztcbmltcG9ydCB7IEZ1bmN0aW9uQmFzZSwgRnVuY3Rpb25JbXBvcnRQcm9wcywgSUZ1bmN0aW9uIH0gZnJvbSAnLi9mdW5jdGlvbi1iYXNlJztcbmltcG9ydCB7IFBlcm1pc3Npb24gfSBmcm9tICcuL3Blcm1pc3Npb24nO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGEgbmV3bHkgY3JlYXRlZCBzaW5nbGV0b24gTGFtYmRhXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2luZ2xldG9uRnVuY3Rpb25Qcm9wcyBleHRlbmRzIEZ1bmN0aW9uUHJvcHMge1xuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciB0byBpZGVudGlmeSB0aGlzIGxhbWJkYVxuICAgKlxuICAgKiBUaGUgaWRlbnRpZmllciBzaG91bGQgYmUgdW5pcXVlIGFjcm9zcyBhbGwgY3VzdG9tIHJlc291cmNlIHByb3ZpZGVycy5cbiAgICogV2UgcmVjb21tZW5kIGdlbmVyYXRpbmcgYSBVVUlEIHBlciBwcm92aWRlci5cbiAgICovXG4gIHV1aWQ6IHN0cmluZztcblxuICAvKipcbiAgICogQSBkZXNjcmlwdGl2ZSBuYW1lIGZvciB0aGUgcHVycG9zZSBvZiB0aGlzIExhbWJkYS5cbiAgICpcbiAgICogSWYgdGhlIExhbWJkYSBkb2VzIG5vdCBoYXZlIGEgcGh5c2ljYWwgbmFtZSwgdGhpcyBzdHJpbmcgd2lsbCBiZVxuICAgKiByZWZsZWN0ZWQgaXRzIGdlbmVyYXRlZCBuYW1lLiBUaGUgY29tYmluYXRpb24gb2YgbGFtYmRhUHVycG9zZVxuICAgKiBhbmQgdXVpZCBtdXN0IGJlIHVuaXF1ZS5cbiAgICpcbiAgICogQGRlZmF1bHQgU2luZ2xldG9uTGFtYmRhXG4gICAqL1xuICBsYW1iZGFQdXJwb3NlPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEEgTGFtYmRhIHRoYXQgd2lsbCBvbmx5IGV2ZXIgYmUgYWRkZWQgdG8gYSBzdGFjayBvbmNlLlxuICpcbiAqIFRoZSBsYW1iZGEgaXMgaWRlbnRpZmllZCB1c2luZyB0aGUgdmFsdWUgb2YgJ3V1aWQnLiBSdW4gJ3V1aWRnZW4nXG4gKiBmb3IgZXZlcnkgU2luZ2xldG9uTGFtYmRhIHlvdSBjcmVhdGUuXG4gKi9cbmV4cG9ydCBjbGFzcyBTaW5nbGV0b25GdW5jdGlvbiBleHRlbmRzIEZ1bmN0aW9uQmFzZSB7XG4gIHB1YmxpYyByZWFkb25seSBmdW5jdGlvbk5hbWU6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IGZ1bmN0aW9uQXJuOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSByb2xlPzogaWFtLklSb2xlIHwgdW5kZWZpbmVkO1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgY2FuQ3JlYXRlUGVybWlzc2lvbnM6IGJvb2xlYW47XG4gIHByaXZhdGUgbGFtYmRhRnVuY3Rpb246IElGdW5jdGlvbjtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5sYW1iZGFGdW5jdGlvbiA9IHRoaXMuZW5zdXJlTGFtYmRhKHByb3BzKTtcblxuICAgIHRoaXMuZnVuY3Rpb25Bcm4gPSB0aGlzLmxhbWJkYUZ1bmN0aW9uLmZ1bmN0aW9uQXJuO1xuICAgIHRoaXMuZnVuY3Rpb25OYW1lID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5mdW5jdGlvbk5hbWU7XG4gICAgdGhpcy5yb2xlID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5yb2xlO1xuXG4gICAgdGhpcy5jYW5DcmVhdGVQZXJtaXNzaW9ucyA9IHRydWU7IC8vIERvZXNuJ3QgbWF0dGVyLCBhZGRQZXJtaXNzaW9uIGlzIG92ZXJyaWRlbiBhbnl3YXlcbiAgfVxuXG4gIHB1YmxpYyBleHBvcnQoKTogRnVuY3Rpb25JbXBvcnRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMubGFtYmRhRnVuY3Rpb24uZXhwb3J0KCk7XG4gIH1cblxuICBwdWJsaWMgYWRkUGVybWlzc2lvbihuYW1lOiBzdHJpbmcsIHBlcm1pc3Npb246IFBlcm1pc3Npb24pIHtcbiAgICByZXR1cm4gdGhpcy5sYW1iZGFGdW5jdGlvbi5hZGRQZXJtaXNzaW9uKG5hbWUsIHBlcm1pc3Npb24pO1xuICB9XG5cbiAgcHJpdmF0ZSBlbnN1cmVMYW1iZGEocHJvcHM6IFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMpOiBJRnVuY3Rpb24ge1xuICAgIGNvbnN0IGNvbnN0cnVjdE5hbWUgPSAocHJvcHMubGFtYmRhUHVycG9zZSB8fCAnU2luZ2xldG9uTGFtYmRhJykgKyBzbHVnaWZ5KHByb3BzLnV1aWQpO1xuICAgIGNvbnN0IHN0YWNrID0gY2RrLlN0YWNrLmZpbmQodGhpcyk7XG4gICAgY29uc3QgZXhpc3RpbmcgPSBzdGFjay5ub2RlLnRyeUZpbmRDaGlsZChjb25zdHJ1Y3ROYW1lKTtcbiAgICBpZiAoZXhpc3RpbmcpIHtcbiAgICAgIC8vIEp1c3QgYXNzdW1lIHRoaXMgaXMgdHJ1ZVxuICAgICAgcmV0dXJuIGV4aXN0aW5nIGFzIEZ1bmN0aW9uQmFzZTtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV3IExhbWJkYUZ1bmN0aW9uKHN0YWNrLCBjb25zdHJ1Y3ROYW1lLCBwcm9wcyk7XG4gIH1cbn1cblxuZnVuY3Rpb24gc2x1Z2lmeSh4OiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4geC5yZXBsYWNlKC9bXmEtekEtWjAtOV0vZywgJycpO1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xldG9uLWxhbWJkYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpbmdsZXRvbi1sYW1iZGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSx5Q0FBdUU7QUFDdkUsbURBQStFO0FBMkIvRTs7Ozs7R0FLRztBQUNILE1BQWEsaUJBQWtCLFNBQVEsNEJBQVk7SUFPakQsWUFBWSxLQUFvQixFQUFFLEVBQVUsRUFBRSxLQUE2QjtRQUN6RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUUvQyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO1FBQ25ELElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUM7UUFDckQsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztRQUVyQyxJQUFJLENBQUMsb0JBQW9CLEdBQUcsSUFBSSxDQUFDLENBQUMsb0RBQW9EO0lBQ3hGLENBQUM7SUFFTSxNQUFNO1FBQ1gsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ3RDLENBQUM7SUFFTSxhQUFhLENBQUMsSUFBWSxFQUFFLFVBQXNCO1FBQ3ZELE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFTyxZQUFZLENBQUMsS0FBNkI7UUFDaEQsTUFBTSxhQUFhLEdBQUcsQ0FBQyxLQUFLLENBQUMsYUFBYSxJQUFJLGlCQUFpQixDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN2RixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2xFLElBQUksUUFBUSxFQUFFO1lBQ1osMkJBQTJCO1lBQzNCLE9BQU8sUUFBd0IsQ0FBQztTQUNqQztRQUVELE9BQU8sSUFBSSxtQkFBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLGFBQWEsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNuRSxDQUFDO0NBQ0Y7QUFyQ0QsOENBcUNDO0FBRUQsU0FBUyxPQUFPLENBQUMsQ0FBUztJQUN4QixPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaWFtID0gcmVxdWlyZSgnQGF3cy1jZGsvYXdzLWlhbScpO1xuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IHsgRnVuY3Rpb24gYXMgTGFtYmRhRnVuY3Rpb24sIEZ1bmN0aW9uUHJvcHMgfSBmcm9tICcuL2Z1bmN0aW9uJztcbmltcG9ydCB7IEZ1bmN0aW9uQmFzZSwgRnVuY3Rpb25JbXBvcnRQcm9wcywgSUZ1bmN0aW9uIH0gZnJvbSAnLi9mdW5jdGlvbi1iYXNlJztcbmltcG9ydCB7IFBlcm1pc3Npb24gfSBmcm9tICcuL3Blcm1pc3Npb24nO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGEgbmV3bHkgY3JlYXRlZCBzaW5nbGV0b24gTGFtYmRhXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2luZ2xldG9uRnVuY3Rpb25Qcm9wcyBleHRlbmRzIEZ1bmN0aW9uUHJvcHMge1xuICAvKipcbiAgICogQSB1bmlxdWUgaWRlbnRpZmllciB0byBpZGVudGlmeSB0aGlzIGxhbWJkYVxuICAgKlxuICAgKiBUaGUgaWRlbnRpZmllciBzaG91bGQgYmUgdW5pcXVlIGFjcm9zcyBhbGwgY3VzdG9tIHJlc291cmNlIHByb3ZpZGVycy5cbiAgICogV2UgcmVjb21tZW5kIGdlbmVyYXRpbmcgYSBVVUlEIHBlciBwcm92aWRlci5cbiAgICovXG4gIHV1aWQ6IHN0cmluZztcblxuICAvKipcbiAgICogQSBkZXNjcmlwdGl2ZSBuYW1lIGZvciB0aGUgcHVycG9zZSBvZiB0aGlzIExhbWJkYS5cbiAgICpcbiAgICogSWYgdGhlIExhbWJkYSBkb2VzIG5vdCBoYXZlIGEgcGh5c2ljYWwgbmFtZSwgdGhpcyBzdHJpbmcgd2lsbCBiZVxuICAgKiByZWZsZWN0ZWQgaXRzIGdlbmVyYXRlZCBuYW1lLiBUaGUgY29tYmluYXRpb24gb2YgbGFtYmRhUHVycG9zZVxuICAgKiBhbmQgdXVpZCBtdXN0IGJlIHVuaXF1ZS5cbiAgICpcbiAgICogQGRlZmF1bHQgU2luZ2xldG9uTGFtYmRhXG4gICAqL1xuICBsYW1iZGFQdXJwb3NlPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEEgTGFtYmRhIHRoYXQgd2lsbCBvbmx5IGV2ZXIgYmUgYWRkZWQgdG8gYSBzdGFjayBvbmNlLlxuICpcbiAqIFRoZSBsYW1iZGEgaXMgaWRlbnRpZmllZCB1c2luZyB0aGUgdmFsdWUgb2YgJ3V1aWQnLiBSdW4gJ3V1aWRnZW4nXG4gKiBmb3IgZXZlcnkgU2luZ2xldG9uTGFtYmRhIHlvdSBjcmVhdGUuXG4gKi9cbmV4cG9ydCBjbGFzcyBTaW5nbGV0b25GdW5jdGlvbiBleHRlbmRzIEZ1bmN0aW9uQmFzZSB7XG4gIHB1YmxpYyByZWFkb25seSBmdW5jdGlvbk5hbWU6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IGZ1bmN0aW9uQXJuOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSByb2xlPzogaWFtLklSb2xlIHwgdW5kZWZpbmVkO1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgY2FuQ3JlYXRlUGVybWlzc2lvbnM6IGJvb2xlYW47XG4gIHByaXZhdGUgbGFtYmRhRnVuY3Rpb246IElGdW5jdGlvbjtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5sYW1iZGFGdW5jdGlvbiA9IHRoaXMuZW5zdXJlTGFtYmRhKHByb3BzKTtcblxuICAgIHRoaXMuZnVuY3Rpb25Bcm4gPSB0aGlzLmxhbWJkYUZ1bmN0aW9uLmZ1bmN0aW9uQXJuO1xuICAgIHRoaXMuZnVuY3Rpb25OYW1lID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5mdW5jdGlvbk5hbWU7XG4gICAgdGhpcy5yb2xlID0gdGhpcy5sYW1iZGFGdW5jdGlvbi5yb2xlO1xuXG4gICAgdGhpcy5jYW5DcmVhdGVQZXJtaXNzaW9ucyA9IHRydWU7IC8vIERvZXNuJ3QgbWF0dGVyLCBhZGRQZXJtaXNzaW9uIGlzIG92ZXJyaWRlbiBhbnl3YXlcbiAgfVxuXG4gIHB1YmxpYyBleHBvcnQoKTogRnVuY3Rpb25JbXBvcnRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMubGFtYmRhRnVuY3Rpb24uZXhwb3J0KCk7XG4gIH1cblxuICBwdWJsaWMgYWRkUGVybWlzc2lvbihuYW1lOiBzdHJpbmcsIHBlcm1pc3Npb246IFBlcm1pc3Npb24pIHtcbiAgICByZXR1cm4gdGhpcy5sYW1iZGFGdW5jdGlvbi5hZGRQZXJtaXNzaW9uKG5hbWUsIHBlcm1pc3Npb24pO1xuICB9XG5cbiAgcHJpdmF0ZSBlbnN1cmVMYW1iZGEocHJvcHM6IFNpbmdsZXRvbkZ1bmN0aW9uUHJvcHMpOiBJRnVuY3Rpb24ge1xuICAgIGNvbnN0IGNvbnN0cnVjdE5hbWUgPSAocHJvcHMubGFtYmRhUHVycG9zZSB8fCAnU2luZ2xldG9uTGFtYmRhJykgKyBzbHVnaWZ5KHByb3BzLnV1aWQpO1xuICAgIGNvbnN0IGV4aXN0aW5nID0gdGhpcy5ub2RlLnN0YWNrLm5vZGUudHJ5RmluZENoaWxkKGNvbnN0cnVjdE5hbWUpO1xuICAgIGlmIChleGlzdGluZykge1xuICAgICAgLy8gSnVzdCBhc3N1bWUgdGhpcyBpcyB0cnVlXG4gICAgICByZXR1cm4gZXhpc3RpbmcgYXMgRnVuY3Rpb25CYXNlO1xuICAgIH1cblxuICAgIHJldHVybiBuZXcgTGFtYmRhRnVuY3Rpb24odGhpcy5ub2RlLnN0YWNrLCBjb25zdHJ1Y3ROYW1lLCBwcm9wcyk7XG4gIH1cbn1cblxuZnVuY3Rpb24gc2x1Z2lmeSh4OiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4geC5yZXBsYWNlKC9bXmEtekEtWjAtOV0vZywgJycpO1xufVxuIl19 |
{ | ||
"name": "@aws-cdk/aws-lambda", | ||
"version": "0.24.1", | ||
"version": "0.25.0", | ||
"description": "CDK Constructs for AWS Lambda", | ||
@@ -61,37 +61,37 @@ "main": "lib/index.js", | ||
"devDependencies": { | ||
"@aws-cdk/assert": "^0.24.1", | ||
"cdk-build-tools": "^0.24.1", | ||
"cdk-integ-tools": "^0.24.1", | ||
"cfn2ts": "^0.24.1", | ||
"pkglint": "^0.24.1" | ||
"@aws-cdk/assert": "^0.25.0", | ||
"cdk-build-tools": "^0.25.0", | ||
"cdk-integ-tools": "^0.25.0", | ||
"cfn2ts": "^0.25.0", | ||
"pkglint": "^0.25.0" | ||
}, | ||
"dependencies": { | ||
"@aws-cdk/assets": "^0.24.1", | ||
"@aws-cdk/aws-cloudwatch": "^0.24.1", | ||
"@aws-cdk/aws-codepipeline-api": "^0.24.1", | ||
"@aws-cdk/aws-ec2": "^0.24.1", | ||
"@aws-cdk/aws-events": "^0.24.1", | ||
"@aws-cdk/aws-iam": "^0.24.1", | ||
"@aws-cdk/aws-logs": "^0.24.1", | ||
"@aws-cdk/aws-s3": "^0.24.1", | ||
"@aws-cdk/aws-s3-notifications": "^0.24.1", | ||
"@aws-cdk/aws-sqs": "^0.24.1", | ||
"@aws-cdk/aws-stepfunctions": "^0.24.1", | ||
"@aws-cdk/cdk": "^0.24.1", | ||
"@aws-cdk/cx-api": "^0.24.1" | ||
"@aws-cdk/assets": "^0.25.0", | ||
"@aws-cdk/aws-cloudwatch": "^0.25.0", | ||
"@aws-cdk/aws-codepipeline-api": "^0.25.0", | ||
"@aws-cdk/aws-ec2": "^0.25.0", | ||
"@aws-cdk/aws-events": "^0.25.0", | ||
"@aws-cdk/aws-iam": "^0.25.0", | ||
"@aws-cdk/aws-logs": "^0.25.0", | ||
"@aws-cdk/aws-s3": "^0.25.0", | ||
"@aws-cdk/aws-s3-notifications": "^0.25.0", | ||
"@aws-cdk/aws-sqs": "^0.25.0", | ||
"@aws-cdk/aws-stepfunctions": "^0.25.0", | ||
"@aws-cdk/cdk": "^0.25.0", | ||
"@aws-cdk/cx-api": "^0.25.0" | ||
}, | ||
"homepage": "https://github.com/awslabs/aws-cdk", | ||
"peerDependencies": { | ||
"@aws-cdk/assets": "^0.24.1", | ||
"@aws-cdk/aws-cloudwatch": "^0.24.1", | ||
"@aws-cdk/aws-codepipeline-api": "^0.24.1", | ||
"@aws-cdk/aws-ec2": "^0.24.1", | ||
"@aws-cdk/aws-events": "^0.24.1", | ||
"@aws-cdk/aws-iam": "^0.24.1", | ||
"@aws-cdk/aws-logs": "^0.24.1", | ||
"@aws-cdk/aws-s3": "^0.24.1", | ||
"@aws-cdk/aws-s3-notifications": "^0.24.1", | ||
"@aws-cdk/aws-sqs": "^0.24.1", | ||
"@aws-cdk/aws-stepfunctions": "^0.24.1", | ||
"@aws-cdk/cdk": "^0.24.1" | ||
"@aws-cdk/assets": "^0.25.0", | ||
"@aws-cdk/aws-cloudwatch": "^0.25.0", | ||
"@aws-cdk/aws-codepipeline-api": "^0.25.0", | ||
"@aws-cdk/aws-ec2": "^0.25.0", | ||
"@aws-cdk/aws-events": "^0.25.0", | ||
"@aws-cdk/aws-iam": "^0.25.0", | ||
"@aws-cdk/aws-logs": "^0.25.0", | ||
"@aws-cdk/aws-s3": "^0.25.0", | ||
"@aws-cdk/aws-s3-notifications": "^0.25.0", | ||
"@aws-cdk/aws-sqs": "^0.25.0", | ||
"@aws-cdk/aws-stepfunctions": "^0.25.0", | ||
"@aws-cdk/cdk": "^0.25.0" | ||
}, | ||
@@ -101,2 +101,2 @@ "engines": { | ||
} | ||
} | ||
} |
@@ -83,14 +83,17 @@ ## AWS Lambda Construct Library | ||
const pipeline = new codepipeline.Pipeline(this, 'MyPipeline'); | ||
const lambdaStage = pipeline.addStage('Lambda'); | ||
new lambda.PipelineInvokeAction(this, 'Lambda', { | ||
stage: lambdaStage, | ||
lambda: fn, | ||
const lambdaAction = new lambda.PipelineInvokeAction({ | ||
actionName: 'Lambda', | ||
lambda: fn, | ||
}); | ||
pipeline.addStage({ | ||
actionName: 'Lambda', | ||
actions: [lambdaAction], | ||
}); | ||
``` | ||
You can also add the Lambda to the Pipeline directly: | ||
You can also create the action from the Lambda directly: | ||
```ts | ||
// equivalent to the code above: | ||
fn.addToPipeline(lambdaStage, 'Lambda'); | ||
const lambdaAction = fn.toCodePipelineInvokeAction({ actionName: 'Lambda' }); | ||
``` | ||
@@ -102,3 +105,4 @@ | ||
```typescript | ||
const lambdaAction = fn.addToPipeline(lambdaStage, 'Lambda', { | ||
const lambdaAction = fn.toCodePipelineInvokeAction({ | ||
actionName: 'Lambda', | ||
inputArtifacts: [ | ||
@@ -105,0 +109,0 @@ sourceAction.outputArtifact, |
@@ -31,4 +31,8 @@ import { Test } from 'nodeunit'; | ||
'using more than 5 layers'(test: Test): void; | ||
'environment variables are prohibited in China'(test: Test): void; | ||
'environment variables work in an unspecified region'(test: Test): void; | ||
'support reserved concurrent executions'(test: Test): void; | ||
'its possible to specify event sources upon creation'(test: Test): void; | ||
'Provided Runtime returns the right values'(test: Test): void; | ||
}; | ||
export = _default; |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
999205
7108
167
1
+ Added@aws-cdk/assets@0.25.3(transitive)
+ Added@aws-cdk/aws-autoscaling-api@0.25.3(transitive)
+ Added@aws-cdk/aws-cloudwatch@0.25.3(transitive)
+ Added@aws-cdk/aws-codepipeline-api@0.25.3(transitive)
+ Added@aws-cdk/aws-ec2@0.25.3(transitive)
+ Added@aws-cdk/aws-events@0.25.3(transitive)
+ Added@aws-cdk/aws-iam@0.25.3(transitive)
+ Added@aws-cdk/aws-kms@0.25.3(transitive)
+ Added@aws-cdk/aws-logs@0.25.3(transitive)
+ Added@aws-cdk/aws-s3@0.25.3(transitive)
+ Added@aws-cdk/aws-s3-notifications@0.25.3(transitive)
+ Added@aws-cdk/aws-sqs@0.25.3(transitive)
+ Added@aws-cdk/aws-stepfunctions@0.25.3(transitive)
+ Added@aws-cdk/cdk@0.25.3(transitive)
+ Added@aws-cdk/cx-api@0.25.3(transitive)
- Removed@aws-cdk/assets@0.24.1(transitive)
- Removed@aws-cdk/aws-autoscaling-api@0.24.1(transitive)
- Removed@aws-cdk/aws-cloudwatch@0.24.1(transitive)
- Removed@aws-cdk/aws-codepipeline-api@0.24.1(transitive)
- Removed@aws-cdk/aws-ec2@0.24.1(transitive)
- Removed@aws-cdk/aws-events@0.24.1(transitive)
- Removed@aws-cdk/aws-iam@0.24.1(transitive)
- Removed@aws-cdk/aws-kms@0.24.1(transitive)
- Removed@aws-cdk/aws-logs@0.24.1(transitive)
- Removed@aws-cdk/aws-s3@0.24.1(transitive)
- Removed@aws-cdk/aws-s3-notifications@0.24.1(transitive)
- Removed@aws-cdk/aws-sqs@0.24.1(transitive)
- Removed@aws-cdk/aws-stepfunctions@0.24.1(transitive)
- Removed@aws-cdk/cdk@0.24.1(transitive)
- Removed@aws-cdk/cx-api@0.24.1(transitive)
Updated@aws-cdk/assets@^0.25.0
Updated@aws-cdk/aws-ec2@^0.25.0
Updated@aws-cdk/aws-events@^0.25.0
Updated@aws-cdk/aws-iam@^0.25.0
Updated@aws-cdk/aws-logs@^0.25.0
Updated@aws-cdk/aws-s3@^0.25.0
Updated@aws-cdk/aws-sqs@^0.25.0
Updated@aws-cdk/cdk@^0.25.0
Updated@aws-cdk/cx-api@^0.25.0