@aws-cdk/aws-elasticloadbalancing
Advanced tools
Comparing version 0.20.0 to 0.21.0
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 @@ */ |
@@ -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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
415254
2275
+ Added@aws-cdk/aws-codedeploy-api@0.21.0(transitive)
+ Added@aws-cdk/aws-ec2@0.21.0(transitive)
+ Added@aws-cdk/aws-iam@0.21.0(transitive)
+ Added@aws-cdk/cdk@0.21.0(transitive)
+ Added@aws-cdk/cx-api@0.21.0(transitive)
- Removed@aws-cdk/aws-codedeploy-api@0.20.0(transitive)
- Removed@aws-cdk/aws-ec2@0.20.0(transitive)
- Removed@aws-cdk/aws-iam@0.20.0(transitive)
- Removed@aws-cdk/cdk@0.20.0(transitive)
- Removed@aws-cdk/cx-api@0.20.0(transitive)
Updated@aws-cdk/aws-ec2@^0.21.0
Updated@aws-cdk/cdk@^0.21.0