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

@aws-cdk/aws-elasticloadbalancing

Package Overview
Dependencies
Maintainers
4
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

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

Comparing version 0.10.0 to 0.11.0

88

lib/elasticloadbalancing.generated.d.ts

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

*/
listeners: Array<LoadBalancerResource.ListenersProperty | cdk.CloudFormationToken> | cdk.CloudFormationToken;
listeners: Array<LoadBalancerResource.ListenersProperty | cdk.Token> | cdk.Token;
/**

@@ -17,3 +17,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.AccessLoggingPolicy``

*/
accessLoggingPolicy?: LoadBalancerResource.AccessLoggingPolicyProperty | cdk.CloudFormationToken;
accessLoggingPolicy?: LoadBalancerResource.AccessLoggingPolicyProperty | cdk.Token;
/**

@@ -23,3 +23,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.AppCookieStickinessPolicy``

*/
appCookieStickinessPolicy?: Array<LoadBalancerResource.AppCookieStickinessPolicyProperty | cdk.CloudFormationToken> | cdk.CloudFormationToken;
appCookieStickinessPolicy?: Array<LoadBalancerResource.AppCookieStickinessPolicyProperty | cdk.Token> | cdk.Token;
/**

@@ -29,3 +29,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.AvailabilityZones``

*/
availabilityZones?: Array<string | cdk.CloudFormationToken> | cdk.CloudFormationToken;
availabilityZones?: Array<string | cdk.Token> | cdk.Token;
/**

@@ -35,3 +35,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.ConnectionDrainingPolicy``

*/
connectionDrainingPolicy?: LoadBalancerResource.ConnectionDrainingPolicyProperty | cdk.CloudFormationToken;
connectionDrainingPolicy?: LoadBalancerResource.ConnectionDrainingPolicyProperty | cdk.Token;
/**

@@ -41,3 +41,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.ConnectionSettings``

*/
connectionSettings?: LoadBalancerResource.ConnectionSettingsProperty | cdk.CloudFormationToken;
connectionSettings?: LoadBalancerResource.ConnectionSettingsProperty | cdk.Token;
/**

@@ -47,3 +47,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.CrossZone``

*/
crossZone?: boolean | cdk.CloudFormationToken;
crossZone?: boolean | cdk.Token;
/**

@@ -53,3 +53,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.HealthCheck``

*/
healthCheck?: LoadBalancerResource.HealthCheckProperty | cdk.CloudFormationToken;
healthCheck?: LoadBalancerResource.HealthCheckProperty | cdk.Token;
/**

@@ -59,3 +59,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.Instances``

*/
instances?: Array<string | cdk.CloudFormationToken> | cdk.CloudFormationToken;
instances?: Array<string | cdk.Token> | cdk.Token;
/**

@@ -65,3 +65,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.LBCookieStickinessPolicy``

*/
lbCookieStickinessPolicy?: Array<LoadBalancerResource.LBCookieStickinessPolicyProperty | cdk.CloudFormationToken> | cdk.CloudFormationToken;
lbCookieStickinessPolicy?: Array<LoadBalancerResource.LBCookieStickinessPolicyProperty | cdk.Token> | cdk.Token;
/**

@@ -71,3 +71,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.LoadBalancerName``

*/
loadBalancerName?: string | cdk.CloudFormationToken;
loadBalancerName?: string | cdk.Token;
/**

@@ -77,3 +77,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.Policies``

*/
policies?: Array<LoadBalancerResource.PoliciesProperty | cdk.CloudFormationToken> | cdk.CloudFormationToken;
policies?: Array<LoadBalancerResource.PoliciesProperty | cdk.Token> | cdk.Token;
/**

@@ -83,3 +83,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.Scheme``

*/
scheme?: string | cdk.CloudFormationToken;
scheme?: string | cdk.Token;
/**

@@ -89,3 +89,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.SecurityGroups``

*/
securityGroups?: Array<string | cdk.CloudFormationToken> | cdk.CloudFormationToken;
securityGroups?: Array<string | cdk.Token> | cdk.Token;
/**

@@ -95,3 +95,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.Subnets``

*/
subnets?: Array<string | cdk.CloudFormationToken> | cdk.CloudFormationToken;
subnets?: Array<string | cdk.Token> | cdk.Token;
/**

@@ -101,3 +101,3 @@ * ``AWS::ElasticLoadBalancing::LoadBalancer.Tags``

*/
tags?: Array<cdk.Tag | cdk.CloudFormationToken> | cdk.CloudFormationToken;
tags?: Array<cdk.Tag | cdk.Token> | cdk.Token;
}

@@ -111,3 +111,3 @@ /**

*/
static readonly resourceTypeName: string;
static readonly resourceTypeName = "AWS::ElasticLoadBalancing::LoadBalancer";
/**

@@ -156,3 +156,3 @@ * @cloudformation_attribute CanonicalHostedZoneName

*/
emitInterval?: number | cdk.CloudFormationToken;
emitInterval?: number | cdk.Token;
/**

@@ -162,3 +162,3 @@ * ``LoadBalancerResource.AccessLoggingPolicyProperty.Enabled``

*/
enabled: boolean | cdk.CloudFormationToken;
enabled: boolean | cdk.Token;
/**

@@ -168,3 +168,3 @@ * ``LoadBalancerResource.AccessLoggingPolicyProperty.S3BucketName``

*/
s3BucketName: string | cdk.CloudFormationToken;
s3BucketName: string | cdk.Token;
/**

@@ -174,3 +174,3 @@ * ``LoadBalancerResource.AccessLoggingPolicyProperty.S3BucketPrefix``

*/
s3BucketPrefix?: string | cdk.CloudFormationToken;
s3BucketPrefix?: string | cdk.Token;
}

@@ -187,3 +187,3 @@ }

*/
cookieName: string | cdk.CloudFormationToken;
cookieName: string | cdk.Token;
/**

@@ -193,3 +193,3 @@ * ``LoadBalancerResource.AppCookieStickinessPolicyProperty.PolicyName``

*/
policyName: string | cdk.CloudFormationToken;
policyName: string | cdk.Token;
}

@@ -206,3 +206,3 @@ }

*/
enabled: boolean | cdk.CloudFormationToken;
enabled: boolean | cdk.Token;
/**

@@ -212,3 +212,3 @@ * ``LoadBalancerResource.ConnectionDrainingPolicyProperty.Timeout``

*/
timeout?: number | cdk.CloudFormationToken;
timeout?: number | cdk.Token;
}

@@ -225,3 +225,3 @@ }

*/
idleTimeout: number | cdk.CloudFormationToken;
idleTimeout: number | cdk.Token;
}

@@ -238,3 +238,3 @@ }

*/
healthyThreshold: string | cdk.CloudFormationToken;
healthyThreshold: string | cdk.Token;
/**

@@ -244,3 +244,3 @@ * ``LoadBalancerResource.HealthCheckProperty.Interval``

*/
interval: string | cdk.CloudFormationToken;
interval: string | cdk.Token;
/**

@@ -250,3 +250,3 @@ * ``LoadBalancerResource.HealthCheckProperty.Target``

*/
target: string | cdk.CloudFormationToken;
target: string | cdk.Token;
/**

@@ -256,3 +256,3 @@ * ``LoadBalancerResource.HealthCheckProperty.Timeout``

*/
timeout: string | cdk.CloudFormationToken;
timeout: string | cdk.Token;
/**

@@ -262,3 +262,3 @@ * ``LoadBalancerResource.HealthCheckProperty.UnhealthyThreshold``

*/
unhealthyThreshold: string | cdk.CloudFormationToken;
unhealthyThreshold: string | cdk.Token;
}

@@ -275,3 +275,3 @@ }

*/
cookieExpirationPeriod?: string | cdk.CloudFormationToken;
cookieExpirationPeriod?: string | cdk.Token;
/**

@@ -281,3 +281,3 @@ * ``LoadBalancerResource.LBCookieStickinessPolicyProperty.PolicyName``

*/
policyName?: string | cdk.CloudFormationToken;
policyName?: string | cdk.Token;
}

@@ -294,3 +294,3 @@ }

*/
instancePort: string | cdk.CloudFormationToken;
instancePort: string | cdk.Token;
/**

@@ -300,3 +300,3 @@ * ``LoadBalancerResource.ListenersProperty.InstanceProtocol``

*/
instanceProtocol?: string | cdk.CloudFormationToken;
instanceProtocol?: string | cdk.Token;
/**

@@ -306,3 +306,3 @@ * ``LoadBalancerResource.ListenersProperty.LoadBalancerPort``

*/
loadBalancerPort: string | cdk.CloudFormationToken;
loadBalancerPort: string | cdk.Token;
/**

@@ -312,3 +312,3 @@ * ``LoadBalancerResource.ListenersProperty.PolicyNames``

*/
policyNames?: Array<string | cdk.CloudFormationToken> | cdk.CloudFormationToken;
policyNames?: Array<string | cdk.Token> | cdk.Token;
/**

@@ -318,3 +318,3 @@ * ``LoadBalancerResource.ListenersProperty.Protocol``

*/
protocol: string | cdk.CloudFormationToken;
protocol: string | cdk.Token;
/**

@@ -324,3 +324,3 @@ * ``LoadBalancerResource.ListenersProperty.SSLCertificateId``

*/
sslCertificateId?: string | cdk.CloudFormationToken;
sslCertificateId?: string | cdk.Token;
}

@@ -337,3 +337,3 @@ }

*/
attributes: Array<object | cdk.CloudFormationToken> | cdk.CloudFormationToken;
attributes: Array<object | cdk.Token> | cdk.Token;
/**

@@ -343,3 +343,3 @@ * ``LoadBalancerResource.PoliciesProperty.InstancePorts``

*/
instancePorts?: Array<string | cdk.CloudFormationToken> | cdk.CloudFormationToken;
instancePorts?: Array<string | cdk.Token> | cdk.Token;
/**

@@ -349,3 +349,3 @@ * ``LoadBalancerResource.PoliciesProperty.LoadBalancerPorts``

*/
loadBalancerPorts?: Array<string | cdk.CloudFormationToken> | cdk.CloudFormationToken;
loadBalancerPorts?: Array<string | cdk.Token> | cdk.Token;
/**

@@ -355,3 +355,3 @@ * ``LoadBalancerResource.PoliciesProperty.PolicyName``

*/
policyName: string | cdk.CloudFormationToken;
policyName: string | cdk.Token;
/**

@@ -361,5 +361,5 @@ * ``LoadBalancerResource.PoliciesProperty.PolicyType``

*/
policyType: string | cdk.CloudFormationToken;
policyType: string | cdk.Token;
}
}
}

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

import codedeploy = require('@aws-cdk/aws-codedeploy-api');
import { Connections, IConnectable, IPortRange, SecurityGroupRef, VpcNetworkRef } from '@aws-cdk/aws-ec2';

@@ -164,3 +165,3 @@ import cdk = require('@aws-cdk/cdk');

*/
export declare class LoadBalancer extends cdk.Construct implements IConnectable {
export declare class LoadBalancer extends cdk.Construct implements IConnectable, codedeploy.ILoadBalancer {
/**

@@ -192,2 +193,3 @@ * Control all connections from and to this load balancer

readonly loadBalancerSourceSecurityGroupOwnerAlias: string;
asCodeDeployLoadBalancer(): codedeploy.ILoadBalancerProps;
/**

@@ -194,0 +196,0 @@ * Allow connections to all existing targets on new instance port

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const codedeploy = require("@aws-cdk/aws-codedeploy-api");
const aws_ec2_1 = require("@aws-cdk/aws-ec2");

@@ -88,2 +89,8 @@ const cdk = require("@aws-cdk/cdk");

}
asCodeDeployLoadBalancer() {
return {
generation: codedeploy.LoadBalancerGeneration.First,
name: this.loadBalancerName,
};
}
/**

@@ -172,2 +179,2 @@ * Allow connections to all existing targets on new instance port

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"load-balancer.js","sourceRoot":"","sources":["load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnyIPv4, Connections, IConnectable, IPortRange, SecurityGroup, SecurityGroupRef,\n  TcpPort, VpcNetworkRef, VpcSubnetRef  } from '@aws-cdk/aws-ec2';\nimport cdk = require('@aws-cdk/cdk');\nimport { cloudformation } from './elasticloadbalancing.generated';\n\n/**\n * Construction properties for a LoadBalancer\n */\nexport interface LoadBalancerProps {\n  /**\n   * VPC network of the fleet instances\n   */\n  vpc: VpcNetworkRef;\n\n  /**\n   * Whether this is an internet-facing Load Balancer\n   *\n   * This controls whether the LB has a public IP address assigned. It does\n   * not open up the Load Balancer's security groups to public internet access.\n   *\n   * @default false\n   */\n  internetFacing?: boolean;\n\n  /**\n   * What listeners to set up for the load balancer.\n   *\n   * Can also be added by .addListener()\n   */\n  listeners?: LoadBalancerListener[];\n\n  /**\n   * What targets to load balance to.\n   *\n   * Can also be added by .addTarget()\n   */\n  targets?: ILoadBalancerTarget[];\n\n  /**\n   * Health check settings for the load balancing targets.\n   *\n   * Not required but recommended.\n   */\n  healthCheck?: HealthCheck;\n}\n\n/**\n * Describe the health check to a load balancer\n */\nexport interface HealthCheck {\n  /**\n   * What port number to health check on\n   */\n  port: number;\n\n  /**\n   * What protocol to use for health checking\n   *\n   * The protocol is automatically determined from the port if it's not supplied.\n   *\n   * @default Automatic\n   */\n  protocol?: LoadBalancingProtocol;\n\n  /**\n   * What path to use for HTTP or HTTPS health check (must return 200)\n   *\n   * For SSL and TCP health checks, accepting connections is enough to be considered\n   * healthy.\n   *\n   * @default \"/\"\n   */\n  path?: string;\n\n  /**\n   * After how many successful checks is an instance considered healthy\n   *\n   * @default 2\n   */\n  healthyThreshold?: number;\n\n  /**\n   * After how many unsuccessful checks is an instance considered unhealthy\n   *\n   * @default 5\n   */\n  unhealthyThreshold?: number;\n\n  /**\n   * Number of seconds between health checks\n   *\n   * @default 30\n   */\n  interval?: number;\n\n  /**\n   * Health check timeout\n   *\n   * @default 5\n   */\n  timeout?: number;\n}\n\n/**\n * Interface that is going to be implemented by constructs that you can load balance to\n */\nexport interface ILoadBalancerTarget extends IConnectable {\n  /**\n   * Attach load-balanced target to a classic ELB\n   */\n  attachToClassicLB(loadBalancer: LoadBalancer): void;\n}\n\n/**\n * Add a backend to the load balancer\n */\nexport interface LoadBalancerListener {\n  /**\n   * External listening port\n   */\n  externalPort: number;\n\n  /**\n   * What public protocol to use for load balancing\n   *\n   * Either 'tcp', 'ssl', 'http' or 'https'.\n   *\n   * May be omitted if the external port is either 80 or 443.\n   */\n  externalProtocol?: LoadBalancingProtocol;\n\n  /**\n   * Instance listening port\n   *\n   * Same as the externalPort if not specified.\n   *\n   * @default externalPort\n   */\n  internalPort?: number;\n\n  /**\n   * What public protocol to use for load balancing\n   *\n   * Either 'tcp', 'ssl', 'http' or 'https'.\n   *\n   * May be omitted if the internal port is either 80 or 443.\n   *\n   * The instance protocol is 'tcp' if the front-end protocol\n   * is 'tcp' or 'ssl', the instance protocol is 'http' if the\n   * front-end protocol is 'https'.\n   */\n  internalProtocol?: LoadBalancingProtocol;\n\n  /**\n   * SSL policy names\n   */\n  policyNames?: string[];\n\n  /**\n   * ID of SSL certificate\n   */\n  sslCertificateId?: string;\n\n  /**\n   * Allow connections to the load balancer from the given set of connection peers\n   *\n   * By default, connections will be allowed from anywhere. Set this to an empty list\n   * to deny connections, or supply a custom list of peers to allow connections from\n   * (IP ranges or security groups).\n   *\n   * @default Anywhere\n   */\n  allowConnectionsFrom?: IConnectable[];\n}\n\nexport enum LoadBalancingProtocol {\n  Tcp = 'tcp',\n  Ssl = 'ssl',\n  Http = 'http',\n  Https = 'https'\n}\n\n/**\n * A load balancer with a single listener\n *\n * Routes to a fleet of of instances in a VPC.\n */\nexport class LoadBalancer extends cdk.Construct implements IConnectable {\n  /**\n   * Control all connections from and to this load balancer\n   */\n  public readonly connections: Connections;\n\n  /**\n   * An object controlling specifically the connections for each listener added to this load balancer\n   */\n  public readonly listenerPorts: ListenerPort[] = [];\n\n  private readonly elb: cloudformation.LoadBalancerResource;\n  private readonly securityGroup: SecurityGroup;\n  private readonly listeners: cloudformation.LoadBalancerResource.ListenersProperty[] = [];\n\n  private readonly instancePorts: number[] = [];\n  private readonly targets: ILoadBalancerTarget[] = [];\n\n  constructor(parent: cdk.Construct, name: string, props: LoadBalancerProps) {\n    super(parent, name);\n\n    this.securityGroup = new SecurityGroup(this, 'SecurityGroup', { vpc: props.vpc });\n    this.connections = new Connections({ securityGroup: this.securityGroup });\n\n    // Depending on whether the ELB has public or internal IPs, pick the right backend subnets\n    const subnets: VpcSubnetRef[] = props.internetFacing ? props.vpc.publicSubnets : props.vpc.privateSubnets;\n\n    this.elb = new cloudformation.LoadBalancerResource(this, 'Resource', {\n      securityGroups: [ this.securityGroup.securityGroupId ],\n      subnets: subnets.map(s => s.subnetId),\n      listeners: new cdk.Token(() => this.listeners),\n      scheme: props.internetFacing ? 'internet-facing' : 'internal',\n      healthCheck: props.healthCheck && healthCheckToJSON(props.healthCheck),\n    });\n\n    ifUndefined(props.listeners, []).forEach(b => this.addListener(b));\n    ifUndefined(props.targets, []).forEach(t => this.addTarget(t));\n  }\n\n  /**\n   * Add a backend to the load balancer\n   *\n   * @returns A ListenerPort object that controls connections to the listener port\n   */\n  public addListener(listener: LoadBalancerListener): ListenerPort {\n    const protocol = ifUndefinedLazy(listener.externalProtocol, () => wellKnownProtocol(listener.externalPort));\n    const instancePort = listener.internalPort || listener.externalPort;\n    const instanceProtocol = ifUndefined(listener.internalProtocol,\n                 ifUndefined(tryWellKnownProtocol(instancePort),\n                 isHttpProtocol(protocol) ? LoadBalancingProtocol.Http : LoadBalancingProtocol.Tcp));\n\n    this.listeners.push({\n      loadBalancerPort: listener.externalPort.toString(),\n      protocol,\n      instancePort: instancePort.toString(),\n      instanceProtocol,\n      sslCertificateId: listener.sslCertificateId,\n      policyNames: listener.policyNames\n    });\n\n    const port = new ListenerPort(this.securityGroup, new TcpPort(listener.externalPort));\n\n    // Allow connections on the public port for all supplied peers (default: everyone)\n    ifUndefined(listener.allowConnectionsFrom, [new AnyIPv4()]).forEach(peer => {\n      port.connections.allowDefaultPortFrom(peer, `Default rule allow on ${listener.externalPort}`);\n    });\n\n    this.newInstancePort(instancePort);\n\n    // Keep track using array so user can get to them even if they were all supplied in the constructor\n    this.listenerPorts.push(port);\n\n    return port;\n  }\n\n  public addTarget(target: ILoadBalancerTarget) {\n    target.attachToClassicLB(this);\n\n    this.newTarget(target);\n  }\n\n  public get loadBalancerName() {\n    return this.elb.ref;\n  }\n\n  public get loadBalancerCanonicalHostedZoneName() {\n    return this.elb.loadBalancerCanonicalHostedZoneName;\n  }\n\n  public get loadBalancerDnsName() {\n    return this.elb.loadBalancerDnsName;\n  }\n\n  public get loadBalancerSourceSecurityGroupGroupName() {\n    return this.elb.loadBalancerSourceSecurityGroupGroupName;\n  }\n\n  public get loadBalancerSourceSecurityGroupOwnerAlias() {\n    return this.elb.loadBalancerSourceSecurityGroupOwnerAlias;\n  }\n\n  /**\n   * Allow connections to all existing targets on new instance port\n   */\n  private newInstancePort(instancePort: number) {\n    this.targets.forEach(t => this.allowTargetConnection(instancePort, t));\n\n    // Keep track of port for future targets\n    this.instancePorts.push(instancePort);\n  }\n\n  /**\n   * Allow connections to target on all existing instance ports\n   */\n  private newTarget(target: ILoadBalancerTarget) {\n    this.instancePorts.forEach(p => this.allowTargetConnection(p, target));\n\n    // Keep track of target for future listeners.\n    this.targets.push(target);\n  }\n\n  /**\n   * Allow connections for a single (port, target) pair\n   */\n  private allowTargetConnection(instancePort: number, target: ILoadBalancerTarget) {\n    this.connections.allowTo(\n      target,\n      new TcpPort(instancePort),\n      `Port ${instancePort} LB to fleet`);\n  }\n}\n\n/**\n * Reference to a listener's port just created.\n *\n * This implements IConnectable with a default port (the port that an ELB\n * listener was just created on) for a given security group so that it can be\n * conveniently used just like any Connectable. E.g:\n *\n *    const listener = elb.addListener(...);\n *\n *    listener.connections.allowDefaultPortFromAnyIPv4();\n *    // or\n *    instance.connections.allowToDefaultPort(listener);\n */\nexport class ListenerPort implements IConnectable {\n  public readonly connections: Connections;\n\n  constructor(securityGroup: SecurityGroupRef, defaultPortRange: IPortRange) {\n    this.connections = new Connections({ securityGroup, defaultPortRange });\n  }\n}\n\nfunction wellKnownProtocol(port: number): LoadBalancingProtocol {\n  const proto = tryWellKnownProtocol(port);\n  if (!proto) {\n    throw new Error(`Please supply protocol to go with port ${port}`);\n  }\n  return proto;\n}\n\nfunction tryWellKnownProtocol(port: number): LoadBalancingProtocol | undefined {\n  if (port === 80) { return LoadBalancingProtocol.Http; }\n  if (port === 443) { return LoadBalancingProtocol.Https; }\n  return undefined;\n}\n\nfunction isHttpProtocol(proto: LoadBalancingProtocol): boolean {\n  return proto === LoadBalancingProtocol.Https || proto === LoadBalancingProtocol.Http;\n}\n\nfunction ifUndefined<T>(x: T | undefined, def: T): T {\n  return x != null ? x : def;\n}\n\nfunction ifUndefinedLazy<T>(x: T | undefined, def: () => T): T {\n  return x != null ? x : def();\n}\n\n/**\n * Turn health check parameters into a parameter blob for the LB\n */\nfunction healthCheckToJSON(healthCheck: HealthCheck): cloudformation.LoadBalancerResource.HealthCheckProperty {\n  const protocol = ifUndefined(healthCheck.protocol,\n           ifUndefined(tryWellKnownProtocol(healthCheck.port),\n           LoadBalancingProtocol.Tcp));\n\n  const path = protocol === LoadBalancingProtocol.Http || protocol === LoadBalancingProtocol.Https ? ifUndefined(healthCheck.path, \"/\") : \"\";\n\n  const target = `${protocol.toUpperCase()}:${healthCheck.port}${path}`;\n\n  return {\n    healthyThreshold: ifUndefined(healthCheck.healthyThreshold, 2).toString(),\n    interval: ifUndefined(healthCheck.interval, 30).toString(),\n    target,\n    timeout: ifUndefined(healthCheck.timeout, 5).toString(),\n    unhealthyThreshold: ifUndefined(healthCheck.unhealthyThreshold, 5).toString(),\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"load-balancer.js","sourceRoot":"","sources":["load-balancer.ts"],"names":[],"mappings":";;AAAA,0DAA2D;AAC3D,8CACkE;AAClE,oCAAqC;AACrC,qFAAkE;AA4KlE,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC/B,oCAAW,CAAA;IACX,oCAAW,CAAA;IACX,sCAAa,CAAA;IACb,wCAAe,CAAA;AACjB,CAAC,EALW,qBAAqB,GAArB,6BAAqB,KAArB,6BAAqB,QAKhC;AAED;;;;GAIG;AACH,MAAa,YAAa,SAAQ,GAAG,CAAC,SAAS;IAkB7C,YAAY,MAAqB,EAAE,IAAY,EAAE,KAAwB;QACvE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAbtB;;WAEG;QACa,kBAAa,GAAmB,EAAE,CAAC;QAIlC,cAAS,GAA4D,EAAE,CAAC;QAExE,kBAAa,GAAa,EAAE,CAAC;QAC7B,YAAO,GAA0B,EAAE,CAAC;QAKnD,IAAI,CAAC,aAAa,GAAG,IAAI,uBAAa,CAAC,IAAI,EAAE,eAAe,EAAE,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QAClF,IAAI,CAAC,WAAW,GAAG,IAAI,qBAAW,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QAE1E,0FAA0F;QAC1F,MAAM,OAAO,GAAmB,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,cAAc,CAAC;QAE1G,IAAI,CAAC,GAAG,GAAG,IAAI,+CAAc,CAAC,oBAAoB,CAAC,IAAI,EAAE,UAAU,EAAE;YACnE,cAAc,EAAE,CAAE,IAAI,CAAC,aAAa,CAAC,eAAe,CAAE;YACtD,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;YACrC,SAAS,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC;YAC9C,MAAM,EAAE,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,UAAU;YAC7D,WAAW,EAAE,KAAK,CAAC,WAAW,IAAI,iBAAiB,CAAC,KAAK,CAAC,WAAW,CAAC;SACvE,CAAC,CAAC;QAEH,WAAW,CAAC,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACnE,WAAW,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IACjE,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,QAA8B;QAC/C,MAAM,QAAQ,GAAG,eAAe,CAAC,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;QAC5G,MAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,IAAI,QAAQ,CAAC,YAAY,CAAC;QACpE,MAAM,gBAAgB,GAAG,WAAW,CAAC,QAAQ,CAAC,gBAAgB,EACjD,WAAW,CAAC,oBAAoB,CAAC,YAAY,CAAC,EAC9C,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC;QAEjG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAClB,gBAAgB,EAAE,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE;YAClD,QAAQ;YACR,YAAY,EAAE,YAAY,CAAC,QAAQ,EAAE;YACrC,gBAAgB;YAChB,gBAAgB,EAAE,QAAQ,CAAC,gBAAgB;YAC3C,WAAW,EAAE,QAAQ,CAAC,WAAW;SAClC,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,iBAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;QAEtF,kFAAkF;QAClF,WAAW,CAAC,QAAQ,CAAC,oBAAoB,EAAE,CAAC,IAAI,iBAAO,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACzE,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,IAAI,EAAE,yBAAyB,QAAQ,CAAC,YAAY,EAAE,CAAC,CAAC;QAChG,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;QAEnC,mGAAmG;QACnG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE9B,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,SAAS,CAAC,MAA2B;QAC1C,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAE/B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACzB,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;IACtB,CAAC;IAED,IAAW,mCAAmC;QAC5C,OAAO,IAAI,CAAC,GAAG,CAAC,mCAAmC,CAAC;IACtD,CAAC;IAED,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,GAAG,CAAC,mBAAmB,CAAC;IACtC,CAAC;IAED,IAAW,wCAAwC;QACjD,OAAO,IAAI,CAAC,GAAG,CAAC,wCAAwC,CAAC;IAC3D,CAAC;IAED,IAAW,yCAAyC;QAClD,OAAO,IAAI,CAAC,GAAG,CAAC,yCAAyC,CAAC;IAC5D,CAAC;IAEM,wBAAwB;QAC7B,OAAO;YACL,UAAU,EAAE,UAAU,CAAC,sBAAsB,CAAC,KAAK;YACnD,IAAI,EAAE,IAAI,CAAC,gBAAgB;SAC5B,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,eAAe,CAAC,YAAoB;QAC1C,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAEvE,wCAAwC;QACxC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACxC,CAAC;IAED;;OAEG;IACK,SAAS,CAAC,MAA2B;QAC3C,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;QAEvE,6CAA6C;QAC7C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACK,qBAAqB,CAAC,YAAoB,EAAE,MAA2B;QAC7E,IAAI,CAAC,WAAW,CAAC,OAAO,CACtB,MAAM,EACN,IAAI,iBAAO,CAAC,YAAY,CAAC,EACzB,QAAQ,YAAY,cAAc,CAAC,CAAC;IACxC,CAAC;CACF;AAzID,oCAyIC;AAED;;;;;;;;;;;;GAYG;AACH,MAAa,YAAY;IAGvB,YAAY,aAA+B,EAAE,gBAA4B;QACvE,IAAI,CAAC,WAAW,GAAG,IAAI,qBAAW,CAAC,EAAE,aAAa,EAAE,gBAAgB,EAAE,CAAC,CAAC;IAC1E,CAAC;CACF;AAND,oCAMC;AAED,SAAS,iBAAiB,CAAC,IAAY;IACrC,MAAM,KAAK,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACzC,IAAI,CAAC,KAAK,EAAE;QACV,MAAM,IAAI,KAAK,CAAC,0CAA0C,IAAI,EAAE,CAAC,CAAC;KACnE;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,oBAAoB,CAAC,IAAY;IACxC,IAAI,IAAI,KAAK,EAAE,EAAE;QAAE,OAAO,qBAAqB,CAAC,IAAI,CAAC;KAAE;IACvD,IAAI,IAAI,KAAK,GAAG,EAAE;QAAE,OAAO,qBAAqB,CAAC,KAAK,CAAC;KAAE;IACzD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,SAAS,cAAc,CAAC,KAA4B;IAClD,OAAO,KAAK,KAAK,qBAAqB,CAAC,KAAK,IAAI,KAAK,KAAK,qBAAqB,CAAC,IAAI,CAAC;AACvF,CAAC;AAED,SAAS,WAAW,CAAI,CAAgB,EAAE,GAAM;IAC9C,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;AAC7B,CAAC;AAED,SAAS,eAAe,CAAI,CAAgB,EAAE,GAAY;IACxD,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;AAC/B,CAAC;AAED;;GAEG;AACH,SAAS,iBAAiB,CAAC,WAAwB;IACjD,MAAM,QAAQ,GAAG,WAAW,CAAC,WAAW,CAAC,QAAQ,EACxC,WAAW,CAAC,oBAAoB,CAAC,WAAW,CAAC,IAAI,CAAC,EAClD,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC;IAErC,MAAM,IAAI,GAAG,QAAQ,KAAK,qBAAqB,CAAC,IAAI,IAAI,QAAQ,KAAK,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAE3I,MAAM,MAAM,GAAG,GAAG,QAAQ,CAAC,WAAW,EAAE,IAAI,WAAW,CAAC,IAAI,GAAG,IAAI,EAAE,CAAC;IAEtE,OAAO;QACL,gBAAgB,EAAE,WAAW,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;QACzE,QAAQ,EAAE,WAAW,CAAC,WAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE;QAC1D,MAAM;QACN,OAAO,EAAE,WAAW,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;QACvD,kBAAkB,EAAE,WAAW,CAAC,WAAW,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;KAC9E,CAAC;AACJ,CAAC","sourcesContent":["import codedeploy = require('@aws-cdk/aws-codedeploy-api');\nimport { AnyIPv4, Connections, IConnectable, IPortRange, SecurityGroup, SecurityGroupRef,\n  TcpPort, VpcNetworkRef, VpcSubnetRef  } from '@aws-cdk/aws-ec2';\nimport cdk = require('@aws-cdk/cdk');\nimport { cloudformation } from './elasticloadbalancing.generated';\n\n/**\n * Construction properties for a LoadBalancer\n */\nexport interface LoadBalancerProps {\n  /**\n   * VPC network of the fleet instances\n   */\n  vpc: VpcNetworkRef;\n\n  /**\n   * Whether this is an internet-facing Load Balancer\n   *\n   * This controls whether the LB has a public IP address assigned. It does\n   * not open up the Load Balancer's security groups to public internet access.\n   *\n   * @default false\n   */\n  internetFacing?: boolean;\n\n  /**\n   * What listeners to set up for the load balancer.\n   *\n   * Can also be added by .addListener()\n   */\n  listeners?: LoadBalancerListener[];\n\n  /**\n   * What targets to load balance to.\n   *\n   * Can also be added by .addTarget()\n   */\n  targets?: ILoadBalancerTarget[];\n\n  /**\n   * Health check settings for the load balancing targets.\n   *\n   * Not required but recommended.\n   */\n  healthCheck?: HealthCheck;\n}\n\n/**\n * Describe the health check to a load balancer\n */\nexport interface HealthCheck {\n  /**\n   * What port number to health check on\n   */\n  port: number;\n\n  /**\n   * What protocol to use for health checking\n   *\n   * The protocol is automatically determined from the port if it's not supplied.\n   *\n   * @default Automatic\n   */\n  protocol?: LoadBalancingProtocol;\n\n  /**\n   * What path to use for HTTP or HTTPS health check (must return 200)\n   *\n   * For SSL and TCP health checks, accepting connections is enough to be considered\n   * healthy.\n   *\n   * @default \"/\"\n   */\n  path?: string;\n\n  /**\n   * After how many successful checks is an instance considered healthy\n   *\n   * @default 2\n   */\n  healthyThreshold?: number;\n\n  /**\n   * After how many unsuccessful checks is an instance considered unhealthy\n   *\n   * @default 5\n   */\n  unhealthyThreshold?: number;\n\n  /**\n   * Number of seconds between health checks\n   *\n   * @default 30\n   */\n  interval?: number;\n\n  /**\n   * Health check timeout\n   *\n   * @default 5\n   */\n  timeout?: number;\n}\n\n/**\n * Interface that is going to be implemented by constructs that you can load balance to\n */\nexport interface ILoadBalancerTarget extends IConnectable {\n  /**\n   * Attach load-balanced target to a classic ELB\n   */\n  attachToClassicLB(loadBalancer: LoadBalancer): void;\n}\n\n/**\n * Add a backend to the load balancer\n */\nexport interface LoadBalancerListener {\n  /**\n   * External listening port\n   */\n  externalPort: number;\n\n  /**\n   * What public protocol to use for load balancing\n   *\n   * Either 'tcp', 'ssl', 'http' or 'https'.\n   *\n   * May be omitted if the external port is either 80 or 443.\n   */\n  externalProtocol?: LoadBalancingProtocol;\n\n  /**\n   * Instance listening port\n   *\n   * Same as the externalPort if not specified.\n   *\n   * @default externalPort\n   */\n  internalPort?: number;\n\n  /**\n   * What public protocol to use for load balancing\n   *\n   * Either 'tcp', 'ssl', 'http' or 'https'.\n   *\n   * May be omitted if the internal port is either 80 or 443.\n   *\n   * The instance protocol is 'tcp' if the front-end protocol\n   * is 'tcp' or 'ssl', the instance protocol is 'http' if the\n   * front-end protocol is 'https'.\n   */\n  internalProtocol?: LoadBalancingProtocol;\n\n  /**\n   * SSL policy names\n   */\n  policyNames?: string[];\n\n  /**\n   * ID of SSL certificate\n   */\n  sslCertificateId?: string;\n\n  /**\n   * Allow connections to the load balancer from the given set of connection peers\n   *\n   * By default, connections will be allowed from anywhere. Set this to an empty list\n   * to deny connections, or supply a custom list of peers to allow connections from\n   * (IP ranges or security groups).\n   *\n   * @default Anywhere\n   */\n  allowConnectionsFrom?: IConnectable[];\n}\n\nexport enum LoadBalancingProtocol {\n  Tcp = 'tcp',\n  Ssl = 'ssl',\n  Http = 'http',\n  Https = 'https'\n}\n\n/**\n * A load balancer with a single listener\n *\n * Routes to a fleet of of instances in a VPC.\n */\nexport class LoadBalancer extends cdk.Construct implements IConnectable, codedeploy.ILoadBalancer {\n  /**\n   * Control all connections from and to this load balancer\n   */\n  public readonly connections: Connections;\n\n  /**\n   * An object controlling specifically the connections for each listener added to this load balancer\n   */\n  public readonly listenerPorts: ListenerPort[] = [];\n\n  private readonly elb: cloudformation.LoadBalancerResource;\n  private readonly securityGroup: SecurityGroup;\n  private readonly listeners: cloudformation.LoadBalancerResource.ListenersProperty[] = [];\n\n  private readonly instancePorts: number[] = [];\n  private readonly targets: ILoadBalancerTarget[] = [];\n\n  constructor(parent: cdk.Construct, name: string, props: LoadBalancerProps) {\n    super(parent, name);\n\n    this.securityGroup = new SecurityGroup(this, 'SecurityGroup', { vpc: props.vpc });\n    this.connections = new Connections({ securityGroup: this.securityGroup });\n\n    // Depending on whether the ELB has public or internal IPs, pick the right backend subnets\n    const subnets: VpcSubnetRef[] = props.internetFacing ? props.vpc.publicSubnets : props.vpc.privateSubnets;\n\n    this.elb = new cloudformation.LoadBalancerResource(this, 'Resource', {\n      securityGroups: [ this.securityGroup.securityGroupId ],\n      subnets: subnets.map(s => s.subnetId),\n      listeners: new cdk.Token(() => this.listeners),\n      scheme: props.internetFacing ? 'internet-facing' : 'internal',\n      healthCheck: props.healthCheck && healthCheckToJSON(props.healthCheck),\n    });\n\n    ifUndefined(props.listeners, []).forEach(b => this.addListener(b));\n    ifUndefined(props.targets, []).forEach(t => this.addTarget(t));\n  }\n\n  /**\n   * Add a backend to the load balancer\n   *\n   * @returns A ListenerPort object that controls connections to the listener port\n   */\n  public addListener(listener: LoadBalancerListener): ListenerPort {\n    const protocol = ifUndefinedLazy(listener.externalProtocol, () => wellKnownProtocol(listener.externalPort));\n    const instancePort = listener.internalPort || listener.externalPort;\n    const instanceProtocol = ifUndefined(listener.internalProtocol,\n                 ifUndefined(tryWellKnownProtocol(instancePort),\n                 isHttpProtocol(protocol) ? LoadBalancingProtocol.Http : LoadBalancingProtocol.Tcp));\n\n    this.listeners.push({\n      loadBalancerPort: listener.externalPort.toString(),\n      protocol,\n      instancePort: instancePort.toString(),\n      instanceProtocol,\n      sslCertificateId: listener.sslCertificateId,\n      policyNames: listener.policyNames\n    });\n\n    const port = new ListenerPort(this.securityGroup, new TcpPort(listener.externalPort));\n\n    // Allow connections on the public port for all supplied peers (default: everyone)\n    ifUndefined(listener.allowConnectionsFrom, [new AnyIPv4()]).forEach(peer => {\n      port.connections.allowDefaultPortFrom(peer, `Default rule allow on ${listener.externalPort}`);\n    });\n\n    this.newInstancePort(instancePort);\n\n    // Keep track using array so user can get to them even if they were all supplied in the constructor\n    this.listenerPorts.push(port);\n\n    return port;\n  }\n\n  public addTarget(target: ILoadBalancerTarget) {\n    target.attachToClassicLB(this);\n\n    this.newTarget(target);\n  }\n\n  public get loadBalancerName() {\n    return this.elb.ref;\n  }\n\n  public get loadBalancerCanonicalHostedZoneName() {\n    return this.elb.loadBalancerCanonicalHostedZoneName;\n  }\n\n  public get loadBalancerDnsName() {\n    return this.elb.loadBalancerDnsName;\n  }\n\n  public get loadBalancerSourceSecurityGroupGroupName() {\n    return this.elb.loadBalancerSourceSecurityGroupGroupName;\n  }\n\n  public get loadBalancerSourceSecurityGroupOwnerAlias() {\n    return this.elb.loadBalancerSourceSecurityGroupOwnerAlias;\n  }\n\n  public asCodeDeployLoadBalancer(): codedeploy.ILoadBalancerProps {\n    return {\n      generation: codedeploy.LoadBalancerGeneration.First,\n      name: this.loadBalancerName,\n    };\n  }\n\n  /**\n   * Allow connections to all existing targets on new instance port\n   */\n  private newInstancePort(instancePort: number) {\n    this.targets.forEach(t => this.allowTargetConnection(instancePort, t));\n\n    // Keep track of port for future targets\n    this.instancePorts.push(instancePort);\n  }\n\n  /**\n   * Allow connections to target on all existing instance ports\n   */\n  private newTarget(target: ILoadBalancerTarget) {\n    this.instancePorts.forEach(p => this.allowTargetConnection(p, target));\n\n    // Keep track of target for future listeners.\n    this.targets.push(target);\n  }\n\n  /**\n   * Allow connections for a single (port, target) pair\n   */\n  private allowTargetConnection(instancePort: number, target: ILoadBalancerTarget) {\n    this.connections.allowTo(\n      target,\n      new TcpPort(instancePort),\n      `Port ${instancePort} LB to fleet`);\n  }\n}\n\n/**\n * Reference to a listener's port just created.\n *\n * This implements IConnectable with a default port (the port that an ELB\n * listener was just created on) for a given security group so that it can be\n * conveniently used just like any Connectable. E.g:\n *\n *    const listener = elb.addListener(...);\n *\n *    listener.connections.allowDefaultPortFromAnyIPv4();\n *    // or\n *    instance.connections.allowToDefaultPort(listener);\n */\nexport class ListenerPort implements IConnectable {\n  public readonly connections: Connections;\n\n  constructor(securityGroup: SecurityGroupRef, defaultPortRange: IPortRange) {\n    this.connections = new Connections({ securityGroup, defaultPortRange });\n  }\n}\n\nfunction wellKnownProtocol(port: number): LoadBalancingProtocol {\n  const proto = tryWellKnownProtocol(port);\n  if (!proto) {\n    throw new Error(`Please supply protocol to go with port ${port}`);\n  }\n  return proto;\n}\n\nfunction tryWellKnownProtocol(port: number): LoadBalancingProtocol | undefined {\n  if (port === 80) { return LoadBalancingProtocol.Http; }\n  if (port === 443) { return LoadBalancingProtocol.Https; }\n  return undefined;\n}\n\nfunction isHttpProtocol(proto: LoadBalancingProtocol): boolean {\n  return proto === LoadBalancingProtocol.Https || proto === LoadBalancingProtocol.Http;\n}\n\nfunction ifUndefined<T>(x: T | undefined, def: T): T {\n  return x != null ? x : def;\n}\n\nfunction ifUndefinedLazy<T>(x: T | undefined, def: () => T): T {\n  return x != null ? x : def();\n}\n\n/**\n * Turn health check parameters into a parameter blob for the LB\n */\nfunction healthCheckToJSON(healthCheck: HealthCheck): cloudformation.LoadBalancerResource.HealthCheckProperty {\n  const protocol = ifUndefined(healthCheck.protocol,\n           ifUndefined(tryWellKnownProtocol(healthCheck.port),\n           LoadBalancingProtocol.Tcp));\n\n  const path = protocol === LoadBalancingProtocol.Http || protocol === LoadBalancingProtocol.Https ? ifUndefined(healthCheck.path, \"/\") : \"\";\n\n  const target = `${protocol.toUpperCase()}:${healthCheck.port}${path}`;\n\n  return {\n    healthyThreshold: ifUndefined(healthCheck.healthyThreshold, 2).toString(),\n    interval: ifUndefined(healthCheck.interval, 30).toString(),\n    target,\n    timeout: ifUndefined(healthCheck.timeout, 5).toString(),\n    unhealthyThreshold: ifUndefined(healthCheck.unhealthyThreshold, 5).toString(),\n  };\n}\n"]}
{
"name": "@aws-cdk/aws-elasticloadbalancing",
"version": "0.10.0",
"version": "0.11.0",
"description": "CDK Constructs for AWS ElasticLoadBalancing",

@@ -55,13 +55,14 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^0.10.0",
"cdk-build-tools": "^0.10.0",
"cdk-integ-tools": "^0.10.0",
"cfn2ts": "^0.10.0",
"pkglint": "^0.10.0"
"@aws-cdk/assert": "^0.11.0",
"cdk-build-tools": "^0.11.0",
"cdk-integ-tools": "^0.11.0",
"cfn2ts": "^0.11.0",
"pkglint": "^0.11.0"
},
"dependencies": {
"@aws-cdk/aws-ec2": "^0.10.0",
"@aws-cdk/cdk": "^0.10.0"
"@aws-cdk/aws-codedeploy-api": "^0.11.0",
"@aws-cdk/aws-ec2": "^0.11.0",
"@aws-cdk/cdk": "^0.11.0"
},
"homepage": "https://github.com/awslabs/aws-cdk"
}

@@ -49,3 +49,3 @@ {

},
"VPCPublicSubnet1RouteTableAssociatioin249B4093": {
"VPCPublicSubnet1RouteTableAssociation0B0896DC": {
"Type": "AWS::EC2::SubnetRouteTableAssociation",

@@ -130,3 +130,3 @@ "Properties": {

},
"VPCPrivateSubnet1RouteTableAssociatioin77F7CA18": {
"VPCPrivateSubnet1RouteTableAssociation347902D1": {
"Type": "AWS::EC2::SubnetRouteTableAssociation",

@@ -190,3 +190,2 @@ "Properties": {

],
"Tags": [],
"VpcId": {

@@ -193,0 +192,0 @@ "Ref": "VPCB9E5F0B4"

@@ -7,3 +7,3 @@ #!/usr/bin/env node

const elb = require("../lib");
const app = new cdk.App(process.argv);
const app = new cdk.App();
const stack = new cdk.Stack(app, 'aws-cdk-elb-integ');

@@ -25,3 +25,3 @@ const vpc = new ec2.VpcNetwork(stack, 'VPC', {

});
process.stdout.write(app.run());
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZWxiLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZWxiLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHdDQUF5QztBQUN6QyxvQ0FBcUM7QUFDckMsOEJBQStCO0FBRS9CLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7QUFDdEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO0FBRXRELE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFO0lBQzNDLE1BQU0sRUFBRSxDQUFDO0NBQ1YsQ0FBQyxDQUFDO0FBRUgsSUFBSSxHQUFHLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDaEMsR0FBRztJQUNILGNBQWMsRUFBRSxJQUFJO0lBQ3BCLFNBQVMsRUFBRSxDQUFDO1lBQ1YsWUFBWSxFQUFFLEVBQUU7WUFDaEIsb0JBQW9CLEVBQUUsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztTQUMxQyxDQUFDO0lBQ0YsV0FBVyxFQUFFO1FBQ1gsSUFBSSxFQUFFLEVBQUU7S0FDVDtJQUNELE9BQU8sRUFBRSxFQUFFO0NBQ1osQ0FBQyxDQUFDO0FBRUgsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG5pbXBvcnQgZWMyID0gcmVxdWlyZSgnQGF3cy1jZGsvYXdzLWVjMicpO1xuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IGVsYiA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcChwcm9jZXNzLmFyZ3YpO1xuY29uc3Qgc3RhY2sgPSBuZXcgY2RrLlN0YWNrKGFwcCwgJ2F3cy1jZGstZWxiLWludGVnJyk7XG5cbmNvbnN0IHZwYyA9IG5ldyBlYzIuVnBjTmV0d29yayhzdGFjaywgJ1ZQQycsIHtcbiAgbWF4QVpzOiAxXG59KTtcblxubmV3IGVsYi5Mb2FkQmFsYW5jZXIoc3RhY2ssICdMQicsIHtcbiAgdnBjLFxuICBpbnRlcm5ldEZhY2luZzogdHJ1ZSxcbiAgbGlzdGVuZXJzOiBbe1xuICAgIGV4dGVybmFsUG9ydDogODAsXG4gICAgYWxsb3dDb25uZWN0aW9uc0Zyb206IFtuZXcgZWMyLkFueUlQdjQoKV1cbiAgfV0sXG4gIGhlYWx0aENoZWNrOiB7XG4gICAgcG9ydDogODBcbiAgfSxcbiAgdGFyZ2V0czogW11cbn0pO1xuXG5wcm9jZXNzLnN0ZG91dC53cml0ZShhcHAucnVuKCkpO1xuIl19
app.run();
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZWxiLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZWxiLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHdDQUF5QztBQUN6QyxvQ0FBcUM7QUFDckMsOEJBQStCO0FBRS9CLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztBQUV0RCxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRTtJQUMzQyxNQUFNLEVBQUUsQ0FBQztDQUNWLENBQUMsQ0FBQztBQUVILElBQUksR0FBRyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFO0lBQ2hDLEdBQUc7SUFDSCxjQUFjLEVBQUUsSUFBSTtJQUNwQixTQUFTLEVBQUUsQ0FBQztZQUNWLFlBQVksRUFBRSxFQUFFO1lBQ2hCLG9CQUFvQixFQUFFLENBQUMsSUFBSSxHQUFHLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDMUMsQ0FBQztJQUNGLFdBQVcsRUFBRTtRQUNYLElBQUksRUFBRSxFQUFFO0tBQ1Q7SUFDRCxPQUFPLEVBQUUsRUFBRTtDQUNaLENBQUMsQ0FBQztBQUVILEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcbmltcG9ydCBlYzIgPSByZXF1aXJlKCdAYXdzLWNkay9hd3MtZWMyJyk7XG5pbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgZWxiID0gcmVxdWlyZSgnLi4vbGliJyk7XG5cbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBjZGsuU3RhY2soYXBwLCAnYXdzLWNkay1lbGItaW50ZWcnKTtcblxuY29uc3QgdnBjID0gbmV3IGVjMi5WcGNOZXR3b3JrKHN0YWNrLCAnVlBDJywge1xuICBtYXhBWnM6IDFcbn0pO1xuXG5uZXcgZWxiLkxvYWRCYWxhbmNlcihzdGFjaywgJ0xCJywge1xuICB2cGMsXG4gIGludGVybmV0RmFjaW5nOiB0cnVlLFxuICBsaXN0ZW5lcnM6IFt7XG4gICAgZXh0ZXJuYWxQb3J0OiA4MCxcbiAgICBhbGxvd0Nvbm5lY3Rpb25zRnJvbTogW25ldyBlYzIuQW55SVB2NCgpXVxuICB9XSxcbiAgaGVhbHRoQ2hlY2s6IHtcbiAgICBwb3J0OiA4MFxuICB9LFxuICB0YXJnZXRzOiBbXVxufSk7XG5cbmFwcC5ydW4oKTtcbiJdfQ==

@@ -9,4 +9,2 @@ {

"inlineSources": true,
"jsx": "react",
"jsxFactory": "jsx.create",
"lib": [

@@ -13,0 +11,0 @@ "es2016",

Sorry, the diff of this file is not supported yet

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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc