Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@aws-cdk/aws-elasticloadbalancingv2

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

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

Comparing version 1.8.0 to 1.9.0

6

lib/alb/application-listener.d.ts

@@ -96,4 +96,8 @@ import ec2 = require('@aws-cdk/aws-ec2');

* Add one or more certificates to this listener.
*
* After the first certificate, this creates ApplicationListenerCertificates
* resources since cloudformation requires the certificates array on the
* listener resource to have a length of 1.
*/
addCertificateArns(_id: string, arns: string[]): void;
addCertificateArns(id: string, arns: string[]): void;
/**

@@ -100,0 +104,0 @@ * Load balance incoming requests to the given target groups.

34

lib/alb/application-listener.js

@@ -32,3 +32,6 @@ "use strict";

this.certificateArns = [];
this.certificateArns.push(...(props.certificateArns || []));
// Attach certificates
if (props.certificateArns && props.certificateArns.length > 0) {
this.addCertificateArns("ListenerCertificate", props.certificateArns);
}
// This listener edits the securitygroup of the load balancer,

@@ -53,5 +56,19 @@ // but adds its own default port.

* Add one or more certificates to this listener.
*
* After the first certificate, this creates ApplicationListenerCertificates
* resources since cloudformation requires the certificates array on the
* listener resource to have a length of 1.
*/
addCertificateArns(_id, arns) {
this.certificateArns.push(...arns);
addCertificateArns(id, arns) {
const additionalCertArns = [...arns];
if (this.certificateArns.length === 0 && additionalCertArns.length > 0) {
const first = additionalCertArns.splice(0, 1)[0];
this.certificateArns.push(first);
}
if (additionalCertArns.length > 0) {
new application_listener_certificate_1.ApplicationListenerCertificate(this, id, {
listener: this,
certificateArns: additionalCertArns
});
}
}

@@ -132,8 +149,3 @@ /**

if (props.priority) {
new application_listener_rule_1.ApplicationListenerRule(this, id + 'Rule', {
listener: this,
priority: props.priority,
fixedResponse,
...props
});
new application_listener_rule_1.ApplicationListenerRule(this, id + 'Rule', Object.assign({ listener: this, priority: props.priority, fixedResponse }, props));
}

@@ -153,3 +165,3 @@ else {

registerConnectable(connectable, portRange) {
this.connections.allowTo(connectable, portRange, 'Load balancer to target');
connectable.connections.allowFrom(this.loadBalancer, portRange, 'Load balancer to target');
}

@@ -259,2 +271,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-listener.js","sourceRoot":"","sources":["application-listener.ts"],"names":[],"mappings":"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","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, Duration, IResource, Lazy, Resource } from '@aws-cdk/core';\nimport { BaseListener } from '../shared/base-listener';\nimport { HealthCheck } from '../shared/base-target-group';\nimport { ApplicationProtocol, SslPolicy } from '../shared/enums';\nimport { determineProtocolAndPort } from '../shared/util';\nimport { ApplicationListenerCertificate } from './application-listener-certificate';\nimport { ApplicationListenerRule, FixedResponse, validateFixedResponse } from './application-listener-rule';\nimport { IApplicationLoadBalancer } from './application-load-balancer';\nimport { ApplicationTargetGroup, IApplicationLoadBalancerTarget, IApplicationTargetGroup } from './application-target-group';\n\n/**\n * Basic properties for an ApplicationListener\n */\nexport interface BaseApplicationListenerProps {\n  /**\n   * The protocol to use\n   *\n   * @default - Determined from port if known.\n   */\n  readonly protocol?: ApplicationProtocol;\n\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default - Determined from protocol if known.\n   */\n  readonly port?: number;\n\n  /**\n   * The certificates to use on this listener\n   *\n   * @default - No certificates.\n   */\n  readonly certificateArns?: string[];\n\n  /**\n   * The security policy that defines which ciphers and protocols are supported.\n   *\n   * @default - The current predefined security policy.\n   */\n  readonly sslPolicy?: SslPolicy;\n\n  /**\n   * Default target groups to load balance to\n   *\n   * @default - None.\n   */\n  readonly defaultTargetGroups?: IApplicationTargetGroup[];\n\n  /**\n   * Allow anyone to connect to this listener\n   *\n   * If this is specified, the listener will be opened up to anyone who can reach it.\n   * For internal load balancers this is anyone in the same VPC. For public load\n   * balancers, this is anyone on the internet.\n   *\n   * If you want to be more selective about who can access this load\n   * balancer, set this to `false` and use the listener's `connections`\n   * object to selectively grant access to the listener.\n   *\n   * @default true\n   */\n  readonly open?: boolean;\n}\n\n/**\n * Properties for defining a standalone ApplicationListener\n */\nexport interface ApplicationListenerProps extends BaseApplicationListenerProps {\n  /**\n   * The load balancer to attach this listener to\n   */\n  readonly loadBalancer: IApplicationLoadBalancer;\n}\n\n/**\n * Define an ApplicationListener\n *\n * @resource AWS::ElasticLoadBalancingV2::Listener\n */\nexport class ApplicationListener extends BaseListener implements IApplicationListener {\n  /**\n   * Import an existing listener\n   */\n  public static fromApplicationListenerAttributes(scope: Construct, id: string, attrs: ApplicationListenerAttributes): IApplicationListener {\n    return new ImportedApplicationListener(scope, id, attrs);\n  }\n\n  /**\n   * Manage connections to this ApplicationListener\n   */\n  public readonly connections: ec2.Connections;\n\n  /**\n   * Load balancer this listener is associated with\n   */\n  public readonly loadBalancer: IApplicationLoadBalancer;\n\n  /**\n   * ARNs of certificates added to this listener\n   */\n  private readonly certificateArns: string[];\n\n  /**\n   * Listener protocol for this listener.\n   */\n  private readonly protocol: ApplicationProtocol;\n\n  constructor(scope: Construct, id: string, props: ApplicationListenerProps) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n    if (protocol === undefined || port === undefined) {\n      throw new Error(`At least one of 'port' or 'protocol' is required`);\n    }\n\n    super(scope, id, {\n      loadBalancerArn: props.loadBalancer.loadBalancerArn,\n      certificates: Lazy.anyValue({ produce: () => this.certificateArns.map(certificateArn => ({ certificateArn })) }, { omitEmptyArray: true}),\n      protocol,\n      port,\n      sslPolicy: props.sslPolicy,\n    });\n\n    this.loadBalancer = props.loadBalancer;\n    this.protocol = protocol;\n    this.certificateArns = [];\n    this.certificateArns.push(...(props.certificateArns || []));\n\n    // This listener edits the securitygroup of the load balancer,\n    // but adds its own default port.\n    this.connections = new ec2.Connections({\n      securityGroups: props.loadBalancer.connections.securityGroups,\n      defaultPort: ec2.Port.tcp(port),\n    });\n\n    (props.defaultTargetGroups || []).forEach(this.addDefaultTargetGroup.bind(this));\n\n    if (props.open !== false) {\n      this.connections.allowDefaultPortFrom(ec2.Peer.anyIpv4(), `Allow from anyone on port ${port}`);\n    }\n  }\n\n  /**\n   * Add one or more certificates to this listener.\n   */\n  public addCertificateArns(_id: string, arns: string[]): void {\n    this.certificateArns.push(...arns);\n  }\n\n  /**\n   * Load balance incoming requests to the given target groups.\n   *\n   * It's possible to add conditions to the TargetGroups added in this way.\n   * At least one TargetGroup must be added without conditions.\n   */\n  public addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void {\n    checkAddRuleProps(props);\n\n    if (props.priority !== undefined) {\n      // New rule\n      //\n      // TargetGroup.registerListener is called inside ApplicationListenerRule.\n      new ApplicationListenerRule(this, id + 'Rule', {\n        listener: this,\n        hostHeader: props.hostHeader,\n        pathPattern: props.pathPattern,\n        priority: props.priority,\n        targetGroups: props.targetGroups\n      });\n    } else {\n      // New default target(s)\n      for (const targetGroup of props.targetGroups) {\n        this.addDefaultTargetGroup(targetGroup);\n      }\n    }\n  }\n\n  /**\n   * Load balance incoming requests to the given load balancing targets.\n   *\n   * This method implicitly creates an ApplicationTargetGroup for the targets\n   * involved.\n   *\n   * It's possible to add conditions to the targets added in this way. At least\n   * one set of targets must be added without conditions.\n   *\n   * @returns The newly created target group\n   */\n  public addTargets(id: string, props: AddApplicationTargetsProps): ApplicationTargetGroup {\n    if (!this.loadBalancer.vpc) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error('Can only call addTargets() when using a constructed Load Balancer; construct a new TargetGroup and use addTargetGroup');\n    }\n\n    const group = new ApplicationTargetGroup(this, id + 'Group', {\n      deregistrationDelay: props.deregistrationDelay,\n      healthCheck: props.healthCheck,\n      port: props.port,\n      protocol: props.protocol,\n      slowStart: props.slowStart,\n      stickinessCookieDuration: props.stickinessCookieDuration,\n      targetGroupName: props.targetGroupName,\n      targets: props.targets,\n      vpc: this.loadBalancer.vpc\n    });\n\n    this.addTargetGroups(id, {\n      hostHeader: props.hostHeader,\n      pathPattern: props.pathPattern,\n      priority: props.priority,\n      targetGroups: [group],\n    });\n\n    return group;\n  }\n\n  /**\n   * Add a fixed response\n   */\n  public addFixedResponse(id: string, props: AddFixedResponseProps) {\n    checkAddRuleProps(props);\n\n    const fixedResponse: FixedResponse = {\n      statusCode: props.statusCode,\n      contentType: props.contentType,\n      messageBody: props.messageBody\n    };\n\n    validateFixedResponse(fixedResponse);\n\n    if (props.priority) {\n      new ApplicationListenerRule(this, id + 'Rule', {\n        listener: this,\n        priority: props.priority,\n        fixedResponse,\n        ...props\n      });\n    } else {\n      this._addDefaultAction({\n        fixedResponseConfig: fixedResponse,\n        type: 'fixed-response'\n      });\n    }\n  }\n\n  /**\n   * Register that a connectable that has been added to this load balancer.\n   *\n   * Don't call this directly. It is called by ApplicationTargetGroup.\n   */\n  public registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void {\n    this.connections.allowTo(connectable, portRange, 'Load balancer to target');\n  }\n\n  /**\n   * Validate this listener.\n   */\n  protected validate(): string[] {\n    const errors = super.validate();\n    if (this.protocol === ApplicationProtocol.HTTPS && this.certificateArns.length === 0) {\n      errors.push('HTTPS Listener needs at least one certificate (call addCertificateArns)');\n    }\n    return errors;\n  }\n\n  /**\n   * Add a default TargetGroup\n   */\n  private addDefaultTargetGroup(targetGroup: IApplicationTargetGroup) {\n    this._addDefaultTargetGroup(targetGroup);\n    targetGroup.registerListener(this);\n  }\n}\n\n/**\n * Properties to reference an existing listener\n */\nexport interface IApplicationListener extends IResource, ec2.IConnectable {\n  /**\n   * ARN of the listener\n   * @attribute\n   */\n  readonly listenerArn: string;\n\n  /**\n   * Add one or more certificates to this listener.\n   */\n  addCertificateArns(id: string, arns: string[]): void;\n\n  /**\n   * Load balance incoming requests to the given target groups.\n   *\n   * It's possible to add conditions to the TargetGroups added in this way.\n   * At least one TargetGroup must be added without conditions.\n   */\n  addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void;\n\n  /**\n   * Load balance incoming requests to the given load balancing targets.\n   *\n   * This method implicitly creates an ApplicationTargetGroup for the targets\n   * involved.\n   *\n   * It's possible to add conditions to the targets added in this way. At least\n   * one set of targets must be added without conditions.\n   *\n   * @returns The newly created target group\n   */\n  addTargets(id: string, props: AddApplicationTargetsProps): ApplicationTargetGroup;\n\n  /**\n   * Register that a connectable that has been added to this load balancer.\n   *\n   * Don't call this directly. It is called by ApplicationTargetGroup.\n   */\n  registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void;\n}\n\n/**\n * Properties to reference an existing listener\n */\nexport interface ApplicationListenerAttributes {\n  /**\n   * ARN of the listener\n   */\n  readonly listenerArn: string;\n\n  /**\n   * Security group ID of the load balancer this listener is associated with\n   *\n   * @deprecated use `securityGroup` instead\n   */\n  readonly securityGroupId?: string;\n\n  /**\n   * Security group of the load balancer this listener is associated with\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The default port on which this listener is listening\n   */\n  readonly defaultPort?: number;\n\n  /**\n   * Whether the imported security group allows all outbound traffic or not when\n   * imported using `securityGroupId`\n   *\n   * Unless set to `false`, no egress rules will be added to the security group.\n   *\n   * @default true\n   *\n   * @deprecated use `securityGroup` instead\n   */\n  readonly securityGroupAllowsAllOutbound?: boolean;\n}\n\nclass ImportedApplicationListener extends Resource implements IApplicationListener {\n  public readonly connections: ec2.Connections;\n\n  /**\n   * ARN of the listener\n   */\n  public readonly listenerArn: string;\n\n  constructor(scope: Construct, id: string, props: ApplicationListenerAttributes) {\n    super(scope, id);\n\n    this.listenerArn = props.listenerArn;\n\n    const defaultPort = props.defaultPort !== undefined ? ec2.Port.tcp(props.defaultPort) : undefined;\n\n    let securityGroup: ec2.ISecurityGroup;\n    if (props.securityGroup) {\n      securityGroup = props.securityGroup;\n    } else if (props.securityGroupId) {\n      securityGroup = ec2.SecurityGroup.fromSecurityGroupId(scope, 'SecurityGroup', props.securityGroupId, {\n        allowAllOutbound: props.securityGroupAllowsAllOutbound\n      });\n    } else {\n      throw new Error('Either `securityGroup` or `securityGroupId` must be specified to import an application listener.');\n    }\n\n    this.connections = new ec2.Connections({\n      securityGroups: [securityGroup],\n      defaultPort,\n    });\n  }\n\n  /**\n   * Add one or more certificates to this listener.\n   */\n  public addCertificateArns(id: string, arns: string[]): void {\n    new ApplicationListenerCertificate(this, id, {\n      listener: this,\n      certificateArns: arns\n    });\n  }\n\n  /**\n   * Load balance incoming requests to the given target groups.\n   *\n   * It's possible to add conditions to the TargetGroups added in this way.\n   * At least one TargetGroup must be added without conditions.\n   */\n  public addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void {\n    if ((props.hostHeader !== undefined || props.pathPattern !== undefined) !== (props.priority !== undefined)) {\n      throw new Error(`Setting 'pathPattern' or 'hostHeader' also requires 'priority', and vice versa`);\n    }\n\n    if (props.priority !== undefined) {\n      // New rule\n      new ApplicationListenerRule(this, id, {\n        listener: this,\n        hostHeader: props.hostHeader,\n        pathPattern: props.pathPattern,\n        priority: props.priority,\n        targetGroups: props.targetGroups\n      });\n    } else {\n      throw new Error('Cannot add default Target Groups to imported ApplicationListener');\n    }\n  }\n\n  /**\n   * Load balance incoming requests to the given load balancing targets.\n   *\n   * This method implicitly creates an ApplicationTargetGroup for the targets\n   * involved.\n   *\n   * It's possible to add conditions to the targets added in this way. At least\n   * one set of targets must be added without conditions.\n   *\n   * @returns The newly created target group\n   */\n  public addTargets(_id: string, _props: AddApplicationTargetsProps): ApplicationTargetGroup {\n    // tslint:disable-next-line:max-line-length\n    throw new Error('Can only call addTargets() when using a constructed ApplicationListener; construct a new TargetGroup and use addTargetGroup.');\n  }\n\n  /**\n   * Register that a connectable that has been added to this load balancer.\n   *\n   * Don't call this directly. It is called by ApplicationTargetGroup.\n   */\n  public registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void {\n    this.connections.allowTo(connectable, portRange, 'Load balancer to target');\n  }\n}\n\n/**\n * Properties for adding a conditional load balancing rule\n */\nexport interface AddRuleProps {\n  /**\n   * Priority of this target group\n   *\n   * The rule with the lowest priority will be used for every request.\n   * If priority is not given, these target groups will be added as\n   * defaults, and must not have conditions.\n   *\n   * Priorities must be unique.\n   *\n   * @default Target groups are used as defaults\n   */\n  readonly priority?: number;\n\n  /**\n   * Rule applies if the requested host matches the indicated host\n   *\n   * May contain up to three '*' wildcards.\n   *\n   * Requires that priority is set.\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#host-conditions\n   *\n   * @default No host condition\n   */\n  readonly hostHeader?: string;\n\n  /**\n   * Rule applies if the requested path matches the given path pattern\n   *\n   * May contain up to three '*' wildcards.\n   *\n   * Requires that priority is set.\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions\n   *\n   * @default No path condition\n   */\n  readonly pathPattern?: string;\n}\n\n/**\n * Properties for adding a new target group to a listener\n */\nexport interface AddApplicationTargetGroupsProps extends AddRuleProps {\n  /**\n   * Target groups to forward requests to\n   */\n  readonly targetGroups: IApplicationTargetGroup[];\n}\n\n/**\n * Properties for adding new targets to a listener\n */\nexport interface AddApplicationTargetsProps extends AddRuleProps {\n  /**\n   * The protocol to use\n   *\n   * @default Determined from port if known\n   */\n  readonly protocol?: ApplicationProtocol;\n\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default Determined from protocol if known\n   */\n  readonly port?: number;\n\n  /**\n   * The time period during which the load balancer sends a newly registered\n   * target a linearly increasing share of the traffic to the target group.\n   *\n   * The range is 30-900 seconds (15 minutes).\n   *\n   * @default 0\n   */\n  readonly slowStart?: Duration;\n\n  /**\n   * The stickiness cookie expiration period.\n   *\n   * Setting this value enables load balancer stickiness.\n   *\n   * After this period, the cookie is considered stale. The minimum value is\n   * 1 second and the maximum value is 7 days (604800 seconds).\n   *\n   * @default Duration.days(1)\n   */\n  readonly stickinessCookieDuration?: Duration;\n\n  /**\n   * The targets to add to this target group.\n   *\n   * Can be `Instance`, `IPAddress`, or any self-registering load balancing\n   * target. All target must be of the same type.\n   */\n  readonly targets?: IApplicationLoadBalancerTarget[];\n\n  /**\n   * The name of the target group.\n   *\n   * This name must be unique per region per account, can have a maximum of\n   * 32 characters, must contain only alphanumeric characters or hyphens, and\n   * must not begin or end with a hyphen.\n   *\n   * @default Automatically generated\n   */\n  readonly targetGroupName?: string;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n   *\n   * The range is 0-3600 seconds.\n   *\n   * @default Duration.minutes(5)\n   */\n  readonly deregistrationDelay?: Duration;\n\n  /**\n   * Health check configuration\n   *\n   * @default No health check\n   */\n  readonly healthCheck?: HealthCheck;\n}\n\n/**\n * Properties for adding a fixed response to a listener\n */\nexport interface AddFixedResponseProps extends AddRuleProps, FixedResponse {\n}\n\nfunction checkAddRuleProps(props: AddRuleProps) {\n  if ((props.hostHeader !== undefined || props.pathPattern !== undefined) !== (props.priority !== undefined)) {\n    throw new Error(`Setting 'pathPattern' or 'hostHeader' also requires 'priority', and vice versa`);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-listener.js","sourceRoot":"","sources":["application-listener.ts"],"names":[],"mappings":"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","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, Duration, IResource, Lazy, Resource } from '@aws-cdk/core';\nimport { BaseListener } from '../shared/base-listener';\nimport { HealthCheck } from '../shared/base-target-group';\nimport { ApplicationProtocol, SslPolicy } from '../shared/enums';\nimport { determineProtocolAndPort } from '../shared/util';\nimport { ApplicationListenerCertificate } from './application-listener-certificate';\nimport { ApplicationListenerRule, FixedResponse, validateFixedResponse } from './application-listener-rule';\nimport { IApplicationLoadBalancer } from './application-load-balancer';\nimport { ApplicationTargetGroup, IApplicationLoadBalancerTarget, IApplicationTargetGroup } from './application-target-group';\n\n/**\n * Basic properties for an ApplicationListener\n */\nexport interface BaseApplicationListenerProps {\n  /**\n   * The protocol to use\n   *\n   * @default - Determined from port if known.\n   */\n  readonly protocol?: ApplicationProtocol;\n\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default - Determined from protocol if known.\n   */\n  readonly port?: number;\n\n  /**\n   * The certificates to use on this listener\n   *\n   * @default - No certificates.\n   */\n  readonly certificateArns?: string[];\n\n  /**\n   * The security policy that defines which ciphers and protocols are supported.\n   *\n   * @default - The current predefined security policy.\n   */\n  readonly sslPolicy?: SslPolicy;\n\n  /**\n   * Default target groups to load balance to\n   *\n   * @default - None.\n   */\n  readonly defaultTargetGroups?: IApplicationTargetGroup[];\n\n  /**\n   * Allow anyone to connect to this listener\n   *\n   * If this is specified, the listener will be opened up to anyone who can reach it.\n   * For internal load balancers this is anyone in the same VPC. For public load\n   * balancers, this is anyone on the internet.\n   *\n   * If you want to be more selective about who can access this load\n   * balancer, set this to `false` and use the listener's `connections`\n   * object to selectively grant access to the listener.\n   *\n   * @default true\n   */\n  readonly open?: boolean;\n}\n\n/**\n * Properties for defining a standalone ApplicationListener\n */\nexport interface ApplicationListenerProps extends BaseApplicationListenerProps {\n  /**\n   * The load balancer to attach this listener to\n   */\n  readonly loadBalancer: IApplicationLoadBalancer;\n}\n\n/**\n * Define an ApplicationListener\n *\n * @resource AWS::ElasticLoadBalancingV2::Listener\n */\nexport class ApplicationListener extends BaseListener implements IApplicationListener {\n  /**\n   * Import an existing listener\n   */\n  public static fromApplicationListenerAttributes(scope: Construct, id: string, attrs: ApplicationListenerAttributes): IApplicationListener {\n    return new ImportedApplicationListener(scope, id, attrs);\n  }\n\n  /**\n   * Manage connections to this ApplicationListener\n   */\n  public readonly connections: ec2.Connections;\n\n  /**\n   * Load balancer this listener is associated with\n   */\n  public readonly loadBalancer: IApplicationLoadBalancer;\n\n  /**\n   * ARNs of certificates added to this listener\n   */\n  private readonly certificateArns: string[];\n\n  /**\n   * Listener protocol for this listener.\n   */\n  private readonly protocol: ApplicationProtocol;\n\n  constructor(scope: Construct, id: string, props: ApplicationListenerProps) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n    if (protocol === undefined || port === undefined) {\n      throw new Error(`At least one of 'port' or 'protocol' is required`);\n    }\n\n    super(scope, id, {\n      loadBalancerArn: props.loadBalancer.loadBalancerArn,\n      certificates: Lazy.anyValue({ produce: () => this.certificateArns.map(certificateArn => ({ certificateArn })) }, { omitEmptyArray: true}),\n      protocol,\n      port,\n      sslPolicy: props.sslPolicy,\n    });\n\n    this.loadBalancer = props.loadBalancer;\n    this.protocol = protocol;\n    this.certificateArns = [];\n\n    // Attach certificates\n    if (props.certificateArns && props.certificateArns.length > 0) {\n      this.addCertificateArns(\"ListenerCertificate\", props.certificateArns);\n    }\n\n    // This listener edits the securitygroup of the load balancer,\n    // but adds its own default port.\n    this.connections = new ec2.Connections({\n      securityGroups: props.loadBalancer.connections.securityGroups,\n      defaultPort: ec2.Port.tcp(port),\n    });\n\n    (props.defaultTargetGroups || []).forEach(this.addDefaultTargetGroup.bind(this));\n\n    if (props.open !== false) {\n      this.connections.allowDefaultPortFrom(ec2.Peer.anyIpv4(), `Allow from anyone on port ${port}`);\n    }\n  }\n\n  /**\n   * Add one or more certificates to this listener.\n   *\n   * After the first certificate, this creates ApplicationListenerCertificates\n   * resources since cloudformation requires the certificates array on the\n   * listener resource to have a length of 1.\n   */\n  public addCertificateArns(id: string, arns: string[]): void {\n    const additionalCertArns = [...arns];\n\n    if (this.certificateArns.length === 0 && additionalCertArns.length > 0) {\n      const first = additionalCertArns.splice(0, 1)[0];\n      this.certificateArns.push(first);\n    }\n\n    if (additionalCertArns.length > 0) {\n      new ApplicationListenerCertificate(this, id, {\n        listener: this,\n        certificateArns: additionalCertArns\n      });\n    }\n  }\n\n  /**\n   * Load balance incoming requests to the given target groups.\n   *\n   * It's possible to add conditions to the TargetGroups added in this way.\n   * At least one TargetGroup must be added without conditions.\n   */\n  public addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void {\n    checkAddRuleProps(props);\n\n    if (props.priority !== undefined) {\n      // New rule\n      //\n      // TargetGroup.registerListener is called inside ApplicationListenerRule.\n      new ApplicationListenerRule(this, id + 'Rule', {\n        listener: this,\n        hostHeader: props.hostHeader,\n        pathPattern: props.pathPattern,\n        priority: props.priority,\n        targetGroups: props.targetGroups\n      });\n    } else {\n      // New default target(s)\n      for (const targetGroup of props.targetGroups) {\n        this.addDefaultTargetGroup(targetGroup);\n      }\n    }\n  }\n\n  /**\n   * Load balance incoming requests to the given load balancing targets.\n   *\n   * This method implicitly creates an ApplicationTargetGroup for the targets\n   * involved.\n   *\n   * It's possible to add conditions to the targets added in this way. At least\n   * one set of targets must be added without conditions.\n   *\n   * @returns The newly created target group\n   */\n  public addTargets(id: string, props: AddApplicationTargetsProps): ApplicationTargetGroup {\n    if (!this.loadBalancer.vpc) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error('Can only call addTargets() when using a constructed Load Balancer; construct a new TargetGroup and use addTargetGroup');\n    }\n\n    const group = new ApplicationTargetGroup(this, id + 'Group', {\n      deregistrationDelay: props.deregistrationDelay,\n      healthCheck: props.healthCheck,\n      port: props.port,\n      protocol: props.protocol,\n      slowStart: props.slowStart,\n      stickinessCookieDuration: props.stickinessCookieDuration,\n      targetGroupName: props.targetGroupName,\n      targets: props.targets,\n      vpc: this.loadBalancer.vpc\n    });\n\n    this.addTargetGroups(id, {\n      hostHeader: props.hostHeader,\n      pathPattern: props.pathPattern,\n      priority: props.priority,\n      targetGroups: [group],\n    });\n\n    return group;\n  }\n\n  /**\n   * Add a fixed response\n   */\n  public addFixedResponse(id: string, props: AddFixedResponseProps) {\n    checkAddRuleProps(props);\n\n    const fixedResponse: FixedResponse = {\n      statusCode: props.statusCode,\n      contentType: props.contentType,\n      messageBody: props.messageBody\n    };\n\n    validateFixedResponse(fixedResponse);\n\n    if (props.priority) {\n      new ApplicationListenerRule(this, id + 'Rule', {\n        listener: this,\n        priority: props.priority,\n        fixedResponse,\n        ...props\n      });\n    } else {\n      this._addDefaultAction({\n        fixedResponseConfig: fixedResponse,\n        type: 'fixed-response'\n      });\n    }\n  }\n\n  /**\n   * Register that a connectable that has been added to this load balancer.\n   *\n   * Don't call this directly. It is called by ApplicationTargetGroup.\n   */\n  public registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void {\n    connectable.connections.allowFrom(this.loadBalancer, portRange, 'Load balancer to target');\n  }\n\n  /**\n   * Validate this listener.\n   */\n  protected validate(): string[] {\n    const errors = super.validate();\n    if (this.protocol === ApplicationProtocol.HTTPS && this.certificateArns.length === 0) {\n      errors.push('HTTPS Listener needs at least one certificate (call addCertificateArns)');\n    }\n    return errors;\n  }\n\n  /**\n   * Add a default TargetGroup\n   */\n  private addDefaultTargetGroup(targetGroup: IApplicationTargetGroup) {\n    this._addDefaultTargetGroup(targetGroup);\n    targetGroup.registerListener(this);\n  }\n}\n\n/**\n * Properties to reference an existing listener\n */\nexport interface IApplicationListener extends IResource, ec2.IConnectable {\n  /**\n   * ARN of the listener\n   * @attribute\n   */\n  readonly listenerArn: string;\n\n  /**\n   * Add one or more certificates to this listener.\n   */\n  addCertificateArns(id: string, arns: string[]): void;\n\n  /**\n   * Load balance incoming requests to the given target groups.\n   *\n   * It's possible to add conditions to the TargetGroups added in this way.\n   * At least one TargetGroup must be added without conditions.\n   */\n  addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void;\n\n  /**\n   * Load balance incoming requests to the given load balancing targets.\n   *\n   * This method implicitly creates an ApplicationTargetGroup for the targets\n   * involved.\n   *\n   * It's possible to add conditions to the targets added in this way. At least\n   * one set of targets must be added without conditions.\n   *\n   * @returns The newly created target group\n   */\n  addTargets(id: string, props: AddApplicationTargetsProps): ApplicationTargetGroup;\n\n  /**\n   * Register that a connectable that has been added to this load balancer.\n   *\n   * Don't call this directly. It is called by ApplicationTargetGroup.\n   */\n  registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void;\n}\n\n/**\n * Properties to reference an existing listener\n */\nexport interface ApplicationListenerAttributes {\n  /**\n   * ARN of the listener\n   */\n  readonly listenerArn: string;\n\n  /**\n   * Security group ID of the load balancer this listener is associated with\n   *\n   * @deprecated use `securityGroup` instead\n   */\n  readonly securityGroupId?: string;\n\n  /**\n   * Security group of the load balancer this listener is associated with\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The default port on which this listener is listening\n   */\n  readonly defaultPort?: number;\n\n  /**\n   * Whether the imported security group allows all outbound traffic or not when\n   * imported using `securityGroupId`\n   *\n   * Unless set to `false`, no egress rules will be added to the security group.\n   *\n   * @default true\n   *\n   * @deprecated use `securityGroup` instead\n   */\n  readonly securityGroupAllowsAllOutbound?: boolean;\n}\n\nclass ImportedApplicationListener extends Resource implements IApplicationListener {\n  public readonly connections: ec2.Connections;\n\n  /**\n   * ARN of the listener\n   */\n  public readonly listenerArn: string;\n\n  constructor(scope: Construct, id: string, props: ApplicationListenerAttributes) {\n    super(scope, id);\n\n    this.listenerArn = props.listenerArn;\n\n    const defaultPort = props.defaultPort !== undefined ? ec2.Port.tcp(props.defaultPort) : undefined;\n\n    let securityGroup: ec2.ISecurityGroup;\n    if (props.securityGroup) {\n      securityGroup = props.securityGroup;\n    } else if (props.securityGroupId) {\n      securityGroup = ec2.SecurityGroup.fromSecurityGroupId(scope, 'SecurityGroup', props.securityGroupId, {\n        allowAllOutbound: props.securityGroupAllowsAllOutbound\n      });\n    } else {\n      throw new Error('Either `securityGroup` or `securityGroupId` must be specified to import an application listener.');\n    }\n\n    this.connections = new ec2.Connections({\n      securityGroups: [securityGroup],\n      defaultPort,\n    });\n  }\n\n  /**\n   * Add one or more certificates to this listener.\n   */\n  public addCertificateArns(id: string, arns: string[]): void {\n    new ApplicationListenerCertificate(this, id, {\n      listener: this,\n      certificateArns: arns\n    });\n  }\n\n  /**\n   * Load balance incoming requests to the given target groups.\n   *\n   * It's possible to add conditions to the TargetGroups added in this way.\n   * At least one TargetGroup must be added without conditions.\n   */\n  public addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void {\n    if ((props.hostHeader !== undefined || props.pathPattern !== undefined) !== (props.priority !== undefined)) {\n      throw new Error(`Setting 'pathPattern' or 'hostHeader' also requires 'priority', and vice versa`);\n    }\n\n    if (props.priority !== undefined) {\n      // New rule\n      new ApplicationListenerRule(this, id, {\n        listener: this,\n        hostHeader: props.hostHeader,\n        pathPattern: props.pathPattern,\n        priority: props.priority,\n        targetGroups: props.targetGroups\n      });\n    } else {\n      throw new Error('Cannot add default Target Groups to imported ApplicationListener');\n    }\n  }\n\n  /**\n   * Load balance incoming requests to the given load balancing targets.\n   *\n   * This method implicitly creates an ApplicationTargetGroup for the targets\n   * involved.\n   *\n   * It's possible to add conditions to the targets added in this way. At least\n   * one set of targets must be added without conditions.\n   *\n   * @returns The newly created target group\n   */\n  public addTargets(_id: string, _props: AddApplicationTargetsProps): ApplicationTargetGroup {\n    // tslint:disable-next-line:max-line-length\n    throw new Error('Can only call addTargets() when using a constructed ApplicationListener; construct a new TargetGroup and use addTargetGroup.');\n  }\n\n  /**\n   * Register that a connectable that has been added to this load balancer.\n   *\n   * Don't call this directly. It is called by ApplicationTargetGroup.\n   */\n  public registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void {\n    this.connections.allowTo(connectable, portRange, 'Load balancer to target');\n  }\n}\n\n/**\n * Properties for adding a conditional load balancing rule\n */\nexport interface AddRuleProps {\n  /**\n   * Priority of this target group\n   *\n   * The rule with the lowest priority will be used for every request.\n   * If priority is not given, these target groups will be added as\n   * defaults, and must not have conditions.\n   *\n   * Priorities must be unique.\n   *\n   * @default Target groups are used as defaults\n   */\n  readonly priority?: number;\n\n  /**\n   * Rule applies if the requested host matches the indicated host\n   *\n   * May contain up to three '*' wildcards.\n   *\n   * Requires that priority is set.\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#host-conditions\n   *\n   * @default No host condition\n   */\n  readonly hostHeader?: string;\n\n  /**\n   * Rule applies if the requested path matches the given path pattern\n   *\n   * May contain up to three '*' wildcards.\n   *\n   * Requires that priority is set.\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions\n   *\n   * @default No path condition\n   */\n  readonly pathPattern?: string;\n}\n\n/**\n * Properties for adding a new target group to a listener\n */\nexport interface AddApplicationTargetGroupsProps extends AddRuleProps {\n  /**\n   * Target groups to forward requests to\n   */\n  readonly targetGroups: IApplicationTargetGroup[];\n}\n\n/**\n * Properties for adding new targets to a listener\n */\nexport interface AddApplicationTargetsProps extends AddRuleProps {\n  /**\n   * The protocol to use\n   *\n   * @default Determined from port if known\n   */\n  readonly protocol?: ApplicationProtocol;\n\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default Determined from protocol if known\n   */\n  readonly port?: number;\n\n  /**\n   * The time period during which the load balancer sends a newly registered\n   * target a linearly increasing share of the traffic to the target group.\n   *\n   * The range is 30-900 seconds (15 minutes).\n   *\n   * @default 0\n   */\n  readonly slowStart?: Duration;\n\n  /**\n   * The stickiness cookie expiration period.\n   *\n   * Setting this value enables load balancer stickiness.\n   *\n   * After this period, the cookie is considered stale. The minimum value is\n   * 1 second and the maximum value is 7 days (604800 seconds).\n   *\n   * @default Duration.days(1)\n   */\n  readonly stickinessCookieDuration?: Duration;\n\n  /**\n   * The targets to add to this target group.\n   *\n   * Can be `Instance`, `IPAddress`, or any self-registering load balancing\n   * target. All target must be of the same type.\n   */\n  readonly targets?: IApplicationLoadBalancerTarget[];\n\n  /**\n   * The name of the target group.\n   *\n   * This name must be unique per region per account, can have a maximum of\n   * 32 characters, must contain only alphanumeric characters or hyphens, and\n   * must not begin or end with a hyphen.\n   *\n   * @default Automatically generated\n   */\n  readonly targetGroupName?: string;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n   *\n   * The range is 0-3600 seconds.\n   *\n   * @default Duration.minutes(5)\n   */\n  readonly deregistrationDelay?: Duration;\n\n  /**\n   * Health check configuration\n   *\n   * @default No health check\n   */\n  readonly healthCheck?: HealthCheck;\n}\n\n/**\n * Properties for adding a fixed response to a listener\n */\nexport interface AddFixedResponseProps extends AddRuleProps, FixedResponse {\n}\n\nfunction checkAddRuleProps(props: AddRuleProps) {\n  if ((props.hostHeader !== undefined || props.pathPattern !== undefined) !== (props.priority !== undefined)) {\n    throw new Error(`Setting 'pathPattern' or 'hostHeader' also requires 'priority', and vice versa`);\n  }\n}\n"]}

@@ -64,6 +64,3 @@ "use strict";

addListener(id, props) {
return new application_listener_1.ApplicationListener(this, id, {
loadBalancer: this,
...props
});
return new application_listener_1.ApplicationListener(this, id, Object.assign({ loadBalancer: this }, props));
}

@@ -76,8 +73,3 @@ /**

metric(metricName, props) {
return new cloudwatch.Metric({
namespace: 'AWS/ApplicationELB',
metricName,
dimensions: { LoadBalancer: this.loadBalancerFullName },
...props
});
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/ApplicationELB', metricName, dimensions: { LoadBalancer: this.loadBalancerFullName } }, props));
}

@@ -91,6 +83,3 @@ /**

metricActiveConnectionCount(props) {
return this.metric('ActiveConnectionCount', {
statistic: 'sum',
...props
});
return this.metric('ActiveConnectionCount', Object.assign({ statistic: 'sum' }, props));
}

@@ -105,6 +94,3 @@ /**

metricClientTlsNegotiationErrorCount(props) {
return this.metric('ClientTLSNegotiationErrorCount', {
statistic: 'sum',
...props
});
return this.metric('ClientTLSNegotiationErrorCount', Object.assign({ statistic: 'sum' }, props));
}

@@ -117,6 +103,3 @@ /**

metricConsumedLCUs(props) {
return this.metric('ConsumedLCUs', {
statistic: 'sum',
...props
});
return this.metric('ConsumedLCUs', Object.assign({ statistic: 'sum' }, props));
}

@@ -129,6 +112,3 @@ /**

metricHttpFixedResponseCount(props) {
return this.metric('HTTP_Fixed_Response_Count', {
statistic: 'Sum',
...props
});
return this.metric('HTTP_Fixed_Response_Count', Object.assign({ statistic: 'Sum' }, props));
}

@@ -141,6 +121,3 @@ /**

metricHttpRedirectCount(props) {
return this.metric('HTTP_Redirect_Count', {
statistic: 'Sum',
...props
});
return this.metric('HTTP_Redirect_Count', Object.assign({ statistic: 'Sum' }, props));
}

@@ -154,6 +131,3 @@ /**

metricHttpRedirectUrlLimitExceededCount(props) {
return this.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', {
statistic: 'Sum',
...props
});
return this.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', Object.assign({ statistic: 'Sum' }, props));
}

@@ -168,6 +142,3 @@ /**

metricHttpCodeElb(code, props) {
return this.metric(code, {
statistic: 'Sum',
...props
});
return this.metric(code, Object.assign({ statistic: 'Sum' }, props));
}

@@ -183,6 +154,3 @@ /**

metricHttpCodeTarget(code, props) {
return this.metric(code, {
statistic: 'Sum',
...props
});
return this.metric(code, Object.assign({ statistic: 'Sum' }, props));
}

@@ -195,6 +163,3 @@ /**

metricIpv6ProcessedBytes(props) {
return this.metric('IPv6ProcessedBytes', {
statistic: 'Sum',
...props
});
return this.metric('IPv6ProcessedBytes', Object.assign({ statistic: 'Sum' }, props));
}

@@ -207,6 +172,3 @@ /**

metricIpv6RequestCount(props) {
return this.metric('IPv6RequestCount', {
statistic: 'Sum',
...props
});
return this.metric('IPv6RequestCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -220,6 +182,3 @@ /**

metricNewConnectionCount(props) {
return this.metric('NewConnectionCount', {
statistic: 'Sum',
...props
});
return this.metric('NewConnectionCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -232,6 +191,3 @@ /**

metricProcessedBytes(props) {
return this.metric('ProcessedBytes', {
statistic: 'Sum',
...props
});
return this.metric('ProcessedBytes', Object.assign({ statistic: 'Sum' }, props));
}

@@ -245,6 +201,3 @@ /**

metricRejectedConnectionCount(props) {
return this.metric('RejectedConnectionCount', {
statistic: 'Sum',
...props
});
return this.metric('RejectedConnectionCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -259,6 +212,3 @@ /**

metricRequestCount(props) {
return this.metric('RequestCount', {
statistic: 'Sum',
...props
});
return this.metric('RequestCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -271,6 +221,3 @@ /**

metricRuleEvaluations(props) {
return this.metric('RuleEvaluations', {
statistic: 'Sum',
...props
});
return this.metric('RuleEvaluations', Object.assign({ statistic: 'Sum' }, props));
}

@@ -283,6 +230,3 @@ /**

metricTargetConnectionErrorCount(props) {
return this.metric('TargetConnectionErrorCount', {
statistic: 'Sum',
...props
});
return this.metric('TargetConnectionErrorCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -295,6 +239,3 @@ /**

metricTargetResponseTime(props) {
return this.metric('TargetResponseTime', {
statistic: 'Average',
...props
});
return this.metric('TargetResponseTime', Object.assign({ statistic: 'Average' }, props));
}

@@ -309,6 +250,3 @@ /**

metricTargetTLSNegotiationErrorCount(props) {
return this.metric('TargetTLSNegotiationErrorCount', {
statistic: 'Sum',
...props
});
return this.metric('TargetTLSNegotiationErrorCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -325,6 +263,3 @@ /**

metricElbAuthError(props) {
return this.metric('ELBAuthError', {
statistic: 'Sum',
...props
});
return this.metric('ELBAuthError', Object.assign({ statistic: 'Sum' }, props));
}

@@ -339,6 +274,3 @@ /**

metricElbAuthFailure(props) {
return this.metric('ELBAuthFailure', {
statistic: 'Sum',
...props
});
return this.metric('ELBAuthFailure', Object.assign({ statistic: 'Sum' }, props));
}

@@ -353,6 +285,3 @@ /**

metricElbAuthLatency(props) {
return this.metric('ELBAuthLatency', {
statistic: 'Average',
...props
});
return this.metric('ELBAuthLatency', Object.assign({ statistic: 'Average' }, props));
}

@@ -368,6 +297,3 @@ /**

metricElbAuthSuccess(props) {
return this.metric('ELBAuthSuccess', {
statistic: 'Sum',
...props
});
return this.metric('ELBAuthSuccess', Object.assign({ statistic: 'Sum' }, props));
}

@@ -459,6 +385,3 @@ }

addListener(id, props) {
return new application_listener_1.ApplicationListener(this, id, {
loadBalancer: this,
...props
});
return new application_listener_1.ApplicationListener(this, id, Object.assign({ loadBalancer: this }, props));
}

@@ -480,2 +403,2 @@ get loadBalancerCanonicalHostedZoneId() {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-load-balancer.js","sourceRoot":"","sources":["application-load-balancer.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 s3 = require('@aws-cdk/aws-s3');\nimport { Construct, Duration, Lazy, Resource, Stack, Token } from '@aws-cdk/core';\nimport { BaseLoadBalancer, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { IpAddressType } from '../shared/enums';\nimport { ApplicationListener, BaseApplicationListenerProps } from './application-listener';\n\n/**\n * Properties for defining an Application Load Balancer\n */\nexport interface ApplicationLoadBalancerProps extends BaseLoadBalancerProps {\n  /**\n   * Security group to associate with this load balancer\n   *\n   * @default A security group is created\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The type of IP addresses to use\n   *\n   * Only applies to application load balancers.\n   *\n   * @default IpAddressType.Ipv4\n   */\n  readonly ipAddressType?: IpAddressType;\n\n  /**\n   * Indicates whether HTTP/2 is enabled.\n   *\n   * @default true\n   */\n  readonly http2Enabled?: boolean;\n\n  /**\n   * The load balancer idle timeout, in seconds\n   *\n   * @default 60\n   */\n  readonly idleTimeout?: Duration;\n}\n\n/**\n * Define an Application Load Balancer\n *\n * @resource AWS::ElasticLoadBalancingV2::LoadBalancer\n */\nexport class ApplicationLoadBalancer extends BaseLoadBalancer implements IApplicationLoadBalancer {\n  /**\n   * Import an existing Application Load Balancer\n   */\n  public static fromApplicationLoadBalancerAttributes(\n    scope: Construct, id: string, attrs: ApplicationLoadBalancerAttributes): IApplicationLoadBalancer {\n\n    return new ImportedApplicationLoadBalancer(scope, id, attrs);\n  }\n\n  public readonly connections: ec2.Connections;\n  private readonly securityGroup: ec2.ISecurityGroup;\n\n  constructor(scope: Construct, id: string, props: ApplicationLoadBalancerProps) {\n    super(scope, id, props, {\n      type: \"application\",\n      securityGroups: Lazy.listValue({ produce: () => [this.securityGroup.securityGroupId] }),\n      ipAddressType: props.ipAddressType,\n    });\n\n    this.securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: `Automatically created Security Group for ELB ${this.node.uniqueId}`,\n      allowAllOutbound: false\n    });\n    this.connections = new ec2.Connections({ securityGroups: [this.securityGroup] });\n\n    if (props.http2Enabled === false) { this.setAttribute('routing.http2.enabled', 'false'); }\n    if (props.idleTimeout !== undefined) { this.setAttribute('idle_timeout.timeout_seconds', props.idleTimeout.toSeconds().toString()); }\n  }\n\n  /**\n   * Enable access logging for this load balancer\n   */\n  public logAccessLogs(bucket: s3.IBucket, prefix?: string) {\n    this.setAttribute('access_logs.s3.enabled', 'true');\n    this.setAttribute('access_logs.s3.bucket', bucket.bucketName.toString());\n    this.setAttribute('access_logs.s3.prefix', prefix);\n\n    const region = Stack.of(this).region;\n    if (Token.isUnresolved(region)) {\n      throw new Error(`Region is required to enable ELBv2 access logging`);\n    }\n\n    const account = ELBV2_ACCOUNTS[region];\n    if (!account) {\n      throw new Error(`Cannot enable access logging; don't know ELBv2 account for region ${region}`);\n    }\n\n    prefix = prefix || '';\n    bucket.grantPut(new iam.AccountPrincipal(account), `${(prefix ? prefix + \"/\" : \"\")}AWSLogs/${Stack.of(this).account}/*`);\n\n    // make sure the bucket's policy is created before the ALB (see https://github.com/aws/aws-cdk/issues/1633)\n    this.node.addDependency(bucket);\n  }\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  /**\n   * Return the given named metric for this Application Load Balancer\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensions: { LoadBalancer: this.loadBalancerFullName },\n      ...props\n    });\n  }\n\n  /**\n   * The total number of concurrent TCP connections active from clients to the\n   * load balancer and from the load balancer to targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricActiveConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('ActiveConnectionCount', {\n      statistic: 'sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the client that did not\n   * establish a session with the load balancer. Possible causes include a\n   * mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricClientTlsNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('ClientTLSNegotiationErrorCount', {\n      statistic: 'sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of load balancer capacity units (LCU) used by your load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.metric('ConsumedLCUs', {\n      statistic: 'sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of fixed-response actions that were successful.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpFixedResponseCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HTTP_Fixed_Response_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of redirect actions that were successful.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpRedirectCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HTTP_Redirect_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of redirect actions that couldn't be completed because the URL\n   * in the response location header is larger than 8K.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpRedirectUrlLimitExceededCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of HTTP 3xx/4xx/5xx codes that originate from the load balancer.\n   *\n   * This does not include any response codes generated by the targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeElb(code: HttpCodeElb, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets\n   * in the load balancer.\n   *\n   * This does not include any response codes generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer over IPv6.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6ProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.metric('IPv6ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of IPv6 requests received by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of new TCP connections established from clients to the\n   * load balancer and from the load balancer to targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricNewConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('NewConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer over IPv4 and IPv6.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of connections that were rejected because the load balancer had\n   * reached its maximum number of connections.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRejectedConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('RejectedConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of requests processed over IPv4 and IPv6.\n   *\n   * This count includes only the requests with a response generated by a target of the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of rules processed by the load balancer given a request rate averaged over an hour.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRuleEvaluations(props?: cloudwatch.MetricOptions) {\n    return this.metric('RuleEvaluations', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of connections that were not successfully established between the load balancer and target.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the load balancer that did not establish a session with the target.\n   *\n   * Possible causes include a mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of user authentications that could not be completed\n   *\n   * Because an authenticate action was misconfigured, the load balancer\n   * couldn't establish a connection with the IdP, or the load balancer\n   * couldn't complete the authentication flow due to an internal error.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthError(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthError', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of user authentications that could not be completed because the\n   * IdP denied access to the user or an authorization code was used more than\n   * once.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthFailure(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthFailure', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The time elapsed, in milliseconds, to query the IdP for the ID token and user info.\n   *\n   * If one or more of these operations fail, this is the time to failure.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricElbAuthLatency(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthLatency', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of authenticate actions that were successful.\n   *\n   * This metric is incremented at the end of the authentication workflow,\n   * after the load balancer has retrieved the user claims from the IdP.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthSuccess(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthSuccess', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n}\n\n/**\n * Count of HTTP status originating from the load balancer\n *\n * This count does not include any response codes generated by the targets.\n */\nexport enum HttpCodeElb {\n  /**\n   * The number of HTTP 3XX redirection codes that originate from the load balancer.\n   */\n  ELB_3XX_COUNT = 'HTTPCode_ELB_3XX_Count',\n\n  /**\n   * The number of HTTP 4XX client error codes that originate from the load balancer.\n   *\n   * Client errors are generated when requests are malformed or incomplete.\n   * These requests have not been received by the target. This count does not\n   * include any response codes generated by the targets.\n   */\n  ELB_4XX_COUNT = 'HTTPCode_ELB_4XX_Count',\n\n  /**\n   * The number of HTTP 5XX server error codes that originate from the load balancer.\n   */\n  ELB_5XX_COUNT = 'HTTPCode_ELB_5XX_Count',\n}\n\n/**\n * Count of HTTP status originating from the targets\n */\nexport enum HttpCodeTarget {\n  /**\n   * The number of 2xx response codes from targets\n   */\n  TARGET_2XX_COUNT = 'HTTPCode_Target_2XX_Count',\n\n  /**\n   * The number of 3xx response codes from targets\n   */\n  TARGET_3XX_COUNT = 'HTTPCode_Target_3XX_Count',\n\n  /**\n   * The number of 4xx response codes from targets\n   */\n  TARGET_4XX_COUNT = 'HTTPCode_Target_4XX_Count',\n\n  /**\n   * The number of 5xx response codes from targets\n   */\n  TARGET_5XX_COUNT = 'HTTPCode_Target_5XX_Count'\n}\n\n/**\n * An application load balancer\n */\nexport interface IApplicationLoadBalancer extends ILoadBalancerV2, ec2.IConnectable {\n  /**\n   * The ARN of this load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The VPC this load balancer has been created in (if available)\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface ApplicationLoadBalancerAttributes {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * ID of the load balancer's security group\n   */\n  readonly securityGroupId: string;\n\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerDnsName?: string;\n\n  /**\n   * Whether the security group allows all outbound traffic or not\n   *\n   * Unless set to `false`, no egress rules will be added to the security group.\n   *\n   * @default true\n   */\n  readonly securityGroupAllowsAllOutbound?: boolean;\n}\n\n// https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-access-logs.html#access-logging-bucket-permissions\nconst ELBV2_ACCOUNTS: { [region: string]: string } = {\n  'us-east-1': '127311923021',\n  'us-east-2': '033677994240',\n  'us-west-1': '027434742980',\n  'us-west-2': '797873946194',\n  'ca-central-1': '985666609251',\n  'eu-central-1': '054676820928',\n  'eu-west-1': '156460612806',\n  'eu-west-2': '652711504416',\n  'eu-west-3': '009996457667',\n  'ap-northeast-1': '582318560864',\n  'ap-northeast-2': '600734575887',\n  'ap-northeast-3': '383597477331',\n  'ap-southeast-1': '114774131450',\n  'ap-southeast-2': '783225319266',\n  'ap-south-1': '718504428378',\n  'sa-east-1': '507241528517',\n  'us-gov-west-1': '048591011584',\n  'cn-north-1': '638102146993',\n  'cn-northwest-1': '037604701340',\n};\n\n/**\n * An ApplicationLoadBalancer that has been defined elsewhere\n */\nclass ImportedApplicationLoadBalancer extends Resource implements IApplicationLoadBalancer {\n  /**\n   * Manage connections for this load balancer\n   */\n  public readonly connections: ec2.Connections;\n\n  /**\n   * ARN of the load balancer\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * VPC of the load balancer\n   *\n   * Always undefined.\n   */\n  public readonly vpc?: ec2.IVpc;\n\n  constructor(scope: Construct, id: string, private readonly props: ApplicationLoadBalancerAttributes) {\n    super(scope, id);\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.connections = new ec2.Connections({\n      securityGroups: [ec2.SecurityGroup.fromSecurityGroupId(this, 'SecurityGroup', props.securityGroupId, {\n        allowAllOutbound: props.securityGroupAllowsAllOutbound\n      })]\n    });\n  }\n\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  public get loadBalancerCanonicalHostedZoneId(): string {\n    if (this.props.loadBalancerCanonicalHostedZoneId) { return this.props.loadBalancerCanonicalHostedZoneId; }\n    // tslint:disable-next-line:max-line-length\n    throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n\n  public get loadBalancerDnsName(): string {\n    if (this.props.loadBalancerDnsName) { return this.props.loadBalancerDnsName; }\n    // tslint:disable-next-line:max-line-length\n    throw new Error(`'loadBalancerDnsName' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-load-balancer.js","sourceRoot":"","sources":["application-load-balancer.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 s3 = require('@aws-cdk/aws-s3');\nimport { Construct, Duration, Lazy, Resource, Stack, Token } from '@aws-cdk/core';\nimport { BaseLoadBalancer, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { IpAddressType } from '../shared/enums';\nimport { ApplicationListener, BaseApplicationListenerProps } from './application-listener';\n\n/**\n * Properties for defining an Application Load Balancer\n */\nexport interface ApplicationLoadBalancerProps extends BaseLoadBalancerProps {\n  /**\n   * Security group to associate with this load balancer\n   *\n   * @default A security group is created\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The type of IP addresses to use\n   *\n   * Only applies to application load balancers.\n   *\n   * @default IpAddressType.Ipv4\n   */\n  readonly ipAddressType?: IpAddressType;\n\n  /**\n   * Indicates whether HTTP/2 is enabled.\n   *\n   * @default true\n   */\n  readonly http2Enabled?: boolean;\n\n  /**\n   * The load balancer idle timeout, in seconds\n   *\n   * @default 60\n   */\n  readonly idleTimeout?: Duration;\n}\n\n/**\n * Define an Application Load Balancer\n *\n * @resource AWS::ElasticLoadBalancingV2::LoadBalancer\n */\nexport class ApplicationLoadBalancer extends BaseLoadBalancer implements IApplicationLoadBalancer {\n  /**\n   * Import an existing Application Load Balancer\n   */\n  public static fromApplicationLoadBalancerAttributes(\n    scope: Construct, id: string, attrs: ApplicationLoadBalancerAttributes): IApplicationLoadBalancer {\n\n    return new ImportedApplicationLoadBalancer(scope, id, attrs);\n  }\n\n  public readonly connections: ec2.Connections;\n  private readonly securityGroup: ec2.ISecurityGroup;\n\n  constructor(scope: Construct, id: string, props: ApplicationLoadBalancerProps) {\n    super(scope, id, props, {\n      type: \"application\",\n      securityGroups: Lazy.listValue({ produce: () => [this.securityGroup.securityGroupId] }),\n      ipAddressType: props.ipAddressType,\n    });\n\n    this.securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: `Automatically created Security Group for ELB ${this.node.uniqueId}`,\n      allowAllOutbound: false\n    });\n    this.connections = new ec2.Connections({ securityGroups: [this.securityGroup] });\n\n    if (props.http2Enabled === false) { this.setAttribute('routing.http2.enabled', 'false'); }\n    if (props.idleTimeout !== undefined) { this.setAttribute('idle_timeout.timeout_seconds', props.idleTimeout.toSeconds().toString()); }\n  }\n\n  /**\n   * Enable access logging for this load balancer\n   */\n  public logAccessLogs(bucket: s3.IBucket, prefix?: string) {\n    this.setAttribute('access_logs.s3.enabled', 'true');\n    this.setAttribute('access_logs.s3.bucket', bucket.bucketName.toString());\n    this.setAttribute('access_logs.s3.prefix', prefix);\n\n    const region = Stack.of(this).region;\n    if (Token.isUnresolved(region)) {\n      throw new Error(`Region is required to enable ELBv2 access logging`);\n    }\n\n    const account = ELBV2_ACCOUNTS[region];\n    if (!account) {\n      throw new Error(`Cannot enable access logging; don't know ELBv2 account for region ${region}`);\n    }\n\n    prefix = prefix || '';\n    bucket.grantPut(new iam.AccountPrincipal(account), `${(prefix ? prefix + \"/\" : \"\")}AWSLogs/${Stack.of(this).account}/*`);\n\n    // make sure the bucket's policy is created before the ALB (see https://github.com/aws/aws-cdk/issues/1633)\n    this.node.addDependency(bucket);\n  }\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  /**\n   * Return the given named metric for this Application Load Balancer\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensions: { LoadBalancer: this.loadBalancerFullName },\n      ...props\n    });\n  }\n\n  /**\n   * The total number of concurrent TCP connections active from clients to the\n   * load balancer and from the load balancer to targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricActiveConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('ActiveConnectionCount', {\n      statistic: 'sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the client that did not\n   * establish a session with the load balancer. Possible causes include a\n   * mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricClientTlsNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('ClientTLSNegotiationErrorCount', {\n      statistic: 'sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of load balancer capacity units (LCU) used by your load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.metric('ConsumedLCUs', {\n      statistic: 'sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of fixed-response actions that were successful.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpFixedResponseCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HTTP_Fixed_Response_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of redirect actions that were successful.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpRedirectCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HTTP_Redirect_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of redirect actions that couldn't be completed because the URL\n   * in the response location header is larger than 8K.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpRedirectUrlLimitExceededCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of HTTP 3xx/4xx/5xx codes that originate from the load balancer.\n   *\n   * This does not include any response codes generated by the targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeElb(code: HttpCodeElb, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets\n   * in the load balancer.\n   *\n   * This does not include any response codes generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer over IPv6.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6ProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.metric('IPv6ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of IPv6 requests received by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of new TCP connections established from clients to the\n   * load balancer and from the load balancer to targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricNewConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('NewConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer over IPv4 and IPv6.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of connections that were rejected because the load balancer had\n   * reached its maximum number of connections.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRejectedConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('RejectedConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of requests processed over IPv4 and IPv6.\n   *\n   * This count includes only the requests with a response generated by a target of the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of rules processed by the load balancer given a request rate averaged over an hour.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRuleEvaluations(props?: cloudwatch.MetricOptions) {\n    return this.metric('RuleEvaluations', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of connections that were not successfully established between the load balancer and target.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the load balancer that did not establish a session with the target.\n   *\n   * Possible causes include a mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of user authentications that could not be completed\n   *\n   * Because an authenticate action was misconfigured, the load balancer\n   * couldn't establish a connection with the IdP, or the load balancer\n   * couldn't complete the authentication flow due to an internal error.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthError(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthError', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of user authentications that could not be completed because the\n   * IdP denied access to the user or an authorization code was used more than\n   * once.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthFailure(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthFailure', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The time elapsed, in milliseconds, to query the IdP for the ID token and user info.\n   *\n   * If one or more of these operations fail, this is the time to failure.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricElbAuthLatency(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthLatency', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of authenticate actions that were successful.\n   *\n   * This metric is incremented at the end of the authentication workflow,\n   * after the load balancer has retrieved the user claims from the IdP.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthSuccess(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthSuccess', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n}\n\n/**\n * Count of HTTP status originating from the load balancer\n *\n * This count does not include any response codes generated by the targets.\n */\nexport enum HttpCodeElb {\n  /**\n   * The number of HTTP 3XX redirection codes that originate from the load balancer.\n   */\n  ELB_3XX_COUNT = 'HTTPCode_ELB_3XX_Count',\n\n  /**\n   * The number of HTTP 4XX client error codes that originate from the load balancer.\n   *\n   * Client errors are generated when requests are malformed or incomplete.\n   * These requests have not been received by the target. This count does not\n   * include any response codes generated by the targets.\n   */\n  ELB_4XX_COUNT = 'HTTPCode_ELB_4XX_Count',\n\n  /**\n   * The number of HTTP 5XX server error codes that originate from the load balancer.\n   */\n  ELB_5XX_COUNT = 'HTTPCode_ELB_5XX_Count',\n}\n\n/**\n * Count of HTTP status originating from the targets\n */\nexport enum HttpCodeTarget {\n  /**\n   * The number of 2xx response codes from targets\n   */\n  TARGET_2XX_COUNT = 'HTTPCode_Target_2XX_Count',\n\n  /**\n   * The number of 3xx response codes from targets\n   */\n  TARGET_3XX_COUNT = 'HTTPCode_Target_3XX_Count',\n\n  /**\n   * The number of 4xx response codes from targets\n   */\n  TARGET_4XX_COUNT = 'HTTPCode_Target_4XX_Count',\n\n  /**\n   * The number of 5xx response codes from targets\n   */\n  TARGET_5XX_COUNT = 'HTTPCode_Target_5XX_Count'\n}\n\n/**\n * An application load balancer\n */\nexport interface IApplicationLoadBalancer extends ILoadBalancerV2, ec2.IConnectable {\n  /**\n   * The ARN of this load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The VPC this load balancer has been created in (if available)\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface ApplicationLoadBalancerAttributes {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * ID of the load balancer's security group\n   */\n  readonly securityGroupId: string;\n\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerDnsName?: string;\n\n  /**\n   * Whether the security group allows all outbound traffic or not\n   *\n   * Unless set to `false`, no egress rules will be added to the security group.\n   *\n   * @default true\n   */\n  readonly securityGroupAllowsAllOutbound?: boolean;\n}\n\n// https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-access-logs.html#access-logging-bucket-permissions\nconst ELBV2_ACCOUNTS: { [region: string]: string } = {\n  'us-east-1': '127311923021',\n  'us-east-2': '033677994240',\n  'us-west-1': '027434742980',\n  'us-west-2': '797873946194',\n  'ca-central-1': '985666609251',\n  'eu-central-1': '054676820928',\n  'eu-west-1': '156460612806',\n  'eu-west-2': '652711504416',\n  'eu-west-3': '009996457667',\n  'ap-northeast-1': '582318560864',\n  'ap-northeast-2': '600734575887',\n  'ap-northeast-3': '383597477331',\n  'ap-southeast-1': '114774131450',\n  'ap-southeast-2': '783225319266',\n  'ap-south-1': '718504428378',\n  'sa-east-1': '507241528517',\n  'us-gov-west-1': '048591011584',\n  'cn-north-1': '638102146993',\n  'cn-northwest-1': '037604701340',\n};\n\n/**\n * An ApplicationLoadBalancer that has been defined elsewhere\n */\nclass ImportedApplicationLoadBalancer extends Resource implements IApplicationLoadBalancer {\n  /**\n   * Manage connections for this load balancer\n   */\n  public readonly connections: ec2.Connections;\n\n  /**\n   * ARN of the load balancer\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * VPC of the load balancer\n   *\n   * Always undefined.\n   */\n  public readonly vpc?: ec2.IVpc;\n\n  constructor(scope: Construct, id: string, private readonly props: ApplicationLoadBalancerAttributes) {\n    super(scope, id);\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.connections = new ec2.Connections({\n      securityGroups: [ec2.SecurityGroup.fromSecurityGroupId(this, 'SecurityGroup', props.securityGroupId, {\n        allowAllOutbound: props.securityGroupAllowsAllOutbound\n      })]\n    });\n  }\n\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  public get loadBalancerCanonicalHostedZoneId(): string {\n    if (this.props.loadBalancerCanonicalHostedZoneId) { return this.props.loadBalancerCanonicalHostedZoneId; }\n    // tslint:disable-next-line:max-line-length\n    throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n\n  public get loadBalancerDnsName(): string {\n    if (this.props.loadBalancerDnsName) { return this.props.loadBalancerDnsName; }\n    // tslint:disable-next-line:max-line-length\n    throw new Error(`'loadBalancerDnsName' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n}\n"]}

@@ -15,3 +15,3 @@ "use strict";

const [protocol, port] = util_1.determineProtocolAndPort(props.protocol, props.port);
super(scope, id, { ...props }, {
super(scope, id, Object.assign({}, props), {
protocol,

@@ -105,11 +105,6 @@ port,

metric(metricName, props) {
return new cloudwatch.Metric({
namespace: 'AWS/ApplicationELB',
metricName,
dimensions: {
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/ApplicationELB', metricName, dimensions: {
TargetGroup: this.targetGroupFullName,
LoadBalancer: this.firstLoadBalancerFullName,
},
...props
});
} }, props));
}

@@ -122,6 +117,3 @@ /**

metricIpv6RequestCount(props) {
return this.metric('IPv6RequestCount', {
statistic: 'Sum',
...props
});
return this.metric('IPv6RequestCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -136,6 +128,3 @@ /**

metricRequestCount(props) {
return this.metric('RequestCount', {
statistic: 'Sum',
...props
});
return this.metric('RequestCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -148,6 +137,3 @@ /**

metricHealthyHostCount(props) {
return this.metric('HealthyHostCount', {
statistic: 'Average',
...props
});
return this.metric('HealthyHostCount', Object.assign({ statistic: 'Average' }, props));
}

@@ -160,6 +146,3 @@ /**

metricUnhealthyHostCount(props) {
return this.metric('UnhealthyHostCount', {
statistic: 'Average',
...props
});
return this.metric('UnHealthyHostCount', Object.assign({ statistic: 'Average' }, props));
}

@@ -174,6 +157,3 @@ /**

metricHttpCodeTarget(code, props) {
return this.metric(code, {
statistic: 'Sum',
...props
});
return this.metric(code, Object.assign({ statistic: 'Sum' }, props));
}

@@ -188,6 +168,3 @@ /**

metricRequestCountPerTarget(props) {
return this.metric('RequestCountPerTarget', {
statistic: 'Sum',
...props
});
return this.metric('RequestCountPerTarget', Object.assign({ statistic: 'Sum' }, props));
}

@@ -200,6 +177,3 @@ /**

metricTargetConnectionErrorCount(props) {
return this.metric('TargetConnectionErrorCount', {
statistic: 'Sum',
...props
});
return this.metric('TargetConnectionErrorCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -212,6 +186,3 @@ /**

metricTargetResponseTime(props) {
return this.metric('TargetResponseTime', {
statistic: 'Average',
...props
});
return this.metric('TargetResponseTime', Object.assign({ statistic: 'Average' }, props));
}

@@ -226,6 +197,3 @@ /**

metricTargetTLSNegotiationErrorCount(props) {
return this.metric('TargetTLSNegotiationErrorCount', {
statistic: 'Sum',
...props
});
return this.metric('TargetTLSNegotiationErrorCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -250,2 +218,2 @@ validate() {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-target-group.js","sourceRoot":"","sources":["application-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, Duration, IConstruct } from '@aws-cdk/core';\nimport {\n  BaseTargetGroupProps, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n  TargetGroupBase, TargetGroupImportProps\n} from '../shared/base-target-group';\nimport { ApplicationProtocol, TargetType } from '../shared/enums';\nimport { ImportedTargetGroupBase } from '../shared/imported';\nimport { determineProtocolAndPort } from '../shared/util';\nimport { IApplicationListener } from './application-listener';\nimport { HttpCodeTarget } from './application-load-balancer';\n\n/**\n * Properties for defining an Application Target Group\n */\nexport interface ApplicationTargetGroupProps extends BaseTargetGroupProps {\n  /**\n   * The protocol to use\n   *\n   * @default - Determined from port if known, optional for Lambda targets.\n   */\n  readonly protocol?: ApplicationProtocol;\n\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default - Determined from protocol if known, optional for Lambda targets.\n   */\n  readonly port?: number;\n\n  /**\n   * The time period during which the load balancer sends a newly registered\n   * target a linearly increasing share of the traffic to the target group.\n   *\n   * The range is 30-900 seconds (15 minutes).\n   *\n   * @default 0\n   */\n  readonly slowStart?: Duration;\n\n  /**\n   * The stickiness cookie expiration period.\n   *\n   * Setting this value enables load balancer stickiness.\n   *\n   * After this period, the cookie is considered stale. The minimum value is\n   * 1 second and the maximum value is 7 days (604800 seconds).\n   *\n   * @default Duration.days(1)\n   */\n  readonly stickinessCookieDuration?: Duration;\n\n  /**\n   * The targets to add to this target group.\n   *\n   * Can be `Instance`, `IPAddress`, or any self-registering load balancing\n   * target. If you use either `Instance` or `IPAddress` as targets, all\n   * target must be of the same type.\n   *\n   * @default - No targets.\n   */\n  readonly targets?: IApplicationLoadBalancerTarget[];\n}\n\n/**\n * Define an Application Target Group\n */\nexport class ApplicationTargetGroup extends TargetGroupBase implements IApplicationTargetGroup {\n  /**\n   * Import an existing target group\n   */\n  public static import(scope: Construct, id: string, props: TargetGroupImportProps): IApplicationTargetGroup {\n    return new ImportedApplicationTargetGroup(scope, id, props);\n  }\n\n  private readonly connectableMembers: ConnectableMember[];\n  private readonly listeners: IApplicationListener[];\n  private readonly protocol?: ApplicationProtocol;\n  private readonly port?: number;\n\n  constructor(scope: Construct, id: string, props: ApplicationTargetGroupProps = {}) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n    super(scope, id, { ...props }, {\n      protocol,\n      port,\n    });\n\n    this.protocol = protocol;\n    this.port = port;\n\n    this.connectableMembers = [];\n    this.listeners = [];\n\n    if (props) {\n      if (props.slowStart !== undefined) {\n        this.setAttribute('slow_start.duration_seconds', props.slowStart.toSeconds().toString());\n      }\n      if (props.stickinessCookieDuration !== undefined) {\n        this.enableCookieStickiness(props.stickinessCookieDuration);\n      }\n      this.addTarget(...(props.targets || []));\n    }\n  }\n\n  /**\n   * Add a load balancing target to this target group\n   */\n  public addTarget(...targets: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n  }\n\n  /**\n   * Enable sticky routing via a cookie to members of this target group\n   */\n  public enableCookieStickiness(duration: Duration) {\n    this.setAttribute('stickiness.enabled', 'true');\n    this.setAttribute('stickiness.type', 'lb_cookie');\n    this.setAttribute('stickiness.lb_cookie.duration_seconds', duration.toSeconds().toString());\n  }\n\n  /**\n   * Register a connectable as a member of this target group.\n   *\n   * Don't call this directly. It will be called by load balancing targets.\n   */\n  public registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port) {\n    portRange = portRange || ec2.Port.tcp(this.defaultPort);\n\n    // Notify all listeners that we already know about of this new connectable.\n    // Then remember for new listeners that might get added later.\n    this.connectableMembers.push({ connectable, portRange });\n    for (const listener of this.listeners) {\n      listener.registerConnectable(connectable, portRange);\n    }\n  }\n\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  public registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    // Notify this listener of all connectables that we know about.\n    // Then remember for new connectables that might get added later.\n    for (const member of this.connectableMembers) {\n      listener.registerConnectable(member.connectable, member.portRange);\n    }\n    this.listeners.push(listener);\n    this.loadBalancerAttachedDependencies.add(associatingConstruct || listener);\n  }\n\n  /**\n   * Full name of first load balancer\n   */\n  public get firstLoadBalancerFullName(): string {\n    if (this.listeners.length === 0) {\n      throw new Error('The TargetGroup needs to be attached to a LoadBalancer before you can call this method');\n    }\n    return loadBalancerNameFromListenerArn(this.listeners[0].listenerArn);\n  }\n\n  /**\n   * Return the given named metric for this Application Load Balancer Target Group\n   *\n   * Returns the metric for this target group from the point of view of the first\n   * load balancer load balancing to it. If you have multiple load balancers load\n   * sending traffic to the same target group, you will have to override the dimensions\n   * on this metric.\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensions: {\n        TargetGroup: this.targetGroupFullName,\n        LoadBalancer: this.firstLoadBalancerFullName,\n      },\n      ...props\n    });\n  }\n\n  /**\n   * The number of IPv6 requests received by the target group\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of requests processed over IPv4 and IPv6.\n   *\n   * This count includes only the requests with a response generated by a target of the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of healthy hosts in the target group\n   *\n   * @default Average over 5 minutes\n   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of unhealthy hosts in the target group\n   *\n   * @default Average over 5 minutes\n   */\n  public metricUnhealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnhealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets in this target group.\n   *\n   * This does not include any response codes generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The average number of requests received by each target in a target group.\n   *\n   * The only valid statistic is Sum. Note that this represents the average not the sum.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCountPerTarget(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCountPerTarget', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of connections that were not successfully established between the load balancer and target.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the load balancer that did not establish a session with the target.\n   *\n   * Possible causes include a mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  protected validate(): string[]  {\n    const ret = super.validate();\n\n    if (this.targetType !== undefined && this.targetType !== TargetType.LAMBDA\n      && (this.protocol === undefined || this.port === undefined)) {\n        ret.push(`At least one of 'port' or 'protocol' is required for a non-Lambda TargetGroup`);\n    }\n\n    return ret;\n  }\n}\n\n/**\n * A connectable member of a target group\n */\ninterface ConnectableMember {\n  /**\n   * The connectable member\n   */\n  connectable: ec2.IConnectable;\n\n  /**\n   * The port (range) the member is listening on\n   */\n  portRange: ec2.Port;\n}\n\n/**\n * A Target Group for Application Load Balancers\n */\nexport interface IApplicationTargetGroup extends ITargetGroup {\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct): void;\n}\n\n/**\n * An imported application target group\n */\nclass ImportedApplicationTargetGroup extends ImportedTargetGroupBase implements IApplicationTargetGroup {\n  public registerListener(_listener: IApplicationListener, _associatingConstruct?: IConstruct) {\n    // Nothing to do, we know nothing of our members\n  }\n}\n\n/**\n * Interface for constructs that can be targets of an application load balancer\n */\nexport interface IApplicationLoadBalancerTarget {\n  /**\n   * Attach load-balanced target to a TargetGroup\n   *\n   * May return JSON to directly add to the [Targets] list, or return undefined\n   * if the target will register itself with the load balancer.\n   */\n  attachToApplicationTargetGroup(targetGroup: ApplicationTargetGroup): LoadBalancerTargetProps;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-target-group.js","sourceRoot":"","sources":["application-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, Duration, IConstruct } from '@aws-cdk/core';\nimport {\n  BaseTargetGroupProps, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n  TargetGroupBase, TargetGroupImportProps\n} from '../shared/base-target-group';\nimport { ApplicationProtocol, TargetType } from '../shared/enums';\nimport { ImportedTargetGroupBase } from '../shared/imported';\nimport { determineProtocolAndPort } from '../shared/util';\nimport { IApplicationListener } from './application-listener';\nimport { HttpCodeTarget } from './application-load-balancer';\n\n/**\n * Properties for defining an Application Target Group\n */\nexport interface ApplicationTargetGroupProps extends BaseTargetGroupProps {\n  /**\n   * The protocol to use\n   *\n   * @default - Determined from port if known, optional for Lambda targets.\n   */\n  readonly protocol?: ApplicationProtocol;\n\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default - Determined from protocol if known, optional for Lambda targets.\n   */\n  readonly port?: number;\n\n  /**\n   * The time period during which the load balancer sends a newly registered\n   * target a linearly increasing share of the traffic to the target group.\n   *\n   * The range is 30-900 seconds (15 minutes).\n   *\n   * @default 0\n   */\n  readonly slowStart?: Duration;\n\n  /**\n   * The stickiness cookie expiration period.\n   *\n   * Setting this value enables load balancer stickiness.\n   *\n   * After this period, the cookie is considered stale. The minimum value is\n   * 1 second and the maximum value is 7 days (604800 seconds).\n   *\n   * @default Duration.days(1)\n   */\n  readonly stickinessCookieDuration?: Duration;\n\n  /**\n   * The targets to add to this target group.\n   *\n   * Can be `Instance`, `IPAddress`, or any self-registering load balancing\n   * target. If you use either `Instance` or `IPAddress` as targets, all\n   * target must be of the same type.\n   *\n   * @default - No targets.\n   */\n  readonly targets?: IApplicationLoadBalancerTarget[];\n}\n\n/**\n * Define an Application Target Group\n */\nexport class ApplicationTargetGroup extends TargetGroupBase implements IApplicationTargetGroup {\n  /**\n   * Import an existing target group\n   */\n  public static import(scope: Construct, id: string, props: TargetGroupImportProps): IApplicationTargetGroup {\n    return new ImportedApplicationTargetGroup(scope, id, props);\n  }\n\n  private readonly connectableMembers: ConnectableMember[];\n  private readonly listeners: IApplicationListener[];\n  private readonly protocol?: ApplicationProtocol;\n  private readonly port?: number;\n\n  constructor(scope: Construct, id: string, props: ApplicationTargetGroupProps = {}) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n    super(scope, id, { ...props }, {\n      protocol,\n      port,\n    });\n\n    this.protocol = protocol;\n    this.port = port;\n\n    this.connectableMembers = [];\n    this.listeners = [];\n\n    if (props) {\n      if (props.slowStart !== undefined) {\n        this.setAttribute('slow_start.duration_seconds', props.slowStart.toSeconds().toString());\n      }\n      if (props.stickinessCookieDuration !== undefined) {\n        this.enableCookieStickiness(props.stickinessCookieDuration);\n      }\n      this.addTarget(...(props.targets || []));\n    }\n  }\n\n  /**\n   * Add a load balancing target to this target group\n   */\n  public addTarget(...targets: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n  }\n\n  /**\n   * Enable sticky routing via a cookie to members of this target group\n   */\n  public enableCookieStickiness(duration: Duration) {\n    this.setAttribute('stickiness.enabled', 'true');\n    this.setAttribute('stickiness.type', 'lb_cookie');\n    this.setAttribute('stickiness.lb_cookie.duration_seconds', duration.toSeconds().toString());\n  }\n\n  /**\n   * Register a connectable as a member of this target group.\n   *\n   * Don't call this directly. It will be called by load balancing targets.\n   */\n  public registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port) {\n    portRange = portRange || ec2.Port.tcp(this.defaultPort);\n\n    // Notify all listeners that we already know about of this new connectable.\n    // Then remember for new listeners that might get added later.\n    this.connectableMembers.push({ connectable, portRange });\n    for (const listener of this.listeners) {\n      listener.registerConnectable(connectable, portRange);\n    }\n  }\n\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  public registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    // Notify this listener of all connectables that we know about.\n    // Then remember for new connectables that might get added later.\n    for (const member of this.connectableMembers) {\n      listener.registerConnectable(member.connectable, member.portRange);\n    }\n    this.listeners.push(listener);\n    this.loadBalancerAttachedDependencies.add(associatingConstruct || listener);\n  }\n\n  /**\n   * Full name of first load balancer\n   */\n  public get firstLoadBalancerFullName(): string {\n    if (this.listeners.length === 0) {\n      throw new Error('The TargetGroup needs to be attached to a LoadBalancer before you can call this method');\n    }\n    return loadBalancerNameFromListenerArn(this.listeners[0].listenerArn);\n  }\n\n  /**\n   * Return the given named metric for this Application Load Balancer Target Group\n   *\n   * Returns the metric for this target group from the point of view of the first\n   * load balancer load balancing to it. If you have multiple load balancers load\n   * sending traffic to the same target group, you will have to override the dimensions\n   * on this metric.\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensions: {\n        TargetGroup: this.targetGroupFullName,\n        LoadBalancer: this.firstLoadBalancerFullName,\n      },\n      ...props\n    });\n  }\n\n  /**\n   * The number of IPv6 requests received by the target group\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of requests processed over IPv4 and IPv6.\n   *\n   * This count includes only the requests with a response generated by a target of the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of healthy hosts in the target group\n   *\n   * @default Average over 5 minutes\n   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of unhealthy hosts in the target group\n   *\n   * @default Average over 5 minutes\n   */\n  public metricUnhealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets in this target group.\n   *\n   * This does not include any response codes generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The average number of requests received by each target in a target group.\n   *\n   * The only valid statistic is Sum. Note that this represents the average not the sum.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCountPerTarget(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCountPerTarget', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of connections that were not successfully established between the load balancer and target.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the load balancer that did not establish a session with the target.\n   *\n   * Possible causes include a mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  protected validate(): string[]  {\n    const ret = super.validate();\n\n    if (this.targetType !== undefined && this.targetType !== TargetType.LAMBDA\n      && (this.protocol === undefined || this.port === undefined)) {\n        ret.push(`At least one of 'port' or 'protocol' is required for a non-Lambda TargetGroup`);\n    }\n\n    return ret;\n  }\n}\n\n/**\n * A connectable member of a target group\n */\ninterface ConnectableMember {\n  /**\n   * The connectable member\n   */\n  connectable: ec2.IConnectable;\n\n  /**\n   * The port (range) the member is listening on\n   */\n  portRange: ec2.Port;\n}\n\n/**\n * A Target Group for Application Load Balancers\n */\nexport interface IApplicationTargetGroup extends ITargetGroup {\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct): void;\n}\n\n/**\n * An imported application target group\n */\nclass ImportedApplicationTargetGroup extends ImportedTargetGroupBase implements IApplicationTargetGroup {\n  public registerListener(_listener: IApplicationListener, _associatingConstruct?: IConstruct) {\n    // Nothing to do, we know nothing of our members\n  }\n}\n\n/**\n * Interface for constructs that can be targets of an application load balancer\n */\nexport interface IApplicationLoadBalancerTarget {\n  /**\n   * Attach load-balanced target to a TargetGroup\n   *\n   * May return JSON to directly add to the [Targets] list, or return undefined\n   * if the target will register itself with the load balancer.\n   */\n  attachToApplicationTargetGroup(targetGroup: ApplicationTargetGroup): LoadBalancerTargetProps;\n}\n"]}

@@ -21,6 +21,3 @@ "use strict";

addListener(lid, props) {
return new network_listener_1.NetworkListener(this, lid, {
loadBalancer: this,
...props
});
return new network_listener_1.NetworkListener(this, lid, Object.assign({ loadBalancer: this }, props));
}

@@ -58,6 +55,3 @@ get loadBalancerCanonicalHostedZoneId() {

addListener(id, props) {
return new network_listener_1.NetworkListener(this, id, {
loadBalancer: this,
...props
});
return new network_listener_1.NetworkListener(this, id, Object.assign({ loadBalancer: this }, props));
}

@@ -70,8 +64,3 @@ /**

metric(metricName, props) {
return new cloudwatch.Metric({
namespace: 'AWS/NetworkELB',
metricName,
dimensions: { LoadBalancer: this.loadBalancerFullName },
...props
});
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/NetworkELB', metricName, dimensions: { LoadBalancer: this.loadBalancerFullName } }, props));
}

@@ -88,6 +77,3 @@ /**

metricActiveFlowCount(props) {
return this.metric('ActiveFlowCount', {
statistic: 'Average',
...props
});
return this.metric('ActiveFlowCount', Object.assign({ statistic: 'Average' }, props));
}

@@ -100,6 +86,3 @@ /**

metricConsumedLCUs(props) {
return this.metric('ConsumedLCUs', {
statistic: 'Sum',
...props
});
return this.metric('ConsumedLCUs', Object.assign({ statistic: 'Sum' }, props));
}

@@ -112,6 +95,3 @@ /**

metricHealthyHostCount(props) {
return this.metric('HealthyHostCount', {
statistic: 'Average',
...props
});
return this.metric('HealthyHostCount', Object.assign({ statistic: 'Average' }, props));
}

@@ -124,6 +104,3 @@ /**

metricUnHealthyHostCount(props) {
return this.metric('UnHealthyHostCount', {
statistic: 'Average',
...props
});
return this.metric('UnHealthyHostCount', Object.assign({ statistic: 'Average' }, props));
}

@@ -136,6 +113,3 @@ /**

metricNewFlowCount(props) {
return this.metric('NewFlowCount', {
statistic: 'Sum',
...props
});
return this.metric('NewFlowCount', Object.assign({ statistic: 'Sum' }, props));
}

@@ -148,6 +122,3 @@ /**

metricProcessedBytes(props) {
return this.metric('ProcessedBytes', {
statistic: 'Sum',
...props
});
return this.metric('ProcessedBytes', Object.assign({ statistic: 'Sum' }, props));
}

@@ -162,6 +133,3 @@ /**

metricTcpClientResetCount(props) {
return this.metric('TCP_Client_Reset_Count', {
statistic: 'Sum',
...props
});
return this.metric('TCP_Client_Reset_Count', Object.assign({ statistic: 'Sum' }, props));
}

@@ -174,6 +142,3 @@ /**

metricTcpElbResetCount(props) {
return this.metric('TCP_ELB_Reset_Count', {
statistic: 'Sum',
...props
});
return this.metric('TCP_ELB_Reset_Count', Object.assign({ statistic: 'Sum' }, props));
}

@@ -188,9 +153,6 @@ /**

metricTcpTargetResetCount(props) {
return this.metric('TCP_Target_Reset_Count', {
statistic: 'Sum',
...props
});
return this.metric('TCP_Target_Reset_Count', Object.assign({ statistic: 'Sum' }, props));
}
}
exports.NetworkLoadBalancer = NetworkLoadBalancer;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-load-balancer.js","sourceRoot":"","sources":["network-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, Resource } from '@aws-cdk/core';\nimport { BaseLoadBalancer, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { BaseNetworkListenerProps, NetworkListener } from './network-listener';\n\n/**\n * Properties for a network load balancer\n */\nexport interface NetworkLoadBalancerProps extends BaseLoadBalancerProps {\n  /**\n   * Indicates whether cross-zone load balancing is enabled.\n   *\n   * @default false\n   */\n  readonly crossZoneEnabled?: boolean;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface NetworkLoadBalancerAttributes {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerDnsName?: string;\n}\n\n/**\n * Define a new network load balancer\n *\n * @resource AWS::ElasticLoadBalancingV2::LoadBalancer\n */\nexport class NetworkLoadBalancer extends BaseLoadBalancer implements INetworkLoadBalancer {\n  public static fromNetworkLoadBalancerAttributes(scope: Construct, id: string, attrs: NetworkLoadBalancerAttributes): INetworkLoadBalancer {\n    class Import extends Resource implements INetworkLoadBalancer {\n      public readonly loadBalancerArn = attrs.loadBalancerArn;\n      public readonly vpc?: ec2.IVpc = undefined;\n      public addListener(lid: string, props: BaseNetworkListenerProps): NetworkListener {\n        return new NetworkListener(this, lid, {\n          loadBalancer: this,\n          ...props\n        });\n      }\n\n      public get loadBalancerCanonicalHostedZoneId(): string {\n        if (attrs.loadBalancerCanonicalHostedZoneId) { return attrs.loadBalancerCanonicalHostedZoneId; }\n        // tslint:disable-next-line:max-line-length\n        throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n\n      public get loadBalancerDnsName(): string {\n        if (attrs.loadBalancerDnsName) { return attrs.loadBalancerDnsName; }\n        // tslint:disable-next-line:max-line-length\n        throw new Error(`'loadBalancerDnsName' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  constructor(scope: Construct, id: string, props: NetworkLoadBalancerProps) {\n    super(scope, id, props, {\n      type: \"network\",\n    });\n\n    if (props.crossZoneEnabled) { this.setAttribute('load_balancing.cross_zone.enabled', 'true'); }\n  }\n\n  /**\n   * Add a listener to this load balancer\n   *\n   * @returns The newly created listener\n   */\n  public addListener(id: string, props: BaseNetworkListenerProps): NetworkListener {\n    return new NetworkListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  /**\n   * Return the given named metric for this Network Load Balancer\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/NetworkELB',\n      metricName,\n      dimensions: { LoadBalancer: this.loadBalancerFullName },\n      ...props\n    });\n  }\n\n  /**\n   * The total number of concurrent TCP flows (or connections) from clients to targets.\n   *\n   * This metric includes connections in the SYN_SENT and ESTABLISHED states.\n   * TCP connections are not terminated at the load balancer, so a client\n   * opening a TCP connection to a target counts as a single flow.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricActiveFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('ActiveFlowCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of load balancer capacity units (LCU) used by your load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.metric('ConsumedLCUs', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of targets that are considered healthy.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of targets that are considered unhealthy.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricUnHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of new TCP flows (or connections) established from clients to targets in the time period.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricNewFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('NewFlowCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer, including TCP/IP headers.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of reset (RST) packets sent from a client to a target.\n   *\n   * These resets are generated by the client and forwarded by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpClientResetCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TCP_Client_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of reset (RST) packets generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpElbResetCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TCP_ELB_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of reset (RST) packets sent from a target to a client.\n   *\n   * These resets are generated by the target and forwarded by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpTargetResetCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TCP_Target_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n}\n\n/**\n * A network load balancer\n */\nexport interface INetworkLoadBalancer extends ILoadBalancerV2 {\n  /**\n   * The ARN of this load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The VPC this load balancer has been created in (if available)\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Add a listener to this load balancer\n   *\n   * @returns The newly created listener\n   */\n  addListener(id: string, props: BaseNetworkListenerProps): NetworkListener;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-load-balancer.js","sourceRoot":"","sources":["network-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, Resource } from '@aws-cdk/core';\nimport { BaseLoadBalancer, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { BaseNetworkListenerProps, NetworkListener } from './network-listener';\n\n/**\n * Properties for a network load balancer\n */\nexport interface NetworkLoadBalancerProps extends BaseLoadBalancerProps {\n  /**\n   * Indicates whether cross-zone load balancing is enabled.\n   *\n   * @default false\n   */\n  readonly crossZoneEnabled?: boolean;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface NetworkLoadBalancerAttributes {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerDnsName?: string;\n}\n\n/**\n * Define a new network load balancer\n *\n * @resource AWS::ElasticLoadBalancingV2::LoadBalancer\n */\nexport class NetworkLoadBalancer extends BaseLoadBalancer implements INetworkLoadBalancer {\n  public static fromNetworkLoadBalancerAttributes(scope: Construct, id: string, attrs: NetworkLoadBalancerAttributes): INetworkLoadBalancer {\n    class Import extends Resource implements INetworkLoadBalancer {\n      public readonly loadBalancerArn = attrs.loadBalancerArn;\n      public readonly vpc?: ec2.IVpc = undefined;\n      public addListener(lid: string, props: BaseNetworkListenerProps): NetworkListener {\n        return new NetworkListener(this, lid, {\n          loadBalancer: this,\n          ...props\n        });\n      }\n\n      public get loadBalancerCanonicalHostedZoneId(): string {\n        if (attrs.loadBalancerCanonicalHostedZoneId) { return attrs.loadBalancerCanonicalHostedZoneId; }\n        // tslint:disable-next-line:max-line-length\n        throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n\n      public get loadBalancerDnsName(): string {\n        if (attrs.loadBalancerDnsName) { return attrs.loadBalancerDnsName; }\n        // tslint:disable-next-line:max-line-length\n        throw new Error(`'loadBalancerDnsName' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  constructor(scope: Construct, id: string, props: NetworkLoadBalancerProps) {\n    super(scope, id, props, {\n      type: \"network\",\n    });\n\n    if (props.crossZoneEnabled) { this.setAttribute('load_balancing.cross_zone.enabled', 'true'); }\n  }\n\n  /**\n   * Add a listener to this load balancer\n   *\n   * @returns The newly created listener\n   */\n  public addListener(id: string, props: BaseNetworkListenerProps): NetworkListener {\n    return new NetworkListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  /**\n   * Return the given named metric for this Network Load Balancer\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/NetworkELB',\n      metricName,\n      dimensions: { LoadBalancer: this.loadBalancerFullName },\n      ...props\n    });\n  }\n\n  /**\n   * The total number of concurrent TCP flows (or connections) from clients to targets.\n   *\n   * This metric includes connections in the SYN_SENT and ESTABLISHED states.\n   * TCP connections are not terminated at the load balancer, so a client\n   * opening a TCP connection to a target counts as a single flow.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricActiveFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('ActiveFlowCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of load balancer capacity units (LCU) used by your load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.metric('ConsumedLCUs', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The number of targets that are considered healthy.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The number of targets that are considered unhealthy.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricUnHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of new TCP flows (or connections) established from clients to targets in the time period.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricNewFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('NewFlowCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer, including TCP/IP headers.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of reset (RST) packets sent from a client to a target.\n   *\n   * These resets are generated by the client and forwarded by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpClientResetCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TCP_Client_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of reset (RST) packets generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpElbResetCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TCP_ELB_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n\n  /**\n   * The total number of reset (RST) packets sent from a target to a client.\n   *\n   * These resets are generated by the target and forwarded by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpTargetResetCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TCP_Target_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n}\n\n/**\n * A network load balancer\n */\nexport interface INetworkLoadBalancer extends ILoadBalancerV2 {\n  /**\n   * The ARN of this load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The VPC this load balancer has been created in (if available)\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Add a listener to this load balancer\n   *\n   * @returns The newly created listener\n   */\n  addListener(id: string, props: BaseNetworkListenerProps): NetworkListener;\n}\n"]}

@@ -12,6 +12,3 @@ "use strict";

this.defaultActions = [];
const resource = new elasticloadbalancingv2_generated_1.CfnListener(this, 'Resource', {
...additionalProps,
defaultActions: core_1.Lazy.anyValue({ produce: () => this.defaultActions }),
});
const resource = new elasticloadbalancingv2_generated_1.CfnListener(this, 'Resource', Object.assign(Object.assign({}, additionalProps), { defaultActions: core_1.Lazy.anyValue({ produce: () => this.defaultActions }) }));
this.listenerArn = resource.ref;

@@ -47,2 +44,2 @@ }

exports.BaseListener = BaseListener;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1saXN0ZW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImJhc2UtbGlzdGVuZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx3Q0FBMEQ7QUFDMUQsMEZBQWtFO0FBR2xFOztHQUVHO0FBQ0gsTUFBc0IsWUFBYSxTQUFRLGVBQVE7SUFRakQsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxlQUFvQjtRQUM1RCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBSEYsbUJBQWMsR0FBaUMsRUFBRSxDQUFDO1FBS2pFLE1BQU0sUUFBUSxHQUFHLElBQUksOENBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ2pELEdBQUcsZUFBZTtZQUNsQixjQUFjLEVBQUUsV0FBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7U0FDdEUsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDO0lBQ2xDLENBQUM7SUFFRDs7T0FFRztJQUNPLFFBQVE7UUFDaEIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDcEMsT0FBTyxDQUFDLHlFQUF5RSxDQUFDLENBQUM7U0FDcEY7UUFDRCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRDs7O09BR0c7SUFDTyxpQkFBaUIsQ0FBQyxNQUFrQztRQUM1RCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ08sc0JBQXNCLENBQUMsV0FBeUI7UUFDeEQsSUFBSSxDQUFDLGlCQUFpQixDQUFDO1lBQ3JCLGNBQWMsRUFBRSxXQUFXLENBQUMsY0FBYztZQUMxQyxJQUFJLEVBQUUsU0FBUztTQUNoQixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUEvQ0Qsb0NBK0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0LCBMYXp5LCBSZXNvdXJjZSB9IGZyb20gJ0Bhd3MtY2RrL2NvcmUnO1xuaW1wb3J0IHsgQ2ZuTGlzdGVuZXIgfSBmcm9tICcuLi9lbGFzdGljbG9hZGJhbGFuY2luZ3YyLmdlbmVyYXRlZCc7XG5pbXBvcnQgeyBJVGFyZ2V0R3JvdXAgfSBmcm9tICcuL2Jhc2UtdGFyZ2V0LWdyb3VwJztcblxuLyoqXG4gKiBCYXNlIGNsYXNzIGZvciBsaXN0ZW5lcnNcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VMaXN0ZW5lciBleHRlbmRzIFJlc291cmNlIHtcbiAgLyoqXG4gICAqIEBhdHRyaWJ1dGVcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBsaXN0ZW5lckFybjogc3RyaW5nO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgZGVmYXVsdEFjdGlvbnM6IENmbkxpc3RlbmVyLkFjdGlvblByb3BlcnR5W10gPSBbXTtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBhZGRpdGlvbmFsUHJvcHM6IGFueSkge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBjb25zdCByZXNvdXJjZSA9IG5ldyBDZm5MaXN0ZW5lcih0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICAuLi5hZGRpdGlvbmFsUHJvcHMsXG4gICAgICBkZWZhdWx0QWN0aW9uczogTGF6eS5hbnlWYWx1ZSh7IHByb2R1Y2U6ICgpID0+IHRoaXMuZGVmYXVsdEFjdGlvbnMgfSksXG4gICAgfSk7XG5cbiAgICB0aGlzLmxpc3RlbmVyQXJuID0gcmVzb3VyY2UucmVmO1xuICB9XG5cbiAgLyoqXG4gICAqIFZhbGlkYXRlIHRoaXMgbGlzdGVuZXJcbiAgICovXG4gIHByb3RlY3RlZCB2YWxpZGF0ZSgpOiBzdHJpbmdbXSB7XG4gICAgaWYgKHRoaXMuZGVmYXVsdEFjdGlvbnMubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gWydMaXN0ZW5lciBuZWVkcyBhdCBsZWFzdCBvbmUgZGVmYXVsdCB0YXJnZXQgZ3JvdXAgKGNhbGwgYWRkVGFyZ2V0R3JvdXBzKSddO1xuICAgIH1cbiAgICByZXR1cm4gW107XG4gIH1cblxuICAvKipcbiAgICogQWRkIGFuIGFjdGlvbiB0byB0aGUgbGlzdCBvZiBkZWZhdWx0IGFjdGlvbnMgb2YgdGhpcyBsaXN0ZW5lclxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHByb3RlY3RlZCBfYWRkRGVmYXVsdEFjdGlvbihhY3Rpb246IENmbkxpc3RlbmVyLkFjdGlvblByb3BlcnR5KSB7XG4gICAgdGhpcy5kZWZhdWx0QWN0aW9ucy5wdXNoKGFjdGlvbik7XG4gIH1cblxuICAvKipcbiAgICogQWRkIGEgVGFyZ2V0R3JvdXAgdG8gdGhlIGxpc3Qgb2YgZGVmYXVsdCBhY3Rpb25zIG9mIHRoaXMgbGlzdGVuZXJcbiAgICogQGludGVybmFsXG4gICAqL1xuICBwcm90ZWN0ZWQgX2FkZERlZmF1bHRUYXJnZXRHcm91cCh0YXJnZXRHcm91cDogSVRhcmdldEdyb3VwKSB7XG4gICAgdGhpcy5fYWRkRGVmYXVsdEFjdGlvbih7XG4gICAgICB0YXJnZXRHcm91cEFybjogdGFyZ2V0R3JvdXAudGFyZ2V0R3JvdXBBcm4sXG4gICAgICB0eXBlOiAnZm9yd2FyZCdcbiAgICB9KTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1saXN0ZW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImJhc2UtbGlzdGVuZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx3Q0FBMEQ7QUFDMUQsMEZBQWtFO0FBR2xFOztHQUVHO0FBQ0gsTUFBc0IsWUFBYSxTQUFRLGVBQVE7SUFRakQsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxlQUFvQjtRQUM1RCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBSEYsbUJBQWMsR0FBaUMsRUFBRSxDQUFDO1FBS2pFLE1BQU0sUUFBUSxHQUFHLElBQUksOENBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxrQ0FDNUMsZUFBZSxLQUNsQixjQUFjLEVBQUUsV0FBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsSUFDckUsQ0FBQztRQUVILElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7O09BRUc7SUFDTyxRQUFRO1FBQ2hCLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ3BDLE9BQU8sQ0FBQyx5RUFBeUUsQ0FBQyxDQUFDO1NBQ3BGO1FBQ0QsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0lBRUQ7OztPQUdHO0lBQ08saUJBQWlCLENBQUMsTUFBa0M7UUFDNUQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVEOzs7T0FHRztJQUNPLHNCQUFzQixDQUFDLFdBQXlCO1FBQ3hELElBQUksQ0FBQyxpQkFBaUIsQ0FBQztZQUNyQixjQUFjLEVBQUUsV0FBVyxDQUFDLGNBQWM7WUFDMUMsSUFBSSxFQUFFLFNBQVM7U0FDaEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBL0NELG9DQStDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCwgTGF6eSwgUmVzb3VyY2UgfSBmcm9tICdAYXdzLWNkay9jb3JlJztcbmltcG9ydCB7IENmbkxpc3RlbmVyIH0gZnJvbSAnLi4vZWxhc3RpY2xvYWRiYWxhbmNpbmd2Mi5nZW5lcmF0ZWQnO1xuaW1wb3J0IHsgSVRhcmdldEdyb3VwIH0gZnJvbSAnLi9iYXNlLXRhcmdldC1ncm91cCc7XG5cbi8qKlxuICogQmFzZSBjbGFzcyBmb3IgbGlzdGVuZXJzXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlTGlzdGVuZXIgZXh0ZW5kcyBSZXNvdXJjZSB7XG4gIC8qKlxuICAgKiBAYXR0cmlidXRlXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgbGlzdGVuZXJBcm46IHN0cmluZztcblxuICBwcml2YXRlIHJlYWRvbmx5IGRlZmF1bHRBY3Rpb25zOiBDZm5MaXN0ZW5lci5BY3Rpb25Qcm9wZXJ0eVtdID0gW107XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgYWRkaXRpb25hbFByb3BzOiBhbnkpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgcmVzb3VyY2UgPSBuZXcgQ2ZuTGlzdGVuZXIodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgLi4uYWRkaXRpb25hbFByb3BzLFxuICAgICAgZGVmYXVsdEFjdGlvbnM6IExhenkuYW55VmFsdWUoeyBwcm9kdWNlOiAoKSA9PiB0aGlzLmRlZmF1bHRBY3Rpb25zIH0pLFxuICAgIH0pO1xuXG4gICAgdGhpcy5saXN0ZW5lckFybiA9IHJlc291cmNlLnJlZjtcbiAgfVxuXG4gIC8qKlxuICAgKiBWYWxpZGF0ZSB0aGlzIGxpc3RlbmVyXG4gICAqL1xuICBwcm90ZWN0ZWQgdmFsaWRhdGUoKTogc3RyaW5nW10ge1xuICAgIGlmICh0aGlzLmRlZmF1bHRBY3Rpb25zLmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIFsnTGlzdGVuZXIgbmVlZHMgYXQgbGVhc3Qgb25lIGRlZmF1bHQgdGFyZ2V0IGdyb3VwIChjYWxsIGFkZFRhcmdldEdyb3VwcyknXTtcbiAgICB9XG4gICAgcmV0dXJuIFtdO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhbiBhY3Rpb24gdG8gdGhlIGxpc3Qgb2YgZGVmYXVsdCBhY3Rpb25zIG9mIHRoaXMgbGlzdGVuZXJcbiAgICogQGludGVybmFsXG4gICAqL1xuICBwcm90ZWN0ZWQgX2FkZERlZmF1bHRBY3Rpb24oYWN0aW9uOiBDZm5MaXN0ZW5lci5BY3Rpb25Qcm9wZXJ0eSkge1xuICAgIHRoaXMuZGVmYXVsdEFjdGlvbnMucHVzaChhY3Rpb24pO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhIFRhcmdldEdyb3VwIHRvIHRoZSBsaXN0IG9mIGRlZmF1bHQgYWN0aW9ucyBvZiB0aGlzIGxpc3RlbmVyXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgcHJvdGVjdGVkIF9hZGREZWZhdWx0VGFyZ2V0R3JvdXAodGFyZ2V0R3JvdXA6IElUYXJnZXRHcm91cCkge1xuICAgIHRoaXMuX2FkZERlZmF1bHRBY3Rpb24oe1xuICAgICAgdGFyZ2V0R3JvdXBBcm46IHRhcmdldEdyb3VwLnRhcmdldEdyb3VwQXJuLFxuICAgICAgdHlwZTogJ2ZvcndhcmQnXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==

@@ -23,9 +23,3 @@ "use strict";

this.vpc = baseProps.vpc;
const resource = new elasticloadbalancingv2_generated_1.CfnLoadBalancer(this, 'Resource', {
name: this.physicalName,
subnets: subnetIds,
scheme: internetFacing ? 'internet-facing' : 'internal',
loadBalancerAttributes: core_1.Lazy.anyValue({ produce: () => util_1.renderAttributes(this.attributes) }, { omitEmptyArray: true }),
...additionalProps
});
const resource = new elasticloadbalancingv2_generated_1.CfnLoadBalancer(this, 'Resource', Object.assign({ name: this.physicalName, subnets: subnetIds, scheme: internetFacing ? 'internet-facing' : 'internal', loadBalancerAttributes: core_1.Lazy.anyValue({ produce: () => util_1.renderAttributes(this.attributes) }, { omitEmptyArray: true }) }, additionalProps));
if (internetFacing) {

@@ -60,2 +54,2 @@ resource.node.addDependency(internetConnectivityEstablished);

exports.BaseLoadBalancer = BaseLoadBalancer;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-load-balancer.js","sourceRoot":"","sources":["base-load-balancer.ts"],"names":[],"mappings":";;AAAA,wCAAyC;AACzC,wCAAqE;AACrE,0FAAsE;AACtE,iCAAmE;AA0DnE;;GAEG;AACH,MAAsB,gBAAiB,SAAQ,eAAQ;IA0DrD,YAAY,KAAgB,EAAE,EAAU,EAAE,SAAgC,EAAE,eAAoB;QAC9F,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,SAAS,CAAC,gBAAgB;SACzC,CAAC,CAAC;QARL;;WAEG;QACc,eAAU,GAAe,EAAE,CAAC;QAO3C,MAAM,cAAc,GAAG,kBAAW,CAAC,SAAS,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAEpE,MAAM,UAAU,GAAG,kBAAW,CAAC,SAAS,CAAC,UAAU,EACjD,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;QAEnF,MAAM,EAAE,SAAS,EAAE,+BAA+B,EAAE,GAAG,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAE/F,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,GAAG,CAAC;QAEzB,MAAM,QAAQ,GAAG,IAAI,kDAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YACrD,IAAI,EAAE,IAAI,CAAC,YAAY;YACvB,OAAO,EAAE,SAAS;YAClB,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,UAAU;YACvD,sBAAsB,EAAE,WAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,uBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,EAAC,cAAc,EAAE,IAAI,EAAC,CAAE;YACpH,GAAG,eAAe;SACnB,CAAC,CAAC;QACH,IAAI,cAAc,EAAE;YAClB,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,+BAA+B,CAAC,CAAC;SAC9D;QAED,IAAI,SAAS,CAAC,kBAAkB,EAAE;YAAE,IAAI,CAAC,YAAY,CAAC,6BAA6B,EAAE,MAAM,CAAC,CAAC;SAAE;QAE/F,IAAI,CAAC,iCAAiC,GAAG,QAAQ,CAAC,yBAAyB,CAAC;QAC5E,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC,WAAW,CAAC;QAChD,IAAI,CAAC,oBAAoB,GAAG,QAAQ,CAAC,wBAAwB,CAAC;QAC9D,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,oBAAoB,CAAC;QACtD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,GAAG,CAAC;QACpC,IAAI,CAAC,0BAA0B,GAAG,QAAQ,CAAC,kBAAkB,CAAC;IAChE,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,GAAW,EAAE,KAAyB;QACxD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;OAEG;IACI,eAAe,CAAC,GAAW;QAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;IACpC,CAAC;CACF;AA5GD,4CA4GC","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, IResource, Lazy, Resource } from '@aws-cdk/core';\nimport { CfnLoadBalancer } from '../elasticloadbalancingv2.generated';\nimport { Attributes, ifUndefined, renderAttributes } from './util';\n\n/**\n * Shared properties of both Application and Network Load Balancers\n */\nexport interface BaseLoadBalancerProps {\n  /**\n   * Name of the load balancer\n   *\n   * @default - Automatically generated name.\n   */\n  readonly loadBalancerName?: string;\n\n  /**\n   * The VPC network to place the load balancer in\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * Whether the load balancer has an internet-routable address\n   *\n   * @default false\n   */\n  readonly internetFacing?: boolean;\n\n  /**\n   * Where in the VPC to place the load balancer\n   *\n   * @default - Public subnets if internetFacing, otherwise private subnets.\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * Indicates whether deletion protection is enabled.\n   *\n   * @default false\n   */\n  readonly deletionProtection?: boolean;\n}\n\nexport interface ILoadBalancerV2 extends IResource {\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @example Z2P70J7EXAMPLE\n   * @attribute\n   */\n  readonly loadBalancerCanonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @example my-load-balancer-424835706.us-west-2.elb.amazonaws.com\n   * @attribute\n   */\n  readonly loadBalancerDnsName: string;\n}\n\n/**\n * Base class for both Application and Network Load Balancers\n */\nexport abstract class BaseLoadBalancer extends Resource {\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @example Z2P70J7EXAMPLE\n   * @attribute\n   */\n  public readonly loadBalancerCanonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @example my-load-balancer-424835706.us-west-2.elb.amazonaws.com\n   * @attribute\n   */\n  public readonly loadBalancerDnsName: string;\n\n  /**\n   * The full name of this load balancer\n   *\n   * @example app/my-load-balancer/50dc6c495c0c9188\n   * @attribute\n   */\n  public readonly loadBalancerFullName: string;\n\n  /**\n   * The name of this load balancer\n   *\n   * @example my-load-balancer\n   * @attribute\n   */\n  public readonly loadBalancerName: string;\n\n  /**\n   * The ARN of this load balancer\n   *\n   * @example arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-internal-load-balancer/50dc6c495c0c9188\n   * @attribute\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * @attribute\n   */\n  public readonly loadBalancerSecurityGroups: string[];\n\n  /**\n   * The VPC this load balancer has been created in, if available\n   *\n   * If the Load Balancer was imported, the VPC is not available.\n   */\n  public readonly vpc?: ec2.IVpc;\n\n  /**\n   * Attributes set on this load balancer\n   */\n  private readonly attributes: Attributes = {};\n\n  constructor(scope: Construct, id: string, baseProps: BaseLoadBalancerProps, additionalProps: any) {\n    super(scope, id, {\n      physicalName: baseProps.loadBalancerName,\n    });\n\n    const internetFacing = ifUndefined(baseProps.internetFacing, false);\n\n    const vpcSubnets = ifUndefined(baseProps.vpcSubnets,\n      { subnetType: internetFacing ? ec2.SubnetType.PUBLIC : ec2.SubnetType.PRIVATE });\n\n    const { subnetIds, internetConnectivityEstablished } = baseProps.vpc.selectSubnets(vpcSubnets);\n\n    this.vpc = baseProps.vpc;\n\n    const resource = new CfnLoadBalancer(this, 'Resource', {\n      name: this.physicalName,\n      subnets: subnetIds,\n      scheme: internetFacing ? 'internet-facing' : 'internal',\n      loadBalancerAttributes: Lazy.anyValue({ produce: () => renderAttributes(this.attributes) }, {omitEmptyArray: true} ),\n      ...additionalProps\n    });\n    if (internetFacing) {\n      resource.node.addDependency(internetConnectivityEstablished);\n    }\n\n    if (baseProps.deletionProtection) { this.setAttribute('deletion_protection.enabled', 'true'); }\n\n    this.loadBalancerCanonicalHostedZoneId = resource.attrCanonicalHostedZoneId;\n    this.loadBalancerDnsName = resource.attrDnsName;\n    this.loadBalancerFullName = resource.attrLoadBalancerFullName;\n    this.loadBalancerName = resource.attrLoadBalancerName;\n    this.loadBalancerArn = resource.ref;\n    this.loadBalancerSecurityGroups = resource.attrSecurityGroups;\n  }\n\n  /**\n   * Set a non-standard attribute on the load balancer\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/application-load-balancers.html#load-balancer-attributes\n   */\n  public setAttribute(key: string, value: string | undefined) {\n    this.attributes[key] = value;\n  }\n\n  /**\n   * Remove an attribute from the load balancer\n   */\n  public removeAttribute(key: string) {\n    this.setAttribute(key, undefined);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-load-balancer.js","sourceRoot":"","sources":["base-load-balancer.ts"],"names":[],"mappings":";;AAAA,wCAAyC;AACzC,wCAAqE;AACrE,0FAAsE;AACtE,iCAAmE;AA0DnE;;GAEG;AACH,MAAsB,gBAAiB,SAAQ,eAAQ;IA0DrD,YAAY,KAAgB,EAAE,EAAU,EAAE,SAAgC,EAAE,eAAoB;QAC9F,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,SAAS,CAAC,gBAAgB;SACzC,CAAC,CAAC;QARL;;WAEG;QACc,eAAU,GAAe,EAAE,CAAC;QAO3C,MAAM,cAAc,GAAG,kBAAW,CAAC,SAAS,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAEpE,MAAM,UAAU,GAAG,kBAAW,CAAC,SAAS,CAAC,UAAU,EACjD,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;QAEnF,MAAM,EAAE,SAAS,EAAE,+BAA+B,EAAE,GAAG,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAE/F,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,GAAG,CAAC;QAEzB,MAAM,QAAQ,GAAG,IAAI,kDAAe,CAAC,IAAI,EAAE,UAAU,kBACnD,IAAI,EAAE,IAAI,CAAC,YAAY,EACvB,OAAO,EAAE,SAAS,EAClB,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,UAAU,EACvD,sBAAsB,EAAE,WAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,uBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,EAAC,cAAc,EAAE,IAAI,EAAC,CAAE,IACjH,eAAe,EAClB,CAAC;QACH,IAAI,cAAc,EAAE;YAClB,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,+BAA+B,CAAC,CAAC;SAC9D;QAED,IAAI,SAAS,CAAC,kBAAkB,EAAE;YAAE,IAAI,CAAC,YAAY,CAAC,6BAA6B,EAAE,MAAM,CAAC,CAAC;SAAE;QAE/F,IAAI,CAAC,iCAAiC,GAAG,QAAQ,CAAC,yBAAyB,CAAC;QAC5E,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC,WAAW,CAAC;QAChD,IAAI,CAAC,oBAAoB,GAAG,QAAQ,CAAC,wBAAwB,CAAC;QAC9D,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,oBAAoB,CAAC;QACtD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,GAAG,CAAC;QACpC,IAAI,CAAC,0BAA0B,GAAG,QAAQ,CAAC,kBAAkB,CAAC;IAChE,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,GAAW,EAAE,KAAyB;QACxD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;OAEG;IACI,eAAe,CAAC,GAAW;QAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;IACpC,CAAC;CACF;AA5GD,4CA4GC","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport { Construct, IResource, Lazy, Resource } from '@aws-cdk/core';\nimport { CfnLoadBalancer } from '../elasticloadbalancingv2.generated';\nimport { Attributes, ifUndefined, renderAttributes } from './util';\n\n/**\n * Shared properties of both Application and Network Load Balancers\n */\nexport interface BaseLoadBalancerProps {\n  /**\n   * Name of the load balancer\n   *\n   * @default - Automatically generated name.\n   */\n  readonly loadBalancerName?: string;\n\n  /**\n   * The VPC network to place the load balancer in\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * Whether the load balancer has an internet-routable address\n   *\n   * @default false\n   */\n  readonly internetFacing?: boolean;\n\n  /**\n   * Where in the VPC to place the load balancer\n   *\n   * @default - Public subnets if internetFacing, otherwise private subnets.\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * Indicates whether deletion protection is enabled.\n   *\n   * @default false\n   */\n  readonly deletionProtection?: boolean;\n}\n\nexport interface ILoadBalancerV2 extends IResource {\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @example Z2P70J7EXAMPLE\n   * @attribute\n   */\n  readonly loadBalancerCanonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @example my-load-balancer-424835706.us-west-2.elb.amazonaws.com\n   * @attribute\n   */\n  readonly loadBalancerDnsName: string;\n}\n\n/**\n * Base class for both Application and Network Load Balancers\n */\nexport abstract class BaseLoadBalancer extends Resource {\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @example Z2P70J7EXAMPLE\n   * @attribute\n   */\n  public readonly loadBalancerCanonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @example my-load-balancer-424835706.us-west-2.elb.amazonaws.com\n   * @attribute\n   */\n  public readonly loadBalancerDnsName: string;\n\n  /**\n   * The full name of this load balancer\n   *\n   * @example app/my-load-balancer/50dc6c495c0c9188\n   * @attribute\n   */\n  public readonly loadBalancerFullName: string;\n\n  /**\n   * The name of this load balancer\n   *\n   * @example my-load-balancer\n   * @attribute\n   */\n  public readonly loadBalancerName: string;\n\n  /**\n   * The ARN of this load balancer\n   *\n   * @example arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-internal-load-balancer/50dc6c495c0c9188\n   * @attribute\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * @attribute\n   */\n  public readonly loadBalancerSecurityGroups: string[];\n\n  /**\n   * The VPC this load balancer has been created in, if available\n   *\n   * If the Load Balancer was imported, the VPC is not available.\n   */\n  public readonly vpc?: ec2.IVpc;\n\n  /**\n   * Attributes set on this load balancer\n   */\n  private readonly attributes: Attributes = {};\n\n  constructor(scope: Construct, id: string, baseProps: BaseLoadBalancerProps, additionalProps: any) {\n    super(scope, id, {\n      physicalName: baseProps.loadBalancerName,\n    });\n\n    const internetFacing = ifUndefined(baseProps.internetFacing, false);\n\n    const vpcSubnets = ifUndefined(baseProps.vpcSubnets,\n      { subnetType: internetFacing ? ec2.SubnetType.PUBLIC : ec2.SubnetType.PRIVATE });\n\n    const { subnetIds, internetConnectivityEstablished } = baseProps.vpc.selectSubnets(vpcSubnets);\n\n    this.vpc = baseProps.vpc;\n\n    const resource = new CfnLoadBalancer(this, 'Resource', {\n      name: this.physicalName,\n      subnets: subnetIds,\n      scheme: internetFacing ? 'internet-facing' : 'internal',\n      loadBalancerAttributes: Lazy.anyValue({ produce: () => renderAttributes(this.attributes) }, {omitEmptyArray: true} ),\n      ...additionalProps\n    });\n    if (internetFacing) {\n      resource.node.addDependency(internetConnectivityEstablished);\n    }\n\n    if (baseProps.deletionProtection) { this.setAttribute('deletion_protection.enabled', 'true'); }\n\n    this.loadBalancerCanonicalHostedZoneId = resource.attrCanonicalHostedZoneId;\n    this.loadBalancerDnsName = resource.attrDnsName;\n    this.loadBalancerFullName = resource.attrLoadBalancerFullName;\n    this.loadBalancerName = resource.attrLoadBalancerName;\n    this.loadBalancerArn = resource.ref;\n    this.loadBalancerSecurityGroups = resource.attrSecurityGroups;\n  }\n\n  /**\n   * Set a non-standard attribute on the load balancer\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/application-load-balancers.html#load-balancer-attributes\n   */\n  public setAttribute(key: string, value: string | undefined) {\n    this.attributes[key] = value;\n  }\n\n  /**\n   * Remove an attribute from the load balancer\n   */\n  public removeAttribute(key: string) {\n    this.setAttribute(key, undefined);\n  }\n}\n"]}

@@ -31,25 +31,11 @@ "use strict";

this.targetType = baseProps.targetType;
this.resource = new elasticloadbalancingv2_generated_1.CfnTargetGroup(this, 'Resource', {
name: baseProps.targetGroupName,
targetGroupAttributes: cdk.Lazy.anyValue({ produce: () => util_1.renderAttributes(this.attributes) }, { omitEmptyArray: true }),
targetType: cdk.Lazy.stringValue({ produce: () => this.targetType }),
targets: cdk.Lazy.anyValue({ produce: () => this.targetsJson }, { omitEmptyArray: true }),
vpcId: cdk.Lazy.stringValue({ produce: () => this.vpc && this.targetType !== enums_1.TargetType.LAMBDA ? this.vpc.vpcId : undefined }),
this.resource = new elasticloadbalancingv2_generated_1.CfnTargetGroup(this, 'Resource', Object.assign({ name: baseProps.targetGroupName, targetGroupAttributes: cdk.Lazy.anyValue({ produce: () => util_1.renderAttributes(this.attributes) }, { omitEmptyArray: true }), targetType: cdk.Lazy.stringValue({ produce: () => this.targetType }), targets: cdk.Lazy.anyValue({ produce: () => this.targetsJson }, { omitEmptyArray: true }), vpcId: cdk.Lazy.stringValue({ produce: () => this.vpc && this.targetType !== enums_1.TargetType.LAMBDA ? this.vpc.vpcId : undefined }),
// HEALTH CHECK
healthCheckIntervalSeconds: cdk.Lazy.numberValue({
produce: () => this.healthCheck && this.healthCheck.interval && this.healthCheck.interval.toSeconds()
}),
healthCheckPath: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.path }),
healthCheckPort: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.port }),
healthCheckProtocol: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.protocol }),
healthCheckTimeoutSeconds: cdk.Lazy.numberValue({
}), healthCheckPath: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.path }), healthCheckPort: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.port }), healthCheckProtocol: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.protocol }), healthCheckTimeoutSeconds: cdk.Lazy.numberValue({
produce: () => this.healthCheck && this.healthCheck.timeout && this.healthCheck.timeout.toSeconds()
}),
healthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.healthyThresholdCount }),
unhealthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.unhealthyThresholdCount }),
matcher: cdk.Lazy.anyValue({ produce: () => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {
}), healthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.healthyThresholdCount }), unhealthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.unhealthyThresholdCount }), matcher: cdk.Lazy.anyValue({ produce: () => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {
httpCode: this.healthCheck.healthyHttpCodes
} : undefined }),
...additionalProps
});
} : undefined }) }, additionalProps));
this.targetGroupLoadBalancerArns = this.resource.attrLoadBalancerArns;

@@ -122,2 +108,2 @@ this.targetGroupArn = this.resource.ref;

exports.loadBalancerNameFromListenerArn = loadBalancerNameFromListenerArn;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-target-group.js","sourceRoot":"","sources":["base-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/core');\nimport { CfnTargetGroup } from '../elasticloadbalancingv2.generated';\nimport { Protocol, TargetType } from './enums';\nimport { Attributes, renderAttributes } from './util';\n\n/**\n * Basic properties of both Application and Network Target Groups\n */\nexport interface BaseTargetGroupProps {\n  /**\n   * The name of the target group.\n   *\n   * This name must be unique per region per account, can have a maximum of\n   * 32 characters, must contain only alphanumeric characters or hyphens, and\n   * must not begin or end with a hyphen.\n   *\n   * @default - Automatically generated.\n   */\n  readonly targetGroupName?: string;\n\n  /**\n   * The virtual private cloud (VPC).\n   *\n   * only if `TargetType` is `Ip` or `InstanceId`\n   *\n   * @default - undefined\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n   *\n   * The range is 0-3600 seconds.\n   *\n   * @default 300\n   */\n  readonly deregistrationDelay?: cdk.Duration;\n\n  /**\n   * Health check configuration\n   *\n   * @default - None.\n   */\n  readonly healthCheck?: HealthCheck;\n\n  /**\n   * The type of targets registered to this TargetGroup, either IP or Instance.\n   *\n   * All targets registered into the group must be of this type. If you\n   * register targets to the TargetGroup in the CDK app, the TargetType is\n   * determined automatically.\n   *\n   * @default - Determined automatically.\n   */\n  readonly targetType?: TargetType;\n}\n\n/**\n * Properties for configuring a health check\n */\nexport interface HealthCheck {\n  /**\n   * The approximate number of seconds between health checks for an individual target.\n   *\n   * @default Duration.seconds(30)\n   */\n  readonly interval?: cdk.Duration;\n\n  /**\n   * The ping path destination where Elastic Load Balancing sends health check requests.\n   *\n   * @default /\n   */\n  readonly path?: string;\n\n  /**\n   * The port that the load balancer uses when performing health checks on the targets.\n   *\n   * @default 'traffic-port'\n   */\n  readonly port?: string;\n\n  /**\n   * The protocol the load balancer uses when performing health checks on targets.\n   *\n   * The TCP protocol is supported only if the protocol of the target group\n   * is TCP.\n   *\n   * @default HTTP for ALBs, TCP for NLBs\n   */\n  readonly protocol?: Protocol;\n\n  /**\n   * The amount of time, in seconds, during which no response from a target means a failed health check.\n   *\n   * For Application Load Balancers, the range is 2-60 seconds and the\n   * default is 5 seconds. For Network Load Balancers, this is 10 seconds for\n   * TCP and HTTPS health checks and 6 seconds for HTTP health checks.\n   *\n   * @default Duration.seconds(5) for ALBs, Duration.seconds(10) or Duration.seconds(6) for NLBs\n   */\n  readonly timeout?: cdk.Duration;\n\n  /**\n   * The number of consecutive health checks successes required before considering an unhealthy target healthy.\n   *\n   * For Application Load Balancers, the default is 5. For Network Load Balancers, the default is 3.\n   *\n   * @default 5 for ALBs, 3 for NLBs\n   */\n  readonly healthyThresholdCount?: number;\n\n  /**\n   * The number of consecutive health check failures required before considering a target unhealthy.\n   *\n   * For Application Load Balancers, the default is 2. For Network Load\n   * Balancers, this value must be the same as the healthy threshold count.\n   *\n   * @default 2\n   */\n  readonly unhealthyThresholdCount?: number;\n\n  /**\n   * HTTP code to use when checking for a successful response from a target.\n   *\n   * For Application Load Balancers, you can specify values between 200 and\n   * 499, and the default value is 200. You can specify multiple values (for\n   * example, \"200,202\") or a range of values (for example, \"200-299\").\n   */\n  readonly healthyHttpCodes?: string;\n}\n\n/**\n * Define the target of a load balancer\n */\nexport abstract class TargetGroupBase extends cdk.Construct implements ITargetGroup {\n  /**\n   * The ARN of the target group\n   */\n  public readonly targetGroupArn: string;\n\n  /**\n   * The full name of the target group\n   */\n  public readonly targetGroupFullName: string;\n\n  /**\n   * The name of the target group\n   */\n  public readonly targetGroupName: string;\n\n  /**\n   * ARNs of load balancers load balancing to this TargetGroup\n   */\n  public readonly targetGroupLoadBalancerArns: string[];\n\n  /**\n   * Full name of first load balancer\n   *\n   * This identifier is emitted as a dimensions of the metrics of this target\n   * group.\n   *\n   * @example app/my-load-balancer/123456789\n   */\n  public abstract readonly firstLoadBalancerFullName: string;\n\n  /**\n   * Health check for the members of this target group\n   */\n  /**\n   * A token representing a list of ARNs of the load balancers that route traffic to this target group\n   */\n  public readonly loadBalancerArns: string;\n\n  public healthCheck: HealthCheck;\n\n  /**\n   * Default port configured for members of this target group\n   */\n  protected readonly defaultPort: number;\n\n  /**\n   * Configurable dependable with all resources that lead to load balancer attachment\n   */\n  protected readonly loadBalancerAttachedDependencies = new cdk.ConcreteDependable();\n\n  /**\n   * The types of the directly registered members of this target group\n   */\n  protected targetType?: TargetType;\n\n  /**\n   * Attributes of this target group\n   */\n  private readonly attributes: Attributes = {};\n\n  /**\n   * The JSON objects returned by the directly registered members of this target group\n   */\n  private readonly targetsJson = new Array<CfnTargetGroup.TargetDescriptionProperty>();\n\n  /**\n   * The target group VPC\n   *\n   * @default - Required if adding instances instead of Lambdas to TargetGroup\n   */\n  private vpc?: ec2.IVpc;\n\n  /**\n   * The target group resource\n   */\n  private readonly resource: CfnTargetGroup;\n\n  constructor(scope: cdk.Construct, id: string, baseProps: BaseTargetGroupProps, additionalProps: any) {\n    super(scope, id);\n\n    if (baseProps.deregistrationDelay !== undefined) {\n      this.setAttribute('deregistration_delay.timeout_seconds', baseProps.deregistrationDelay.toSeconds().toString());\n    }\n\n    this.healthCheck = baseProps.healthCheck || {};\n    this.vpc = baseProps.vpc;\n    this.targetType = baseProps.targetType;\n\n    this.resource = new CfnTargetGroup(this, 'Resource', {\n      name: baseProps.targetGroupName,\n      targetGroupAttributes: cdk.Lazy.anyValue({ produce: () => renderAttributes(this.attributes) }, { omitEmptyArray: true}),\n      targetType: cdk.Lazy.stringValue({ produce: () => this.targetType }),\n      targets: cdk.Lazy.anyValue({ produce: () => this.targetsJson}, { omitEmptyArray: true }),\n      vpcId: cdk.Lazy.stringValue({ produce: () => this.vpc && this.targetType !== TargetType.LAMBDA ? this.vpc.vpcId : undefined}),\n\n      // HEALTH CHECK\n      healthCheckIntervalSeconds: cdk.Lazy.numberValue({\n        produce: () => this.healthCheck && this.healthCheck.interval && this.healthCheck.interval.toSeconds()\n      }),\n      healthCheckPath: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.path }),\n      healthCheckPort: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.port }),\n      healthCheckProtocol: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.protocol }),\n      healthCheckTimeoutSeconds: cdk.Lazy.numberValue({\n        produce: () => this.healthCheck && this.healthCheck.timeout && this.healthCheck.timeout.toSeconds()\n      }),\n      healthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.healthyThresholdCount }),\n      unhealthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.unhealthyThresholdCount }),\n      matcher: cdk.Lazy.anyValue({ produce: () => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {\n        httpCode: this.healthCheck.healthyHttpCodes\n      } : undefined }),\n\n      ...additionalProps\n    });\n\n    this.targetGroupLoadBalancerArns = this.resource.attrLoadBalancerArns;\n    this.targetGroupArn = this.resource.ref;\n    this.targetGroupFullName = this.resource.attrTargetGroupFullName;\n    this.loadBalancerArns = this.resource.attrLoadBalancerArns.toString();\n    this.targetGroupName = this.resource.attrTargetGroupName;\n    this.defaultPort = additionalProps.port;\n  }\n\n  /**\n   * List of constructs that need to be depended on to ensure the TargetGroup is associated to a load balancer\n   */\n  public get loadBalancerAttached(): cdk.IDependable {\n    return this.loadBalancerAttachedDependencies;\n  }\n\n  /**\n   * Set/replace the target group's health check\n   */\n  public configureHealthCheck(healthCheck: HealthCheck) {\n    this.healthCheck = healthCheck;\n  }\n\n  /**\n   * Set a non-standard attribute on the target group\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-target-groups.html#target-group-attributes\n   */\n  public setAttribute(key: string, value: string | undefined) {\n    this.attributes[key] = value;\n  }\n\n  /**\n   * Register the given load balancing target as part of this group\n   */\n  protected addLoadBalancerTarget(props: LoadBalancerTargetProps) {\n    if (this.targetType !== undefined && this.targetType !== props.targetType) {\n      throw new Error(`Already have a of type '${this.targetType}', adding '${props.targetType}'; make all targets the same type.`);\n    }\n    this.targetType = props.targetType;\n\n    if (this.targetType === TargetType.LAMBDA && this.targetsJson.length >= 1) {\n      throw new Error(`TargetGroup can only contain one LAMBDA target. Create a new TargetGroup.`);\n    }\n\n    if (props.targetJson) {\n      this.targetsJson.push(props.targetJson);\n    }\n  }\n\n  protected validate(): string[]  {\n    const ret = super.validate();\n\n    if (this.targetType !== undefined && this.targetType !== TargetType.LAMBDA && this.vpc === undefined) {\n      ret.push(`'vpc' is required for a non-Lambda TargetGroup`);\n    }\n\n    return ret;\n  }\n}\n\n/**\n * Properties to reference an existing target group\n */\nexport interface TargetGroupImportProps {\n  /**\n   * ARN of the target group\n   */\n  readonly targetGroupArn: string;\n\n  /**\n   * Port target group is listening on\n   */\n  readonly defaultPort: string;\n\n  /**\n   * A Token representing the list of ARNs for the load balancer routing to this target group\n   */\n  readonly loadBalancerArns?: string;\n}\n\n/**\n * A target group\n */\nexport interface ITargetGroup extends cdk.IConstruct {\n  /**\n   * ARN of the target group\n   */\n  readonly targetGroupArn: string;\n\n  /**\n   * A token representing a list of ARNs of the load balancers that route traffic to this target group\n   */\n  readonly loadBalancerArns: string;\n\n  /**\n   * Return an object to depend on the listeners added to this target group\n   */\n  readonly loadBalancerAttached: cdk.IDependable;\n}\n\n/**\n * Result of attaching a target to load balancer\n */\nexport interface LoadBalancerTargetProps {\n  /**\n   * What kind of target this is\n   */\n  readonly targetType: TargetType;\n\n  /**\n   * JSON representing the target's direct addition to the TargetGroup list\n   *\n   * May be omitted if the target is going to register itself later.\n   */\n  readonly targetJson?: any;\n}\n\n/**\n * Extract the full load balancer name (used for metrics) from the listener ARN:\n *\n * Turns\n *\n *     arn:aws:elasticloadbalancing:us-west-2:123456789012:listener/app/my-load-balancer/50dc6c495c0c9188/f2f7dc8efc522ab2\n *\n * Into\n *\n *     app/my-load-balancer/50dc6c495c0c9188\n */\nexport function loadBalancerNameFromListenerArn(listenerArn: string) {\n    const arnParts = cdk.Fn.split('/', listenerArn);\n    return `${cdk.Fn.select(1, arnParts)}/${cdk.Fn.select(2, arnParts)}/${cdk.Fn.select(3, arnParts)}`;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-target-group.js","sourceRoot":"","sources":["base-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/core');\nimport { CfnTargetGroup } from '../elasticloadbalancingv2.generated';\nimport { Protocol, TargetType } from './enums';\nimport { Attributes, renderAttributes } from './util';\n\n/**\n * Basic properties of both Application and Network Target Groups\n */\nexport interface BaseTargetGroupProps {\n  /**\n   * The name of the target group.\n   *\n   * This name must be unique per region per account, can have a maximum of\n   * 32 characters, must contain only alphanumeric characters or hyphens, and\n   * must not begin or end with a hyphen.\n   *\n   * @default - Automatically generated.\n   */\n  readonly targetGroupName?: string;\n\n  /**\n   * The virtual private cloud (VPC).\n   *\n   * only if `TargetType` is `Ip` or `InstanceId`\n   *\n   * @default - undefined\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n   *\n   * The range is 0-3600 seconds.\n   *\n   * @default 300\n   */\n  readonly deregistrationDelay?: cdk.Duration;\n\n  /**\n   * Health check configuration\n   *\n   * @default - None.\n   */\n  readonly healthCheck?: HealthCheck;\n\n  /**\n   * The type of targets registered to this TargetGroup, either IP or Instance.\n   *\n   * All targets registered into the group must be of this type. If you\n   * register targets to the TargetGroup in the CDK app, the TargetType is\n   * determined automatically.\n   *\n   * @default - Determined automatically.\n   */\n  readonly targetType?: TargetType;\n}\n\n/**\n * Properties for configuring a health check\n */\nexport interface HealthCheck {\n  /**\n   * The approximate number of seconds between health checks for an individual target.\n   *\n   * @default Duration.seconds(30)\n   */\n  readonly interval?: cdk.Duration;\n\n  /**\n   * The ping path destination where Elastic Load Balancing sends health check requests.\n   *\n   * @default /\n   */\n  readonly path?: string;\n\n  /**\n   * The port that the load balancer uses when performing health checks on the targets.\n   *\n   * @default 'traffic-port'\n   */\n  readonly port?: string;\n\n  /**\n   * The protocol the load balancer uses when performing health checks on targets.\n   *\n   * The TCP protocol is supported only if the protocol of the target group\n   * is TCP.\n   *\n   * @default HTTP for ALBs, TCP for NLBs\n   */\n  readonly protocol?: Protocol;\n\n  /**\n   * The amount of time, in seconds, during which no response from a target means a failed health check.\n   *\n   * For Application Load Balancers, the range is 2-60 seconds and the\n   * default is 5 seconds. For Network Load Balancers, this is 10 seconds for\n   * TCP and HTTPS health checks and 6 seconds for HTTP health checks.\n   *\n   * @default Duration.seconds(5) for ALBs, Duration.seconds(10) or Duration.seconds(6) for NLBs\n   */\n  readonly timeout?: cdk.Duration;\n\n  /**\n   * The number of consecutive health checks successes required before considering an unhealthy target healthy.\n   *\n   * For Application Load Balancers, the default is 5. For Network Load Balancers, the default is 3.\n   *\n   * @default 5 for ALBs, 3 for NLBs\n   */\n  readonly healthyThresholdCount?: number;\n\n  /**\n   * The number of consecutive health check failures required before considering a target unhealthy.\n   *\n   * For Application Load Balancers, the default is 2. For Network Load\n   * Balancers, this value must be the same as the healthy threshold count.\n   *\n   * @default 2\n   */\n  readonly unhealthyThresholdCount?: number;\n\n  /**\n   * HTTP code to use when checking for a successful response from a target.\n   *\n   * For Application Load Balancers, you can specify values between 200 and\n   * 499, and the default value is 200. You can specify multiple values (for\n   * example, \"200,202\") or a range of values (for example, \"200-299\").\n   */\n  readonly healthyHttpCodes?: string;\n}\n\n/**\n * Define the target of a load balancer\n */\nexport abstract class TargetGroupBase extends cdk.Construct implements ITargetGroup {\n  /**\n   * The ARN of the target group\n   */\n  public readonly targetGroupArn: string;\n\n  /**\n   * The full name of the target group\n   */\n  public readonly targetGroupFullName: string;\n\n  /**\n   * The name of the target group\n   */\n  public readonly targetGroupName: string;\n\n  /**\n   * ARNs of load balancers load balancing to this TargetGroup\n   */\n  public readonly targetGroupLoadBalancerArns: string[];\n\n  /**\n   * Full name of first load balancer\n   *\n   * This identifier is emitted as a dimensions of the metrics of this target\n   * group.\n   *\n   * @example app/my-load-balancer/123456789\n   */\n  public abstract readonly firstLoadBalancerFullName: string;\n\n  /**\n   * Health check for the members of this target group\n   */\n  /**\n   * A token representing a list of ARNs of the load balancers that route traffic to this target group\n   */\n  public readonly loadBalancerArns: string;\n\n  public healthCheck: HealthCheck;\n\n  /**\n   * Default port configured for members of this target group\n   */\n  protected readonly defaultPort: number;\n\n  /**\n   * Configurable dependable with all resources that lead to load balancer attachment\n   */\n  protected readonly loadBalancerAttachedDependencies = new cdk.ConcreteDependable();\n\n  /**\n   * The types of the directly registered members of this target group\n   */\n  protected targetType?: TargetType;\n\n  /**\n   * Attributes of this target group\n   */\n  private readonly attributes: Attributes = {};\n\n  /**\n   * The JSON objects returned by the directly registered members of this target group\n   */\n  private readonly targetsJson = new Array<CfnTargetGroup.TargetDescriptionProperty>();\n\n  /**\n   * The target group VPC\n   *\n   * @default - Required if adding instances instead of Lambdas to TargetGroup\n   */\n  private vpc?: ec2.IVpc;\n\n  /**\n   * The target group resource\n   */\n  private readonly resource: CfnTargetGroup;\n\n  constructor(scope: cdk.Construct, id: string, baseProps: BaseTargetGroupProps, additionalProps: any) {\n    super(scope, id);\n\n    if (baseProps.deregistrationDelay !== undefined) {\n      this.setAttribute('deregistration_delay.timeout_seconds', baseProps.deregistrationDelay.toSeconds().toString());\n    }\n\n    this.healthCheck = baseProps.healthCheck || {};\n    this.vpc = baseProps.vpc;\n    this.targetType = baseProps.targetType;\n\n    this.resource = new CfnTargetGroup(this, 'Resource', {\n      name: baseProps.targetGroupName,\n      targetGroupAttributes: cdk.Lazy.anyValue({ produce: () => renderAttributes(this.attributes) }, { omitEmptyArray: true}),\n      targetType: cdk.Lazy.stringValue({ produce: () => this.targetType }),\n      targets: cdk.Lazy.anyValue({ produce: () => this.targetsJson}, { omitEmptyArray: true }),\n      vpcId: cdk.Lazy.stringValue({ produce: () => this.vpc && this.targetType !== TargetType.LAMBDA ? this.vpc.vpcId : undefined}),\n\n      // HEALTH CHECK\n      healthCheckIntervalSeconds: cdk.Lazy.numberValue({\n        produce: () => this.healthCheck && this.healthCheck.interval && this.healthCheck.interval.toSeconds()\n      }),\n      healthCheckPath: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.path }),\n      healthCheckPort: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.port }),\n      healthCheckProtocol: cdk.Lazy.stringValue({ produce: () => this.healthCheck && this.healthCheck.protocol }),\n      healthCheckTimeoutSeconds: cdk.Lazy.numberValue({\n        produce: () => this.healthCheck && this.healthCheck.timeout && this.healthCheck.timeout.toSeconds()\n      }),\n      healthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.healthyThresholdCount }),\n      unhealthyThresholdCount: cdk.Lazy.numberValue({ produce: () => this.healthCheck && this.healthCheck.unhealthyThresholdCount }),\n      matcher: cdk.Lazy.anyValue({ produce: () => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {\n        httpCode: this.healthCheck.healthyHttpCodes\n      } : undefined }),\n\n      ...additionalProps\n    });\n\n    this.targetGroupLoadBalancerArns = this.resource.attrLoadBalancerArns;\n    this.targetGroupArn = this.resource.ref;\n    this.targetGroupFullName = this.resource.attrTargetGroupFullName;\n    this.loadBalancerArns = this.resource.attrLoadBalancerArns.toString();\n    this.targetGroupName = this.resource.attrTargetGroupName;\n    this.defaultPort = additionalProps.port;\n  }\n\n  /**\n   * List of constructs that need to be depended on to ensure the TargetGroup is associated to a load balancer\n   */\n  public get loadBalancerAttached(): cdk.IDependable {\n    return this.loadBalancerAttachedDependencies;\n  }\n\n  /**\n   * Set/replace the target group's health check\n   */\n  public configureHealthCheck(healthCheck: HealthCheck) {\n    this.healthCheck = healthCheck;\n  }\n\n  /**\n   * Set a non-standard attribute on the target group\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-target-groups.html#target-group-attributes\n   */\n  public setAttribute(key: string, value: string | undefined) {\n    this.attributes[key] = value;\n  }\n\n  /**\n   * Register the given load balancing target as part of this group\n   */\n  protected addLoadBalancerTarget(props: LoadBalancerTargetProps) {\n    if (this.targetType !== undefined && this.targetType !== props.targetType) {\n      throw new Error(`Already have a of type '${this.targetType}', adding '${props.targetType}'; make all targets the same type.`);\n    }\n    this.targetType = props.targetType;\n\n    if (this.targetType === TargetType.LAMBDA && this.targetsJson.length >= 1) {\n      throw new Error(`TargetGroup can only contain one LAMBDA target. Create a new TargetGroup.`);\n    }\n\n    if (props.targetJson) {\n      this.targetsJson.push(props.targetJson);\n    }\n  }\n\n  protected validate(): string[]  {\n    const ret = super.validate();\n\n    if (this.targetType !== undefined && this.targetType !== TargetType.LAMBDA && this.vpc === undefined) {\n      ret.push(`'vpc' is required for a non-Lambda TargetGroup`);\n    }\n\n    return ret;\n  }\n}\n\n/**\n * Properties to reference an existing target group\n */\nexport interface TargetGroupImportProps {\n  /**\n   * ARN of the target group\n   */\n  readonly targetGroupArn: string;\n\n  /**\n   * Port target group is listening on\n   */\n  readonly defaultPort: string;\n\n  /**\n   * A Token representing the list of ARNs for the load balancer routing to this target group\n   */\n  readonly loadBalancerArns?: string;\n}\n\n/**\n * A target group\n */\nexport interface ITargetGroup extends cdk.IConstruct {\n  /**\n   * ARN of the target group\n   */\n  readonly targetGroupArn: string;\n\n  /**\n   * A token representing a list of ARNs of the load balancers that route traffic to this target group\n   */\n  readonly loadBalancerArns: string;\n\n  /**\n   * Return an object to depend on the listeners added to this target group\n   */\n  readonly loadBalancerAttached: cdk.IDependable;\n}\n\n/**\n * Result of attaching a target to load balancer\n */\nexport interface LoadBalancerTargetProps {\n  /**\n   * What kind of target this is\n   */\n  readonly targetType: TargetType;\n\n  /**\n   * JSON representing the target's direct addition to the TargetGroup list\n   *\n   * May be omitted if the target is going to register itself later.\n   */\n  readonly targetJson?: any;\n}\n\n/**\n * Extract the full load balancer name (used for metrics) from the listener ARN:\n *\n * Turns\n *\n *     arn:aws:elasticloadbalancing:us-west-2:123456789012:listener/app/my-load-balancer/50dc6c495c0c9188/f2f7dc8efc522ab2\n *\n * Into\n *\n *     app/my-load-balancer/50dc6c495c0c9188\n */\nexport function loadBalancerNameFromListenerArn(listenerArn: string) {\n    const arnParts = cdk.Fn.split('/', listenerArn);\n    return `${cdk.Fn.select(1, arnParts)}/${cdk.Fn.select(2, arnParts)}/${cdk.Fn.select(3, arnParts)}`;\n}\n"]}
{
"name": "@aws-cdk/aws-elasticloadbalancingv2",
"version": "1.8.0",
"version": "1.9.0",
"description": "The CDK Construct Library for AWS::ElasticLoadBalancingV2",

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

"assemblyOriginatorKeyFile": "../../key.snk",
"versionSuffix": "-devpreview"
"versionSuffix": "-devpreview",
"iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/png/default-256-dark.png"
},

@@ -66,3 +67,3 @@ "python": {

"devDependencies": {
"@aws-cdk/assert": "^1.8.0",
"@aws-cdk/assert": "^1.9.0",
"cdk-build-tools": "file:../../../tools/cdk-build-tools",

@@ -74,22 +75,22 @@ "cdk-integ-tools": "file:../../../tools/cdk-integ-tools",

"dependencies": {
"@aws-cdk/aws-certificatemanager": "^1.8.0",
"@aws-cdk/aws-cloudwatch": "^1.8.0",
"@aws-cdk/aws-ec2": "^1.8.0",
"@aws-cdk/aws-iam": "^1.8.0",
"@aws-cdk/aws-lambda": "^1.8.0",
"@aws-cdk/aws-s3": "^1.8.0",
"@aws-cdk/core": "^1.8.0"
"@aws-cdk/aws-certificatemanager": "^1.9.0",
"@aws-cdk/aws-cloudwatch": "^1.9.0",
"@aws-cdk/aws-ec2": "^1.9.0",
"@aws-cdk/aws-iam": "^1.9.0",
"@aws-cdk/aws-lambda": "^1.9.0",
"@aws-cdk/aws-s3": "^1.9.0",
"@aws-cdk/core": "^1.9.0"
},
"homepage": "https://github.com/aws/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-certificatemanager": "^1.8.0",
"@aws-cdk/aws-cloudwatch": "^1.8.0",
"@aws-cdk/aws-ec2": "^1.8.0",
"@aws-cdk/aws-iam": "^1.8.0",
"@aws-cdk/aws-lambda": "^1.8.0",
"@aws-cdk/aws-s3": "^1.8.0",
"@aws-cdk/core": "^1.8.0"
"@aws-cdk/aws-certificatemanager": "^1.9.0",
"@aws-cdk/aws-cloudwatch": "^1.9.0",
"@aws-cdk/aws-ec2": "^1.9.0",
"@aws-cdk/aws-iam": "^1.9.0",
"@aws-cdk/aws-lambda": "^1.9.0",
"@aws-cdk/aws-s3": "^1.9.0",
"@aws-cdk/core": "^1.9.0"
},
"engines": {
"node": ">= 8.10.0"
"node": ">= 10.3.0"
},

@@ -96,0 +97,0 @@ "awslint": {

@@ -7,2 +7,3 @@ import { Test } from 'nodeunit';

'HTTPS listener requires certificate'(test: Test): void;
'HTTPS listener can add certificate after construction'(test: Test): void;
'Can configure targetType on TargetGroups'(test: Test): void;

@@ -28,3 +29,5 @@ 'Can configure name on TargetGroups'(test: Test): void;

'Imported listener with imported security group and allowAllOutbound set to false'(test: Test): void;
'Can pass multiple certificate arns to application listener constructor'(test: Test): void;
'Can add additional certificates via addCertficateArns to application listener'(test: Test): void;
};
export = _default;

@@ -7,2 +7,3 @@ import { Test } from 'nodeunit';

'same result if target is added to group after assigning to listener'(test: Test): void;
'ingress is added to child stack SG instead of parent stack'(test: Test): void;
'SG peering works on exported/imported load balancer'(test: Test): void;

@@ -9,0 +10,0 @@ 'SG peering works on exported/imported listener'(test: Test): void;

@@ -123,2 +123,31 @@ "use strict";

},
'ingress is added to child stack SG instead of parent stack'(test) {
// GIVEN
const fixture = new TestFixture(true);
const parentGroup = new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup', {
vpc: fixture.vpc,
port: 8008,
targets: [new helpers_1.FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc)],
});
// listener requires at least one rule for ParentStack to create
fixture.listener.addTargetGroups('Default', { targetGroups: [parentGroup] });
const childStack = new cdk.Stack(fixture.app, 'childStack');
// WHEN
const childGroup = new elbv2.ApplicationTargetGroup(childStack, 'TargetGroup', {
// We're assuming the 2nd VPC is peered to the 1st, or something.
vpc: fixture.vpc,
port: 8008,
targets: [new helpers_1.FakeSelfRegisteringTarget(childStack, 'Target', fixture.vpc)],
});
new elbv2.ApplicationListenerRule(childStack, 'ListenerRule', {
listener: fixture.listener,
targetGroups: [childGroup],
priority: 100,
hostHeader: 'www.foo.com'
});
// THEN
expectSameStackSGRules(fixture.stack);
expectedImportedSGRules(childStack);
test.done();
},
'SG peering works on exported/imported load balancer'(test) {

@@ -218,2 +247,2 @@ // GIVEN

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.security-groups.js","sourceRoot":"","sources":["test.security-groups.ts"],"names":[],"mappings":";AAAA,4CAAuD;AACvD,wCAAyC;AACzC,qCAAsC;AAEtC,mCAAoC;AACpC,wCAAuD;AA8MvD,MAAM,iBAAiB,GAAG,EAAE,YAAY,EAAE,CAAE,yBAAyB,EAAE,SAAS,CAAE,EAAE,CAAC;AACrF,MAAM,0BAA0B,GAAG,EAAE,iBAAiB,EAAE,mEAAmE,EAAE,CAAC;AAE9H,SAAS,sBAAsB,CAAC,KAAgB;IAC9C,aAAa,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC;AAC1C,CAAC;AAED,SAAS,uBAAuB,CAAC,KAAgB;IAC/C,aAAa,CAAC,KAAK,EAAE,0BAA0B,CAAC,CAAC;AACnD,CAAC;AAED,SAAS,aAAa,CAAC,KAAgB,EAAE,OAAY;IACnD,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,+BAA+B,EAAE;QAC7D,OAAO,EAAE,OAAO;QAChB,UAAU,EAAE,KAAK;QACjB,WAAW,EAAE,yBAAyB;QACtC,0BAA0B,EAAE,EAAE,YAAY,EAAE,CAAE,kBAAkB,EAAE,SAAS,CAAE,EAAE;QAC/E,QAAQ,EAAE,IAAI;QACd,MAAM,EAAE,IAAI;KACb,CAAC,CAAC,CAAC;IACJ,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,gCAAgC,EAAE;QAC9D,UAAU,EAAE,KAAK;QACjB,WAAW,EAAE,yBAAyB;QACtC,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,EAAE,YAAY,EAAE,CAAE,kBAAkB,EAAE,SAAS,CAAE,EAAE;QAC5D,qBAAqB,EAAE,OAAO;QAC9B,MAAM,EAAE,IAAI;KACb,CAAC,CAAC,CAAC;AACN,CAAC;AAED,MAAM,WAAW;IAOf,YAAY,cAAwB;QAClC,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;QAC9C,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE;YACxC,MAAM,EAAE,CAAC;SACV,CAAC,CAAC;QACH,IAAI,CAAC,EAAE,GAAG,IAAI,KAAK,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;QAEjF,cAAc,GAAG,cAAc,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC;QACtE,IAAI,cAAc,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;SAC5E;IACH,CAAC;CACF;AA9PD,iBAAS;IACP,gEAAgE,CAAC,IAAU;QACzE,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,MAAM,MAAM,GAAG,IAAI,mCAAyB,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QAEnF,OAAO;QACP,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,aAAa,EAAE;YACzC,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,CAAC,MAAM,CAAC;SAClB,CAAC,CAAC;QAEH,OAAO;QACP,sBAAsB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,mEAAmE,CAAC,IAAU;QAC5E,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,MAAM,OAAO,GAAG,IAAI,mCAAyB,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QAC3F,MAAM,OAAO,GAAG,IAAI,mCAAyB,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QAEpF,OAAO;QACP,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,cAAc,EAAE;YAC1C,IAAI,EAAE,EAAE;YACR,OAAO,EAAE,CAAC,OAAO,CAAC;SACnB,CAAC,CAAC;QAEH,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM,EAAE;YACvC,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,aAAa;YACzB,YAAY,EAAE,CAAC,IAAI,KAAK,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,cAAc,EAAE;oBAC7E,GAAG,EAAE,OAAO,CAAC,GAAG;oBAChB,IAAI,EAAE,IAAI;oBACV,OAAO,EAAE,CAAC,OAAO,CAAC;iBACnB,CAAC,CAAC;SACJ,CAAC,CAAC;QAEH,OAAO;QACP,sBAAsB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,0CAA0C,CAAC,IAAU;QACnD,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,MAAM,MAAM,GAAG,IAAI,mCAAyB,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QAEnF,OAAO;QACP,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa,EAAE;YAC3E,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,CAAC,MAAM,CAAC;SAClB,CAAC,CAAC;QAEH,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,SAAS,EAAE;YAC1C,YAAY,EAAE,CAAC,KAAK,CAAC;SACtB,CAAC,CAAC;QACH,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,UAAU,EAAE;YAC3C,QAAQ,EAAE,EAAE;YACZ,WAAW,EAAE,QAAQ;YACrB,YAAY,EAAE,CAAC,KAAK,CAAC;SACtB,CAAC,CAAC;QAEH,OAAO;QACP,sBAAsB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,qEAAqE,CAAC,IAAU;QAC9E,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa,EAAE;YAC3E,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,IAAI,EAAE,IAAI;SACX,CAAC,CAAC;QACH,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,SAAS,EAAE;YAC1C,YAAY,EAAE,CAAC,KAAK,CAAC;SACtB,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,MAAM,GAAG,IAAI,mCAAyB,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QACnF,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAExB,OAAO;QACP,sBAAsB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,qDAAqD,CAAC,IAAU;QAC9D,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QACpD,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACxC,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,sBAAsB,CAAC,MAAM,EAAE,aAAa,EAAE;YACpE,iEAAiE;YACjE,GAAG,EAAE,IAAI;YACT,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,CAAC,IAAI,mCAAyB,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;SACjE,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,GAAG,GAAG,KAAK,CAAC,uBAAuB,CAAC,qCAAqC,CAAC,MAAM,EAAE,IAAI,EAAE;YAC5F,eAAe,EAAE,OAAO,CAAC,EAAE,CAAC,eAAe;YAC3C,eAAe,EAAE,OAAO,CAAC,EAAE,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,eAAe;YACzE,8BAA8B,EAAE,KAAK;SACtC,CAAC,CAAC;QACH,MAAM,SAAS,GAAG,GAAG,CAAC,WAAW,CAAC,oBAAoB,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;QACtE,SAAS,CAAC,eAAe,CAAC,SAAS,EAAE,EAAE,YAAY,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAEhE,OAAO;QACP,uBAAuB,CAAC,MAAM,CAAC,CAAC;QAEhC,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,gDAAgD,CAAC,IAAU;QACzD,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QACpD,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACxC,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,sBAAsB,CAAC,MAAM,EAAE,aAAa,EAAE;YACpE,iEAAiE;YACjE,GAAG,EAAE,IAAI;YACT,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,CAAC,IAAI,mCAAyB,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;SACjE,CAAC,CAAC;QACH,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;QAErD,OAAO;QACP,MAAM,SAAS,GAAG,KAAK,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,MAAM,EAAE,oBAAoB,EAAE;YAC1G,WAAW,EAAE,IAAI;YACjB,eAAe,EAAE,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,eAAe;YAC/E,WAAW,EAAE,OAAO,CAAC,QAAQ,CAAC,WAAW;YACzC,8BAA8B,EAAE,KAAK;SACtC,CAAC,CAAC;QACH,SAAS,CAAC,eAAe,CAAC,SAAS,EAAE;YACnC,+BAA+B;YAC/B,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,aAAa;YACzB,YAAY,EAAE,CAAC,KAAK,CAAC;SACtB,CAAC,CAAC;QAEH,OAAO;QACP,uBAAuB,CAAC,MAAM,CAAC,CAAC;QAEhC,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,oDAAoD,CAAC,IAAU;QAC7D,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,IAAI,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;QAEvG,OAAO;QACP,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,2BAA2B,CAAC,mBAAmB,CAAC,CAAC;QAE9E,OAAO;QACP,eAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YAC/D,oBAAoB,EAAE;gBACpB;oBACE,MAAM,EAAE,WAAW;oBACnB,WAAW,EAAE,mBAAmB;oBAChC,QAAQ,EAAE,EAAE;oBACZ,UAAU,EAAE,KAAK;oBACjB,MAAM,EAAE,EAAE;iBACX;aACF;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,iDAAiD,CAAC,IAAU;QAC1D,QAAQ;QACR,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAE/B,OAAO;QACP,MAAM,SAAS,GAAG,KAAK,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,MAAM,EAAE,oBAAoB,EAAE;YAC1G,WAAW,EAAE,cAAc;YAC3B,eAAe,EAAE,4BAA4B;YAC7C,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC;QACH,SAAS,CAAC,WAAW,CAAC,2BAA2B,CAAC,mBAAmB,CAAC,CAAC;QAEvE,OAAO;QACP,eAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,gCAAgC,EAAE;YAC/D,MAAM,EAAE,WAAW;YACnB,WAAW,EAAE,mBAAmB;YAChC,UAAU,EAAE,KAAK;YACjB,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE,4BAA4B;SACtC,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;CACF,CAAC","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport elbv2 = require('../../lib');\nimport { FakeSelfRegisteringTarget } from '../helpers';\n\nexport = {\n  'security groups are automatically opened bidi for default rule'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const target = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n\n    // WHEN\n    fixture.listener.addTargets('TargetGroup', {\n      port: 8008,\n      targets: [target]\n    });\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'security groups are automatically opened bidi for additional rule'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const target1 = new FakeSelfRegisteringTarget(fixture.stack, 'DefaultTarget', fixture.vpc);\n    const target2 = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n\n    // WHEN\n    fixture.listener.addTargets('TargetGroup1', {\n      port: 80,\n      targets: [target1]\n    });\n\n    fixture.listener.addTargetGroups('Rule', {\n      priority: 10,\n      hostHeader: 'example.com',\n      targetGroups: [new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup2', {\n        vpc: fixture.vpc,\n        port: 8008,\n        targets: [target2]\n      })]\n    });\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'adding the same targets twice also works'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const target = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n\n    // WHEN\n    const group = new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup', {\n      vpc: fixture.vpc,\n      port: 8008,\n      targets: [target]\n    });\n\n    fixture.listener.addTargetGroups('Default', {\n      targetGroups: [group]\n    });\n    fixture.listener.addTargetGroups('WithPath', {\n      priority: 10,\n      pathPattern: '/hello',\n      targetGroups: [group]\n    });\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'same result if target is added to group after assigning to listener'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const group = new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup', {\n      vpc: fixture.vpc,\n      port: 8008\n    });\n    fixture.listener.addTargetGroups('Default', {\n      targetGroups: [group]\n    });\n\n    // WHEN\n    const target = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n    group.addTarget(target);\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'SG peering works on exported/imported load balancer'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture(false);\n    const stack2 = new cdk.Stack(fixture.app, 'stack2');\n    const vpc2 = new ec2.Vpc(stack2, 'VPC');\n    const group = new elbv2.ApplicationTargetGroup(stack2, 'TargetGroup', {\n      // We're assuming the 2nd VPC is peered to the 1st, or something.\n      vpc: vpc2,\n      port: 8008,\n      targets: [new FakeSelfRegisteringTarget(stack2, 'Target', vpc2)],\n    });\n\n    // WHEN\n    const lb2 = elbv2.ApplicationLoadBalancer.fromApplicationLoadBalancerAttributes(stack2, 'LB', {\n      loadBalancerArn: fixture.lb.loadBalancerArn,\n      securityGroupId: fixture.lb.connections.securityGroups[0].securityGroupId,\n      securityGroupAllowsAllOutbound: false,\n    });\n    const listener2 = lb2.addListener('YetAnotherListener', { port: 80 });\n    listener2.addTargetGroups('Default', { targetGroups: [group] });\n\n    // THEN\n    expectedImportedSGRules(stack2);\n\n    test.done();\n  },\n\n  'SG peering works on exported/imported listener'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const stack2 = new cdk.Stack(fixture.app, 'stack2');\n    const vpc2 = new ec2.Vpc(stack2, 'VPC');\n    const group = new elbv2.ApplicationTargetGroup(stack2, 'TargetGroup', {\n      // We're assuming the 2nd VPC is peered to the 1st, or something.\n      vpc: vpc2,\n      port: 8008,\n      targets: [new FakeSelfRegisteringTarget(stack2, 'Target', vpc2)],\n    });\n    fixture.listener.addTargets('default', { port: 80 });\n\n    // WHEN\n    const listener2 = elbv2.ApplicationListener.fromApplicationListenerAttributes(stack2, 'YetAnotherListener', {\n      defaultPort: 8008,\n      securityGroupId: fixture.listener.connections.securityGroups[0].securityGroupId,\n      listenerArn: fixture.listener.listenerArn,\n      securityGroupAllowsAllOutbound: false,\n    });\n    listener2.addTargetGroups('Default', {\n      // Must be a non-default target\n      priority: 10,\n      hostHeader: 'example.com',\n      targetGroups: [group]\n    });\n\n    // THEN\n    expectedImportedSGRules(stack2);\n\n    test.done();\n  },\n\n  'default port peering works on constructed listener'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    fixture.listener.addTargets('Default', { port: 8080, targets: [new elbv2.InstanceTarget('i-12345')] });\n\n    // WHEN\n    fixture.listener.connections.allowDefaultPortFromAnyIpv4('Open to the world');\n\n    // THEN\n    expect(fixture.stack).to(haveResource('AWS::EC2::SecurityGroup', {\n      SecurityGroupIngress: [\n        {\n          CidrIp: \"0.0.0.0/0\",\n          Description: \"Open to the world\",\n          FromPort: 80,\n          IpProtocol: \"tcp\",\n          ToPort: 80\n        }\n      ],\n    }));\n\n    test.done();\n  },\n\n  'default port peering works on imported listener'(test: Test) {\n    // GIVEN\n    const stack2 = new cdk.Stack();\n\n    // WHEN\n    const listener2 = elbv2.ApplicationListener.fromApplicationListenerAttributes(stack2, 'YetAnotherListener', {\n      listenerArn: 'listener-arn',\n      securityGroupId: 'imported-security-group-id',\n      defaultPort: 8080\n    });\n    listener2.connections.allowDefaultPortFromAnyIpv4('Open to the world');\n\n    // THEN\n    expect(stack2).to(haveResource('AWS::EC2::SecurityGroupIngress', {\n      CidrIp: \"0.0.0.0/0\",\n      Description: \"Open to the world\",\n      IpProtocol: \"tcp\",\n      FromPort: 8080,\n      ToPort: 8080,\n      GroupId: 'imported-security-group-id'\n    }));\n\n    test.done();\n  },\n};\n\nconst LB_SECURITY_GROUP = { \"Fn::GetAtt\": [ \"LBSecurityGroup8A41EA2B\", \"GroupId\" ] };\nconst IMPORTED_LB_SECURITY_GROUP = { \"Fn::ImportValue\": \"Stack:ExportsOutputFnGetAttLBSecurityGroup8A41EA2BGroupId851EE1F6\" };\n\nfunction expectSameStackSGRules(stack: cdk.Stack) {\n  expectSGRules(stack, LB_SECURITY_GROUP);\n}\n\nfunction expectedImportedSGRules(stack: cdk.Stack) {\n  expectSGRules(stack, IMPORTED_LB_SECURITY_GROUP);\n}\n\nfunction expectSGRules(stack: cdk.Stack, lbGroup: any) {\n  expect(stack).to(haveResource('AWS::EC2::SecurityGroupEgress', {\n    GroupId: lbGroup,\n    IpProtocol: \"tcp\",\n    Description: \"Load balancer to target\",\n    DestinationSecurityGroupId: { \"Fn::GetAtt\": [ \"TargetSGDB98152D\", \"GroupId\" ] },\n    FromPort: 8008,\n    ToPort: 8008\n  }));\n  expect(stack).to(haveResource('AWS::EC2::SecurityGroupIngress', {\n    IpProtocol: \"tcp\",\n    Description: \"Load balancer to target\",\n    FromPort: 8008,\n    GroupId: { \"Fn::GetAtt\": [ \"TargetSGDB98152D\", \"GroupId\" ] },\n    SourceSecurityGroupId: lbGroup,\n    ToPort: 8008\n  }));\n}\n\nclass TestFixture {\n  public readonly app: cdk.App;\n  public readonly stack: cdk.Stack;\n  public readonly vpc: ec2.Vpc;\n  public readonly lb: elbv2.ApplicationLoadBalancer;\n  public readonly listener: elbv2.ApplicationListener;\n\n  constructor(createListener?: boolean) {\n    this.app = new cdk.App();\n    this.stack = new cdk.Stack(this.app, 'Stack');\n    this.vpc = new ec2.Vpc(this.stack, 'VPC', {\n      maxAzs: 2\n    });\n    this.lb = new elbv2.ApplicationLoadBalancer(this.stack, 'LB', { vpc: this.vpc });\n\n    createListener = createListener === undefined ? true : createListener;\n    if (createListener) {\n      this.listener = this.lb.addListener('Listener', { port: 80, open: false });\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.security-groups.js","sourceRoot":"","sources":["test.security-groups.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport elbv2 = require('../../lib');\nimport { FakeSelfRegisteringTarget } from '../helpers';\n\nexport = {\n  'security groups are automatically opened bidi for default rule'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const target = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n\n    // WHEN\n    fixture.listener.addTargets('TargetGroup', {\n      port: 8008,\n      targets: [target]\n    });\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'security groups are automatically opened bidi for additional rule'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const target1 = new FakeSelfRegisteringTarget(fixture.stack, 'DefaultTarget', fixture.vpc);\n    const target2 = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n\n    // WHEN\n    fixture.listener.addTargets('TargetGroup1', {\n      port: 80,\n      targets: [target1]\n    });\n\n    fixture.listener.addTargetGroups('Rule', {\n      priority: 10,\n      hostHeader: 'example.com',\n      targetGroups: [new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup2', {\n        vpc: fixture.vpc,\n        port: 8008,\n        targets: [target2]\n      })]\n    });\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'adding the same targets twice also works'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const target = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n\n    // WHEN\n    const group = new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup', {\n      vpc: fixture.vpc,\n      port: 8008,\n      targets: [target]\n    });\n\n    fixture.listener.addTargetGroups('Default', {\n      targetGroups: [group]\n    });\n    fixture.listener.addTargetGroups('WithPath', {\n      priority: 10,\n      pathPattern: '/hello',\n      targetGroups: [group]\n    });\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'same result if target is added to group after assigning to listener'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const group = new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup', {\n      vpc: fixture.vpc,\n      port: 8008\n    });\n    fixture.listener.addTargetGroups('Default', {\n      targetGroups: [group]\n    });\n\n    // WHEN\n    const target = new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc);\n    group.addTarget(target);\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n\n    test.done();\n  },\n\n  'ingress is added to child stack SG instead of parent stack'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture(true);\n\n    const parentGroup = new elbv2.ApplicationTargetGroup(fixture.stack, 'TargetGroup', {\n      vpc: fixture.vpc,\n      port: 8008,\n      targets: [new FakeSelfRegisteringTarget(fixture.stack, 'Target', fixture.vpc)],\n    });\n\n    // listener requires at least one rule for ParentStack to create\n    fixture.listener.addTargetGroups('Default', { targetGroups: [parentGroup] });\n\n    const childStack = new cdk.Stack(fixture.app, 'childStack');\n\n    // WHEN\n    const childGroup = new elbv2.ApplicationTargetGroup(childStack, 'TargetGroup', {\n      // We're assuming the 2nd VPC is peered to the 1st, or something.\n      vpc: fixture.vpc,\n      port: 8008,\n      targets: [new FakeSelfRegisteringTarget(childStack, 'Target', fixture.vpc)],\n    });\n\n    new elbv2.ApplicationListenerRule(childStack, 'ListenerRule', {\n      listener: fixture.listener,\n      targetGroups: [childGroup],\n      priority: 100,\n      hostHeader: 'www.foo.com'\n    });\n\n    // THEN\n    expectSameStackSGRules(fixture.stack);\n    expectedImportedSGRules(childStack);\n\n    test.done();\n  },\n\n  'SG peering works on exported/imported load balancer'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture(false);\n    const stack2 = new cdk.Stack(fixture.app, 'stack2');\n    const vpc2 = new ec2.Vpc(stack2, 'VPC');\n    const group = new elbv2.ApplicationTargetGroup(stack2, 'TargetGroup', {\n      // We're assuming the 2nd VPC is peered to the 1st, or something.\n      vpc: vpc2,\n      port: 8008,\n      targets: [new FakeSelfRegisteringTarget(stack2, 'Target', vpc2)],\n    });\n\n    // WHEN\n    const lb2 = elbv2.ApplicationLoadBalancer.fromApplicationLoadBalancerAttributes(stack2, 'LB', {\n      loadBalancerArn: fixture.lb.loadBalancerArn,\n      securityGroupId: fixture.lb.connections.securityGroups[0].securityGroupId,\n      securityGroupAllowsAllOutbound: false,\n    });\n    const listener2 = lb2.addListener('YetAnotherListener', { port: 80 });\n    listener2.addTargetGroups('Default', { targetGroups: [group] });\n\n    // THEN\n    expectedImportedSGRules(stack2);\n\n    test.done();\n  },\n\n  'SG peering works on exported/imported listener'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    const stack2 = new cdk.Stack(fixture.app, 'stack2');\n    const vpc2 = new ec2.Vpc(stack2, 'VPC');\n    const group = new elbv2.ApplicationTargetGroup(stack2, 'TargetGroup', {\n      // We're assuming the 2nd VPC is peered to the 1st, or something.\n      vpc: vpc2,\n      port: 8008,\n      targets: [new FakeSelfRegisteringTarget(stack2, 'Target', vpc2)],\n    });\n    fixture.listener.addTargets('default', { port: 80 });\n\n    // WHEN\n    const listener2 = elbv2.ApplicationListener.fromApplicationListenerAttributes(stack2, 'YetAnotherListener', {\n      defaultPort: 8008,\n      securityGroupId: fixture.listener.connections.securityGroups[0].securityGroupId,\n      listenerArn: fixture.listener.listenerArn,\n      securityGroupAllowsAllOutbound: false,\n    });\n    listener2.addTargetGroups('Default', {\n      // Must be a non-default target\n      priority: 10,\n      hostHeader: 'example.com',\n      targetGroups: [group]\n    });\n\n    // THEN\n    expectedImportedSGRules(stack2);\n\n    test.done();\n  },\n\n  'default port peering works on constructed listener'(test: Test) {\n    // GIVEN\n    const fixture = new TestFixture();\n    fixture.listener.addTargets('Default', { port: 8080, targets: [new elbv2.InstanceTarget('i-12345')] });\n\n    // WHEN\n    fixture.listener.connections.allowDefaultPortFromAnyIpv4('Open to the world');\n\n    // THEN\n    expect(fixture.stack).to(haveResource('AWS::EC2::SecurityGroup', {\n      SecurityGroupIngress: [\n        {\n          CidrIp: \"0.0.0.0/0\",\n          Description: \"Open to the world\",\n          FromPort: 80,\n          IpProtocol: \"tcp\",\n          ToPort: 80\n        }\n      ],\n    }));\n\n    test.done();\n  },\n\n  'default port peering works on imported listener'(test: Test) {\n    // GIVEN\n    const stack2 = new cdk.Stack();\n\n    // WHEN\n    const listener2 = elbv2.ApplicationListener.fromApplicationListenerAttributes(stack2, 'YetAnotherListener', {\n      listenerArn: 'listener-arn',\n      securityGroupId: 'imported-security-group-id',\n      defaultPort: 8080\n    });\n    listener2.connections.allowDefaultPortFromAnyIpv4('Open to the world');\n\n    // THEN\n    expect(stack2).to(haveResource('AWS::EC2::SecurityGroupIngress', {\n      CidrIp: \"0.0.0.0/0\",\n      Description: \"Open to the world\",\n      IpProtocol: \"tcp\",\n      FromPort: 8080,\n      ToPort: 8080,\n      GroupId: 'imported-security-group-id'\n    }));\n\n    test.done();\n  },\n};\n\nconst LB_SECURITY_GROUP = { \"Fn::GetAtt\": [ \"LBSecurityGroup8A41EA2B\", \"GroupId\" ] };\nconst IMPORTED_LB_SECURITY_GROUP = { \"Fn::ImportValue\": \"Stack:ExportsOutputFnGetAttLBSecurityGroup8A41EA2BGroupId851EE1F6\" };\n\nfunction expectSameStackSGRules(stack: cdk.Stack) {\n  expectSGRules(stack, LB_SECURITY_GROUP);\n}\n\nfunction expectedImportedSGRules(stack: cdk.Stack) {\n  expectSGRules(stack, IMPORTED_LB_SECURITY_GROUP);\n}\n\nfunction expectSGRules(stack: cdk.Stack, lbGroup: any) {\n  expect(stack).to(haveResource('AWS::EC2::SecurityGroupEgress', {\n    GroupId: lbGroup,\n    IpProtocol: \"tcp\",\n    Description: \"Load balancer to target\",\n    DestinationSecurityGroupId: { \"Fn::GetAtt\": [ \"TargetSGDB98152D\", \"GroupId\" ] },\n    FromPort: 8008,\n    ToPort: 8008\n  }));\n  expect(stack).to(haveResource('AWS::EC2::SecurityGroupIngress', {\n    IpProtocol: \"tcp\",\n    Description: \"Load balancer to target\",\n    FromPort: 8008,\n    GroupId: { \"Fn::GetAtt\": [ \"TargetSGDB98152D\", \"GroupId\" ] },\n    SourceSecurityGroupId: lbGroup,\n    ToPort: 8008\n  }));\n}\n\nclass TestFixture {\n  public readonly app: cdk.App;\n  public readonly stack: cdk.Stack;\n  public readonly vpc: ec2.Vpc;\n  public readonly lb: elbv2.ApplicationLoadBalancer;\n  public readonly listener: elbv2.ApplicationListener;\n\n  constructor(createListener?: boolean) {\n    this.app = new cdk.App();\n    this.stack = new cdk.Stack(this.app, 'Stack');\n    this.vpc = new ec2.Vpc(this.stack, 'VPC', {\n      maxAzs: 2\n    });\n    this.lb = new elbv2.ApplicationLoadBalancer(this.stack, 'LB', { vpc: this.vpc });\n\n    createListener = createListener === undefined ? true : createListener;\n    if (createListener) {\n      this.listener = this.lb.addListener('Listener', { port: 80, open: false });\n    }\n  }\n}\n"]}

@@ -25,3 +25,3 @@ {

"stripInternal": true,
"target": "ES2018",
"target": "ES2017",
"composite": true

@@ -28,0 +28,0 @@ },

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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc