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

@aws-cdk/aws-elasticloadbalancingv2

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

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

Comparing version 1.144.0 to 1.145.0

26

.warnings.jsii.js

@@ -157,6 +157,6 @@ function _aws_cdk_aws_elasticloadbalancingv2_ContentType(p) {

}
function _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerLookupOptions(p) {
}
function _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerProps(p) {
}
function _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerLookupOptions(p) {
}
function _aws_cdk_aws_elasticloadbalancingv2_TargetGroupImportProps(p) {

@@ -186,16 +186,16 @@ if (p == null)

}
function _aws_cdk_aws_elasticloadbalancingv2_NetworkWeightedTargetGroup(p) {
function _aws_cdk_aws_elasticloadbalancingv2_LoadBalancerTargetProps(p) {
if (p == null)
return;
visitedObjects.add(p);
if (!visitedObjects.has(p.targetGroup))
_aws_cdk_aws_elasticloadbalancingv2_INetworkTargetGroup(p.targetGroup);
if (!visitedObjects.has(p.targetType))
_aws_cdk_aws_elasticloadbalancingv2_TargetType(p.targetType);
visitedObjects.delete(p);
}
function _aws_cdk_aws_elasticloadbalancingv2_LoadBalancerTargetProps(p) {
function _aws_cdk_aws_elasticloadbalancingv2_NetworkWeightedTargetGroup(p) {
if (p == null)
return;
visitedObjects.add(p);
if (!visitedObjects.has(p.targetType))
_aws_cdk_aws_elasticloadbalancingv2_TargetType(p.targetType);
if (!visitedObjects.has(p.targetGroup))
_aws_cdk_aws_elasticloadbalancingv2_INetworkTargetGroup(p.targetGroup);
visitedObjects.delete(p);

@@ -527,6 +527,2 @@ }

}
function _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateCognitoConfigProperty(p) {
}
function _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateOidcConfigProperty(p) {
}
function _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule(p) {

@@ -552,2 +548,6 @@ }

}
function _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateCognitoConfigProperty(p) {
}
function _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateOidcConfigProperty(p) {
}
function _aws_cdk_aws_elasticloadbalancingv2_CfnListener_TargetGroupStickinessConfigProperty(p) {

@@ -698,3 +698,3 @@ }

}
module.exports = { print, _aws_cdk_aws_elasticloadbalancingv2_ContentType, _aws_cdk_aws_elasticloadbalancingv2_HttpCodeElb, _aws_cdk_aws_elasticloadbalancingv2_HttpCodeTarget, _aws_cdk_aws_elasticloadbalancingv2_UnauthenticatedAction, _aws_cdk_aws_elasticloadbalancingv2_IpAddressType, _aws_cdk_aws_elasticloadbalancingv2_Protocol, _aws_cdk_aws_elasticloadbalancingv2_ApplicationProtocol, _aws_cdk_aws_elasticloadbalancingv2_ApplicationProtocolVersion, _aws_cdk_aws_elasticloadbalancingv2_SslPolicy, _aws_cdk_aws_elasticloadbalancingv2_TargetType, _aws_cdk_aws_elasticloadbalancingv2_AlpnPolicy, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupLoadBalancingAlgorithmType, _aws_cdk_aws_elasticloadbalancingv2_IListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_QueryStringCondition, _aws_cdk_aws_elasticloadbalancingv2_FixedResponseOptions, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupAttributes, _aws_cdk_aws_elasticloadbalancingv2_BaseLoadBalancerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_BaseListenerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_RedirectResponse, _aws_cdk_aws_elasticloadbalancingv2_RedirectOptions, _aws_cdk_aws_elasticloadbalancingv2_INetworkListener, _aws_cdk_aws_elasticloadbalancingv2_ILoadBalancerV2, _aws_cdk_aws_elasticloadbalancingv2_ForwardOptions, _aws_cdk_aws_elasticloadbalancingv2_NetworkForwardOptions, _aws_cdk_aws_elasticloadbalancingv2_IListenerAction, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerAttributes, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerAttributes, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerAttributes, _aws_cdk_aws_elasticloadbalancingv2_AddFixedResponseProps, _aws_cdk_aws_elasticloadbalancingv2_AddRedirectResponseProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_INetworkListenerCertificateProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupImportProps, _aws_cdk_aws_elasticloadbalancingv2_WeightedTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_AddNetworkActionProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkWeightedTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_LoadBalancerTargetProps, _aws_cdk_aws_elasticloadbalancingv2_AddRuleProps, _aws_cdk_aws_elasticloadbalancingv2_BaseListener, _aws_cdk_aws_elasticloadbalancingv2_ITargetGroup, _aws_cdk_aws_elasticloadbalancingv2_BaseLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerProps, _aws_cdk_aws_elasticloadbalancingv2_AddApplicationTargetGroupsProps, _aws_cdk_aws_elasticloadbalancingv2_AddApplicationActionProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerRuleProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkListenerProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerCertificateProps, _aws_cdk_aws_elasticloadbalancingv2_IApplicationLoadBalancerTarget, _aws_cdk_aws_elasticloadbalancingv2_INetworkLoadBalancerTarget, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerCertificateProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_INetworkTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_IApplicationTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_INetworkLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_ListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerRedirectConfig, _aws_cdk_aws_elasticloadbalancingv2_BaseLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_InstanceTarget, _aws_cdk_aws_elasticloadbalancingv2_IpTarget, _aws_cdk_aws_elasticloadbalancingv2_BaseApplicationListenerRuleProps, _aws_cdk_aws_elasticloadbalancingv2_FixedResponse, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerProps, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRuleProps, _aws_cdk_aws_elasticloadbalancingv2_IApplicationListener, _aws_cdk_aws_elasticloadbalancingv2_AuthenticateOidcOptions, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_BaseTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_IApplicationLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerCertificate_CertificateProperty, _aws_cdk_aws_elasticloadbalancingv2_NetworkListenerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_ListenerCondition, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerRule, _aws_cdk_aws_elasticloadbalancingv2_HealthCheck, _aws_cdk_aws_elasticloadbalancingv2_NetworkTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_AddNetworkTargetsProps, _aws_cdk_aws_elasticloadbalancingv2_CfnListener, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_CertificateProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_TargetGroupTupleProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_FixedResponseConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_RedirectConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateCognitoConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateOidcConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_HostHeaderConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_HttpRequestMethodConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_PathPatternConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_SourceIpConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_QueryStringKeyValueProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_TargetGroupTupleProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_FixedResponseConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_HttpHeaderConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_RedirectConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_TargetGroupStickinessConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancer_LoadBalancerAttributeProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancer_SubnetMappingProperty, _aws_cdk_aws_elasticloadbalancingv2_ApplicationTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_AuthenticateCognitoConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_TargetGroupStickinessConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_NetworkListenerAction, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_AuthenticateOidcConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupBase, _aws_cdk_aws_elasticloadbalancingv2_AddApplicationTargetsProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkListener, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_QueryStringConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup_MatcherProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup_TargetGroupAttributeProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup_TargetDescriptionProperty, _aws_cdk_aws_elasticloadbalancingv2_NetworkTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_ForwardConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_ForwardConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_BaseApplicationListenerProps, _aws_cdk_aws_elasticloadbalancingv2_ListenerAction, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListener, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_ActionProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_ActionProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_RuleConditionProperty, _aws_cdk_aws_elasticloadbalancingv2_BaseNetworkListenerProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_ApplicationTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancer };
module.exports = { print, _aws_cdk_aws_elasticloadbalancingv2_ContentType, _aws_cdk_aws_elasticloadbalancingv2_HttpCodeElb, _aws_cdk_aws_elasticloadbalancingv2_HttpCodeTarget, _aws_cdk_aws_elasticloadbalancingv2_UnauthenticatedAction, _aws_cdk_aws_elasticloadbalancingv2_IpAddressType, _aws_cdk_aws_elasticloadbalancingv2_Protocol, _aws_cdk_aws_elasticloadbalancingv2_ApplicationProtocol, _aws_cdk_aws_elasticloadbalancingv2_ApplicationProtocolVersion, _aws_cdk_aws_elasticloadbalancingv2_SslPolicy, _aws_cdk_aws_elasticloadbalancingv2_TargetType, _aws_cdk_aws_elasticloadbalancingv2_AlpnPolicy, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupLoadBalancingAlgorithmType, _aws_cdk_aws_elasticloadbalancingv2_IListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_QueryStringCondition, _aws_cdk_aws_elasticloadbalancingv2_FixedResponseOptions, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupAttributes, _aws_cdk_aws_elasticloadbalancingv2_BaseLoadBalancerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_BaseListenerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_RedirectResponse, _aws_cdk_aws_elasticloadbalancingv2_RedirectOptions, _aws_cdk_aws_elasticloadbalancingv2_INetworkListener, _aws_cdk_aws_elasticloadbalancingv2_ILoadBalancerV2, _aws_cdk_aws_elasticloadbalancingv2_ForwardOptions, _aws_cdk_aws_elasticloadbalancingv2_NetworkForwardOptions, _aws_cdk_aws_elasticloadbalancingv2_IListenerAction, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerAttributes, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerAttributes, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerAttributes, _aws_cdk_aws_elasticloadbalancingv2_AddFixedResponseProps, _aws_cdk_aws_elasticloadbalancingv2_AddRedirectResponseProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_INetworkListenerCertificateProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupImportProps, _aws_cdk_aws_elasticloadbalancingv2_WeightedTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_AddNetworkActionProps, _aws_cdk_aws_elasticloadbalancingv2_LoadBalancerTargetProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkWeightedTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_AddRuleProps, _aws_cdk_aws_elasticloadbalancingv2_BaseListener, _aws_cdk_aws_elasticloadbalancingv2_ITargetGroup, _aws_cdk_aws_elasticloadbalancingv2_BaseLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerProps, _aws_cdk_aws_elasticloadbalancingv2_AddApplicationTargetGroupsProps, _aws_cdk_aws_elasticloadbalancingv2_AddApplicationActionProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerRuleProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkListenerProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerCertificateProps, _aws_cdk_aws_elasticloadbalancingv2_IApplicationLoadBalancerTarget, _aws_cdk_aws_elasticloadbalancingv2_INetworkLoadBalancerTarget, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerCertificateProps, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_INetworkTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_IApplicationTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_INetworkLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_ListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerRedirectConfig, _aws_cdk_aws_elasticloadbalancingv2_BaseLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_InstanceTarget, _aws_cdk_aws_elasticloadbalancingv2_IpTarget, _aws_cdk_aws_elasticloadbalancingv2_BaseApplicationListenerRuleProps, _aws_cdk_aws_elasticloadbalancingv2_FixedResponse, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerProps, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRuleProps, _aws_cdk_aws_elasticloadbalancingv2_IApplicationListener, _aws_cdk_aws_elasticloadbalancingv2_AuthenticateOidcOptions, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancerProps, _aws_cdk_aws_elasticloadbalancingv2_BaseTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_IApplicationLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerCertificate, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerCertificate_CertificateProperty, _aws_cdk_aws_elasticloadbalancingv2_NetworkListenerLookupOptions, _aws_cdk_aws_elasticloadbalancingv2_ListenerCondition, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListenerRule, _aws_cdk_aws_elasticloadbalancingv2_HealthCheck, _aws_cdk_aws_elasticloadbalancingv2_NetworkTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_AddNetworkTargetsProps, _aws_cdk_aws_elasticloadbalancingv2_CfnListener, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_CertificateProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_TargetGroupTupleProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_FixedResponseConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_RedirectConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_HostHeaderConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_HttpRequestMethodConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_PathPatternConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_SourceIpConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_QueryStringKeyValueProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_TargetGroupTupleProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_FixedResponseConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_HttpHeaderConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_RedirectConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateCognitoConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_AuthenticateOidcConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_TargetGroupStickinessConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancer_LoadBalancerAttributeProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnLoadBalancer_SubnetMappingProperty, _aws_cdk_aws_elasticloadbalancingv2_ApplicationTargetGroupProps, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_AuthenticateCognitoConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_TargetGroupStickinessConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_NetworkListenerAction, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_AuthenticateOidcConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_TargetGroupBase, _aws_cdk_aws_elasticloadbalancingv2_AddApplicationTargetsProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkListener, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_QueryStringConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup_MatcherProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup_TargetGroupAttributeProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnTargetGroup_TargetDescriptionProperty, _aws_cdk_aws_elasticloadbalancingv2_NetworkTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_ForwardConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_ForwardConfigProperty, _aws_cdk_aws_elasticloadbalancingv2_BaseApplicationListenerProps, _aws_cdk_aws_elasticloadbalancingv2_ListenerAction, _aws_cdk_aws_elasticloadbalancingv2_ApplicationListener, _aws_cdk_aws_elasticloadbalancingv2_CfnListener_ActionProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_ActionProperty, _aws_cdk_aws_elasticloadbalancingv2_CfnListenerRule_RuleConditionProperty, _aws_cdk_aws_elasticloadbalancingv2_BaseNetworkListenerProps, _aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancer, _aws_cdk_aws_elasticloadbalancingv2_ApplicationTargetGroup, _aws_cdk_aws_elasticloadbalancingv2_ApplicationLoadBalancer };
module.exports.DeprecationError = DeprecationError;

@@ -8,3 +8,3 @@ import { Duration, IConstruct, SecretValue } from '@aws-cdk/core';

/**
* What to do when a client makes a request to a listener.
* What to do when a client makes a request to a listener
*

@@ -23,4 +23,2 @@ * Some actions can be combined with other ones (specifically,

* with, and we want to make it not too visually overwhelming).
*
* @stability stable
*/

@@ -31,31 +29,27 @@ export declare class ListenerAction implements IListenerAction {

/**
* Authenticate using an identity provider (IdP) that is compliant with OpenID Connect (OIDC).
* Authenticate using an identity provider (IdP) that is compliant with OpenID Connect (OIDC)
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/listener-authenticate-users.html#oidc-requirements
* @stability stable
*/
static authenticateOidc(options: AuthenticateOidcOptions): ListenerAction;
/**
* Forward to one or more Target Groups.
* Forward to one or more Target Groups
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#forward-actions
* @stability stable
*/
static forward(targetGroups: IApplicationTargetGroup[], options?: ForwardOptions): ListenerAction;
/**
* Forward to one or more Target Groups which are weighted differently.
* Forward to one or more Target Groups which are weighted differently
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#forward-actions
* @stability stable
*/
static weightedForward(targetGroups: WeightedTargetGroup[], options?: ForwardOptions): ListenerAction;
/**
* Return a fixed response.
* Return a fixed response
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#fixed-response-actions
* @stability stable
*/
static fixedResponse(statusCode: number, options?: FixedResponseOptions): ListenerAction;
/**
* Redirect to a different URI.
* Redirect to a different URI
*

@@ -79,7 +73,6 @@ * A URI consists of the following components:

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#redirect-actions
* @stability stable
*/
static redirect(options: RedirectOptions): ListenerAction;
/**
* Create an instance of ListenerAction.
* Create an instance of ListenerAction
*

@@ -89,16 +82,10 @@ * The default class should be good enough for most cases and

* but allow overriding to make sure we allow flexibility for the future.
*
* @stability stable
*/
protected constructor(actionJson: CfnListener.ActionProperty, next?: ListenerAction | undefined);
/**
* Render the actions in this chain.
*
* @stability stable
* Render the actions in this chain
*/
renderActions(): CfnListener.ActionProperty[];
/**
* Called when the action is being used in a listener.
*
* @stability stable
* Called when the action is being used in a listener
*/

@@ -114,4 +101,2 @@ bind(scope: Construct, listener: IApplicationListener, associatingConstruct?: IConstruct): void;

* users the opportunity to override by subclassing and overriding `renderActions`.
*
* @stability stable
*/

@@ -121,9 +106,7 @@ protected renumber(actions: CfnListener.ActionProperty[]): CfnListener.ActionProperty[];

/**
* Options for `ListenerAction.forward()`.
*
* @stability stable
* Options for `ListenerAction.forward()`
*/
export interface ForwardOptions {
/**
* For how long clients should be directed to the same target group.
* For how long clients should be directed to the same target group
*

@@ -133,3 +116,2 @@ * Range between 1 second and 7 days.

* @default - No stickiness
* @stability stable
*/

@@ -139,15 +121,11 @@ readonly stickinessDuration?: Duration;

/**
* A Target Group and weight combination.
*
* @stability stable
* A Target Group and weight combination
*/
export interface WeightedTargetGroup {
/**
* The target group.
*
* @stability stable
* The target group
*/
readonly targetGroup: IApplicationTargetGroup;
/**
* The target group's weight.
* The target group's weight
*

@@ -157,3 +135,2 @@ * Range is [0..1000).

* @default 1
* @stability stable
*/

@@ -163,9 +140,7 @@ readonly weight?: number;

/**
* Options for `ListenerAction.fixedResponse()`.
*
* @stability stable
* Options for `ListenerAction.fixedResponse()`
*/
export interface FixedResponseOptions {
/**
* Content Type of the response.
* Content Type of the response
*

@@ -175,10 +150,8 @@ * Valid Values: text/plain | text/css | text/html | application/javascript | application/json

* @default - Automatically determined
* @stability stable
*/
readonly contentType?: string;
/**
* The response body.
* The response body
*
* @default - No body
* @stability stable
*/

@@ -188,3 +161,3 @@ readonly messageBody?: string;

/**
* Options for `ListenerAction.redirect()`.
* Options for `ListenerAction.redirect()`
*

@@ -206,4 +179,2 @@ * A URI consists of the following components:

* "example.#{host}", or the query to "#{query}&value=xyz".
*
* @stability stable
*/

@@ -217,3 +188,2 @@ export interface RedirectOptions {

* @default - No change
* @stability stable
*/

@@ -227,3 +197,2 @@ readonly host?: string;

* @default - No change
* @stability stable
*/

@@ -237,3 +206,2 @@ readonly path?: string;

* @default - No change
* @stability stable
*/

@@ -247,3 +215,2 @@ readonly port?: string;

* @default - No change
* @stability stable
*/

@@ -257,3 +224,2 @@ readonly protocol?: string;

* @default - No change
* @stability stable
*/

@@ -267,3 +233,2 @@ readonly query?: string;

* @default false
* @stability stable
*/

@@ -273,11 +238,7 @@ readonly permanent?: boolean;

/**
* Options for `ListenerAction.authenciateOidc()`.
*
* @stability stable
* Options for `ListenerAction.authenciateOidc()`
*/
export interface AuthenticateOidcOptions {
/**
* What action to execute next.
*
* @stability stable
* What action to execute next
*/

@@ -289,3 +250,2 @@ readonly next: ListenerAction;

* @default - No extra parameters
* @stability stable
*/

@@ -297,4 +257,2 @@ readonly authenticationRequestExtraParams?: Record<string, string>;

* This must be a full URL, including the HTTPS protocol, the domain, and the path.
*
* @stability stable
*/

@@ -304,4 +262,2 @@ readonly authorizationEndpoint: string;

* The OAuth 2.0 client identifier.
*
* @stability stable
*/

@@ -311,4 +267,2 @@ readonly clientId: string;

* The OAuth 2.0 client secret.
*
* @stability stable
*/

@@ -320,4 +274,2 @@ readonly clientSecret: SecretValue;

* This must be a full URL, including the HTTPS protocol, the domain, and the path.
*
* @stability stable
*/

@@ -329,3 +281,2 @@ readonly issuer: string;

* @default UnauthenticatedAction.AUTHENTICATE
* @stability stable
*/

@@ -339,3 +290,2 @@ readonly onUnauthenticatedRequest?: UnauthenticatedAction;

* @default "openid"
* @stability stable
*/

@@ -347,3 +297,2 @@ readonly scope?: string;

* @default "AWSELBAuthSessionCookie"
* @stability stable
*/

@@ -355,3 +304,2 @@ readonly sessionCookieName?: string;

* @default Duration.days(7)
* @stability stable
*/

@@ -363,4 +311,2 @@ readonly sessionTimeout?: Duration;

* This must be a full URL, including the HTTPS protocol, the domain, and the path.
*
* @stability stable
*/

@@ -372,4 +318,2 @@ readonly tokenEndpoint: string;

* This must be a full URL, including the HTTPS protocol, the domain, and the path.
*
* @stability stable
*/

@@ -379,5 +323,3 @@ readonly userInfoEndpoint: string;

/**
* What to do with unauthenticated requests.
*
* @stability stable
* What to do with unauthenticated requests
*/

@@ -387,4 +329,2 @@ export declare enum UnauthenticatedAction {

* Return an HTTP 401 Unauthorized error.
*
* @stability stable
*/

@@ -394,4 +334,2 @@ DENY = "deny",

* Allow the request to be forwarded to the target.
*
* @stability stable
*/

@@ -401,6 +339,4 @@ ALLOW = "allow",

* Redirect the request to the IdP authorization endpoint.
*
* @stability stable
*/
AUTHENTICATE = "authenticate"
}

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

/**
* What to do when a client makes a request to a listener.
* What to do when a client makes a request to a listener
*

@@ -24,8 +24,6 @@ * Some actions can be combined with other ones (specifically,

* with, and we want to make it not too visually overwhelming).
*
* @stability stable
*/
class ListenerAction {
/**
* Create an instance of ListenerAction.
* Create an instance of ListenerAction
*

@@ -35,4 +33,2 @@ * The default class should be good enough for most cases and

* but allow overriding to make sure we allow flexibility for the future.
*
* @stability stable
*/

@@ -46,6 +42,5 @@ constructor(actionJson, next) {

/**
* Authenticate using an identity provider (IdP) that is compliant with OpenID Connect (OIDC).
* Authenticate using an identity provider (IdP) that is compliant with OpenID Connect (OIDC)
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/listener-authenticate-users.html#oidc-requirements
* @stability stable
*/

@@ -73,6 +68,5 @@ static authenticateOidc(options) {

/**
* Forward to one or more Target Groups.
* Forward to one or more Target Groups
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#forward-actions
* @stability stable
*/

@@ -103,6 +97,5 @@ static forward(targetGroups, options = {}) {

/**
* Forward to one or more Target Groups which are weighted differently.
* Forward to one or more Target Groups which are weighted differently
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#forward-actions
* @stability stable
*/

@@ -126,6 +119,5 @@ static weightedForward(targetGroups, options = {}) {

/**
* Return a fixed response.
* Return a fixed response
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#fixed-response-actions
* @stability stable
*/

@@ -144,3 +136,3 @@ static fixedResponse(statusCode, options = {}) {

/**
* Redirect to a different URI.
* Redirect to a different URI
*

@@ -164,3 +156,2 @@ * A URI consists of the following components:

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#redirect-actions
* @stability stable
*/

@@ -185,5 +176,3 @@ static redirect(options) {

/**
* Render the actions in this chain.
*
* @stability stable
* Render the actions in this chain
*/

@@ -195,5 +184,3 @@ renderActions() {

/**
* Called when the action is being used in a listener.
*
* @stability stable
* Called when the action is being used in a listener
*/

@@ -215,4 +202,2 @@ bind(scope, listener, associatingConstruct) {

* users the opportunity to override by subclassing and overriding `renderActions`.
*
* @stability stable
*/

@@ -228,12 +213,19 @@ renumber(actions) {

_a = JSII_RTTI_SYMBOL_1;
ListenerAction[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ListenerAction", version: "1.144.0" };
ListenerAction[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ListenerAction", version: "1.145.0" };
/**
* What to do with unauthenticated requests.
*
* @stability stable
* What to do with unauthenticated requests
*/
var UnauthenticatedAction;
(function (UnauthenticatedAction) {
/**
* Return an HTTP 401 Unauthorized error.
*/
UnauthenticatedAction["DENY"] = "deny";
/**
* Allow the request to be forwarded to the target.
*/
UnauthenticatedAction["ALLOW"] = "allow";
/**
* Redirect the request to the IdP authorization endpoint.
*/
UnauthenticatedAction["AUTHENTICATE"] = "authenticate";

@@ -255,2 +247,2 @@ })(UnauthenticatedAction = exports.UnauthenticatedAction || (exports.UnauthenticatedAction = {}));

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-listener-action.js","sourceRoot":"","sources":["application-listener-action.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, IConstruct, SecretValue, Tokenization } from '@aws-cdk/core';\nimport { CfnListener } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from '../shared/listener-action';\nimport { IApplicationListener } from './application-listener';\nimport { IApplicationTargetGroup } from './application-target-group';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct } from '@aws-cdk/core';\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       \nexport class ListenerAction implements IListenerAction {\n                                                                                                                                                                                                                                                 \n  public static authenticateOidc(options: AuthenticateOidcOptions): ListenerAction {\n    return new ListenerAction({\n      type: 'authenticate-oidc',\n      authenticateOidcConfig: {\n        authorizationEndpoint: options.authorizationEndpoint,\n        clientId: options.clientId,\n        clientSecret: options.clientSecret.toString(),\n        issuer: options.issuer,\n        tokenEndpoint: options.tokenEndpoint,\n        userInfoEndpoint: options.userInfoEndpoint,\n        authenticationRequestExtraParams: options.authenticationRequestExtraParams,\n        onUnauthenticatedRequest: options.onUnauthenticatedRequest,\n        scope: options.scope,\n        sessionCookieName: options.sessionCookieName,\n        sessionTimeout: options.sessionTimeout?.toSeconds().toString(),\n      },\n    }, options.next);\n  }\n\n                                                                                                                                                                                     \n  public static forward(targetGroups: IApplicationTargetGroup[], options: ForwardOptions = {}): ListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a ListenerAction.forward()');\n    }\n    if (targetGroups.length === 1 && options.stickinessDuration === undefined) {\n      // Render a \"simple\" action for backwards compatibility with old templates\n      return new TargetGroupListenerAction(targetGroups, {\n        type: 'forward',\n        targetGroupArn: targetGroups[0].targetGroupArn,\n      });\n    }\n\n    return new TargetGroupListenerAction(targetGroups, {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroupArn })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n                                                                                                                                                                                                                    \n  public static weightedForward(targetGroups: WeightedTargetGroup[], options: ForwardOptions = {}): ListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a ListenerAction.weightedForward()');\n    }\n\n    return new TargetGroupListenerAction(targetGroups.map(g => g.targetGroup), {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroup.targetGroupArn, weight: g.weight })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n                                                                                                                                                                               \n  public static fixedResponse(statusCode: number, options: FixedResponseOptions = {}): ListenerAction {\n    return new ListenerAction({\n      type: 'fixed-response',\n      fixedResponseConfig: {\n        statusCode: Tokenization.stringifyNumber(statusCode),\n        contentType: options.contentType,\n        messageBody: options.messageBody,\n      },\n    });\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           \n  public static redirect(options: RedirectOptions): ListenerAction {\n    if ([options.host, options.path, options.port, options.protocol, options.query].findIndex(x => x !== undefined) === -1) {\n      throw new Error('To prevent redirect loops, set at least one of \\'protocol\\', \\'host\\', \\'port\\', \\'path\\', or \\'query\\'.');\n    }\n\n    return new ListenerAction({\n      type: 'redirect',\n      redirectConfig: {\n        statusCode: options.permanent ? 'HTTP_301' : 'HTTP_302',\n        host: options.host,\n        path: options.path,\n        port: options.port,\n        protocol: options.protocol,\n        query: options.query,\n      },\n    });\n  }\n\n                                                                                                                                                                                                                                                                           \n  protected constructor(private readonly actionJson: CfnListener.ActionProperty, protected readonly next?: ListenerAction) {\n  }\n\n                                                 \n  public renderActions(): CfnListener.ActionProperty[] {\n    return this.renumber([this.actionJson, ...this.next?.renderActions() ?? []]);\n  }\n\n                                                                   \n  public bind(scope: Construct, listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    // Empty on purpose\n    Array.isArray(scope);\n    Array.isArray(listener);\n    Array.isArray(associatingConstruct);\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                      \n  protected renumber(actions: CfnListener.ActionProperty[]): CfnListener.ActionProperty[] {\n    if (actions.length < 2) { return actions; }\n\n    return actions.map((action, i) => ({ ...action, order: i + 1 }));\n  }\n}\n\n                                                 \nexport interface ForwardOptions {\n                                                                                                                                                                 \n  readonly stickinessDuration?: Duration;\n}\n\n                                                \nexport interface WeightedTargetGroup {\n                                 \n  readonly targetGroup: IApplicationTargetGroup;\n\n                                                                                             \n  readonly weight?: number;\n}\n\n                                                       \nexport interface FixedResponseOptions {\n                                                                                                                                                                                                 \n  readonly contentType?: string;\n\n                                                               \n  readonly messageBody?: string;\n}\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                \nexport interface RedirectOptions {\n                                                                                                                                                \n  readonly host?: string;\n\n                                                                                                                                                                                                      \n  readonly path?: string;\n\n                                                                                                                       \n  readonly port?: string;\n\n                                                                                                                                                                                                                         \n  readonly protocol?: string;\n\n                                                                                                                                                                                                                                                \n  readonly query?: string;\n\n                                                                                                                                                \n  readonly permanent?: boolean;\n}\n\n                                                         \nexport interface AuthenticateOidcOptions {\n                                            \n  readonly next: ListenerAction;\n\n                                                                                                                                                           \n  readonly authenticationRequestExtraParams?: Record<string, string>;\n\n                                                                                                                                                  \n  readonly authorizationEndpoint: string;\n\n                                                 \n  readonly clientId: string;\n\n                                             \n  readonly clientSecret: SecretValue;\n\n                                                                                                                                                  \n  readonly issuer: string;\n\n                                                                                                                     \n  readonly onUnauthenticatedRequest?: UnauthenticatedAction;\n\n                                                                                                                                                                                                                                   \n  readonly scope?: string;\n\n                                                                                                                          \n  readonly sessionCookieName?: string;\n\n                                                                                                        \n  readonly sessionTimeout?: Duration;\n\n                                                                                                                                          \n  readonly tokenEndpoint: string;\n\n                                                                                                                                              \n  readonly userInfoEndpoint: string;\n}\n\n                                                   \nexport enum UnauthenticatedAction {\n                                                       \n  DENY = 'deny',\n\n                                                                 \n  ALLOW = 'allow',\n\n                                                                        \n  AUTHENTICATE = 'authenticate',\n}\n\n/**\n * Listener Action that calls \"registerListener\" on TargetGroups\n */\nclass TargetGroupListenerAction extends ListenerAction {\n  constructor(private readonly targetGroups: IApplicationTargetGroup[], actionJson: CfnListener.ActionProperty) {\n    super(actionJson);\n  }\n\n  public bind(_scope: Construct, listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    for (const tg of this.targetGroups) {\n      tg.registerListener(listener, associatingConstruct);\n    }\n  }\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-listener-action.js","sourceRoot":"","sources":["application-listener-action.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, IConstruct, SecretValue, Tokenization } from '@aws-cdk/core';\nimport { CfnListener } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from '../shared/listener-action';\nimport { IApplicationListener } from './application-listener';\nimport { IApplicationTargetGroup } from './application-target-group';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct } from '@aws-cdk/core';\n\n/**\n * What to do when a client makes a request to a listener\n *\n * Some actions can be combined with other ones (specifically,\n * you can perform authentication before serving the request).\n *\n * Multiple actions form a linked chain; the chain must always terminate in a\n * *(weighted)forward*, *fixedResponse* or *redirect* action.\n *\n * If an action supports chaining, the next action can be indicated\n * by passing it in the `next` property.\n *\n * (Called `ListenerAction` instead of the more strictly correct\n * `ListenerAction` because this is the class most users interact\n * with, and we want to make it not too visually overwhelming).\n */\nexport class ListenerAction implements IListenerAction {\n  /**\n   * Authenticate using an identity provider (IdP) that is compliant with OpenID Connect (OIDC)\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/listener-authenticate-users.html#oidc-requirements\n   */\n  public static authenticateOidc(options: AuthenticateOidcOptions): ListenerAction {\n    return new ListenerAction({\n      type: 'authenticate-oidc',\n      authenticateOidcConfig: {\n        authorizationEndpoint: options.authorizationEndpoint,\n        clientId: options.clientId,\n        clientSecret: options.clientSecret.toString(),\n        issuer: options.issuer,\n        tokenEndpoint: options.tokenEndpoint,\n        userInfoEndpoint: options.userInfoEndpoint,\n        authenticationRequestExtraParams: options.authenticationRequestExtraParams,\n        onUnauthenticatedRequest: options.onUnauthenticatedRequest,\n        scope: options.scope,\n        sessionCookieName: options.sessionCookieName,\n        sessionTimeout: options.sessionTimeout?.toSeconds().toString(),\n      },\n    }, options.next);\n  }\n\n  /**\n   * Forward to one or more Target Groups\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#forward-actions\n   */\n  public static forward(targetGroups: IApplicationTargetGroup[], options: ForwardOptions = {}): ListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a ListenerAction.forward()');\n    }\n    if (targetGroups.length === 1 && options.stickinessDuration === undefined) {\n      // Render a \"simple\" action for backwards compatibility with old templates\n      return new TargetGroupListenerAction(targetGroups, {\n        type: 'forward',\n        targetGroupArn: targetGroups[0].targetGroupArn,\n      });\n    }\n\n    return new TargetGroupListenerAction(targetGroups, {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroupArn })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n  /**\n   * Forward to one or more Target Groups which are weighted differently\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#forward-actions\n   */\n  public static weightedForward(targetGroups: WeightedTargetGroup[], options: ForwardOptions = {}): ListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a ListenerAction.weightedForward()');\n    }\n\n    return new TargetGroupListenerAction(targetGroups.map(g => g.targetGroup), {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroup.targetGroupArn, weight: g.weight })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n  /**\n   * Return a fixed response\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#fixed-response-actions\n   */\n  public static fixedResponse(statusCode: number, options: FixedResponseOptions = {}): ListenerAction {\n    return new ListenerAction({\n      type: 'fixed-response',\n      fixedResponseConfig: {\n        statusCode: Tokenization.stringifyNumber(statusCode),\n        contentType: options.contentType,\n        messageBody: options.messageBody,\n      },\n    });\n  }\n\n  /**\n   * Redirect to a different URI\n   *\n   * A URI consists of the following components:\n   * protocol://hostname:port/path?query. You must modify at least one of the\n   * following components to avoid a redirect loop: protocol, hostname, port, or\n   * path. Any components that you do not modify retain their original values.\n   *\n   * You can reuse URI components using the following reserved keywords:\n   *\n   * - `#{protocol}`\n   * - `#{host}`\n   * - `#{port}`\n   * - `#{path}` (the leading \"/\" is removed)\n   * - `#{query}`\n   *\n   * For example, you can change the path to \"/new/#{path}\", the hostname to\n   * \"example.#{host}\", or the query to \"#{query}&value=xyz\".\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#redirect-actions\n   */\n  public static redirect(options: RedirectOptions): ListenerAction {\n    if ([options.host, options.path, options.port, options.protocol, options.query].findIndex(x => x !== undefined) === -1) {\n      throw new Error('To prevent redirect loops, set at least one of \\'protocol\\', \\'host\\', \\'port\\', \\'path\\', or \\'query\\'.');\n    }\n\n    return new ListenerAction({\n      type: 'redirect',\n      redirectConfig: {\n        statusCode: options.permanent ? 'HTTP_301' : 'HTTP_302',\n        host: options.host,\n        path: options.path,\n        port: options.port,\n        protocol: options.protocol,\n        query: options.query,\n      },\n    });\n  }\n\n  /**\n   * Create an instance of ListenerAction\n   *\n   * The default class should be good enough for most cases and\n   * should be created by using one of the static factory functions,\n   * but allow overriding to make sure we allow flexibility for the future.\n   */\n  protected constructor(private readonly actionJson: CfnListener.ActionProperty, protected readonly next?: ListenerAction) {\n  }\n\n  /**\n   * Render the actions in this chain\n   */\n  public renderActions(): CfnListener.ActionProperty[] {\n    return this.renumber([this.actionJson, ...this.next?.renderActions() ?? []]);\n  }\n\n  /**\n   * Called when the action is being used in a listener\n   */\n  public bind(scope: Construct, listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    // Empty on purpose\n    Array.isArray(scope);\n    Array.isArray(listener);\n    Array.isArray(associatingConstruct);\n  }\n\n  /**\n   * Renumber the \"order\" fields in the actions array.\n   *\n   * We don't number for 0 or 1 elements, but otherwise number them 1...#actions\n   * so ELB knows about the right order.\n   *\n   * Do this in `ListenerAction` instead of in `Listener` so that we give\n   * users the opportunity to override by subclassing and overriding `renderActions`.\n   */\n  protected renumber(actions: CfnListener.ActionProperty[]): CfnListener.ActionProperty[] {\n    if (actions.length < 2) { return actions; }\n\n    return actions.map((action, i) => ({ ...action, order: i + 1 }));\n  }\n}\n\n/**\n * Options for `ListenerAction.forward()`\n */\nexport interface ForwardOptions {\n  /**\n   * For how long clients should be directed to the same target group\n   *\n   * Range between 1 second and 7 days.\n   *\n   * @default - No stickiness\n   */\n  readonly stickinessDuration?: Duration;\n}\n\n/**\n * A Target Group and weight combination\n */\nexport interface WeightedTargetGroup {\n  /**\n   * The target group\n   */\n  readonly targetGroup: IApplicationTargetGroup;\n\n  /**\n   * The target group's weight\n   *\n   * Range is [0..1000).\n   *\n   * @default 1\n   */\n  readonly weight?: number;\n}\n\n/**\n * Options for `ListenerAction.fixedResponse()`\n */\nexport interface FixedResponseOptions {\n  /**\n   * Content Type of the response\n   *\n   * Valid Values: text/plain | text/css | text/html | application/javascript | application/json\n   *\n   * @default - Automatically determined\n   */\n  readonly contentType?: string;\n\n  /**\n   * The response body\n   *\n   * @default - No body\n   */\n  readonly messageBody?: string;\n}\n\n/**\n * Options for `ListenerAction.redirect()`\n *\n * A URI consists of the following components:\n * protocol://hostname:port/path?query. You must modify at least one of the\n * following components to avoid a redirect loop: protocol, hostname, port, or\n * path. Any components that you do not modify retain their original values.\n *\n * You can reuse URI components using the following reserved keywords:\n *\n * - `#{protocol}`\n * - `#{host}`\n * - `#{port}`\n * - `#{path}` (the leading \"/\" is removed)\n * - `#{query}`\n *\n * For example, you can change the path to \"/new/#{path}\", the hostname to\n * \"example.#{host}\", or the query to \"#{query}&value=xyz\".\n */\nexport interface RedirectOptions {\n  /**\n   * The hostname.\n   *\n   * This component is not percent-encoded. The hostname can contain #{host}.\n   *\n   * @default - No change\n   */\n  readonly host?: string;\n\n  /**\n   * The absolute path, starting with the leading \"/\".\n   *\n   * This component is not percent-encoded. The path can contain #{host}, #{path}, and #{port}.\n   *\n   * @default - No change\n   */\n  readonly path?: string;\n\n  /**\n   * The port.\n   *\n   * You can specify a value from 1 to 65535 or #{port}.\n   *\n   * @default - No change\n   */\n  readonly port?: string;\n\n  /**\n   * The protocol.\n   *\n   * You can specify HTTP, HTTPS, or #{protocol}. You can redirect HTTP to HTTP, HTTP to HTTPS, and HTTPS to HTTPS. You cannot redirect HTTPS to HTTP.\n   *\n   * @default - No change\n   */\n  readonly protocol?: string;\n\n  /**\n   * The query parameters, URL-encoded when necessary, but not percent-encoded.\n   *\n   * Do not include the leading \"?\", as it is automatically added. You can specify any of the reserved keywords.\n   *\n   * @default - No change\n   */\n  readonly query?: string;\n\n  /**\n   * The HTTP redirect code.\n   *\n   * The redirect is either permanent (HTTP 301) or temporary (HTTP 302).\n   *\n   * @default false\n   */\n  readonly permanent?: boolean;\n}\n\n/**\n * Options for `ListenerAction.authenciateOidc()`\n */\nexport interface AuthenticateOidcOptions {\n  /**\n   * What action to execute next\n   */\n  readonly next: ListenerAction;\n\n  /**\n   * The query parameters (up to 10) to include in the redirect request to the authorization endpoint.\n   *\n   * @default - No extra parameters\n   */\n  readonly authenticationRequestExtraParams?: Record<string, string>;\n\n  /**\n   * The authorization endpoint of the IdP.\n   *\n   * This must be a full URL, including the HTTPS protocol, the domain, and the path.\n   */\n  readonly authorizationEndpoint: string;\n\n  /**\n   * The OAuth 2.0 client identifier.\n   */\n  readonly clientId: string;\n\n  /**\n   * The OAuth 2.0 client secret.\n   */\n  readonly clientSecret: SecretValue;\n\n  /**\n   * The OIDC issuer identifier of the IdP.\n   *\n   * This must be a full URL, including the HTTPS protocol, the domain, and the path.\n   */\n  readonly issuer: string;\n\n  /**\n   * The behavior if the user is not authenticated.\n   *\n   * @default UnauthenticatedAction.AUTHENTICATE\n   */\n  readonly onUnauthenticatedRequest?: UnauthenticatedAction;\n\n  /**\n   * The set of user claims to be requested from the IdP.\n   *\n   * To verify which scope values your IdP supports and how to separate multiple values, see the documentation for your IdP.\n   *\n   * @default \"openid\"\n   */\n  readonly scope?: string;\n\n  /**\n   * The name of the cookie used to maintain session information.\n   *\n   * @default \"AWSELBAuthSessionCookie\"\n   */\n  readonly sessionCookieName?: string;\n\n  /**\n   * The maximum duration of the authentication session.\n   *\n   * @default Duration.days(7)\n   */\n  readonly sessionTimeout?: Duration;\n\n  /**\n   * The token endpoint of the IdP.\n   *\n   * This must be a full URL, including the HTTPS protocol, the domain, and the path.\n   */\n  readonly tokenEndpoint: string;\n\n  /**\n   * The user info endpoint of the IdP.\n   *\n   * This must be a full URL, including the HTTPS protocol, the domain, and the path.\n   */\n  readonly userInfoEndpoint: string;\n}\n\n/**\n * What to do with unauthenticated requests\n */\nexport enum UnauthenticatedAction {\n  /**\n   * Return an HTTP 401 Unauthorized error.\n   */\n  DENY = 'deny',\n\n  /**\n   * Allow the request to be forwarded to the target.\n   */\n  ALLOW = 'allow',\n\n  /**\n   * Redirect the request to the IdP authorization endpoint.\n   */\n  AUTHENTICATE = 'authenticate',\n}\n\n/**\n * Listener Action that calls \"registerListener\" on TargetGroups\n */\nclass TargetGroupListenerAction extends ListenerAction {\n  constructor(private readonly targetGroups: IApplicationTargetGroup[], actionJson: CfnListener.ActionProperty) {\n    super(actionJson);\n  }\n\n  public bind(_scope: Construct, listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    for (const tg of this.targetGroups) {\n      tg.registerListener(listener, associatingConstruct);\n    }\n  }\n}"]}

@@ -6,24 +6,20 @@ import { Construct } from 'constructs';

/**
* Properties for adding a set of certificates to a listener.
*
* @stability stable
* Properties for adding a set of certificates to a listener
*/
export interface ApplicationListenerCertificateProps {
/**
* The listener to attach the rule to.
*
* @stability stable
* The listener to attach the rule to
*/
readonly listener: IApplicationListener;
/**
* (deprecated) ARNs of certificates to attach.
* ARNs of certificates to attach
*
* Duplicates are not allowed.
*
* @deprecated Use `certificates` instead.
* @default - One of 'certificates' and 'certificateArns' is required.
* @deprecated Use `certificates` instead.
*/
readonly certificateArns?: string[];
/**
* Certificates to attach.
* Certificates to attach
*

@@ -33,3 +29,2 @@ * Duplicates are not allowed.

* @default - One of 'certificates' and 'certificateArns' is required.
* @stability stable
*/

@@ -39,11 +34,6 @@ readonly certificates?: IListenerCertificate[];

/**
* Add certificates to a listener.
*
* @stability stable
* Add certificates to a listener
*/
export declare class ApplicationListenerCertificate extends CoreConstruct {
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: ApplicationListenerCertificateProps);
}

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

/**
* Add certificates to a listener.
*
* @stability stable
* Add certificates to a listener
*/
class ApplicationListenerCertificate extends core_1.Construct {
/**
* @stability stable
*/
constructor(scope, id, props) {

@@ -39,3 +34,3 @@ super(scope, id);

_a = JSII_RTTI_SYMBOL_1;
ApplicationListenerCertificate[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ApplicationListenerCertificate", version: "1.144.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24tbGlzdGVuZXItY2VydGlmaWNhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhcHBsaWNhdGlvbi1saXN0ZW5lci1jZXJ0aWZpY2F0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSwwRkFBNkU7QUFJN0UsaUdBQWlHO0FBQ2pHLDhEQUE4RDtBQUM5RCx3Q0FBMkQ7Ozs7OztBQWUzRCxNQUFhLDhCQUErQixTQUFRLGdCQUFhOzs7O0lBQy9ELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMEM7UUFDbEYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQzs7UUFFakIsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFO1lBQ2pELE1BQU0sSUFBSSxLQUFLLENBQUMscUVBQXFFLENBQUMsQ0FBQztTQUN4RjtRQUVELE1BQU0sWUFBWSxHQUFHO1lBQ25CLEdBQUcsQ0FBQyxLQUFLLENBQUMsWUFBWSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxjQUFjLEVBQUUsQ0FBQyxDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUM7WUFDOUUsR0FBRyxDQUFDLEtBQUssQ0FBQyxlQUFlLElBQUksRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLGNBQWMsRUFBRSxDQUFDLENBQUM7U0FDN0UsQ0FBQztRQUVGLElBQUkseURBQXNCLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUMzQyxXQUFXLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxXQUFXO1lBQ3ZDLFlBQVk7U0FDYixDQUFDLENBQUM7S0FDSjs7QUFqQkgsd0VBa0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBDZm5MaXN0ZW5lckNlcnRpZmljYXRlIH0gZnJvbSAnLi4vZWxhc3RpY2xvYWRiYWxhbmNpbmd2Mi5nZW5lcmF0ZWQnO1xuaW1wb3J0IHsgSUxpc3RlbmVyQ2VydGlmaWNhdGUgfSBmcm9tICcuLi9zaGFyZWQvbGlzdGVuZXItY2VydGlmaWNhdGUnO1xuaW1wb3J0IHsgSUFwcGxpY2F0aW9uTGlzdGVuZXIgfSBmcm9tICcuL2FwcGxpY2F0aW9uLWxpc3RlbmVyJztcblxuLy8ga2VlcCB0aGlzIGltcG9ydCBzZXBhcmF0ZSBmcm9tIG90aGVyIGltcG9ydHMgdG8gcmVkdWNlIGNoYW5jZSBmb3IgbWVyZ2UgY29uZmxpY3RzIHdpdGggdjItbWFpblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWR1cGxpY2F0ZS1pbXBvcnRzLCBpbXBvcnQvb3JkZXJcbmltcG9ydCB7IENvbnN0cnVjdCBhcyBDb3JlQ29uc3RydWN0IH0gZnJvbSAnQGF3cy1jZGsvY29yZSc7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgaW50ZXJmYWNlIEFwcGxpY2F0aW9uTGlzdGVuZXJDZXJ0aWZpY2F0ZVByb3BzIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBsaXN0ZW5lcjogSUFwcGxpY2F0aW9uTGlzdGVuZXI7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgY2VydGlmaWNhdGVBcm5zPzogc3RyaW5nW107XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGNlcnRpZmljYXRlcz86IElMaXN0ZW5lckNlcnRpZmljYXRlW107XG59XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgY2xhc3MgQXBwbGljYXRpb25MaXN0ZW5lckNlcnRpZmljYXRlIGV4dGVuZHMgQ29yZUNvbnN0cnVjdCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBBcHBsaWNhdGlvbkxpc3RlbmVyQ2VydGlmaWNhdGVQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBpZiAoIXByb3BzLmNlcnRpZmljYXRlQXJucyAmJiAhcHJvcHMuY2VydGlmaWNhdGVzKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0F0IGxlYXN0IG9uZSBvZiBcXCdjZXJ0aWZpY2F0ZUFybnNcXCcgb3IgXFwnY2VydGlmaWNhdGVzXFwnIGlzIHJlcXVpcmVkJyk7XG4gICAgfVxuXG4gICAgY29uc3QgY2VydGlmaWNhdGVzID0gW1xuICAgICAgLi4uKHByb3BzLmNlcnRpZmljYXRlcyB8fCBbXSkubWFwKGMgPT4gKHsgY2VydGlmaWNhdGVBcm46IGMuY2VydGlmaWNhdGVBcm4gfSkpLFxuICAgICAgLi4uKHByb3BzLmNlcnRpZmljYXRlQXJucyB8fCBbXSkubWFwKGNlcnRpZmljYXRlQXJuID0+ICh7IGNlcnRpZmljYXRlQXJuIH0pKSxcbiAgICBdO1xuXG4gICAgbmV3IENmbkxpc3RlbmVyQ2VydGlmaWNhdGUodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgbGlzdGVuZXJBcm46IHByb3BzLmxpc3RlbmVyLmxpc3RlbmVyQXJuLFxuICAgICAgY2VydGlmaWNhdGVzLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
ApplicationListenerCertificate[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ApplicationListenerCertificate", version: "1.145.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24tbGlzdGVuZXItY2VydGlmaWNhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhcHBsaWNhdGlvbi1saXN0ZW5lci1jZXJ0aWZpY2F0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSwwRkFBNkU7QUFJN0UsaUdBQWlHO0FBQ2pHLDhEQUE4RDtBQUM5RCx3Q0FBMkQ7QUErQjNEOztHQUVHO0FBQ0gsTUFBYSw4QkFBK0IsU0FBUSxnQkFBYTtJQUMvRCxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQTBDO1FBQ2xGLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7O1FBRWpCLElBQUksQ0FBQyxLQUFLLENBQUMsZUFBZSxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksRUFBRTtZQUNqRCxNQUFNLElBQUksS0FBSyxDQUFDLHFFQUFxRSxDQUFDLENBQUM7U0FDeEY7UUFFRCxNQUFNLFlBQVksR0FBRztZQUNuQixHQUFHLENBQUMsS0FBSyxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUUsY0FBYyxFQUFFLENBQUMsQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDO1lBQzlFLEdBQUcsQ0FBQyxLQUFLLENBQUMsZUFBZSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxjQUFjLEVBQUUsQ0FBQyxDQUFDO1NBQzdFLENBQUM7UUFFRixJQUFJLHlEQUFzQixDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDM0MsV0FBVyxFQUFFLEtBQUssQ0FBQyxRQUFRLENBQUMsV0FBVztZQUN2QyxZQUFZO1NBQ2IsQ0FBQyxDQUFDO0tBQ0o7O0FBakJILHdFQWtCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQ2ZuTGlzdGVuZXJDZXJ0aWZpY2F0ZSB9IGZyb20gJy4uL2VsYXN0aWNsb2FkYmFsYW5jaW5ndjIuZ2VuZXJhdGVkJztcbmltcG9ydCB7IElMaXN0ZW5lckNlcnRpZmljYXRlIH0gZnJvbSAnLi4vc2hhcmVkL2xpc3RlbmVyLWNlcnRpZmljYXRlJztcbmltcG9ydCB7IElBcHBsaWNhdGlvbkxpc3RlbmVyIH0gZnJvbSAnLi9hcHBsaWNhdGlvbi1saXN0ZW5lcic7XG5cbi8vIGtlZXAgdGhpcyBpbXBvcnQgc2VwYXJhdGUgZnJvbSBvdGhlciBpbXBvcnRzIHRvIHJlZHVjZSBjaGFuY2UgZm9yIG1lcmdlIGNvbmZsaWN0cyB3aXRoIHYyLW1haW5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1kdXBsaWNhdGUtaW1wb3J0cywgaW1wb3J0L29yZGVyXG5pbXBvcnQgeyBDb25zdHJ1Y3QgYXMgQ29yZUNvbnN0cnVjdCB9IGZyb20gJ0Bhd3MtY2RrL2NvcmUnO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGFkZGluZyBhIHNldCBvZiBjZXJ0aWZpY2F0ZXMgdG8gYSBsaXN0ZW5lclxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFwcGxpY2F0aW9uTGlzdGVuZXJDZXJ0aWZpY2F0ZVByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBsaXN0ZW5lciB0byBhdHRhY2ggdGhlIHJ1bGUgdG9cbiAgICovXG4gIHJlYWRvbmx5IGxpc3RlbmVyOiBJQXBwbGljYXRpb25MaXN0ZW5lcjtcblxuICAvKipcbiAgICogQVJOcyBvZiBjZXJ0aWZpY2F0ZXMgdG8gYXR0YWNoXG4gICAqXG4gICAqIER1cGxpY2F0ZXMgYXJlIG5vdCBhbGxvd2VkLlxuICAgKlxuICAgKiBAZGVwcmVjYXRlZCBVc2UgYGNlcnRpZmljYXRlc2AgaW5zdGVhZC5cbiAgICogQGRlZmF1bHQgLSBPbmUgb2YgJ2NlcnRpZmljYXRlcycgYW5kICdjZXJ0aWZpY2F0ZUFybnMnIGlzIHJlcXVpcmVkLlxuICAgKi9cbiAgcmVhZG9ubHkgY2VydGlmaWNhdGVBcm5zPzogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIENlcnRpZmljYXRlcyB0byBhdHRhY2hcbiAgICpcbiAgICogRHVwbGljYXRlcyBhcmUgbm90IGFsbG93ZWQuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gT25lIG9mICdjZXJ0aWZpY2F0ZXMnIGFuZCAnY2VydGlmaWNhdGVBcm5zJyBpcyByZXF1aXJlZC5cbiAgICovXG4gIHJlYWRvbmx5IGNlcnRpZmljYXRlcz86IElMaXN0ZW5lckNlcnRpZmljYXRlW107XG59XG5cbi8qKlxuICogQWRkIGNlcnRpZmljYXRlcyB0byBhIGxpc3RlbmVyXG4gKi9cbmV4cG9ydCBjbGFzcyBBcHBsaWNhdGlvbkxpc3RlbmVyQ2VydGlmaWNhdGUgZXh0ZW5kcyBDb3JlQ29uc3RydWN0IHtcbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IEFwcGxpY2F0aW9uTGlzdGVuZXJDZXJ0aWZpY2F0ZVByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGlmICghcHJvcHMuY2VydGlmaWNhdGVBcm5zICYmICFwcm9wcy5jZXJ0aWZpY2F0ZXMpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQXQgbGVhc3Qgb25lIG9mIFxcJ2NlcnRpZmljYXRlQXJuc1xcJyBvciBcXCdjZXJ0aWZpY2F0ZXNcXCcgaXMgcmVxdWlyZWQnKTtcbiAgICB9XG5cbiAgICBjb25zdCBjZXJ0aWZpY2F0ZXMgPSBbXG4gICAgICAuLi4ocHJvcHMuY2VydGlmaWNhdGVzIHx8IFtdKS5tYXAoYyA9PiAoeyBjZXJ0aWZpY2F0ZUFybjogYy5jZXJ0aWZpY2F0ZUFybiB9KSksXG4gICAgICAuLi4ocHJvcHMuY2VydGlmaWNhdGVBcm5zIHx8IFtdKS5tYXAoY2VydGlmaWNhdGVBcm4gPT4gKHsgY2VydGlmaWNhdGVBcm4gfSkpLFxuICAgIF07XG5cbiAgICBuZXcgQ2ZuTGlzdGVuZXJDZXJ0aWZpY2F0ZSh0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBsaXN0ZW5lckFybjogcHJvcHMubGlzdGVuZXIubGlzdGVuZXJBcm4sXG4gICAgICBjZXJ0aWZpY2F0ZXMsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==

@@ -8,9 +8,7 @@ import { Construct } from 'constructs';

/**
* Basic properties for defining a rule on a listener.
*
* @stability stable
* Basic properties for defining a rule on a listener
*/
export interface BaseApplicationListenerRuleProps {
/**
* Priority of the rule.
* Priority of the rule
*

@@ -20,4 +18,2 @@ * The rule with the lowest priority will be used for every request.

* Priorities must be unique.
*
* @stability stable
*/

@@ -33,7 +29,6 @@ readonly priority: number;

* @default - No target groups.
* @stability stable
*/
readonly targetGroups?: IApplicationTargetGroup[];
/**
* Action to perform when requests are received.
* Action to perform when requests are received
*

@@ -43,7 +38,6 @@ * Only one of `action`, `fixedResponse`, `redirectResponse` or `targetGroups` can be specified.

* @default - No action
* @stability stable
*/
readonly action?: ListenerAction;
/**
* (deprecated) Fixed response to return.
* Fixed response to return.
*

@@ -57,3 +51,3 @@ * Only one of `action`, `fixedResponse`, `redirectResponse` or `targetGroups` can be specified.

/**
* (deprecated) Redirect response to return.
* Redirect response to return.
*

@@ -69,14 +63,15 @@ * Only one of `action`, `fixedResponse`, `redirectResponse` or `targetGroups` can be specified.

*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html
*
* @default - No conditions.
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html
* @stability stable
*/
readonly conditions?: ListenerCondition[];
/**
* (deprecated) Rule applies if the requested host matches the indicated host.
* Rule applies if the requested host matches the indicated host
*
* May contain up to three '*' wildcards.
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#host-conditions
*
* @default - No host condition.
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#host-conditions
* @deprecated Use `conditions` instead.

@@ -86,6 +81,6 @@ */

/**
* (deprecated) Rule applies if the requested path matches the given path pattern.
* Rule applies if the requested path matches the given path pattern
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @default - No path condition.
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @deprecated Use `conditions` instead.

@@ -95,8 +90,8 @@ */

/**
* (deprecated) Rule applies if the requested path matches any of the given patterns.
* Rule applies if the requested path matches any of the given patterns.
*
* Paths may contain up to three '*' wildcards.
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @default - No path conditions.
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @deprecated Use `conditions` instead.

@@ -107,11 +102,7 @@ */

/**
* Properties for defining a listener rule.
*
* @stability stable
* Properties for defining a listener rule
*/
export interface ApplicationListenerRuleProps extends BaseApplicationListenerRuleProps {
/**
* The listener to attach the rule to.
*
* @stability stable
* The listener to attach the rule to
*/

@@ -121,31 +112,14 @@ readonly listener: IApplicationListener;

/**
* (deprecated) The content type for a fixed response.
*
* The content type for a fixed response
* @deprecated superceded by `FixedResponseOptions`.
*/
export declare enum ContentType {
/**
* @deprecated
*/
TEXT_PLAIN = "text/plain",
/**
* @deprecated
*/
TEXT_CSS = "text/css",
/**
* @deprecated
*/
TEXT_HTML = "text/html",
/**
* @deprecated
*/
APPLICATION_JAVASCRIPT = "application/javascript",
/**
* @deprecated
*/
APPLICATION_JSON = "application/json"
}
/**
* (deprecated) A fixed response.
*
* A fixed response
* @deprecated superceded by `ListenerAction.fixedResponse()`.

@@ -155,19 +129,15 @@ */

/**
* (deprecated) The HTTP response code (2XX, 4XX or 5XX).
*
* @deprecated
* The HTTP response code (2XX, 4XX or 5XX)
*/
readonly statusCode: string;
/**
* (deprecated) The content type.
* The content type
*
* @default text/plain
* @deprecated
*/
readonly contentType?: ContentType;
/**
* (deprecated) The message.
* The message
*
* @default no message
* @deprecated
*/

@@ -177,4 +147,3 @@ readonly messageBody?: string;

/**
* (deprecated) A redirect response.
*
* A redirect response
* @deprecated superceded by `ListenerAction.redirect()`.

@@ -184,42 +153,29 @@ */

/**
* (deprecated) The hostname.
* The hostname. This component is not percent-encoded. The hostname can contain #{host}.
*
* This component is not percent-encoded. The hostname can contain #{host}.
*
* @default origin host of request
* @deprecated
*/
readonly host?: string;
/**
* (deprecated) The absolute path, starting with the leading "/".
*
* This component is not percent-encoded.
* The absolute path, starting with the leading "/". This component is not percent-encoded.
* The path can contain #{host}, #{path}, and #{port}.
*
* @default origin path of request
* @deprecated
*/
readonly path?: string;
/**
* (deprecated) The port.
* The port. You can specify a value from 1 to 65535 or #{port}.
*
* You can specify a value from 1 to 65535 or #{port}.
*
* @default origin port of request
* @deprecated
*/
readonly port?: string;
/**
* (deprecated) The protocol.
*
* You can specify HTTP, HTTPS, or #{protocol}. You can redirect HTTP to HTTP,
* The protocol. You can specify HTTP, HTTPS, or #{protocol}. You can redirect HTTP to HTTP,
* HTTP to HTTPS, and HTTPS to HTTPS. You cannot redirect HTTPS to HTTP.
*
* @default origin protocol of request
* @deprecated
*/
readonly protocol?: string;
/**
* (deprecated) The query parameters, URL-encoded when necessary, but not percent-encoded.
*
* The query parameters, URL-encoded when necessary, but not percent-encoded.
* Do not include the leading "?", as it is automatically added.

@@ -229,9 +185,6 @@ * You can specify any of the reserved keywords.

* @default origin query string of request
* @deprecated
*/
readonly query?: string;
/**
* (deprecated) The HTTP redirect code (HTTP_301 or HTTP_302).
*
* @deprecated
* The HTTP redirect code (HTTP_301 or HTTP_302)
*/

@@ -241,11 +194,7 @@ readonly statusCode: string;

/**
* Define a new listener rule.
*
* @stability stable
* Define a new listener rule
*/
export declare class ApplicationListenerRule extends CoreConstruct {
/**
* The ARN of this rule.
*
* @stability stable
* The ARN of this rule
*/

@@ -257,8 +206,5 @@ readonly listenerRuleArn: string;

private action?;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: ApplicationListenerRuleProps);
/**
* (deprecated) Add a non-standard condition to this rule.
* Add a non-standard condition to this rule
*

@@ -271,15 +217,11 @@ * If the condition conflicts with an already set condition, it will be overwritten by the one you specified.

/**
* Add a non-standard condition to this rule.
*
* @stability stable
* Add a non-standard condition to this rule
*/
addCondition(condition: ListenerCondition): void;
/**
* Configure the action to perform for this rule.
*
* @stability stable
* Configure the action to perform for this rule
*/
configureAction(action: ListenerAction): void;
/**
* (deprecated) Add a TargetGroup to load balance to.
* Add a TargetGroup to load balance to
*

@@ -290,3 +232,3 @@ * @deprecated Use configureAction instead

/**
* (deprecated) Add a fixed response.
* Add a fixed response
*

@@ -297,3 +239,3 @@ * @deprecated Use configureAction instead

/**
* (deprecated) Add a redirect response.
* Add a redirect response
*

@@ -304,5 +246,3 @@ * @deprecated Use configureAction instead

/**
* Validate the rule.
*
* @stability stable
* Validate the rule
*/

@@ -309,0 +249,0 @@ protected validate(): string[];

@@ -14,4 +14,3 @@ "use strict";

/**
* (deprecated) The content type for a fixed response.
*
* The content type for a fixed response
* @deprecated superceded by `FixedResponseOptions`.

@@ -28,10 +27,5 @@ */

/**
* Define a new listener rule.
*
* @stability stable
* Define a new listener rule
*/
class ApplicationListenerRule extends core_1.Construct {
/**
* @stability stable
*/
constructor(scope, id, props) {

@@ -86,3 +80,3 @@ super(scope, id);

/**
* (deprecated) Add a non-standard condition to this rule.
* Add a non-standard condition to this rule
*

@@ -102,5 +96,3 @@ * If the condition conflicts with an already set condition, it will be overwritten by the one you specified.

/**
* Add a non-standard condition to this rule.
*
* @stability stable
* Add a non-standard condition to this rule
*/

@@ -112,5 +104,3 @@ addCondition(condition) {

/**
* Configure the action to perform for this rule.
*
* @stability stable
* Configure the action to perform for this rule
*/

@@ -135,3 +125,3 @@ configureAction(action) {

/**
* (deprecated) Add a TargetGroup to load balance to.
* Add a TargetGroup to load balance to
*

@@ -146,3 +136,3 @@ * @deprecated Use configureAction instead

/**
* (deprecated) Add a fixed response.
* Add a fixed response
*

@@ -161,3 +151,3 @@ * @deprecated Use configureAction instead

/**
* (deprecated) Add a redirect response.
* Add a redirect response
*

@@ -180,5 +170,3 @@ * @deprecated Use configureAction instead

/**
* Validate the rule.
*
* @stability stable
* Validate the rule
*/

@@ -211,3 +199,3 @@ validate() {

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

@@ -241,2 +229,2 @@ * Validate the status code and message body of a fixed response

exports.validateRedirectResponse = validateRedirectResponse;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-listener-rule.js","sourceRoot":"","sources":["application-listener-rule.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnListenerRule } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from '../shared/listener-action';\nimport { IApplicationListener } from './application-listener';\nimport { ListenerAction } from './application-listener-action';\nimport { IApplicationTargetGroup } from './application-target-group';\nimport { ListenerCondition } from './conditions';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct as CoreConstruct } from '@aws-cdk/core';\n\n                                                             \nexport interface BaseApplicationListenerRuleProps {\n                                                                                                                                                      \n  readonly priority: number;\n\n                                                                                                                                                                                                                                           \n  readonly targetGroups?: IApplicationTargetGroup[];\n\n                                                                                                                                                                                                    \n  readonly action?: ListenerAction;\n\n                                                                                                                                                                                                                                 \n  readonly fixedResponse?: FixedResponse;\n\n                                                                                                                                                                                                                                       \n  readonly redirectResponse?: RedirectResponse;\n\n                                                                                                                                                                                                            \n  readonly conditions?: ListenerCondition[];\n\n                                                                                                                                                                                                                                                                                                                                                  \n  readonly hostHeader?: string;\n\n                                                                                                                                                                                                                                                                                                \n  readonly pathPattern?: string;\n\n                                                                                                                                                                                                                                                                                                                                                            \n  readonly pathPatterns?: string[];\n}\n\n                                                  \nexport interface ApplicationListenerRuleProps extends BaseApplicationListenerRuleProps {\n                                                   \n  readonly listener: IApplicationListener;\n}\n\n                                                                                                     \nexport enum ContentType {\n  TEXT_PLAIN = 'text/plain',\n  TEXT_CSS = 'text/css',\n  TEXT_HTML = 'text/html',\n  APPLICATION_JAVASCRIPT = 'application/javascript',\n  APPLICATION_JSON = 'application/json'\n}\n\n                                                                                          \nexport interface FixedResponse {\n                                                         \n  readonly statusCode: string;\n\n                                                               \n  readonly contentType?: ContentType;\n\n                                                          \n  readonly messageBody?: string;\n}\n\n                                                                                        \nexport interface RedirectResponse {\n                                                                                                                                                 \n  readonly host?: string;\n                                                                                                                                                                                                            \n  readonly path?: string;\n                                                                                                                        \n  readonly port?: string;\n                                                                                                                                                                                                                                   \n  readonly protocol?: string;\n                                                                                                                                                                                                                                                                   \n  readonly query?: string;\n                                                              \n  readonly statusCode: string;\n}\n\n                                     \nexport class ApplicationListenerRule extends CoreConstruct {\n                                     \n  public readonly listenerRuleArn: string;\n\n  private readonly conditions: ListenerCondition[];\n  private readonly legacyConditions: {[key: string]: string[]} = {};\n\n  private readonly listener: IApplicationListener;\n  private action?: IListenerAction;\n\n  constructor(scope: Construct, id: string, props: ApplicationListenerRuleProps) {\n    super(scope, id);\n\n    this.conditions = props.conditions || [];\n\n    const hasPathPatterns = props.pathPatterns || props.pathPattern;\n    if (this.conditions.length === 0 && !props.hostHeader && !hasPathPatterns) {\n      throw new Error('At least one of \\'conditions\\', \\'hostHeader\\', \\'pathPattern\\' or \\'pathPatterns\\' is required when defining a load balancing rule.');\n    }\n\n    const possibleActions: Array<keyof ApplicationListenerRuleProps> = ['action', 'targetGroups', 'fixedResponse', 'redirectResponse'];\n    const providedActions = possibleActions.filter(action => props[action] !== undefined);\n    if (providedActions.length > 1) {\n      throw new Error(`'${providedActions}' specified together, specify only one`);\n    }\n\n    if (!cdk.Token.isUnresolved(props.priority) && props.priority <= 0) {\n      throw new Error('Priority must have value greater than or equal to 1');\n    }\n\n    this.listener = props.listener;\n\n    const resource = new CfnListenerRule(this, 'Resource', {\n      listenerArn: props.listener.listenerArn,\n      priority: props.priority,\n      conditions: cdk.Lazy.any({ produce: () => this.renderConditions() }),\n      actions: cdk.Lazy.any({ produce: () => this.action ? this.action.renderActions() : [] }),\n    });\n\n    if (props.hostHeader) {\n      this.setCondition('host-header', [props.hostHeader]);\n    }\n\n    if (hasPathPatterns) {\n      if (props.pathPattern && props.pathPatterns) {\n        throw new Error('Both `pathPatterns` and `pathPattern` are specified, specify only one');\n      }\n      const pathPattern = props.pathPattern ? [props.pathPattern] : props.pathPatterns;\n      this.setCondition('path-pattern', pathPattern);\n    }\n\n    if (props.action) {\n      this.configureAction(props.action);\n    }\n\n    (props.targetGroups || []).forEach((group) => {\n      this.configureAction(ListenerAction.forward([group]));\n    });\n\n    if (props.fixedResponse) {\n      this.addFixedResponse(props.fixedResponse);\n    } else if (props.redirectResponse) {\n      this.addRedirectResponse(props.redirectResponse);\n    }\n\n    this.listenerRuleArn = resource.ref;\n  }\n\n                                                                                                                                                                                                                                 \n  public setCondition(field: string, values: string[] | undefined) {\n    if (values === undefined) {\n      delete this.legacyConditions[field];\n      return;\n    }\n\n    this.legacyConditions[field] = values;\n  }\n\n                                                          \n  public addCondition(condition: ListenerCondition) {\n    this.conditions.push(condition);\n  }\n\n                                                              \n  public configureAction(action: ListenerAction) {\n    // It might make sense to 'throw' here.\n    //\n    // However, programs may already exist out there which configured an action twice,\n    // in which case the second action accidentally overwrite the initial action, and in some\n    // way ended up with a program that did what the author intended. If we were to add throw now,\n    // the previously working program would be broken.\n    //\n    // Instead, signal this through a warning.\n    // @deprecate: upon the next major version bump, replace this with a `throw`\n    if (this.action) {\n      cdk.Annotations.of(this).addWarning('An Action already existed on this ListenerRule and was replaced. Configure exactly one default Action.');\n    }\n\n    action.bind(this, this.listener, this);\n    this.action = action;\n  }\n\n                                                                                                       \n  public addTargetGroup(targetGroup: IApplicationTargetGroup) {\n    this.configureAction(ListenerAction.forward([targetGroup]));\n  }\n\n                                                                                       \n  public addFixedResponse(fixedResponse: FixedResponse) {\n    validateFixedResponse(fixedResponse);\n\n    this.configureAction(ListenerAction.fixedResponse(cdk.Token.asNumber(fixedResponse.statusCode), {\n      contentType: fixedResponse.contentType,\n      messageBody: fixedResponse.messageBody,\n    }));\n  }\n\n                                                                                          \n  public addRedirectResponse(redirectResponse: RedirectResponse) {\n    validateRedirectResponse(redirectResponse);\n\n    this.configureAction(ListenerAction.redirect({\n      host: redirectResponse.host,\n      path: redirectResponse.path,\n      permanent: redirectResponse.statusCode === 'HTTP_301',\n      port: redirectResponse.port,\n      protocol: redirectResponse.protocol,\n      query: redirectResponse.query,\n    }));\n  }\n\n                                  \n  protected validate() {\n    if (this.action === undefined) {\n      return ['Listener rule needs at least one action'];\n    }\n\n    const legacyConditionFields = Object.keys(this.legacyConditions);\n    if (legacyConditionFields.length === 0 && this.conditions.length === 0) {\n      return ['Listener rule needs at least one condition'];\n    }\n\n    return [];\n  }\n\n  /**\n   * Render the conditions for this rule\n   */\n  private renderConditions(): any {\n    const legacyConditions = Object.entries(this.legacyConditions).map(([field, values]) => {\n      return { field, values };\n    });\n    const conditions = this.conditions.map(condition => condition.renderRawCondition());\n\n    return [\n      ...legacyConditions,\n      ...conditions,\n    ];\n  }\n}\n\n/**\n * Validate the status code and message body of a fixed response\n * @internal\n * @deprecated\n */\nexport function validateFixedResponse(fixedResponse: FixedResponse) {\n  if (fixedResponse.statusCode && !/^(2|4|5)\\d\\d$/.test(fixedResponse.statusCode)) {\n    throw new Error('`statusCode` must be 2XX, 4XX or 5XX.');\n  }\n\n  if (fixedResponse.messageBody && fixedResponse.messageBody.length > 1024) {\n    throw new Error('`messageBody` cannot have more than 1024 characters.');\n  }\n}\n\n/**\n * Validate the status code and message body of a redirect response\n * @internal\n * @deprecated\n */\nexport function validateRedirectResponse(redirectResponse: RedirectResponse) {\n  if (redirectResponse.protocol && !/^(HTTPS?|#\\{protocol\\})$/i.test(redirectResponse.protocol)) {\n    throw new Error('`protocol` must be HTTP, HTTPS, or #{protocol}.');\n  }\n\n  if (!redirectResponse.statusCode || !/^HTTP_30[12]$/.test(redirectResponse.statusCode)) {\n    throw new Error('`statusCode` must be HTTP_301 or HTTP_302.');\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-listener-rule.js","sourceRoot":"","sources":["application-listener-rule.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnListenerRule } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from '../shared/listener-action';\nimport { IApplicationListener } from './application-listener';\nimport { ListenerAction } from './application-listener-action';\nimport { IApplicationTargetGroup } from './application-target-group';\nimport { ListenerCondition } from './conditions';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct as CoreConstruct } from '@aws-cdk/core';\n\n/**\n * Basic properties for defining a rule on a listener\n */\nexport interface BaseApplicationListenerRuleProps {\n  /**\n   * Priority of the rule\n   *\n   * The rule with the lowest priority will be used for every request.\n   *\n   * Priorities must be unique.\n   */\n  readonly priority: number;\n\n  /**\n   * Target groups to forward requests to.\n   *\n   * Only one of `action`, `fixedResponse`, `redirectResponse` or `targetGroups` can be specified.\n   *\n   * Implies a `forward` action.\n   *\n   * @default - No target groups.\n   */\n  readonly targetGroups?: IApplicationTargetGroup[];\n\n  /**\n   * Action to perform when requests are received\n   *\n   * Only one of `action`, `fixedResponse`, `redirectResponse` or `targetGroups` can be specified.\n   *\n   * @default - No action\n   */\n  readonly action?: ListenerAction;\n\n  /**\n   * Fixed response to return.\n   *\n   * Only one of `action`, `fixedResponse`, `redirectResponse` or `targetGroups` can be specified.\n   *\n   * @default - No fixed response.\n   * @deprecated Use `action` instead.\n   */\n  readonly fixedResponse?: FixedResponse;\n\n  /**\n   * Redirect response to return.\n   *\n   * Only one of `action`, `fixedResponse`, `redirectResponse` or `targetGroups` can be specified.\n   *\n   * @default - No redirect response.\n   * @deprecated Use `action` instead.\n   */\n  readonly redirectResponse?: RedirectResponse;\n\n  /**\n   * Rule applies if matches the conditions.\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html\n   *\n   * @default - No conditions.\n   */\n  readonly conditions?: ListenerCondition[];\n\n  /**\n   * Rule applies if the requested host matches the indicated host\n   *\n   * May contain up to three '*' wildcards.\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#host-conditions\n   *\n   * @default - No host condition.\n   * @deprecated Use `conditions` instead.\n   */\n  readonly hostHeader?: string;\n\n  /**\n   * Rule applies if the requested path matches the given path pattern\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions\n   * @default - No path condition.\n   * @deprecated Use `conditions` instead.\n   */\n  readonly pathPattern?: string;\n\n  /**\n   * Rule applies if the requested path matches any of the given patterns.\n   *\n   * Paths may contain up to three '*' wildcards.\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions\n   * @default - No path conditions.\n   * @deprecated Use `conditions` instead.\n   */\n  readonly pathPatterns?: string[];\n}\n\n/**\n * Properties for defining a listener rule\n */\nexport interface ApplicationListenerRuleProps extends BaseApplicationListenerRuleProps {\n  /**\n   * The listener to attach the rule to\n   */\n  readonly listener: IApplicationListener;\n}\n\n/**\n * The content type for a fixed response\n * @deprecated superceded by `FixedResponseOptions`.\n */\nexport enum ContentType {\n  TEXT_PLAIN = 'text/plain',\n  TEXT_CSS = 'text/css',\n  TEXT_HTML = 'text/html',\n  APPLICATION_JAVASCRIPT = 'application/javascript',\n  APPLICATION_JSON = 'application/json'\n}\n\n/**\n * A fixed response\n * @deprecated superceded by `ListenerAction.fixedResponse()`.\n */\nexport interface FixedResponse {\n  /**\n   * The HTTP response code (2XX, 4XX or 5XX)\n   */\n  readonly statusCode: string;\n\n  /**\n   * The content type\n   *\n   * @default text/plain\n   */\n  readonly contentType?: ContentType;\n\n  /**\n   * The message\n   *\n   * @default no message\n   */\n  readonly messageBody?: string;\n}\n\n/**\n * A redirect response\n * @deprecated superceded by `ListenerAction.redirect()`.\n */\nexport interface RedirectResponse {\n  /**\n   * The hostname. This component is not percent-encoded. The hostname can contain #{host}.\n   *\n   * @default origin host of request\n   */\n  readonly host?: string;\n  /**\n   * The absolute path, starting with the leading \"/\". This component is not percent-encoded.\n   * The path can contain #{host}, #{path}, and #{port}.\n   *\n   * @default origin path of request\n   */\n  readonly path?: string;\n  /**\n   * The port. You can specify a value from 1 to 65535 or #{port}.\n   *\n   * @default origin port of request\n   */\n  readonly port?: string;\n  /**\n   * The protocol. You can specify HTTP, HTTPS, or #{protocol}. You can redirect HTTP to HTTP,\n   * HTTP to HTTPS, and HTTPS to HTTPS. You cannot redirect HTTPS to HTTP.\n   *\n   * @default origin protocol of request\n   */\n  readonly protocol?: string;\n  /**\n   * The query parameters, URL-encoded when necessary, but not percent-encoded.\n   * Do not include the leading \"?\", as it is automatically added.\n   * You can specify any of the reserved keywords.\n   *\n   * @default origin query string of request\n   */\n  readonly query?: string;\n  /**\n   * The HTTP redirect code (HTTP_301 or HTTP_302)\n   */\n  readonly statusCode: string;\n}\n\n/**\n * Define a new listener rule\n */\nexport class ApplicationListenerRule extends CoreConstruct {\n  /**\n   * The ARN of this rule\n   */\n  public readonly listenerRuleArn: string;\n\n  private readonly conditions: ListenerCondition[];\n  private readonly legacyConditions: {[key: string]: string[]} = {};\n\n  private readonly listener: IApplicationListener;\n  private action?: IListenerAction;\n\n  constructor(scope: Construct, id: string, props: ApplicationListenerRuleProps) {\n    super(scope, id);\n\n    this.conditions = props.conditions || [];\n\n    const hasPathPatterns = props.pathPatterns || props.pathPattern;\n    if (this.conditions.length === 0 && !props.hostHeader && !hasPathPatterns) {\n      throw new Error('At least one of \\'conditions\\', \\'hostHeader\\', \\'pathPattern\\' or \\'pathPatterns\\' is required when defining a load balancing rule.');\n    }\n\n    const possibleActions: Array<keyof ApplicationListenerRuleProps> = ['action', 'targetGroups', 'fixedResponse', 'redirectResponse'];\n    const providedActions = possibleActions.filter(action => props[action] !== undefined);\n    if (providedActions.length > 1) {\n      throw new Error(`'${providedActions}' specified together, specify only one`);\n    }\n\n    if (!cdk.Token.isUnresolved(props.priority) && props.priority <= 0) {\n      throw new Error('Priority must have value greater than or equal to 1');\n    }\n\n    this.listener = props.listener;\n\n    const resource = new CfnListenerRule(this, 'Resource', {\n      listenerArn: props.listener.listenerArn,\n      priority: props.priority,\n      conditions: cdk.Lazy.any({ produce: () => this.renderConditions() }),\n      actions: cdk.Lazy.any({ produce: () => this.action ? this.action.renderActions() : [] }),\n    });\n\n    if (props.hostHeader) {\n      this.setCondition('host-header', [props.hostHeader]);\n    }\n\n    if (hasPathPatterns) {\n      if (props.pathPattern && props.pathPatterns) {\n        throw new Error('Both `pathPatterns` and `pathPattern` are specified, specify only one');\n      }\n      const pathPattern = props.pathPattern ? [props.pathPattern] : props.pathPatterns;\n      this.setCondition('path-pattern', pathPattern);\n    }\n\n    if (props.action) {\n      this.configureAction(props.action);\n    }\n\n    (props.targetGroups || []).forEach((group) => {\n      this.configureAction(ListenerAction.forward([group]));\n    });\n\n    if (props.fixedResponse) {\n      this.addFixedResponse(props.fixedResponse);\n    } else if (props.redirectResponse) {\n      this.addRedirectResponse(props.redirectResponse);\n    }\n\n    this.listenerRuleArn = resource.ref;\n  }\n\n  /**\n   * Add a non-standard condition to this rule\n   *\n   * If the condition conflicts with an already set condition, it will be overwritten by the one you specified.\n   *\n   * @deprecated use `addCondition` instead.\n   */\n  public setCondition(field: string, values: string[] | undefined) {\n    if (values === undefined) {\n      delete this.legacyConditions[field];\n      return;\n    }\n\n    this.legacyConditions[field] = values;\n  }\n\n  /**\n   * Add a non-standard condition to this rule\n   */\n  public addCondition(condition: ListenerCondition) {\n    this.conditions.push(condition);\n  }\n\n  /**\n   * Configure the action to perform for this rule\n   */\n  public configureAction(action: ListenerAction) {\n    // It might make sense to 'throw' here.\n    //\n    // However, programs may already exist out there which configured an action twice,\n    // in which case the second action accidentally overwrite the initial action, and in some\n    // way ended up with a program that did what the author intended. If we were to add throw now,\n    // the previously working program would be broken.\n    //\n    // Instead, signal this through a warning.\n    // @deprecate: upon the next major version bump, replace this with a `throw`\n    if (this.action) {\n      cdk.Annotations.of(this).addWarning('An Action already existed on this ListenerRule and was replaced. Configure exactly one default Action.');\n    }\n\n    action.bind(this, this.listener, this);\n    this.action = action;\n  }\n\n  /**\n   * Add a TargetGroup to load balance to\n   *\n   * @deprecated Use configureAction instead\n   */\n  public addTargetGroup(targetGroup: IApplicationTargetGroup) {\n    this.configureAction(ListenerAction.forward([targetGroup]));\n  }\n\n  /**\n   * Add a fixed response\n   *\n   * @deprecated Use configureAction instead\n   */\n  public addFixedResponse(fixedResponse: FixedResponse) {\n    validateFixedResponse(fixedResponse);\n\n    this.configureAction(ListenerAction.fixedResponse(cdk.Token.asNumber(fixedResponse.statusCode), {\n      contentType: fixedResponse.contentType,\n      messageBody: fixedResponse.messageBody,\n    }));\n  }\n\n  /**\n   * Add a redirect response\n   *\n   * @deprecated Use configureAction instead\n   */\n  public addRedirectResponse(redirectResponse: RedirectResponse) {\n    validateRedirectResponse(redirectResponse);\n\n    this.configureAction(ListenerAction.redirect({\n      host: redirectResponse.host,\n      path: redirectResponse.path,\n      permanent: redirectResponse.statusCode === 'HTTP_301',\n      port: redirectResponse.port,\n      protocol: redirectResponse.protocol,\n      query: redirectResponse.query,\n    }));\n  }\n\n  /**\n   * Validate the rule\n   */\n  protected validate() {\n    if (this.action === undefined) {\n      return ['Listener rule needs at least one action'];\n    }\n\n    const legacyConditionFields = Object.keys(this.legacyConditions);\n    if (legacyConditionFields.length === 0 && this.conditions.length === 0) {\n      return ['Listener rule needs at least one condition'];\n    }\n\n    return [];\n  }\n\n  /**\n   * Render the conditions for this rule\n   */\n  private renderConditions(): any {\n    const legacyConditions = Object.entries(this.legacyConditions).map(([field, values]) => {\n      return { field, values };\n    });\n    const conditions = this.conditions.map(condition => condition.renderRawCondition());\n\n    return [\n      ...legacyConditions,\n      ...conditions,\n    ];\n  }\n}\n\n/**\n * Validate the status code and message body of a fixed response\n * @internal\n * @deprecated\n */\nexport function validateFixedResponse(fixedResponse: FixedResponse) {\n  if (fixedResponse.statusCode && !/^(2|4|5)\\d\\d$/.test(fixedResponse.statusCode)) {\n    throw new Error('`statusCode` must be 2XX, 4XX or 5XX.');\n  }\n\n  if (fixedResponse.messageBody && fixedResponse.messageBody.length > 1024) {\n    throw new Error('`messageBody` cannot have more than 1024 characters.');\n  }\n}\n\n/**\n * Validate the status code and message body of a redirect response\n * @internal\n * @deprecated\n */\nexport function validateRedirectResponse(redirectResponse: RedirectResponse) {\n  if (redirectResponse.protocol && !/^(HTTPS?|#\\{protocol\\})$/i.test(redirectResponse.protocol)) {\n    throw new Error('`protocol` must be HTTP, HTTPS, or #{protocol}.');\n  }\n\n  if (!redirectResponse.statusCode || !/^HTTP_30[12]$/.test(redirectResponse.statusCode)) {\n    throw new Error('`statusCode` must be HTTP_301 or HTTP_302.');\n  }\n}\n"]}

@@ -14,12 +14,9 @@ import * as ec2 from '@aws-cdk/aws-ec2';

/**
* Basic properties for an ApplicationListener.
*
* @stability stable
* Basic properties for an ApplicationListener
*/
export interface BaseApplicationListenerProps {
/**
* The protocol to use.
* The protocol to use
*
* @default - Determined from port if known.
* @stability stable
*/

@@ -31,7 +28,6 @@ readonly protocol?: ApplicationProtocol;

* @default - Determined from protocol if known.
* @stability stable
*/
readonly port?: number;
/**
* (deprecated) The certificates to use on this listener.
* The certificates to use on this listener
*

@@ -43,8 +39,5 @@ * @default - No certificates.

/**
* Certificate list of ACM cert ARNs.
* Certificate list of ACM cert ARNs. You must provide exactly one certificate if the listener protocol is HTTPS or TLS.
*
* You must provide exactly one certificate if the listener protocol is HTTPS or TLS.
*
* @default - No certificates.
* @stability stable
*/

@@ -56,7 +49,6 @@ readonly certificates?: IListenerCertificate[];

* @default - The current predefined security policy.
* @stability stable
*/
readonly sslPolicy?: SslPolicy;
/**
* Default target groups to load balance to.
* Default target groups to load balance to
*

@@ -70,7 +62,6 @@ * All target groups will be load balanced to with equal weight and without

* @default - None.
* @stability stable
*/
readonly defaultTargetGroups?: IApplicationTargetGroup[];
/**
* Default action to take for requests to this listener.
* Default action to take for requests to this listener
*

@@ -85,9 +76,8 @@ * This allows full control of the default action of the load balancer,

* @default - None.
* @stability stable
*/
readonly defaultAction?: ListenerAction;
/**
* Allow anyone to connect to this listener.
* Allow anyone to connect to the load balancer on the listener port
*
* If this is specified, the listener will be opened up to anyone who can reach it.
* If this is specified, the load balancer will be opened up to anyone who can reach it.
* For internal load balancers this is anyone in the same VPC. For public load

@@ -98,6 +88,5 @@ * balancers, this is anyone on the internet.

* balancer, set this to `false` and use the listener's `connections`
* object to selectively grant access to the listener.
* object to selectively grant access to the load balancer on the listener port.
*
* @default true
* @stability stable
*/

@@ -107,11 +96,7 @@ readonly open?: boolean;

/**
* Properties for defining a standalone ApplicationListener.
*
* @stability stable
* Properties for defining a standalone ApplicationListener
*/
export interface ApplicationListenerProps extends BaseApplicationListenerProps {
/**
* The load balancer to attach this listener to.
*
* @stability stable
* The load balancer to attach this listener to
*/

@@ -121,19 +106,13 @@ readonly loadBalancer: IApplicationLoadBalancer;

/**
* Options for ApplicationListener lookup.
*
* @stability stable
* Options for ApplicationListener lookup
*/
export interface ApplicationListenerLookupOptions extends BaseListenerLookupOptions {
/**
* ARN of the listener to look up.
*
* ARN of the listener to look up
* @default - does not filter by listener arn
* @stability stable
*/
readonly listenerArn?: string;
/**
* Filter listeners by listener protocol.
*
* Filter listeners by listener protocol
* @default - does not filter by listener protocol
* @stability stable
*/

@@ -143,5 +122,4 @@ readonly listenerProtocol?: ApplicationProtocol;

/**
* Define an ApplicationListener.
* Define an ApplicationListener
*
* @stability stable
* @resource AWS::ElasticLoadBalancingV2::Listener

@@ -152,22 +130,14 @@ */

* Look up an ApplicationListener.
*
* @stability stable
*/
static fromLookup(scope: Construct, id: string, options: ApplicationListenerLookupOptions): IApplicationListener;
/**
* Import an existing listener.
*
* @stability stable
* Import an existing listener
*/
static fromApplicationListenerAttributes(scope: Construct, id: string, attrs: ApplicationListenerAttributes): IApplicationListener;
/**
* Manage connections to this ApplicationListener.
*
* @stability stable
* Manage connections to this ApplicationListener
*/
readonly connections: ec2.Connections;
/**
* Load balancer this listener is associated with.
*
* @stability stable
* Load balancer this listener is associated with
*/

@@ -183,8 +153,5 @@ readonly loadBalancer: IApplicationLoadBalancer;

private readonly protocol;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: ApplicationListenerProps);
/**
* (deprecated) Add one or more certificates to this listener.
* Add one or more certificates to this listener.
*

@@ -204,8 +171,6 @@ * After the first certificate, this creates ApplicationListenerCertificates

* listener resource to have a length of 1.
*
* @stability stable
*/
addCertificates(id: string, certificates: IListenerCertificate[]): void;
/**
* Perform the given default action on incoming requests.
* Perform the given default action on incoming requests
*

@@ -219,4 +184,2 @@ * This allows full control of the default action of the load balancer,

* default Action).
*
* @stability stable
*/

@@ -233,4 +196,2 @@ addAction(id: string, props: AddApplicationActionProps): void;

* become the default Action for this listener).
*
* @stability stable
*/

@@ -251,7 +212,6 @@ addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void;

* @returns The newly created target group
* @stability stable
*/
addTargets(id: string, props: AddApplicationTargetsProps): ApplicationTargetGroup;
/**
* (deprecated) Add a fixed response.
* Add a fixed response
*

@@ -262,3 +222,3 @@ * @deprecated Use `addAction()` instead

/**
* (deprecated) Add a redirect response.
* Add a redirect response
*

@@ -272,4 +232,2 @@ * @deprecated Use `addAction()` instead

* Don't call this directly. It is called by ApplicationTargetGroup.
*
* @stability stable
*/

@@ -279,4 +237,2 @@ registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void;

* Validate this listener.
*
* @stability stable
*/

@@ -290,17 +246,12 @@ protected validate(): string[];

/**
* Properties to reference an existing listener.
*
* @stability stable
* Properties to reference an existing listener
*/
export interface IApplicationListener extends IResource, ec2.IConnectable {
/**
* ARN of the listener.
*
* @stability stable
* @attribute true
* ARN of the listener
* @attribute
*/
readonly listenerArn: string;
/**
* (deprecated) Add one or more certificates to this listener.
*
* Add one or more certificates to this listener.
* @deprecated use `addCertificates()`

@@ -311,4 +262,2 @@ */

* Add one or more certificates to this listener.
*
* @stability stable
*/

@@ -321,4 +270,2 @@ addCertificates(id: string, certificates: IListenerCertificate[]): void;

* At least one TargetGroup must be added without conditions.
*
* @stability stable
*/

@@ -336,3 +283,2 @@ addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void;

* @returns The newly created target group
* @stability stable
*/

@@ -344,4 +290,2 @@ addTargets(id: string, props: AddApplicationTargetsProps): ApplicationTargetGroup;

* Don't call this directly. It is called by ApplicationTargetGroup.
*
* @stability stable
*/

@@ -351,15 +295,11 @@ registerConnectable(connectable: ec2.IConnectable, portRange: ec2.Port): void;

/**
* Properties to reference an existing listener.
*
* @stability stable
* Properties to reference an existing listener
*/
export interface ApplicationListenerAttributes {
/**
* ARN of the listener.
*
* @stability stable
* ARN of the listener
*/
readonly listenerArn: string;
/**
* (deprecated) Security group ID of the load balancer this listener is associated with.
* Security group ID of the load balancer this listener is associated with
*

@@ -370,15 +310,12 @@ * @deprecated use `securityGroup` instead

/**
* Security group of the load balancer this listener is associated with.
*
* @stability stable
* Security group of the load balancer this listener is associated with
*/
readonly securityGroup?: ec2.ISecurityGroup;
/**
* The default port on which this listener is listening.
*
* @stability stable
* The default port on which this listener is listening
*/
readonly defaultPort?: number;
/**
* (deprecated) Whether the imported security group allows all outbound traffic or not when imported using `securityGroupId`.
* Whether the imported security group allows all outbound traffic or not when
* imported using `securityGroupId`
*

@@ -388,2 +325,3 @@ * Unless set to `false`, no egress rules will be added to the security group.

* @default true
*
* @deprecated use `securityGroup` instead

@@ -394,9 +332,7 @@ */

/**
* Properties for adding a conditional load balancing rule.
*
* @stability stable
* Properties for adding a conditional load balancing rule
*/
export interface AddRuleProps {
/**
* Priority of this target group.
* Priority of this target group
*

@@ -410,3 +346,2 @@ * The rule with the lowest priority will be used for every request.

* @default Target groups are used as defaults
* @stability stable
*/

@@ -417,9 +352,9 @@ readonly priority?: number;

*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html
*
* @default - No conditions.
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html
* @stability stable
*/
readonly conditions?: ListenerCondition[];
/**
* (deprecated) Rule applies if the requested host matches the indicated host.
* Rule applies if the requested host matches the indicated host
*

@@ -430,4 +365,5 @@ * May contain up to three '*' wildcards.

*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#host-conditions
*
* @default No host condition
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#host-conditions
* @deprecated Use `conditions` instead.

@@ -437,3 +373,3 @@ */

/**
* (deprecated) Rule applies if the requested path matches the given path pattern.
* Rule applies if the requested path matches the given path pattern
*

@@ -444,4 +380,4 @@ * May contain up to three '*' wildcards.

*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @default No path condition
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @deprecated Use `conditions` instead.

@@ -451,3 +387,3 @@ */

/**
* (deprecated) Rule applies if the requested path matches any of the given patterns.
* Rule applies if the requested path matches any of the given patterns.
*

@@ -458,4 +394,4 @@ * May contain up to three '*' wildcards.

*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @default - No path condition.
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-listeners.html#path-conditions
* @deprecated Use `conditions` instead.

@@ -466,11 +402,7 @@ */

/**
* Properties for adding a new target group to a listener.
*
* @stability stable
* Properties for adding a new target group to a listener
*/
export interface AddApplicationTargetGroupsProps extends AddRuleProps {
/**
* Target groups to forward requests to.
*
* @stability stable
* Target groups to forward requests to
*/

@@ -480,11 +412,7 @@ readonly targetGroups: IApplicationTargetGroup[];

/**
* Properties for adding a new action to a listener.
*
* @stability stable
* Properties for adding a new action to a listener
*/
export interface AddApplicationActionProps extends AddRuleProps {
/**
* Action to perform.
*
* @stability stable
* Action to perform
*/

@@ -494,19 +422,15 @@ readonly action: ListenerAction;

/**
* Properties for adding new targets to a listener.
*
* @stability stable
* Properties for adding new targets to a listener
*/
export interface AddApplicationTargetsProps extends AddRuleProps {
/**
* The protocol to use.
* The protocol to use
*
* @default Determined from port if known
* @stability stable
*/
readonly protocol?: ApplicationProtocol;
/**
* The protocol version to use.
* The protocol version to use
*
* @default ApplicationProtocolVersion.HTTP1
* @stability stable
*/

@@ -518,7 +442,7 @@ readonly protocolVersion?: ApplicationProtocolVersion;

* @default Determined from protocol if known
* @stability stable
*/
readonly port?: number;
/**
* The time period during which the load balancer sends a newly registered target a linearly increasing share of the traffic to the target group.
* The time period during which the load balancer sends a newly registered
* target a linearly increasing share of the traffic to the target group.
*

@@ -528,3 +452,2 @@ * The range is 30-900 seconds (15 minutes).

* @default 0
* @stability stable
*/

@@ -541,3 +464,2 @@ readonly slowStart?: Duration;

* @default Stickiness disabled
* @stability stable
*/

@@ -556,3 +478,2 @@ readonly stickinessCookieDuration?: Duration;

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/sticky-sessions.html
* @stability stable
*/

@@ -565,4 +486,2 @@ readonly stickinessCookieName?: string;

* target. All target must be of the same type.
*
* @stability stable
*/

@@ -578,3 +497,2 @@ readonly targets?: IApplicationLoadBalancerTarget[];

* @default Automatically generated
* @stability stable
*/

@@ -588,10 +506,8 @@ readonly targetGroupName?: string;

* @default Duration.minutes(5)
* @stability stable
*/
readonly deregistrationDelay?: Duration;
/**
* Health check configuration.
* Health check configuration
*
* @default No health check
* @stability stable
*/

@@ -603,3 +519,2 @@ readonly healthCheck?: HealthCheck;

* @default round_robin.
* @stability stable
*/

@@ -609,3 +524,3 @@ readonly loadBalancingAlgorithmType?: TargetGroupLoadBalancingAlgorithmType;

/**
* (deprecated) Properties for adding a fixed response to a listener.
* Properties for adding a fixed response to a listener
*

@@ -617,3 +532,3 @@ * @deprecated Use `ApplicationListener.addAction` instead.

/**
* (deprecated) Properties for adding a redirect response to a listener.
* Properties for adding a redirect response to a listener
*

@@ -620,0 +535,0 @@ * @deprecated Use `ApplicationListener.addAction` instead.

@@ -9,16 +9,13 @@ import * as cloudwatch from '@aws-cdk/aws-cloudwatch';

/**
* Properties for defining an Application Load Balancer.
*
* @stability stable
* Properties for defining an Application Load Balancer
*/
export interface ApplicationLoadBalancerProps extends BaseLoadBalancerProps {
/**
* Security group to associate with this load balancer.
* Security group to associate with this load balancer
*
* @default A security group is created
* @stability stable
*/
readonly securityGroup?: ec2.ISecurityGroup;
/**
* The type of IP addresses to use.
* The type of IP addresses to use
*

@@ -28,3 +25,2 @@ * Only applies to application load balancers.

* @default IpAddressType.Ipv4
* @stability stable
*/

@@ -36,10 +32,8 @@ readonly ipAddressType?: IpAddressType;

* @default true
* @stability stable
*/
readonly http2Enabled?: boolean;
/**
* The load balancer idle timeout, in seconds.
* The load balancer idle timeout, in seconds
*
* @default 60
* @stability stable
*/

@@ -49,5 +43,3 @@ readonly idleTimeout?: Duration;

/**
* Options for looking up an ApplicationLoadBalancer.
*
* @stability stable
* Options for looking up an ApplicationLoadBalancer
*/

@@ -57,5 +49,4 @@ export interface ApplicationLoadBalancerLookupOptions extends BaseLoadBalancerLookupOptions {

/**
* Define an Application Load Balancer.
* Define an Application Load Balancer
*
* @stability stable
* @resource AWS::ElasticLoadBalancingV2::LoadBalancer

@@ -66,76 +57,43 @@ */

* Look up an application load balancer.
*
* @stability stable
*/
static fromLookup(scope: Construct, id: string, options: ApplicationLoadBalancerLookupOptions): IApplicationLoadBalancer;
/**
* Import an existing Application Load Balancer.
*
* @stability stable
* Import an existing Application Load Balancer
*/
static fromApplicationLoadBalancerAttributes(scope: Construct, id: string, attrs: ApplicationLoadBalancerAttributes): IApplicationLoadBalancer;
/**
* The network connections associated with this resource.
*
* @stability stable
*/
readonly connections: ec2.Connections;
/**
* The IP Address Type for this load balancer.
*
* @stability stable
*/
readonly ipAddressType?: IpAddressType;
/**
* A list of listeners that have been added to the load balancer.
*
* This list is only valid for owned constructs.
*
* @stability stable
*/
readonly listeners: ApplicationListener[];
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: ApplicationLoadBalancerProps);
/**
* Add a new listener to this load balancer.
*
* @stability stable
* Add a new listener to this load balancer
*/
addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;
/**
* Add a redirection listener to this load balancer.
*
* @stability stable
* Add a redirection listener to this load balancer
*/
addRedirect(props?: ApplicationLoadBalancerRedirectConfig): ApplicationListener;
/**
* Add a security group to this load balancer.
*
* @stability stable
* Add a security group to this load balancer
*/
addSecurityGroup(securityGroup: ec2.ISecurityGroup): void;
/**
* Return the given named metric for this Application Load Balancer.
* Return the given named metric for this Application Load Balancer
*
* @default Average over 5 minutes
* @stability stable
*/
metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The total number of concurrent TCP connections active from clients to the load balancer and from the load balancer to targets.
* The total number of concurrent TCP connections active from clients to the
* load balancer and from the load balancer to targets.
*
* @default Sum over 5 minutes
* @stability stable
*/
metricActiveConnectionCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of TLS connections initiated by the client that did not establish a session with the load balancer.
*
* Possible causes include a
* The number of TLS connections initiated by the client that did not
* establish a session with the load balancer. Possible causes include a
* mismatch of ciphers or protocols.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -147,3 +105,2 @@ metricClientTlsNegotiationErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -155,3 +112,2 @@ metricConsumedLCUs(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -163,10 +119,9 @@ metricHttpFixedResponseCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricHttpRedirectCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of redirect actions that couldn't be completed because the URL in the response location header is larger than 8K.
* The number of redirect actions that couldn't be completed because the URL
* in the response location header is larger than 8K.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -180,7 +135,7 @@ metricHttpRedirectUrlLimitExceededCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricHttpCodeElb(code: HttpCodeElb, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets in the load balancer.
* The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets
* in the load balancer.
*

@@ -190,3 +145,2 @@ * This does not include any response codes generated by the load balancer.

* @default Sum over 5 minutes
* @stability stable
*/

@@ -198,3 +152,2 @@ metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -206,10 +159,9 @@ metricIpv6ProcessedBytes(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricIpv6RequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The total number of new TCP connections established from clients to the load balancer and from the load balancer to targets.
* The total number of new TCP connections established from clients to the
* load balancer and from the load balancer to targets.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -221,10 +173,9 @@ metricNewConnectionCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricProcessedBytes(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of connections that were rejected because the load balancer had reached its maximum number of connections.
* The number of connections that were rejected because the load balancer had
* reached its maximum number of connections.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -238,3 +189,2 @@ metricRejectedConnectionCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -246,3 +196,2 @@ metricRequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -254,3 +203,2 @@ metricRuleEvaluations(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -262,3 +210,2 @@ metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Average over 5 minutes
* @stability stable
*/

@@ -272,7 +219,6 @@ metricTargetResponseTime(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of user authentications that could not be completed.
* The number of user authentications that could not be completed
*

@@ -284,10 +230,10 @@ * Because an authenticate action was misconfigured, the load balancer

* @default Sum over 5 minutes
* @stability stable
*/
metricElbAuthError(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of user authentications that could not be completed because the IdP denied access to the user or an authorization code was used more than once.
* The number of user authentications that could not be completed because the
* IdP denied access to the user or an authorization code was used more than
* once.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -301,3 +247,2 @@ metricElbAuthFailure(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Average over 5 minutes
* @stability stable
*/

@@ -312,3 +257,2 @@ metricElbAuthLatency(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -319,7 +263,5 @@ metricElbAuthSuccess(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

/**
* Count of HTTP status originating from the load balancer.
* Count of HTTP status originating from the load balancer
*
* This count does not include any response codes generated by the targets.
*
* @stability stable
*/

@@ -329,4 +271,2 @@ export declare enum HttpCodeElb {

* The number of HTTP 3XX redirection codes that originate from the load balancer.
*
* @stability stable
*/

@@ -340,4 +280,2 @@ ELB_3XX_COUNT = "HTTPCode_ELB_3XX_Count",

* include any response codes generated by the targets.
*
* @stability stable
*/

@@ -347,4 +285,2 @@ ELB_4XX_COUNT = "HTTPCode_ELB_4XX_Count",

* The number of HTTP 5XX server error codes that originate from the load balancer.
*
* @stability stable
*/

@@ -354,29 +290,19 @@ ELB_5XX_COUNT = "HTTPCode_ELB_5XX_Count"

/**
* Count of HTTP status originating from the targets.
*
* @stability stable
* Count of HTTP status originating from the targets
*/
export declare enum HttpCodeTarget {
/**
* The number of 2xx response codes from targets.
*
* @stability stable
* The number of 2xx response codes from targets
*/
TARGET_2XX_COUNT = "HTTPCode_Target_2XX_Count",
/**
* The number of 3xx response codes from targets.
*
* @stability stable
* The number of 3xx response codes from targets
*/
TARGET_3XX_COUNT = "HTTPCode_Target_3XX_Count",
/**
* The number of 4xx response codes from targets.
*
* @stability stable
* The number of 4xx response codes from targets
*/
TARGET_4XX_COUNT = "HTTPCode_Target_4XX_Count",
/**
* The number of 5xx response codes from targets.
*
* @stability stable
* The number of 5xx response codes from targets
*/

@@ -386,11 +312,7 @@ TARGET_5XX_COUNT = "HTTPCode_Target_5XX_Count"

/**
* An application load balancer.
*
* @stability stable
* An application load balancer
*/
export interface IApplicationLoadBalancer extends ILoadBalancerV2, ec2.IConnectable {
/**
* The ARN of this load balancer.
*
* @stability stable
* The ARN of this load balancer
*/

@@ -400,14 +322,10 @@ readonly loadBalancerArn: string;

* The VPC this load balancer has been created in (if available).
*
* If this interface is the result of an import call to fromApplicationLoadBalancerAttributes,
* the vpc attribute will be undefined unless specified in the optional properties of that method.
*
* @stability stable
*/
readonly vpc?: ec2.IVpc;
/**
* The IP Address Type for this load balancer.
* The IP Address Type for this load balancer
*
* @default IpAddressType.IPV4
* @stability stable
*/

@@ -417,12 +335,7 @@ readonly ipAddressType?: IpAddressType;

* A list of listeners that have been added to the load balancer.
*
* This list is only valid for owned constructs.
*
* @stability stable
*/
readonly listeners: ApplicationListener[];
/**
* Add a new listener to this load balancer.
*
* @stability stable
* Add a new listener to this load balancer
*/

@@ -432,35 +345,27 @@ addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;

/**
* Properties to reference an existing load balancer.
*
* @stability stable
* Properties to reference an existing load balancer
*/
export interface ApplicationLoadBalancerAttributes {
/**
* ARN of the load balancer.
*
* @stability stable
* ARN of the load balancer
*/
readonly loadBalancerArn: string;
/**
* ID of the load balancer's security group.
*
* @stability stable
* ID of the load balancer's security group
*/
readonly securityGroupId: string;
/**
* The canonical hosted zone ID of this load balancer.
* The canonical hosted zone ID of this load balancer
*
* @default - When not provided, LB cannot be used as Route53 Alias target.
* @stability stable
*/
readonly loadBalancerCanonicalHostedZoneId?: string;
/**
* The DNS name of this load balancer.
* The DNS name of this load balancer
*
* @default - When not provided, LB cannot be used as Route53 Alias target.
* @stability stable
*/
readonly loadBalancerDnsName?: string;
/**
* Whether the security group allows all outbound traffic or not.
* Whether the security group allows all outbound traffic or not
*

@@ -470,11 +375,9 @@ * Unless set to `false`, no egress rules will be added to the security group.

* @default true
* @stability stable
*/
readonly securityGroupAllowsAllOutbound?: boolean;
/**
* The VPC this load balancer has been created in, if available.
* The VPC this load balancer has been created in, if available
*
* @default - If the Load Balancer was imported and a VPC was not specified,
* the VPC is not available.
* @stability stable
*/

@@ -484,37 +387,31 @@ readonly vpc?: ec2.IVpc;

/**
* Properties for a redirection config.
*
* @stability stable
* Properties for a redirection config
*/
export interface ApplicationLoadBalancerRedirectConfig {
/**
* The protocol of the listener being created.
* The protocol of the listener being created
*
* @default HTTP
* @stability stable
*/
readonly sourceProtocol?: ApplicationProtocol;
/**
* The port number to listen to.
* The port number to listen to
*
* @default 80
* @stability stable
*/
readonly sourcePort?: number;
/**
* The protocol of the redirection target.
* The protocol of the redirection target
*
* @default HTTPS
* @stability stable
*/
readonly targetProtocol?: ApplicationProtocol;
/**
* The port number to redirect to.
* The port number to redirect to
*
* @default 443
* @stability stable
*/
readonly targetPort?: number;
/**
* Allow anyone to connect to this listener.
* Allow anyone to connect to this listener
*

@@ -530,5 +427,4 @@ * If this is specified, the listener will be opened up to anyone who can reach it.

* @default true
* @stability stable
*/
readonly open?: boolean;
}

@@ -18,11 +18,7 @@ "use strict";

/**
* Define an Application Load Balancer.
* Define an Application Load Balancer
*
* @stability stable
* @resource AWS::ElasticLoadBalancingV2::LoadBalancer
*/
class ApplicationLoadBalancer extends base_load_balancer_1.BaseLoadBalancer {
/**
* @stability stable
*/
constructor(scope, id, props) {

@@ -53,4 +49,2 @@ var _b;

* Look up an application load balancer.
*
* @stability stable
*/

@@ -66,5 +60,3 @@ static fromLookup(scope, id, options) {

/**
* Import an existing Application Load Balancer.
*
* @stability stable
* Import an existing Application Load Balancer
*/

@@ -76,5 +68,3 @@ static fromApplicationLoadBalancerAttributes(scope, id, attrs) {

/**
* Add a new listener to this load balancer.
*
* @stability stable
* Add a new listener to this load balancer
*/

@@ -91,5 +81,3 @@ addListener(id, props) {

/**
* Add a redirection listener to this load balancer.
*
* @stability stable
* Add a redirection listener to this load balancer
*/

@@ -113,5 +101,3 @@ addRedirect(props = {}) {

/**
* Add a security group to this load balancer.
*
* @stability stable
* Add a security group to this load balancer
*/

@@ -122,6 +108,5 @@ addSecurityGroup(securityGroup) {

/**
* Return the given named metric for this Application Load Balancer.
* Return the given named metric for this Application Load Balancer
*
* @default Average over 5 minutes
* @stability stable
*/

@@ -137,6 +122,6 @@ metric(metricName, props) {

/**
* The total number of concurrent TCP connections active from clients to the load balancer and from the load balancer to targets.
* The total number of concurrent TCP connections active from clients to the
* load balancer and from the load balancer to targets.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -147,9 +132,7 @@ metricActiveConnectionCount(props) {

/**
* The number of TLS connections initiated by the client that did not establish a session with the load balancer.
*
* Possible causes include a
* The number of TLS connections initiated by the client that did not
* establish a session with the load balancer. Possible causes include a
* mismatch of ciphers or protocols.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -163,3 +146,2 @@ metricClientTlsNegotiationErrorCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -176,3 +158,2 @@ metricConsumedLCUs(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -186,3 +167,2 @@ metricHttpFixedResponseCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -193,6 +173,6 @@ metricHttpRedirectCount(props) {

/**
* The number of redirect actions that couldn't be completed because the URL in the response location header is larger than 8K.
* The number of redirect actions that couldn't be completed because the URL
* in the response location header is larger than 8K.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -208,3 +188,2 @@ metricHttpRedirectUrlLimitExceededCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -219,3 +198,4 @@ metricHttpCodeElb(code, props) {

/**
* The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets in the load balancer.
* The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets
* in the load balancer.
*

@@ -225,3 +205,2 @@ * This does not include any response codes generated by the load balancer.

* @default Sum over 5 minutes
* @stability stable
*/

@@ -239,3 +218,2 @@ metricHttpCodeTarget(code, props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -249,3 +227,2 @@ metricIpv6ProcessedBytes(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -256,6 +233,6 @@ metricIpv6RequestCount(props) {

/**
* The total number of new TCP connections established from clients to the load balancer and from the load balancer to targets.
* The total number of new TCP connections established from clients to the
* load balancer and from the load balancer to targets.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -269,3 +246,2 @@ metricNewConnectionCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -276,6 +252,6 @@ metricProcessedBytes(props) {

/**
* The number of connections that were rejected because the load balancer had reached its maximum number of connections.
* The number of connections that were rejected because the load balancer had
* reached its maximum number of connections.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -291,3 +267,2 @@ metricRejectedConnectionCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -301,3 +276,2 @@ metricRequestCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -311,3 +285,2 @@ metricRuleEvaluations(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -324,3 +297,2 @@ metricTargetConnectionErrorCount(props) {

* @default Average over 5 minutes
* @stability stable
*/

@@ -339,3 +311,2 @@ metricTargetResponseTime(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -349,3 +320,3 @@ metricTargetTLSNegotiationErrorCount(props) {

/**
* The number of user authentications that could not be completed.
* The number of user authentications that could not be completed
*

@@ -357,3 +328,2 @@ * Because an authenticate action was misconfigured, the load balancer

* @default Sum over 5 minutes
* @stability stable
*/

@@ -367,6 +337,7 @@ metricElbAuthError(props) {

/**
* The number of user authentications that could not be completed because the IdP denied access to the user or an authorization code was used more than once.
* The number of user authentications that could not be completed because the
* IdP denied access to the user or an authorization code was used more than
* once.
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -385,3 +356,2 @@ metricElbAuthFailure(props) {

* @default Average over 5 minutes
* @stability stable
*/

@@ -401,3 +371,2 @@ metricElbAuthLatency(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -419,26 +388,47 @@ metricElbAuthSuccess(props) {

_a = JSII_RTTI_SYMBOL_1;
ApplicationLoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ApplicationLoadBalancer", version: "1.144.0" };
ApplicationLoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ApplicationLoadBalancer", version: "1.145.0" };
/**
* Count of HTTP status originating from the load balancer.
* Count of HTTP status originating from the load balancer
*
* This count does not include any response codes generated by the targets.
*
* @stability stable
*/
var HttpCodeElb;
(function (HttpCodeElb) {
/**
* The number of HTTP 3XX redirection codes that originate from the load balancer.
*/
HttpCodeElb["ELB_3XX_COUNT"] = "HTTPCode_ELB_3XX_Count";
/**
* The number of HTTP 4XX client error codes that originate from the load balancer.
*
* Client errors are generated when requests are malformed or incomplete.
* These requests have not been received by the target. This count does not
* include any response codes generated by the targets.
*/
HttpCodeElb["ELB_4XX_COUNT"] = "HTTPCode_ELB_4XX_Count";
/**
* The number of HTTP 5XX server error codes that originate from the load balancer.
*/
HttpCodeElb["ELB_5XX_COUNT"] = "HTTPCode_ELB_5XX_Count";
})(HttpCodeElb = exports.HttpCodeElb || (exports.HttpCodeElb = {}));
/**
* Count of HTTP status originating from the targets.
*
* @stability stable
* Count of HTTP status originating from the targets
*/
var HttpCodeTarget;
(function (HttpCodeTarget) {
/**
* The number of 2xx response codes from targets
*/
HttpCodeTarget["TARGET_2XX_COUNT"] = "HTTPCode_Target_2XX_Count";
/**
* The number of 3xx response codes from targets
*/
HttpCodeTarget["TARGET_3XX_COUNT"] = "HTTPCode_Target_3XX_Count";
/**
* The number of 4xx response codes from targets
*/
HttpCodeTarget["TARGET_4XX_COUNT"] = "HTTPCode_Target_4XX_Count";
/**
* The number of 5xx response codes from targets
*/
HttpCodeTarget["TARGET_5XX_COUNT"] = "HTTPCode_Target_5XX_Count";

@@ -520,2 +510,2 @@ })(HttpCodeTarget = exports.HttpCodeTarget || (exports.HttpCodeTarget = {}));

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-load-balancer.js","sourceRoot":"","sources":["application-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as ec2 from '@aws-cdk/aws-ec2';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Duration, Lazy, Names, Resource } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Construct } from 'constructs';\nimport { ApplicationELBMetrics } from '../elasticloadbalancingv2-canned-metrics.generated';\nimport { BaseLoadBalancer, BaseLoadBalancerLookupOptions, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { IpAddressType, ApplicationProtocol } from '../shared/enums';\nimport { ApplicationListener, BaseApplicationListenerProps } from './application-listener';\nimport { ListenerAction } from './application-listener-action';\n\n                                                               \nexport interface ApplicationLoadBalancerProps extends BaseLoadBalancerProps {\n                                                                                                                   \n  readonly securityGroup?: ec2.ISecurityGroup;\n\n                                                                                                                                            \n  readonly ipAddressType?: IpAddressType;\n\n                                                                             \n  readonly http2Enabled?: boolean;\n\n                                                                                 \n  readonly idleTimeout?: Duration;\n}\n\n                                                            \nexport interface ApplicationLoadBalancerLookupOptions extends BaseLoadBalancerLookupOptions {\n}\n\n                                                                                                        \nexport class ApplicationLoadBalancer extends BaseLoadBalancer implements IApplicationLoadBalancer {\n                                                      \n  public static fromLookup(scope: Construct, id: string, options: ApplicationLoadBalancerLookupOptions): IApplicationLoadBalancer {\n    const props = BaseLoadBalancer._queryContextProvider(scope, {\n      userOptions: options,\n      loadBalancerType: cxschema.LoadBalancerType.APPLICATION,\n    });\n\n    return new LookedUpApplicationLoadBalancer(scope, id, props);\n  }\n\n                                                             \n  public static fromApplicationLoadBalancerAttributes(\n    scope: Construct, id: string, attrs: ApplicationLoadBalancerAttributes): IApplicationLoadBalancer {\n\n    return new ImportedApplicationLoadBalancer(scope, id, attrs);\n  }\n\n  public readonly connections: ec2.Connections;\n  public readonly ipAddressType?: IpAddressType;\n  public readonly listeners: ApplicationListener[];\n\n  constructor(scope: Construct, id: string, props: ApplicationLoadBalancerProps) {\n    super(scope, id, props, {\n      type: 'application',\n      securityGroups: Lazy.list({ produce: () => this.connections.securityGroups.map(sg => sg.securityGroupId) }),\n      ipAddressType: props.ipAddressType,\n    });\n\n    this.ipAddressType = props.ipAddressType ?? IpAddressType.IPV4;\n    const securityGroups = [props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: `Automatically created Security Group for ELB ${Names.uniqueId(this)}`,\n      allowAllOutbound: false,\n    })];\n    this.connections = new ec2.Connections({ securityGroups });\n    this.listeners = [];\n\n    if (props.http2Enabled === false) { this.setAttribute('routing.http2.enabled', 'false'); }\n    if (props.idleTimeout !== undefined) { this.setAttribute('idle_timeout.timeout_seconds', props.idleTimeout.toSeconds().toString()); }\n  }\n\n                                                         \n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    const listener = new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props,\n    });\n    this.listeners.push(listener);\n    return listener;\n  }\n\n                                                                 \n  public addRedirect(props: ApplicationLoadBalancerRedirectConfig = {}): ApplicationListener {\n    const sourcePort = props.sourcePort ?? 80;\n    const targetPort = (props.targetPort ?? 443).toString();\n    return this.addListener(`Redirect${sourcePort}To${targetPort}`, {\n      protocol: props.sourceProtocol ?? ApplicationProtocol.HTTP,\n      port: sourcePort,\n      open: props.open ?? true,\n      defaultAction: ListenerAction.redirect({\n        port: targetPort,\n        protocol: props.targetProtocol ?? ApplicationProtocol.HTTPS,\n        permanent: true,\n      }),\n    });\n  }\n\n                                                           \n  public addSecurityGroup(securityGroup: ec2.ISecurityGroup) {\n    this.connections.addSecurityGroup(securityGroup);\n  }\n\n                                                                                                                           \n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensionsMap: { LoadBalancer: this.loadBalancerFullName },\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                          \n  public metricActiveConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.activeConnectionCountSum, props);\n  }\n\n                                                                                                                                                                                                                                           \n  public metricClientTlsNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.clientTlsNegotiationErrorCountSum, props);\n  }\n\n                                                                                                                                   \n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.consumedLcUsAverage, {\n      statistic: 'sum',\n      ...props,\n    });\n  }\n\n                                                                                                                 \n  public metricHttpFixedResponseCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.httpFixedResponseCountSum, props);\n  }\n\n                                                                                                           \n  public metricHttpRedirectCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.httpRedirectCountSum, props);\n  }\n\n                                                                                                                                                                                        \n  public metricHttpRedirectUrlLimitExceededCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.httpRedirectUrlLimitExceededCountSum, props);\n  }\n\n                                                                                                                                                                                                               \n  public metricHttpCodeElb(code: HttpCodeElb, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                                               \n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                          \n  public metricIpv6ProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.iPv6ProcessedBytesSum, props);\n  }\n\n                                                                                                                 \n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.iPv6RequestCountSum, props);\n  }\n\n                                                                                                                                                                                        \n  public metricNewConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.newConnectionCountSum, props);\n  }\n\n                                                                                                                                   \n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.processedBytesSum, props);\n  }\n\n                                                                                                                                                                                 \n  public metricRejectedConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.rejectedConnectionCountSum, props);\n  }\n\n                                                                                                                                                                                                                       \n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.requestCountSum, props);\n  }\n\n                                                                                                                                                     \n  public metricRuleEvaluations(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.ruleEvaluationsSum, props);\n  }\n\n                                                                                                                                                             \n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                 \n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                                           \n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                                                                                                                                                    \n  public metricElbAuthError(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthError', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                           \n  public metricElbAuthFailure(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthFailure', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                              \n  public metricElbAuthLatency(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthLatency', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                                                                        \n  public metricElbAuthSuccess(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthSuccess', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  private cannedMetric(\n    fn: (dims: { LoadBalancer: string }) => cloudwatch.MetricProps,\n    props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      ...fn({ LoadBalancer: this.loadBalancerFullName }),\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n                                                                                                                                                 \nexport enum HttpCodeElb {\n                                                                                                \n  ELB_3XX_COUNT = 'HTTPCode_ELB_3XX_Count',\n\n                                                                                                                                                                                                                                                                                                                          \n  ELB_4XX_COUNT = 'HTTPCode_ELB_4XX_Count',\n\n                                                                                                 \n  ELB_5XX_COUNT = 'HTTPCode_ELB_5XX_Count',\n}\n\n                                                            \nexport enum HttpCodeTarget {\n                                                              \n  TARGET_2XX_COUNT = 'HTTPCode_Target_2XX_Count',\n\n                                                              \n  TARGET_3XX_COUNT = 'HTTPCode_Target_3XX_Count',\n\n                                                              \n  TARGET_4XX_COUNT = 'HTTPCode_Target_4XX_Count',\n\n                                                              \n  TARGET_5XX_COUNT = 'HTTPCode_Target_5XX_Count'\n}\n\n                                       \nexport interface IApplicationLoadBalancer extends ILoadBalancerV2, ec2.IConnectable {\n                                              \n  readonly loadBalancerArn: string;\n\n                                                                                                                                                                                                                                                                                     \n  readonly vpc?: ec2.IVpc;\n\n                                                                                                 \n  readonly ipAddressType?: IpAddressType;\n\n                                                                                                                                  \n  readonly listeners: ApplicationListener[];\n\n                                                         \n  addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;\n}\n\n                                                            \nexport interface ApplicationLoadBalancerAttributes {\n                                         \n  readonly loadBalancerArn: string;\n\n                                                         \n  readonly securityGroupId: string;\n\n                                                                                                                                                      \n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n                                                                                                                                      \n  readonly loadBalancerDnsName?: string;\n\n                                                                                                                                                                                            \n  readonly securityGroupAllowsAllOutbound?: boolean;\n\n                                                                                                                                                                                                \n  readonly vpc?: ec2.IVpc;\n\n}\n\n/**\n * An ApplicationLoadBalancer that has been defined elsewhere\n */\nclass ImportedApplicationLoadBalancer extends Resource implements IApplicationLoadBalancer {\n  /**\n   * Manage connections for this load balancer\n   */\n  public readonly connections: ec2.Connections;\n\n  /**\n   * ARN of the load balancer\n   */\n  public readonly loadBalancerArn: string;\n\n  public get listeners(): ApplicationListener[] {\n    throw Error('.listeners can only be accessed if the class was constructed as an owned, not imported, load balancer');\n  }\n\n  /**\n   * VPC of the load balancer\n   *\n   * Undefined if optional vpc is not specified.\n   */\n  public readonly vpc?: ec2.IVpc;\n\n  constructor(scope: Construct, id: string, private readonly props: ApplicationLoadBalancerAttributes) {\n    super(scope, id, {\n      environmentFromArn: props.loadBalancerArn,\n    });\n\n    this.vpc = props.vpc;\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.connections = new ec2.Connections({\n      securityGroups: [ec2.SecurityGroup.fromSecurityGroupId(this, 'SecurityGroup', props.securityGroupId, {\n        allowAllOutbound: props.securityGroupAllowsAllOutbound,\n      })],\n    });\n  }\n\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props,\n    });\n  }\n\n  public get loadBalancerCanonicalHostedZoneId(): string {\n    if (this.props.loadBalancerCanonicalHostedZoneId) { return this.props.loadBalancerCanonicalHostedZoneId; }\n    // eslint-disable-next-line max-len\n    throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n\n  public get loadBalancerDnsName(): string {\n    if (this.props.loadBalancerDnsName) { return this.props.loadBalancerDnsName; }\n    // eslint-disable-next-line max-len\n    throw new Error(`'loadBalancerDnsName' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n}\n\nclass LookedUpApplicationLoadBalancer extends Resource implements IApplicationLoadBalancer {\n  public readonly loadBalancerArn: string;\n  public readonly loadBalancerCanonicalHostedZoneId: string;\n  public readonly loadBalancerDnsName: string;\n  public readonly ipAddressType?: IpAddressType;\n  public readonly connections: ec2.Connections;\n  public readonly vpc?: ec2.IVpc;\n\n  public get listeners(): ApplicationListener[] {\n    throw Error('.listeners can only be accessed if the class was constructed as an owned, not looked up, load balancer');\n  }\n\n  constructor(scope: Construct, id: string, props: cxapi.LoadBalancerContextResponse) {\n    super(scope, id, {\n      environmentFromArn: props.loadBalancerArn,\n    });\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.loadBalancerCanonicalHostedZoneId = props.loadBalancerCanonicalHostedZoneId;\n    this.loadBalancerDnsName = props.loadBalancerDnsName;\n\n    if (props.ipAddressType === cxapi.LoadBalancerIpAddressType.IPV4) {\n      this.ipAddressType = IpAddressType.IPV4;\n    } else if (props.ipAddressType === cxapi.LoadBalancerIpAddressType.DUAL_STACK) {\n      this.ipAddressType = IpAddressType.DUAL_STACK;\n    }\n\n    this.vpc = ec2.Vpc.fromLookup(this, 'Vpc', {\n      vpcId: props.vpcId,\n    });\n\n    this.connections = new ec2.Connections();\n    for (const securityGroupId of props.securityGroupIds) {\n      const securityGroup = ec2.SecurityGroup.fromLookupById(this, `SecurityGroup-${securityGroupId}`, securityGroupId);\n      this.connections.addSecurityGroup(securityGroup);\n    }\n  }\n\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      ...props,\n      loadBalancer: this,\n    });\n  }\n}\n\n                                              \nexport interface ApplicationLoadBalancerRedirectConfig {\n\n                                                                                   \n  readonly sourceProtocol?: ApplicationProtocol;\n\n                                                                   \n  readonly sourcePort?: number;\n\n                                                                                \n  readonly targetProtocol?: ApplicationProtocol;\n\n                                                                      \n  readonly targetPort?: number;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        \n  readonly open?: boolean;\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-load-balancer.js","sourceRoot":"","sources":["application-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as ec2 from '@aws-cdk/aws-ec2';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Duration, Lazy, Names, Resource } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Construct } from 'constructs';\nimport { ApplicationELBMetrics } from '../elasticloadbalancingv2-canned-metrics.generated';\nimport { BaseLoadBalancer, BaseLoadBalancerLookupOptions, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { IpAddressType, ApplicationProtocol } from '../shared/enums';\nimport { ApplicationListener, BaseApplicationListenerProps } from './application-listener';\nimport { ListenerAction } from './application-listener-action';\n\n/**\n * Properties for defining an Application Load Balancer\n */\nexport interface ApplicationLoadBalancerProps extends BaseLoadBalancerProps {\n  /**\n   * Security group to associate with this load balancer\n   *\n   * @default A security group is created\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The type of IP addresses to use\n   *\n   * Only applies to application load balancers.\n   *\n   * @default IpAddressType.Ipv4\n   */\n  readonly ipAddressType?: IpAddressType;\n\n  /**\n   * Indicates whether HTTP/2 is enabled.\n   *\n   * @default true\n   */\n  readonly http2Enabled?: boolean;\n\n  /**\n   * The load balancer idle timeout, in seconds\n   *\n   * @default 60\n   */\n  readonly idleTimeout?: Duration;\n}\n\n/**\n * Options for looking up an ApplicationLoadBalancer\n */\nexport interface ApplicationLoadBalancerLookupOptions extends BaseLoadBalancerLookupOptions {\n}\n\n/**\n * Define an Application Load Balancer\n *\n * @resource AWS::ElasticLoadBalancingV2::LoadBalancer\n */\nexport class ApplicationLoadBalancer extends BaseLoadBalancer implements IApplicationLoadBalancer {\n  /**\n   * Look up an application load balancer.\n   */\n  public static fromLookup(scope: Construct, id: string, options: ApplicationLoadBalancerLookupOptions): IApplicationLoadBalancer {\n    const props = BaseLoadBalancer._queryContextProvider(scope, {\n      userOptions: options,\n      loadBalancerType: cxschema.LoadBalancerType.APPLICATION,\n    });\n\n    return new LookedUpApplicationLoadBalancer(scope, id, props);\n  }\n\n  /**\n   * Import an existing Application Load Balancer\n   */\n  public static fromApplicationLoadBalancerAttributes(\n    scope: Construct, id: string, attrs: ApplicationLoadBalancerAttributes): IApplicationLoadBalancer {\n\n    return new ImportedApplicationLoadBalancer(scope, id, attrs);\n  }\n\n  public readonly connections: ec2.Connections;\n  public readonly ipAddressType?: IpAddressType;\n  public readonly listeners: ApplicationListener[];\n\n  constructor(scope: Construct, id: string, props: ApplicationLoadBalancerProps) {\n    super(scope, id, props, {\n      type: 'application',\n      securityGroups: Lazy.list({ produce: () => this.connections.securityGroups.map(sg => sg.securityGroupId) }),\n      ipAddressType: props.ipAddressType,\n    });\n\n    this.ipAddressType = props.ipAddressType ?? IpAddressType.IPV4;\n    const securityGroups = [props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: `Automatically created Security Group for ELB ${Names.uniqueId(this)}`,\n      allowAllOutbound: false,\n    })];\n    this.connections = new ec2.Connections({ securityGroups });\n    this.listeners = [];\n\n    if (props.http2Enabled === false) { this.setAttribute('routing.http2.enabled', 'false'); }\n    if (props.idleTimeout !== undefined) { this.setAttribute('idle_timeout.timeout_seconds', props.idleTimeout.toSeconds().toString()); }\n  }\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    const listener = new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props,\n    });\n    this.listeners.push(listener);\n    return listener;\n  }\n\n  /**\n   * Add a redirection listener to this load balancer\n   */\n  public addRedirect(props: ApplicationLoadBalancerRedirectConfig = {}): ApplicationListener {\n    const sourcePort = props.sourcePort ?? 80;\n    const targetPort = (props.targetPort ?? 443).toString();\n    return this.addListener(`Redirect${sourcePort}To${targetPort}`, {\n      protocol: props.sourceProtocol ?? ApplicationProtocol.HTTP,\n      port: sourcePort,\n      open: props.open ?? true,\n      defaultAction: ListenerAction.redirect({\n        port: targetPort,\n        protocol: props.targetProtocol ?? ApplicationProtocol.HTTPS,\n        permanent: true,\n      }),\n    });\n  }\n\n  /**\n   * Add a security group to this load balancer\n   */\n  public addSecurityGroup(securityGroup: ec2.ISecurityGroup) {\n    this.connections.addSecurityGroup(securityGroup);\n  }\n\n  /**\n   * Return the given named metric for this Application Load Balancer\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensionsMap: { LoadBalancer: this.loadBalancerFullName },\n      ...props,\n    });\n  }\n\n  /**\n   * The total number of concurrent TCP connections active from clients to the\n   * load balancer and from the load balancer to targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricActiveConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.activeConnectionCountSum, props);\n  }\n\n  /**\n   * The number of TLS connections initiated by the client that did not\n   * establish a session with the load balancer. Possible causes include a\n   * mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricClientTlsNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.clientTlsNegotiationErrorCountSum, props);\n  }\n\n  /**\n   * The number of load balancer capacity units (LCU) used by your load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.consumedLcUsAverage, {\n      statistic: 'sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of fixed-response actions that were successful.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpFixedResponseCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.httpFixedResponseCountSum, props);\n  }\n\n  /**\n   * The number of redirect actions that were successful.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpRedirectCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.httpRedirectCountSum, props);\n  }\n\n  /**\n   * The number of redirect actions that couldn't be completed because the URL\n   * in the response location header is larger than 8K.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpRedirectUrlLimitExceededCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.httpRedirectUrlLimitExceededCountSum, props);\n  }\n\n  /**\n   * The number of HTTP 3xx/4xx/5xx codes that originate from the load balancer.\n   *\n   * This does not include any response codes generated by the targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeElb(code: HttpCodeElb, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets\n   * in the load balancer.\n   *\n   * This does not include any response codes generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer over IPv6.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6ProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.iPv6ProcessedBytesSum, props);\n  }\n\n  /**\n   * The number of IPv6 requests received by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.iPv6RequestCountSum, props);\n  }\n\n  /**\n   * The total number of new TCP connections established from clients to the\n   * load balancer and from the load balancer to targets.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricNewConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.newConnectionCountSum, props);\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer over IPv4 and IPv6.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.processedBytesSum, props);\n  }\n\n  /**\n   * The number of connections that were rejected because the load balancer had\n   * reached its maximum number of connections.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRejectedConnectionCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.rejectedConnectionCountSum, props);\n  }\n\n  /**\n   * The number of requests processed over IPv4 and IPv6.\n   *\n   * This count includes only the requests with a response generated by a target of the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.requestCountSum, props);\n  }\n\n  /**\n   * The number of rules processed by the load balancer given a request rate averaged over an hour.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRuleEvaluations(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.ruleEvaluationsSum, props);\n  }\n\n  /**\n   * The number of connections that were not successfully established between the load balancer and target.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the load balancer that did not establish a session with the target.\n   *\n   * Possible causes include a mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of user authentications that could not be completed\n   *\n   * Because an authenticate action was misconfigured, the load balancer\n   * couldn't establish a connection with the IdP, or the load balancer\n   * couldn't complete the authentication flow due to an internal error.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthError(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthError', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of user authentications that could not be completed because the\n   * IdP denied access to the user or an authorization code was used more than\n   * once.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthFailure(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthFailure', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The time elapsed, in milliseconds, to query the IdP for the ID token and user info.\n   *\n   * If one or more of these operations fail, this is the time to failure.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricElbAuthLatency(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthLatency', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of authenticate actions that were successful.\n   *\n   * This metric is incremented at the end of the authentication workflow,\n   * after the load balancer has retrieved the user claims from the IdP.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricElbAuthSuccess(props?: cloudwatch.MetricOptions) {\n    return this.metric('ELBAuthSuccess', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  private cannedMetric(\n    fn: (dims: { LoadBalancer: string }) => cloudwatch.MetricProps,\n    props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      ...fn({ LoadBalancer: this.loadBalancerFullName }),\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n/**\n * Count of HTTP status originating from the load balancer\n *\n * This count does not include any response codes generated by the targets.\n */\nexport enum HttpCodeElb {\n  /**\n   * The number of HTTP 3XX redirection codes that originate from the load balancer.\n   */\n  ELB_3XX_COUNT = 'HTTPCode_ELB_3XX_Count',\n\n  /**\n   * The number of HTTP 4XX client error codes that originate from the load balancer.\n   *\n   * Client errors are generated when requests are malformed or incomplete.\n   * These requests have not been received by the target. This count does not\n   * include any response codes generated by the targets.\n   */\n  ELB_4XX_COUNT = 'HTTPCode_ELB_4XX_Count',\n\n  /**\n   * The number of HTTP 5XX server error codes that originate from the load balancer.\n   */\n  ELB_5XX_COUNT = 'HTTPCode_ELB_5XX_Count',\n}\n\n/**\n * Count of HTTP status originating from the targets\n */\nexport enum HttpCodeTarget {\n  /**\n   * The number of 2xx response codes from targets\n   */\n  TARGET_2XX_COUNT = 'HTTPCode_Target_2XX_Count',\n\n  /**\n   * The number of 3xx response codes from targets\n   */\n  TARGET_3XX_COUNT = 'HTTPCode_Target_3XX_Count',\n\n  /**\n   * The number of 4xx response codes from targets\n   */\n  TARGET_4XX_COUNT = 'HTTPCode_Target_4XX_Count',\n\n  /**\n   * The number of 5xx response codes from targets\n   */\n  TARGET_5XX_COUNT = 'HTTPCode_Target_5XX_Count'\n}\n\n/**\n * An application load balancer\n */\nexport interface IApplicationLoadBalancer extends ILoadBalancerV2, ec2.IConnectable {\n  /**\n   * The ARN of this load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The VPC this load balancer has been created in (if available).\n   * If this interface is the result of an import call to fromApplicationLoadBalancerAttributes,\n   * the vpc attribute will be undefined unless specified in the optional properties of that method.\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * The IP Address Type for this load balancer\n   *\n   * @default IpAddressType.IPV4\n   */\n  readonly ipAddressType?: IpAddressType;\n\n  /**\n   * A list of listeners that have been added to the load balancer.\n   * This list is only valid for owned constructs.\n   */\n  readonly listeners: ApplicationListener[];\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface ApplicationLoadBalancerAttributes {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * ID of the load balancer's security group\n   */\n  readonly securityGroupId: string;\n\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerDnsName?: string;\n\n  /**\n   * Whether the security group allows all outbound traffic or not\n   *\n   * Unless set to `false`, no egress rules will be added to the security group.\n   *\n   * @default true\n   */\n  readonly securityGroupAllowsAllOutbound?: boolean;\n\n  /**\n   * The VPC this load balancer has been created in, if available\n   *\n   * @default - If the Load Balancer was imported and a VPC was not specified,\n   * the VPC is not available.\n   */\n  readonly vpc?: ec2.IVpc;\n\n}\n\n/**\n * An ApplicationLoadBalancer that has been defined elsewhere\n */\nclass ImportedApplicationLoadBalancer extends Resource implements IApplicationLoadBalancer {\n  /**\n   * Manage connections for this load balancer\n   */\n  public readonly connections: ec2.Connections;\n\n  /**\n   * ARN of the load balancer\n   */\n  public readonly loadBalancerArn: string;\n\n  public get listeners(): ApplicationListener[] {\n    throw Error('.listeners can only be accessed if the class was constructed as an owned, not imported, load balancer');\n  }\n\n  /**\n   * VPC of the load balancer\n   *\n   * Undefined if optional vpc is not specified.\n   */\n  public readonly vpc?: ec2.IVpc;\n\n  constructor(scope: Construct, id: string, private readonly props: ApplicationLoadBalancerAttributes) {\n    super(scope, id, {\n      environmentFromArn: props.loadBalancerArn,\n    });\n\n    this.vpc = props.vpc;\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.connections = new ec2.Connections({\n      securityGroups: [ec2.SecurityGroup.fromSecurityGroupId(this, 'SecurityGroup', props.securityGroupId, {\n        allowAllOutbound: props.securityGroupAllowsAllOutbound,\n      })],\n    });\n  }\n\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props,\n    });\n  }\n\n  public get loadBalancerCanonicalHostedZoneId(): string {\n    if (this.props.loadBalancerCanonicalHostedZoneId) { return this.props.loadBalancerCanonicalHostedZoneId; }\n    // eslint-disable-next-line max-len\n    throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n\n  public get loadBalancerDnsName(): string {\n    if (this.props.loadBalancerDnsName) { return this.props.loadBalancerDnsName; }\n    // eslint-disable-next-line max-len\n    throw new Error(`'loadBalancerDnsName' was not provided when constructing Application Load Balancer ${this.node.path} from attributes`);\n  }\n}\n\nclass LookedUpApplicationLoadBalancer extends Resource implements IApplicationLoadBalancer {\n  public readonly loadBalancerArn: string;\n  public readonly loadBalancerCanonicalHostedZoneId: string;\n  public readonly loadBalancerDnsName: string;\n  public readonly ipAddressType?: IpAddressType;\n  public readonly connections: ec2.Connections;\n  public readonly vpc?: ec2.IVpc;\n\n  public get listeners(): ApplicationListener[] {\n    throw Error('.listeners can only be accessed if the class was constructed as an owned, not looked up, load balancer');\n  }\n\n  constructor(scope: Construct, id: string, props: cxapi.LoadBalancerContextResponse) {\n    super(scope, id, {\n      environmentFromArn: props.loadBalancerArn,\n    });\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.loadBalancerCanonicalHostedZoneId = props.loadBalancerCanonicalHostedZoneId;\n    this.loadBalancerDnsName = props.loadBalancerDnsName;\n\n    if (props.ipAddressType === cxapi.LoadBalancerIpAddressType.IPV4) {\n      this.ipAddressType = IpAddressType.IPV4;\n    } else if (props.ipAddressType === cxapi.LoadBalancerIpAddressType.DUAL_STACK) {\n      this.ipAddressType = IpAddressType.DUAL_STACK;\n    }\n\n    this.vpc = ec2.Vpc.fromLookup(this, 'Vpc', {\n      vpcId: props.vpcId,\n    });\n\n    this.connections = new ec2.Connections();\n    for (const securityGroupId of props.securityGroupIds) {\n      const securityGroup = ec2.SecurityGroup.fromLookupById(this, `SecurityGroup-${securityGroupId}`, securityGroupId);\n      this.connections.addSecurityGroup(securityGroup);\n    }\n  }\n\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      ...props,\n      loadBalancer: this,\n    });\n  }\n}\n\n/**\n * Properties for a redirection config\n */\nexport interface ApplicationLoadBalancerRedirectConfig {\n\n  /**\n   * The protocol of the listener being created\n   *\n   * @default HTTP\n   */\n  readonly sourceProtocol?: ApplicationProtocol;\n\n  /**\n   * The port number to listen to\n   *\n   * @default 80\n   */\n  readonly sourcePort?: number;\n\n  /**\n   * The protocol of the redirection target\n   *\n   * @default HTTPS\n   */\n  readonly targetProtocol?: ApplicationProtocol;\n\n  /**\n   * The port number to redirect to\n   *\n   * @default 443\n   */\n  readonly targetPort?: number;\n\n  /**\n   * Allow anyone to connect to this listener\n   *\n   * If this is specified, the listener will be opened up to anyone who can reach it.\n   * For internal load balancers this is anyone in the same VPC. For public load\n   * balancers, this is anyone on the internet.\n   *\n   * If you want to be more selective about who can access this load\n   * balancer, set this to `false` and use the listener's `connections`\n   * object to selectively grant access to the listener.\n   *\n   * @default true\n   */\n  readonly open?: boolean;\n\n}\n"]}

@@ -10,19 +10,15 @@ import * as cloudwatch from '@aws-cdk/aws-cloudwatch';

/**
* Properties for defining an Application Target Group.
*
* @stability stable
* Properties for defining an Application Target Group
*/
export interface ApplicationTargetGroupProps extends BaseTargetGroupProps {
/**
* The protocol to use.
* The protocol to use
*
* @default - Determined from port if known, optional for Lambda targets.
* @stability stable
*/
readonly protocol?: ApplicationProtocol;
/**
* The protocol version to use.
* The protocol version to use
*
* @default ApplicationProtocolVersion.HTTP1
* @stability stable
*/

@@ -34,7 +30,7 @@ readonly protocolVersion?: ApplicationProtocolVersion;

* @default - Determined from protocol if known, optional for Lambda targets.
* @stability stable
*/
readonly port?: number;
/**
* The time period during which the load balancer sends a newly registered target a linearly increasing share of the traffic to the target group.
* The time period during which the load balancer sends a newly registered
* target a linearly increasing share of the traffic to the target group.
*

@@ -44,3 +40,2 @@ * The range is 30-900 seconds (15 minutes).

* @default 0
* @stability stable
*/

@@ -57,3 +52,2 @@ readonly slowStart?: Duration;

* @default Duration.days(1)
* @stability stable
*/

@@ -72,3 +66,2 @@ readonly stickinessCookieDuration?: Duration;

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/sticky-sessions.html
* @stability stable
*/

@@ -80,3 +73,2 @@ readonly stickinessCookieName?: string;

* @default TargetGroupLoadBalancingAlgorithmType.ROUND_ROBIN
* @stability stable
*/

@@ -92,3 +84,2 @@ readonly loadBalancingAlgorithmType?: TargetGroupLoadBalancingAlgorithmType;

* @default - No targets.
* @stability stable
*/

@@ -98,15 +89,11 @@ readonly targets?: IApplicationLoadBalancerTarget[];

/**
* Define an Application Target Group.
*
* @stability stable
* Define an Application Target Group
*/
export declare class ApplicationTargetGroup extends TargetGroupBase implements IApplicationTargetGroup {
/**
* Import an existing target group.
*
* @stability stable
* Import an existing target group
*/
static fromTargetGroupAttributes(scope: Construct, id: string, attrs: TargetGroupAttributes): IApplicationTargetGroup;
/**
* (deprecated) Import an existing target group.
* Import an existing target group
*

@@ -120,10 +107,5 @@ * @deprecated Use `fromTargetGroupAttributes` instead

private readonly port?;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props?: ApplicationTargetGroupProps);
/**
* Add a load balancing target to this target group.
*
* @stability stable
* Add a load balancing target to this target group
*/

@@ -138,3 +120,2 @@ addTarget(...targets: IApplicationLoadBalancerTarget[]): void;

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/sticky-sessions.html
* @stability stable
*/

@@ -146,4 +127,2 @@ enableCookieStickiness(duration: Duration, cookieName?: string): void;

* Don't call this directly. It will be called by load balancing targets.
*
* @stability stable
*/

@@ -155,14 +134,10 @@ registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port): void;

* Don't call this directly. It will be called by listeners.
*
* @stability stable
*/
registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct): void;
/**
* Full name of first load balancer.
*
* @stability stable
* Full name of first load balancer
*/
get firstLoadBalancerFullName(): string;
/**
* Return the given named metric for this Application Load Balancer Target Group.
* Return the given named metric for this Application Load Balancer Target Group
*

@@ -175,10 +150,8 @@ * Returns the metric for this target group from the point of view of the first

* @default Average over 5 minutes
* @stability stable
*/
metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of IPv6 requests received by the target group.
* The number of IPv6 requests received by the target group
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -192,17 +165,14 @@ metricIpv6RequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricRequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of healthy hosts in the target group.
* The number of healthy hosts in the target group
*
* @default Average over 5 minutes
* @stability stable
*/
metricHealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* The number of unhealthy hosts in the target group.
* The number of unhealthy hosts in the target group
*
* @default Average over 5 minutes
* @stability stable
*/

@@ -216,3 +186,2 @@ metricUnhealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -226,3 +195,2 @@ metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -234,3 +202,2 @@ metricRequestCountPerTarget(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -242,3 +209,2 @@ metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Average over 5 minutes
* @stability stable
*/

@@ -252,13 +218,4 @@ metricTargetResponseTime(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* Validate the current construct.
*
* This method can be implemented by derived constructs in order to perform
* validation logic. It is called on all constructs before synthesis.
*
* @stability stable
*/
protected validate(): string[];

@@ -268,5 +225,3 @@ private cannedMetric;

/**
* A Target Group for Application Load Balancers.
*
* @stability stable
* A Target Group for Application Load Balancers
*/

@@ -278,4 +233,2 @@ export interface IApplicationTargetGroup extends ITargetGroup {

* Don't call this directly. It will be called by listeners.
*
* @stability stable
*/

@@ -287,10 +240,6 @@ registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct): void;

* Don't call this directly. It will be called by load balancing targets.
*
* @stability stable
*/
registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port): void;
/**
* Add a load balancing target to this target group.
*
* @stability stable
* Add a load balancing target to this target group
*/

@@ -300,16 +249,12 @@ addTarget(...targets: IApplicationLoadBalancerTarget[]): void;

/**
* Interface for constructs that can be targets of an application load balancer.
*
* @stability stable
* Interface for constructs that can be targets of an application load balancer
*/
export interface IApplicationLoadBalancerTarget {
/**
* Attach load-balanced target to a TargetGroup.
* Attach load-balanced target to a TargetGroup
*
* May return JSON to directly add to the [Targets] list, or return undefined
* if the target will register itself with the load balancer.
*
* @stability stable
*/
attachToApplicationTargetGroup(targetGroup: IApplicationTargetGroup): LoadBalancerTargetProps;
}

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

/**
* Define an Application Target Group.
*
* @stability stable
* Define an Application Target Group
*/
class ApplicationTargetGroup extends base_target_group_1.TargetGroupBase {
/**
* @stability stable
*/
constructor(scope, id, props = {}) {

@@ -58,5 +53,3 @@ jsiiDeprecationWarnings._aws_cdk_aws_elasticloadbalancingv2_ApplicationTargetGroupProps(props);

/**
* Import an existing target group.
*
* @stability stable
* Import an existing target group
*/

@@ -68,3 +61,3 @@ static fromTargetGroupAttributes(scope, id, attrs) {

/**
* (deprecated) Import an existing target group.
* Import an existing target group
*

@@ -79,5 +72,3 @@ * @deprecated Use `fromTargetGroupAttributes` instead

/**
* Add a load balancing target to this target group.
*
* @stability stable
* Add a load balancing target to this target group
*/

@@ -101,3 +92,2 @@ addTarget(...targets) {

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/sticky-sessions.html
* @stability stable
*/

@@ -131,4 +121,2 @@ enableCookieStickiness(duration, cookieName) {

* Don't call this directly. It will be called by load balancing targets.
*
* @stability stable
*/

@@ -148,4 +136,2 @@ registerConnectable(connectable, portRange) {

* Don't call this directly. It will be called by listeners.
*
* @stability stable
*/

@@ -163,5 +149,3 @@ registerListener(listener, associatingConstruct) {

/**
* Full name of first load balancer.
*
* @stability stable
* Full name of first load balancer
*/

@@ -175,3 +159,3 @@ get firstLoadBalancerFullName() {

/**
* Return the given named metric for this Application Load Balancer Target Group.
* Return the given named metric for this Application Load Balancer Target Group
*

@@ -184,3 +168,2 @@ * Returns the metric for this target group from the point of view of the first

* @default Average over 5 minutes
* @stability stable
*/

@@ -199,6 +182,5 @@ metric(metricName, props) {

/**
* The number of IPv6 requests received by the target group.
* The number of IPv6 requests received by the target group
*
* @default Sum over 5 minutes
* @stability stable
*/

@@ -214,3 +196,2 @@ metricIpv6RequestCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -221,6 +202,5 @@ metricRequestCount(props) {

/**
* The number of healthy hosts in the target group.
* The number of healthy hosts in the target group
*
* @default Average over 5 minutes
* @stability stable
*/

@@ -234,6 +214,5 @@ metricHealthyHostCount(props) {

/**
* The number of unhealthy hosts in the target group.
* The number of unhealthy hosts in the target group
*
* @default Average over 5 minutes
* @stability stable
*/

@@ -252,3 +231,2 @@ metricUnhealthyHostCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -268,3 +246,2 @@ metricHttpCodeTarget(code, props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -281,3 +258,2 @@ metricRequestCountPerTarget(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -294,3 +270,2 @@ metricTargetConnectionErrorCount(props) {

* @default Average over 5 minutes
* @stability stable
*/

@@ -309,3 +284,2 @@ metricTargetResponseTime(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -318,10 +292,2 @@ metricTargetTLSNegotiationErrorCount(props) {

}
/**
* Validate the current construct.
*
* This method can be implemented by derived constructs in order to perform
* validation logic. It is called on all constructs before synthesis.
*
* @stability stable
*/
validate() {

@@ -361,3 +327,3 @@ const ret = super.validate();

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

@@ -384,2 +350,2 @@ * An imported application target group

const ALB_HEALTH_CHECK_PROTOCOLS = [enums_1.Protocol.HTTP, enums_1.Protocol.HTTPS];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-target-group.js","sourceRoot":"","sources":["application-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as ec2 from '@aws-cdk/aws-ec2';\nimport { Annotations, Duration, Token } from '@aws-cdk/core';\nimport { IConstruct, Construct } from 'constructs';\nimport { ApplicationELBMetrics } from '../elasticloadbalancingv2-canned-metrics.generated';\nimport {\n  BaseTargetGroupProps, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n  TargetGroupAttributes, TargetGroupBase, TargetGroupImportProps,\n} from '../shared/base-target-group';\nimport { ApplicationProtocol, ApplicationProtocolVersion, Protocol, TargetType, TargetGroupLoadBalancingAlgorithmType } from '../shared/enums';\nimport { ImportedTargetGroupBase } from '../shared/imported';\nimport { determineProtocolAndPort } from '../shared/util';\nimport { IApplicationListener } from './application-listener';\nimport { HttpCodeTarget } from './application-load-balancer';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct as CoreConstruct } from '@aws-cdk/core';\n\n                                                              \nexport interface ApplicationTargetGroupProps extends BaseTargetGroupProps {\n                                                                                                                     \n  readonly protocol?: ApplicationProtocol;\n\n                                                                                                \n  readonly protocolVersion?: ApplicationProtocolVersion;\n\n                                                                                                                                                          \n  readonly port?: number;\n\n                                                                                                                                                                                                                                             \n  readonly slowStart?: Duration;\n\n                                                                                                                                                                                                                                                                                                              \n  readonly stickinessCookieDuration?: Duration;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       \n  readonly stickinessCookieName?: string;\n\n                                                                                                                                                          \n  readonly loadBalancingAlgorithmType?: TargetGroupLoadBalancingAlgorithmType;\n\n                                                                                                                                                                                                                                                                                          \n  readonly targets?: IApplicationLoadBalancerTarget[];\n}\n\n                                             \nexport class ApplicationTargetGroup extends TargetGroupBase implements IApplicationTargetGroup {\n                                                \n  public static fromTargetGroupAttributes(scope: Construct, id: string, attrs: TargetGroupAttributes): IApplicationTargetGroup {\n    return new ImportedApplicationTargetGroup(scope, id, attrs);\n  }\n\n                                                                                                              \n  public static import(scope: Construct, id: string, props: TargetGroupImportProps): IApplicationTargetGroup {\n    return ApplicationTargetGroup.fromTargetGroupAttributes(scope, id, props);\n  }\n\n  private readonly connectableMembers: ConnectableMember[];\n  private readonly listeners: IApplicationListener[];\n  private readonly protocol?: ApplicationProtocol;\n  private readonly port?: number;\n\n  constructor(scope: Construct, id: string, props: ApplicationTargetGroupProps = {}) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n    const { protocolVersion } = props;\n    super(scope, id, { ...props }, {\n      protocol,\n      protocolVersion,\n      port,\n    });\n\n    this.protocol = protocol;\n    this.port = port;\n\n    this.connectableMembers = [];\n    this.listeners = [];\n\n    if (props) {\n      if (props.slowStart !== undefined) {\n        if (props.slowStart.toSeconds() < 30 || props.slowStart.toSeconds() > 900) {\n          throw new Error('Slow start duration value must be between 30 and 900 seconds.');\n        }\n        this.setAttribute('slow_start.duration_seconds', props.slowStart.toSeconds().toString());\n      }\n\n      if (props.stickinessCookieDuration) {\n        this.enableCookieStickiness(props.stickinessCookieDuration, props.stickinessCookieName);\n      } else {\n        this.setAttribute('stickiness.enabled', 'false');\n      }\n\n      if (props.loadBalancingAlgorithmType) {\n        this.setAttribute('load_balancing.algorithm.type', props.loadBalancingAlgorithmType);\n      }\n      this.addTarget(...(props.targets || []));\n    }\n  }\n\n                                                                 \n  public addTarget(...targets: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n\n    if (this.targetType === TargetType.LAMBDA) {\n      this.setAttribute('stickiness.enabled', undefined);\n    }\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                  \n  public enableCookieStickiness(duration: Duration, cookieName?: string) {\n    if (duration.toSeconds() < 1 || duration.toSeconds() > 604800) {\n      throw new Error('Stickiness cookie duration value must be between 1 second and 7 days (604800 seconds).');\n    }\n    if (cookieName !== undefined) {\n      if (!Token.isUnresolved(cookieName) && (cookieName.startsWith('AWSALB') || cookieName.startsWith('AWSALBAPP') || cookieName.startsWith('AWSALBTG'))) {\n        throw new Error('App cookie names that start with the following prefixes are not allowed: AWSALB, AWSALBAPP, and AWSALBTG; they\\'re reserved for use by the load balancer.');\n      }\n      if (cookieName === '') {\n        throw new Error('App cookie name cannot be an empty string.');\n      }\n    }\n    this.setAttribute('stickiness.enabled', 'true');\n    if (cookieName) {\n      this.setAttribute('stickiness.type', 'app_cookie');\n      this.setAttribute('stickiness.app_cookie.cookie_name', cookieName);\n      this.setAttribute('stickiness.app_cookie.duration_seconds', duration.toSeconds().toString());\n    } else {\n      this.setAttribute('stickiness.type', 'lb_cookie');\n      this.setAttribute('stickiness.lb_cookie.duration_seconds', duration.toSeconds().toString());\n    }\n  }\n\n                                                                                                                                                          \n  public registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port) {\n    portRange = portRange || ec2.Port.tcp(this.defaultPort);\n\n    // Notify all listeners that we already know about of this new connectable.\n    // Then remember for new listeners that might get added later.\n    this.connectableMembers.push({ connectable, portRange });\n    for (const listener of this.listeners) {\n      listener.registerConnectable(connectable, portRange);\n    }\n  }\n\n                                                                                                                                                     \n  public registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    // Notify this listener of all connectables that we know about.\n    // Then remember for new connectables that might get added later.\n    for (const member of this.connectableMembers) {\n      listener.registerConnectable(member.connectable, member.portRange);\n    }\n    this.listeners.push(listener);\n    this.loadBalancerAttachedDependencies.add((associatingConstruct || listener) as CoreConstruct);\n  }\n\n                                                 \n  public get firstLoadBalancerFullName(): string {\n    if (this.listeners.length === 0) {\n      throw new Error('The TargetGroup needs to be attached to a LoadBalancer before you can call this method');\n    }\n    return loadBalancerNameFromListenerArn(this.listeners[0].listenerArn);\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                                                              \n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensionsMap: {\n        TargetGroup: this.targetGroupFullName,\n        LoadBalancer: this.firstLoadBalancerFullName,\n      },\n      ...props,\n    }).attachTo(this);\n  }\n\n                                                                                                               \n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.iPv6RequestCountSum, props);\n  }\n\n                                                                                                                                                                                                                       \n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.requestCountSum, props);\n  }\n\n                                                                                                          \n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                            \n  public metricUnhealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                                          \n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                              \n  public metricRequestCountPerTarget(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCountPerTarget', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                             \n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                 \n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                                                                           \n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  protected validate(): string[] {\n    const ret = super.validate();\n\n    if (this.targetType !== undefined && this.targetType !== TargetType.LAMBDA\n      && (this.protocol === undefined || this.port === undefined)) {\n      ret.push('At least one of \\'port\\' or \\'protocol\\' is required for a non-Lambda TargetGroup');\n    }\n\n    if (this.healthCheck && this.healthCheck.protocol) {\n\n      if (ALB_HEALTH_CHECK_PROTOCOLS.includes(this.healthCheck.protocol)) {\n        if (this.healthCheck.interval && this.healthCheck.timeout &&\n          this.healthCheck.interval.toMilliseconds() <= this.healthCheck.timeout.toMilliseconds()) {\n          ret.push(`Healthcheck interval ${this.healthCheck.interval.toHumanString()} must be greater than the timeout ${this.healthCheck.timeout.toHumanString()}`);\n        }\n      }\n\n      if (!ALB_HEALTH_CHECK_PROTOCOLS.includes(this.healthCheck.protocol)) {\n        ret.push([\n          `Health check protocol '${this.healthCheck.protocol}' is not supported. `,\n          `Must be one of [${ALB_HEALTH_CHECK_PROTOCOLS.join(', ')}]`,\n        ].join(''));\n      }\n    }\n\n    return ret;\n  }\n\n  private cannedMetric(\n    fn: (dims: { LoadBalancer: string, TargetGroup: string }) => cloudwatch.MetricProps,\n    props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      ...fn({\n        LoadBalancer: this.firstLoadBalancerFullName,\n        TargetGroup: this.targetGroupFullName,\n      }),\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n/**\n * A connectable member of a target group\n */\ninterface ConnectableMember {\n  /**\n   * The connectable member\n   */\n  connectable: ec2.IConnectable;\n\n  /**\n   * The port (range) the member is listening on\n   */\n  portRange: ec2.Port;\n}\n\n                                                        \nexport interface IApplicationTargetGroup extends ITargetGroup {\n                                                                                                                                                     \n  registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct): void;\n\n                                                                                                                                                          \n  registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port): void;\n\n                                                                 \n  addTarget(...targets: IApplicationLoadBalancerTarget[]): void;\n}\n\n/**\n * An imported application target group\n */\nclass ImportedApplicationTargetGroup extends ImportedTargetGroupBase implements IApplicationTargetGroup {\n  public registerListener(_listener: IApplicationListener, _associatingConstruct?: IConstruct) {\n    // Nothing to do, we know nothing of our members\n    Annotations.of(this).addWarning('Cannot register listener on imported target group -- security groups might need to be updated manually');\n  }\n\n  public registerConnectable(_connectable: ec2.IConnectable, _portRange?: ec2.Port | undefined): void {\n    Annotations.of(this).addWarning('Cannot register connectable on imported target group -- security groups might need to be updated manually');\n  }\n\n  public addTarget(...targets: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n\n      if (result.targetJson !== undefined) {\n        throw new Error('Cannot add a non-self registering target to an imported TargetGroup. Create a new TargetGroup instead.');\n      }\n    }\n  }\n}\n\n                                                                                       \nexport interface IApplicationLoadBalancerTarget {\n                                                                                                                                                                                                                  \n  attachToApplicationTargetGroup(targetGroup: IApplicationTargetGroup): LoadBalancerTargetProps;\n}\n\nconst ALB_HEALTH_CHECK_PROTOCOLS = [Protocol.HTTP, Protocol.HTTPS];\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-target-group.js","sourceRoot":"","sources":["application-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as ec2 from '@aws-cdk/aws-ec2';\nimport { Annotations, Duration, Token } from '@aws-cdk/core';\nimport { IConstruct, Construct } from 'constructs';\nimport { ApplicationELBMetrics } from '../elasticloadbalancingv2-canned-metrics.generated';\nimport {\n  BaseTargetGroupProps, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n  TargetGroupAttributes, TargetGroupBase, TargetGroupImportProps,\n} from '../shared/base-target-group';\nimport { ApplicationProtocol, ApplicationProtocolVersion, Protocol, TargetType, TargetGroupLoadBalancingAlgorithmType } from '../shared/enums';\nimport { ImportedTargetGroupBase } from '../shared/imported';\nimport { determineProtocolAndPort } from '../shared/util';\nimport { IApplicationListener } from './application-listener';\nimport { HttpCodeTarget } from './application-load-balancer';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct as CoreConstruct } from '@aws-cdk/core';\n\n/**\n * Properties for defining an Application Target Group\n */\nexport interface ApplicationTargetGroupProps extends BaseTargetGroupProps {\n  /**\n   * The protocol to use\n   *\n   * @default - Determined from port if known, optional for Lambda targets.\n   */\n  readonly protocol?: ApplicationProtocol;\n\n  /**\n   * The protocol version to use\n   *\n   * @default ApplicationProtocolVersion.HTTP1\n   */\n  readonly protocolVersion?: ApplicationProtocolVersion;\n\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default - Determined from protocol if known, optional for Lambda targets.\n   */\n  readonly port?: number;\n\n  /**\n   * The time period during which the load balancer sends a newly registered\n   * target a linearly increasing share of the traffic to the target group.\n   *\n   * The range is 30-900 seconds (15 minutes).\n   *\n   * @default 0\n   */\n  readonly slowStart?: Duration;\n\n  /**\n   * The stickiness cookie expiration period.\n   *\n   * Setting this value enables load balancer stickiness.\n   *\n   * After this period, the cookie is considered stale. The minimum value is\n   * 1 second and the maximum value is 7 days (604800 seconds).\n   *\n   * @default Duration.days(1)\n   */\n  readonly stickinessCookieDuration?: Duration;\n\n  /**\n   * The name of an application-based stickiness cookie.\n   *\n   * Names that start with the following prefixes are not allowed: AWSALB, AWSALBAPP,\n   * and AWSALBTG; they're reserved for use by the load balancer.\n   *\n   * Note: `stickinessCookieName` parameter depends on the presence of `stickinessCookieDuration` parameter.\n   * If `stickinessCookieDuration` is not set, `stickinessCookieName` will be omitted.\n   *\n   * @default - If `stickinessCookieDuration` is set, a load-balancer generated cookie is used. Otherwise, no stickiness is defined.\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/sticky-sessions.html\n   */\n  readonly stickinessCookieName?: string;\n\n  /**\n   * The load balancing algorithm to select targets for routing requests.\n   *\n   * @default TargetGroupLoadBalancingAlgorithmType.ROUND_ROBIN\n   */\n  readonly loadBalancingAlgorithmType?: TargetGroupLoadBalancingAlgorithmType;\n\n  /**\n   * The targets to add to this target group.\n   *\n   * Can be `Instance`, `IPAddress`, or any self-registering load balancing\n   * target. If you use either `Instance` or `IPAddress` as targets, all\n   * target must be of the same type.\n   *\n   * @default - No targets.\n   */\n  readonly targets?: IApplicationLoadBalancerTarget[];\n}\n\n/**\n * Define an Application Target Group\n */\nexport class ApplicationTargetGroup extends TargetGroupBase implements IApplicationTargetGroup {\n  /**\n   * Import an existing target group\n   */\n  public static fromTargetGroupAttributes(scope: Construct, id: string, attrs: TargetGroupAttributes): IApplicationTargetGroup {\n    return new ImportedApplicationTargetGroup(scope, id, attrs);\n  }\n\n  /**\n   * Import an existing target group\n   *\n   * @deprecated Use `fromTargetGroupAttributes` instead\n   */\n  public static import(scope: Construct, id: string, props: TargetGroupImportProps): IApplicationTargetGroup {\n    return ApplicationTargetGroup.fromTargetGroupAttributes(scope, id, props);\n  }\n\n  private readonly connectableMembers: ConnectableMember[];\n  private readonly listeners: IApplicationListener[];\n  private readonly protocol?: ApplicationProtocol;\n  private readonly port?: number;\n\n  constructor(scope: Construct, id: string, props: ApplicationTargetGroupProps = {}) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n    const { protocolVersion } = props;\n    super(scope, id, { ...props }, {\n      protocol,\n      protocolVersion,\n      port,\n    });\n\n    this.protocol = protocol;\n    this.port = port;\n\n    this.connectableMembers = [];\n    this.listeners = [];\n\n    if (props) {\n      if (props.slowStart !== undefined) {\n        if (props.slowStart.toSeconds() < 30 || props.slowStart.toSeconds() > 900) {\n          throw new Error('Slow start duration value must be between 30 and 900 seconds.');\n        }\n        this.setAttribute('slow_start.duration_seconds', props.slowStart.toSeconds().toString());\n      }\n\n      if (props.stickinessCookieDuration) {\n        this.enableCookieStickiness(props.stickinessCookieDuration, props.stickinessCookieName);\n      } else {\n        this.setAttribute('stickiness.enabled', 'false');\n      }\n\n      if (props.loadBalancingAlgorithmType) {\n        this.setAttribute('load_balancing.algorithm.type', props.loadBalancingAlgorithmType);\n      }\n      this.addTarget(...(props.targets || []));\n    }\n  }\n\n  /**\n   * Add a load balancing target to this target group\n   */\n  public addTarget(...targets: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n\n    if (this.targetType === TargetType.LAMBDA) {\n      this.setAttribute('stickiness.enabled', undefined);\n    }\n  }\n\n  /**\n   * Enable sticky routing via a cookie to members of this target group.\n   *\n   * Note: If the `cookieName` parameter is set, application-based stickiness will be applied,\n   * otherwise it defaults to duration-based stickiness attributes (`lb_cookie`).\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/sticky-sessions.html\n   */\n  public enableCookieStickiness(duration: Duration, cookieName?: string) {\n    if (duration.toSeconds() < 1 || duration.toSeconds() > 604800) {\n      throw new Error('Stickiness cookie duration value must be between 1 second and 7 days (604800 seconds).');\n    }\n    if (cookieName !== undefined) {\n      if (!Token.isUnresolved(cookieName) && (cookieName.startsWith('AWSALB') || cookieName.startsWith('AWSALBAPP') || cookieName.startsWith('AWSALBTG'))) {\n        throw new Error('App cookie names that start with the following prefixes are not allowed: AWSALB, AWSALBAPP, and AWSALBTG; they\\'re reserved for use by the load balancer.');\n      }\n      if (cookieName === '') {\n        throw new Error('App cookie name cannot be an empty string.');\n      }\n    }\n    this.setAttribute('stickiness.enabled', 'true');\n    if (cookieName) {\n      this.setAttribute('stickiness.type', 'app_cookie');\n      this.setAttribute('stickiness.app_cookie.cookie_name', cookieName);\n      this.setAttribute('stickiness.app_cookie.duration_seconds', duration.toSeconds().toString());\n    } else {\n      this.setAttribute('stickiness.type', 'lb_cookie');\n      this.setAttribute('stickiness.lb_cookie.duration_seconds', duration.toSeconds().toString());\n    }\n  }\n\n  /**\n   * Register a connectable as a member of this target group.\n   *\n   * Don't call this directly. It will be called by load balancing targets.\n   */\n  public registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port) {\n    portRange = portRange || ec2.Port.tcp(this.defaultPort);\n\n    // Notify all listeners that we already know about of this new connectable.\n    // Then remember for new listeners that might get added later.\n    this.connectableMembers.push({ connectable, portRange });\n    for (const listener of this.listeners) {\n      listener.registerConnectable(connectable, portRange);\n    }\n  }\n\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  public registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct) {\n    // Notify this listener of all connectables that we know about.\n    // Then remember for new connectables that might get added later.\n    for (const member of this.connectableMembers) {\n      listener.registerConnectable(member.connectable, member.portRange);\n    }\n    this.listeners.push(listener);\n    this.loadBalancerAttachedDependencies.add((associatingConstruct || listener) as CoreConstruct);\n  }\n\n  /**\n   * Full name of first load balancer\n   */\n  public get firstLoadBalancerFullName(): string {\n    if (this.listeners.length === 0) {\n      throw new Error('The TargetGroup needs to be attached to a LoadBalancer before you can call this method');\n    }\n    return loadBalancerNameFromListenerArn(this.listeners[0].listenerArn);\n  }\n\n  /**\n   * Return the given named metric for this Application Load Balancer Target Group\n   *\n   * Returns the metric for this target group from the point of view of the first\n   * load balancer load balancing to it. If you have multiple load balancers load\n   * sending traffic to the same target group, you will have to override the dimensions\n   * on this metric.\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensionsMap: {\n        TargetGroup: this.targetGroupFullName,\n        LoadBalancer: this.firstLoadBalancerFullName,\n      },\n      ...props,\n    }).attachTo(this);\n  }\n\n  /**\n   * The number of IPv6 requests received by the target group\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricIpv6RequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.iPv6RequestCountSum, props);\n  }\n\n  /**\n   * The number of requests processed over IPv4 and IPv6.\n   *\n   * This count includes only the requests with a response generated by a target of the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(ApplicationELBMetrics.requestCountSum, props);\n  }\n\n  /**\n   * The number of healthy hosts in the target group\n   *\n   * @default Average over 5 minutes\n   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of unhealthy hosts in the target group\n   *\n   * @default Average over 5 minutes\n   */\n  public metricUnhealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets in this target group.\n   *\n   * This does not include any response codes generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions) {\n    return this.metric(code, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The average number of requests received by each target in a target group.\n   *\n   * The only valid statistic is Sum. Note that this represents the average not the sum.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricRequestCountPerTarget(props?: cloudwatch.MetricOptions) {\n    return this.metric('RequestCountPerTarget', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of connections that were not successfully established between the load balancer and target.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetConnectionErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricTargetResponseTime(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetResponseTime', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of TLS connections initiated by the load balancer that did not establish a session with the target.\n   *\n   * Possible causes include a mismatch of ciphers or protocols.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  protected validate(): string[] {\n    const ret = super.validate();\n\n    if (this.targetType !== undefined && this.targetType !== TargetType.LAMBDA\n      && (this.protocol === undefined || this.port === undefined)) {\n      ret.push('At least one of \\'port\\' or \\'protocol\\' is required for a non-Lambda TargetGroup');\n    }\n\n    if (this.healthCheck && this.healthCheck.protocol) {\n\n      if (ALB_HEALTH_CHECK_PROTOCOLS.includes(this.healthCheck.protocol)) {\n        if (this.healthCheck.interval && this.healthCheck.timeout &&\n          this.healthCheck.interval.toMilliseconds() <= this.healthCheck.timeout.toMilliseconds()) {\n          ret.push(`Healthcheck interval ${this.healthCheck.interval.toHumanString()} must be greater than the timeout ${this.healthCheck.timeout.toHumanString()}`);\n        }\n      }\n\n      if (!ALB_HEALTH_CHECK_PROTOCOLS.includes(this.healthCheck.protocol)) {\n        ret.push([\n          `Health check protocol '${this.healthCheck.protocol}' is not supported. `,\n          `Must be one of [${ALB_HEALTH_CHECK_PROTOCOLS.join(', ')}]`,\n        ].join(''));\n      }\n    }\n\n    return ret;\n  }\n\n  private cannedMetric(\n    fn: (dims: { LoadBalancer: string, TargetGroup: string }) => cloudwatch.MetricProps,\n    props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      ...fn({\n        LoadBalancer: this.firstLoadBalancerFullName,\n        TargetGroup: this.targetGroupFullName,\n      }),\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n/**\n * A connectable member of a target group\n */\ninterface ConnectableMember {\n  /**\n   * The connectable member\n   */\n  connectable: ec2.IConnectable;\n\n  /**\n   * The port (range) the member is listening on\n   */\n  portRange: ec2.Port;\n}\n\n/**\n * A Target Group for Application Load Balancers\n */\nexport interface IApplicationTargetGroup extends ITargetGroup {\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  registerListener(listener: IApplicationListener, associatingConstruct?: IConstruct): void;\n\n  /**\n   * Register a connectable as a member of this target group.\n   *\n   * Don't call this directly. It will be called by load balancing targets.\n   */\n  registerConnectable(connectable: ec2.IConnectable, portRange?: ec2.Port): void;\n\n  /**\n   * Add a load balancing target to this target group\n   */\n  addTarget(...targets: IApplicationLoadBalancerTarget[]): void;\n}\n\n/**\n * An imported application target group\n */\nclass ImportedApplicationTargetGroup extends ImportedTargetGroupBase implements IApplicationTargetGroup {\n  public registerListener(_listener: IApplicationListener, _associatingConstruct?: IConstruct) {\n    // Nothing to do, we know nothing of our members\n    Annotations.of(this).addWarning('Cannot register listener on imported target group -- security groups might need to be updated manually');\n  }\n\n  public registerConnectable(_connectable: ec2.IConnectable, _portRange?: ec2.Port | undefined): void {\n    Annotations.of(this).addWarning('Cannot register connectable on imported target group -- security groups might need to be updated manually');\n  }\n\n  public addTarget(...targets: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n\n      if (result.targetJson !== undefined) {\n        throw new Error('Cannot add a non-self registering target to an imported TargetGroup. Create a new TargetGroup instead.');\n      }\n    }\n  }\n}\n\n/**\n * Interface for constructs that can be targets of an application load balancer\n */\nexport interface IApplicationLoadBalancerTarget {\n  /**\n   * Attach load-balanced target to a TargetGroup\n   *\n   * May return JSON to directly add to the [Targets] list, or return undefined\n   * if the target will register itself with the load balancer.\n   */\n  attachToApplicationTargetGroup(targetGroup: IApplicationTargetGroup): LoadBalancerTargetProps;\n}\n\nconst ALB_HEALTH_CHECK_PROTOCOLS = [Protocol.HTTP, Protocol.HTTPS];\n"]}
/**
* ListenerCondition providers definition.
*
* @stability stable
*/
export declare abstract class ListenerCondition {
/**
* Create a host-header listener rule condition.
* Create a host-header listener rule condition
*
* @param values Hosts for host headers.
* @stability stable
* @param values Hosts for host headers
*/
static hostHeaders(values: string[]): ListenerCondition;
/**
* Create a http-header listener rule condition.
* Create a http-header listener rule condition
*
* @param name HTTP header name.
* @param values HTTP header values.
* @stability stable
* @param name HTTP header name
* @param values HTTP header values
*/
static httpHeader(name: string, values: string[]): ListenerCondition;
/**
* Create a http-request-method listener rule condition.
* Create a http-request-method listener rule condition
*
* @param values HTTP request methods.
* @stability stable
* @param values HTTP request methods
*/
static httpRequestMethods(values: string[]): ListenerCondition;
/**
* Create a path-pattern listener rule condition.
* Create a path-pattern listener rule condition
*
* @param values Path patterns.
* @stability stable
* @param values Path patterns
*/
static pathPatterns(values: string[]): ListenerCondition;
/**
* Create a query-string listener rule condition.
* Create a query-string listener rule condition
*
* @param values Query string key/value pairs.
* @stability stable
* @param values Query string key/value pairs
*/
static queryStrings(values: QueryStringCondition[]): ListenerCondition;
/**
* Create a source-ip listener rule condition.
* Create a source-ip listener rule condition
*
* @param values Source ips.
* @stability stable
* @param values Source ips
*/

@@ -52,4 +44,2 @@ static sourceIps(values: string[]): ListenerCondition;

* Render the raw Cfn listener rule condition object.
*
* @stability stable
*/

@@ -59,20 +49,15 @@ abstract renderRawCondition(): any;

/**
* Properties for the key/value pair of the query string.
*
* @stability stable
* Properties for the key/value pair of the query string
*/
export interface QueryStringCondition {
/**
* The query string key for the condition.
* The query string key for the condition
*
* @default - Any key can be matched.
* @stability stable
*/
readonly key?: string;
/**
* The query string value for the condition.
*
* @stability stable
* The query string value for the condition
*/
readonly value: string;
}

@@ -8,11 +8,8 @@ "use strict";

* ListenerCondition providers definition.
*
* @stability stable
*/
class ListenerCondition {
/**
* Create a host-header listener rule condition.
* Create a host-header listener rule condition
*
* @param values Hosts for host headers.
* @stability stable
* @param values Hosts for host headers
*/

@@ -23,7 +20,6 @@ static hostHeaders(values) {

/**
* Create a http-header listener rule condition.
* Create a http-header listener rule condition
*
* @param name HTTP header name.
* @param values HTTP header values.
* @stability stable
* @param name HTTP header name
* @param values HTTP header values
*/

@@ -34,6 +30,5 @@ static httpHeader(name, values) {

/**
* Create a http-request-method listener rule condition.
* Create a http-request-method listener rule condition
*
* @param values HTTP request methods.
* @stability stable
* @param values HTTP request methods
*/

@@ -44,6 +39,5 @@ static httpRequestMethods(values) {

/**
* Create a path-pattern listener rule condition.
* Create a path-pattern listener rule condition
*
* @param values Path patterns.
* @stability stable
* @param values Path patterns
*/

@@ -54,6 +48,5 @@ static pathPatterns(values) {

/**
* Create a query-string listener rule condition.
* Create a query-string listener rule condition
*
* @param values Query string key/value pairs.
* @stability stable
* @param values Query string key/value pairs
*/

@@ -64,6 +57,5 @@ static queryStrings(values) {

/**
* Create a source-ip listener rule condition.
* Create a source-ip listener rule condition
*
* @param values Source ips.
* @stability stable
* @param values Source ips
*/

@@ -76,3 +68,3 @@ static sourceIps(values) {

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

@@ -185,2 +177,2 @@ * Host header config of the listener rule condition

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"conditions.js","sourceRoot":"","sources":["conditions.ts"],"names":[],"mappings":"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","sourcesContent":["                                                  \nexport abstract class ListenerCondition {\n                                                                                                            \n  public static hostHeaders(values: string[]): ListenerCondition {\n    return new HostHeaderListenerCondition(values);\n  }\n\n                                                                                                                                          \n  public static httpHeader(name: string, values: string[]): ListenerCondition {\n    return new HttpHeaderListenerCondition(name, values);\n  }\n\n                                                                                                                  \n  public static httpRequestMethods(values: string[]): ListenerCondition {\n    return new HttpRequestMethodListenerCondition(values);\n  }\n\n                                                                                                    \n  public static pathPatterns(values: string[]): ListenerCondition {\n    return new PathPatternListenerCondition(values);\n  }\n\n                                                                                                                   \n  public static queryStrings(values: QueryStringCondition[]): ListenerCondition {\n    return new QueryStringListenerCondition(values);\n  }\n\n                                                                                              \n  public static sourceIps(values: string[]): ListenerCondition {\n    return new SourceIpListenerCondition(values);\n  }\n\n                                                                   \n  public abstract renderRawCondition(): any;\n}\n\n                                                                \nexport interface QueryStringCondition {\n                                                                                                    \n  readonly key?: string;\n\n                                                         \n  readonly value: string;\n}\n\n/**\n * Host header config of the listener rule condition\n */\nclass HostHeaderListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'host-header',\n      hostHeaderConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * HTTP header config of the listener rule condition\n */\nclass HttpHeaderListenerCondition extends ListenerCondition {\n  constructor(public readonly name: string, public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'http-header',\n      httpHeaderConfig: {\n        httpHeaderName: this.name,\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * HTTP reqeust method config of the listener rule condition\n */\nclass HttpRequestMethodListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'http-request-method',\n      httpRequestMethodConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * Path pattern config of the listener rule condition\n */\nclass PathPatternListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n    if (values && values.length > 5) {\n      throw new Error(\"A rule can only have '5' condition values\");\n    }\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'path-pattern',\n      pathPatternConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * Query string config of the listener rule condition\n */\nclass QueryStringListenerCondition extends ListenerCondition {\n  constructor(public readonly values: QueryStringCondition[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'query-string',\n      queryStringConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * Source ip config of the listener rule condition\n */\nclass SourceIpListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'source-ip',\n      sourceIpConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"conditions.js","sourceRoot":"","sources":["conditions.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ListenerCondition providers definition.\n */\nexport abstract class ListenerCondition {\n  /**\n   * Create a host-header listener rule condition\n   *\n   * @param values Hosts for host headers\n   */\n  public static hostHeaders(values: string[]): ListenerCondition {\n    return new HostHeaderListenerCondition(values);\n  }\n\n  /**\n   * Create a http-header listener rule condition\n   *\n   * @param name HTTP header name\n   * @param values HTTP header values\n   */\n  public static httpHeader(name: string, values: string[]): ListenerCondition {\n    return new HttpHeaderListenerCondition(name, values);\n  }\n\n  /**\n   * Create a http-request-method listener rule condition\n   *\n   * @param values HTTP request methods\n   */\n  public static httpRequestMethods(values: string[]): ListenerCondition {\n    return new HttpRequestMethodListenerCondition(values);\n  }\n\n  /**\n   * Create a path-pattern listener rule condition\n   *\n   * @param values Path patterns\n   */\n  public static pathPatterns(values: string[]): ListenerCondition {\n    return new PathPatternListenerCondition(values);\n  }\n\n  /**\n   * Create a query-string listener rule condition\n   *\n   * @param values Query string key/value pairs\n   */\n  public static queryStrings(values: QueryStringCondition[]): ListenerCondition {\n    return new QueryStringListenerCondition(values);\n  }\n\n  /**\n   * Create a source-ip listener rule condition\n   *\n   * @param values Source ips\n   */\n  public static sourceIps(values: string[]): ListenerCondition {\n    return new SourceIpListenerCondition(values);\n  }\n\n  /**\n   * Render the raw Cfn listener rule condition object.\n   */\n  public abstract renderRawCondition(): any;\n}\n\n/**\n * Properties for the key/value pair of the query string\n */\nexport interface QueryStringCondition {\n  /**\n   * The query string key for the condition\n   *\n   * @default - Any key can be matched.\n   */\n  readonly key?: string;\n\n  /**\n   * The query string value for the condition\n   */\n  readonly value: string;\n}\n\n/**\n * Host header config of the listener rule condition\n */\nclass HostHeaderListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'host-header',\n      hostHeaderConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * HTTP header config of the listener rule condition\n */\nclass HttpHeaderListenerCondition extends ListenerCondition {\n  constructor(public readonly name: string, public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'http-header',\n      httpHeaderConfig: {\n        httpHeaderName: this.name,\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * HTTP reqeust method config of the listener rule condition\n */\nclass HttpRequestMethodListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'http-request-method',\n      httpRequestMethodConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * Path pattern config of the listener rule condition\n */\nclass PathPatternListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n    if (values && values.length > 5) {\n      throw new Error(\"A rule can only have '5' condition values\");\n    }\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'path-pattern',\n      pathPatternConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * Query string config of the listener rule condition\n */\nclass QueryStringListenerCondition extends ListenerCondition {\n  constructor(public readonly values: QueryStringCondition[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'query-string',\n      queryStringConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n\n/**\n * Source ip config of the listener rule condition\n */\nclass SourceIpListenerCondition extends ListenerCondition {\n  constructor(public readonly values: string[]) {\n    super();\n  }\n\n  public renderRawCondition(): any {\n    return {\n      field: 'source-ip',\n      sourceIpConfig: {\n        values: this.values,\n      },\n    };\n  }\n}\n"]}

@@ -8,3 +8,3 @@ import { Duration } from '@aws-cdk/core';

/**
* What to do when a client makes a request to a listener.
* What to do when a client makes a request to a listener
*

@@ -19,4 +19,2 @@ * Some actions can be combined with other ones (specifically,

* by passing it in the `next` property.
*
* @stability stable
*/

@@ -27,15 +25,11 @@ export declare class NetworkListenerAction implements IListenerAction {

/**
* Forward to one or more Target Groups.
*
* @stability stable
* Forward to one or more Target Groups
*/
static forward(targetGroups: INetworkTargetGroup[], options?: NetworkForwardOptions): NetworkListenerAction;
/**
* Forward to one or more Target Groups which are weighted differently.
*
* @stability stable
* Forward to one or more Target Groups which are weighted differently
*/
static weightedForward(targetGroups: NetworkWeightedTargetGroup[], options?: NetworkForwardOptions): NetworkListenerAction;
/**
* Create an instance of NetworkListenerAction.
* Create an instance of NetworkListenerAction
*

@@ -45,16 +39,10 @@ * The default class should be good enough for most cases and

* but allow overriding to make sure we allow flexibility for the future.
*
* @stability stable
*/
protected constructor(actionJson: CfnListener.ActionProperty, next?: NetworkListenerAction | undefined);
/**
* Render the actions in this chain.
*
* @stability stable
* Render the actions in this chain
*/
renderActions(): CfnListener.ActionProperty[];
/**
* Called when the action is being used in a listener.
*
* @stability stable
* Called when the action is being used in a listener
*/

@@ -70,4 +58,2 @@ bind(scope: Construct, listener: INetworkListener): void;

* users the opportunity to override by subclassing and overriding `renderActions`.
*
* @stability stable
*/

@@ -77,9 +63,7 @@ protected renumber(actions: CfnListener.ActionProperty[]): CfnListener.ActionProperty[];

/**
* Options for `NetworkListenerAction.forward()`.
*
* @stability stable
* Options for `NetworkListenerAction.forward()`
*/
export interface NetworkForwardOptions {
/**
* For how long clients should be directed to the same target group.
* For how long clients should be directed to the same target group
*

@@ -89,3 +73,2 @@ * Range between 1 second and 7 days.

* @default - No stickiness
* @stability stable
*/

@@ -95,15 +78,11 @@ readonly stickinessDuration?: Duration;

/**
* A Target Group and weight combination.
*
* @stability stable
* A Target Group and weight combination
*/
export interface NetworkWeightedTargetGroup {
/**
* The target group.
*
* @stability stable
* The target group
*/
readonly targetGroup: INetworkTargetGroup;
/**
* The target group's weight.
* The target group's weight
*

@@ -113,5 +92,4 @@ * Range is [0..1000).

* @default 1
* @stability stable
*/
readonly weight?: number;
}

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

/**
* What to do when a client makes a request to a listener.
* What to do when a client makes a request to a listener
*

@@ -19,8 +19,6 @@ * Some actions can be combined with other ones (specifically,

* by passing it in the `next` property.
*
* @stability stable
*/
class NetworkListenerAction {
/**
* Create an instance of NetworkListenerAction.
* Create an instance of NetworkListenerAction
*

@@ -30,4 +28,2 @@ * The default class should be good enough for most cases and

* but allow overriding to make sure we allow flexibility for the future.
*
* @stability stable
*/

@@ -41,5 +37,3 @@ constructor(actionJson, next) {

/**
* Forward to one or more Target Groups.
*
* @stability stable
* Forward to one or more Target Groups
*/

@@ -70,5 +64,3 @@ static forward(targetGroups, options = {}) {

/**
* Forward to one or more Target Groups which are weighted differently.
*
* @stability stable
* Forward to one or more Target Groups which are weighted differently
*/

@@ -92,5 +84,3 @@ static weightedForward(targetGroups, options = {}) {

/**
* Render the actions in this chain.
*
* @stability stable
* Render the actions in this chain
*/

@@ -102,5 +92,3 @@ renderActions() {

/**
* Called when the action is being used in a listener.
*
* @stability stable
* Called when the action is being used in a listener
*/

@@ -121,4 +109,2 @@ bind(scope, listener) {

* users the opportunity to override by subclassing and overriding `renderActions`.
*
* @stability stable
*/

@@ -134,3 +120,3 @@ renumber(actions) {

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

@@ -150,2 +136,2 @@ * Listener Action that calls "registerListener" on TargetGroups

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-listener-action.js","sourceRoot":"","sources":["network-listener-action.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from '@aws-cdk/core';\nimport { CfnListener } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from '../shared/listener-action';\nimport { INetworkListener } from './network-listener';\nimport { INetworkTargetGroup } from './network-target-group';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct } from '@aws-cdk/core';\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                 \nexport class NetworkListenerAction implements IListenerAction {\n                                                     \n  public static forward(targetGroups: INetworkTargetGroup[], options: NetworkForwardOptions = {}): NetworkListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a NetworkListenerAction.forward()');\n    }\n    if (targetGroups.length === 1 && options.stickinessDuration === undefined) {\n      // Render a \"simple\" action for backwards compatibility with old templates\n      return new TargetGroupListenerAction(targetGroups, {\n        type: 'forward',\n        targetGroupArn: targetGroups[0].targetGroupArn,\n      });\n    }\n\n    return new TargetGroupListenerAction(targetGroups, {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroupArn })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n                                                                                    \n  public static weightedForward(targetGroups: NetworkWeightedTargetGroup[], options: NetworkForwardOptions = {}): NetworkListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a NetworkListenerAction.weightedForward()');\n    }\n\n    return new TargetGroupListenerAction(targetGroups.map(g => g.targetGroup), {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroup.targetGroupArn, weight: g.weight })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n                                                                                                                                                                                                                                                                                  \n  protected constructor(private readonly actionJson: CfnListener.ActionProperty, protected readonly next?: NetworkListenerAction) {\n  }\n\n                                                 \n  public renderActions(): CfnListener.ActionProperty[] {\n    return this.renumber([this.actionJson, ...this.next?.renderActions() ?? []]);\n  }\n\n                                                                   \n  public bind(scope: Construct, listener: INetworkListener) {\n    // Empty on purpose\n    Array.isArray(scope);\n    Array.isArray(listener);\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                             \n  protected renumber(actions: CfnListener.ActionProperty[]): CfnListener.ActionProperty[] {\n    if (actions.length < 2) { return actions; }\n\n    return actions.map((action, i) => ({ ...action, order: i + 1 }));\n  }\n}\n\n                                                        \nexport interface NetworkForwardOptions {\n                                                                                                                                                                 \n  readonly stickinessDuration?: Duration;\n}\n\n                                                \nexport interface NetworkWeightedTargetGroup {\n                                 \n  readonly targetGroup: INetworkTargetGroup;\n\n                                                                                             \n  readonly weight?: number;\n}\n\n/**\n * Listener Action that calls \"registerListener\" on TargetGroups\n */\nclass TargetGroupListenerAction extends NetworkListenerAction {\n  constructor(private readonly targetGroups: INetworkTargetGroup[], actionJson: CfnListener.ActionProperty) {\n    super(actionJson);\n  }\n\n  public bind(_scope: Construct, listener: INetworkListener) {\n    for (const tg of this.targetGroups) {\n      tg.registerListener(listener);\n    }\n  }\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-listener-action.js","sourceRoot":"","sources":["network-listener-action.ts"],"names":[],"mappings":";;;;;;AAUA;;;;;;;;;;;GAWG;AACH,MAAa,qBAAqB;IAgDhC;;;;;;OAMG;IACH,YAAuC,UAAsC,EAAqB,IAA4B;QAAvF,eAAU,GAAV,UAAU,CAA4B;QAAqB,SAAI,GAAJ,IAAI,CAAwB;;;KAC7H;IAvDD;;OAEG;IACI,MAAM,CAAC,OAAO,CAAC,YAAmC,EAAE,UAAiC,EAAE;;QAC5F,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,oEAAoE,CAAC,CAAC;SACvF;QACD,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,kBAAkB,KAAK,SAAS,EAAE;YACzE,0EAA0E;YAC1E,OAAO,IAAI,yBAAyB,CAAC,YAAY,EAAE;gBACjD,IAAI,EAAE,SAAS;gBACf,cAAc,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,cAAc;aAC/C,CAAC,CAAC;SACJ;QAED,OAAO,IAAI,yBAAyB,CAAC,YAAY,EAAE;YACjD,IAAI,EAAE,SAAS;YACf,aAAa,EAAE;gBACb,YAAY,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC;gBAC3E,2BAA2B,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC;oBACxD,eAAe,EAAE,OAAO,CAAC,kBAAkB,CAAC,SAAS,EAAE;oBACvD,OAAO,EAAE,IAAI;iBACd,CAAC,CAAC,CAAC,SAAS;aACd;SACF,CAAC,CAAC;KACJ;IAED;;OAEG;IACI,MAAM,CAAC,eAAe,CAAC,YAA0C,EAAE,UAAiC,EAAE;;QAC3G,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,4EAA4E,CAAC,CAAC;SAC/F;QAED,OAAO,IAAI,yBAAyB,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,EAAE;YACzE,IAAI,EAAE,SAAS;YACf,aAAa,EAAE;gBACb,YAAY,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC,WAAW,CAAC,cAAc,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;gBACzG,2BAA2B,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC;oBACxD,eAAe,EAAE,OAAO,CAAC,kBAAkB,CAAC,SAAS,EAAE;oBACvD,OAAO,EAAE,IAAI;iBACd,CAAC,CAAC,CAAC,SAAS;aACd;SACF,CAAC,CAAC;KACJ;IAYD;;OAEG;IACI,aAAa;;QAClB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,eAAG,IAAI,CAAC,IAAI,0CAAE,aAAa,qCAAM,EAAE,CAAC,CAAC,CAAC;KAC9E;IAED;;OAEG;IACI,IAAI,CAAC,KAAgB,EAAE,QAA0B;;QACtD,mBAAmB;QACnB,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrB,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;KACzB;IAED;;;;;;;;OAQG;IACO,QAAQ,CAAC,OAAqC;QACtD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAAE,OAAO,OAAO,CAAC;SAAE;QAE3C,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;KAClE;;AAvFH,sDAwFC;;;AAmCD;;GAEG;AACH,MAAM,yBAA0B,SAAQ,qBAAqB;IAC3D,YAA6B,YAAmC,EAAE,UAAsC;QACtG,KAAK,CAAC,UAAU,CAAC,CAAC;QADS,iBAAY,GAAZ,YAAY,CAAuB;KAE/D;IAEM,IAAI,CAAC,MAAiB,EAAE,QAA0B;QACvD,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE;YAClC,EAAE,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;SAC/B;KACF;CACF","sourcesContent":["import { Duration } from '@aws-cdk/core';\nimport { CfnListener } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from '../shared/listener-action';\nimport { INetworkListener } from './network-listener';\nimport { INetworkTargetGroup } from './network-target-group';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct } from '@aws-cdk/core';\n\n/**\n * What to do when a client makes a request to a listener\n *\n * Some actions can be combined with other ones (specifically,\n * you can perform authentication before serving the request).\n *\n * Multiple actions form a linked chain; the chain must always terminate in a\n * *(weighted)forward*, *fixedResponse* or *redirect* action.\n *\n * If an action supports chaining, the next action can be indicated\n * by passing it in the `next` property.\n */\nexport class NetworkListenerAction implements IListenerAction {\n  /**\n   * Forward to one or more Target Groups\n   */\n  public static forward(targetGroups: INetworkTargetGroup[], options: NetworkForwardOptions = {}): NetworkListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a NetworkListenerAction.forward()');\n    }\n    if (targetGroups.length === 1 && options.stickinessDuration === undefined) {\n      // Render a \"simple\" action for backwards compatibility with old templates\n      return new TargetGroupListenerAction(targetGroups, {\n        type: 'forward',\n        targetGroupArn: targetGroups[0].targetGroupArn,\n      });\n    }\n\n    return new TargetGroupListenerAction(targetGroups, {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroupArn })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n  /**\n   * Forward to one or more Target Groups which are weighted differently\n   */\n  public static weightedForward(targetGroups: NetworkWeightedTargetGroup[], options: NetworkForwardOptions = {}): NetworkListenerAction {\n    if (targetGroups.length === 0) {\n      throw new Error('Need at least one targetGroup in a NetworkListenerAction.weightedForward()');\n    }\n\n    return new TargetGroupListenerAction(targetGroups.map(g => g.targetGroup), {\n      type: 'forward',\n      forwardConfig: {\n        targetGroups: targetGroups.map(g => ({ targetGroupArn: g.targetGroup.targetGroupArn, weight: g.weight })),\n        targetGroupStickinessConfig: options.stickinessDuration ? {\n          durationSeconds: options.stickinessDuration.toSeconds(),\n          enabled: true,\n        } : undefined,\n      },\n    });\n  }\n\n  /**\n   * Create an instance of NetworkListenerAction\n   *\n   * The default class should be good enough for most cases and\n   * should be created by using one of the static factory functions,\n   * but allow overriding to make sure we allow flexibility for the future.\n   */\n  protected constructor(private readonly actionJson: CfnListener.ActionProperty, protected readonly next?: NetworkListenerAction) {\n  }\n\n  /**\n   * Render the actions in this chain\n   */\n  public renderActions(): CfnListener.ActionProperty[] {\n    return this.renumber([this.actionJson, ...this.next?.renderActions() ?? []]);\n  }\n\n  /**\n   * Called when the action is being used in a listener\n   */\n  public bind(scope: Construct, listener: INetworkListener) {\n    // Empty on purpose\n    Array.isArray(scope);\n    Array.isArray(listener);\n  }\n\n  /**\n   * Renumber the \"order\" fields in the actions array.\n   *\n   * We don't number for 0 or 1 elements, but otherwise number them 1...#actions\n   * so ELB knows about the right order.\n   *\n   * Do this in `NetworkListenerAction` instead of in `Listener` so that we give\n   * users the opportunity to override by subclassing and overriding `renderActions`.\n   */\n  protected renumber(actions: CfnListener.ActionProperty[]): CfnListener.ActionProperty[] {\n    if (actions.length < 2) { return actions; }\n\n    return actions.map((action, i) => ({ ...action, order: i + 1 }));\n  }\n}\n\n/**\n * Options for `NetworkListenerAction.forward()`\n */\nexport interface NetworkForwardOptions {\n  /**\n   * For how long clients should be directed to the same target group\n   *\n   * Range between 1 second and 7 days.\n   *\n   * @default - No stickiness\n   */\n  readonly stickinessDuration?: Duration;\n}\n\n/**\n * A Target Group and weight combination\n */\nexport interface NetworkWeightedTargetGroup {\n  /**\n   * The target group\n   */\n  readonly targetGroup: INetworkTargetGroup;\n\n  /**\n   * The target group's weight\n   *\n   * Range is [0..1000).\n   *\n   * @default 1\n   */\n  readonly weight?: number;\n}\n\n/**\n * Listener Action that calls \"registerListener\" on TargetGroups\n */\nclass TargetGroupListenerAction extends NetworkListenerAction {\n  constructor(private readonly targetGroups: INetworkTargetGroup[], actionJson: CfnListener.ActionProperty) {\n    super(actionJson);\n  }\n\n  public bind(_scope: Construct, listener: INetworkListener) {\n    for (const tg of this.targetGroups) {\n      tg.registerListener(listener);\n    }\n  }\n}"]}

@@ -11,5 +11,3 @@ import { Duration, IResource } from '@aws-cdk/core';

/**
* Basic properties for a Network Listener.
*
* @stability stable
* Basic properties for a Network Listener
*/

@@ -19,8 +17,6 @@ export interface BaseNetworkListenerProps {

* The port on which the listener listens for requests.
*
* @stability stable
*/
readonly port: number;
/**
* Default target groups to load balance to.
* Default target groups to load balance to
*

@@ -34,7 +30,6 @@ * All target groups will be load balanced to with equal weight and without

* @default - None.
* @stability stable
*/
readonly defaultTargetGroups?: INetworkTargetGroup[];
/**
* Default action to take for requests to this listener.
* Default action to take for requests to this listener
*

@@ -48,3 +43,2 @@ * This allows full control of the default Action of the load balancer,

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

@@ -56,19 +50,14 @@ readonly defaultAction?: NetworkListenerAction;

* @default - TLS if certificates are provided. TCP otherwise.
* @stability stable
*/
readonly protocol?: Protocol;
/**
* Certificate list of ACM cert ARNs.
* Certificate list of ACM cert ARNs. You must provide exactly one certificate if the listener protocol is HTTPS or TLS.
*
* You must provide exactly one certificate if the listener protocol is HTTPS or TLS.
*
* @default - No certificates.
* @stability stable
*/
readonly certificates?: IListenerCertificate[];
/**
* SSL Policy.
* SSL Policy
*
* @default - Current predefined security policy.
* @stability stable
*/

@@ -78,3 +67,2 @@ readonly sslPolicy?: SslPolicy;

* Application-Layer Protocol Negotiation (ALPN) is a TLS extension that is sent on the initial TLS handshake hello messages.
*
* ALPN enables the application layer to negotiate which protocols should be used over a secure connection, such as HTTP/1 and HTTP/2.

@@ -85,3 +73,2 @@ *

* @default - None
* @stability stable
*/

@@ -91,3 +78,3 @@ readonly alpnPolicy?: AlpnPolicy;

/**
* (deprecated) Properties for adding a certificate to a listener.
* Properties for adding a certificate to a listener
*

@@ -101,11 +88,7 @@ * This interface exists for backwards compatibility.

/**
* Properties for a Network Listener attached to a Load Balancer.
*
* @stability stable
* Properties for a Network Listener attached to a Load Balancer
*/
export interface NetworkListenerProps extends BaseNetworkListenerProps {
/**
* The load balancer to attach this listener to.
*
* @stability stable
* The load balancer to attach this listener to
*/

@@ -116,11 +99,7 @@ readonly loadBalancer: INetworkLoadBalancer;

* Options for looking up a network listener.
*
* @stability stable
*/
export interface NetworkListenerLookupOptions extends BaseListenerLookupOptions {
/**
* Protocol of the listener port.
*
* Protocol of the listener port
* @default - listener is not filtered by protocol
* @stability stable
*/

@@ -130,5 +109,4 @@ readonly listenerProtocol?: Protocol;

/**
* Define a Network Listener.
* Define a Network Listener
*
* @stability stable
* @resource AWS::ElasticLoadBalancingV2::Listener

@@ -138,17 +116,11 @@ */

/**
* Looks up a network listener.
*
* @stability stable
* Looks up a network listener
*/
static fromLookup(scope: Construct, id: string, options: NetworkListenerLookupOptions): INetworkListener;
/**
* Import an existing listener.
*
* @stability stable
* Import an existing listener
*/
static fromNetworkListenerArn(scope: Construct, id: string, networkListenerArn: string): INetworkListener;
/**
* The load balancer this listener is attached to.
*
* @stability stable
* The load balancer this listener is attached to
*/

@@ -160,5 +132,2 @@ readonly loadBalancer: INetworkLoadBalancer;

private readonly protocol;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: NetworkListenerProps);

@@ -170,8 +139,6 @@ /**

* stickiness. For a more complex configuration than that, use `addAction()`.
*
* @stability stable
*/
addTargetGroups(_id: string, ...targetGroups: INetworkTargetGroup[]): void;
/**
* Perform the given Action on incoming requests.
* Perform the given Action on incoming requests
*

@@ -181,4 +148,2 @@ * This allows full control of the default Action of the load balancer,

* all options.
*
* @stability stable
*/

@@ -199,3 +164,2 @@ addAction(_id: string, props: AddNetworkActionProps): void;

* @returns The newly created target group
* @stability stable
*/

@@ -209,12 +173,8 @@ addTargets(id: string, props: AddNetworkTargetsProps): NetworkTargetGroup;

/**
* Properties to reference an existing listener.
*
* @stability stable
* Properties to reference an existing listener
*/
export interface INetworkListener extends IResource {
/**
* ARN of the listener.
*
* @stability stable
* @attribute true
* ARN of the listener
* @attribute
*/

@@ -224,11 +184,7 @@ readonly listenerArn: string;

/**
* Properties for adding a new action to a listener.
*
* @stability stable
* Properties for adding a new action to a listener
*/
export interface AddNetworkActionProps {
/**
* Action to perform.
*
* @stability stable
* Action to perform
*/

@@ -238,5 +194,3 @@ readonly action: NetworkListenerAction;

/**
* Properties for adding new network targets to a listener.
*
* @stability stable
* Properties for adding new network targets to a listener
*/

@@ -248,3 +202,2 @@ export interface AddNetworkTargetsProps {

* @default Determined from protocol if known
* @stability stable
*/

@@ -256,3 +209,2 @@ readonly port: number;

* @default - inherits the protocol of the listener
* @stability stable
*/

@@ -266,4 +218,2 @@ readonly protocol?: Protocol;

* target must be of the same type.
*
* @stability stable
*/

@@ -279,3 +229,2 @@ readonly targets?: INetworkLoadBalancerTarget[];

* @default Automatically generated
* @stability stable
*/

@@ -289,3 +238,2 @@ readonly targetGroupName?: string;

* @default Duration.minutes(5)
* @stability stable
*/

@@ -297,3 +245,2 @@ readonly deregistrationDelay?: Duration;

* @default false
* @stability stable
*/

@@ -306,12 +253,10 @@ readonly proxyProtocolV2?: boolean;

* target group protocol is TCP or TLS. Otherwise, true.
* @stability stable
*/
readonly preserveClientIp?: boolean;
/**
* Health check configuration.
* Health check configuration
*
* @default No health check
* @stability stable
*/
readonly healthCheck?: HealthCheck;
}

@@ -15,11 +15,7 @@ "use strict";

/**
* Define a Network Listener.
* Define a Network Listener
*
* @stability stable
* @resource AWS::ElasticLoadBalancingV2::Listener
*/
class NetworkListener extends base_listener_1.BaseListener {
/**
* @stability stable
*/
constructor(scope, id, props) {

@@ -60,5 +56,3 @@ jsiiDeprecationWarnings._aws_cdk_aws_elasticloadbalancingv2_NetworkListenerProps(props);

/**
* Looks up a network listener.
*
* @stability stable
* Looks up a network listener
*/

@@ -99,5 +93,3 @@ static fromLookup(scope, id, options) {

/**
* Import an existing listener.
*
* @stability stable
* Import an existing listener
*/

@@ -118,4 +110,2 @@ static fromNetworkListenerArn(scope, id, networkListenerArn) {

* stickiness. For a more complex configuration than that, use `addAction()`.
*
* @stability stable
*/

@@ -127,3 +117,3 @@ addTargetGroups(_id, ...targetGroups) {

/**
* Perform the given Action on incoming requests.
* Perform the given Action on incoming requests
*

@@ -133,4 +123,2 @@ * This allows full control of the default Action of the load balancer,

* all options.
*
* @stability stable
*/

@@ -154,3 +142,2 @@ addAction(_id, props) {

* @returns The newly created target group
* @stability stable
*/

@@ -188,3 +175,3 @@ addTargets(id, props) {

_a = JSII_RTTI_SYMBOL_1;
NetworkListener[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.NetworkListener", version: "1.144.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-listener.js","sourceRoot":"","sources":["network-listener.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Duration, IResource, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { BaseListener, BaseListenerLookupOptions } from '../shared/base-listener';\nimport { HealthCheck } from '../shared/base-target-group';\nimport { AlpnPolicy, Protocol, SslPolicy } from '../shared/enums';\nimport { IListenerCertificate } from '../shared/listener-certificate';\nimport { validateNetworkProtocol } from '../shared/util';\nimport { NetworkListenerAction } from './network-listener-action';\nimport { INetworkLoadBalancer } from './network-load-balancer';\nimport { INetworkLoadBalancerTarget, INetworkTargetGroup, NetworkTargetGroup } from './network-target-group';\n\n                                                  \nexport interface BaseNetworkListenerProps {\n                                                                     \n  readonly port: number;\n\n                                                                                                                                                                                                                                                                                                                                                   \n  readonly defaultTargetGroups?: INetworkTargetGroup[];\n\n                                                                                                                                                                                                                                                                                                                                                  \n  readonly defaultAction?: NetworkListenerAction;\n\n                                                                                                                                                \n  readonly protocol?: Protocol;\n\n                                                                                                                                                                            \n  readonly certificates?: IListenerCertificate[];\n\n                                                                                    \n  readonly sslPolicy?: SslPolicy;\n\n\n                                                                                                                                                                                                                                                                                                                                                                          \n  readonly alpnPolicy?: AlpnPolicy;\n}\n\n                                                                                                                                                                        \nexport interface INetworkListenerCertificateProps extends IListenerCertificate {\n}\n\n                                                                        \nexport interface NetworkListenerProps extends BaseNetworkListenerProps {\n                                                             \n  readonly loadBalancer: INetworkLoadBalancer;\n}\n\n                                                     \nexport interface NetworkListenerLookupOptions extends BaseListenerLookupOptions {\n                                                                                                   \n  readonly listenerProtocol?: Protocol;\n}\n\n                                                                                          \nexport class NetworkListener extends BaseListener implements INetworkListener {\n                                            \n  public static fromLookup(scope: Construct, id: string, options: NetworkListenerLookupOptions): INetworkListener {\n    let listenerProtocol: cxschema.LoadBalancerListenerProtocol | undefined;\n    if (options.listenerProtocol) {\n      validateNetworkProtocol(options.listenerProtocol);\n\n      switch (options.listenerProtocol) {\n        case Protocol.TCP: listenerProtocol = cxschema.LoadBalancerListenerProtocol.TCP; break;\n        case Protocol.UDP: listenerProtocol = cxschema.LoadBalancerListenerProtocol.UDP; break;\n        case Protocol.TCP_UDP: listenerProtocol = cxschema.LoadBalancerListenerProtocol.TCP_UDP; break;\n        case Protocol.TLS: listenerProtocol = cxschema.LoadBalancerListenerProtocol.TLS; break;\n      }\n    }\n\n    const props = BaseListener._queryContextProvider(scope, {\n      userOptions: options,\n      listenerProtocol: listenerProtocol,\n      loadBalancerType: cxschema.LoadBalancerType.NETWORK,\n    });\n\n    class LookedUp extends Resource implements INetworkListener {\n      public listenerArn = props.listenerArn;\n    }\n\n    return new LookedUp(scope, id);\n  }\n\n                                            \n  public static fromNetworkListenerArn(scope: Construct, id: string, networkListenerArn: string): INetworkListener {\n    class Import extends Resource implements INetworkListener {\n      public listenerArn = networkListenerArn;\n    }\n\n    return new Import(scope, id);\n  }\n\n                                                               \n  public readonly loadBalancer: INetworkLoadBalancer;\n\n  /**\n   * the protocol of the listener\n   */\n  private readonly protocol: Protocol;\n\n  constructor(scope: Construct, id: string, props: NetworkListenerProps) {\n    const certs = props.certificates || [];\n    const proto = props.protocol || (certs.length > 0 ? Protocol.TLS : Protocol.TCP);\n\n    validateNetworkProtocol(proto);\n\n    if (proto === Protocol.TLS && certs.filter(v => v != null).length === 0) {\n      throw new Error('When the protocol is set to TLS, you must specify certificates');\n    }\n\n    if (proto !== Protocol.TLS && certs.length > 0) {\n      throw new Error('Protocol must be TLS when certificates have been specified');\n    }\n\n    if (proto !== Protocol.TLS && props.alpnPolicy) {\n      throw new Error('Protocol must be TLS when alpnPolicy have been specified');\n    }\n\n    super(scope, id, {\n      loadBalancerArn: props.loadBalancer.loadBalancerArn,\n      protocol: proto,\n      port: props.port,\n      sslPolicy: props.sslPolicy,\n      certificates: props.certificates,\n      alpnPolicy: props.alpnPolicy ? [props.alpnPolicy] : undefined,\n    });\n\n    this.loadBalancer = props.loadBalancer;\n    this.protocol = proto;\n\n    if (props.defaultAction && props.defaultTargetGroups) {\n      throw new Error('Specify at most one of \\'defaultAction\\' and \\'defaultTargetGroups\\'');\n    }\n\n    if (props.defaultAction) {\n      this.setDefaultAction(props.defaultAction);\n    }\n\n    if (props.defaultTargetGroups) {\n      this.setDefaultAction(NetworkListenerAction.forward(props.defaultTargetGroups));\n    }\n  }\n\n                                                                                                                                                                                                                                              \n  public addTargetGroups(_id: string, ...targetGroups: INetworkTargetGroup[]): void {\n    this.setDefaultAction(NetworkListenerAction.forward(targetGroups));\n  }\n\n                                                                                                                                                                                                                                             \n  public addAction(_id: string, props: AddNetworkActionProps): void {\n    this.setDefaultAction(props.action);\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         \n  public addTargets(id: string, props: AddNetworkTargetsProps): NetworkTargetGroup {\n    if (!this.loadBalancer.vpc) {\n      // eslint-disable-next-line max-len\n      throw new Error('Can only call addTargets() when using a constructed Load Balancer or imported Load Balancer with specified VPC; construct a new TargetGroup and use addTargetGroup');\n    }\n\n    const group = new NetworkTargetGroup(this, id + 'Group', {\n      deregistrationDelay: props.deregistrationDelay,\n      healthCheck: props.healthCheck,\n      port: props.port,\n      protocol: props.protocol ?? this.protocol,\n      proxyProtocolV2: props.proxyProtocolV2,\n      preserveClientIp: props.preserveClientIp,\n      targetGroupName: props.targetGroupName,\n      targets: props.targets,\n      vpc: this.loadBalancer.vpc,\n    });\n\n    this.addTargetGroups(id, group);\n\n    return group;\n  }\n\n  /**\n   * Wrapper for _setDefaultAction which does a type-safe bind\n   */\n  private setDefaultAction(action: NetworkListenerAction) {\n    action.bind(this, this);\n    this._setDefaultAction(action);\n  }\n}\n\n                                                       \nexport interface INetworkListener extends IResource {\n                                                    \n  readonly listenerArn: string;\n}\n\n                                                           \nexport interface AddNetworkActionProps {\n                                  \n  readonly action: NetworkListenerAction;\n}\n\n                                                                  \nexport interface AddNetworkTargetsProps {\n                                                                                                                          \n  readonly port: number;\n\n                                                                                                                                         \n  readonly protocol?: Protocol;\n\n                                                                                                                                                                                                                                                         \n  readonly targets?: INetworkLoadBalancerTarget[];\n\n                                                                                                                                                                                                                                                                                                  \n  readonly targetGroupName?: string;\n\n                                                                                                                                                                                   \n  readonly deregistrationDelay?: Duration;\n\n                                                                                                \n  readonly proxyProtocolV2?: boolean;\n\n                                                                                                                                                                                                        \n  readonly preserveClientIp?: boolean;\n\n                                                                              \n  readonly healthCheck?: HealthCheck;\n}\n"]}
NetworkListener[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.NetworkListener", version: "1.145.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-listener.js","sourceRoot":"","sources":["network-listener.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Duration, IResource, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { BaseListener, BaseListenerLookupOptions } from '../shared/base-listener';\nimport { HealthCheck } from '../shared/base-target-group';\nimport { AlpnPolicy, Protocol, SslPolicy } from '../shared/enums';\nimport { IListenerCertificate } from '../shared/listener-certificate';\nimport { validateNetworkProtocol } from '../shared/util';\nimport { NetworkListenerAction } from './network-listener-action';\nimport { INetworkLoadBalancer } from './network-load-balancer';\nimport { INetworkLoadBalancerTarget, INetworkTargetGroup, NetworkTargetGroup } from './network-target-group';\n\n/**\n * Basic properties for a Network Listener\n */\nexport interface BaseNetworkListenerProps {\n  /**\n   * The port on which the listener listens for requests.\n   */\n  readonly port: number;\n\n  /**\n   * Default target groups to load balance to\n   *\n   * All target groups will be load balanced to with equal weight and without\n   * stickiness. For a more complex configuration than that, use\n   * either `defaultAction` or `addAction()`.\n   *\n   * Cannot be specified together with `defaultAction`.\n   *\n   * @default - None.\n   */\n  readonly defaultTargetGroups?: INetworkTargetGroup[];\n\n  /**\n   * Default action to take for requests to this listener\n   *\n   * This allows full control of the default Action of the load balancer,\n   * including weighted forwarding. See the `NetworkListenerAction` class for\n   * all options.\n   *\n   * Cannot be specified together with `defaultTargetGroups`.\n   *\n   * @default - None.\n   */\n  readonly defaultAction?: NetworkListenerAction;\n\n  /**\n   * Protocol for listener, expects TCP, TLS, UDP, or TCP_UDP.\n   *\n   * @default - TLS if certificates are provided. TCP otherwise.\n   */\n  readonly protocol?: Protocol;\n\n  /**\n   * Certificate list of ACM cert ARNs. You must provide exactly one certificate if the listener protocol is HTTPS or TLS.\n   *\n   * @default - No certificates.\n   */\n  readonly certificates?: IListenerCertificate[];\n\n  /**\n   * SSL Policy\n   *\n   * @default - Current predefined security policy.\n   */\n  readonly sslPolicy?: SslPolicy;\n\n\n  /**\n   * Application-Layer Protocol Negotiation (ALPN) is a TLS extension that is sent on the initial TLS handshake hello messages.\n   * ALPN enables the application layer to negotiate which protocols should be used over a secure connection, such as HTTP/1 and HTTP/2.\n   *\n   * Can only be specified together with Protocol TLS.\n   *\n   * @default - None\n   */\n  readonly alpnPolicy?: AlpnPolicy;\n}\n\n/**\n * Properties for adding a certificate to a listener\n *\n * This interface exists for backwards compatibility.\n *\n * @deprecated Use IListenerCertificate instead\n */\nexport interface INetworkListenerCertificateProps extends IListenerCertificate {\n}\n\n/**\n * Properties for a Network Listener attached to a Load Balancer\n */\nexport interface NetworkListenerProps extends BaseNetworkListenerProps {\n  /**\n   * The load balancer to attach this listener to\n   */\n  readonly loadBalancer: INetworkLoadBalancer;\n}\n\n/**\n * Options for looking up a network listener.\n */\nexport interface NetworkListenerLookupOptions extends BaseListenerLookupOptions {\n  /**\n   * Protocol of the listener port\n   * @default - listener is not filtered by protocol\n   */\n  readonly listenerProtocol?: Protocol;\n}\n\n/**\n * Define a Network Listener\n *\n * @resource AWS::ElasticLoadBalancingV2::Listener\n */\nexport class NetworkListener extends BaseListener implements INetworkListener {\n  /**\n   * Looks up a network listener\n   */\n  public static fromLookup(scope: Construct, id: string, options: NetworkListenerLookupOptions): INetworkListener {\n    let listenerProtocol: cxschema.LoadBalancerListenerProtocol | undefined;\n    if (options.listenerProtocol) {\n      validateNetworkProtocol(options.listenerProtocol);\n\n      switch (options.listenerProtocol) {\n        case Protocol.TCP: listenerProtocol = cxschema.LoadBalancerListenerProtocol.TCP; break;\n        case Protocol.UDP: listenerProtocol = cxschema.LoadBalancerListenerProtocol.UDP; break;\n        case Protocol.TCP_UDP: listenerProtocol = cxschema.LoadBalancerListenerProtocol.TCP_UDP; break;\n        case Protocol.TLS: listenerProtocol = cxschema.LoadBalancerListenerProtocol.TLS; break;\n      }\n    }\n\n    const props = BaseListener._queryContextProvider(scope, {\n      userOptions: options,\n      listenerProtocol: listenerProtocol,\n      loadBalancerType: cxschema.LoadBalancerType.NETWORK,\n    });\n\n    class LookedUp extends Resource implements INetworkListener {\n      public listenerArn = props.listenerArn;\n    }\n\n    return new LookedUp(scope, id);\n  }\n\n  /**\n   * Import an existing listener\n   */\n  public static fromNetworkListenerArn(scope: Construct, id: string, networkListenerArn: string): INetworkListener {\n    class Import extends Resource implements INetworkListener {\n      public listenerArn = networkListenerArn;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The load balancer this listener is attached to\n   */\n  public readonly loadBalancer: INetworkLoadBalancer;\n\n  /**\n   * the protocol of the listener\n   */\n  private readonly protocol: Protocol;\n\n  constructor(scope: Construct, id: string, props: NetworkListenerProps) {\n    const certs = props.certificates || [];\n    const proto = props.protocol || (certs.length > 0 ? Protocol.TLS : Protocol.TCP);\n\n    validateNetworkProtocol(proto);\n\n    if (proto === Protocol.TLS && certs.filter(v => v != null).length === 0) {\n      throw new Error('When the protocol is set to TLS, you must specify certificates');\n    }\n\n    if (proto !== Protocol.TLS && certs.length > 0) {\n      throw new Error('Protocol must be TLS when certificates have been specified');\n    }\n\n    if (proto !== Protocol.TLS && props.alpnPolicy) {\n      throw new Error('Protocol must be TLS when alpnPolicy have been specified');\n    }\n\n    super(scope, id, {\n      loadBalancerArn: props.loadBalancer.loadBalancerArn,\n      protocol: proto,\n      port: props.port,\n      sslPolicy: props.sslPolicy,\n      certificates: props.certificates,\n      alpnPolicy: props.alpnPolicy ? [props.alpnPolicy] : undefined,\n    });\n\n    this.loadBalancer = props.loadBalancer;\n    this.protocol = proto;\n\n    if (props.defaultAction && props.defaultTargetGroups) {\n      throw new Error('Specify at most one of \\'defaultAction\\' and \\'defaultTargetGroups\\'');\n    }\n\n    if (props.defaultAction) {\n      this.setDefaultAction(props.defaultAction);\n    }\n\n    if (props.defaultTargetGroups) {\n      this.setDefaultAction(NetworkListenerAction.forward(props.defaultTargetGroups));\n    }\n  }\n\n  /**\n   * Load balance incoming requests to the given target groups.\n   *\n   * All target groups will be load balanced to with equal weight and without\n   * stickiness. For a more complex configuration than that, use `addAction()`.\n   */\n  public addTargetGroups(_id: string, ...targetGroups: INetworkTargetGroup[]): void {\n    this.setDefaultAction(NetworkListenerAction.forward(targetGroups));\n  }\n\n  /**\n   * Perform the given Action on incoming requests\n   *\n   * This allows full control of the default Action of the load balancer,\n   * including weighted forwarding. See the `NetworkListenerAction` class for\n   * all options.\n   */\n  public addAction(_id: string, props: AddNetworkActionProps): void {\n    this.setDefaultAction(props.action);\n  }\n\n  /**\n   * Load balance incoming requests to the given load balancing targets.\n   *\n   * This method implicitly creates a NetworkTargetGroup for the targets\n   * involved, and a 'forward' action to route traffic to the given TargetGroup.\n   *\n   * If you want more control over the precise setup, create the TargetGroup\n   * and use `addAction` yourself.\n   *\n   * It's possible to add conditions to the targets added in this way. At least\n   * one set of targets must be added without conditions.\n   *\n   * @returns The newly created target group\n   */\n  public addTargets(id: string, props: AddNetworkTargetsProps): NetworkTargetGroup {\n    if (!this.loadBalancer.vpc) {\n      // eslint-disable-next-line max-len\n      throw new Error('Can only call addTargets() when using a constructed Load Balancer or imported Load Balancer with specified VPC; construct a new TargetGroup and use addTargetGroup');\n    }\n\n    const group = new NetworkTargetGroup(this, id + 'Group', {\n      deregistrationDelay: props.deregistrationDelay,\n      healthCheck: props.healthCheck,\n      port: props.port,\n      protocol: props.protocol ?? this.protocol,\n      proxyProtocolV2: props.proxyProtocolV2,\n      preserveClientIp: props.preserveClientIp,\n      targetGroupName: props.targetGroupName,\n      targets: props.targets,\n      vpc: this.loadBalancer.vpc,\n    });\n\n    this.addTargetGroups(id, group);\n\n    return group;\n  }\n\n  /**\n   * Wrapper for _setDefaultAction which does a type-safe bind\n   */\n  private setDefaultAction(action: NetworkListenerAction) {\n    action.bind(this, this);\n    this._setDefaultAction(action);\n  }\n}\n\n/**\n * Properties to reference an existing listener\n */\nexport interface INetworkListener extends IResource {\n  /**\n   * ARN of the listener\n   * @attribute\n   */\n  readonly listenerArn: string;\n}\n\n/**\n * Properties for adding a new action to a listener\n */\nexport interface AddNetworkActionProps {\n  /**\n   * Action to perform\n   */\n  readonly action: NetworkListenerAction;\n}\n\n/**\n * Properties for adding new network targets to a listener\n */\nexport interface AddNetworkTargetsProps {\n  /**\n   * The port on which the listener listens for requests.\n   *\n   * @default Determined from protocol if known\n   */\n  readonly port: number;\n\n  /**\n   * Protocol for target group, expects TCP, TLS, UDP, or TCP_UDP.\n   *\n   * @default - inherits the protocol of the listener\n   */\n  readonly protocol?: Protocol;\n\n  /**\n   * The targets to add to this target group.\n   *\n   * Can be `Instance`, `IPAddress`, or any self-registering load balancing\n   * target. If you use either `Instance` or `IPAddress` as targets, all\n   * target must be of the same type.\n   */\n  readonly targets?: INetworkLoadBalancerTarget[];\n\n  /**\n   * The name of the target group.\n   *\n   * This name must be unique per region per account, can have a maximum of\n   * 32 characters, must contain only alphanumeric characters or hyphens, and\n   * must not begin or end with a hyphen.\n   *\n   * @default Automatically generated\n   */\n  readonly targetGroupName?: string;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n   *\n   * The range is 0-3600 seconds.\n   *\n   * @default Duration.minutes(5)\n   */\n  readonly deregistrationDelay?: Duration;\n\n  /**\n   * Indicates whether Proxy Protocol version 2 is enabled.\n   *\n   * @default false\n   */\n  readonly proxyProtocolV2?: boolean;\n\n  /**\n   * Indicates whether client IP preservation is enabled.\n   *\n   * @default false if the target group type is IP address and the\n   * target group protocol is TCP or TLS. Otherwise, true.\n   */\n  readonly preserveClientIp?: boolean;\n\n  /**\n   * Health check configuration\n   *\n   * @default No health check\n   */\n  readonly healthCheck?: HealthCheck;\n}\n"]}

@@ -7,5 +7,3 @@ import * as cloudwatch from '@aws-cdk/aws-cloudwatch';

/**
* Properties for a network load balancer.
*
* @stability stable
* Properties for a network load balancer
*/

@@ -17,3 +15,2 @@ export interface NetworkLoadBalancerProps extends BaseLoadBalancerProps {

* @default false
* @stability stable
*/

@@ -23,25 +20,19 @@ readonly crossZoneEnabled?: boolean;

/**
* Properties to reference an existing load balancer.
*
* @stability stable
* Properties to reference an existing load balancer
*/
export interface NetworkLoadBalancerAttributes {
/**
* ARN of the load balancer.
*
* @stability stable
* ARN of the load balancer
*/
readonly loadBalancerArn: string;
/**
* The canonical hosted zone ID of this load balancer.
* The canonical hosted zone ID of this load balancer
*
* @default - When not provided, LB cannot be used as Route53 Alias target.
* @stability stable
*/
readonly loadBalancerCanonicalHostedZoneId?: string;
/**
* The DNS name of this load balancer.
* The DNS name of this load balancer
*
* @default - When not provided, LB cannot be used as Route53 Alias target.
* @stability stable
*/

@@ -54,3 +45,2 @@ readonly loadBalancerDnsName?: string;

* balancers.
* @stability stable
*/

@@ -60,5 +50,3 @@ readonly vpc?: ec2.IVpc;

/**
* Options for looking up an NetworkLoadBalancer.
*
* @stability stable
* Options for looking up an NetworkLoadBalancer
*/

@@ -68,5 +56,4 @@ export interface NetworkLoadBalancerLookupOptions extends BaseLoadBalancerLookupOptions {

/**
* Define a new network load balancer.
* Define a new network load balancer
*
* @stability stable
* @resource AWS::ElasticLoadBalancingV2::LoadBalancer

@@ -77,26 +64,16 @@ */

* Looks up the network load balancer.
*
* @stability stable
*/
static fromLookup(scope: Construct, id: string, options: NetworkLoadBalancerLookupOptions): INetworkLoadBalancer;
/**
* @stability stable
*/
static fromNetworkLoadBalancerAttributes(scope: Construct, id: string, attrs: NetworkLoadBalancerAttributes): INetworkLoadBalancer;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: NetworkLoadBalancerProps);
/**
* Add a listener to this load balancer.
* Add a listener to this load balancer
*
* @returns The newly created listener
* @stability stable
*/
addListener(id: string, props: BaseNetworkListenerProps): NetworkListener;
/**
* Return the given named metric for this Network Load Balancer.
* Return the given named metric for this Network Load Balancer
*
* @default Average over 5 minutes
* @stability stable
*/

@@ -112,3 +89,2 @@ metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Average over 5 minutes
* @stability stable
*/

@@ -120,7 +96,6 @@ metricActiveFlowCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/
metricConsumedLCUs(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* (deprecated) The number of targets that are considered healthy.
* The number of targets that are considered healthy.
*

@@ -132,3 +107,3 @@ * @default Average over 5 minutes

/**
* (deprecated) The number of targets that are considered unhealthy.
* The number of targets that are considered unhealthy.
*

@@ -143,3 +118,2 @@ * @default Average over 5 minutes

* @default Sum over 5 minutes
* @stability stable
*/

@@ -151,3 +125,2 @@ metricNewFlowCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -161,3 +134,2 @@ metricProcessedBytes(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -169,3 +141,2 @@ metricTcpClientResetCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -179,3 +150,2 @@ metricTcpElbResetCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Sum over 5 minutes
* @stability stable
*/

@@ -186,20 +156,15 @@ metricTcpTargetResetCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

/**
* A network load balancer.
*
* @stability stable
* A network load balancer
*/
export interface INetworkLoadBalancer extends ILoadBalancerV2, ec2.IVpcEndpointServiceLoadBalancer {
/**
* The VPC this load balancer has been created in (if available).
*
* @stability stable
* The VPC this load balancer has been created in (if available)
*/
readonly vpc?: ec2.IVpc;
/**
* Add a listener to this load balancer.
* Add a listener to this load balancer
*
* @returns The newly created listener
* @stability stable
*/
addListener(id: string, props: BaseNetworkListenerProps): NetworkListener;
}

@@ -15,11 +15,7 @@ "use strict";

/**
* Define a new network load balancer.
* Define a new network load balancer
*
* @stability stable
* @resource AWS::ElasticLoadBalancingV2::LoadBalancer
*/
class NetworkLoadBalancer extends base_load_balancer_1.BaseLoadBalancer {
/**
* @stability stable
*/
constructor(scope, id, props) {

@@ -36,4 +32,2 @@ super(scope, id, props, {

* Looks up the network load balancer.
*
* @stability stable
*/

@@ -48,5 +42,2 @@ static fromLookup(scope, id, options) {

}
/**
* @stability stable
*/
static fromNetworkLoadBalancerAttributes(scope, id, attrs) {

@@ -84,6 +75,5 @@ jsiiDeprecationWarnings._aws_cdk_aws_elasticloadbalancingv2_NetworkLoadBalancerAttributes(attrs);

/**
* Add a listener to this load balancer.
* Add a listener to this load balancer
*
* @returns The newly created listener
* @stability stable
*/

@@ -98,6 +88,5 @@ addListener(id, props) {

/**
* Return the given named metric for this Network Load Balancer.
* Return the given named metric for this Network Load Balancer
*
* @default Average over 5 minutes
* @stability stable
*/

@@ -120,3 +109,2 @@ metric(metricName, props) {

* @default Average over 5 minutes
* @stability stable
*/

@@ -130,3 +118,2 @@ metricActiveFlowCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -140,3 +127,3 @@ metricConsumedLCUs(props) {

/**
* (deprecated) The number of targets that are considered healthy.
* The number of targets that are considered healthy.
*

@@ -154,3 +141,3 @@ * @default Average over 5 minutes

/**
* (deprecated) The number of targets that are considered unhealthy.
* The number of targets that are considered unhealthy.
*

@@ -171,3 +158,2 @@ * @default Average over 5 minutes

* @default Sum over 5 minutes
* @stability stable
*/

@@ -181,3 +167,2 @@ metricNewFlowCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -193,3 +178,2 @@ metricProcessedBytes(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -203,3 +187,2 @@ metricTcpClientResetCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -215,3 +198,2 @@ metricTcpElbResetCount(props) {

* @default Sum over 5 minutes
* @stability stable
*/

@@ -230,3 +212,3 @@ metricTcpTargetResetCount(props) {

_a = JSII_RTTI_SYMBOL_1;
NetworkLoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.NetworkLoadBalancer", version: "1.144.0" };
NetworkLoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.NetworkLoadBalancer", version: "1.145.0" };
class LookedUpNetworkLoadBalancer extends core_1.Resource {

@@ -249,2 +231,2 @@ constructor(scope, id, props) {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-load-balancer.js","sourceRoot":"","sources":["network-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as ec2 from '@aws-cdk/aws-ec2';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Resource } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Construct } from 'constructs';\nimport { NetworkELBMetrics } from '../elasticloadbalancingv2-canned-metrics.generated';\nimport { BaseLoadBalancer, BaseLoadBalancerLookupOptions, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { BaseNetworkListenerProps, NetworkListener } from './network-listener';\n\n                                                 \nexport interface NetworkLoadBalancerProps extends BaseLoadBalancerProps {\n                                                                                                 \n  readonly crossZoneEnabled?: boolean;\n}\n\n                                                            \nexport interface NetworkLoadBalancerAttributes {\n                                         \n  readonly loadBalancerArn: string;\n\n                                                                                                                                                      \n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n                                                                                                                                      \n  readonly loadBalancerDnsName?: string;\n\n                                                                                                                                                                  \n  readonly vpc?: ec2.IVpc;\n}\n\n                                                        \nexport interface NetworkLoadBalancerLookupOptions extends BaseLoadBalancerLookupOptions {\n}\n\n                                                                                                       \nexport class NetworkLoadBalancer extends BaseLoadBalancer implements INetworkLoadBalancer {\n                                                    \n  public static fromLookup(scope: Construct, id: string, options: NetworkLoadBalancerLookupOptions): INetworkLoadBalancer {\n    const props = BaseLoadBalancer._queryContextProvider(scope, {\n      userOptions: options,\n      loadBalancerType: cxschema.LoadBalancerType.NETWORK,\n    });\n\n    return new LookedUpNetworkLoadBalancer(scope, id, props);\n  }\n\n  public static fromNetworkLoadBalancerAttributes(scope: Construct, id: string, attrs: NetworkLoadBalancerAttributes): INetworkLoadBalancer {\n    class Import extends Resource implements INetworkLoadBalancer {\n      public readonly loadBalancerArn = attrs.loadBalancerArn;\n      public readonly vpc?: ec2.IVpc = attrs.vpc;\n      public addListener(lid: string, props: BaseNetworkListenerProps): NetworkListener {\n        return new NetworkListener(this, lid, {\n          loadBalancer: this,\n          ...props,\n        });\n      }\n\n      public get loadBalancerCanonicalHostedZoneId(): string {\n        if (attrs.loadBalancerCanonicalHostedZoneId) { return attrs.loadBalancerCanonicalHostedZoneId; }\n        // eslint-disable-next-line max-len\n        throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n\n      public get loadBalancerDnsName(): string {\n        if (attrs.loadBalancerDnsName) { return attrs.loadBalancerDnsName; }\n        // eslint-disable-next-line max-len\n        throw new Error(`'loadBalancerDnsName' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n    }\n\n    return new Import(scope, id, { environmentFromArn: attrs.loadBalancerArn });\n  }\n\n  constructor(scope: Construct, id: string, props: NetworkLoadBalancerProps) {\n    super(scope, id, props, {\n      type: 'network',\n    });\n\n    if (props.crossZoneEnabled) { this.setAttribute('load_balancing.cross_zone.enabled', 'true'); }\n  }\n\n                                                                                                   \n  public addListener(id: string, props: BaseNetworkListenerProps): NetworkListener {\n    return new NetworkListener(this, id, {\n      loadBalancer: this,\n      ...props,\n    });\n  }\n\n                                                                                                                       \n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/NetworkELB',\n      metricName,\n      dimensions: { LoadBalancer: this.loadBalancerFullName },\n      ...props,\n    }).attachTo(this);\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                             \n  public metricActiveFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.activeFlowCountAverage, props);\n  }\n\n                                                                                                                                   \n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.consumedLcUsAverage, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                        \n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                                            \n  public metricUnHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                                                                                 \n  public metricNewFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.newFlowCountSum, props);\n  }\n\n                                                                                                                                          \n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.processedBytesSum, props);\n  }\n\n                                                                                                                                                                                                                     \n  public metricTcpClientResetCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.tcpClientResetCountSum, props);\n  }\n\n                                                                                                                              \n  public metricTcpElbResetCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.tcpElbResetCountSum, props);\n  }\n\n                                                                                                                                                                                                                     \n  public metricTcpTargetResetCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.tcpTargetResetCountSum, props);\n  }\n\n  private cannedMetric(\n    fn: (dims: { LoadBalancer: string }) => cloudwatch.MetricProps,\n    props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      ...fn({ LoadBalancer: this.loadBalancerFullName }),\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n                                  \nexport interface INetworkLoadBalancer extends ILoadBalancerV2, ec2.IVpcEndpointServiceLoadBalancer {\n\n                                                                              \n  readonly vpc?: ec2.IVpc;\n\n                                                                                                   \n  addListener(id: string, props: BaseNetworkListenerProps): NetworkListener;\n}\n\nclass LookedUpNetworkLoadBalancer extends Resource implements INetworkLoadBalancer {\n  public readonly loadBalancerCanonicalHostedZoneId: string;\n  public readonly loadBalancerDnsName: string;\n  public readonly loadBalancerArn: string;\n  public readonly vpc?: ec2.IVpc;\n\n  constructor(scope: Construct, id: string, props: cxapi.LoadBalancerContextResponse) {\n    super(scope, id, { environmentFromArn: props.loadBalancerArn });\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.loadBalancerCanonicalHostedZoneId = props.loadBalancerCanonicalHostedZoneId;\n    this.loadBalancerDnsName = props.loadBalancerDnsName;\n\n    this.vpc = ec2.Vpc.fromLookup(this, 'Vpc', {\n      vpcId: props.vpcId,\n    });\n  }\n\n  public addListener(lid: string, props: BaseNetworkListenerProps): NetworkListener {\n    return new NetworkListener(this, lid, {\n      loadBalancer: this,\n      ...props,\n    });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-load-balancer.js","sourceRoot":"","sources":["network-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as ec2 from '@aws-cdk/aws-ec2';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Resource } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Construct } from 'constructs';\nimport { NetworkELBMetrics } from '../elasticloadbalancingv2-canned-metrics.generated';\nimport { BaseLoadBalancer, BaseLoadBalancerLookupOptions, BaseLoadBalancerProps, ILoadBalancerV2 } from '../shared/base-load-balancer';\nimport { BaseNetworkListenerProps, NetworkListener } from './network-listener';\n\n/**\n * Properties for a network load balancer\n */\nexport interface NetworkLoadBalancerProps extends BaseLoadBalancerProps {\n  /**\n   * Indicates whether cross-zone load balancing is enabled.\n   *\n   * @default false\n   */\n  readonly crossZoneEnabled?: boolean;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface NetworkLoadBalancerAttributes {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerCanonicalHostedZoneId?: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @default - When not provided, LB cannot be used as Route53 Alias target.\n   */\n  readonly loadBalancerDnsName?: string;\n\n  /**\n   * The VPC to associate with the load balancer.\n   *\n   * @default - When not provided, listeners cannot be created on imported load\n   * balancers.\n   */\n  readonly vpc?: ec2.IVpc;\n}\n\n/**\n * Options for looking up an NetworkLoadBalancer\n */\nexport interface NetworkLoadBalancerLookupOptions extends BaseLoadBalancerLookupOptions {\n}\n\n/**\n * Define a new network load balancer\n *\n * @resource AWS::ElasticLoadBalancingV2::LoadBalancer\n */\nexport class NetworkLoadBalancer extends BaseLoadBalancer implements INetworkLoadBalancer {\n  /**\n   * Looks up the network load balancer.\n   */\n  public static fromLookup(scope: Construct, id: string, options: NetworkLoadBalancerLookupOptions): INetworkLoadBalancer {\n    const props = BaseLoadBalancer._queryContextProvider(scope, {\n      userOptions: options,\n      loadBalancerType: cxschema.LoadBalancerType.NETWORK,\n    });\n\n    return new LookedUpNetworkLoadBalancer(scope, id, props);\n  }\n\n  public static fromNetworkLoadBalancerAttributes(scope: Construct, id: string, attrs: NetworkLoadBalancerAttributes): INetworkLoadBalancer {\n    class Import extends Resource implements INetworkLoadBalancer {\n      public readonly loadBalancerArn = attrs.loadBalancerArn;\n      public readonly vpc?: ec2.IVpc = attrs.vpc;\n      public addListener(lid: string, props: BaseNetworkListenerProps): NetworkListener {\n        return new NetworkListener(this, lid, {\n          loadBalancer: this,\n          ...props,\n        });\n      }\n\n      public get loadBalancerCanonicalHostedZoneId(): string {\n        if (attrs.loadBalancerCanonicalHostedZoneId) { return attrs.loadBalancerCanonicalHostedZoneId; }\n        // eslint-disable-next-line max-len\n        throw new Error(`'loadBalancerCanonicalHostedZoneId' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n\n      public get loadBalancerDnsName(): string {\n        if (attrs.loadBalancerDnsName) { return attrs.loadBalancerDnsName; }\n        // eslint-disable-next-line max-len\n        throw new Error(`'loadBalancerDnsName' was not provided when constructing Network Load Balancer ${this.node.path} from attributes`);\n      }\n    }\n\n    return new Import(scope, id, { environmentFromArn: attrs.loadBalancerArn });\n  }\n\n  constructor(scope: Construct, id: string, props: NetworkLoadBalancerProps) {\n    super(scope, id, props, {\n      type: 'network',\n    });\n\n    if (props.crossZoneEnabled) { this.setAttribute('load_balancing.cross_zone.enabled', 'true'); }\n  }\n\n  /**\n   * Add a listener to this load balancer\n   *\n   * @returns The newly created listener\n   */\n  public addListener(id: string, props: BaseNetworkListenerProps): NetworkListener {\n    return new NetworkListener(this, id, {\n      loadBalancer: this,\n      ...props,\n    });\n  }\n\n  /**\n   * Return the given named metric for this Network Load Balancer\n   *\n   * @default Average over 5 minutes\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/NetworkELB',\n      metricName,\n      dimensions: { LoadBalancer: this.loadBalancerFullName },\n      ...props,\n    }).attachTo(this);\n  }\n\n  /**\n   * The total number of concurrent TCP flows (or connections) from clients to targets.\n   *\n   * This metric includes connections in the SYN_SENT and ESTABLISHED states.\n   * TCP connections are not terminated at the load balancer, so a client\n   * opening a TCP connection to a target counts as a single flow.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricActiveFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.activeFlowCountAverage, props);\n  }\n\n  /**\n   * The number of load balancer capacity units (LCU) used by your load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricConsumedLCUs(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.consumedLcUsAverage, {\n      statistic: 'Sum',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of targets that are considered healthy.\n   *\n   * @default Average over 5 minutes\n   * @deprecated use ``NetworkTargetGroup.metricHealthyHostCount`` instead\n   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of targets that are considered unhealthy.\n   *\n   * @default Average over 5 minutes\n   * @deprecated use ``NetworkTargetGroup.metricUnHealthyHostCount`` instead\n   */\n  public metricUnHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The total number of new TCP flows (or connections) established from clients to targets in the time period.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricNewFlowCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.newFlowCountSum, props);\n  }\n\n  /**\n   * The total number of bytes processed by the load balancer, including TCP/IP headers.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricProcessedBytes(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.processedBytesSum, props);\n  }\n\n  /**\n   * The total number of reset (RST) packets sent from a client to a target.\n   *\n   * These resets are generated by the client and forwarded by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpClientResetCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.tcpClientResetCountSum, props);\n  }\n\n  /**\n   * The total number of reset (RST) packets generated by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpElbResetCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.tcpElbResetCountSum, props);\n  }\n\n  /**\n   * The total number of reset (RST) packets sent from a target to a client.\n   *\n   * These resets are generated by the target and forwarded by the load balancer.\n   *\n   * @default Sum over 5 minutes\n   */\n  public metricTcpTargetResetCount(props?: cloudwatch.MetricOptions) {\n    return this.cannedMetric(NetworkELBMetrics.tcpTargetResetCountSum, props);\n  }\n\n  private cannedMetric(\n    fn: (dims: { LoadBalancer: string }) => cloudwatch.MetricProps,\n    props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      ...fn({ LoadBalancer: this.loadBalancerFullName }),\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n/**\n * A network load balancer\n */\nexport interface INetworkLoadBalancer extends ILoadBalancerV2, ec2.IVpcEndpointServiceLoadBalancer {\n\n  /**\n   * The VPC this load balancer has been created in (if available)\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Add a listener to this load balancer\n   *\n   * @returns The newly created listener\n   */\n  addListener(id: string, props: BaseNetworkListenerProps): NetworkListener;\n}\n\nclass LookedUpNetworkLoadBalancer extends Resource implements INetworkLoadBalancer {\n  public readonly loadBalancerCanonicalHostedZoneId: string;\n  public readonly loadBalancerDnsName: string;\n  public readonly loadBalancerArn: string;\n  public readonly vpc?: ec2.IVpc;\n\n  constructor(scope: Construct, id: string, props: cxapi.LoadBalancerContextResponse) {\n    super(scope, id, { environmentFromArn: props.loadBalancerArn });\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.loadBalancerCanonicalHostedZoneId = props.loadBalancerCanonicalHostedZoneId;\n    this.loadBalancerDnsName = props.loadBalancerDnsName;\n\n    this.vpc = ec2.Vpc.fromLookup(this, 'Vpc', {\n      vpcId: props.vpcId,\n    });\n  }\n\n  public addListener(lid: string, props: BaseNetworkListenerProps): NetworkListener {\n    return new NetworkListener(this, lid, {\n      loadBalancer: this,\n      ...props,\n    });\n  }\n}\n"]}

@@ -7,5 +7,3 @@ import * as cloudwatch from '@aws-cdk/aws-cloudwatch';

/**
* Properties for a new Network Target Group.
*
* @stability stable
* Properties for a new Network Target Group
*/

@@ -15,4 +13,2 @@ export interface NetworkTargetGroupProps extends BaseTargetGroupProps {

* The port on which the listener listens for requests.
*
* @stability stable
*/

@@ -24,3 +20,2 @@ readonly port: number;

* @default - TCP
* @stability stable
*/

@@ -32,3 +27,2 @@ readonly protocol?: Protocol;

* @default false
* @stability stable
*/

@@ -41,3 +35,2 @@ readonly proxyProtocolV2?: boolean;

* target group protocol is TCP or TLS. Otherwise, true.
* @stability stable
*/

@@ -53,3 +46,2 @@ readonly preserveClientIp?: boolean;

* @default - No targets.
* @stability stable
*/

@@ -59,15 +51,11 @@ readonly targets?: INetworkLoadBalancerTarget[];

/**
* Define a Network Target Group.
*
* @stability stable
* Define a Network Target Group
*/
export declare class NetworkTargetGroup extends TargetGroupBase implements INetworkTargetGroup {
/**
* Import an existing target group.
*
* @stability stable
* Import an existing target group
*/
static fromTargetGroupAttributes(scope: Construct, id: string, attrs: TargetGroupAttributes): INetworkTargetGroup;
/**
* (deprecated) Import an existing listener.
* Import an existing listener
*

@@ -78,10 +66,5 @@ * @deprecated Use `fromTargetGroupAttributes` instead

private readonly listeners;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, props: NetworkTargetGroupProps);
/**
* Add a load balancing target to this target group.
*
* @stability stable
* Add a load balancing target to this target group
*/

@@ -93,4 +76,2 @@ addTarget(...targets: INetworkLoadBalancerTarget[]): void;

* Don't call this directly. It will be called by listeners.
*
* @stability stable
*/

@@ -102,3 +83,2 @@ registerListener(listener: INetworkListener): void;

* @default Average over 5 minutes
* @stability stable
*/

@@ -110,19 +90,8 @@ metricHealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;

* @default Average over 5 minutes
* @stability stable
*/
metricUnHealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**
* Full name of first load balancer.
*
* @stability stable
* Full name of first load balancer
*/
get firstLoadBalancerFullName(): string;
/**
* Validate the current construct.
*
* This method can be implemented by derived constructs in order to perform
* validation logic. It is called on all constructs before synthesis.
*
* @stability stable
*/
protected validate(): string[];

@@ -132,5 +101,3 @@ private metric;

/**
* A network target group.
*
* @stability stable
* A network target group
*/

@@ -142,10 +109,6 @@ export interface INetworkTargetGroup extends ITargetGroup {

* Don't call this directly. It will be called by listeners.
*
* @stability stable
*/
registerListener(listener: INetworkListener): void;
/**
* Add a load balancing target to this target group.
*
* @stability stable
* Add a load balancing target to this target group
*/

@@ -155,16 +118,12 @@ addTarget(...targets: INetworkLoadBalancerTarget[]): void;

/**
* Interface for constructs that can be targets of an network load balancer.
*
* @stability stable
* Interface for constructs that can be targets of an network load balancer
*/
export interface INetworkLoadBalancerTarget {
/**
* Attach load-balanced target to a TargetGroup.
* Attach load-balanced target to a TargetGroup
*
* May return JSON to directly add to the [Targets] list, or return undefined
* if the target will register itself with the load balancer.
*
* @stability stable
*/
attachToNetworkTargetGroup(targetGroup: INetworkTargetGroup): LoadBalancerTargetProps;
}

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

/**
* Define a Network Target Group.
*
* @stability stable
* Define a Network Target Group
*/
class NetworkTargetGroup extends base_target_group_1.TargetGroupBase {
/**
* @stability stable
*/
constructor(scope, id, props) {

@@ -41,5 +36,3 @@ jsiiDeprecationWarnings._aws_cdk_aws_elasticloadbalancingv2_NetworkTargetGroupProps(props);

/**
* Import an existing target group.
*
* @stability stable
* Import an existing target group
*/

@@ -51,3 +44,3 @@ static fromTargetGroupAttributes(scope, id, attrs) {

/**
* (deprecated) Import an existing listener.
* Import an existing listener
*

@@ -62,5 +55,3 @@ * @deprecated Use `fromTargetGroupAttributes` instead

/**
* Add a load balancing target to this target group.
*
* @stability stable
* Add a load balancing target to this target group
*/

@@ -78,4 +69,2 @@ addTarget(...targets) {

* Don't call this directly. It will be called by listeners.
*
* @stability stable
*/

@@ -91,3 +80,2 @@ registerListener(listener) {

* @default Average over 5 minutes
* @stability stable
*/

@@ -104,3 +92,2 @@ metricHealthyHostCount(props) {

* @default Average over 5 minutes
* @stability stable
*/

@@ -114,5 +101,3 @@ metricUnHealthyHostCount(props) {

/**
* Full name of first load balancer.
*
* @stability stable
* Full name of first load balancer
*/

@@ -125,10 +110,2 @@ get firstLoadBalancerFullName() {

}
/**
* Validate the current construct.
*
* This method can be implemented by derived constructs in order to perform
* validation logic. It is called on all constructs before synthesis.
*
* @stability stable
*/
validate() {

@@ -194,3 +171,3 @@ const ret = super.validate();

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

@@ -218,2 +195,2 @@ * An imported network target group

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-target-group.js","sourceRoot":"","sources":["network-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport {\n  BaseTargetGroupProps, HealthCheck, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n  TargetGroupAttributes, TargetGroupBase, TargetGroupImportProps,\n} from '../shared/base-target-group';\nimport { Protocol } from '../shared/enums';\nimport { ImportedTargetGroupBase } from '../shared/imported';\nimport { validateNetworkProtocol } from '../shared/util';\nimport { INetworkListener } from './network-listener';\n\n                                                    \nexport interface NetworkTargetGroupProps extends BaseTargetGroupProps {\n                                                                     \n  readonly port: number;\n\n                                                                                                       \n  readonly protocol?: Protocol;\n\n                                                                                                \n  readonly proxyProtocolV2?: boolean;\n\n                                                                                                                                                                                                        \n  readonly preserveClientIp?: boolean;\n\n                                                                                                                                                                                                                                                                                          \n  readonly targets?: INetworkLoadBalancerTarget[];\n}\n\n                                        \nexport class NetworkTargetGroup extends TargetGroupBase implements INetworkTargetGroup {\n                                                \n  public static fromTargetGroupAttributes(scope: Construct, id: string, attrs: TargetGroupAttributes): INetworkTargetGroup {\n    return new ImportedNetworkTargetGroup(scope, id, attrs);\n  }\n\n                                                                                                          \n  public static import(scope: Construct, id: string, props: TargetGroupImportProps): INetworkTargetGroup {\n    return NetworkTargetGroup.fromTargetGroupAttributes(scope, id, props);\n  }\n\n  private readonly listeners: INetworkListener[];\n\n  constructor(scope: Construct, id: string, props: NetworkTargetGroupProps) {\n    const proto = props.protocol || Protocol.TCP;\n    validateNetworkProtocol(proto);\n\n    super(scope, id, props, {\n      protocol: proto,\n      port: props.port,\n    });\n\n    this.listeners = [];\n\n    if (props.proxyProtocolV2 != null) {\n      this.setAttribute('proxy_protocol_v2.enabled', props.proxyProtocolV2 ? 'true' : 'false');\n    }\n\n    if (props.preserveClientIp !== undefined) {\n      this.setAttribute('preserve_client_ip.enabled', props.preserveClientIp ? 'true' : 'false');\n    }\n\n    this.addTarget(...(props.targets || []));\n  }\n\n                                                                 \n  public addTarget(...targets: INetworkLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToNetworkTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n  }\n\n                                                                                                                                                     \n  public registerListener(listener: INetworkListener) {\n    this.loadBalancerAttachedDependencies.add(listener);\n    this.listeners.push(listener);\n  }\n\n                                                                                                             \n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                                                                               \n  public metricUnHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n                                                 \n  public get firstLoadBalancerFullName(): string {\n    if (this.listeners.length === 0) {\n      throw new Error('The TargetGroup needs to be attached to a LoadBalancer before you can call this method');\n    }\n    return loadBalancerNameFromListenerArn(this.listeners[0].listenerArn);\n  }\n\n  protected validate(): string[] {\n    const ret = super.validate();\n\n    const healthCheck: HealthCheck = this.healthCheck || {};\n\n    const allowedIntervals = [10, 30];\n    if (healthCheck.interval) {\n      const seconds = healthCheck.interval.toSeconds();\n      if (!cdk.Token.isUnresolved(seconds) && !allowedIntervals.includes(seconds)) {\n        ret.push(`Health check interval '${seconds}' not supported. Must be one of the following values '${allowedIntervals.join(',')}'.`);\n      }\n    }\n\n    if (healthCheck.healthyThresholdCount) {\n      const thresholdCount = healthCheck.healthyThresholdCount;\n      if (thresholdCount < 2 || thresholdCount > 10) {\n        ret.push(`Healthy Threshold Count '${thresholdCount}' not supported. Must be a number between 2 and 10.`);\n      }\n    }\n\n    if (healthCheck.unhealthyThresholdCount) {\n      const thresholdCount = healthCheck.unhealthyThresholdCount;\n      if (thresholdCount < 2 || thresholdCount > 10) {\n        ret.push(`Unhealthy Threshold Count '${thresholdCount}' not supported. Must be a number between 2 and 10.`);\n      }\n    }\n\n    if (healthCheck.healthyThresholdCount && healthCheck.unhealthyThresholdCount &&\n      healthCheck.healthyThresholdCount !== healthCheck.unhealthyThresholdCount) {\n      ret.push([\n        `Healthy and Unhealthy Threshold Counts must be the same: ${healthCheck.healthyThresholdCount}`,\n        `is not equal to ${healthCheck.unhealthyThresholdCount}.`,\n      ].join(' '));\n    }\n\n    if (!healthCheck.protocol) {\n      return ret;\n    }\n\n    if (!NLB_HEALTH_CHECK_PROTOCOLS.includes(healthCheck.protocol)) {\n      ret.push(`Health check protocol '${healthCheck.protocol}' is not supported. Must be one of [${NLB_HEALTH_CHECK_PROTOCOLS.join(', ')}]`);\n    }\n    if (healthCheck.path && !NLB_PATH_HEALTH_CHECK_PROTOCOLS.includes(healthCheck.protocol)) {\n      ret.push([\n        `'${healthCheck.protocol}' health checks do not support the path property.`,\n        `Must be one of [${NLB_PATH_HEALTH_CHECK_PROTOCOLS.join(', ')}]`,\n      ].join(' '));\n    }\n    if (healthCheck.timeout && healthCheck.timeout.toSeconds() !== NLB_HEALTH_CHECK_TIMEOUTS[healthCheck.protocol]) {\n      ret.push([\n        'Custom health check timeouts are not supported for Network Load Balancer health checks.',\n        `Expected ${NLB_HEALTH_CHECK_TIMEOUTS[healthCheck.protocol]} seconds for ${healthCheck.protocol}, got ${healthCheck.timeout.toSeconds()}`,\n      ].join(' '));\n    }\n\n    return ret;\n  }\n\n  private metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/NetworkELB',\n      metricName,\n      dimensionsMap: { LoadBalancer: this.firstLoadBalancerFullName, TargetGroup: this.targetGroupFullName },\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n                                 \nexport interface INetworkTargetGroup extends ITargetGroup {\n                                                                                                                                                     \n  registerListener(listener: INetworkListener): void;\n\n                                                                 \n  addTarget(...targets: INetworkLoadBalancerTarget[]): void;\n}\n\n/**\n * An imported network target group\n */\nclass ImportedNetworkTargetGroup extends ImportedTargetGroupBase implements INetworkTargetGroup {\n  public registerListener(_listener: INetworkListener) {\n    // Nothing to do, we know nothing of our members\n  }\n\n  public addTarget(...targets: INetworkLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToNetworkTargetGroup(this);\n      if (result.targetJson !== undefined) {\n        throw new Error('Cannot add a non-self registering target to an imported TargetGroup. Create a new TargetGroup instead.');\n      }\n    }\n  }\n}\n\n                                                                                   \nexport interface INetworkLoadBalancerTarget {\n                                                                                                                                                                                                                  \n  attachToNetworkTargetGroup(targetGroup: INetworkTargetGroup): LoadBalancerTargetProps;\n}\n\nconst NLB_HEALTH_CHECK_PROTOCOLS = [Protocol.HTTP, Protocol.HTTPS, Protocol.TCP];\nconst NLB_PATH_HEALTH_CHECK_PROTOCOLS = [Protocol.HTTP, Protocol.HTTPS];\nconst NLB_HEALTH_CHECK_TIMEOUTS: { [protocol in Protocol]?: number } = {\n  [Protocol.HTTP]: 6,\n  [Protocol.HTTPS]: 10,\n  [Protocol.TCP]: 10,\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-target-group.js","sourceRoot":"","sources":["network-target-group.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport {\n  BaseTargetGroupProps, HealthCheck, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n  TargetGroupAttributes, TargetGroupBase, TargetGroupImportProps,\n} from '../shared/base-target-group';\nimport { Protocol } from '../shared/enums';\nimport { ImportedTargetGroupBase } from '../shared/imported';\nimport { validateNetworkProtocol } from '../shared/util';\nimport { INetworkListener } from './network-listener';\n\n/**\n * Properties for a new Network Target Group\n */\nexport interface NetworkTargetGroupProps extends BaseTargetGroupProps {\n  /**\n   * The port on which the listener listens for requests.\n   */\n  readonly port: number;\n\n  /**\n   * Protocol for target group, expects TCP, TLS, UDP, or TCP_UDP.\n   *\n   * @default - TCP\n   */\n  readonly protocol?: Protocol;\n\n  /**\n   * Indicates whether Proxy Protocol version 2 is enabled.\n   *\n   * @default false\n   */\n  readonly proxyProtocolV2?: boolean;\n\n  /**\n   * Indicates whether client IP preservation is enabled.\n   *\n   * @default false if the target group type is IP address and the\n   * target group protocol is TCP or TLS. Otherwise, true.\n   */\n  readonly preserveClientIp?: boolean;\n\n  /**\n   * The targets to add to this target group.\n   *\n   * Can be `Instance`, `IPAddress`, or any self-registering load balancing\n   * target. If you use either `Instance` or `IPAddress` as targets, all\n   * target must be of the same type.\n   *\n   * @default - No targets.\n   */\n  readonly targets?: INetworkLoadBalancerTarget[];\n}\n\n/**\n * Define a Network Target Group\n */\nexport class NetworkTargetGroup extends TargetGroupBase implements INetworkTargetGroup {\n  /**\n   * Import an existing target group\n   */\n  public static fromTargetGroupAttributes(scope: Construct, id: string, attrs: TargetGroupAttributes): INetworkTargetGroup {\n    return new ImportedNetworkTargetGroup(scope, id, attrs);\n  }\n\n  /**\n   * Import an existing listener\n   *\n   * @deprecated Use `fromTargetGroupAttributes` instead\n   */\n  public static import(scope: Construct, id: string, props: TargetGroupImportProps): INetworkTargetGroup {\n    return NetworkTargetGroup.fromTargetGroupAttributes(scope, id, props);\n  }\n\n  private readonly listeners: INetworkListener[];\n\n  constructor(scope: Construct, id: string, props: NetworkTargetGroupProps) {\n    const proto = props.protocol || Protocol.TCP;\n    validateNetworkProtocol(proto);\n\n    super(scope, id, props, {\n      protocol: proto,\n      port: props.port,\n    });\n\n    this.listeners = [];\n\n    if (props.proxyProtocolV2 != null) {\n      this.setAttribute('proxy_protocol_v2.enabled', props.proxyProtocolV2 ? 'true' : 'false');\n    }\n\n    if (props.preserveClientIp !== undefined) {\n      this.setAttribute('preserve_client_ip.enabled', props.preserveClientIp ? 'true' : 'false');\n    }\n\n    this.addTarget(...(props.targets || []));\n  }\n\n  /**\n   * Add a load balancing target to this target group\n   */\n  public addTarget(...targets: INetworkLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToNetworkTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n  }\n\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  public registerListener(listener: INetworkListener) {\n    this.loadBalancerAttachedDependencies.add(listener);\n    this.listeners.push(listener);\n  }\n\n  /**\n   * The number of targets that are considered healthy.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('HealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * The number of targets that are considered unhealthy.\n   *\n   * @default Average over 5 minutes\n   */\n  public metricUnHealthyHostCount(props?: cloudwatch.MetricOptions) {\n    return this.metric('UnHealthyHostCount', {\n      statistic: 'Average',\n      ...props,\n    });\n  }\n\n  /**\n   * Full name of first load balancer\n   */\n  public get firstLoadBalancerFullName(): string {\n    if (this.listeners.length === 0) {\n      throw new Error('The TargetGroup needs to be attached to a LoadBalancer before you can call this method');\n    }\n    return loadBalancerNameFromListenerArn(this.listeners[0].listenerArn);\n  }\n\n  protected validate(): string[] {\n    const ret = super.validate();\n\n    const healthCheck: HealthCheck = this.healthCheck || {};\n\n    const allowedIntervals = [10, 30];\n    if (healthCheck.interval) {\n      const seconds = healthCheck.interval.toSeconds();\n      if (!cdk.Token.isUnresolved(seconds) && !allowedIntervals.includes(seconds)) {\n        ret.push(`Health check interval '${seconds}' not supported. Must be one of the following values '${allowedIntervals.join(',')}'.`);\n      }\n    }\n\n    if (healthCheck.healthyThresholdCount) {\n      const thresholdCount = healthCheck.healthyThresholdCount;\n      if (thresholdCount < 2 || thresholdCount > 10) {\n        ret.push(`Healthy Threshold Count '${thresholdCount}' not supported. Must be a number between 2 and 10.`);\n      }\n    }\n\n    if (healthCheck.unhealthyThresholdCount) {\n      const thresholdCount = healthCheck.unhealthyThresholdCount;\n      if (thresholdCount < 2 || thresholdCount > 10) {\n        ret.push(`Unhealthy Threshold Count '${thresholdCount}' not supported. Must be a number between 2 and 10.`);\n      }\n    }\n\n    if (healthCheck.healthyThresholdCount && healthCheck.unhealthyThresholdCount &&\n      healthCheck.healthyThresholdCount !== healthCheck.unhealthyThresholdCount) {\n      ret.push([\n        `Healthy and Unhealthy Threshold Counts must be the same: ${healthCheck.healthyThresholdCount}`,\n        `is not equal to ${healthCheck.unhealthyThresholdCount}.`,\n      ].join(' '));\n    }\n\n    if (!healthCheck.protocol) {\n      return ret;\n    }\n\n    if (!NLB_HEALTH_CHECK_PROTOCOLS.includes(healthCheck.protocol)) {\n      ret.push(`Health check protocol '${healthCheck.protocol}' is not supported. Must be one of [${NLB_HEALTH_CHECK_PROTOCOLS.join(', ')}]`);\n    }\n    if (healthCheck.path && !NLB_PATH_HEALTH_CHECK_PROTOCOLS.includes(healthCheck.protocol)) {\n      ret.push([\n        `'${healthCheck.protocol}' health checks do not support the path property.`,\n        `Must be one of [${NLB_PATH_HEALTH_CHECK_PROTOCOLS.join(', ')}]`,\n      ].join(' '));\n    }\n    if (healthCheck.timeout && healthCheck.timeout.toSeconds() !== NLB_HEALTH_CHECK_TIMEOUTS[healthCheck.protocol]) {\n      ret.push([\n        'Custom health check timeouts are not supported for Network Load Balancer health checks.',\n        `Expected ${NLB_HEALTH_CHECK_TIMEOUTS[healthCheck.protocol]} seconds for ${healthCheck.protocol}, got ${healthCheck.timeout.toSeconds()}`,\n      ].join(' '));\n    }\n\n    return ret;\n  }\n\n  private metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/NetworkELB',\n      metricName,\n      dimensionsMap: { LoadBalancer: this.firstLoadBalancerFullName, TargetGroup: this.targetGroupFullName },\n      ...props,\n    }).attachTo(this);\n  }\n}\n\n/**\n * A network target group\n */\nexport interface INetworkTargetGroup extends ITargetGroup {\n  /**\n   * Register a listener that is load balancing to this target group.\n   *\n   * Don't call this directly. It will be called by listeners.\n   */\n  registerListener(listener: INetworkListener): void;\n\n  /**\n   * Add a load balancing target to this target group\n   */\n  addTarget(...targets: INetworkLoadBalancerTarget[]): void;\n}\n\n/**\n * An imported network target group\n */\nclass ImportedNetworkTargetGroup extends ImportedTargetGroupBase implements INetworkTargetGroup {\n  public registerListener(_listener: INetworkListener) {\n    // Nothing to do, we know nothing of our members\n  }\n\n  public addTarget(...targets: INetworkLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToNetworkTargetGroup(this);\n      if (result.targetJson !== undefined) {\n        throw new Error('Cannot add a non-self registering target to an imported TargetGroup. Create a new TargetGroup instead.');\n      }\n    }\n  }\n}\n\n/**\n * Interface for constructs that can be targets of an network load balancer\n */\nexport interface INetworkLoadBalancerTarget {\n  /**\n   * Attach load-balanced target to a TargetGroup\n   *\n   * May return JSON to directly add to the [Targets] list, or return undefined\n   * if the target will register itself with the load balancer.\n   */\n  attachToNetworkTargetGroup(targetGroup: INetworkTargetGroup): LoadBalancerTargetProps;\n}\n\nconst NLB_HEALTH_CHECK_PROTOCOLS = [Protocol.HTTP, Protocol.HTTPS, Protocol.TCP];\nconst NLB_PATH_HEALTH_CHECK_PROTOCOLS = [Protocol.HTTP, Protocol.HTTPS];\nconst NLB_HEALTH_CHECK_TIMEOUTS: { [protocol in Protocol]?: number } = {\n  [Protocol.HTTP]: 6,\n  [Protocol.HTTPS]: 10,\n  [Protocol.TCP]: 10,\n};\n"]}

@@ -7,26 +7,18 @@ import * as cxschema from '@aws-cdk/cloud-assembly-schema';

/**
* Options for listener lookup.
*
* @stability stable
* Options for listener lookup
*/
export interface BaseListenerLookupOptions {
/**
* Filter listeners by associated load balancer arn.
*
* Filter listeners by associated load balancer arn
* @default - does not filter by load balancer arn
* @stability stable
*/
readonly loadBalancerArn?: string;
/**
* Filter listeners by associated load balancer tags.
*
* Filter listeners by associated load balancer tags
* @default - does not filter by load balancer tags
* @stability stable
*/
readonly loadBalancerTags?: Record<string, string>;
/**
* Filter listeners by listener port.
*
* Filter listeners by listener port
* @default - does not filter by listener port
* @stability stable
*/

@@ -59,5 +51,3 @@ readonly listenerPort?: number;

/**
* Base class for listeners.
*
* @stability stable
* Base class for listeners
*/

@@ -72,15 +62,9 @@ export declare abstract class BaseListener extends Resource {

/**
* @stability stable
* @attribute true
* @attribute
*/
readonly listenerArn: string;
private defaultAction?;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, additionalProps: any);
/**
* Validate this listener.
*
* @stability stable
* Validate this listener
*/

@@ -87,0 +71,0 @@ protected validate(): string[];

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

/**
* Base class for listeners.
*
* @stability stable
* Base class for listeners
*/
class BaseListener extends core_1.Resource {
/**
* @stability stable
*/
constructor(scope, id, additionalProps) {

@@ -63,5 +58,3 @@ super(scope, id);

/**
* Validate this listener.
*
* @stability stable
* Validate this listener
*/

@@ -97,3 +90,3 @@ validate() {

_a = JSII_RTTI_SYMBOL_1;
BaseListener[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.BaseListener", version: "1.144.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-listener.js","sourceRoot":"","sources":["base-listener.ts"],"names":[],"mappings":";;;;;AAAA,2DAA2D;AAC3D,wCAAoF;AAGpF,0FAAkE;AAElE,iCAA6C;;;;;;AA0C7C,MAAsB,YAAa,SAAQ,eAAQ;;;;IA0CjD,YAAY,KAAgB,EAAE,EAAU,EAAE,eAAoB;QAC5D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,QAAQ,GAAG,IAAI,8CAAW,CAAC,IAAI,EAAE,UAAU,EAAE;YACjD,GAAG,eAAe;YAClB,cAAc,EAAE,WAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,kCAAC,IAAI,CAAC,aAAa,0CAAE,aAAa,qCAAM,EAAE,GAAA,EAAE,CAAC;SACvF,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC;KACjC;IAlDD;;;;OAIG;IACO,MAAM,CAAC,qBAAqB,CAAC,KAAgB,EAAE,OAA4C;;QACnG,IAAI,YAAK,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,eAAe,CAAC;eACtD,MAAM,CAAC,MAAM,OAAC,OAAO,CAAC,WAAW,CAAC,gBAAgB,mCAAI,EAAE,CAAC,CAAC,IAAI,CAAC,YAAK,CAAC,YAAY,CAAC;eAClF,YAAK,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE;YACzD,MAAM,IAAI,KAAK,CAAC,gFAAgF,CAAC,CAAC;SACnG;QAED,IAAI,YAAwC,CAAC;QAC7C,IAAI,OAAO,CAAC,WAAW,CAAC,gBAAgB,EAAE;YACxC,YAAY,GAAG,0BAAmB,CAAC,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;SAC1E;QAED,MAAM,KAAK,GAA8C,sBAAe,CAAC,QAAQ,CAAC,KAAK,EAAE;YACvF,QAAQ,EAAE,QAAQ,CAAC,eAAe,CAAC,+BAA+B;YAClE,KAAK,EAAE;gBACL,WAAW,EAAE,OAAO,CAAC,WAAW;gBAChC,YAAY,EAAE,OAAO,CAAC,WAAW,CAAC,YAAY;gBAC9C,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;gBAC1C,eAAe,EAAE,OAAO,CAAC,WAAW,CAAC,eAAe;gBACpD,gBAAgB,EAAE,YAAY;gBAC9B,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;aACE;YAC9C,UAAU,EAAE;gBACV,WAAW,EAAE,gEAAgE,OAAO,CAAC,gBAAgB,qDAAqD;gBAC1J,YAAY,EAAE,EAAE;gBAChB,gBAAgB,EAAE,CAAC,iBAAiB,CAAC;aACO;SAC/C,CAAC,CAAC,KAAK,CAAC;QAET,OAAO,KAAK,CAAC;KACd;;;;;;IAkBS,QAAQ;QAChB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,OAAO,CAAC,gGAAgG,CAAC,CAAC;SAC3G;QACD,OAAO,EAAE,CAAC;KACX;IAED;;;;OAIG;IACO,iBAAiB,CAAC,MAAuB;QACjD,uCAAuC;QACvC,EAAE;QACF,kFAAkF;QAClF,yFAAyF;QACzF,8FAA8F;QAC9F,kDAAkD;QAClD,EAAE;QACF,0CAA0C;QAC1C,4EAA4E;QAC5E,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,kBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,2GAA2G,CAAC,CAAC;SAC9I;QAED,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;KAC7B;;AAjFH,oCAkFC","sourcesContent":["import * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Annotations, ContextProvider, Lazy, Resource, Token } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Construct } from 'constructs';\nimport { CfnListener } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from './listener-action';\nimport { mapTagMapToCxschema } from './util';\n\n                                      \nexport interface BaseListenerLookupOptions {\n                                                                                                                      \n  readonly loadBalancerArn?: string;\n\n                                                                                                                        \n  readonly loadBalancerTags?: Record<string, string>;\n\n                                                                                                   \n  readonly listenerPort?: number;\n}\n\n/**\n * Options for querying the load balancer listener context provider\n * @internal\n */\nexport interface ListenerQueryContextProviderOptions {\n  /**\n   * User's provided options\n   */\n  readonly userOptions: BaseListenerLookupOptions;\n\n  /**\n   * Type of load balancer expected\n   */\n  readonly loadBalancerType: cxschema.LoadBalancerType;\n\n  /**\n   * ARN of the listener to look up\n   * @default - does not filter by listener arn\n   */\n  readonly listenerArn?: string;\n\n  /**\n   * Optional protocol of the listener to look up\n   */\n  readonly listenerProtocol?: cxschema.LoadBalancerListenerProtocol;\n}\n\n                                   \nexport abstract class BaseListener extends Resource {\n  /**\n   * Queries the load balancer listener context provider for load balancer\n   * listener info.\n   * @internal\n   */\n  protected static _queryContextProvider(scope: Construct, options: ListenerQueryContextProviderOptions) {\n    if (Token.isUnresolved(options.userOptions.loadBalancerArn)\n      || Object.values(options.userOptions.loadBalancerTags ?? {}).some(Token.isUnresolved)\n      || Token.isUnresolved(options.userOptions.listenerPort)) {\n      throw new Error('All arguments to look up a load balancer listener must be concrete (no Tokens)');\n    }\n\n    let cxschemaTags: cxschema.Tag[] | undefined;\n    if (options.userOptions.loadBalancerTags) {\n      cxschemaTags = mapTagMapToCxschema(options.userOptions.loadBalancerTags);\n    }\n\n    const props: cxapi.LoadBalancerListenerContextResponse = ContextProvider.getValue(scope, {\n      provider: cxschema.ContextProvider.LOAD_BALANCER_LISTENER_PROVIDER,\n      props: {\n        listenerArn: options.listenerArn,\n        listenerPort: options.userOptions.listenerPort,\n        listenerProtocol: options.listenerProtocol,\n        loadBalancerArn: options.userOptions.loadBalancerArn,\n        loadBalancerTags: cxschemaTags,\n        loadBalancerType: options.loadBalancerType,\n      } as cxschema.LoadBalancerListenerContextQuery,\n      dummyValue: {\n        listenerArn: `arn:aws:elasticloadbalancing:us-west-2:123456789012:listener/${options.loadBalancerType}/my-load-balancer/50dc6c495c0c9188/f2f7dc8efc522ab2`,\n        listenerPort: 80,\n        securityGroupIds: ['sg-123456789012'],\n      } as cxapi.LoadBalancerListenerContextResponse,\n    }).value;\n\n    return props;\n  }\n                           \n  public readonly listenerArn: string;\n\n  private defaultAction?: IListenerAction;\n\n  constructor(scope: Construct, id: string, additionalProps: any) {\n    super(scope, id);\n\n    const resource = new CfnListener(this, 'Resource', {\n      ...additionalProps,\n      defaultActions: Lazy.any({ produce: () => this.defaultAction?.renderActions() ?? [] }),\n    });\n\n    this.listenerArn = resource.ref;\n  }\n\n                                       \n  protected validate(): string[] {\n    if (!this.defaultAction) {\n      return ['Listener needs at least one default action or target group (call addTargetGroups or addAction)'];\n    }\n    return [];\n  }\n\n  /**\n   * Configure the default action\n   *\n   * @internal\n   */\n  protected _setDefaultAction(action: IListenerAction) {\n    // It might make sense to 'throw' here.\n    //\n    // However, programs may already exist out there which configured an action twice,\n    // in which case the second action accidentally overwrite the initial action, and in some\n    // way ended up with a program that did what the author intended. If we were to add throw now,\n    // the previously working program would be broken.\n    //\n    // Instead, signal this through a warning.\n    // @deprecate: upon the next major version bump, replace this with a `throw`\n    if (this.defaultAction) {\n      Annotations.of(this).addWarning('A default Action already existed on this Listener and was replaced. Configure exactly one default Action.');\n    }\n\n    this.defaultAction = action;\n  }\n}\n"]}
BaseListener[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.BaseListener", version: "1.145.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-listener.js","sourceRoot":"","sources":["base-listener.ts"],"names":[],"mappings":";;;;;AAAA,2DAA2D;AAC3D,wCAAoF;AAGpF,0FAAkE;AAElE,iCAA6C;AAoD7C;;GAEG;AACH,MAAsB,YAAa,SAAQ,eAAQ;IA4CjD,YAAY,KAAgB,EAAE,EAAU,EAAE,eAAoB;QAC5D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,QAAQ,GAAG,IAAI,8CAAW,CAAC,IAAI,EAAE,UAAU,EAAE;YACjD,GAAG,eAAe;YAClB,cAAc,EAAE,WAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,kCAAC,IAAI,CAAC,aAAa,0CAAE,aAAa,qCAAM,EAAE,GAAA,EAAE,CAAC;SACvF,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC;KACjC;IApDD;;;;OAIG;IACO,MAAM,CAAC,qBAAqB,CAAC,KAAgB,EAAE,OAA4C;;QACnG,IAAI,YAAK,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,eAAe,CAAC;eACtD,MAAM,CAAC,MAAM,OAAC,OAAO,CAAC,WAAW,CAAC,gBAAgB,mCAAI,EAAE,CAAC,CAAC,IAAI,CAAC,YAAK,CAAC,YAAY,CAAC;eAClF,YAAK,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE;YACzD,MAAM,IAAI,KAAK,CAAC,gFAAgF,CAAC,CAAC;SACnG;QAED,IAAI,YAAwC,CAAC;QAC7C,IAAI,OAAO,CAAC,WAAW,CAAC,gBAAgB,EAAE;YACxC,YAAY,GAAG,0BAAmB,CAAC,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;SAC1E;QAED,MAAM,KAAK,GAA8C,sBAAe,CAAC,QAAQ,CAAC,KAAK,EAAE;YACvF,QAAQ,EAAE,QAAQ,CAAC,eAAe,CAAC,+BAA+B;YAClE,KAAK,EAAE;gBACL,WAAW,EAAE,OAAO,CAAC,WAAW;gBAChC,YAAY,EAAE,OAAO,CAAC,WAAW,CAAC,YAAY;gBAC9C,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;gBAC1C,eAAe,EAAE,OAAO,CAAC,WAAW,CAAC,eAAe;gBACpD,gBAAgB,EAAE,YAAY;gBAC9B,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;aACE;YAC9C,UAAU,EAAE;gBACV,WAAW,EAAE,gEAAgE,OAAO,CAAC,gBAAgB,qDAAqD;gBAC1J,YAAY,EAAE,EAAE;gBAChB,gBAAgB,EAAE,CAAC,iBAAiB,CAAC;aACO;SAC/C,CAAC,CAAC,KAAK,CAAC;QAET,OAAO,KAAK,CAAC;KACd;IAmBD;;OAEG;IACO,QAAQ;QAChB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,OAAO,CAAC,gGAAgG,CAAC,CAAC;SAC3G;QACD,OAAO,EAAE,CAAC;KACX;IAED;;;;OAIG;IACO,iBAAiB,CAAC,MAAuB;QACjD,uCAAuC;QACvC,EAAE;QACF,kFAAkF;QAClF,yFAAyF;QACzF,8FAA8F;QAC9F,kDAAkD;QAClD,EAAE;QACF,0CAA0C;QAC1C,4EAA4E;QAC5E,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,kBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,2GAA2G,CAAC,CAAC;SAC9I;QAED,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;KAC7B;;AArFH,oCAsFC","sourcesContent":["import * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { Annotations, ContextProvider, Lazy, Resource, Token } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Construct } from 'constructs';\nimport { CfnListener } from '../elasticloadbalancingv2.generated';\nimport { IListenerAction } from './listener-action';\nimport { mapTagMapToCxschema } from './util';\n\n/**\n * Options for listener lookup\n */\nexport interface BaseListenerLookupOptions {\n  /**\n   * Filter listeners by associated load balancer arn\n   * @default - does not filter by load balancer arn\n   */\n  readonly loadBalancerArn?: string;\n\n  /**\n   * Filter listeners by associated load balancer tags\n   * @default - does not filter by load balancer tags\n   */\n  readonly loadBalancerTags?: Record<string, string>;\n\n  /**\n   * Filter listeners by listener port\n   * @default - does not filter by listener port\n   */\n  readonly listenerPort?: number;\n}\n\n/**\n * Options for querying the load balancer listener context provider\n * @internal\n */\nexport interface ListenerQueryContextProviderOptions {\n  /**\n   * User's provided options\n   */\n  readonly userOptions: BaseListenerLookupOptions;\n\n  /**\n   * Type of load balancer expected\n   */\n  readonly loadBalancerType: cxschema.LoadBalancerType;\n\n  /**\n   * ARN of the listener to look up\n   * @default - does not filter by listener arn\n   */\n  readonly listenerArn?: string;\n\n  /**\n   * Optional protocol of the listener to look up\n   */\n  readonly listenerProtocol?: cxschema.LoadBalancerListenerProtocol;\n}\n\n/**\n * Base class for listeners\n */\nexport abstract class BaseListener extends Resource {\n  /**\n   * Queries the load balancer listener context provider for load balancer\n   * listener info.\n   * @internal\n   */\n  protected static _queryContextProvider(scope: Construct, options: ListenerQueryContextProviderOptions) {\n    if (Token.isUnresolved(options.userOptions.loadBalancerArn)\n      || Object.values(options.userOptions.loadBalancerTags ?? {}).some(Token.isUnresolved)\n      || Token.isUnresolved(options.userOptions.listenerPort)) {\n      throw new Error('All arguments to look up a load balancer listener must be concrete (no Tokens)');\n    }\n\n    let cxschemaTags: cxschema.Tag[] | undefined;\n    if (options.userOptions.loadBalancerTags) {\n      cxschemaTags = mapTagMapToCxschema(options.userOptions.loadBalancerTags);\n    }\n\n    const props: cxapi.LoadBalancerListenerContextResponse = ContextProvider.getValue(scope, {\n      provider: cxschema.ContextProvider.LOAD_BALANCER_LISTENER_PROVIDER,\n      props: {\n        listenerArn: options.listenerArn,\n        listenerPort: options.userOptions.listenerPort,\n        listenerProtocol: options.listenerProtocol,\n        loadBalancerArn: options.userOptions.loadBalancerArn,\n        loadBalancerTags: cxschemaTags,\n        loadBalancerType: options.loadBalancerType,\n      } as cxschema.LoadBalancerListenerContextQuery,\n      dummyValue: {\n        listenerArn: `arn:aws:elasticloadbalancing:us-west-2:123456789012:listener/${options.loadBalancerType}/my-load-balancer/50dc6c495c0c9188/f2f7dc8efc522ab2`,\n        listenerPort: 80,\n        securityGroupIds: ['sg-123456789012'],\n      } as cxapi.LoadBalancerListenerContextResponse,\n    }).value;\n\n    return props;\n  }\n  /**\n   * @attribute\n   */\n  public readonly listenerArn: string;\n\n  private defaultAction?: IListenerAction;\n\n  constructor(scope: Construct, id: string, additionalProps: any) {\n    super(scope, id);\n\n    const resource = new CfnListener(this, 'Resource', {\n      ...additionalProps,\n      defaultActions: Lazy.any({ produce: () => this.defaultAction?.renderActions() ?? [] }),\n    });\n\n    this.listenerArn = resource.ref;\n  }\n\n  /**\n   * Validate this listener\n   */\n  protected validate(): string[] {\n    if (!this.defaultAction) {\n      return ['Listener needs at least one default action or target group (call addTargetGroups or addAction)'];\n    }\n    return [];\n  }\n\n  /**\n   * Configure the default action\n   *\n   * @internal\n   */\n  protected _setDefaultAction(action: IListenerAction) {\n    // It might make sense to 'throw' here.\n    //\n    // However, programs may already exist out there which configured an action twice,\n    // in which case the second action accidentally overwrite the initial action, and in some\n    // way ended up with a program that did what the author intended. If we were to add throw now,\n    // the previously working program would be broken.\n    //\n    // Instead, signal this through a warning.\n    // @deprecate: upon the next major version bump, replace this with a `throw`\n    if (this.defaultAction) {\n      Annotations.of(this).addWarning('A default Action already existed on this Listener and was replaced. Configure exactly one default Action.');\n    }\n\n    this.defaultAction = action;\n  }\n}\n"]}

@@ -8,32 +8,26 @@ import * as ec2 from '@aws-cdk/aws-ec2';

/**
* Shared properties of both Application and Network Load Balancers.
*
* @stability stable
* Shared properties of both Application and Network Load Balancers
*/
export interface BaseLoadBalancerProps {
/**
* Name of the load balancer.
* Name of the load balancer
*
* @default - Automatically generated name.
* @stability stable
*/
readonly loadBalancerName?: string;
/**
* The VPC network to place the load balancer in.
*
* @stability stable
* The VPC network to place the load balancer in
*/
readonly vpc: ec2.IVpc;
/**
* Whether the load balancer has an internet-routable address.
* Whether the load balancer has an internet-routable address
*
* @default false
* @stability stable
*/
readonly internetFacing?: boolean;
/**
* Which subnets place the load balancer in.
* Which subnets place the load balancer in
*
* @default - the Vpc default strategy.
* @stability stable
*
*/

@@ -45,26 +39,20 @@ readonly vpcSubnets?: ec2.SubnetSelection;

* @default false
* @stability stable
*/
readonly deletionProtection?: boolean;
}
/**
* @stability stable
*/
export interface ILoadBalancerV2 extends IResource {
/**
* The canonical hosted zone ID of this load balancer.
* The canonical hosted zone ID of this load balancer
*
* Example value: `Z2P70J7EXAMPLE`
*
* @stability stable
* @attribute true
* @attribute
*/
readonly loadBalancerCanonicalHostedZoneId: string;
/**
* The DNS name of this load balancer.
* The DNS name of this load balancer
*
* Example value: `my-load-balancer-424835706.us-west-2.elb.amazonaws.com`
*
* @stability stable
* @attribute true
* @attribute
*/

@@ -74,12 +62,8 @@ readonly loadBalancerDnsName: string;

/**
* Options for looking up load balancers.
*
* @stability stable
* Options for looking up load balancers
*/
export interface BaseLoadBalancerLookupOptions {
/**
* Find by load balancer's ARN.
*
* Find by load balancer's ARN
* @default - does not search by load balancer arn
* @stability stable
*/

@@ -89,5 +73,3 @@ readonly loadBalancerArn?: string;

* Match load balancer tags.
*
* @default - does not match load balancers by tags
* @stability stable
*/

@@ -111,5 +93,3 @@ readonly loadBalancerTags?: Record<string, string>;

/**
* Base class for both Application and Network Load Balancers.
*
* @stability stable
* Base class for both Application and Network Load Balancers
*/

@@ -123,49 +103,43 @@ export declare abstract class BaseLoadBalancer extends Resource {

/**
* The canonical hosted zone ID of this load balancer.
* The canonical hosted zone ID of this load balancer
*
* Example value: `Z2P70J7EXAMPLE`
*
* @stability stable
* @attribute true
* @attribute
*/
readonly loadBalancerCanonicalHostedZoneId: string;
/**
* The DNS name of this load balancer.
* The DNS name of this load balancer
*
* Example value: `my-load-balancer-424835706.us-west-2.elb.amazonaws.com`
*
* @stability stable
* @attribute true
* @attribute
*/
readonly loadBalancerDnsName: string;
/**
* The full name of this load balancer.
* The full name of this load balancer
*
* Example value: `app/my-load-balancer/50dc6c495c0c9188`
*
* @stability stable
* @attribute true
* @attribute
*/
readonly loadBalancerFullName: string;
/**
* The name of this load balancer.
* The name of this load balancer
*
* Example value: `my-load-balancer`
*
* @stability stable
* @attribute true
* @attribute
*/
readonly loadBalancerName: string;
/**
* The ARN of this load balancer.
* The ARN of this load balancer
*
* Example value: `arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-internal-load-balancer/50dc6c495c0c9188`
*
* @stability stable
* @attribute true
* @attribute
*/
readonly loadBalancerArn: string;
/**
* @stability stable
* @attribute true
* @attribute
*/

@@ -177,4 +151,2 @@ readonly loadBalancerSecurityGroups: string[];

* This property is always defined (not `null` or `undefined`) for sub-classes of `BaseLoadBalancer`.
*
* @stability stable
*/

@@ -186,5 +158,2 @@ readonly vpc?: ec2.IVpc;

private readonly attributes;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, baseProps: BaseLoadBalancerProps, additionalProps: any);

@@ -196,19 +165,14 @@ /**

* environment-agnostic stacks. See https://docs.aws.amazon.com/cdk/latest/guide/environments.html
*
* @stability stable
*/
logAccessLogs(bucket: s3.IBucket, prefix?: string): void;
/**
* Set a non-standard attribute on the load balancer.
* Set a non-standard attribute on the load balancer
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/application-load-balancers.html#load-balancer-attributes
* @stability stable
*/
setAttribute(key: string, value: string | undefined): void;
/**
* Remove an attribute from the load balancer.
*
* @stability stable
* Remove an attribute from the load balancer
*/
removeAttribute(key: string): void;
}

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

/**
* Base class for both Application and Network Load Balancers.
*
* @stability stable
* Base class for both Application and Network Load Balancers
*/
class BaseLoadBalancer extends core_1.Resource {
/**
* @stability stable
*/
constructor(scope, id, baseProps, additionalProps) {

@@ -94,4 +89,2 @@ super(scope, id, {

* environment-agnostic stacks. See https://docs.aws.amazon.com/cdk/latest/guide/environments.html
*
* @stability stable
*/

@@ -132,6 +125,5 @@ logAccessLogs(bucket, prefix) {

/**
* Set a non-standard attribute on the load balancer.
* Set a non-standard attribute on the load balancer
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/application-load-balancers.html#load-balancer-attributes
* @stability stable
*/

@@ -142,5 +134,3 @@ setAttribute(key, value) {

/**
* Remove an attribute from the load balancer.
*
* @stability stable
* Remove an attribute from the load balancer
*/

@@ -153,3 +143,3 @@ removeAttribute(key) {

_a = JSII_RTTI_SYMBOL_1;
BaseLoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.BaseLoadBalancer", version: "1.144.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-load-balancer.js","sourceRoot":"","sources":["base-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from '@aws-cdk/aws-ec2';\nimport * as iam from '@aws-cdk/aws-iam';\nimport { PolicyStatement, ServicePrincipal } from '@aws-cdk/aws-iam';\nimport * as s3 from '@aws-cdk/aws-s3';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { ContextProvider, IResource, Lazy, Resource, Stack, Token } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { RegionInfo } from '@aws-cdk/region-info';\nimport { Construct } from 'constructs';\nimport { CfnLoadBalancer } from '../elasticloadbalancingv2.generated';\nimport { Attributes, ifUndefined, mapTagMapToCxschema, renderAttributes } from './util';\n\n                                                                           \nexport interface BaseLoadBalancerProps {\n                                                                                             \n  readonly loadBalancerName?: string;\n\n                                                              \n  readonly vpc: ec2.IVpc;\n\n                                                                                                    \n  readonly internetFacing?: boolean;\n\n                                                                                                             \n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n                                                                                           \n  readonly deletionProtection?: boolean;\n}\n\nexport interface ILoadBalancerV2 extends IResource {\n                                                                                                                                  \n  readonly loadBalancerCanonicalHostedZoneId: string;\n\n                                                                                                                                                          \n  readonly loadBalancerDnsName: string;\n}\n\n                                                \nexport interface BaseLoadBalancerLookupOptions {\n                                                                                                 \n  readonly loadBalancerArn?: string;\n\n                                                                                                \n  readonly loadBalancerTags?: Record<string, string>;\n}\n\n/**\n * Options for query context provider\n * @internal\n */\nexport interface LoadBalancerQueryContextProviderOptions {\n  /**\n   * User's lookup options\n   */\n  readonly userOptions: BaseLoadBalancerLookupOptions;\n\n  /**\n   * Type of load balancer\n   */\n  readonly loadBalancerType: cxschema.LoadBalancerType;\n}\n\n                                                                     \nexport abstract class BaseLoadBalancer extends Resource {\n  /**\n   * Queries the load balancer context provider for load balancer info.\n   * @internal\n   */\n  protected static _queryContextProvider(scope: Construct, options: LoadBalancerQueryContextProviderOptions) {\n    if (Token.isUnresolved(options.userOptions.loadBalancerArn)\n      || Object.values(options.userOptions.loadBalancerTags ?? {}).some(Token.isUnresolved)) {\n      throw new Error('All arguments to look up a load balancer must be concrete (no Tokens)');\n    }\n\n    let cxschemaTags: cxschema.Tag[] | undefined;\n    if (options.userOptions.loadBalancerTags) {\n      cxschemaTags = mapTagMapToCxschema(options.userOptions.loadBalancerTags);\n    }\n\n    const props: cxapi.LoadBalancerContextResponse = ContextProvider.getValue(scope, {\n      provider: cxschema.ContextProvider.LOAD_BALANCER_PROVIDER,\n      props: {\n        loadBalancerArn: options.userOptions.loadBalancerArn,\n        loadBalancerTags: cxschemaTags,\n        loadBalancerType: options.loadBalancerType,\n      } as cxschema.LoadBalancerContextQuery,\n      dummyValue: {\n        ipAddressType: cxapi.LoadBalancerIpAddressType.DUAL_STACK,\n        loadBalancerArn: `arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/${options.loadBalancerType}/my-load-balancer/50dc6c495c0c9188`,\n        loadBalancerCanonicalHostedZoneId: 'Z3DZXE0EXAMPLE',\n        loadBalancerDnsName: 'my-load-balancer-1234567890.us-west-2.elb.amazonaws.com',\n        securityGroupIds: ['sg-1234'],\n        vpcId: 'vpc-12345',\n      } as cxapi.LoadBalancerContextResponse,\n    }).value;\n\n    return props;\n  }\n\n                                                                                                                                  \n  public readonly loadBalancerCanonicalHostedZoneId: string;\n\n                                                                                                                                                          \n  public readonly loadBalancerDnsName: string;\n\n                                                                                                                                          \n  public readonly loadBalancerFullName: string;\n\n                                                                                                                \n  public readonly loadBalancerName: string;\n\n                                                                                                                                                                                                              \n  public readonly loadBalancerArn: string;\n\n                           \n  public readonly loadBalancerSecurityGroups: string[];\n\n                                                                                                                                                                             \n  public readonly vpc?: ec2.IVpc;\n\n  /**\n   * Attributes set on this load balancer\n   */\n  private readonly attributes: Attributes = {};\n\n  constructor(scope: Construct, id: string, baseProps: BaseLoadBalancerProps, additionalProps: any) {\n    super(scope, id, {\n      physicalName: baseProps.loadBalancerName,\n    });\n\n    const internetFacing = ifUndefined(baseProps.internetFacing, false);\n\n    const vpcSubnets = ifUndefined(baseProps.vpcSubnets,\n      (internetFacing ? { subnetType: ec2.SubnetType.PUBLIC } : {}) );\n    const { subnetIds, internetConnectivityEstablished } = baseProps.vpc.selectSubnets(vpcSubnets);\n\n    this.vpc = baseProps.vpc;\n\n    const resource = new CfnLoadBalancer(this, 'Resource', {\n      name: this.physicalName,\n      subnets: subnetIds,\n      scheme: internetFacing ? 'internet-facing' : 'internal',\n      loadBalancerAttributes: Lazy.any({ produce: () => renderAttributes(this.attributes) }, { omitEmptyArray: true } ),\n      ...additionalProps,\n    });\n    if (internetFacing) {\n      resource.node.addDependency(internetConnectivityEstablished);\n    }\n\n    this.setAttribute('deletion_protection.enabled', baseProps.deletionProtection ? 'true' : 'false');\n\n    this.loadBalancerCanonicalHostedZoneId = resource.attrCanonicalHostedZoneId;\n    this.loadBalancerDnsName = resource.attrDnsName;\n    this.loadBalancerFullName = resource.attrLoadBalancerFullName;\n    this.loadBalancerName = resource.attrLoadBalancerName;\n    this.loadBalancerArn = resource.ref;\n    this.loadBalancerSecurityGroups = resource.attrSecurityGroups;\n  }\n\n                                                                                                                                                                                                                                                                                \n  public logAccessLogs(bucket: s3.IBucket, prefix?: string) {\n    prefix = prefix || '';\n    this.setAttribute('access_logs.s3.enabled', 'true');\n    this.setAttribute('access_logs.s3.bucket', bucket.bucketName.toString());\n    this.setAttribute('access_logs.s3.prefix', prefix);\n\n    const region = Stack.of(this).region;\n    if (Token.isUnresolved(region)) {\n      throw new Error('Region is required to enable ELBv2 access logging');\n    }\n\n    const account = RegionInfo.get(region).elbv2Account;\n    if (!account) {\n      throw new Error(`Cannot enable access logging; don't know ELBv2 account for region ${region}`);\n    }\n\n    const logsDeliveryServicePrincipal = new ServicePrincipal('delivery.logs.amazonaws.com');\n    bucket.grantPut(new iam.AccountPrincipal(account), `${(prefix ? prefix + '/' : '')}AWSLogs/${Stack.of(this).account}/*`);\n    bucket.addToResourcePolicy(\n      new PolicyStatement({\n        actions: ['s3:PutObject'],\n        principals: [logsDeliveryServicePrincipal],\n        resources: [\n          bucket.arnForObjects(`${prefix ? prefix + '/' : ''}AWSLogs/${this.stack.account}/*`),\n        ],\n        conditions: {\n          StringEquals: { 's3:x-amz-acl': 'bucket-owner-full-control' },\n        },\n      }),\n    );\n    bucket.addToResourcePolicy(\n      new PolicyStatement({\n        actions: ['s3:GetBucketAcl'],\n        principals: [logsDeliveryServicePrincipal],\n        resources: [bucket.bucketArn],\n      }),\n    );\n\n    // make sure the bucket's policy is created before the ALB (see https://github.com/aws/aws-cdk/issues/1633)\n    this.node.addDependency(bucket);\n  }\n\n                                                                                                                                                                                                              \n  public setAttribute(key: string, value: string | undefined) {\n    this.attributes[key] = value;\n  }\n\n                                                           \n  public removeAttribute(key: string) {\n    this.setAttribute(key, undefined);\n  }\n}\n"]}
BaseLoadBalancer[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.BaseLoadBalancer", version: "1.145.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-load-balancer.js","sourceRoot":"","sources":["base-load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from '@aws-cdk/aws-ec2';\nimport * as iam from '@aws-cdk/aws-iam';\nimport { PolicyStatement, ServicePrincipal } from '@aws-cdk/aws-iam';\nimport * as s3 from '@aws-cdk/aws-s3';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { ContextProvider, IResource, Lazy, Resource, Stack, Token } from '@aws-cdk/core';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { RegionInfo } from '@aws-cdk/region-info';\nimport { Construct } from 'constructs';\nimport { CfnLoadBalancer } from '../elasticloadbalancingv2.generated';\nimport { Attributes, ifUndefined, mapTagMapToCxschema, renderAttributes } from './util';\n\n/**\n * Shared properties of both Application and Network Load Balancers\n */\nexport interface BaseLoadBalancerProps {\n  /**\n   * Name of the load balancer\n   *\n   * @default - Automatically generated name.\n   */\n  readonly loadBalancerName?: string;\n\n  /**\n   * The VPC network to place the load balancer in\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * Whether the load balancer has an internet-routable address\n   *\n   * @default false\n   */\n  readonly internetFacing?: boolean;\n\n  /**\n   * Which subnets place the load balancer in\n   *\n   * @default - the Vpc default strategy.\n   *\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * Indicates whether deletion protection is enabled.\n   *\n   * @default false\n   */\n  readonly deletionProtection?: boolean;\n}\n\nexport interface ILoadBalancerV2 extends IResource {\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * Example value: `Z2P70J7EXAMPLE`\n   *\n   * @attribute\n   */\n  readonly loadBalancerCanonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * Example value: `my-load-balancer-424835706.us-west-2.elb.amazonaws.com`\n   *\n   * @attribute\n   */\n  readonly loadBalancerDnsName: string;\n}\n\n/**\n * Options for looking up load balancers\n */\nexport interface BaseLoadBalancerLookupOptions {\n  /**\n   * Find by load balancer's ARN\n   * @default - does not search by load balancer arn\n   */\n  readonly loadBalancerArn?: string;\n\n  /**\n   * Match load balancer tags.\n   * @default - does not match load balancers by tags\n   */\n  readonly loadBalancerTags?: Record<string, string>;\n}\n\n/**\n * Options for query context provider\n * @internal\n */\nexport interface LoadBalancerQueryContextProviderOptions {\n  /**\n   * User's lookup options\n   */\n  readonly userOptions: BaseLoadBalancerLookupOptions;\n\n  /**\n   * Type of load balancer\n   */\n  readonly loadBalancerType: cxschema.LoadBalancerType;\n}\n\n/**\n * Base class for both Application and Network Load Balancers\n */\nexport abstract class BaseLoadBalancer extends Resource {\n  /**\n   * Queries the load balancer context provider for load balancer info.\n   * @internal\n   */\n  protected static _queryContextProvider(scope: Construct, options: LoadBalancerQueryContextProviderOptions) {\n    if (Token.isUnresolved(options.userOptions.loadBalancerArn)\n      || Object.values(options.userOptions.loadBalancerTags ?? {}).some(Token.isUnresolved)) {\n      throw new Error('All arguments to look up a load balancer must be concrete (no Tokens)');\n    }\n\n    let cxschemaTags: cxschema.Tag[] | undefined;\n    if (options.userOptions.loadBalancerTags) {\n      cxschemaTags = mapTagMapToCxschema(options.userOptions.loadBalancerTags);\n    }\n\n    const props: cxapi.LoadBalancerContextResponse = ContextProvider.getValue(scope, {\n      provider: cxschema.ContextProvider.LOAD_BALANCER_PROVIDER,\n      props: {\n        loadBalancerArn: options.userOptions.loadBalancerArn,\n        loadBalancerTags: cxschemaTags,\n        loadBalancerType: options.loadBalancerType,\n      } as cxschema.LoadBalancerContextQuery,\n      dummyValue: {\n        ipAddressType: cxapi.LoadBalancerIpAddressType.DUAL_STACK,\n        loadBalancerArn: `arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/${options.loadBalancerType}/my-load-balancer/50dc6c495c0c9188`,\n        loadBalancerCanonicalHostedZoneId: 'Z3DZXE0EXAMPLE',\n        loadBalancerDnsName: 'my-load-balancer-1234567890.us-west-2.elb.amazonaws.com',\n        securityGroupIds: ['sg-1234'],\n        vpcId: 'vpc-12345',\n      } as cxapi.LoadBalancerContextResponse,\n    }).value;\n\n    return props;\n  }\n\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * Example value: `Z2P70J7EXAMPLE`\n   *\n   * @attribute\n   */\n  public readonly loadBalancerCanonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * Example value: `my-load-balancer-424835706.us-west-2.elb.amazonaws.com`\n   *\n   * @attribute\n   */\n  public readonly loadBalancerDnsName: string;\n\n  /**\n   * The full name of this load balancer\n   *\n   * Example value: `app/my-load-balancer/50dc6c495c0c9188`\n   *\n   * @attribute\n   */\n  public readonly loadBalancerFullName: string;\n\n  /**\n   * The name of this load balancer\n   *\n   * Example value: `my-load-balancer`\n   *\n   * @attribute\n   */\n  public readonly loadBalancerName: string;\n\n  /**\n   * The ARN of this load balancer\n   *\n   * Example value: `arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-internal-load-balancer/50dc6c495c0c9188`\n   *\n   * @attribute\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * @attribute\n   */\n  public readonly loadBalancerSecurityGroups: string[];\n\n  /**\n   * The VPC this load balancer has been created in.\n   *\n   * This property is always defined (not `null` or `undefined`) for sub-classes of `BaseLoadBalancer`.\n   */\n  public readonly vpc?: ec2.IVpc;\n\n  /**\n   * Attributes set on this load balancer\n   */\n  private readonly attributes: Attributes = {};\n\n  constructor(scope: Construct, id: string, baseProps: BaseLoadBalancerProps, additionalProps: any) {\n    super(scope, id, {\n      physicalName: baseProps.loadBalancerName,\n    });\n\n    const internetFacing = ifUndefined(baseProps.internetFacing, false);\n\n    const vpcSubnets = ifUndefined(baseProps.vpcSubnets,\n      (internetFacing ? { subnetType: ec2.SubnetType.PUBLIC } : {}) );\n    const { subnetIds, internetConnectivityEstablished } = baseProps.vpc.selectSubnets(vpcSubnets);\n\n    this.vpc = baseProps.vpc;\n\n    const resource = new CfnLoadBalancer(this, 'Resource', {\n      name: this.physicalName,\n      subnets: subnetIds,\n      scheme: internetFacing ? 'internet-facing' : 'internal',\n      loadBalancerAttributes: Lazy.any({ produce: () => renderAttributes(this.attributes) }, { omitEmptyArray: true } ),\n      ...additionalProps,\n    });\n    if (internetFacing) {\n      resource.node.addDependency(internetConnectivityEstablished);\n    }\n\n    this.setAttribute('deletion_protection.enabled', baseProps.deletionProtection ? 'true' : 'false');\n\n    this.loadBalancerCanonicalHostedZoneId = resource.attrCanonicalHostedZoneId;\n    this.loadBalancerDnsName = resource.attrDnsName;\n    this.loadBalancerFullName = resource.attrLoadBalancerFullName;\n    this.loadBalancerName = resource.attrLoadBalancerName;\n    this.loadBalancerArn = resource.ref;\n    this.loadBalancerSecurityGroups = resource.attrSecurityGroups;\n  }\n\n  /**\n   * Enable access logging for this load balancer.\n   *\n   * A region must be specified on the stack containing the load balancer; you cannot enable logging on\n   * environment-agnostic stacks. See https://docs.aws.amazon.com/cdk/latest/guide/environments.html\n   */\n  public logAccessLogs(bucket: s3.IBucket, prefix?: string) {\n    prefix = prefix || '';\n    this.setAttribute('access_logs.s3.enabled', 'true');\n    this.setAttribute('access_logs.s3.bucket', bucket.bucketName.toString());\n    this.setAttribute('access_logs.s3.prefix', prefix);\n\n    const region = Stack.of(this).region;\n    if (Token.isUnresolved(region)) {\n      throw new Error('Region is required to enable ELBv2 access logging');\n    }\n\n    const account = RegionInfo.get(region).elbv2Account;\n    if (!account) {\n      throw new Error(`Cannot enable access logging; don't know ELBv2 account for region ${region}`);\n    }\n\n    const logsDeliveryServicePrincipal = new ServicePrincipal('delivery.logs.amazonaws.com');\n    bucket.grantPut(new iam.AccountPrincipal(account), `${(prefix ? prefix + '/' : '')}AWSLogs/${Stack.of(this).account}/*`);\n    bucket.addToResourcePolicy(\n      new PolicyStatement({\n        actions: ['s3:PutObject'],\n        principals: [logsDeliveryServicePrincipal],\n        resources: [\n          bucket.arnForObjects(`${prefix ? prefix + '/' : ''}AWSLogs/${this.stack.account}/*`),\n        ],\n        conditions: {\n          StringEquals: { 's3:x-amz-acl': 'bucket-owner-full-control' },\n        },\n      }),\n    );\n    bucket.addToResourcePolicy(\n      new PolicyStatement({\n        actions: ['s3:GetBucketAcl'],\n        principals: [logsDeliveryServicePrincipal],\n        resources: [bucket.bucketArn],\n      }),\n    );\n\n    // make sure the bucket's policy is created before the ALB (see https://github.com/aws/aws-cdk/issues/1633)\n    this.node.addDependency(bucket);\n  }\n\n  /**\n   * Set a non-standard attribute on the load balancer\n   *\n   * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/application-load-balancers.html#load-balancer-attributes\n   */\n  public setAttribute(key: string, value: string | undefined) {\n    this.attributes[key] = value;\n  }\n\n  /**\n   * Remove an attribute from the load balancer\n   */\n  public removeAttribute(key: string) {\n    this.setAttribute(key, undefined);\n  }\n}\n"]}

@@ -7,5 +7,3 @@ import * as ec2 from '@aws-cdk/aws-ec2';

/**
* Basic properties of both Application and Network Target Groups.
*
* @stability stable
* Basic properties of both Application and Network Target Groups
*/

@@ -21,3 +19,2 @@ export interface BaseTargetGroupProps {

* @default - Automatically generated.
* @stability stable
*/

@@ -31,3 +28,2 @@ readonly targetGroupName?: string;

* @default - undefined
* @stability stable
*/

@@ -41,10 +37,8 @@ readonly vpc?: ec2.IVpc;

* @default 300
* @stability stable
*/
readonly deregistrationDelay?: cdk.Duration;
/**
* Health check configuration.
* Health check configuration
*
* @default - None.
* @stability stable
*/

@@ -60,3 +54,2 @@ readonly healthCheck?: HealthCheck;

* @default - Determined automatically.
* @stability stable
*/

@@ -66,11 +59,7 @@ readonly targetType?: TargetType;

/**
* Properties for configuring a health check.
*
* @stability stable
* Properties for configuring a health check
*/
export interface HealthCheck {
/**
* Indicates whether health checks are enabled.
*
* If the target type is lambda,
* Indicates whether health checks are enabled. If the target type is lambda,
* health checks are disabled by default but can be enabled. If the target type

@@ -80,3 +69,2 @@ * is instance or ip, health checks are always enabled and cannot be disabled.

* @default - Determined automatically.
* @stability stable
*/

@@ -88,3 +76,2 @@ readonly enabled?: boolean;

* @default Duration.seconds(30)
* @stability stable
*/

@@ -96,3 +83,2 @@ readonly interval?: cdk.Duration;

* @default /
* @stability stable
*/

@@ -104,3 +90,2 @@ readonly path?: string;

* @default 'traffic-port'
* @stability stable
*/

@@ -115,3 +100,2 @@ readonly port?: string;

* @default HTTP for ALBs, TCP for NLBs
* @stability stable
*/

@@ -127,3 +111,2 @@ readonly protocol?: Protocol;

* @default Duration.seconds(5) for ALBs, Duration.seconds(10) or Duration.seconds(6) for NLBs
* @stability stable
*/

@@ -137,3 +120,2 @@ readonly timeout?: cdk.Duration;

* @default 5 for ALBs, 3 for NLBs
* @stability stable
*/

@@ -148,3 +130,2 @@ readonly healthyThresholdCount?: number;

* @default 2
* @stability stable
*/

@@ -159,3 +140,2 @@ readonly unhealthyThresholdCount?: number;

* @default - 12
* @stability stable
*/

@@ -169,4 +149,2 @@ readonly healthyGrpcCodes?: string;

* example, "200,202") or a range of values (for example, "200-299").
*
* @stability stable
*/

@@ -176,33 +154,23 @@ readonly healthyHttpCodes?: string;

/**
* Define the target of a load balancer.
*
* @stability stable
* Define the target of a load balancer
*/
export declare abstract class TargetGroupBase extends CoreConstruct implements ITargetGroup {
/**
* The ARN of the target group.
*
* @stability stable
* The ARN of the target group
*/
readonly targetGroupArn: string;
/**
* The full name of the target group.
*
* @stability stable
* The full name of the target group
*/
readonly targetGroupFullName: string;
/**
* The name of the target group.
*
* @stability stable
* The name of the target group
*/
readonly targetGroupName: string;
/**
* ARNs of load balancers load balancing to this TargetGroup.
*
* @stability stable
* ARNs of load balancers load balancing to this TargetGroup
*/
readonly targetGroupLoadBalancerArns: string[];
/**
* Full name of first load balancer.
* Full name of first load balancer
*

@@ -213,32 +181,22 @@ * This identifier is emitted as a dimensions of the metrics of this target

* Example value: `app/my-load-balancer/123456789`
*
* @stability stable
*/
abstract readonly firstLoadBalancerFullName: string;
/**
* A token representing a list of ARNs of the load balancers that route traffic to this target group.
*
* @stability stable
* Health check for the members of this target group
*/
readonly loadBalancerArns: string;
/**
* @stability stable
* A token representing a list of ARNs of the load balancers that route traffic to this target group
*/
readonly loadBalancerArns: string;
healthCheck: HealthCheck;
/**
* Default port configured for members of this target group.
*
* @stability stable
* Default port configured for members of this target group
*/
protected readonly defaultPort: number;
/**
* Configurable dependable with all resources that lead to load balancer attachment.
*
* @stability stable
* Configurable dependable with all resources that lead to load balancer attachment
*/
protected readonly loadBalancerAttachedDependencies: cdk.ConcreteDependable;
/**
* The types of the directly registered members of this target group.
*
* @stability stable
* The types of the directly registered members of this target group
*/

@@ -264,55 +222,33 @@ protected targetType?: TargetType;

private readonly resource;
/**
* @stability stable
*/
constructor(scope: Construct, id: string, baseProps: BaseTargetGroupProps, additionalProps: any);
/**
* List of constructs that need to be depended on to ensure the TargetGroup is associated to a load balancer.
*
* @stability stable
* List of constructs that need to be depended on to ensure the TargetGroup is associated to a load balancer
*/
get loadBalancerAttached(): cdk.IDependable;
/**
* Set/replace the target group's health check.
*
* @stability stable
* Set/replace the target group's health check
*/
configureHealthCheck(healthCheck: HealthCheck): void;
/**
* Set a non-standard attribute on the target group.
* Set a non-standard attribute on the target group
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-target-groups.html#target-group-attributes
* @stability stable
*/
setAttribute(key: string, value: string | undefined): void;
/**
* Register the given load balancing target as part of this group.
*
* @stability stable
* Register the given load balancing target as part of this group
*/
protected addLoadBalancerTarget(props: LoadBalancerTargetProps): void;
/**
* Validate the current construct.
*
* This method can be implemented by derived constructs in order to perform
* validation logic. It is called on all constructs before synthesis.
*
* @stability stable
*/
protected validate(): string[];
}
/**
* Properties to reference an existing target group.
*
* @stability stable
* Properties to reference an existing target group
*/
export interface TargetGroupAttributes {
/**
* ARN of the target group.
*
* @stability stable
* ARN of the target group
*/
readonly targetGroupArn: string;
/**
* (deprecated) Port target group is listening on.
* Port target group is listening on
*

@@ -323,5 +259,3 @@ * @deprecated - This property is unused and the wrong type. No need to use it.

/**
* A Token representing the list of ARNs for the load balancer routing to this target group.
*
* @stability stable
* A Token representing the list of ARNs for the load balancer routing to this target group
*/

@@ -331,3 +265,3 @@ readonly loadBalancerArns?: string;

/**
* (deprecated) Properties to reference an existing target group.
* Properties to reference an existing target group
*

@@ -339,29 +273,19 @@ * @deprecated Use TargetGroupAttributes instead

/**
* A target group.
*
* @stability stable
* A target group
*/
export interface ITargetGroup extends cdk.IConstruct {
/**
* The name of the target group.
*
* @stability stable
* The name of the target group
*/
readonly targetGroupName: string;
/**
* ARN of the target group.
*
* @stability stable
* ARN of the target group
*/
readonly targetGroupArn: string;
/**
* A token representing a list of ARNs of the load balancers that route traffic to this target group.
*
* @stability stable
* A token representing a list of ARNs of the load balancers that route traffic to this target group
*/
readonly loadBalancerArns: string;
/**
* Return an object to depend on the listeners added to this target group.
*
* @stability stable
* Return an object to depend on the listeners added to this target group
*/

@@ -371,19 +295,13 @@ readonly loadBalancerAttached: cdk.IDependable;

/**
* Result of attaching a target to load balancer.
*
* @stability stable
* Result of attaching a target to load balancer
*/
export interface LoadBalancerTargetProps {
/**
* What kind of target this is.
*
* @stability stable
* What kind of target this is
*/
readonly targetType: TargetType;
/**
* JSON representing the target's direct addition to the TargetGroup list.
* JSON representing the target's direct addition to the TargetGroup list
*
* May be omitted if the target is going to register itself later.
*
* @stability stable
*/

@@ -390,0 +308,0 @@ readonly targetJson?: any;

@@ -15,16 +15,9 @@ "use strict";

/**
* Define the target of a load balancer.
*
* @stability stable
* Define the target of a load balancer
*/
class TargetGroupBase extends core_1.Construct {
/**
* @stability stable
*/
constructor(scope, id, baseProps, additionalProps) {
super(scope, id);
/**
* Configurable dependable with all resources that lead to load balancer attachment.
*
* @stability stable
* Configurable dependable with all resources that lead to load balancer attachment
*/

@@ -85,5 +78,3 @@ this.loadBalancerAttachedDependencies = new cdk.ConcreteDependable();

/**
* List of constructs that need to be depended on to ensure the TargetGroup is associated to a load balancer.
*
* @stability stable
* List of constructs that need to be depended on to ensure the TargetGroup is associated to a load balancer
*/

@@ -94,5 +85,3 @@ get loadBalancerAttached() {

/**
* Set/replace the target group's health check.
*
* @stability stable
* Set/replace the target group's health check
*/

@@ -104,6 +93,5 @@ configureHealthCheck(healthCheck) {

/**
* Set a non-standard attribute on the target group.
* Set a non-standard attribute on the target group
*
* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-target-groups.html#target-group-attributes
* @stability stable
*/

@@ -114,5 +102,3 @@ setAttribute(key, value) {

/**
* Register the given load balancing target as part of this group.
*
* @stability stable
* Register the given load balancing target as part of this group
*/

@@ -132,10 +118,2 @@ addLoadBalancerTarget(props) {

}
/**
* Validate the current construct.
*
* This method can be implemented by derived constructs in order to perform
* validation logic. It is called on all constructs before synthesis.
*
* @stability stable
*/
validate() {

@@ -154,3 +132,3 @@ const ret = super.validate();

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

@@ -172,2 +150,2 @@ * Extract the full load balancer name (used for metrics) from the listener ARN:

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

@@ -21,41 +15,27 @@ DUAL_STACK = "dualstack"

/**
* Backend protocol for network load balancers and health checks.
*
* @stability stable
* Backend protocol for network load balancers and health checks
*/
export declare enum Protocol {
/**
* HTTP (ALB health checks and NLB health checks).
*
* @stability stable
* HTTP (ALB health checks and NLB health checks)
*/
HTTP = "HTTP",
/**
* HTTPS (ALB health checks and NLB health checks).
*
* @stability stable
* HTTPS (ALB health checks and NLB health checks)
*/
HTTPS = "HTTPS",
/**
* TCP (NLB, NLB health checks).
*
* @stability stable
* TCP (NLB, NLB health checks)
*/
TCP = "TCP",
/**
* TLS (NLB).
*
* @stability stable
* TLS (NLB)
*/
TLS = "TLS",
/**
* UDP (NLB).
*
* @stability stable
* UDP (NLB)
*/
UDP = "UDP",
/**
* Listen to both TCP and UDP on the same port (NLB).
*
* @stability stable
* Listen to both TCP and UDP on the same port (NLB)
*/

@@ -65,17 +45,11 @@ TCP_UDP = "TCP_UDP"

/**
* Load balancing protocol for application load balancers.
*
* @stability stable
* Load balancing protocol for application load balancers
*/
export declare enum ApplicationProtocol {
/**
* HTTP.
*
* @stability stable
* HTTP
*/
HTTP = "HTTP",
/**
* HTTPS.
*
* @stability stable
* HTTPS
*/

@@ -85,23 +59,15 @@ HTTPS = "HTTPS"

/**
* Load balancing protocol version for application load balancers.
*
* @stability stable
* Load balancing protocol version for application load balancers
*/
export declare enum ApplicationProtocolVersion {
/**
* GRPC.
*
* @stability stable
* GRPC
*/
GRPC = "GRPC",
/**
* HTTP1.
*
* @stability stable
* HTTP1
*/
HTTP1 = "HTTP1",
/**
* HTTP2.
*
* @stability stable
* HTTP2
*/

@@ -111,3 +77,3 @@ HTTP2 = "HTTP2"

/**
* Elastic Load Balancing provides the following security policies for Application Load Balancers.
* Elastic Load Balancing provides the following security policies for Application Load Balancers
*

@@ -123,66 +89,46 @@ * We recommend the Recommended policy for general use. You can

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/create-https-listener.html
* @stability stable
*/
export declare enum SslPolicy {
/**
* The recommended security policy.
*
* @stability stable
* The recommended security policy
*/
RECOMMENDED = "ELBSecurityPolicy-2016-08",
/**
* Strong foward secrecy ciphers and TLV1.2 only (2020 edition). Same as FORWARD_SECRECY_TLS12_RES, but only supports GCM versions of the TLS ciphers.
*
* @stability stable
* Strong foward secrecy ciphers and TLV1.2 only (2020 edition).
* Same as FORWARD_SECRECY_TLS12_RES, but only supports GCM versions of the TLS ciphers
*/
FORWARD_SECRECY_TLS12_RES_GCM = "ELBSecurityPolicy-FS-1-2-Res-2020-10",
/**
* Strong forward secrecy ciphers and TLS1.2 only.
*
* @stability stable
* Strong forward secrecy ciphers and TLS1.2 only
*/
FORWARD_SECRECY_TLS12_RES = "ELBSecurityPolicy-FS-1-2-Res-2019-08",
/**
* Forward secrecy ciphers and TLS1.2 only.
*
* @stability stable
* Forward secrecy ciphers and TLS1.2 only
*/
FORWARD_SECRECY_TLS12 = "ELBSecurityPolicy-FS-1-2-2019-08",
/**
* Forward secrecy ciphers only with TLS1.1 and higher.
*
* @stability stable
* Forward secrecy ciphers only with TLS1.1 and higher
*/
FORWARD_SECRECY_TLS11 = "ELBSecurityPolicy-FS-1-1-2019-08",
/**
* Forward secrecy ciphers only.
*
* @stability stable
* Forward secrecy ciphers only
*/
FORWARD_SECRECY = "ELBSecurityPolicy-FS-2018-06",
/**
* TLS1.2 only and no SHA ciphers.
*
* @stability stable
* TLS1.2 only and no SHA ciphers
*/
TLS12 = "ELBSecurityPolicy-TLS-1-2-2017-01",
/**
* TLS1.2 only with all ciphers.
*
* @stability stable
* TLS1.2 only with all ciphers
*/
TLS12_EXT = "ELBSecurityPolicy-TLS-1-2-Ext-2018-06",
/**
* TLS1.1 and higher with all ciphers.
*
* @stability stable
* TLS1.1 and higher with all ciphers
*/
TLS11 = "ELBSecurityPolicy-TLS-1-1-2017-01",
/**
* Support for DES-CBC3-SHA.
* Support for DES-CBC3-SHA
*
* Do not use this security policy unless you must support a legacy client
* that requires the DES-CBC3-SHA cipher, which is a weak cipher.
*
* @stability stable
*/

@@ -192,29 +138,19 @@ LEGACY = "ELBSecurityPolicy-TLS-1-0-2015-04"

/**
* How to interpret the load balancing target identifiers.
*
* @stability stable
* How to interpret the load balancing target identifiers
*/
export declare enum TargetType {
/**
* Targets identified by instance ID.
*
* @stability stable
* Targets identified by instance ID
*/
INSTANCE = "instance",
/**
* Targets identified by IP address.
*
* @stability stable
* Targets identified by IP address
*/
IP = "ip",
/**
* Target is a single Lambda Function.
*
* @stability stable
* Target is a single Lambda Function
*/
LAMBDA = "lambda",
/**
* Target is a single Application Load Balancer.
*
* @stability stable
* Target is a single Application Load Balancer
*/

@@ -225,38 +161,23 @@ ALB = "alb"

* Application-Layer Protocol Negotiation Policies for network load balancers.
*
* Which protocols should be used over a secure connection.
*
* @stability stable
*/
export declare enum AlpnPolicy {
/**
* Negotiate only HTTP/1.*. The ALPN preference list is http/1.1, http/1.0.
*
* @stability stable
* Negotiate only HTTP/1.*. The ALPN preference list is http/1.1, http/1.0
*/
HTTP1_ONLY = "HTTP1Only",
/**
* Negotiate only HTTP/2.
*
* The ALPN preference list is h2
*
* @stability stable
* Negotiate only HTTP/2. The ALPN preference list is h2
*/
HTTP2_ONLY = "HTTP2Only",
/**
* Prefer HTTP/1.* over HTTP/2 (which can be useful for HTTP/2 testing). The ALPN preference list is http/1.1, http/1.0, h2.
*
* @stability stable
* Prefer HTTP/1.* over HTTP/2 (which can be useful for HTTP/2 testing). The ALPN preference list is http/1.1, http/1.0, h2
*/
HTTP2_OPTIONAL = "HTTP2Optional",
/**
* Prefer HTTP/2 over HTTP/1.*. The ALPN preference list is h2, http/1.1, http/1.0.
*
* @stability stable
* Prefer HTTP/2 over HTTP/1.*. The ALPN preference list is h2, http/1.1, http/1.0
*/
HTTP2_PREFERRED = "HTTP2Preferred",
/**
* Do not negotiate ALPN.
*
* @stability stable
* Do not negotiate ALPN
*/

@@ -266,19 +187,13 @@ NONE = "None"

/**
* Load balancing algorithmm type for target groups.
*
* @stability stable
* Load balancing algorithmm type for target groups
*/
export declare enum TargetGroupLoadBalancingAlgorithmType {
/**
* round_robin.
*
* @stability stable
* round_robin
*/
ROUND_ROBIN = "round_robin",
/**
* least_outstanding_requests.
*
* @stability stable
* least_outstanding_requests
*/
LEAST_OUTSTANDING_REQUESTS = "least_outstanding_requests"
}

@@ -5,48 +5,79 @@ "use strict";

/**
* What kind of addresses to allocate to the load balancer.
*
* @stability stable
* What kind of addresses to allocate to the load balancer
*/
var IpAddressType;
(function (IpAddressType) {
/**
* Allocate IPv4 addresses
*/
IpAddressType["IPV4"] = "ipv4";
/**
* Allocate both IPv4 and IPv6 addresses
*/
IpAddressType["DUAL_STACK"] = "dualstack";
})(IpAddressType = exports.IpAddressType || (exports.IpAddressType = {}));
/**
* Backend protocol for network load balancers and health checks.
*
* @stability stable
* Backend protocol for network load balancers and health checks
*/
var Protocol;
(function (Protocol) {
/**
* HTTP (ALB health checks and NLB health checks)
*/
Protocol["HTTP"] = "HTTP";
/**
* HTTPS (ALB health checks and NLB health checks)
*/
Protocol["HTTPS"] = "HTTPS";
/**
* TCP (NLB, NLB health checks)
*/
Protocol["TCP"] = "TCP";
/**
* TLS (NLB)
*/
Protocol["TLS"] = "TLS";
/**
* UDP (NLB)
*/
Protocol["UDP"] = "UDP";
/**
* Listen to both TCP and UDP on the same port (NLB)
*/
Protocol["TCP_UDP"] = "TCP_UDP";
})(Protocol = exports.Protocol || (exports.Protocol = {}));
/**
* Load balancing protocol for application load balancers.
*
* @stability stable
* Load balancing protocol for application load balancers
*/
var ApplicationProtocol;
(function (ApplicationProtocol) {
/**
* HTTP
*/
ApplicationProtocol["HTTP"] = "HTTP";
/**
* HTTPS
*/
ApplicationProtocol["HTTPS"] = "HTTPS";
})(ApplicationProtocol = exports.ApplicationProtocol || (exports.ApplicationProtocol = {}));
/**
* Load balancing protocol version for application load balancers.
*
* @stability stable
* Load balancing protocol version for application load balancers
*/
var ApplicationProtocolVersion;
(function (ApplicationProtocolVersion) {
/**
* GRPC
*/
ApplicationProtocolVersion["GRPC"] = "GRPC";
/**
* HTTP1
*/
ApplicationProtocolVersion["HTTP1"] = "HTTP1";
/**
* HTTP2
*/
ApplicationProtocolVersion["HTTP2"] = "HTTP2";
})(ApplicationProtocolVersion = exports.ApplicationProtocolVersion || (exports.ApplicationProtocolVersion = {}));
/**
* Elastic Load Balancing provides the following security policies for Application Load Balancers.
* Elastic Load Balancing provides the following security policies for Application Load Balancers
*

@@ -62,27 +93,70 @@ * We recommend the Recommended policy for general use. You can

* @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/create-https-listener.html
* @stability stable
*/
var SslPolicy;
(function (SslPolicy) {
/**
* The recommended security policy
*/
SslPolicy["RECOMMENDED"] = "ELBSecurityPolicy-2016-08";
/**
* Strong foward secrecy ciphers and TLV1.2 only (2020 edition).
* Same as FORWARD_SECRECY_TLS12_RES, but only supports GCM versions of the TLS ciphers
*/
SslPolicy["FORWARD_SECRECY_TLS12_RES_GCM"] = "ELBSecurityPolicy-FS-1-2-Res-2020-10";
/**
* Strong forward secrecy ciphers and TLS1.2 only
*/
SslPolicy["FORWARD_SECRECY_TLS12_RES"] = "ELBSecurityPolicy-FS-1-2-Res-2019-08";
/**
* Forward secrecy ciphers and TLS1.2 only
*/
SslPolicy["FORWARD_SECRECY_TLS12"] = "ELBSecurityPolicy-FS-1-2-2019-08";
/**
* Forward secrecy ciphers only with TLS1.1 and higher
*/
SslPolicy["FORWARD_SECRECY_TLS11"] = "ELBSecurityPolicy-FS-1-1-2019-08";
/**
* Forward secrecy ciphers only
*/
SslPolicy["FORWARD_SECRECY"] = "ELBSecurityPolicy-FS-2018-06";
/**
* TLS1.2 only and no SHA ciphers
*/
SslPolicy["TLS12"] = "ELBSecurityPolicy-TLS-1-2-2017-01";
/**
* TLS1.2 only with all ciphers
*/
SslPolicy["TLS12_EXT"] = "ELBSecurityPolicy-TLS-1-2-Ext-2018-06";
/**
* TLS1.1 and higher with all ciphers
*/
SslPolicy["TLS11"] = "ELBSecurityPolicy-TLS-1-1-2017-01";
/**
* Support for DES-CBC3-SHA
*
* Do not use this security policy unless you must support a legacy client
* that requires the DES-CBC3-SHA cipher, which is a weak cipher.
*/
SslPolicy["LEGACY"] = "ELBSecurityPolicy-TLS-1-0-2015-04";
})(SslPolicy = exports.SslPolicy || (exports.SslPolicy = {}));
/**
* How to interpret the load balancing target identifiers.
*
* @stability stable
* How to interpret the load balancing target identifiers
*/
var TargetType;
(function (TargetType) {
/**
* Targets identified by instance ID
*/
TargetType["INSTANCE"] = "instance";
/**
* Targets identified by IP address
*/
TargetType["IP"] = "ip";
/**
* Target is a single Lambda Function
*/
TargetType["LAMBDA"] = "lambda";
/**
* Target is a single Application Load Balancer
*/
TargetType["ALB"] = "alb";

@@ -92,25 +166,41 @@ })(TargetType = exports.TargetType || (exports.TargetType = {}));

* Application-Layer Protocol Negotiation Policies for network load balancers.
*
* Which protocols should be used over a secure connection.
*
* @stability stable
*/
var AlpnPolicy;
(function (AlpnPolicy) {
/**
* Negotiate only HTTP/1.*. The ALPN preference list is http/1.1, http/1.0
*/
AlpnPolicy["HTTP1_ONLY"] = "HTTP1Only";
/**
* Negotiate only HTTP/2. The ALPN preference list is h2
*/
AlpnPolicy["HTTP2_ONLY"] = "HTTP2Only";
/**
* Prefer HTTP/1.* over HTTP/2 (which can be useful for HTTP/2 testing). The ALPN preference list is http/1.1, http/1.0, h2
*/
AlpnPolicy["HTTP2_OPTIONAL"] = "HTTP2Optional";
/**
* Prefer HTTP/2 over HTTP/1.*. The ALPN preference list is h2, http/1.1, http/1.0
*/
AlpnPolicy["HTTP2_PREFERRED"] = "HTTP2Preferred";
/**
* Do not negotiate ALPN
*/
AlpnPolicy["NONE"] = "None";
})(AlpnPolicy = exports.AlpnPolicy || (exports.AlpnPolicy = {}));
/**
* Load balancing algorithmm type for target groups.
*
* @stability stable
* Load balancing algorithmm type for target groups
*/
var TargetGroupLoadBalancingAlgorithmType;
(function (TargetGroupLoadBalancingAlgorithmType) {
/**
* round_robin
*/
TargetGroupLoadBalancingAlgorithmType["ROUND_ROBIN"] = "round_robin";
/**
* least_outstanding_requests
*/
TargetGroupLoadBalancingAlgorithmType["LEAST_OUTSTANDING_REQUESTS"] = "least_outstanding_requests";
})(TargetGroupLoadBalancingAlgorithmType = exports.TargetGroupLoadBalancingAlgorithmType || (exports.TargetGroupLoadBalancingAlgorithmType = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enums.js","sourceRoot":"","sources":["enums.ts"],"names":[],"mappings":";;;;;;;;AACA,IAAY,aAMX;AAND,WAAY,aAAa;IAEvB,8BAAa,CAAA;IAGb,yCAAwB,CAAA;AAC1B,CAAC,EANW,aAAa,GAAb,qBAAa,KAAb,qBAAa,QAMxB;;;;;;AAGD,IAAY,QAkBX;AAlBD,WAAY,QAAQ;IAElB,yBAAa,CAAA;IAGb,2BAAe,CAAA;IAGf,uBAAW,CAAA;IAGX,uBAAW,CAAA;IAGX,uBAAW,CAAA;IAGX,+BAAmB,CAAA;AACrB,CAAC,EAlBW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAkBnB;;;;;;AAGD,IAAY,mBAMX;AAND,WAAY,mBAAmB;IAE7B,oCAAa,CAAA;IAGb,sCAAe,CAAA;AACjB,CAAC,EANW,mBAAmB,GAAnB,2BAAmB,KAAnB,2BAAmB,QAM9B;;;;;;AAGD,IAAY,0BASX;AATD,WAAY,0BAA0B;IAEpC,2CAAa,CAAA;IAGb,6CAAe,CAAA;IAGf,6CAAe,CAAA;AACjB,CAAC,EATW,0BAA0B,GAA1B,kCAA0B,KAA1B,kCAA0B,QASrC;;;;;;;;;;;;;;;AAGD,IAAY,SA8BX;AA9BD,WAAY,SAAS;IAEnB,sDAAyC,CAAA;IAGzC,mFAAsE,CAAA;IAGtE,+EAAkE,CAAA;IAGlE,uEAA0D,CAAA;IAG1D,uEAA0D,CAAA;IAG1D,6DAAgD,CAAA;IAGhD,wDAA2C,CAAA;IAG3C,gEAAmD,CAAA;IAGnD,wDAA2C,CAAA;IAG3C,yDAA4C,CAAA;AAC9C,CAAC,EA9BW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QA8BpB;;;;;;AAGD,IAAY,UAYX;AAZD,WAAY,UAAU;IAEpB,mCAAqB,CAAA;IAGrB,uBAAS,CAAA;IAGT,+BAAiB,CAAA;IAGjB,yBAAW,CAAA;AACb,CAAC,EAZW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAYrB;;;;;;;;AAGD,IAAY,UAeX;AAfD,WAAY,UAAU;IAEpB,sCAAwB,CAAA;IAGxB,sCAAwB,CAAA;IAGxB,8CAAgC,CAAA;IAGhC,gDAAkC,CAAA;IAGlC,2BAAa,CAAA;AACf,CAAC,EAfW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAerB;;;;;;AAGD,IAAY,qCAMX;AAND,WAAY,qCAAqC;IAE/C,oEAA2B,CAAA;IAG3B,kGAAyD,CAAA;AAC3D,CAAC,EANW,qCAAqC,GAArC,6CAAqC,KAArC,6CAAqC,QAMhD","sourcesContent":["                                                                  \nexport enum IpAddressType {\n                                        \n  IPV4 = 'ipv4',\n\n                                                      \n  DUAL_STACK = 'dualstack',\n}\n\n                                                                        \nexport enum Protocol {\n                                                               \n  HTTP = 'HTTP',\n\n                                                                \n  HTTPS = 'HTTPS',\n\n                                             \n  TCP = 'TCP',\n\n                          \n  TLS = 'TLS',\n\n                          \n  UDP = 'UDP',\n\n                                                                  \n  TCP_UDP = 'TCP_UDP',\n}\n\n                                                                 \nexport enum ApplicationProtocol {\n                     \n  HTTP = 'HTTP',\n\n                      \n  HTTPS = 'HTTPS',\n}\n\n                                                                         \nexport enum ApplicationProtocolVersion {\n                     \n  GRPC = 'GRPC',\n\n                      \n  HTTP1 = 'HTTP1',\n\n                      \n  HTTP2 = 'HTTP2',\n}\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             \nexport enum SslPolicy {\n                                                \n  RECOMMENDED = 'ELBSecurityPolicy-2016-08',\n\n                                                                                                                                                                        \n  FORWARD_SECRECY_TLS12_RES_GCM = 'ELBSecurityPolicy-FS-1-2-Res-2020-10',\n\n                                                               \n  FORWARD_SECRECY_TLS12_RES = 'ELBSecurityPolicy-FS-1-2-Res-2019-08',\n\n                                                        \n  FORWARD_SECRECY_TLS12 = 'ELBSecurityPolicy-FS-1-2-2019-08',\n\n                                                                    \n  FORWARD_SECRECY_TLS11 = 'ELBSecurityPolicy-FS-1-1-2019-08',\n\n                                             \n  FORWARD_SECRECY = 'ELBSecurityPolicy-FS-2018-06',\n\n                                               \n  TLS12 = 'ELBSecurityPolicy-TLS-1-2-2017-01',\n\n                                             \n  TLS12_EXT = 'ELBSecurityPolicy-TLS-1-2-Ext-2018-06',\n\n                                                   \n  TLS11 = 'ELBSecurityPolicy-TLS-1-1-2017-01',\n\n                                                                                                                                                                                               \n  LEGACY = 'ELBSecurityPolicy-TLS-1-0-2015-04',\n}\n\n                                                                 \nexport enum TargetType {\n                                                  \n  INSTANCE = 'instance',\n\n                                                 \n  IP = 'ip',\n\n                                                   \n  LAMBDA = 'lambda',\n\n                                                             \n  ALB = 'alb',\n}\n\n                                                                                                                                                  \nexport enum AlpnPolicy {\n                                                                                        \n  HTTP1_ONLY = 'HTTP1Only',\n\n                                                                      \n  HTTP2_ONLY = 'HTTP2Only',\n\n                                                                                                                                         \n  HTTP2_OPTIONAL = 'HTTP2Optional',\n\n                                                                                                \n  HTTP2_PREFERRED = 'HTTP2Preferred',\n\n                                      \n  NONE = 'None',\n}\n\n                                                           \nexport enum TargetGroupLoadBalancingAlgorithmType {\n                            \n  ROUND_ROBIN = 'round_robin',\n\n                                           \n  LEAST_OUTSTANDING_REQUESTS = 'least_outstanding_requests',\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enums.js","sourceRoot":"","sources":["enums.ts"],"names":[],"mappings":";;;AAAA;;GAEG;AACH,IAAY,aAUX;AAVD,WAAY,aAAa;IACvB;;OAEG;IACH,8BAAa,CAAA;IAEb;;OAEG;IACH,yCAAwB,CAAA;AAC1B,CAAC,EAVW,aAAa,GAAb,qBAAa,KAAb,qBAAa,QAUxB;AAED;;GAEG;AACH,IAAY,QA8BX;AA9BD,WAAY,QAAQ;IAClB;;OAEG;IACH,yBAAa,CAAA;IAEb;;OAEG;IACH,2BAAe,CAAA;IAEf;;OAEG;IACH,uBAAW,CAAA;IAEX;;OAEG;IACH,uBAAW,CAAA;IAEX;;OAEG;IACH,uBAAW,CAAA;IAEX;;OAEG;IACH,+BAAmB,CAAA;AACrB,CAAC,EA9BW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QA8BnB;AAED;;GAEG;AACH,IAAY,mBAUX;AAVD,WAAY,mBAAmB;IAC7B;;OAEG;IACH,oCAAa,CAAA;IAEb;;OAEG;IACH,sCAAe,CAAA;AACjB,CAAC,EAVW,mBAAmB,GAAnB,2BAAmB,KAAnB,2BAAmB,QAU9B;AAED;;GAEG;AACH,IAAY,0BAeX;AAfD,WAAY,0BAA0B;IACpC;;OAEG;IACH,2CAAa,CAAA;IAEb;;OAEG;IACH,6CAAe,CAAA;IAEf;;OAEG;IACH,6CAAe,CAAA;AACjB,CAAC,EAfW,0BAA0B,GAA1B,kCAA0B,KAA1B,kCAA0B,QAerC;AAED;;;;;;;;;;;;GAYG;AACH,IAAY,SAsDX;AAtDD,WAAY,SAAS;IACnB;;OAEG;IACH,sDAAyC,CAAA;IAEzC;;;OAGG;IACH,mFAAsE,CAAA;IAEtE;;OAEG;IACH,+EAAkE,CAAA;IAElE;;OAEG;IACH,uEAA0D,CAAA;IAE1D;;OAEG;IACH,uEAA0D,CAAA;IAE1D;;OAEG;IACH,6DAAgD,CAAA;IAEhD;;OAEG;IACH,wDAA2C,CAAA;IAE3C;;OAEG;IACH,gEAAmD,CAAA;IAEnD;;OAEG;IACH,wDAA2C,CAAA;IAE3C;;;;;OAKG;IACH,yDAA4C,CAAA;AAC9C,CAAC,EAtDW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAsDpB;AAED;;GAEG;AACH,IAAY,UAoBX;AApBD,WAAY,UAAU;IACpB;;OAEG;IACH,mCAAqB,CAAA;IAErB;;OAEG;IACH,uBAAS,CAAA;IAET;;OAEG;IACH,+BAAiB,CAAA;IAEjB;;OAEG;IACH,yBAAW,CAAA;AACb,CAAC,EApBW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAoBrB;AAED;;;GAGG;AACH,IAAY,UAyBX;AAzBD,WAAY,UAAU;IACpB;;OAEG;IACH,sCAAwB,CAAA;IAExB;;OAEG;IACH,sCAAwB,CAAA;IAExB;;OAEG;IACH,8CAAgC,CAAA;IAEhC;;OAEG;IACH,gDAAkC,CAAA;IAElC;;OAEG;IACH,2BAAa,CAAA;AACf,CAAC,EAzBW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAyBrB;AAED;;GAEG;AACH,IAAY,qCAUX;AAVD,WAAY,qCAAqC;IAC/C;;OAEG;IACH,oEAA2B,CAAA;IAE3B;;OAEG;IACH,kGAAyD,CAAA;AAC3D,CAAC,EAVW,qCAAqC,GAArC,6CAAqC,KAArC,6CAAqC,QAUhD","sourcesContent":["/**\n * What kind of addresses to allocate to the load balancer\n */\nexport enum IpAddressType {\n  /**\n   * Allocate IPv4 addresses\n   */\n  IPV4 = 'ipv4',\n\n  /**\n   * Allocate both IPv4 and IPv6 addresses\n   */\n  DUAL_STACK = 'dualstack',\n}\n\n/**\n * Backend protocol for network load balancers and health checks\n */\nexport enum Protocol {\n  /**\n   * HTTP (ALB health checks and NLB health checks)\n   */\n  HTTP = 'HTTP',\n\n  /**\n   * HTTPS (ALB health checks and NLB health checks)\n   */\n  HTTPS = 'HTTPS',\n\n  /**\n   * TCP (NLB, NLB health checks)\n   */\n  TCP = 'TCP',\n\n  /**\n   * TLS (NLB)\n   */\n  TLS = 'TLS',\n\n  /**\n   * UDP (NLB)\n   */\n  UDP = 'UDP',\n\n  /**\n   * Listen to both TCP and UDP on the same port (NLB)\n   */\n  TCP_UDP = 'TCP_UDP',\n}\n\n/**\n * Load balancing protocol for application load balancers\n */\nexport enum ApplicationProtocol {\n  /**\n   * HTTP\n   */\n  HTTP = 'HTTP',\n\n  /**\n   * HTTPS\n   */\n  HTTPS = 'HTTPS',\n}\n\n/**\n * Load balancing protocol version for application load balancers\n */\nexport enum ApplicationProtocolVersion {\n  /**\n   * GRPC\n   */\n  GRPC = 'GRPC',\n\n  /**\n   * HTTP1\n   */\n  HTTP1 = 'HTTP1',\n\n  /**\n   * HTTP2\n   */\n  HTTP2 = 'HTTP2',\n}\n\n/**\n * Elastic Load Balancing provides the following security policies for Application Load Balancers\n *\n * We recommend the Recommended policy for general use. You can\n * use the ForwardSecrecy policy if you require Forward Secrecy\n * (FS).\n *\n * You can use one of the TLS policies to meet compliance and security\n * standards that require disabling certain TLS protocol versions, or to\n * support legacy clients that require deprecated ciphers.\n *\n * @see https://docs.aws.amazon.com/elasticloadbalancing/latest/application/create-https-listener.html\n */\nexport enum SslPolicy {\n  /**\n   * The recommended security policy\n   */\n  RECOMMENDED = 'ELBSecurityPolicy-2016-08',\n\n  /**\n   * Strong foward secrecy ciphers and TLV1.2 only (2020 edition).\n   * Same as FORWARD_SECRECY_TLS12_RES, but only supports GCM versions of the TLS ciphers\n   */\n  FORWARD_SECRECY_TLS12_RES_GCM = 'ELBSecurityPolicy-FS-1-2-Res-2020-10',\n\n  /**\n   * Strong forward secrecy ciphers and TLS1.2 only\n   */\n  FORWARD_SECRECY_TLS12_RES = 'ELBSecurityPolicy-FS-1-2-Res-2019-08',\n\n  /**\n   * Forward secrecy ciphers and TLS1.2 only\n   */\n  FORWARD_SECRECY_TLS12 = 'ELBSecurityPolicy-FS-1-2-2019-08',\n\n  /**\n   * Forward secrecy ciphers only with TLS1.1 and higher\n   */\n  FORWARD_SECRECY_TLS11 = 'ELBSecurityPolicy-FS-1-1-2019-08',\n\n  /**\n   * Forward secrecy ciphers only\n   */\n  FORWARD_SECRECY = 'ELBSecurityPolicy-FS-2018-06',\n\n  /**\n   * TLS1.2 only and no SHA ciphers\n   */\n  TLS12 = 'ELBSecurityPolicy-TLS-1-2-2017-01',\n\n  /**\n   * TLS1.2 only with all ciphers\n   */\n  TLS12_EXT = 'ELBSecurityPolicy-TLS-1-2-Ext-2018-06',\n\n  /**\n   * TLS1.1 and higher with all ciphers\n   */\n  TLS11 = 'ELBSecurityPolicy-TLS-1-1-2017-01',\n\n  /**\n   * Support for DES-CBC3-SHA\n   *\n   * Do not use this security policy unless you must support a legacy client\n   * that requires the DES-CBC3-SHA cipher, which is a weak cipher.\n   */\n  LEGACY = 'ELBSecurityPolicy-TLS-1-0-2015-04',\n}\n\n/**\n * How to interpret the load balancing target identifiers\n */\nexport enum TargetType {\n  /**\n   * Targets identified by instance ID\n   */\n  INSTANCE = 'instance',\n\n  /**\n   * Targets identified by IP address\n   */\n  IP = 'ip',\n\n  /**\n   * Target is a single Lambda Function\n   */\n  LAMBDA = 'lambda',\n\n  /**\n   * Target is a single Application Load Balancer\n   */\n  ALB = 'alb',\n}\n\n/**\n * Application-Layer Protocol Negotiation Policies for network load balancers.\n * Which protocols should be used over a secure connection.\n */\nexport enum AlpnPolicy {\n  /**\n   * Negotiate only HTTP/1.*. The ALPN preference list is http/1.1, http/1.0\n   */\n  HTTP1_ONLY = 'HTTP1Only',\n\n  /**\n   * Negotiate only HTTP/2. The ALPN preference list is h2\n   */\n  HTTP2_ONLY = 'HTTP2Only',\n\n  /**\n   * Prefer HTTP/1.* over HTTP/2 (which can be useful for HTTP/2 testing). The ALPN preference list is http/1.1, http/1.0, h2\n   */\n  HTTP2_OPTIONAL = 'HTTP2Optional',\n\n  /**\n   * Prefer HTTP/2 over HTTP/1.*. The ALPN preference list is h2, http/1.1, http/1.0\n   */\n  HTTP2_PREFERRED = 'HTTP2Preferred',\n\n  /**\n   * Do not negotiate ALPN\n   */\n  NONE = 'None',\n}\n\n/**\n * Load balancing algorithmm type for target groups\n */\nexport enum TargetGroupLoadBalancingAlgorithmType {\n  /**\n   * round_robin\n   */\n  ROUND_ROBIN = 'round_robin',\n\n  /**\n   * least_outstanding_requests\n   */\n  LEAST_OUTSTANDING_REQUESTS = 'least_outstanding_requests',\n}\n"]}
import { CfnListener } from '../elasticloadbalancingv2.generated';
/**
* Interface for listener actions.
*
* @stability stable
* Interface for listener actions
*/
export interface IListenerAction {
/**
* Render the actions in this chain.
*
* @stability stable
* Render the actions in this chain
*/
renderActions(): CfnListener.ActionProperty[];
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdGVuZXItYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGlzdGVuZXItYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZm5MaXN0ZW5lciB9IGZyb20gJy4uL2VsYXN0aWNsb2FkYmFsYW5jaW5ndjIuZ2VuZXJhdGVkJztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbmV4cG9ydCBpbnRlcmZhY2UgSUxpc3RlbmVyQWN0aW9uIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVuZGVyQWN0aW9ucygpOiBDZm5MaXN0ZW5lci5BY3Rpb25Qcm9wZXJ0eVtdO1xufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdGVuZXItYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGlzdGVuZXItYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZm5MaXN0ZW5lciB9IGZyb20gJy4uL2VsYXN0aWNsb2FkYmFsYW5jaW5ndjIuZ2VuZXJhdGVkJztcblxuLyoqXG4gKiBJbnRlcmZhY2UgZm9yIGxpc3RlbmVyIGFjdGlvbnNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJTGlzdGVuZXJBY3Rpb24ge1xuICAvKipcbiAgICogUmVuZGVyIHRoZSBhY3Rpb25zIGluIHRoaXMgY2hhaW5cbiAgICovXG4gIHJlbmRlckFjdGlvbnMoKTogQ2ZuTGlzdGVuZXIuQWN0aW9uUHJvcGVydHlbXTtcbn0iXX0=
import * as acm from '@aws-cdk/aws-certificatemanager';
/**
* A certificate source for an ELBv2 listener.
*
* @stability stable
* A certificate source for an ELBv2 listener
*/
export interface IListenerCertificate {
/**
* The ARN of the certificate to use.
*
* @stability stable
* The ARN of the certificate to use
*/

@@ -16,29 +12,18 @@ readonly certificateArn: string;

/**
* A certificate source for an ELBv2 listener.
*
* @stability stable
* A certificate source for an ELBv2 listener
*/
export declare class ListenerCertificate implements IListenerCertificate {
/**
* Use an ACM certificate as a listener certificate.
*
* @stability stable
* Use an ACM certificate as a listener certificate
*/
static fromCertificateManager(acmCertificate: acm.ICertificate): ListenerCertificate;
/**
* Use any certificate, identified by its ARN, as a listener certificate.
*
* @stability stable
* Use any certificate, identified by its ARN, as a listener certificate
*/
static fromArn(certificateArn: string): ListenerCertificate;
/**
* The ARN of the certificate to use.
*
* @stability stable
* The ARN of the certificate to use
*/
readonly certificateArn: string;
/**
* @stability stable
*/
protected constructor(certificateArn: string);
}

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

/**
* A certificate source for an ELBv2 listener.
*
* @stability stable
* A certificate source for an ELBv2 listener
*/
class ListenerCertificate {
/**
* @stability stable
*/
constructor(certificateArn) {

@@ -20,5 +15,3 @@ this.certificateArn = certificateArn;

/**
* Use an ACM certificate as a listener certificate.
*
* @stability stable
* Use an ACM certificate as a listener certificate
*/

@@ -29,5 +22,3 @@ static fromCertificateManager(acmCertificate) {

/**
* Use any certificate, identified by its ARN, as a listener certificate.
*
* @stability stable
* Use any certificate, identified by its ARN, as a listener certificate
*/

@@ -40,3 +31,3 @@ static fromArn(certificateArn) {

_a = JSII_RTTI_SYMBOL_1;
ListenerCertificate[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ListenerCertificate", version: "1.144.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdGVuZXItY2VydGlmaWNhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJsaXN0ZW5lci1jZXJ0aWZpY2F0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBU0EsTUFBYSxtQkFBbUI7Ozs7SUFjOUIsWUFBc0IsY0FBc0I7UUFDMUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7S0FDdEM7Ozs7OztJQWRNLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxjQUFnQztRQUNuRSxPQUFPLElBQUksbUJBQW1CLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0tBQy9EOzs7Ozs7SUFHTSxNQUFNLENBQUMsT0FBTyxDQUFDLGNBQXNCO1FBQzFDLE9BQU8sSUFBSSxtQkFBbUIsQ0FBQyxjQUFjLENBQUMsQ0FBQztLQUNoRDs7QUFUSCxrREFpQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBhY20gZnJvbSAnQGF3cy1jZGsvYXdzLWNlcnRpZmljYXRlbWFuYWdlcic7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgaW50ZXJmYWNlIElMaXN0ZW5lckNlcnRpZmljYXRlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGNlcnRpZmljYXRlQXJuOiBzdHJpbmc7XG59XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgY2xhc3MgTGlzdGVuZXJDZXJ0aWZpY2F0ZSBpbXBsZW1lbnRzIElMaXN0ZW5lckNlcnRpZmljYXRlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHB1YmxpYyBzdGF0aWMgZnJvbUNlcnRpZmljYXRlTWFuYWdlcihhY21DZXJ0aWZpY2F0ZTogYWNtLklDZXJ0aWZpY2F0ZSkge1xuICAgIHJldHVybiBuZXcgTGlzdGVuZXJDZXJ0aWZpY2F0ZShhY21DZXJ0aWZpY2F0ZS5jZXJ0aWZpY2F0ZUFybik7XG4gIH1cblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcHVibGljIHN0YXRpYyBmcm9tQXJuKGNlcnRpZmljYXRlQXJuOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gbmV3IExpc3RlbmVyQ2VydGlmaWNhdGUoY2VydGlmaWNhdGVBcm4pO1xuICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHB1YmxpYyByZWFkb25seSBjZXJ0aWZpY2F0ZUFybjogc3RyaW5nO1xuXG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcihjZXJ0aWZpY2F0ZUFybjogc3RyaW5nKSB7XG4gICAgdGhpcy5jZXJ0aWZpY2F0ZUFybiA9IGNlcnRpZmljYXRlQXJuO1xuICB9XG59XG4iXX0=
ListenerCertificate[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.ListenerCertificate", version: "1.145.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdGVuZXItY2VydGlmaWNhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJsaXN0ZW5lci1jZXJ0aWZpY2F0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQVlBOztHQUVHO0FBQ0gsTUFBYSxtQkFBbUI7SUFvQjlCLFlBQXNCLGNBQXNCO1FBQzFDLElBQUksQ0FBQyxjQUFjLEdBQUcsY0FBYyxDQUFDO0tBQ3RDO0lBckJEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLHNCQUFzQixDQUFDLGNBQWdDO1FBQ25FLE9BQU8sSUFBSSxtQkFBbUIsQ0FBQyxjQUFjLENBQUMsY0FBYyxDQUFDLENBQUM7S0FDL0Q7SUFFRDs7T0FFRztJQUNJLE1BQU0sQ0FBQyxPQUFPLENBQUMsY0FBc0I7UUFDMUMsT0FBTyxJQUFJLG1CQUFtQixDQUFDLGNBQWMsQ0FBQyxDQUFDO0tBQ2hEOztBQWJILGtEQXVCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGFjbSBmcm9tICdAYXdzLWNkay9hd3MtY2VydGlmaWNhdGVtYW5hZ2VyJztcblxuLyoqXG4gKiBBIGNlcnRpZmljYXRlIHNvdXJjZSBmb3IgYW4gRUxCdjIgbGlzdGVuZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJTGlzdGVuZXJDZXJ0aWZpY2F0ZSB7XG4gIC8qKlxuICAgKiBUaGUgQVJOIG9mIHRoZSBjZXJ0aWZpY2F0ZSB0byB1c2VcbiAgICovXG4gIHJlYWRvbmx5IGNlcnRpZmljYXRlQXJuOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQSBjZXJ0aWZpY2F0ZSBzb3VyY2UgZm9yIGFuIEVMQnYyIGxpc3RlbmVyXG4gKi9cbmV4cG9ydCBjbGFzcyBMaXN0ZW5lckNlcnRpZmljYXRlIGltcGxlbWVudHMgSUxpc3RlbmVyQ2VydGlmaWNhdGUge1xuICAvKipcbiAgICogVXNlIGFuIEFDTSBjZXJ0aWZpY2F0ZSBhcyBhIGxpc3RlbmVyIGNlcnRpZmljYXRlXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGZyb21DZXJ0aWZpY2F0ZU1hbmFnZXIoYWNtQ2VydGlmaWNhdGU6IGFjbS5JQ2VydGlmaWNhdGUpIHtcbiAgICByZXR1cm4gbmV3IExpc3RlbmVyQ2VydGlmaWNhdGUoYWNtQ2VydGlmaWNhdGUuY2VydGlmaWNhdGVBcm4pO1xuICB9XG5cbiAgLyoqXG4gICAqIFVzZSBhbnkgY2VydGlmaWNhdGUsIGlkZW50aWZpZWQgYnkgaXRzIEFSTiwgYXMgYSBsaXN0ZW5lciBjZXJ0aWZpY2F0ZVxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBmcm9tQXJuKGNlcnRpZmljYXRlQXJuOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gbmV3IExpc3RlbmVyQ2VydGlmaWNhdGUoY2VydGlmaWNhdGVBcm4pO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIGNlcnRpZmljYXRlIHRvIHVzZVxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGNlcnRpZmljYXRlQXJuOiBzdHJpbmc7XG5cbiAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKGNlcnRpZmljYXRlQXJuOiBzdHJpbmcpIHtcbiAgICB0aGlzLmNlcnRpZmljYXRlQXJuID0gY2VydGlmaWNhdGVBcm47XG4gIH1cbn1cbiJdfQ==

@@ -5,3 +5,3 @@ import { IApplicationLoadBalancerTarget, IApplicationTargetGroup } from '../alb/application-target-group';

/**
* (deprecated) An EC2 instance that is the target for load balancing.
* An EC2 instance that is the target for load balancing
*

@@ -11,4 +11,3 @@ * If you register a target of this type, you are responsible for making

*
* @deprecated Use IpTarget from the
* @aws-cdk /aws-elasticloadbalancingv2-targets package instead.
* @deprecated Use IpTarget from the @aws-cdk/aws-elasticloadbalancingv2-targets package instead.
*/

@@ -19,25 +18,20 @@ export declare class InstanceTarget implements IApplicationLoadBalancerTarget, INetworkLoadBalancerTarget {

/**
* (deprecated) Create a new Instance target.
* Create a new Instance target
*
* @param instanceId Instance ID of the instance to register to.
* @param port Override the default port for the target group.
* @deprecated
* @param instanceId Instance ID of the instance to register to
* @param port Override the default port for the target group
*/
constructor(instanceId: string, port?: number | undefined);
/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/
attachToApplicationTargetGroup(targetGroup: IApplicationTargetGroup): LoadBalancerTargetProps;
/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/

@@ -48,3 +42,3 @@ attachToNetworkTargetGroup(targetGroup: INetworkTargetGroup): LoadBalancerTargetProps;

/**
* (deprecated) An IP address that is a target for load balancing.
* An IP address that is a target for load balancing.
*

@@ -59,4 +53,3 @@ * Specify IP addresses from the subnets of the virtual private cloud (VPC) for

*
* @deprecated Use IpTarget from the
* @aws-cdk /aws-elasticloadbalancingv2-targets package instead.
* @deprecated Use IpTarget from the @aws-cdk/aws-elasticloadbalancingv2-targets package instead.
*/

@@ -68,3 +61,3 @@ export declare class IpTarget implements IApplicationLoadBalancerTarget, INetworkLoadBalancerTarget {

/**
* (deprecated) Create a new IPAddress target.
* Create a new IPAddress target
*

@@ -86,24 +79,19 @@ * The availabilityZone parameter determines whether the target receives

*
* @param ipAddress The IP Address to load balance to.
* @param port Override the group's default port.
* @param availabilityZone Availability zone to send traffic from.
* @deprecated
* @param ipAddress The IP Address to load balance to
* @param port Override the group's default port
* @param availabilityZone Availability zone to send traffic from
*/
constructor(ipAddress: string, port?: number | undefined, availabilityZone?: string | undefined);
/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/
attachToApplicationTargetGroup(targetGroup: IApplicationTargetGroup): LoadBalancerTargetProps;
/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/

@@ -110,0 +98,0 @@ attachToNetworkTargetGroup(targetGroup: INetworkTargetGroup): LoadBalancerTargetProps;

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

/**
* (deprecated) An EC2 instance that is the target for load balancing.
* An EC2 instance that is the target for load balancing
*

@@ -15,12 +15,10 @@ * If you register a target of this type, you are responsible for making

*
* @deprecated Use IpTarget from the
* @aws-cdk /aws-elasticloadbalancingv2-targets package instead.
* @deprecated Use IpTarget from the @aws-cdk/aws-elasticloadbalancingv2-targets package instead.
*/
class InstanceTarget {
/**
* (deprecated) Create a new Instance target.
* Create a new Instance target
*
* @param instanceId Instance ID of the instance to register to.
* @param port Override the default port for the target group.
* @deprecated
* @param instanceId Instance ID of the instance to register to
* @param port Override the default port for the target group
*/

@@ -33,8 +31,6 @@ constructor(instanceId, port) {

/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/

@@ -47,8 +43,6 @@ attachToApplicationTargetGroup(targetGroup) {

/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/

@@ -69,5 +63,5 @@ attachToNetworkTargetGroup(targetGroup) {

_a = JSII_RTTI_SYMBOL_1;
InstanceTarget[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.InstanceTarget", version: "1.144.0" };
InstanceTarget[_a] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.InstanceTarget", version: "1.145.0" };
/**
* (deprecated) An IP address that is a target for load balancing.
* An IP address that is a target for load balancing.
*

@@ -82,8 +76,7 @@ * Specify IP addresses from the subnets of the virtual private cloud (VPC) for

*
* @deprecated Use IpTarget from the
* @aws-cdk /aws-elasticloadbalancingv2-targets package instead.
* @deprecated Use IpTarget from the @aws-cdk/aws-elasticloadbalancingv2-targets package instead.
*/
class IpTarget {
/**
* (deprecated) Create a new IPAddress target.
* Create a new IPAddress target
*

@@ -105,6 +98,5 @@ * The availabilityZone parameter determines whether the target receives

*
* @param ipAddress The IP Address to load balance to.
* @param port Override the group's default port.
* @param availabilityZone Availability zone to send traffic from.
* @deprecated
* @param ipAddress The IP Address to load balance to
* @param port Override the group's default port
* @param availabilityZone Availability zone to send traffic from
*/

@@ -118,8 +110,6 @@ constructor(ipAddress, port, availabilityZone) {

/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/

@@ -132,8 +122,6 @@ attachToApplicationTargetGroup(targetGroup) {

/**
* (deprecated) Register this instance target with a load balancer.
* Register this instance target with a load balancer
*
* Don't call this, it is called automatically when you add the target to a
* load balancer.
*
* @deprecated
*/

@@ -154,3 +142,3 @@ attachToNetworkTargetGroup(targetGroup) {

_b = JSII_RTTI_SYMBOL_1;
IpTarget[_b] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.IpTarget", version: "1.144.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC1iYWxhbmNlci10YXJnZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibG9hZC1iYWxhbmNlci10YXJnZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUdBLG1DQUFxQzs7Ozs7Ozs7OztBQUdyQyxNQUFhLGNBQWM7Ozs7Ozs7O0lBRXpCLFlBQTZCLFVBQWtCLEVBQW1CLElBQWE7UUFBbEQsZUFBVSxHQUFWLFVBQVUsQ0FBUTtRQUFtQixTQUFJLEdBQUosSUFBSSxDQUFTOztLQUM5RTs7Ozs7Ozs7O0lBR00sOEJBQThCLENBQUMsV0FBb0M7OztRQUN4RSxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7S0FDakM7Ozs7Ozs7OztJQUdNLDBCQUEwQixDQUFDLFdBQWdDOzs7UUFDaEUsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0tBQ2pDO0lBRU8sTUFBTSxDQUFDLFlBQTBCO1FBQ3ZDLE9BQU87WUFDTCxVQUFVLEVBQUUsa0JBQVUsQ0FBQyxRQUFRO1lBQy9CLFVBQVUsRUFBRSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFO1NBQ3JELENBQUM7S0FDSDs7QUFwQkgsd0NBcUJDOzs7Ozs7Ozs7Ozs7Ozs7OztBQUdELE1BQWEsUUFBUTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBRW5CLFlBQTZCLFNBQWlCLEVBQW1CLElBQWEsRUFBbUIsZ0JBQXlCO1FBQTdGLGNBQVMsR0FBVCxTQUFTLENBQVE7UUFBbUIsU0FBSSxHQUFKLElBQUksQ0FBUztRQUFtQixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQVM7O0tBQ3pIOzs7Ozs7Ozs7SUFHTSw4QkFBOEIsQ0FBQyxXQUFvQzs7O1FBQ3hFLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztLQUNqQzs7Ozs7Ozs7O0lBR00sMEJBQTBCLENBQUMsV0FBZ0M7OztRQUNoRSxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7S0FDakM7SUFFTyxNQUFNLENBQUMsWUFBMEI7UUFDdkMsT0FBTztZQUNMLFVBQVUsRUFBRSxrQkFBVSxDQUFDLEVBQUU7WUFDekIsVUFBVSxFQUFFLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixFQUFFO1NBQzdGLENBQUM7S0FDSDs7QUFwQkgsNEJBcUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyVGFyZ2V0LCBJQXBwbGljYXRpb25UYXJnZXRHcm91cCB9IGZyb20gJy4uL2FsYi9hcHBsaWNhdGlvbi10YXJnZXQtZ3JvdXAnO1xuaW1wb3J0IHsgSU5ldHdvcmtMb2FkQmFsYW5jZXJUYXJnZXQsIElOZXR3b3JrVGFyZ2V0R3JvdXAgfSBmcm9tICcuLi9ubGIvbmV0d29yay10YXJnZXQtZ3JvdXAnO1xuaW1wb3J0IHsgSVRhcmdldEdyb3VwLCBMb2FkQmFsYW5jZXJUYXJnZXRQcm9wcyB9IGZyb20gJy4vYmFzZS10YXJnZXQtZ3JvdXAnO1xuaW1wb3J0IHsgVGFyZ2V0VHlwZSB9IGZyb20gJy4vZW51bXMnO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgY2xhc3MgSW5zdGFuY2VUYXJnZXQgaW1wbGVtZW50cyBJQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJUYXJnZXQsIElOZXR3b3JrTG9hZEJhbGFuY2VyVGFyZ2V0IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGluc3RhbmNlSWQ6IHN0cmluZywgcHJpdmF0ZSByZWFkb25seSBwb3J0PzogbnVtYmVyKSB7XG4gIH1cblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcHVibGljIGF0dGFjaFRvQXBwbGljYXRpb25UYXJnZXRHcm91cCh0YXJnZXRHcm91cDogSUFwcGxpY2F0aW9uVGFyZ2V0R3JvdXApOiBMb2FkQmFsYW5jZXJUYXJnZXRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMuYXR0YWNoKHRhcmdldEdyb3VwKTtcbiAgfVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICBwdWJsaWMgYXR0YWNoVG9OZXR3b3JrVGFyZ2V0R3JvdXAodGFyZ2V0R3JvdXA6IElOZXR3b3JrVGFyZ2V0R3JvdXApOiBMb2FkQmFsYW5jZXJUYXJnZXRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMuYXR0YWNoKHRhcmdldEdyb3VwKTtcbiAgfVxuXG4gIHByaXZhdGUgYXR0YWNoKF90YXJnZXRHcm91cDogSVRhcmdldEdyb3VwKTogTG9hZEJhbGFuY2VyVGFyZ2V0UHJvcHMge1xuICAgIHJldHVybiB7XG4gICAgICB0YXJnZXRUeXBlOiBUYXJnZXRUeXBlLklOU1RBTkNFLFxuICAgICAgdGFyZ2V0SnNvbjogeyBpZDogdGhpcy5pbnN0YW5jZUlkLCBwb3J0OiB0aGlzLnBvcnQgfSxcbiAgICB9O1xuICB9XG59XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuZXhwb3J0IGNsYXNzIElwVGFyZ2V0IGltcGxlbWVudHMgSUFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyVGFyZ2V0LCBJTmV0d29ya0xvYWRCYWxhbmNlclRhcmdldCB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGlwQWRkcmVzczogc3RyaW5nLCBwcml2YXRlIHJlYWRvbmx5IHBvcnQ/OiBudW1iZXIsIHByaXZhdGUgcmVhZG9ubHkgYXZhaWxhYmlsaXR5Wm9uZT86IHN0cmluZykge1xuICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHB1YmxpYyBhdHRhY2hUb0FwcGxpY2F0aW9uVGFyZ2V0R3JvdXAodGFyZ2V0R3JvdXA6IElBcHBsaWNhdGlvblRhcmdldEdyb3VwKTogTG9hZEJhbGFuY2VyVGFyZ2V0UHJvcHMge1xuICAgIHJldHVybiB0aGlzLmF0dGFjaCh0YXJnZXRHcm91cCk7XG4gIH1cblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcHVibGljIGF0dGFjaFRvTmV0d29ya1RhcmdldEdyb3VwKHRhcmdldEdyb3VwOiBJTmV0d29ya1RhcmdldEdyb3VwKTogTG9hZEJhbGFuY2VyVGFyZ2V0UHJvcHMge1xuICAgIHJldHVybiB0aGlzLmF0dGFjaCh0YXJnZXRHcm91cCk7XG4gIH1cblxuICBwcml2YXRlIGF0dGFjaChfdGFyZ2V0R3JvdXA6IElUYXJnZXRHcm91cCk6IExvYWRCYWxhbmNlclRhcmdldFByb3BzIHtcbiAgICByZXR1cm4ge1xuICAgICAgdGFyZ2V0VHlwZTogVGFyZ2V0VHlwZS5JUCxcbiAgICAgIHRhcmdldEpzb246IHsgaWQ6IHRoaXMuaXBBZGRyZXNzLCBwb3J0OiB0aGlzLnBvcnQsIGF2YWlsYWJpbGl0eVpvbmU6IHRoaXMuYXZhaWxhYmlsaXR5Wm9uZSB9LFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
IpTarget[_b] = { fqn: "@aws-cdk/aws-elasticloadbalancingv2.IpTarget", version: "1.145.0" };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC1iYWxhbmNlci10YXJnZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibG9hZC1iYWxhbmNlci10YXJnZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUdBLG1DQUFxQztBQUVyQzs7Ozs7OztHQU9HO0FBQ0gsTUFBYSxjQUFjO0lBQ3pCOzs7OztPQUtHO0lBQ0gsWUFBNkIsVUFBa0IsRUFBbUIsSUFBYTtRQUFsRCxlQUFVLEdBQVYsVUFBVSxDQUFRO1FBQW1CLFNBQUksR0FBSixJQUFJLENBQVM7O0tBQzlFO0lBRUQ7Ozs7O09BS0c7SUFDSSw4QkFBOEIsQ0FBQyxXQUFvQzs7O1FBQ3hFLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztLQUNqQztJQUVEOzs7OztPQUtHO0lBQ0ksMEJBQTBCLENBQUMsV0FBZ0M7OztRQUNoRSxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7S0FDakM7SUFFTyxNQUFNLENBQUMsWUFBMEI7UUFDdkMsT0FBTztZQUNMLFVBQVUsRUFBRSxrQkFBVSxDQUFDLFFBQVE7WUFDL0IsVUFBVSxFQUFFLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUU7U0FDckQsQ0FBQztLQUNIOztBQW5DSCx3Q0FvQ0M7OztBQUVEOzs7Ozs7Ozs7Ozs7R0FZRztBQUNILE1BQWEsUUFBUTtJQUNuQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O09BcUJHO0lBQ0gsWUFBNkIsU0FBaUIsRUFBbUIsSUFBYSxFQUFtQixnQkFBeUI7UUFBN0YsY0FBUyxHQUFULFNBQVMsQ0FBUTtRQUFtQixTQUFJLEdBQUosSUFBSSxDQUFTO1FBQW1CLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBUzs7S0FDekg7SUFFRDs7Ozs7T0FLRztJQUNJLDhCQUE4QixDQUFDLFdBQW9DOzs7UUFDeEUsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0tBQ2pDO0lBRUQ7Ozs7O09BS0c7SUFDSSwwQkFBMEIsQ0FBQyxXQUFnQzs7O1FBQ2hFLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztLQUNqQztJQUVPLE1BQU0sQ0FBQyxZQUEwQjtRQUN2QyxPQUFPO1lBQ0wsVUFBVSxFQUFFLGtCQUFVLENBQUMsRUFBRTtZQUN6QixVQUFVLEVBQUUsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxJQUFJLENBQUMsZ0JBQWdCLEVBQUU7U0FDN0YsQ0FBQztLQUNIOztBQW5ESCw0QkFvREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJUYXJnZXQsIElBcHBsaWNhdGlvblRhcmdldEdyb3VwIH0gZnJvbSAnLi4vYWxiL2FwcGxpY2F0aW9uLXRhcmdldC1ncm91cCc7XG5pbXBvcnQgeyBJTmV0d29ya0xvYWRCYWxhbmNlclRhcmdldCwgSU5ldHdvcmtUYXJnZXRHcm91cCB9IGZyb20gJy4uL25sYi9uZXR3b3JrLXRhcmdldC1ncm91cCc7XG5pbXBvcnQgeyBJVGFyZ2V0R3JvdXAsIExvYWRCYWxhbmNlclRhcmdldFByb3BzIH0gZnJvbSAnLi9iYXNlLXRhcmdldC1ncm91cCc7XG5pbXBvcnQgeyBUYXJnZXRUeXBlIH0gZnJvbSAnLi9lbnVtcyc7XG5cbi8qKlxuICogQW4gRUMyIGluc3RhbmNlIHRoYXQgaXMgdGhlIHRhcmdldCBmb3IgbG9hZCBiYWxhbmNpbmdcbiAqXG4gKiBJZiB5b3UgcmVnaXN0ZXIgYSB0YXJnZXQgb2YgdGhpcyB0eXBlLCB5b3UgYXJlIHJlc3BvbnNpYmxlIGZvciBtYWtpbmdcbiAqIHN1cmUgdGhlIGxvYWQgYmFsYW5jZXIncyBzZWN1cml0eSBncm91cCBjYW4gY29ubmVjdCB0byB0aGUgaW5zdGFuY2UuXG4gKlxuICogQGRlcHJlY2F0ZWQgVXNlIElwVGFyZ2V0IGZyb20gdGhlIEBhd3MtY2RrL2F3cy1lbGFzdGljbG9hZGJhbGFuY2luZ3YyLXRhcmdldHMgcGFja2FnZSBpbnN0ZWFkLlxuICovXG5leHBvcnQgY2xhc3MgSW5zdGFuY2VUYXJnZXQgaW1wbGVtZW50cyBJQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJUYXJnZXQsIElOZXR3b3JrTG9hZEJhbGFuY2VyVGFyZ2V0IHtcbiAgLyoqXG4gICAqIENyZWF0ZSBhIG5ldyBJbnN0YW5jZSB0YXJnZXRcbiAgICpcbiAgICogQHBhcmFtIGluc3RhbmNlSWQgSW5zdGFuY2UgSUQgb2YgdGhlIGluc3RhbmNlIHRvIHJlZ2lzdGVyIHRvXG4gICAqIEBwYXJhbSBwb3J0IE92ZXJyaWRlIHRoZSBkZWZhdWx0IHBvcnQgZm9yIHRoZSB0YXJnZXQgZ3JvdXBcbiAgICovXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgaW5zdGFuY2VJZDogc3RyaW5nLCBwcml2YXRlIHJlYWRvbmx5IHBvcnQ/OiBudW1iZXIpIHtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWdpc3RlciB0aGlzIGluc3RhbmNlIHRhcmdldCB3aXRoIGEgbG9hZCBiYWxhbmNlclxuICAgKlxuICAgKiBEb24ndCBjYWxsIHRoaXMsIGl0IGlzIGNhbGxlZCBhdXRvbWF0aWNhbGx5IHdoZW4geW91IGFkZCB0aGUgdGFyZ2V0IHRvIGFcbiAgICogbG9hZCBiYWxhbmNlci5cbiAgICovXG4gIHB1YmxpYyBhdHRhY2hUb0FwcGxpY2F0aW9uVGFyZ2V0R3JvdXAodGFyZ2V0R3JvdXA6IElBcHBsaWNhdGlvblRhcmdldEdyb3VwKTogTG9hZEJhbGFuY2VyVGFyZ2V0UHJvcHMge1xuICAgIHJldHVybiB0aGlzLmF0dGFjaCh0YXJnZXRHcm91cCk7XG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXIgdGhpcyBpbnN0YW5jZSB0YXJnZXQgd2l0aCBhIGxvYWQgYmFsYW5jZXJcbiAgICpcbiAgICogRG9uJ3QgY2FsbCB0aGlzLCBpdCBpcyBjYWxsZWQgYXV0b21hdGljYWxseSB3aGVuIHlvdSBhZGQgdGhlIHRhcmdldCB0byBhXG4gICAqIGxvYWQgYmFsYW5jZXIuXG4gICAqL1xuICBwdWJsaWMgYXR0YWNoVG9OZXR3b3JrVGFyZ2V0R3JvdXAodGFyZ2V0R3JvdXA6IElOZXR3b3JrVGFyZ2V0R3JvdXApOiBMb2FkQmFsYW5jZXJUYXJnZXRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMuYXR0YWNoKHRhcmdldEdyb3VwKTtcbiAgfVxuXG4gIHByaXZhdGUgYXR0YWNoKF90YXJnZXRHcm91cDogSVRhcmdldEdyb3VwKTogTG9hZEJhbGFuY2VyVGFyZ2V0UHJvcHMge1xuICAgIHJldHVybiB7XG4gICAgICB0YXJnZXRUeXBlOiBUYXJnZXRUeXBlLklOU1RBTkNFLFxuICAgICAgdGFyZ2V0SnNvbjogeyBpZDogdGhpcy5pbnN0YW5jZUlkLCBwb3J0OiB0aGlzLnBvcnQgfSxcbiAgICB9O1xuICB9XG59XG5cbi8qKlxuICogQW4gSVAgYWRkcmVzcyB0aGF0IGlzIGEgdGFyZ2V0IGZvciBsb2FkIGJhbGFuY2luZy5cbiAqXG4gKiBTcGVjaWZ5IElQIGFkZHJlc3NlcyBmcm9tIHRoZSBzdWJuZXRzIG9mIHRoZSB2aXJ0dWFsIHByaXZhdGUgY2xvdWQgKFZQQykgZm9yXG4gKiB0aGUgdGFyZ2V0IGdyb3VwLCB0aGUgUkZDIDE5MTggcmFuZ2UgKDEwLjAuMC4wLzgsIDE3Mi4xNi4wLjAvMTIsIGFuZFxuICogMTkyLjE2OC4wLjAvMTYpLCBhbmQgdGhlIFJGQyA2NTk4IHJhbmdlICgxMDAuNjQuMC4wLzEwKS4gWW91IGNhbid0IHNwZWNpZnlcbiAqIHB1YmxpY2x5IHJvdXRhYmxlIElQIGFkZHJlc3Nlcy5cbiAqXG4gKiBJZiB5b3UgcmVnaXN0ZXIgYSB0YXJnZXQgb2YgdGhpcyB0eXBlLCB5b3UgYXJlIHJlc3BvbnNpYmxlIGZvciBtYWtpbmdcbiAqIHN1cmUgdGhlIGxvYWQgYmFsYW5jZXIncyBzZWN1cml0eSBncm91cCBjYW4gc2VuZCBwYWNrZXRzIHRvIHRoZSBJUCBhZGRyZXNzLlxuICpcbiAqIEBkZXByZWNhdGVkIFVzZSBJcFRhcmdldCBmcm9tIHRoZSBAYXdzLWNkay9hd3MtZWxhc3RpY2xvYWRiYWxhbmNpbmd2Mi10YXJnZXRzIHBhY2thZ2UgaW5zdGVhZC5cbiAqL1xuZXhwb3J0IGNsYXNzIElwVGFyZ2V0IGltcGxlbWVudHMgSUFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyVGFyZ2V0LCBJTmV0d29ya0xvYWRCYWxhbmNlclRhcmdldCB7XG4gIC8qKlxuICAgKiBDcmVhdGUgYSBuZXcgSVBBZGRyZXNzIHRhcmdldFxuICAgKlxuICAgKiBUaGUgYXZhaWxhYmlsaXR5Wm9uZSBwYXJhbWV0ZXIgZGV0ZXJtaW5lcyB3aGV0aGVyIHRoZSB0YXJnZXQgcmVjZWl2ZXNcbiAgICogdHJhZmZpYyBmcm9tIHRoZSBsb2FkIGJhbGFuY2VyIG5vZGVzIGluIHRoZSBzcGVjaWZpZWQgQXZhaWxhYmlsaXR5IFpvbmVcbiAgICogb3IgZnJvbSBhbGwgZW5hYmxlZCBBdmFpbGFiaWxpdHkgWm9uZXMgZm9yIHRoZSBsb2FkIGJhbGFuY2VyLlxuICAgKlxuICAgKiBUaGlzIHBhcmFtZXRlciBpcyBub3Qgc3VwcG9ydGVkIGlmIHRoZSB0YXJnZXQgdHlwZSBvZiB0aGUgdGFyZ2V0IGdyb3VwXG4gICAqIGlzIGluc3RhbmNlLiBJZiB0aGUgSVAgYWRkcmVzcyBpcyBpbiBhIHN1Ym5ldCBvZiB0aGUgVlBDIGZvciB0aGUgdGFyZ2V0XG4gICAqIGdyb3VwLCB0aGUgQXZhaWxhYmlsaXR5IFpvbmUgaXMgYXV0b21hdGljYWxseSBkZXRlY3RlZCBhbmQgdGhpc1xuICAgKiBwYXJhbWV0ZXIgaXMgb3B0aW9uYWwuIElmIHRoZSBJUCBhZGRyZXNzIGlzIG91dHNpZGUgdGhlIFZQQywgdGhpc1xuICAgKiBwYXJhbWV0ZXIgaXMgcmVxdWlyZWQuXG4gICAqXG4gICAqIFdpdGggYW4gQXBwbGljYXRpb24gTG9hZCBCYWxhbmNlciwgaWYgdGhlIElQIGFkZHJlc3MgaXMgb3V0c2lkZSB0aGUgVlBDXG4gICAqIGZvciB0aGUgdGFyZ2V0IGdyb3VwLCB0aGUgb25seSBzdXBwb3J0ZWQgdmFsdWUgaXMgYWxsLlxuICAgKlxuICAgKiBEZWZhdWx0IGlzIGF1dG9tYXRpYy5cbiAgICpcbiAgICogQHBhcmFtIGlwQWRkcmVzcyBUaGUgSVAgQWRkcmVzcyB0byBsb2FkIGJhbGFuY2UgdG9cbiAgICogQHBhcmFtIHBvcnQgT3ZlcnJpZGUgdGhlIGdyb3VwJ3MgZGVmYXVsdCBwb3J0XG4gICAqIEBwYXJhbSBhdmFpbGFiaWxpdHlab25lIEF2YWlsYWJpbGl0eSB6b25lIHRvIHNlbmQgdHJhZmZpYyBmcm9tXG4gICAqL1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGlwQWRkcmVzczogc3RyaW5nLCBwcml2YXRlIHJlYWRvbmx5IHBvcnQ/OiBudW1iZXIsIHByaXZhdGUgcmVhZG9ubHkgYXZhaWxhYmlsaXR5Wm9uZT86IHN0cmluZykge1xuICB9XG5cbiAgLyoqXG4gICAqIFJlZ2lzdGVyIHRoaXMgaW5zdGFuY2UgdGFyZ2V0IHdpdGggYSBsb2FkIGJhbGFuY2VyXG4gICAqXG4gICAqIERvbid0IGNhbGwgdGhpcywgaXQgaXMgY2FsbGVkIGF1dG9tYXRpY2FsbHkgd2hlbiB5b3UgYWRkIHRoZSB0YXJnZXQgdG8gYVxuICAgKiBsb2FkIGJhbGFuY2VyLlxuICAgKi9cbiAgcHVibGljIGF0dGFjaFRvQXBwbGljYXRpb25UYXJnZXRHcm91cCh0YXJnZXRHcm91cDogSUFwcGxpY2F0aW9uVGFyZ2V0R3JvdXApOiBMb2FkQmFsYW5jZXJUYXJnZXRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMuYXR0YWNoKHRhcmdldEdyb3VwKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWdpc3RlciB0aGlzIGluc3RhbmNlIHRhcmdldCB3aXRoIGEgbG9hZCBiYWxhbmNlclxuICAgKlxuICAgKiBEb24ndCBjYWxsIHRoaXMsIGl0IGlzIGNhbGxlZCBhdXRvbWF0aWNhbGx5IHdoZW4geW91IGFkZCB0aGUgdGFyZ2V0IHRvIGFcbiAgICogbG9hZCBiYWxhbmNlci5cbiAgICovXG4gIHB1YmxpYyBhdHRhY2hUb05ldHdvcmtUYXJnZXRHcm91cCh0YXJnZXRHcm91cDogSU5ldHdvcmtUYXJnZXRHcm91cCk6IExvYWRCYWxhbmNlclRhcmdldFByb3BzIHtcbiAgICByZXR1cm4gdGhpcy5hdHRhY2godGFyZ2V0R3JvdXApO1xuICB9XG5cbiAgcHJpdmF0ZSBhdHRhY2goX3RhcmdldEdyb3VwOiBJVGFyZ2V0R3JvdXApOiBMb2FkQmFsYW5jZXJUYXJnZXRQcm9wcyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRhcmdldFR5cGU6IFRhcmdldFR5cGUuSVAsXG4gICAgICB0YXJnZXRKc29uOiB7IGlkOiB0aGlzLmlwQWRkcmVzcywgcG9ydDogdGhpcy5wb3J0LCBhdmFpbGFiaWxpdHlab25lOiB0aGlzLmF2YWlsYWJpbGl0eVpvbmUgfSxcbiAgICB9O1xuICB9XG59XG4iXX0=
{
"name": "@aws-cdk/aws-elasticloadbalancingv2",
"version": "1.144.0",
"version": "1.145.0",
"description": "The CDK Construct Library for AWS::ElasticLoadBalancingV2",

@@ -82,20 +82,20 @@ "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-certificatemanager": "1.144.0",
"@aws-cdk/aws-cloudwatch": "1.144.0",
"@aws-cdk/aws-ec2": "1.144.0",
"@aws-cdk/aws-iam": "1.144.0",
"@aws-cdk/aws-lambda": "1.144.0",
"@aws-cdk/aws-s3": "1.144.0",
"@aws-cdk/cloud-assembly-schema": "1.144.0",
"@aws-cdk/core": "1.144.0",
"@aws-cdk/cx-api": "1.144.0",
"@aws-cdk/region-info": "1.144.0",
"@aws-cdk/aws-certificatemanager": "1.145.0",
"@aws-cdk/aws-cloudwatch": "1.145.0",
"@aws-cdk/aws-ec2": "1.145.0",
"@aws-cdk/aws-iam": "1.145.0",
"@aws-cdk/aws-lambda": "1.145.0",
"@aws-cdk/aws-s3": "1.145.0",
"@aws-cdk/cloud-assembly-schema": "1.145.0",
"@aws-cdk/core": "1.145.0",
"@aws-cdk/cx-api": "1.145.0",
"@aws-cdk/region-info": "1.145.0",
"constructs": "^3.3.69"

@@ -105,12 +105,12 @@ },

"peerDependencies": {
"@aws-cdk/aws-certificatemanager": "1.144.0",
"@aws-cdk/aws-cloudwatch": "1.144.0",
"@aws-cdk/aws-ec2": "1.144.0",
"@aws-cdk/aws-iam": "1.144.0",
"@aws-cdk/aws-lambda": "1.144.0",
"@aws-cdk/aws-s3": "1.144.0",
"@aws-cdk/cloud-assembly-schema": "1.144.0",
"@aws-cdk/core": "1.144.0",
"@aws-cdk/cx-api": "1.144.0",
"@aws-cdk/region-info": "1.144.0",
"@aws-cdk/aws-certificatemanager": "1.145.0",
"@aws-cdk/aws-cloudwatch": "1.145.0",
"@aws-cdk/aws-ec2": "1.145.0",
"@aws-cdk/aws-iam": "1.145.0",
"@aws-cdk/aws-lambda": "1.145.0",
"@aws-cdk/aws-s3": "1.145.0",
"@aws-cdk/cloud-assembly-schema": "1.145.0",
"@aws-cdk/core": "1.145.0",
"@aws-cdk/cx-api": "1.145.0",
"@aws-cdk/region-info": "1.145.0",
"constructs": "^3.3.69"

@@ -117,0 +117,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

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