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
5
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 1.144.0 to 1.145.0

22

.warnings.jsii.js

@@ -7,10 +7,2 @@ function _aws_cdk_aws_elasticloadbalancing_LoadBalancingProtocol(p) {

}
function _aws_cdk_aws_elasticloadbalancing_HealthCheck(p) {
if (p == null)
return;
visitedObjects.add(p);
if (!visitedObjects.has(p.protocol))
_aws_cdk_aws_elasticloadbalancing_LoadBalancingProtocol(p.protocol);
visitedObjects.delete(p);
}
function _aws_cdk_aws_elasticloadbalancing_LoadBalancerProps(p) {

@@ -30,2 +22,10 @@ if (p == null)

}
function _aws_cdk_aws_elasticloadbalancing_HealthCheck(p) {
if (p == null)
return;
visitedObjects.add(p);
if (!visitedObjects.has(p.protocol))
_aws_cdk_aws_elasticloadbalancing_LoadBalancingProtocol(p.protocol);
visitedObjects.delete(p);
}
function _aws_cdk_aws_elasticloadbalancing_LoadBalancer(p) {

@@ -67,2 +67,4 @@ }

}
function _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ConnectionDrainingPolicyProperty(p) {
}
function _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_PoliciesProperty(p) {

@@ -72,4 +74,2 @@ }

}
function _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ConnectionDrainingPolicyProperty(p) {
}
function print(name, deprecationMessage) {

@@ -90,3 +90,3 @@ const deprecated = process.env.JSII_DEPRECATED;

}
module.exports = { print, _aws_cdk_aws_elasticloadbalancing_LoadBalancingProtocol, _aws_cdk_aws_elasticloadbalancing_ILoadBalancerTarget, _aws_cdk_aws_elasticloadbalancing_ListenerPort, _aws_cdk_aws_elasticloadbalancing_HealthCheck, _aws_cdk_aws_elasticloadbalancing_LoadBalancerProps, _aws_cdk_aws_elasticloadbalancing_LoadBalancer, _aws_cdk_aws_elasticloadbalancing_LoadBalancerListener, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancerProps, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ConnectionSettingsProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_AppCookieStickinessPolicyProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_HealthCheckProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_LBCookieStickinessPolicyProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ListenersProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_PoliciesProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_AccessLoggingPolicyProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ConnectionDrainingPolicyProperty };
module.exports = { print, _aws_cdk_aws_elasticloadbalancing_LoadBalancingProtocol, _aws_cdk_aws_elasticloadbalancing_ILoadBalancerTarget, _aws_cdk_aws_elasticloadbalancing_ListenerPort, _aws_cdk_aws_elasticloadbalancing_LoadBalancerProps, _aws_cdk_aws_elasticloadbalancing_HealthCheck, _aws_cdk_aws_elasticloadbalancing_LoadBalancer, _aws_cdk_aws_elasticloadbalancing_LoadBalancerListener, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancerProps, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ConnectionSettingsProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_AppCookieStickinessPolicyProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_HealthCheckProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_LBCookieStickinessPolicyProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ListenersProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_ConnectionDrainingPolicyProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_PoliciesProperty, _aws_cdk_aws_elasticloadbalancing_CfnLoadBalancer_AccessLoggingPolicyProperty };
module.exports.DeprecationError = DeprecationError;
import * as cdk from '@aws-cdk/core';
import * as cfn_parse from '@aws-cdk/core/lib/cfn-parse';
/**
* Properties for defining a `CfnLoadBalancer`.
* Properties for defining a `CfnLoadBalancer`
*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html

@@ -15,3 +17,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-listeners

@@ -23,3 +24,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-accessloggingpolicy

@@ -31,3 +31,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-appcookiestickinesspolicy

@@ -41,3 +40,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-availabilityzones

@@ -51,3 +49,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-connectiondrainingpolicy

@@ -61,3 +58,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-connectionsettings

@@ -71,3 +67,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-crosszone

@@ -81,3 +76,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-healthcheck

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

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-instances

@@ -97,3 +90,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-lbcookiestickinesspolicy

@@ -103,9 +95,6 @@ */

/**
* The name of the load balancer.
* The name of the load balancer. This name must be unique within your set of load balancers for the region.
*
* This name must be unique within your set of load balancers for the region.
*
* If you don't specify a name, AWS CloudFormation generates a unique physical ID for the load balancer. For more information, see [Name Type](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html) . If you specify a name, you cannot perform updates that require replacement of this resource, but you can perform other updates. To replace the resource, specify a new name.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-elbname

@@ -115,7 +104,4 @@ */

/**
* The policies defined for your Classic Load Balancer.
* The policies defined for your Classic Load Balancer. Specify only back-end server policies.
*
* Specify only back-end server policies.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-policies

@@ -131,3 +117,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-scheme

@@ -137,7 +122,4 @@ */

/**
* The security groups for the load balancer.
* The security groups for the load balancer. Valid only for load balancers in a VPC.
*
* Valid only for load balancers in a VPC.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-securitygroups

@@ -151,3 +133,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-subnets

@@ -159,3 +140,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-elasticloadbalancing-loadbalancer-tags

@@ -166,3 +146,3 @@ */

/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`
*

@@ -175,4 +155,5 @@ * Specifies a Classic Load Balancer.

*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html

@@ -183,4 +164,2 @@ */

* The CloudFormation resource type name for this resource class.
*
* @external
*/

@@ -197,7 +176,3 @@ static readonly CFN_RESOURCE_TYPE_NAME = "AWS::ElasticLoadBalancing::LoadBalancer";

/**
* The name of the Route 53 hosted zone that is associated with the load balancer.
*
* Internal-facing load balancers don't use this value, use `DNSName` instead.
*
* @external
* The name of the Route 53 hosted zone that is associated with the load balancer. Internal-facing load balancers don't use this value, use `DNSName` instead.
* @cloudformationAttribute CanonicalHostedZoneName

@@ -208,4 +183,2 @@ */

* The ID of the Route 53 hosted zone name that is associated with the load balancer.
*
* @external
* @cloudformationAttribute CanonicalHostedZoneNameID

@@ -216,4 +189,2 @@ */

* The DNS name for the load balancer.
*
* @external
* @cloudformationAttribute DNSName

@@ -224,4 +195,2 @@ */

* The name of the security group that you can use as part of your inbound rules for your load balancer's back-end instances.
*
* @external
* @cloudformationAttribute SourceSecurityGroup.GroupName

@@ -232,4 +201,2 @@ */

* The owner of the source security group.
*
* @external
* @cloudformationAttribute SourceSecurityGroup.OwnerAlias

@@ -243,3 +210,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-listeners

@@ -251,3 +217,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-accessloggingpolicy

@@ -259,3 +224,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-appcookiestickinesspolicy

@@ -269,3 +233,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-availabilityzones

@@ -279,3 +242,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-connectiondrainingpolicy

@@ -289,3 +251,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-connectionsettings

@@ -299,3 +260,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-crosszone

@@ -309,3 +269,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-healthcheck

@@ -317,3 +276,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-instances

@@ -325,3 +283,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-lbcookiestickinesspolicy

@@ -331,9 +288,6 @@ */

/**
* The name of the load balancer.
* The name of the load balancer. This name must be unique within your set of load balancers for the region.
*
* This name must be unique within your set of load balancers for the region.
*
* If you don't specify a name, AWS CloudFormation generates a unique physical ID for the load balancer. For more information, see [Name Type](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html) . If you specify a name, you cannot perform updates that require replacement of this resource, but you can perform other updates. To replace the resource, specify a new name.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-elbname

@@ -343,7 +297,4 @@ */

/**
* The policies defined for your Classic Load Balancer.
* The policies defined for your Classic Load Balancer. Specify only back-end server policies.
*
* Specify only back-end server policies.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-policies

@@ -359,3 +310,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-scheme

@@ -365,7 +315,4 @@ */

/**
* The security groups for the load balancer.
* The security groups for the load balancer. Valid only for load balancers in a VPC.
*
* Valid only for load balancers in a VPC.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-securitygroups

@@ -379,3 +326,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-ec2-elb-subnets

@@ -387,3 +333,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html#cfn-elasticloadbalancing-loadbalancer-tags

@@ -395,6 +340,5 @@ */

*
* @param scope - scope in which this resource is defined.
* @param id - scoped id of the resource.
* @param props - resource properties.
* @external
* @param scope - scope in which this resource is defined
* @param id - scoped id of the resource
* @param props - resource properties
*/

@@ -405,15 +349,9 @@ constructor(scope: cdk.Construct, id: string, props: CfnLoadBalancerProps);

*
* @param inspector - tree inspector to collect and process attributes.
* @external
* @param inspector - tree inspector to collect and process attributes
*
*/
inspect(inspector: cdk.TreeInspector): void;
/**
* @external
*/
protected get cfnProperties(): {
[key: string]: any;
};
/**
* @external
*/
protected renderProperties(props: {

@@ -425,15 +363,2 @@ [key: string]: any;

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -443,3 +368,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html

@@ -453,3 +380,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-emitinterval

@@ -461,3 +387,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-enabled

@@ -469,3 +394,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-s3bucketname

@@ -475,7 +399,4 @@ */

/**
* The logical hierarchy you created for your Amazon S3 bucket, for example `my-bucket-prefix/prod` .
* The logical hierarchy you created for your Amazon S3 bucket, for example `my-bucket-prefix/prod` . If the prefix is not provided, the log is placed at the root level of the bucket.
*
* If the prefix is not provided, the log is placed at the root level of the bucket.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-accessloggingpolicy.html#cfn-elb-accessloggingpolicy-s3bucketprefix

@@ -486,15 +407,2 @@ */

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -506,3 +414,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-AppCookieStickinessPolicy.html

@@ -514,3 +424,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-AppCookieStickinessPolicy.html#cfn-elb-appcookiestickinesspolicy-cookiename

@@ -520,7 +429,4 @@ */

/**
* The mnemonic name for the policy being created.
* The mnemonic name for the policy being created. The name must be unique within a set of policies for this load balancer.
*
* The name must be unique within a set of policies for this load balancer.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-AppCookieStickinessPolicy.html#cfn-elb-appcookiestickinesspolicy-policyname

@@ -531,15 +437,2 @@ */

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -549,3 +442,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectiondrainingpolicy.html

@@ -557,3 +452,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectiondrainingpolicy.html#cfn-elb-connectiondrainingpolicy-enabled

@@ -565,3 +459,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectiondrainingpolicy.html#cfn-elb-connectiondrainingpolicy-timeout

@@ -572,15 +465,2 @@ */

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -590,3 +470,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectionsettings.html

@@ -598,3 +480,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-connectionsettings.html#cfn-elb-connectionsettings-idletimeout

@@ -605,15 +486,2 @@ */

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -623,3 +491,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html

@@ -631,3 +501,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-healthythreshold

@@ -639,3 +508,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-interval

@@ -645,6 +513,4 @@ */

/**
* The instance being checked.
* The instance being checked. The protocol is either TCP, HTTP, HTTPS, or SSL. The range of valid ports is one (1) through 65535.
*
* The protocol is either TCP, HTTP, HTTPS, or SSL. The range of valid ports is one (1) through 65535.
*
* TCP is the default, specified as a TCP: port pair, for example "TCP:5000". In this case, a health check simply attempts to open a TCP connection to the instance on the specified port. Failure to connect within the configured timeout is considered unhealthy.

@@ -658,3 +524,2 @@ *

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-target

@@ -668,3 +533,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-timeout

@@ -676,3 +540,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-health-check.html#cfn-elb-healthcheck-unhealthythreshold

@@ -683,15 +546,2 @@ */

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -703,3 +553,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-LBCookieStickinessPolicy.html

@@ -709,7 +561,4 @@ */

/**
* The time period, in seconds, after which the cookie should be considered stale.
* The time period, in seconds, after which the cookie should be considered stale. If this parameter is not specified, the stickiness session lasts for the duration of the browser session.
*
* If this parameter is not specified, the stickiness session lasts for the duration of the browser session.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-LBCookieStickinessPolicy.html#cfn-elb-lbcookiestickinesspolicy-cookieexpirationperiod

@@ -719,7 +568,4 @@ */

/**
* The name of the policy.
* The name of the policy. This name must be unique within the set of policies for this load balancer.
*
* This name must be unique within the set of policies for this load balancer.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-LBCookieStickinessPolicy.html#cfn-elb-lbcookiestickinesspolicy-policyname

@@ -730,15 +576,2 @@ */

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -748,3 +581,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html

@@ -756,3 +591,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-instanceport

@@ -770,3 +604,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-instanceprotocol

@@ -776,7 +609,4 @@ */

/**
* The port on which the load balancer is listening.
* The port on which the load balancer is listening. On EC2-VPC, you can specify any port from the range 1-65535. On EC2-Classic, you can specify any port from the following list: 25, 80, 443, 465, 587, 1024-65535.
*
* On EC2-VPC, you can specify any port from the range 1-65535. On EC2-Classic, you can specify any port from the following list: 25, 80, 443, 465, 587, 1024-65535.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-loadbalancerport

@@ -788,3 +618,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-policynames

@@ -796,3 +625,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-protocol

@@ -804,3 +632,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-listener.html#cfn-ec2-elb-listener-sslcertificateid

@@ -811,15 +638,2 @@ */

}
/**
* A CloudFormation `AWS::ElasticLoadBalancing::LoadBalancer`.
*
* Specifies a Classic Load Balancer.
*
* You can specify the `AvailabilityZones` or `Subnets` property, but not both.
*
* If this resource has a public IP address and is also in a VPC that is defined in the same template, you must use the [DependsOn attribute](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-dependson.html) to declare a dependency on the VPC-gateway attachment.
*
* @external
* @cloudformationResource AWS::ElasticLoadBalancing::LoadBalancer
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb.html
*/
export declare namespace CfnLoadBalancer {

@@ -831,3 +645,5 @@ /**

*
* @external
* @struct
* @stability external
*
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html

@@ -839,3 +655,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-attributes

@@ -845,7 +660,4 @@ */

/**
* The instance ports for the policy.
* The instance ports for the policy. Required only for some policy types.
*
* Required only for some policy types.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-instanceports

@@ -855,7 +667,4 @@ */

/**
* The load balancer ports for the policy.
* The load balancer ports for the policy. Required only for some policy types.
*
* Required only for some policy types.
*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-loadbalancerports

@@ -867,3 +676,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-policyname

@@ -875,3 +683,2 @@ */

*
* @external
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-elb-policy.html#cfn-ec2-elb-policy-policytype

@@ -878,0 +685,0 @@ */

@@ -6,15 +6,11 @@ import { Connections, IConnectable, ISecurityGroup, IVpc, Port, SubnetSelection } from '@aws-cdk/aws-ec2';

/**
* Construction properties for a LoadBalancer.
*
* @stability stable
* Construction properties for a LoadBalancer
*/
export interface LoadBalancerProps {
/**
* VPC network of the fleet instances.
*
* @stability stable
* VPC network of the fleet instances
*/
readonly vpc: IVpc;
/**
* Whether this is an internet-facing Load Balancer.
* Whether this is an internet-facing Load Balancer
*

@@ -25,3 +21,2 @@ * This controls whether the LB has a public IP address assigned. It does

* @default false
* @stability stable
*/

@@ -35,3 +30,2 @@ readonly internetFacing?: boolean;

* @default -
* @stability stable
*/

@@ -45,3 +39,2 @@ readonly listeners?: LoadBalancerListener[];

* @default - None.
* @stability stable
*/

@@ -55,7 +48,6 @@ readonly targets?: ILoadBalancerTarget[];

* @default - None.
* @stability stable
*/
readonly healthCheck?: HealthCheck;
/**
* Whether cross zone load balancing is enabled.
* Whether cross zone load balancing is enabled
*

@@ -66,7 +58,6 @@ * This controls whether the load balancer evenly distributes requests

* @default true
* @stability stable
*/
readonly crossZone?: boolean;
/**
* Which subnets to deploy the load balancer.
* Which subnets to deploy the load balancer
*

@@ -77,10 +68,11 @@ * Can be used to define a specific set of subnets to deploy the load balancer to.

* @default - Public subnets if internetFacing, Private subnets otherwise
* @stability stable
*/
readonly subnetSelection?: SubnetSelection;
/**
* Enable Loadbalancer access logs Can be used to avoid manual work as aws console Required S3 bucket name , enabled flag Can add interval for pushing log Can set bucket prefix in order to provide folder name inside bucket.
*
* Enable Loadbalancer access logs
* Can be used to avoid manual work as aws console
* Required S3 bucket name , enabled flag
* Can add interval for pushing log
* Can set bucket prefix in order to provide folder name inside bucket
* @default - disabled
* @stability stable
*/

@@ -90,15 +82,11 @@ readonly accessLoggingPolicy?: CfnLoadBalancer.AccessLoggingPolicyProperty;

/**
* Describe the health check to a load balancer.
*
* @stability stable
* Describe the health check to a load balancer
*/
export interface HealthCheck {
/**
* What port number to health check on.
*
* @stability stable
* What port number to health check on
*/
readonly port: number;
/**
* What protocol to use for health checking.
* What protocol to use for health checking
*

@@ -108,7 +96,6 @@ * The protocol is automatically determined from the port if it's not supplied.

* @default Automatic
* @stability stable
*/
readonly protocol?: LoadBalancingProtocol;
/**
* What path to use for HTTP or HTTPS health check (must return 200).
* What path to use for HTTP or HTTPS health check (must return 200)
*

@@ -119,31 +106,26 @@ * For SSL and TCP health checks, accepting connections is enough to be considered

* @default "/"
* @stability stable
*/
readonly path?: string;
/**
* After how many successful checks is an instance considered healthy.
* After how many successful checks is an instance considered healthy
*
* @default 2
* @stability stable
*/
readonly healthyThreshold?: number;
/**
* After how many unsuccessful checks is an instance considered unhealthy.
* After how many unsuccessful checks is an instance considered unhealthy
*
* @default 5
* @stability stable
*/
readonly unhealthyThreshold?: number;
/**
* Number of seconds between health checks.
* Number of seconds between health checks
*
* @default Duration.seconds(30)
* @stability stable
*/
readonly interval?: Duration;
/**
* Health check timeout.
* Health check timeout
*
* @default Duration.seconds(5)
* @stability stable
*/

@@ -153,12 +135,8 @@ readonly timeout?: Duration;

/**
* Interface that is going to be implemented by constructs that you can load balance to.
*
* @stability stable
* Interface that is going to be implemented by constructs that you can load balance to
*/
export interface ILoadBalancerTarget extends IConnectable {
/**
* Attach load-balanced target to a classic ELB.
*
* @param loadBalancer [disable-awslint:ref-via-interface] The load balancer to attach the target to.
* @stability stable
* Attach load-balanced target to a classic ELB
* @param loadBalancer [disable-awslint:ref-via-interface] The load balancer to attach the target to
*/

@@ -168,15 +146,11 @@ attachToClassicLB(loadBalancer: LoadBalancer): void;

/**
* Add a backend to the load balancer.
*
* @stability stable
* Add a backend to the load balancer
*/
export interface LoadBalancerListener {
/**
* External listening port.
*
* @stability stable
* External listening port
*/
readonly externalPort: number;
/**
* What public protocol to use for load balancing.
* What public protocol to use for load balancing
*

@@ -186,8 +160,6 @@ * Either 'tcp', 'ssl', 'http' or 'https'.

* May be omitted if the external port is either 80 or 443.
*
* @stability stable
*/
readonly externalProtocol?: LoadBalancingProtocol;
/**
* Instance listening port.
* Instance listening port
*

@@ -197,7 +169,6 @@ * Same as the externalPort if not specified.

* @default externalPort
* @stability stable
*/
readonly internalPort?: number;
/**
* What public protocol to use for load balancing.
* What public protocol to use for load balancing
*

@@ -211,15 +182,10 @@ * Either 'tcp', 'ssl', 'http' or 'https'.

* front-end protocol is 'https'.
*
* @stability stable
*/
readonly internalProtocol?: LoadBalancingProtocol;
/**
* SSL policy names.
*
* @stability stable
* SSL policy names
*/
readonly policyNames?: string[];
/**
* (deprecated) the ARN of the SSL certificate.
*
* the ARN of the SSL certificate
* @deprecated - use sslCertificateArn instead

@@ -229,10 +195,9 @@ */

/**
* the ARN of the SSL certificate.
* the ARN of the SSL certificate
*
* @default - none
* @stability stable
*/
readonly sslCertificateArn?: string;
/**
* Allow connections to the load balancer from the given set of connection peers.
* Allow connections to the load balancer from the given set of connection peers
*

@@ -244,45 +209,23 @@ * By default, connections will be allowed from anywhere. Set this to an empty list

* @default Anywhere
* @stability stable
*/
readonly allowConnectionsFrom?: IConnectable[];
}
/**
* @stability stable
*/
export declare enum LoadBalancingProtocol {
/**
* @stability stable
*/
TCP = "tcp",
/**
* @stability stable
*/
SSL = "ssl",
/**
* @stability stable
*/
HTTP = "http",
/**
* @stability stable
*/
HTTPS = "https"
}
/**
* A load balancer with a single listener.
* A load balancer with a single listener
*
* Routes to a fleet of of instances in a VPC.
*
* @stability stable
*/
export declare class LoadBalancer extends Resource implements IConnectable {
/**
* Control all connections from and to this load balancer.
*
* @stability stable
* Control all connections from and to this load balancer
*/
readonly connections: Connections;
/**
* An object controlling specifically the connections for each listener added to this load balancer.
*
* @stability stable
* An object controlling specifically the connections for each listener added to this load balancer
*/

@@ -295,45 +238,32 @@ readonly listenerPorts: ListenerPort[];

private readonly targets;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: LoadBalancerProps);
/**
* Add a backend to the load balancer.
* Add a backend to the load balancer
*
* @returns A ListenerPort object that controls connections to the listener port
* @stability stable
*/
addListener(listener: LoadBalancerListener): ListenerPort;
/**
* @stability stable
*/
addTarget(target: ILoadBalancerTarget): void;
/**
* @stability stable
* @attribute true
* @attribute
*/
get loadBalancerName(): string;
/**
* @stability stable
* @attribute true
* @attribute
*/
get loadBalancerCanonicalHostedZoneNameId(): string;
/**
* @stability stable
* @attribute true
* @attribute
*/
get loadBalancerCanonicalHostedZoneName(): string;
/**
* @stability stable
* @attribute true
* @attribute
*/
get loadBalancerDnsName(): string;
/**
* @stability stable
* @attribute true
* @attribute
*/
get loadBalancerSourceSecurityGroupGroupName(): string;
/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -361,21 +291,11 @@ get loadBalancerSourceSecurityGroupOwnerAlias(): string;

*
* const listener = elb.addListener(...);
* const listener = elb.addListener(...);
*
* listener.connections.allowDefaultPortFromAnyIPv4();
* // or
* instance.connections.allowToDefaultPort(listener);
*
* @stability stable
* listener.connections.allowDefaultPortFromAnyIPv4();
* // or
* instance.connections.allowToDefaultPort(listener);
*/
export declare class ListenerPort implements IConnectable {
/**
* The network connections associated with this resource.
*
* @stability stable
*/
readonly connections: Connections;
/**
* @stability stable
*/
constructor(securityGroup: ISecurityGroup, defaultPort: Port);
}

@@ -10,5 +10,2 @@ "use strict";

const elasticloadbalancing_generated_1 = require("./elasticloadbalancing.generated");
/**
* @stability stable
*/
var LoadBalancingProtocol;

@@ -22,12 +19,7 @@ (function (LoadBalancingProtocol) {

/**
* A load balancer with a single listener.
* A load balancer with a single listener
*
* Routes to a fleet of of instances in a VPC.
*
* @stability stable
*/
class LoadBalancer extends core_1.Resource {
/**
* @stability stable
*/
constructor(scope, id, props) {

@@ -37,5 +29,3 @@ var _c;

/**
* An object controlling specifically the connections for each listener added to this load balancer.
*
* @stability stable
* An object controlling specifically the connections for each listener added to this load balancer
*/

@@ -69,6 +59,5 @@ this.listenerPorts = [];

/**
* Add a backend to the load balancer.
* Add a backend to the load balancer
*
* @returns A ListenerPort object that controls connections to the listener port
* @stability stable
*/

@@ -102,5 +91,2 @@ addListener(listener) {

}
/**
* @stability stable
*/
addTarget(target) {

@@ -112,4 +98,3 @@ jsiiDeprecationWarnings._aws_cdk_aws_elasticloadbalancing_ILoadBalancerTarget(target);

/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -120,4 +105,3 @@ get loadBalancerName() {

/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -128,4 +112,3 @@ get loadBalancerCanonicalHostedZoneNameId() {

/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -136,4 +119,3 @@ get loadBalancerCanonicalHostedZoneName() {

/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -144,4 +126,3 @@ get loadBalancerDnsName() {

/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -152,4 +133,3 @@ get loadBalancerSourceSecurityGroupGroupName() {

/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -184,3 +164,3 @@ get loadBalancerSourceSecurityGroupOwnerAlias() {

_a = JSII_RTTI_SYMBOL_1;
LoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancing.LoadBalancer", version: "1.144.0" };
LoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancing.LoadBalancer", version: "1.145.0" };
/**

@@ -193,14 +173,9 @@ * Reference to a listener's port just created.

*
* const listener = elb.addListener(...);
* const listener = elb.addListener(...);
*
* listener.connections.allowDefaultPortFromAnyIPv4();
* // or
* instance.connections.allowToDefaultPort(listener);
*
* @stability stable
* listener.connections.allowDefaultPortFromAnyIPv4();
* // or
* instance.connections.allowToDefaultPort(listener);
*/
class ListenerPort {
/**
* @stability stable
*/
constructor(securityGroup, defaultPort) {

@@ -212,3 +187,3 @@ this.connections = new aws_ec2_1.Connections({ securityGroups: [securityGroup], defaultPort });

_b = JSII_RTTI_SYMBOL_1;
ListenerPort[_b] = { fqn: "@aws-cdk/aws-elasticloadbalancing.ListenerPort", version: "1.144.0" };
ListenerPort[_b] = { fqn: "@aws-cdk/aws-elasticloadbalancing.ListenerPort", version: "1.145.0" };
function wellKnownProtocol(port) {

@@ -269,2 +244,2 @@ const proto = tryWellKnownProtocol(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 {\n  Connections, IConnectable, ISecurityGroup, IVpc, Peer, Port,\n  SecurityGroup, SelectedSubnets, SubnetSelection, SubnetType,\n} from '@aws-cdk/aws-ec2';\nimport { Duration, Lazy, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnLoadBalancer } from './elasticloadbalancing.generated';\n\n                                                     \nexport interface LoadBalancerProps {\n                                                   \n  readonly vpc: IVpc;\n\n                                                                                                                                                                                                                                                           \n  readonly internetFacing?: boolean;\n\n                                                                                                                                   \n  readonly listeners?: LoadBalancerListener[];\n\n                                                                                                                        \n  readonly targets?: ILoadBalancerTarget[];\n\n                                                                                                                                         \n  readonly healthCheck?: HealthCheck;\n\n                                                                                                                                                                                                      \n  readonly crossZone?: boolean;\n\n                                                                                                                                                                                                                                                                                                                             \n  readonly subnetSelection?: SubnetSelection;\n\n                                                                                                                                                                                                                                                                                         \n  readonly accessLoggingPolicy?: CfnLoadBalancer.AccessLoggingPolicyProperty;\n\n}\n\n                                                       \nexport interface HealthCheck {\n                                                    \n  readonly port: number;\n\n                                                                                                                                                                             \n  readonly protocol?: LoadBalancingProtocol;\n\n                                                                                                                                                                                                                 \n  readonly path?: string;\n\n                                                                                                        \n  readonly healthyThreshold?: number;\n\n                                                                                                            \n  readonly unhealthyThreshold?: number;\n\n                                                                                                \n  readonly interval?: Duration;\n\n                                                                            \n  readonly timeout?: Duration;\n}\n\n                                                                                               \nexport interface ILoadBalancerTarget extends IConnectable {\n                                                                                                                                                                    \n  attachToClassicLB(loadBalancer: LoadBalancer): void;\n}\n\n                                             \nexport interface LoadBalancerListener {\n                                        \n  readonly externalPort: number;\n\n                                                                                                                                                                                    \n  readonly externalProtocol?: LoadBalancingProtocol;\n\n                                                                                                                             \n  readonly internalPort?: number;\n\n                                                                                                                                                                                                                                                                                                                                                          \n  readonly internalProtocol?: LoadBalancingProtocol;\n\n                                 \n  readonly policyNames?: string[];\n\n                                                                                                \n  readonly sslCertificateId?: string;\n\n                                                                         \n  readonly sslCertificateArn?: string;\n\n                                                                                                                                                                                                                                                                                                                                               \n  readonly allowConnectionsFrom?: IConnectable[];\n}\n\nexport enum LoadBalancingProtocol {\n  TCP = 'tcp',\n  SSL = 'ssl',\n  HTTP = 'http',\n  HTTPS = 'https'\n}\n\n                                                                                                   \nexport class LoadBalancer extends Resource implements IConnectable {\n                                                                       \n  public readonly connections: Connections;\n\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(scope: Construct, id: string, props: LoadBalancerProps) {\n    super(scope, id);\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 selectedSubnets: SelectedSubnets = loadBalancerSubnets(props);\n\n    this.elb = new CfnLoadBalancer(this, 'Resource', {\n      securityGroups: [this.securityGroup.securityGroupId],\n      subnets: selectedSubnets.subnetIds,\n      listeners: Lazy.any({ produce: () => this.listeners }),\n      scheme: props.internetFacing ? 'internet-facing' : 'internal',\n      healthCheck: props.healthCheck && healthCheckToJSON(props.healthCheck),\n      crossZone: props.crossZone ?? true,\n    });\n    if (props.internetFacing) {\n      this.elb.node.addDependency(selectedSubnets.internetConnectivityEstablished);\n    }\n\n    if (props.accessLoggingPolicy !== undefined) {\n      this.elb.accessLoggingPolicy = props.accessLoggingPolicy;\n    }\n\n    ifUndefined(props.listeners, []).forEach(b => this.addListener(b));\n    ifUndefined(props.targets, []).forEach(t => this.addTarget(t));\n  }\n\n                                                                                                                                           \n  public addListener(listener: LoadBalancerListener): ListenerPort {\n    if (listener.sslCertificateArn && listener.sslCertificateId) {\n      throw new Error('\"sslCertificateId\" is deprecated, please use \"sslCertificateArn\" only.');\n    }\n    const protocol = ifUndefinedLazy(listener.externalProtocol, () => wellKnownProtocol(listener.externalPort));\n    const instancePort = listener.internalPort || listener.externalPort;\n    const sslCertificateArn = listener.sslCertificateArn || listener.sslCertificateId;\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: sslCertificateArn,\n      policyNames: listener.policyNames,\n    });\n\n    const port = new ListenerPort(this.securityGroup, Port.tcp(listener.externalPort));\n\n    // Allow connections on the public port for all supplied peers (default: everyone)\n    ifUndefined(listener.allowConnectionsFrom, [Peer.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                           \n  public get loadBalancerName() {\n    return this.elb.ref;\n  }\n\n                           \n  public get loadBalancerCanonicalHostedZoneNameId() {\n    return this.elb.attrCanonicalHostedZoneNameId;\n  }\n\n                           \n  public get loadBalancerCanonicalHostedZoneName() {\n    return this.elb.attrCanonicalHostedZoneName;\n  }\n\n                           \n  public get loadBalancerDnsName() {\n    return this.elb.attrDnsName;\n  }\n\n                           \n  public get loadBalancerSourceSecurityGroupGroupName() {\n    return this.elb.attrSourceSecurityGroupGroupName;\n  }\n\n                           \n  public get loadBalancerSourceSecurityGroupOwnerAlias() {\n    return this.elb.attrSourceSecurityGroupOwnerAlias;\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      Port.tcp(instancePort),\n      `Port ${instancePort} LB to fleet`);\n  }\n}\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                         \nexport class ListenerPort implements IConnectable {\n  public readonly connections: Connections;\n\n  constructor(securityGroup: ISecurityGroup, defaultPort: Port) {\n    this.connections = new Connections({ securityGroups: [securityGroup], defaultPort });\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: (healthCheck.interval || Duration.seconds(30)).toSeconds().toString(),\n    target,\n    timeout: (healthCheck.timeout || Duration.seconds(5)).toSeconds().toString(),\n    unhealthyThreshold: ifUndefined(healthCheck.unhealthyThreshold, 5).toString(),\n  };\n}\n\nfunction loadBalancerSubnets(props: LoadBalancerProps): SelectedSubnets {\n  if (props.subnetSelection !== undefined) {\n    return props.vpc.selectSubnets(props.subnetSelection);\n  } else if (props.internetFacing) {\n    return props.vpc.selectSubnets({\n      subnetType: SubnetType.PUBLIC,\n    });\n  } else {\n    return props.vpc.selectSubnets({\n      subnetType: SubnetType.PRIVATE,\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 {\n  Connections, IConnectable, ISecurityGroup, IVpc, Peer, Port,\n  SecurityGroup, SelectedSubnets, SubnetSelection, SubnetType,\n} from '@aws-cdk/aws-ec2';\nimport { Duration, Lazy, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\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  readonly vpc: IVpc;\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  readonly internetFacing?: boolean;\n\n  /**\n   * What listeners to set up for the load balancer.\n   *\n   * Can also be added by .addListener()\n   *\n   * @default -\n   */\n  readonly listeners?: LoadBalancerListener[];\n\n  /**\n   * What targets to load balance to.\n   *\n   * Can also be added by .addTarget()\n   *\n   * @default - None.\n   */\n  readonly targets?: ILoadBalancerTarget[];\n\n  /**\n   * Health check settings for the load balancing targets.\n   *\n   * Not required but recommended.\n   *\n   * @default - None.\n   */\n  readonly healthCheck?: HealthCheck;\n\n  /**\n   * Whether cross zone load balancing is enabled\n   *\n   * This controls whether the load balancer evenly distributes requests\n   * across each availability zone\n   *\n   * @default true\n   */\n  readonly crossZone?: boolean;\n\n  /**\n   * Which subnets to deploy the load balancer\n   *\n   * Can be used to define a specific set of subnets to deploy the load balancer to.\n   * Useful multiple public or private subnets are covering the same availability zone.\n   *\n   * @default - Public subnets if internetFacing, Private subnets otherwise\n   */\n  readonly subnetSelection?: SubnetSelection;\n\n  /**\n   * Enable Loadbalancer access logs\n   * Can be used to avoid manual work as aws console\n   * Required S3 bucket name , enabled flag\n   * Can add interval for pushing log\n   * Can set bucket prefix in order to provide folder name inside bucket\n   * @default - disabled\n   */\n  readonly accessLoggingPolicy?: CfnLoadBalancer.AccessLoggingPolicyProperty;\n\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  readonly 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  readonly 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  readonly path?: string;\n\n  /**\n   * After how many successful checks is an instance considered healthy\n   *\n   * @default 2\n   */\n  readonly healthyThreshold?: number;\n\n  /**\n   * After how many unsuccessful checks is an instance considered unhealthy\n   *\n   * @default 5\n   */\n  readonly unhealthyThreshold?: number;\n\n  /**\n   * Number of seconds between health checks\n   *\n   * @default Duration.seconds(30)\n   */\n  readonly interval?: Duration;\n\n  /**\n   * Health check timeout\n   *\n   * @default Duration.seconds(5)\n   */\n  readonly timeout?: Duration;\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   * @param loadBalancer [disable-awslint:ref-via-interface] The load balancer to attach the target to\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  readonly 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  readonly externalProtocol?: LoadBalancingProtocol;\n\n  /**\n   * Instance listening port\n   *\n   * Same as the externalPort if not specified.\n   *\n   * @default externalPort\n   */\n  readonly 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  readonly internalProtocol?: LoadBalancingProtocol;\n\n  /**\n   * SSL policy names\n   */\n  readonly policyNames?: string[];\n\n  /**\n   * the ARN of the SSL certificate\n   * @deprecated - use sslCertificateArn instead\n   */\n  readonly sslCertificateId?: string;\n\n  /**\n   * the ARN of the SSL certificate\n   *\n   * @default - none\n   */\n  readonly sslCertificateArn?: 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  readonly 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 Resource 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: 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(scope: Construct, id: string, props: LoadBalancerProps) {\n    super(scope, id);\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 selectedSubnets: SelectedSubnets = loadBalancerSubnets(props);\n\n    this.elb = new CfnLoadBalancer(this, 'Resource', {\n      securityGroups: [this.securityGroup.securityGroupId],\n      subnets: selectedSubnets.subnetIds,\n      listeners: Lazy.any({ produce: () => this.listeners }),\n      scheme: props.internetFacing ? 'internet-facing' : 'internal',\n      healthCheck: props.healthCheck && healthCheckToJSON(props.healthCheck),\n      crossZone: props.crossZone ?? true,\n    });\n    if (props.internetFacing) {\n      this.elb.node.addDependency(selectedSubnets.internetConnectivityEstablished);\n    }\n\n    if (props.accessLoggingPolicy !== undefined) {\n      this.elb.accessLoggingPolicy = props.accessLoggingPolicy;\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    if (listener.sslCertificateArn && listener.sslCertificateId) {\n      throw new Error('\"sslCertificateId\" is deprecated, please use \"sslCertificateArn\" only.');\n    }\n    const protocol = ifUndefinedLazy(listener.externalProtocol, () => wellKnownProtocol(listener.externalPort));\n    const instancePort = listener.internalPort || listener.externalPort;\n    const sslCertificateArn = listener.sslCertificateArn || listener.sslCertificateId;\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: sslCertificateArn,\n      policyNames: listener.policyNames,\n    });\n\n    const port = new ListenerPort(this.securityGroup, Port.tcp(listener.externalPort));\n\n    // Allow connections on the public port for all supplied peers (default: everyone)\n    ifUndefined(listener.allowConnectionsFrom, [Peer.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  /**\n   * @attribute\n   */\n  public get loadBalancerName() {\n    return this.elb.ref;\n  }\n\n  /**\n   * @attribute\n   */\n  public get loadBalancerCanonicalHostedZoneNameId() {\n    return this.elb.attrCanonicalHostedZoneNameId;\n  }\n\n  /**\n   * @attribute\n   */\n  public get loadBalancerCanonicalHostedZoneName() {\n    return this.elb.attrCanonicalHostedZoneName;\n  }\n\n  /**\n   * @attribute\n   */\n  public get loadBalancerDnsName() {\n    return this.elb.attrDnsName;\n  }\n\n  /**\n   * @attribute\n   */\n  public get loadBalancerSourceSecurityGroupGroupName() {\n    return this.elb.attrSourceSecurityGroupGroupName;\n  }\n\n  /**\n   * @attribute\n   */\n  public get loadBalancerSourceSecurityGroupOwnerAlias() {\n    return this.elb.attrSourceSecurityGroupOwnerAlias;\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      Port.tcp(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: ISecurityGroup, defaultPort: Port) {\n    this.connections = new Connections({ securityGroups: [securityGroup], defaultPort });\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: (healthCheck.interval || Duration.seconds(30)).toSeconds().toString(),\n    target,\n    timeout: (healthCheck.timeout || Duration.seconds(5)).toSeconds().toString(),\n    unhealthyThreshold: ifUndefined(healthCheck.unhealthyThreshold, 5).toString(),\n  };\n}\n\nfunction loadBalancerSubnets(props: LoadBalancerProps): SelectedSubnets {\n  if (props.subnetSelection !== undefined) {\n    return props.vpc.selectSubnets(props.subnetSelection);\n  } else if (props.internetFacing) {\n    return props.vpc.selectSubnets({\n      subnetType: SubnetType.PUBLIC,\n    });\n  } else {\n    return props.vpc.selectSubnets({\n      subnetType: SubnetType.PRIVATE,\n    });\n  }\n}"]}
{
"name": "@aws-cdk/aws-elasticloadbalancing",
"version": "1.144.0",
"version": "1.145.0",
"description": "The CDK Construct Library for AWS::ElasticLoadBalancing",

@@ -82,12 +82,12 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assertions": "1.144.0",
"@aws-cdk/cdk-build-tools": "1.144.0",
"@aws-cdk/cdk-integ-tools": "1.144.0",
"@aws-cdk/cfn2ts": "1.144.0",
"@aws-cdk/pkglint": "1.144.0",
"@aws-cdk/assertions": "1.145.0",
"@aws-cdk/cdk-build-tools": "1.145.0",
"@aws-cdk/cdk-integ-tools": "1.145.0",
"@aws-cdk/cfn2ts": "1.145.0",
"@aws-cdk/pkglint": "1.145.0",
"@types/jest": "^27.4.0"
},
"dependencies": {
"@aws-cdk/aws-ec2": "1.144.0",
"@aws-cdk/core": "1.144.0",
"@aws-cdk/aws-ec2": "1.145.0",
"@aws-cdk/core": "1.145.0",
"constructs": "^3.3.69"

@@ -97,4 +97,4 @@ },

"peerDependencies": {
"@aws-cdk/aws-ec2": "1.144.0",
"@aws-cdk/core": "1.144.0",
"@aws-cdk/aws-ec2": "1.145.0",
"@aws-cdk/core": "1.145.0",
"constructs": "^3.3.69"

@@ -101,0 +101,0 @@ },

Sorry, the diff of this file is not supported yet

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

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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc