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.20.0 to 0.21.0

319

lib/elasticloadbalancing.generated.d.ts
import cdk = require('@aws-cdk/cdk');
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export interface CfnLoadBalancerProps {
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.Listeners``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-listeners
*/
listeners: Array<CfnLoadBalancer.ListenersProperty | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.AccessLoggingPolicy``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-accessloggingpolicy
*/
accessLoggingPolicy?: CfnLoadBalancer.AccessLoggingPolicyProperty | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.AppCookieStickinessPolicy``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-appcookiestickinesspolicy
*/
appCookieStickinessPolicy?: Array<CfnLoadBalancer.AppCookieStickinessPolicyProperty | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.AvailabilityZones``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-availabilityzones
*/
availabilityZones?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.ConnectionDrainingPolicy``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-connectiondrainingpolicy
*/
connectionDrainingPolicy?: CfnLoadBalancer.ConnectionDrainingPolicyProperty | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.ConnectionSettings``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-connectionsettings
*/
connectionSettings?: CfnLoadBalancer.ConnectionSettingsProperty | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.CrossZone``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-crosszone
*/
crossZone?: boolean | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.HealthCheck``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-healthcheck
*/
healthCheck?: CfnLoadBalancer.HealthCheckProperty | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.Instances``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-instances
*/
instances?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.LBCookieStickinessPolicy``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-lbcookiestickinesspolicy
*/
lbCookieStickinessPolicy?: Array<CfnLoadBalancer.LBCookieStickinessPolicyProperty | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.LoadBalancerName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-elbname
*/
loadBalancerName?: string | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.Policies``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-policies
*/
policies?: Array<CfnLoadBalancer.PoliciesProperty | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.Scheme``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-scheme
*/
scheme?: string | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.SecurityGroups``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-securitygroups
*/
securityGroups?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.Subnets``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-subnets
*/
subnets?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::ElasticLoadBalancing::LoadBalancer.Tags``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-elasticloadbalancing-loadbalancer-tags
*/
tags?: Array<cdk.Tag | cdk.Token> | cdk.Token;
}
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare class CfnLoadBalancer extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::ElasticLoadBalancing::LoadBalancer";
/**
* @cloudformation_attribute CanonicalHostedZoneName
*/
readonly loadBalancerCanonicalHostedZoneName: string;
/**
* @cloudformation_attribute CanonicalHostedZoneNameID
*/
readonly loadBalancerCanonicalHostedZoneNameId: string;
/**
* @cloudformation_attribute DNSName
*/
readonly loadBalancerDnsName: string;
/**
* @cloudformation_attribute SourceSecurityGroup.GroupName
*/
readonly loadBalancerSourceSecurityGroupGroupName: string;
/**
* @cloudformation_attribute SourceSecurityGroup.OwnerAlias
*/
readonly loadBalancerSourceSecurityGroupOwnerAlias: string;
readonly loadBalancerName: string;
/**
* Creates a new ``AWS::ElasticLoadBalancing::LoadBalancer``.
*
* @param parent the ``cdk.Construct`` this ``CfnLoadBalancer`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnLoadBalancer``
*/
constructor(parent: cdk.Construct, name: string, properties: CfnLoadBalancerProps);
readonly propertyOverrides: CfnLoadBalancerProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html
*/
interface AccessLoggingPolicyProperty {
/**
* ``CfnLoadBalancer.AccessLoggingPolicyProperty.EmitInterval``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-emitinterval
*/
emitInterval?: number | cdk.Token;
/**
* ``CfnLoadBalancer.AccessLoggingPolicyProperty.Enabled``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-enabled
*/
enabled: boolean | cdk.Token;
/**
* ``CfnLoadBalancer.AccessLoggingPolicyProperty.S3BucketName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-s3bucketname
*/
s3BucketName: string | cdk.Token;
/**
* ``CfnLoadBalancer.AccessLoggingPolicyProperty.S3BucketPrefix``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-s3bucketprefix
*/
s3BucketPrefix?: string | cdk.Token;
}
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-AppCookieStickinessPolicy.html
*/
interface AppCookieStickinessPolicyProperty {
/**
* ``CfnLoadBalancer.AppCookieStickinessPolicyProperty.CookieName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-AppCookieStickinessPolicy.html#cfn-elb-appcookiestickinesspolicy-cookiename
*/
cookieName: string | cdk.Token;
/**
* ``CfnLoadBalancer.AppCookieStickinessPolicyProperty.PolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-AppCookieStickinessPolicy.html#cfn-elb-appcookiestickinesspolicy-policyname
*/
policyName: string | cdk.Token;
}
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectiondrainingpolicy.html
*/
interface ConnectionDrainingPolicyProperty {
/**
* ``CfnLoadBalancer.ConnectionDrainingPolicyProperty.Enabled``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectiondrainingpolicy.html#cfn-elb-connectiondrainingpolicy-enabled
*/
enabled: boolean | cdk.Token;
/**
* ``CfnLoadBalancer.ConnectionDrainingPolicyProperty.Timeout``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectiondrainingpolicy.html#cfn-elb-connectiondrainingpolicy-timeout
*/
timeout?: number | cdk.Token;
}
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectionsettings.html
*/
interface ConnectionSettingsProperty {
/**
* ``CfnLoadBalancer.ConnectionSettingsProperty.IdleTimeout``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectionsettings.html#cfn-elb-connectionsettings-idletimeout
*/
idleTimeout: number | cdk.Token;
}
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html
*/
interface HealthCheckProperty {
/**
* ``CfnLoadBalancer.HealthCheckProperty.HealthyThreshold``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-healthythreshold
*/
healthyThreshold: string | cdk.Token;
/**
* ``CfnLoadBalancer.HealthCheckProperty.Interval``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-interval
*/
interval: string | cdk.Token;
/**
* ``CfnLoadBalancer.HealthCheckProperty.Target``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-target
*/
target: string | cdk.Token;
/**
* ``CfnLoadBalancer.HealthCheckProperty.Timeout``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-timeout
*/
timeout: string | cdk.Token;
/**
* ``CfnLoadBalancer.HealthCheckProperty.UnhealthyThreshold``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-unhealthythreshold
*/
unhealthyThreshold: string | cdk.Token;
}
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-LBCookieStickinessPolicy.html
*/
interface LBCookieStickinessPolicyProperty {
/**
* ``CfnLoadBalancer.LBCookieStickinessPolicyProperty.CookieExpirationPeriod``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-LBCookieStickinessPolicy.html#cfn-elb-lbcookiestickinesspolicy-cookieexpirationperiod
*/
cookieExpirationPeriod?: string | cdk.Token;
/**
* ``CfnLoadBalancer.LBCookieStickinessPolicyProperty.PolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-LBCookieStickinessPolicy.html#cfn-elb-lbcookiestickinesspolicy-policyname
*/
policyName?: string | cdk.Token;
}
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html
*/
interface ListenersProperty {
/**
* ``CfnLoadBalancer.ListenersProperty.InstancePort``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-instanceport
*/
instancePort: string | cdk.Token;
/**
* ``CfnLoadBalancer.ListenersProperty.InstanceProtocol``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-instanceprotocol
*/
instanceProtocol?: string | cdk.Token;
/**
* ``CfnLoadBalancer.ListenersProperty.LoadBalancerPort``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-loadbalancerport
*/
loadBalancerPort: string | cdk.Token;
/**
* ``CfnLoadBalancer.ListenersProperty.PolicyNames``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-policynames
*/
policyNames?: Array<string | cdk.Token> | cdk.Token;
/**
* ``CfnLoadBalancer.ListenersProperty.Protocol``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-protocol
*/
protocol: string | cdk.Token;
/**
* ``CfnLoadBalancer.ListenersProperty.SSLCertificateId``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-sslcertificateid
*/
sslCertificateId?: string | cdk.Token;
}
}
export declare namespace CfnLoadBalancer {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html
*/
interface PoliciesProperty {
/**
* ``CfnLoadBalancer.PoliciesProperty.Attributes``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-attributes
*/
attributes: Array<object | cdk.Token> | cdk.Token;
/**
* ``CfnLoadBalancer.PoliciesProperty.InstancePorts``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-instanceports
*/
instancePorts?: Array<string | cdk.Token> | cdk.Token;
/**
* ``CfnLoadBalancer.PoliciesProperty.LoadBalancerPorts``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-loadbalancerports
*/
loadBalancerPorts?: Array<string | cdk.Token> | cdk.Token;
/**
* ``CfnLoadBalancer.PoliciesProperty.PolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-policyname
*/
policyName: string | cdk.Token;
/**
* ``CfnLoadBalancer.PoliciesProperty.PolicyType``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-policytype
*/
policyType: string | cdk.Token;
}
}
export declare namespace cloudformation {

@@ -89,2 +407,3 @@ /**

/**
* @deprecated "cloudformation.LoadBalancerResource" will be deprecated in a future release in favor of "CfnLoadBalancer" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html

@@ -91,0 +410,0 @@ */

4

lib/load-balancer.js

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

const subnets = props.internetFacing ? props.vpc.publicSubnets : props.vpc.privateSubnets;
this.elb = new elasticloadbalancing_generated_1.cloudformation.LoadBalancerResource(this, 'Resource', {
this.elb = new elasticloadbalancing_generated_1.CfnLoadBalancer(this, 'Resource', {
securityGroups: [this.securityGroup.securityGroupId],

@@ -182,2 +182,2 @@ subnets: subnets.map(s => s.subnetId),

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"load-balancer.js","sourceRoot":"","sources":["load-balancer.ts"],"names":[],"mappings":"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","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, allowAllOutbound: false });\n    this.connections = new Connections({ securityGroups: [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    if (props.internetFacing) {\n      this.elb.addDependency(props.vpc.internetDependency());\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({ securityGroups: [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":"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","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 { CfnLoadBalancer } 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: CfnLoadBalancer;\n  private readonly securityGroup: SecurityGroup;\n  private readonly listeners: CfnLoadBalancer.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, allowAllOutbound: false });\n    this.connections = new Connections({ securityGroups: [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 CfnLoadBalancer(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    if (props.internetFacing) {\n      this.elb.addDependency(props.vpc.internetDependency());\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({ securityGroups: [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): CfnLoadBalancer.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.20.0",
"version": "0.21.0",
"description": "CDK Constructs for AWS ElasticLoadBalancing",

@@ -55,19 +55,22 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^0.20.0",
"cdk-build-tools": "^0.20.0",
"cdk-integ-tools": "^0.20.0",
"cfn2ts": "^0.20.0",
"pkglint": "^0.20.0"
"@aws-cdk/assert": "^0.21.0",
"cdk-build-tools": "^0.21.0",
"cdk-integ-tools": "^0.21.0",
"cfn2ts": "^0.21.0",
"pkglint": "^0.21.0"
},
"dependencies": {
"@aws-cdk/aws-codedeploy-api": "^0.20.0",
"@aws-cdk/aws-ec2": "^0.20.0",
"@aws-cdk/cdk": "^0.20.0"
"@aws-cdk/aws-codedeploy-api": "^0.21.0",
"@aws-cdk/aws-ec2": "^0.21.0",
"@aws-cdk/cdk": "^0.21.0"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-codedeploy-api": "^0.20.0",
"@aws-cdk/aws-ec2": "^0.20.0",
"@aws-cdk/cdk": "^0.20.0"
"@aws-cdk/aws-codedeploy-api": "^0.21.0",
"@aws-cdk/aws-ec2": "^0.21.0",
"@aws-cdk/cdk": "^0.21.0"
},
"engines": {
"node": ">= 8.10.0"
}
}

Sorry, the diff of this file is not supported yet

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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc