Socket
Socket
Sign inDemoInstall

@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 0.28.0 to 0.29.0

46

lib/alb/application-load-balancer.d.ts

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

*/
metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -75,3 +75,3 @@ * The total number of concurrent TCP connections active from clients to the

*/
metricActiveConnectionCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricActiveConnectionCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -84,3 +84,3 @@ * The number of TLS connections initiated by the client that did not

*/
metricClientTlsNegotiationErrorCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricClientTlsNegotiationErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -91,3 +91,3 @@ * The number of load balancer capacity units (LCU) used by your load balancer.

*/
metricConsumedLCUs(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricConsumedLCUs(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -98,3 +98,3 @@ * The number of fixed-response actions that were successful.

*/
metricHttpFixedResponseCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHttpFixedResponseCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -105,3 +105,3 @@ * The number of redirect actions that were successful.

*/
metricHttpRedirectCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHttpRedirectCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -113,3 +113,3 @@ * The number of redirect actions that couldn't be completed because the URL

*/
metricHttpRedirectUrlLimitExceededCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHttpRedirectUrlLimitExceededCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -122,3 +122,3 @@ * The number of HTTP 3xx/4xx/5xx codes that originate from the load balancer.

*/
metricHttpCodeElb(code: HttpCodeElb, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHttpCodeElb(code: HttpCodeElb, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -132,3 +132,3 @@ * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets

*/
metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -139,3 +139,3 @@ * The total number of bytes processed by the load balancer over IPv6.

*/
metricIPv6ProcessedBytes(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricIPv6ProcessedBytes(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -146,3 +146,3 @@ * The number of IPv6 requests received by the load balancer.

*/
metricIPv6RequestCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricIPv6RequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -154,3 +154,3 @@ * The total number of new TCP connections established from clients to the

*/
metricNewConnectionCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricNewConnectionCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -161,3 +161,3 @@ * The total number of bytes processed by the load balancer over IPv4 and IPv6.

*/
metricProcessedBytes(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricProcessedBytes(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -169,3 +169,3 @@ * The number of connections that were rejected because the load balancer had

*/
metricRejectedConnectionCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricRejectedConnectionCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -178,3 +178,3 @@ * The number of requests processed over IPv4 and IPv6.

*/
metricRequestCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricRequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -185,3 +185,3 @@ * The number of rules processed by the load balancer given a request rate averaged over an hour.

*/
metricRuleEvaluations(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricRuleEvaluations(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -192,3 +192,3 @@ * The number of connections that were not successfully established between the load balancer and target.

*/
metricTargetConnectionErrorCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -199,3 +199,3 @@ * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.

*/
metricTargetResponseTime(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTargetResponseTime(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -208,3 +208,3 @@ * The number of TLS connections initiated by the load balancer that did not establish a session with the target.

*/
metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -219,3 +219,3 @@ * The number of user authentications that could not be completed

*/
metricElbAuthError(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricElbAuthError(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -228,3 +228,3 @@ * The number of user authentications that could not be completed because the

*/
metricElbAuthFailure(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricElbAuthFailure(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -237,3 +237,3 @@ * The time elapsed, in milliseconds, to query the IdP for the ID token and user info.

*/
metricElbAuthLatency(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricElbAuthLatency(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -247,3 +247,3 @@ * The number of authenticate actions that were successful.

*/
metricElbAuthSuccess(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricElbAuthSuccess(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
}

@@ -250,0 +250,0 @@ /**

@@ -50,7 +50,6 @@ "use strict";

}
// FIXME: can't use grantPut() here because that only takes IAM objects, not arbitrary principals
bucket.addToResourcePolicy(new iam.PolicyStatement()
.addPrincipal(new iam.AccountPrincipal(account))
.addAction('s3:PutObject')
.addResource(bucket.arnForObjects(prefix || '', '*')));
prefix = prefix || '';
bucket.grantPut(new iam.AccountPrincipal(account), prefix + '*');
// make sure the bucket's policy is created before the ALB (see https://github.com/awslabs/aws-cdk/issues/1633)
this.node.addDependency(bucket);
}

@@ -61,3 +60,6 @@ /**

addListener(id, props) {
return new application_listener_1.ApplicationListener(this, id, Object.assign({ loadBalancer: this }, props));
return new application_listener_1.ApplicationListener(this, id, {
loadBalancer: this,
...props
});
}

@@ -79,3 +81,8 @@ /**

metric(metricName, props) {
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/ApplicationELB', metricName, dimensions: { LoadBalancer: this.fullName } }, props));
return new cloudwatch.Metric({
namespace: 'AWS/ApplicationELB',
metricName,
dimensions: { LoadBalancer: this.fullName },
...props
});
}

@@ -89,3 +96,6 @@ /**

metricActiveConnectionCount(props) {
return this.metric('ActiveConnectionCount', Object.assign({ statistic: 'sum' }, props));
return this.metric('ActiveConnectionCount', {
statistic: 'sum',
...props
});
}

@@ -100,3 +110,6 @@ /**

metricClientTlsNegotiationErrorCount(props) {
return this.metric('ClientTLSNegotiationErrorCount', Object.assign({ statistic: 'sum' }, props));
return this.metric('ClientTLSNegotiationErrorCount', {
statistic: 'sum',
...props
});
}

@@ -109,3 +122,6 @@ /**

metricConsumedLCUs(props) {
return this.metric('ConsumedLCUs', Object.assign({ statistic: 'sum' }, props));
return this.metric('ConsumedLCUs', {
statistic: 'sum',
...props
});
}

@@ -118,3 +134,6 @@ /**

metricHttpFixedResponseCount(props) {
return this.metric('HTTP_Fixed_Response_Count', Object.assign({ statistic: 'Sum' }, props));
return this.metric('HTTP_Fixed_Response_Count', {
statistic: 'Sum',
...props
});
}

@@ -127,3 +146,6 @@ /**

metricHttpRedirectCount(props) {
return this.metric('HTTP_Redirect_Count', Object.assign({ statistic: 'Sum' }, props));
return this.metric('HTTP_Redirect_Count', {
statistic: 'Sum',
...props
});
}

@@ -137,3 +159,6 @@ /**

metricHttpRedirectUrlLimitExceededCount(props) {
return this.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', Object.assign({ statistic: 'Sum' }, props));
return this.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', {
statistic: 'Sum',
...props
});
}

@@ -148,3 +173,6 @@ /**

metricHttpCodeElb(code, props) {
return this.metric(code, Object.assign({ statistic: 'Sum' }, props));
return this.metric(code, {
statistic: 'Sum',
...props
});
}

@@ -160,3 +188,6 @@ /**

metricHttpCodeTarget(code, props) {
return this.metric(code, Object.assign({ statistic: 'Sum' }, props));
return this.metric(code, {
statistic: 'Sum',
...props
});
}

@@ -169,3 +200,6 @@ /**

metricIPv6ProcessedBytes(props) {
return this.metric('IPv6ProcessedBytes', Object.assign({ statistic: 'Sum' }, props));
return this.metric('IPv6ProcessedBytes', {
statistic: 'Sum',
...props
});
}

@@ -178,3 +212,6 @@ /**

metricIPv6RequestCount(props) {
return this.metric('IPv6RequestCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('IPv6RequestCount', {
statistic: 'Sum',
...props
});
}

@@ -188,3 +225,6 @@ /**

metricNewConnectionCount(props) {
return this.metric('NewConnectionCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('NewConnectionCount', {
statistic: 'Sum',
...props
});
}

@@ -197,3 +237,6 @@ /**

metricProcessedBytes(props) {
return this.metric('ProcessedBytes', Object.assign({ statistic: 'Sum' }, props));
return this.metric('ProcessedBytes', {
statistic: 'Sum',
...props
});
}

@@ -207,3 +250,6 @@ /**

metricRejectedConnectionCount(props) {
return this.metric('RejectedConnectionCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('RejectedConnectionCount', {
statistic: 'Sum',
...props
});
}

@@ -218,3 +264,6 @@ /**

metricRequestCount(props) {
return this.metric('RequestCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('RequestCount', {
statistic: 'Sum',
...props
});
}

@@ -227,3 +276,6 @@ /**

metricRuleEvaluations(props) {
return this.metric('RuleEvaluations', Object.assign({ statistic: 'Sum' }, props));
return this.metric('RuleEvaluations', {
statistic: 'Sum',
...props
});
}

@@ -236,3 +288,6 @@ /**

metricTargetConnectionErrorCount(props) {
return this.metric('TargetConnectionErrorCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('TargetConnectionErrorCount', {
statistic: 'Sum',
...props
});
}

@@ -245,3 +300,6 @@ /**

metricTargetResponseTime(props) {
return this.metric('TargetResponseTime', Object.assign({ statistic: 'Average' }, props));
return this.metric('TargetResponseTime', {
statistic: 'Average',
...props
});
}

@@ -256,3 +314,6 @@ /**

metricTargetTLSNegotiationErrorCount(props) {
return this.metric('TargetTLSNegotiationErrorCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('TargetTLSNegotiationErrorCount', {
statistic: 'Sum',
...props
});
}

@@ -269,3 +330,6 @@ /**

metricElbAuthError(props) {
return this.metric('ELBAuthError', Object.assign({ statistic: 'Sum' }, props));
return this.metric('ELBAuthError', {
statistic: 'Sum',
...props
});
}

@@ -280,3 +344,6 @@ /**

metricElbAuthFailure(props) {
return this.metric('ELBAuthFailure', Object.assign({ statistic: 'Sum' }, props));
return this.metric('ELBAuthFailure', {
statistic: 'Sum',
...props
});
}

@@ -291,3 +358,6 @@ /**

metricElbAuthLatency(props) {
return this.metric('ELBAuthLatency', Object.assign({ statistic: 'Average' }, props));
return this.metric('ELBAuthLatency', {
statistic: 'Average',
...props
});
}

@@ -303,3 +373,6 @@ /**

metricElbAuthSuccess(props) {
return this.metric('ELBAuthSuccess', Object.assign({ statistic: 'Sum' }, props));
return this.metric('ELBAuthSuccess', {
statistic: 'Sum',
...props
});
}

@@ -392,5 +465,8 @@ }

addListener(id, props) {
return new application_listener_1.ApplicationListener(this, id, Object.assign({ loadBalancer: this }, props));
return new application_listener_1.ApplicationListener(this, id, {
loadBalancer: this,
...props
});
}
}
//# 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 cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport iam = require('@aws-cdk/aws-iam');\nimport s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { BaseLoadBalancer, BaseLoadBalancerProps } from '../shared/base-load-balancer';\nimport { IpAddressType } from '../shared/enums';\nimport { ApplicationListener, BaseApplicationListenerProps } from './application-listener';\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 idleTimeoutSecs?: number;\n}\n\n/**\n * Define an Application Load Balancer\n */\nexport class ApplicationLoadBalancer extends BaseLoadBalancer implements IApplicationLoadBalancer {\n  /**\n   * Import an existing Application Load Balancer\n   */\n  public static import(scope: cdk.Construct, id: string, props: ApplicationLoadBalancerImportProps): IApplicationLoadBalancer {\n    return new ImportedApplicationLoadBalancer(scope, id, props);\n  }\n\n  public readonly connections: ec2.Connections;\n  private readonly securityGroup: ec2.ISecurityGroup;\n\n  constructor(scope: cdk.Construct, id: string, props: ApplicationLoadBalancerProps) {\n    super(scope, id, props, {\n      type: \"application\",\n      securityGroups: new cdk.Token(() => [this.securityGroup.securityGroupId]),\n      ipAddressType: props.ipAddressType,\n    });\n\n    this.securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: `Automatically created Security Group for ELB ${this.node.uniqueId}`,\n      allowAllOutbound: false\n    });\n    this.connections = new ec2.Connections({ securityGroups: [this.securityGroup] });\n\n    if (props.http2Enabled === false) { this.setAttribute('routing.http2.enabled', 'false'); }\n    if (props.idleTimeoutSecs !== undefined) { this.setAttribute('idle_timeout.timeout_seconds', props.idleTimeoutSecs.toString()); }\n  }\n\n  /**\n   * Enable access logging for this load balancer\n   */\n  public logAccessLogs(bucket: s3.IBucket, prefix?: string) {\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 = this.node.stack.requireRegion('Enable ELBv2 access logging');\n    const account = ELBV2_ACCOUNTS[region];\n    if (!account) {\n      throw new Error(`Cannot enable access logging; don't know ELBv2 account for region ${region}`);\n    }\n\n    // FIXME: can't use grantPut() here because that only takes IAM objects, not arbitrary principals\n    bucket.addToResourcePolicy(new iam.PolicyStatement()\n      .addPrincipal(new iam.AccountPrincipal(account))\n      .addAction('s3:PutObject')\n      .addResource(bucket.arnForObjects(prefix || '', '*')));\n  }\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  /**\n   * Export this load balancer\n   */\n  public export(): ApplicationLoadBalancerImportProps {\n    return {\n      loadBalancerArn: new cdk.CfnOutput(this, 'LoadBalancerArn', { value: this.loadBalancerArn }).makeImportValue().toString(),\n      securityGroupId: this.securityGroup.export().securityGroupId,\n    };\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.MetricCustomization): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensions: { LoadBalancer: this.fullName },\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.MetricCustomization) {\n    return this.metric('ActiveConnectionCount', {\n      statistic: 'sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('ClientTLSNegotiationErrorCount', {\n      statistic: 'sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('ConsumedLCUs', {\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.MetricCustomization) {\n    return this.metric('HTTP_Fixed_Response_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('HTTP_Redirect_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\n    return this.metric('IPv6ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('NewConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('RejectedConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('RuleEvaluations', {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\n    return this.metric('ELBAuthSuccess', {\n      statistic: 'Sum',\n      ...props\n    });\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  Elb3xxCount = '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  Elb4xxCount = 'HTTPCode_ELB_4XX_Count',\n\n  /**\n   * The number of HTTP 5XX server error codes that originate from the load balancer.\n   */\n  Elb5xxCount = '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  Target2xxCount = 'HTTPCode_Target_2XX_Count',\n\n  /**\n   * The number of 3xx response codes from targets\n   */\n  Target3xxCount = 'HTTPCode_Target_3XX_Count',\n\n  /**\n   * The number of 4xx response codes from targets\n   */\n  Target4xxCount = 'HTTPCode_Target_4XX_Count',\n\n  /**\n   * The number of 5xx response codes from targets\n   */\n  Target5xxCount = 'HTTPCode_Target_5XX_Count'\n}\n\n/**\n * An application load balancer\n */\nexport interface IApplicationLoadBalancer extends cdk.IConstruct, 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   */\n  readonly vpc?: ec2.IVpcNetwork;\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;\n\n  /**\n   * Export this load balancer\n   */\n  export(): ApplicationLoadBalancerImportProps;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface ApplicationLoadBalancerImportProps {\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// https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-access-logs.html#access-logging-bucket-permissions\nconst ELBV2_ACCOUNTS: {[region: string]: string } = {\n  'us-east-1': '127311923021',\n  'us-east-2': '033677994240',\n  'us-west-1': '027434742980',\n  'us-west-2': '797873946194',\n  'ca-central-1': '985666609251',\n  'eu-central-1': '054676820928',\n  'eu-west-1': '156460612806',\n  'eu-west-2': '652711504416',\n  'eu-west-3': '009996457667',\n  'ap-northeast-1': '582318560864',\n  'ap-northeast-2': '600734575887',\n  'ap-northeast-3': '383597477331',\n  'ap-southeast-1': '114774131450',\n  'ap-southeast-2': '783225319266',\n  'ap-south-1': '718504428378',\n  'sa-east-1': '507241528517',\n  'us-gov-west-1': '048591011584',\n  'cn-north-1': '638102146993',\n  'cn-northwest-1': '037604701340',\n};\n\n/**\n * An ApplicationLoadBalancer that has been defined elsewhere\n */\nclass ImportedApplicationLoadBalancer extends cdk.Construct 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  /**\n   * VPC of the load balancer\n   *\n   * Always undefined.\n   */\n  public readonly vpc?: ec2.IVpcNetwork;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: ApplicationLoadBalancerImportProps) {\n    super(scope, id);\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.connections = new ec2.Connections({\n      securityGroups: [ec2.SecurityGroup.import(this, 'SecurityGroup', { securityGroupId: props.securityGroupId })]\n    });\n  }\n\n  public export() {\n    return this.props;\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"]}
//# 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 cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport iam = require('@aws-cdk/aws-iam');\nimport s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { BaseLoadBalancer, BaseLoadBalancerProps } from '../shared/base-load-balancer';\nimport { IpAddressType } from '../shared/enums';\nimport { ApplicationListener, BaseApplicationListenerProps } from './application-listener';\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 idleTimeoutSecs?: number;\n}\n\n/**\n * Define an Application Load Balancer\n */\nexport class ApplicationLoadBalancer extends BaseLoadBalancer implements IApplicationLoadBalancer {\n  /**\n   * Import an existing Application Load Balancer\n   */\n  public static import(scope: cdk.Construct, id: string, props: ApplicationLoadBalancerImportProps): IApplicationLoadBalancer {\n    return new ImportedApplicationLoadBalancer(scope, id, props);\n  }\n\n  public readonly connections: ec2.Connections;\n  private readonly securityGroup: ec2.ISecurityGroup;\n\n  constructor(scope: cdk.Construct, id: string, props: ApplicationLoadBalancerProps) {\n    super(scope, id, props, {\n      type: \"application\",\n      securityGroups: new cdk.Token(() => [this.securityGroup.securityGroupId]),\n      ipAddressType: props.ipAddressType,\n    });\n\n    this.securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n      vpc: props.vpc,\n      description: `Automatically created Security Group for ELB ${this.node.uniqueId}`,\n      allowAllOutbound: false\n    });\n    this.connections = new ec2.Connections({ securityGroups: [this.securityGroup] });\n\n    if (props.http2Enabled === false) { this.setAttribute('routing.http2.enabled', 'false'); }\n    if (props.idleTimeoutSecs !== undefined) { this.setAttribute('idle_timeout.timeout_seconds', props.idleTimeoutSecs.toString()); }\n  }\n\n  /**\n   * Enable access logging for this load balancer\n   */\n  public logAccessLogs(bucket: s3.IBucket, prefix?: string) {\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 = this.node.stack.requireRegion('Enable ELBv2 access logging');\n    const account = ELBV2_ACCOUNTS[region];\n    if (!account) {\n      throw new Error(`Cannot enable access logging; don't know ELBv2 account for region ${region}`);\n    }\n\n    prefix = prefix || '';\n    bucket.grantPut(new iam.AccountPrincipal(account), prefix + '*');\n\n    // make sure the bucket's policy is created before the ALB (see https://github.com/awslabs/aws-cdk/issues/1633)\n    this.node.addDependency(bucket);\n  }\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  public addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener {\n    return new ApplicationListener(this, id, {\n      loadBalancer: this,\n      ...props\n    });\n  }\n\n  /**\n   * Export this load balancer\n   */\n  public export(): ApplicationLoadBalancerImportProps {\n    return {\n      loadBalancerArn: new cdk.CfnOutput(this, 'LoadBalancerArn', { value: this.loadBalancerArn }).makeImportValue().toString(),\n      securityGroupId: this.securityGroup.export().securityGroupId,\n    };\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      dimensions: { LoadBalancer: this.fullName },\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.metric('ActiveConnectionCount', {\n      statistic: 'sum',\n      ...props\n    });\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.metric('ClientTLSNegotiationErrorCount', {\n      statistic: 'sum',\n      ...props\n    });\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.metric('ConsumedLCUs', {\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.metric('HTTP_Fixed_Response_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('HTTP_Redirect_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('HTTP_Redirect_Url_Limit_Exceeded_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('IPv6ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('NewConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('RejectedConnectionCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('RuleEvaluations', {\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  /**\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\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  Elb3xxCount = '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  Elb4xxCount = 'HTTPCode_ELB_4XX_Count',\n\n  /**\n   * The number of HTTP 5XX server error codes that originate from the load balancer.\n   */\n  Elb5xxCount = '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  Target2xxCount = 'HTTPCode_Target_2XX_Count',\n\n  /**\n   * The number of 3xx response codes from targets\n   */\n  Target3xxCount = 'HTTPCode_Target_3XX_Count',\n\n  /**\n   * The number of 4xx response codes from targets\n   */\n  Target4xxCount = 'HTTPCode_Target_4XX_Count',\n\n  /**\n   * The number of 5xx response codes from targets\n   */\n  Target5xxCount = 'HTTPCode_Target_5XX_Count'\n}\n\n/**\n * An application load balancer\n */\nexport interface IApplicationLoadBalancer extends cdk.IConstruct, 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   */\n  readonly vpc?: ec2.IVpcNetwork;\n\n  /**\n   * Add a new listener to this load balancer\n   */\n  addListener(id: string, props: BaseApplicationListenerProps): ApplicationListener;\n\n  /**\n   * Export this load balancer\n   */\n  export(): ApplicationLoadBalancerImportProps;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface ApplicationLoadBalancerImportProps {\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// https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-access-logs.html#access-logging-bucket-permissions\nconst ELBV2_ACCOUNTS: {[region: string]: string } = {\n  'us-east-1': '127311923021',\n  'us-east-2': '033677994240',\n  'us-west-1': '027434742980',\n  'us-west-2': '797873946194',\n  'ca-central-1': '985666609251',\n  'eu-central-1': '054676820928',\n  'eu-west-1': '156460612806',\n  'eu-west-2': '652711504416',\n  'eu-west-3': '009996457667',\n  'ap-northeast-1': '582318560864',\n  'ap-northeast-2': '600734575887',\n  'ap-northeast-3': '383597477331',\n  'ap-southeast-1': '114774131450',\n  'ap-southeast-2': '783225319266',\n  'ap-south-1': '718504428378',\n  'sa-east-1': '507241528517',\n  'us-gov-west-1': '048591011584',\n  'cn-north-1': '638102146993',\n  'cn-northwest-1': '037604701340',\n};\n\n/**\n * An ApplicationLoadBalancer that has been defined elsewhere\n */\nclass ImportedApplicationLoadBalancer extends cdk.Construct 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  /**\n   * VPC of the load balancer\n   *\n   * Always undefined.\n   */\n  public readonly vpc?: ec2.IVpcNetwork;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: ApplicationLoadBalancerImportProps) {\n    super(scope, id);\n\n    this.loadBalancerArn = props.loadBalancerArn;\n    this.connections = new ec2.Connections({\n      securityGroups: [ec2.SecurityGroup.import(this, 'SecurityGroup', { securityGroupId: props.securityGroupId })]\n    });\n  }\n\n  public export() {\n    return this.props;\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"]}

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

*/
metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -105,3 +105,3 @@ * The number of IPv6 requests received by the target group

*/
metricIPv6RequestCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricIPv6RequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -114,3 +114,3 @@ * The number of requests processed over IPv4 and IPv6.

*/
metricRequestCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricRequestCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -121,3 +121,3 @@ * The number of healthy hosts in the target group

*/
metricHealthyHostCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -128,3 +128,3 @@ * The number of unhealthy hosts in the target group

*/
metricUnhealthyHostCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricUnhealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -137,3 +137,3 @@ * The number of HTTP 2xx/3xx/4xx/5xx response codes generated by all targets in this target group.

*/
metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHttpCodeTarget(code: HttpCodeTarget, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -146,3 +146,3 @@ * The average number of requests received by each target in a target group.

*/
metricRequestCountPerTarget(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricRequestCountPerTarget(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -153,3 +153,3 @@ * The number of connections that were not successfully established between the load balancer and target.

*/
metricTargetConnectionErrorCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTargetConnectionErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -160,3 +160,3 @@ * The time elapsed, in seconds, after the request leaves the load balancer until a response from the target is received.

*/
metricTargetResponseTime(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTargetResponseTime(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -169,3 +169,3 @@ * The number of TLS connections initiated by the load balancer that did not establish a session with the target.

*/
metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTargetTLSNegotiationErrorCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
}

@@ -172,0 +172,0 @@ /**

@@ -107,6 +107,11 @@ "use strict";

metric(metricName, props) {
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/ApplicationELB', metricName, dimensions: {
return new cloudwatch.Metric({
namespace: 'AWS/ApplicationELB',
metricName,
dimensions: {
TargetGroup: this.targetGroupFullName,
LoadBalancer: this.firstLoadBalancerFullName,
} }, props));
},
...props
});
}

@@ -119,3 +124,6 @@ /**

metricIPv6RequestCount(props) {
return this.metric('IPv6RequestCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('IPv6RequestCount', {
statistic: 'Sum',
...props
});
}

@@ -130,3 +138,6 @@ /**

metricRequestCount(props) {
return this.metric('RequestCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('RequestCount', {
statistic: 'Sum',
...props
});
}

@@ -139,3 +150,6 @@ /**

metricHealthyHostCount(props) {
return this.metric('HealthyHostCount', Object.assign({ statistic: 'Average' }, props));
return this.metric('HealthyHostCount', {
statistic: 'Average',
...props
});
}

@@ -148,3 +162,6 @@ /**

metricUnhealthyHostCount(props) {
return this.metric('UnhealthyHostCount', Object.assign({ statistic: 'Average' }, props));
return this.metric('UnhealthyHostCount', {
statistic: 'Average',
...props
});
}

@@ -159,3 +176,6 @@ /**

metricHttpCodeTarget(code, props) {
return this.metric(code, Object.assign({ statistic: 'Sum' }, props));
return this.metric(code, {
statistic: 'Sum',
...props
});
}

@@ -170,3 +190,6 @@ /**

metricRequestCountPerTarget(props) {
return this.metric('RequestCountPerTarget', Object.assign({ statistic: 'Sum' }, props));
return this.metric('RequestCountPerTarget', {
statistic: 'Sum',
...props
});
}

@@ -179,3 +202,6 @@ /**

metricTargetConnectionErrorCount(props) {
return this.metric('TargetConnectionErrorCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('TargetConnectionErrorCount', {
statistic: 'Sum',
...props
});
}

@@ -188,3 +214,6 @@ /**

metricTargetResponseTime(props) {
return this.metric('TargetResponseTime', Object.assign({ statistic: 'Average' }, props));
return this.metric('TargetResponseTime', {
statistic: 'Average',
...props
});
}

@@ -199,3 +228,6 @@ /**

metricTargetTLSNegotiationErrorCount(props) {
return this.metric('TargetTLSNegotiationErrorCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('TargetTLSNegotiationErrorCount', {
statistic: 'Sum',
...props
});
}

@@ -212,2 +244,2 @@ }

}
//# 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 cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { BaseTargetGroupProps, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n         TargetGroupBase, TargetGroupImportProps } from '../shared/base-target-group';\nimport { ApplicationProtocol } 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/**\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\n   */\n  readonly protocol?: ApplicationProtocol;\n\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   * 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 slowStartSec?: number;\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 86400 (1 day)\n   */\n  readonly stickinessCookieDurationSec?: number;\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?: 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 import(scope: cdk.Construct, id: string, props: TargetGroupImportProps): IApplicationTargetGroup {\n    return new ImportedApplicationTargetGroup(scope, id, props);\n  }\n\n  private readonly connectableMembers: ConnectableMember[];\n  private readonly listeners: IApplicationListener[];\n\n  constructor(scope: cdk.Construct, id: string, props: ApplicationTargetGroupProps) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n\n    super(scope, id, props, {\n      protocol,\n      port,\n    });\n\n    this.connectableMembers = [];\n    this.listeners = [];\n\n    if (props.slowStartSec !== undefined) {\n      this.setAttribute('slow_start.duration_seconds', props.slowStartSec.toString());\n    }\n    if (props.stickinessCookieDurationSec !== undefined) {\n      this.enableCookieStickiness(props.stickinessCookieDurationSec);\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: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n  }\n\n  /**\n   * Enable sticky routing via a cookie to members of this target group\n   */\n  public enableCookieStickiness(durationSec: number) {\n    this.setAttribute('stickiness.enabled', 'true');\n    this.setAttribute('stickiness.type', 'lb_cookie');\n    this.setAttribute('stickiness.lb_cookie.duration_seconds', durationSec.toString());\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.IPortRange) {\n    if (portRange === undefined) {\n      if (cdk.unresolved(this.defaultPort)) {\n        portRange = new ec2.TcpPortFromAttribute(this.defaultPort);\n      } else {\n        portRange = new ec2.TcpPort(parseInt(this.defaultPort, 10));\n      }\n    }\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?: cdk.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);\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.MetricCustomization): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ApplicationELB',\n      metricName,\n      dimensions: {\n        TargetGroup: this.targetGroupFullName,\n        LoadBalancer: this.firstLoadBalancerFullName,\n      },\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\n    return this.metric('TargetTLSNegotiationErrorCount', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\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.IPortRange;\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?: cdk.IConstruct): void;\n}\n\n/**\n * An imported application target group\n */\nclass ImportedApplicationTargetGroup extends ImportedTargetGroupBase implements IApplicationTargetGroup {\n  public registerListener(_listener: IApplicationListener, _associatingConstruct?: cdk.IConstruct) {\n    // Nothing to do, we know nothing of our members\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: ApplicationTargetGroup): LoadBalancerTargetProps;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-target-group.js","sourceRoot":"","sources":["application-target-group.ts"],"names":[],"mappings":";;AAAA,sDAAuD;AACvD,wCAAyC;AACzC,oCAAqC;AACrC,mEACsF;AAEtF,iDAA6D;AAC7D,yCAA0D;AAsD1D;;GAEG;AACH,MAAa,sBAAuB,SAAQ,mCAAe;IACzD;;OAEG;IACI,MAAM,CAAC,MAAM,CAAC,KAAoB,EAAE,EAAU,EAAE,KAA6B;QAClF,OAAO,IAAI,8BAA8B,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;IAC9D,CAAC;IAKD,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAkC;QAC9E,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,GAAG,+BAAwB,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAE9E,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;YACtB,QAAQ;YACR,IAAI;SACL,CAAC,CAAC;QAEH,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QAEpB,IAAI,KAAK,CAAC,YAAY,KAAK,SAAS,EAAE;YACpC,IAAI,CAAC,YAAY,CAAC,6BAA6B,EAAE,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,CAAC;SACjF;QACD,IAAI,KAAK,CAAC,2BAA2B,KAAK,SAAS,EAAE;YACnD,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;SAChE;QAED,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACI,SAAS,CAAC,GAAG,OAAyC;QAC3D,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC5B,MAAM,MAAM,GAAG,MAAM,CAAC,8BAA8B,CAAC,IAAI,CAAC,CAAC;YAC3D,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;SACpC;IACH,CAAC;IAED;;OAEG;IACI,sBAAsB,CAAC,WAAmB;QAC/C,IAAI,CAAC,YAAY,CAAC,oBAAoB,EAAE,MAAM,CAAC,CAAC;QAChD,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE,WAAW,CAAC,CAAC;QAClD,IAAI,CAAC,YAAY,CAAC,uCAAuC,EAAE,WAAW,CAAC,QAAQ,EAAE,CAAC,CAAC;IACrF,CAAC;IAED;;;;OAIG;IACI,mBAAmB,CAAC,WAA6B,EAAE,SAA0B;QAClF,IAAI,SAAS,KAAK,SAAS,EAAE;YAC3B,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;gBACpC,SAAS,GAAG,IAAI,GAAG,CAAC,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC5D;iBAAM;gBACL,SAAS,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,CAAC;aAC7D;SACF;QAED,2EAA2E;QAC3E,8DAA8D;QAC9D,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,SAAS,EAAE,CAAC,CAAC;QACzD,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE;YACrC,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;SACtD;IACH,CAAC;IAED;;;;OAIG;IACI,gBAAgB,CAAC,QAA8B,EAAE,oBAAqC;QAC3F,+DAA+D;QAC/D,iEAAiE;QACjE,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC5C,QAAQ,CAAC,mBAAmB,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;SACpE;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9B,IAAI,CAAC,gCAAgC,CAAC,GAAG,CAAC,oBAAoB,IAAI,QAAQ,CAAC,CAAC;IAC9E,CAAC;IAED;;OAEG;IACH,IAAW,yBAAyB;QAClC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,wFAAwF,CAAC,CAAC;SAC3G;QACD,OAAO,mDAA+B,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IACxE,CAAC;IAED;;;;;;;;;OASG;IACI,MAAM,CAAC,UAAkB,EAAE,KAAgC;QAChE,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC;YAC3B,SAAS,EAAE,oBAAoB;YAC/B,UAAU;YACV,UAAU,EAAE;gBACV,WAAW,EAAE,IAAI,CAAC,mBAAmB;gBACrC,YAAY,EAAE,IAAI,CAAC,yBAAyB;aAC7C;YACD,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,sBAAsB,CAAC,KAAgC;QAC5D,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE;YACrC,SAAS,EAAE,KAAK;YAChB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB,CAAC,KAAgC;QACxD,OAAO,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE;YACjC,SAAS,EAAE,KAAK;YAChB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,sBAAsB,CAAC,KAAgC;QAC5D,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE;YACrC,SAAS,EAAE,SAAS;YACpB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,wBAAwB,CAAC,KAAgC;QAC9D,OAAO,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE;YACvC,SAAS,EAAE,SAAS;YACpB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACI,oBAAoB,CAAC,IAAoB,EAAE,KAAgC;QAChF,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YACvB,SAAS,EAAE,KAAK;YAChB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACI,2BAA2B,CAAC,KAAgC;QACjE,OAAO,IAAI,CAAC,MAAM,CAAC,uBAAuB,EAAE;YAC1C,SAAS,EAAE,KAAK;YAChB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,gCAAgC,CAAC,KAAgC;QACtE,OAAO,IAAI,CAAC,MAAM,CAAC,4BAA4B,EAAE;YAC/C,SAAS,EAAE,KAAK;YAChB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,wBAAwB,CAAC,KAAgC;QAC9D,OAAO,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE;YACvC,SAAS,EAAE,SAAS;YACpB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACI,oCAAoC,CAAC,KAAgC;QAC1E,OAAO,IAAI,CAAC,MAAM,CAAC,gCAAgC,EAAE;YACnD,SAAS,EAAE,KAAK;YAChB,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;CAEF;AA5OD,wDA4OC;AA6BD;;GAEG;AACH,MAAM,8BAA+B,SAAQ,kCAAuB;IAC3D,gBAAgB,CAAC,SAA+B,EAAE,qBAAsC;QAC7F,gDAAgD;IAClD,CAAC;CACF","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { BaseTargetGroupProps, ITargetGroup, loadBalancerNameFromListenerArn, LoadBalancerTargetProps,\n         TargetGroupBase, TargetGroupImportProps } from '../shared/base-target-group';\nimport { ApplicationProtocol } 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/**\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\n   */\n  readonly protocol?: ApplicationProtocol;\n\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   * 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 slowStartSec?: number;\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 86400 (1 day)\n   */\n  readonly stickinessCookieDurationSec?: number;\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?: 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 import(scope: cdk.Construct, id: string, props: TargetGroupImportProps): IApplicationTargetGroup {\n    return new ImportedApplicationTargetGroup(scope, id, props);\n  }\n\n  private readonly connectableMembers: ConnectableMember[];\n  private readonly listeners: IApplicationListener[];\n\n  constructor(scope: cdk.Construct, id: string, props: ApplicationTargetGroupProps) {\n    const [protocol, port] = determineProtocolAndPort(props.protocol, props.port);\n\n    super(scope, id, props, {\n      protocol,\n      port,\n    });\n\n    this.connectableMembers = [];\n    this.listeners = [];\n\n    if (props.slowStartSec !== undefined) {\n      this.setAttribute('slow_start.duration_seconds', props.slowStartSec.toString());\n    }\n    if (props.stickinessCookieDurationSec !== undefined) {\n      this.enableCookieStickiness(props.stickinessCookieDurationSec);\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: IApplicationLoadBalancerTarget[]) {\n    for (const target of targets) {\n      const result = target.attachToApplicationTargetGroup(this);\n      this.addLoadBalancerTarget(result);\n    }\n  }\n\n  /**\n   * Enable sticky routing via a cookie to members of this target group\n   */\n  public enableCookieStickiness(durationSec: number) {\n    this.setAttribute('stickiness.enabled', 'true');\n    this.setAttribute('stickiness.type', 'lb_cookie');\n    this.setAttribute('stickiness.lb_cookie.duration_seconds', durationSec.toString());\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.IPortRange) {\n    if (portRange === undefined) {\n      if (cdk.unresolved(this.defaultPort)) {\n        portRange = new ec2.TcpPortFromAttribute(this.defaultPort);\n      } else {\n        portRange = new ec2.TcpPort(parseInt(this.defaultPort, 10));\n      }\n    }\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?: cdk.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);\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      dimensions: {\n        TargetGroup: this.targetGroupFullName,\n        LoadBalancer: this.firstLoadBalancerFullName,\n      },\n      ...props\n    });\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.metric('IPv6RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('RequestCount', {\n      statistic: 'Sum',\n      ...props\n    });\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}\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.IPortRange;\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?: cdk.IConstruct): void;\n}\n\n/**\n * An imported application target group\n */\nclass ImportedApplicationTargetGroup extends ImportedTargetGroupBase implements IApplicationTargetGroup {\n  public registerListener(_listener: IApplicationListener, _associatingConstruct?: cdk.IConstruct) {\n    // Nothing to do, we know nothing of our members\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: ApplicationTargetGroup): LoadBalancerTargetProps;\n}\n"]}

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

*/
metric(metricName: string, props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -49,3 +49,3 @@ * The total number of concurrent TCP flows (or connections) from clients to targets.

*/
metricActiveFlowCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricActiveFlowCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -56,3 +56,3 @@ * The number of load balancer capacity units (LCU) used by your load balancer.

*/
metricConsumedLCUs(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricConsumedLCUs(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -63,3 +63,3 @@ * The number of targets that are considered healthy.

*/
metricHealthyHostCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricHealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -70,3 +70,3 @@ * The number of targets that are considered unhealthy.

*/
metricUnHealthyHostCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricUnHealthyHostCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -77,3 +77,3 @@ * The total number of new TCP flows (or connections) established from clients to targets in the time period.

*/
metricNewFlowCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricNewFlowCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -84,3 +84,3 @@ * The total number of bytes processed by the load balancer, including TCP/IP headers.

*/
metricProcessedBytes(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricProcessedBytes(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -93,3 +93,3 @@ * The total number of reset (RST) packets sent from a client to a target.

*/
metricTcpClientResetCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTcpClientResetCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -100,3 +100,3 @@ * The total number of reset (RST) packets generated by the load balancer.

*/
metricTcpElbResetCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTcpElbResetCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
/**

@@ -109,3 +109,3 @@ * The total number of reset (RST) packets sent from a target to a client.

*/
metricTcpTargetResetCount(props?: cloudwatch.MetricCustomization): cloudwatch.Metric;
metricTcpTargetResetCount(props?: cloudwatch.MetricOptions): cloudwatch.Metric;
}

@@ -112,0 +112,0 @@ /**

@@ -28,3 +28,6 @@ "use strict";

addListener(id, props) {
return new network_listener_1.NetworkListener(this, id, Object.assign({ loadBalancer: this }, props));
return new network_listener_1.NetworkListener(this, id, {
loadBalancer: this,
...props
});
}

@@ -45,3 +48,8 @@ /**

metric(metricName, props) {
return new cloudwatch.Metric(Object.assign({ namespace: 'AWS/NetworkELB', metricName, dimensions: { LoadBalancer: this.fullName } }, props));
return new cloudwatch.Metric({
namespace: 'AWS/NetworkELB',
metricName,
dimensions: { LoadBalancer: this.fullName },
...props
});
}

@@ -58,3 +66,6 @@ /**

metricActiveFlowCount(props) {
return this.metric('ActiveFlowCount', Object.assign({ statistic: 'Average' }, props));
return this.metric('ActiveFlowCount', {
statistic: 'Average',
...props
});
}

@@ -67,3 +78,6 @@ /**

metricConsumedLCUs(props) {
return this.metric('ConsumedLCUs', Object.assign({ statistic: 'Sum' }, props));
return this.metric('ConsumedLCUs', {
statistic: 'Sum',
...props
});
}

@@ -76,3 +90,6 @@ /**

metricHealthyHostCount(props) {
return this.metric('HealthyHostCount', Object.assign({ statistic: 'Average' }, props));
return this.metric('HealthyHostCount', {
statistic: 'Average',
...props
});
}

@@ -85,3 +102,6 @@ /**

metricUnHealthyHostCount(props) {
return this.metric('UnHealthyHostCount', Object.assign({ statistic: 'Average' }, props));
return this.metric('UnHealthyHostCount', {
statistic: 'Average',
...props
});
}

@@ -94,3 +114,6 @@ /**

metricNewFlowCount(props) {
return this.metric('NewFlowCount', Object.assign({ statistic: 'Sum' }, props));
return this.metric('NewFlowCount', {
statistic: 'Sum',
...props
});
}

@@ -103,3 +126,6 @@ /**

metricProcessedBytes(props) {
return this.metric('ProcessedBytes', Object.assign({ statistic: 'Sum' }, props));
return this.metric('ProcessedBytes', {
statistic: 'Sum',
...props
});
}

@@ -114,3 +140,6 @@ /**

metricTcpClientResetCount(props) {
return this.metric('TCP_Client_Reset_Count', Object.assign({ statistic: 'Sum' }, props));
return this.metric('TCP_Client_Reset_Count', {
statistic: 'Sum',
...props
});
}

@@ -123,3 +152,6 @@ /**

metricTcpElbResetCount(props) {
return this.metric('TCP_ELB_Reset_Count', Object.assign({ statistic: 'Sum' }, props));
return this.metric('TCP_ELB_Reset_Count', {
statistic: 'Sum',
...props
});
}

@@ -134,3 +166,6 @@ /**

metricTcpTargetResetCount(props) {
return this.metric('TCP_Target_Reset_Count', Object.assign({ statistic: 'Sum' }, props));
return this.metric('TCP_Target_Reset_Count', {
statistic: 'Sum',
...props
});
}

@@ -157,5 +192,8 @@ }

addListener(id, props) {
return new network_listener_1.NetworkListener(this, id, Object.assign({ loadBalancer: this }, props));
return new network_listener_1.NetworkListener(this, id, {
loadBalancer: this,
...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 cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { BaseLoadBalancer, BaseLoadBalancerProps } 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 * Define a new network load balancer\n */\nexport class NetworkLoadBalancer extends BaseLoadBalancer implements INetworkLoadBalancer {\n  public static import(scope: cdk.Construct, id: string, props: NetworkLoadBalancerImportProps): INetworkLoadBalancer {\n    return new ImportedNetworkLoadBalancer(scope, id, props);\n  }\n\n  constructor(scope: cdk.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   * Export this load balancer\n   */\n  public export(): NetworkLoadBalancerImportProps {\n    return {\n      loadBalancerArn: new cdk.CfnOutput(this, 'LoadBalancerArn', { value: this.loadBalancerArn }).makeImportValue().toString()\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.MetricCustomization): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/NetworkELB',\n      metricName,\n      dimensions: { LoadBalancer: this.fullName },\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('ActiveFlowCount', {\n      statistic: 'Average',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('ConsumedLCUs', {\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   */\n  public metricHealthyHostCount(props?: cloudwatch.MetricCustomization) {\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.MetricCustomization) {\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.MetricCustomization) {\n    return this.metric('NewFlowCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('TCP_Client_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('TCP_ELB_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.MetricCustomization) {\n    return this.metric('TCP_Target_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n}\n\n/**\n * A network load balancer\n */\nexport interface INetworkLoadBalancer extends cdk.IConstruct {\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   */\n  readonly vpc?: ec2.IVpcNetwork;\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  /**\n   * Export this load balancer\n   */\n  export(): NetworkLoadBalancerImportProps;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface NetworkLoadBalancerImportProps {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n}\n\n/**\n * An imported network load balancer\n */\nclass ImportedNetworkLoadBalancer extends cdk.Construct implements INetworkLoadBalancer {\n  /**\n   * ARN of the load balancer\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * VPC of the load balancer\n   *\n   * Always undefined.\n   */\n  public readonly vpc?: ec2.IVpcNetwork;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: NetworkLoadBalancerImportProps) {\n    super(scope, id);\n\n    this.loadBalancerArn = props.loadBalancerArn;\n  }\n\n  public export() {\n    return this.props;\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"]}
//# 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 cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { BaseLoadBalancer, BaseLoadBalancerProps } 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 * Define a new network load balancer\n */\nexport class NetworkLoadBalancer extends BaseLoadBalancer implements INetworkLoadBalancer {\n  public static import(scope: cdk.Construct, id: string, props: NetworkLoadBalancerImportProps): INetworkLoadBalancer {\n    return new ImportedNetworkLoadBalancer(scope, id, props);\n  }\n\n  constructor(scope: cdk.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   * Export this load balancer\n   */\n  public export(): NetworkLoadBalancerImportProps {\n    return {\n      loadBalancerArn: new cdk.CfnOutput(this, 'LoadBalancerArn', { value: this.loadBalancerArn }).makeImportValue().toString()\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.fullName },\n      ...props\n    });\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.metric('ActiveFlowCount', {\n      statistic: 'Average',\n      ...props\n    });\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.metric('ConsumedLCUs', {\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   */\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   * 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.metric('NewFlowCount', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('ProcessedBytes', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('TCP_Client_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('TCP_ELB_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\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.metric('TCP_Target_Reset_Count', {\n      statistic: 'Sum',\n      ...props\n    });\n  }\n}\n\n/**\n * A network load balancer\n */\nexport interface INetworkLoadBalancer extends cdk.IConstruct {\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   */\n  readonly vpc?: ec2.IVpcNetwork;\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  /**\n   * Export this load balancer\n   */\n  export(): NetworkLoadBalancerImportProps;\n}\n\n/**\n * Properties to reference an existing load balancer\n */\nexport interface NetworkLoadBalancerImportProps {\n  /**\n   * ARN of the load balancer\n   */\n  readonly loadBalancerArn: string;\n}\n\n/**\n * An imported network load balancer\n */\nclass ImportedNetworkLoadBalancer extends cdk.Construct implements INetworkLoadBalancer {\n  /**\n   * ARN of the load balancer\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * VPC of the load balancer\n   *\n   * Always undefined.\n   */\n  public readonly vpc?: ec2.IVpcNetwork;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: NetworkLoadBalancerImportProps) {\n    super(scope, id);\n\n    this.loadBalancerArn = props.loadBalancerArn;\n  }\n\n  public export() {\n    return this.props;\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"]}

@@ -12,3 +12,6 @@ "use strict";

this.defaultActions = [];
const resource = new elasticloadbalancingv2_generated_1.CfnListener(this, 'Resource', Object.assign({}, additionalProps, { defaultActions: new cdk.Token(() => this.defaultActions) }));
const resource = new elasticloadbalancingv2_generated_1.CfnListener(this, 'Resource', {
...additionalProps,
defaultActions: new cdk.Token(() => this.defaultActions),
});
this.listenerArn = resource.ref;

@@ -37,2 +40,2 @@ }

exports.BaseListener = BaseListener;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1saXN0ZW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImJhc2UtbGlzdGVuZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsMEZBQWtFO0FBR2xFOztHQUVHO0FBQ0gsTUFBc0IsWUFBYSxTQUFRLEdBQUcsQ0FBQyxTQUFTO0lBSXRELFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQUUsZUFBb0I7UUFDaEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUhGLG1CQUFjLEdBQVUsRUFBRSxDQUFDO1FBSzFDLE1BQU0sUUFBUSxHQUFHLElBQUksOENBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxvQkFDNUMsZUFBZSxJQUNsQixjQUFjLEVBQUUsSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFDeEQsQ0FBQztRQUVILElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7O09BRUc7SUFDTyxRQUFRO1FBQ2hCLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ3BDLE9BQU8sQ0FBQyx5RUFBeUUsQ0FBQyxDQUFDO1NBQ3BGO1FBQ0QsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0lBRUQ7OztPQUdHO0lBQ08sc0JBQXNCLENBQUMsV0FBeUI7UUFDeEQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUM7WUFDdkIsY0FBYyxFQUFFLFdBQVcsQ0FBQyxjQUFjO1lBQzFDLElBQUksRUFBRSxTQUFTO1NBQ2hCLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQW5DRCxvQ0FtQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBDZm5MaXN0ZW5lciB9IGZyb20gJy4uL2VsYXN0aWNsb2FkYmFsYW5jaW5ndjIuZ2VuZXJhdGVkJztcbmltcG9ydCB7IElUYXJnZXRHcm91cCB9IGZyb20gJy4vYmFzZS10YXJnZXQtZ3JvdXAnO1xuXG4vKipcbiAqIEJhc2UgY2xhc3MgZm9yIGxpc3RlbmVyc1xuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUxpc3RlbmVyIGV4dGVuZHMgY2RrLkNvbnN0cnVjdCB7XG4gIHB1YmxpYyByZWFkb25seSBsaXN0ZW5lckFybjogc3RyaW5nO1xuICBwcml2YXRlIHJlYWRvbmx5IGRlZmF1bHRBY3Rpb25zOiBhbnlbXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBjZGsuQ29uc3RydWN0LCBpZDogc3RyaW5nLCBhZGRpdGlvbmFsUHJvcHM6IGFueSkge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBjb25zdCByZXNvdXJjZSA9IG5ldyBDZm5MaXN0ZW5lcih0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICAuLi5hZGRpdGlvbmFsUHJvcHMsXG4gICAgICBkZWZhdWx0QWN0aW9uczogbmV3IGNkay5Ub2tlbigoKSA9PiB0aGlzLmRlZmF1bHRBY3Rpb25zKSxcbiAgICB9KTtcblxuICAgIHRoaXMubGlzdGVuZXJBcm4gPSByZXNvdXJjZS5yZWY7XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGUgdGhpcyBsaXN0ZW5lclxuICAgKi9cbiAgcHJvdGVjdGVkIHZhbGlkYXRlKCk6IHN0cmluZ1tdIHtcbiAgICBpZiAodGhpcy5kZWZhdWx0QWN0aW9ucy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybiBbJ0xpc3RlbmVyIG5lZWRzIGF0IGxlYXN0IG9uZSBkZWZhdWx0IHRhcmdldCBncm91cCAoY2FsbCBhZGRUYXJnZXRHcm91cHMpJ107XG4gICAgfVxuICAgIHJldHVybiBbXTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGQgYSBUYXJnZXRHcm91cCB0byB0aGUgbGlzdCBvZiBkZWZhdWx0IGFjdGlvbnMgb2YgdGhpcyBsaXN0ZW5lclxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHByb3RlY3RlZCBfYWRkRGVmYXVsdFRhcmdldEdyb3VwKHRhcmdldEdyb3VwOiBJVGFyZ2V0R3JvdXApIHtcbiAgICB0aGlzLmRlZmF1bHRBY3Rpb25zLnB1c2goe1xuICAgICAgdGFyZ2V0R3JvdXBBcm46IHRhcmdldEdyb3VwLnRhcmdldEdyb3VwQXJuLFxuICAgICAgdHlwZTogJ2ZvcndhcmQnXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1saXN0ZW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImJhc2UtbGlzdGVuZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsMEZBQWtFO0FBR2xFOztHQUVHO0FBQ0gsTUFBc0IsWUFBYSxTQUFRLEdBQUcsQ0FBQyxTQUFTO0lBSXRELFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQUUsZUFBb0I7UUFDaEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUhGLG1CQUFjLEdBQVUsRUFBRSxDQUFDO1FBSzFDLE1BQU0sUUFBUSxHQUFHLElBQUksOENBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ2pELEdBQUcsZUFBZTtZQUNsQixjQUFjLEVBQUUsSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7U0FDekQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDO0lBQ2xDLENBQUM7SUFFRDs7T0FFRztJQUNPLFFBQVE7UUFDaEIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDcEMsT0FBTyxDQUFDLHlFQUF5RSxDQUFDLENBQUM7U0FDcEY7UUFDRCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRDs7O09BR0c7SUFDTyxzQkFBc0IsQ0FBQyxXQUF5QjtRQUN4RCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztZQUN2QixjQUFjLEVBQUUsV0FBVyxDQUFDLGNBQWM7WUFDMUMsSUFBSSxFQUFFLFNBQVM7U0FDaEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBbkNELG9DQW1DQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IENmbkxpc3RlbmVyIH0gZnJvbSAnLi4vZWxhc3RpY2xvYWRiYWxhbmNpbmd2Mi5nZW5lcmF0ZWQnO1xuaW1wb3J0IHsgSVRhcmdldEdyb3VwIH0gZnJvbSAnLi9iYXNlLXRhcmdldC1ncm91cCc7XG5cbi8qKlxuICogQmFzZSBjbGFzcyBmb3IgbGlzdGVuZXJzXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlTGlzdGVuZXIgZXh0ZW5kcyBjZGsuQ29uc3RydWN0IHtcbiAgcHVibGljIHJlYWRvbmx5IGxpc3RlbmVyQXJuOiBzdHJpbmc7XG4gIHByaXZhdGUgcmVhZG9ubHkgZGVmYXVsdEFjdGlvbnM6IGFueVtdID0gW107XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIGFkZGl0aW9uYWxQcm9wczogYW55KSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGNvbnN0IHJlc291cmNlID0gbmV3IENmbkxpc3RlbmVyKHRoaXMsICdSZXNvdXJjZScsIHtcbiAgICAgIC4uLmFkZGl0aW9uYWxQcm9wcyxcbiAgICAgIGRlZmF1bHRBY3Rpb25zOiBuZXcgY2RrLlRva2VuKCgpID0+IHRoaXMuZGVmYXVsdEFjdGlvbnMpLFxuICAgIH0pO1xuXG4gICAgdGhpcy5saXN0ZW5lckFybiA9IHJlc291cmNlLnJlZjtcbiAgfVxuXG4gIC8qKlxuICAgKiBWYWxpZGF0ZSB0aGlzIGxpc3RlbmVyXG4gICAqL1xuICBwcm90ZWN0ZWQgdmFsaWRhdGUoKTogc3RyaW5nW10ge1xuICAgIGlmICh0aGlzLmRlZmF1bHRBY3Rpb25zLmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIFsnTGlzdGVuZXIgbmVlZHMgYXQgbGVhc3Qgb25lIGRlZmF1bHQgdGFyZ2V0IGdyb3VwIChjYWxsIGFkZFRhcmdldEdyb3VwcyknXTtcbiAgICB9XG4gICAgcmV0dXJuIFtdO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhIFRhcmdldEdyb3VwIHRvIHRoZSBsaXN0IG9mIGRlZmF1bHQgYWN0aW9ucyBvZiB0aGlzIGxpc3RlbmVyXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgcHJvdGVjdGVkIF9hZGREZWZhdWx0VGFyZ2V0R3JvdXAodGFyZ2V0R3JvdXA6IElUYXJnZXRHcm91cCkge1xuICAgIHRoaXMuZGVmYXVsdEFjdGlvbnMucHVzaCh7XG4gICAgICB0YXJnZXRHcm91cEFybjogdGFyZ2V0R3JvdXAudGFyZ2V0R3JvdXBBcm4sXG4gICAgICB0eXBlOiAnZm9yd2FyZCdcbiAgICB9KTtcbiAgfVxufVxuIl19

@@ -19,7 +19,13 @@ "use strict";

const vpcSubnets = util_1.ifUndefined(baseProps.vpcSubnets, { subnetType: internetFacing ? ec2.SubnetType.Public : ec2.SubnetType.Private });
const subnets = baseProps.vpc.subnetIds(vpcSubnets);
const { subnetIds, internetConnectedDependency } = baseProps.vpc.selectSubnets(vpcSubnets);
this.vpc = baseProps.vpc;
const resource = new elasticloadbalancingv2_generated_1.CfnLoadBalancer(this, 'Resource', Object.assign({ name: baseProps.loadBalancerName, subnets, scheme: internetFacing ? 'internet-facing' : 'internal', loadBalancerAttributes: new cdk.Token(() => util_1.renderAttributes(this.attributes)) }, additionalProps));
const resource = new elasticloadbalancingv2_generated_1.CfnLoadBalancer(this, 'Resource', {
name: baseProps.loadBalancerName,
subnets: subnetIds,
scheme: internetFacing ? 'internet-facing' : 'internal',
loadBalancerAttributes: new cdk.Token(() => util_1.renderAttributes(this.attributes)),
...additionalProps
});
if (internetFacing) {
resource.node.addDependency(baseProps.vpc.subnetInternetDependencies(vpcSubnets));
resource.node.addDependency(internetConnectedDependency);
}

@@ -57,2 +63,2 @@ if (baseProps.deletionProtection) {

exports.BaseLoadBalancer = BaseLoadBalancer;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-load-balancer.js","sourceRoot":"","sources":["base-load-balancer.ts"],"names":[],"mappings":";;AAAA,wCAAyC;AAEzC,oCAAqC;AACrC,0FAAsE;AACtE,iCAAmE;AAwCnE;;GAEG;AACH,MAAsB,gBAAiB,SAAQ,GAAG,CAAC,SAAS;IAgD1D,YAAY,KAAoB,EAAE,EAAU,EAAE,SAAgC,EAAE,eAAoB;QAClG,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QANnB;;WAEG;QACc,eAAU,GAAe,EAAE,CAAC;QAK3C,MAAM,cAAc,GAAG,kBAAW,CAAC,SAAS,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAEpE,MAAM,UAAU,GAAG,kBAAW,CAAC,SAAS,CAAC,UAAU,EACjD,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;QAEnF,MAAM,OAAO,GAAG,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAEpD,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,GAAG,CAAC;QAEzB,MAAM,QAAQ,GAAG,IAAI,kDAAe,CAAC,IAAI,EAAE,UAAU,kBACnD,IAAI,EAAE,SAAS,CAAC,gBAAgB,EAChC,OAAO,EACP,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,UAAU,EACvD,sBAAsB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,uBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAC3E,eAAe,EAClB,CAAC;QACH,IAAI,cAAc,EAAE;YAClB,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,0BAA0B,CAAC,UAAU,CAAC,CAAC,CAAC;SACnF;QAED,IAAI,SAAS,CAAC,kBAAkB,EAAE;YAAE,IAAI,CAAC,YAAY,CAAC,6BAA6B,EAAE,MAAM,CAAC,CAAC;SAAE;QAE/F,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC,iCAAiC,CAAC;QACxE,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,mBAAmB,CAAC;QAC5C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,oBAAoB,CAAC;QAC9C,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC;QAClD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,GAAG,CAAC;IACtC,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,GAAW,EAAE,KAAyB;QACxD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;OAEG;IACI,eAAe,CAAC,GAAW;QAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;IACpC,CAAC;IAEM,mBAAmB;QACxB,OAAO;YACL,YAAY,EAAE,IAAI,CAAC,qBAAqB;YACxC,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC;IACJ,CAAC;CACF;AAtGD,4CAsGC","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport route53 = require('@aws-cdk/aws-route53');\nimport cdk = require('@aws-cdk/cdk');\nimport { CfnLoadBalancer } from '../elasticloadbalancingv2.generated';\nimport { Attributes, ifUndefined, 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.IVpcNetwork;\n\n  /**\n   * Whether the load balancer has an internet-routable address\n   *\n   * @default false\n   */\n  readonly internetFacing?: boolean;\n\n  /**\n   * Where in the VPC to place the load balancer\n   *\n   * @default Public subnets if internetFacing, otherwise private subnets\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\n/**\n * Base class for both Application and Network Load Balancers\n */\nexport abstract class BaseLoadBalancer extends cdk.Construct implements route53.IAliasRecordTarget {\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @example  Z2P70J7EXAMPLE\n   */\n  public readonly canonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @example my-load-balancer-424835706.us-west-2.elb.amazonaws.com\n   */\n  public readonly dnsName: string;\n\n  /**\n   * The full name of this load balancer\n   *\n   * @example app/my-load-balancer/50dc6c495c0c9188\n   */\n  public readonly fullName: string;\n\n  /**\n   * The name of this load balancer\n   *\n   * @example my-load-balancer\n   */\n  public readonly loadBalancerName: string;\n\n  /**\n   * The ARN of this load balancer\n   *\n   * @example arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-internal-load-balancer/50dc6c495c0c9188\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * The VPC this load balancer has been created in, if available\n   *\n   * If the Load Balancer was imported, the VPC is not available.\n   */\n  public readonly vpc?: ec2.IVpcNetwork;\n\n  /**\n   * Attributes set on this load balancer\n   */\n  private readonly attributes: Attributes = {};\n\n  constructor(scope: cdk.Construct, id: string, baseProps: BaseLoadBalancerProps, additionalProps: any) {\n    super(scope, id);\n\n    const internetFacing = ifUndefined(baseProps.internetFacing, false);\n\n    const vpcSubnets = ifUndefined(baseProps.vpcSubnets,\n      { subnetType: internetFacing ? ec2.SubnetType.Public : ec2.SubnetType.Private });\n\n    const subnets = baseProps.vpc.subnetIds(vpcSubnets);\n\n    this.vpc = baseProps.vpc;\n\n    const resource = new CfnLoadBalancer(this, 'Resource', {\n      name: baseProps.loadBalancerName,\n      subnets,\n      scheme: internetFacing ? 'internet-facing' : 'internal',\n      loadBalancerAttributes: new cdk.Token(() => renderAttributes(this.attributes)),\n      ...additionalProps\n    });\n    if (internetFacing) {\n      resource.node.addDependency(baseProps.vpc.subnetInternetDependencies(vpcSubnets));\n    }\n\n    if (baseProps.deletionProtection) { this.setAttribute('deletion_protection.enabled', 'true'); }\n\n    this.canonicalHostedZoneId = resource.loadBalancerCanonicalHostedZoneId;\n    this.dnsName = resource.loadBalancerDnsName;\n    this.fullName = resource.loadBalancerFullName;\n    this.loadBalancerName = resource.loadBalancerName;\n    this.loadBalancerArn = resource.ref;\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  public asAliasRecordTarget(): route53.AliasRecordTargetProps {\n    return {\n      hostedZoneId: this.canonicalHostedZoneId,\n      dnsName: this.dnsName\n    };\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-load-balancer.js","sourceRoot":"","sources":["base-load-balancer.ts"],"names":[],"mappings":";;AAAA,wCAAyC;AAEzC,oCAAqC;AACrC,0FAAsE;AACtE,iCAAmE;AAwCnE;;GAEG;AACH,MAAsB,gBAAiB,SAAQ,GAAG,CAAC,SAAS;IAgD1D,YAAY,KAAoB,EAAE,EAAU,EAAE,SAAgC,EAAE,eAAoB;QAClG,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QANnB;;WAEG;QACc,eAAU,GAAe,EAAE,CAAC;QAK3C,MAAM,cAAc,GAAG,kBAAW,CAAC,SAAS,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAEpE,MAAM,UAAU,GAAG,kBAAW,CAAC,SAAS,CAAC,UAAU,EACjD,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;QAEnF,MAAM,EAAE,SAAS,EAAE,2BAA2B,EAAE,GAAG,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAE3F,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,GAAG,CAAC;QAEzB,MAAM,QAAQ,GAAG,IAAI,kDAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YACrD,IAAI,EAAE,SAAS,CAAC,gBAAgB;YAChC,OAAO,EAAE,SAAS;YAClB,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,UAAU;YACvD,sBAAsB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,uBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC9E,GAAG,eAAe;SACnB,CAAC,CAAC;QACH,IAAI,cAAc,EAAE;YAClB,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,2BAA2B,CAAC,CAAC;SAC1D;QAED,IAAI,SAAS,CAAC,kBAAkB,EAAE;YAAE,IAAI,CAAC,YAAY,CAAC,6BAA6B,EAAE,MAAM,CAAC,CAAC;SAAE;QAE/F,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC,iCAAiC,CAAC;QACxE,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,mBAAmB,CAAC;QAC5C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,oBAAoB,CAAC;QAC9C,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC;QAClD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,GAAG,CAAC;IACtC,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,GAAW,EAAE,KAAyB;QACxD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;OAEG;IACI,eAAe,CAAC,GAAW;QAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;IACpC,CAAC;IAEM,mBAAmB;QACxB,OAAO;YACL,YAAY,EAAE,IAAI,CAAC,qBAAqB;YACxC,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC;IACJ,CAAC;CACF;AAtGD,4CAsGC","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport route53 = require('@aws-cdk/aws-route53');\nimport cdk = require('@aws-cdk/cdk');\nimport { CfnLoadBalancer } from '../elasticloadbalancingv2.generated';\nimport { Attributes, ifUndefined, 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.IVpcNetwork;\n\n  /**\n   * Whether the load balancer has an internet-routable address\n   *\n   * @default false\n   */\n  readonly internetFacing?: boolean;\n\n  /**\n   * Where in the VPC to place the load balancer\n   *\n   * @default Public subnets if internetFacing, otherwise private subnets\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\n/**\n * Base class for both Application and Network Load Balancers\n */\nexport abstract class BaseLoadBalancer extends cdk.Construct implements route53.IAliasRecordTarget {\n  /**\n   * The canonical hosted zone ID of this load balancer\n   *\n   * @example  Z2P70J7EXAMPLE\n   */\n  public readonly canonicalHostedZoneId: string;\n\n  /**\n   * The DNS name of this load balancer\n   *\n   * @example my-load-balancer-424835706.us-west-2.elb.amazonaws.com\n   */\n  public readonly dnsName: string;\n\n  /**\n   * The full name of this load balancer\n   *\n   * @example app/my-load-balancer/50dc6c495c0c9188\n   */\n  public readonly fullName: string;\n\n  /**\n   * The name of this load balancer\n   *\n   * @example my-load-balancer\n   */\n  public readonly loadBalancerName: string;\n\n  /**\n   * The ARN of this load balancer\n   *\n   * @example arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-internal-load-balancer/50dc6c495c0c9188\n   */\n  public readonly loadBalancerArn: string;\n\n  /**\n   * The VPC this load balancer has been created in, if available\n   *\n   * If the Load Balancer was imported, the VPC is not available.\n   */\n  public readonly vpc?: ec2.IVpcNetwork;\n\n  /**\n   * Attributes set on this load balancer\n   */\n  private readonly attributes: Attributes = {};\n\n  constructor(scope: cdk.Construct, id: string, baseProps: BaseLoadBalancerProps, additionalProps: any) {\n    super(scope, id);\n\n    const internetFacing = ifUndefined(baseProps.internetFacing, false);\n\n    const vpcSubnets = ifUndefined(baseProps.vpcSubnets,\n      { subnetType: internetFacing ? ec2.SubnetType.Public : ec2.SubnetType.Private });\n\n    const { subnetIds, internetConnectedDependency } = baseProps.vpc.selectSubnets(vpcSubnets);\n\n    this.vpc = baseProps.vpc;\n\n    const resource = new CfnLoadBalancer(this, 'Resource', {\n      name: baseProps.loadBalancerName,\n      subnets: subnetIds,\n      scheme: internetFacing ? 'internet-facing' : 'internal',\n      loadBalancerAttributes: new cdk.Token(() => renderAttributes(this.attributes)),\n      ...additionalProps\n    });\n    if (internetFacing) {\n      resource.node.addDependency(internetConnectedDependency);\n    }\n\n    if (baseProps.deletionProtection) { this.setAttribute('deletion_protection.enabled', 'true'); }\n\n    this.canonicalHostedZoneId = resource.loadBalancerCanonicalHostedZoneId;\n    this.dnsName = resource.loadBalancerDnsName;\n    this.fullName = resource.loadBalancerFullName;\n    this.loadBalancerName = resource.loadBalancerName;\n    this.loadBalancerArn = resource.ref;\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  public asAliasRecordTarget(): route53.AliasRecordTargetProps {\n    return {\n      hostedZoneId: this.canonicalHostedZoneId,\n      dnsName: this.dnsName\n    };\n  }\n}\n"]}

@@ -30,7 +30,21 @@ "use strict";

this.targetType = baseProps.targetType;
this.resource = new elasticloadbalancingv2_generated_1.CfnTargetGroup(this, 'Resource', Object.assign({ name: baseProps.targetGroupName, targetGroupAttributes: new cdk.Token(() => util_1.renderAttributes(this.attributes)), targetType: new cdk.Token(() => this.targetType), targets: new cdk.Token(() => this.targetsJson), vpcId: baseProps.vpc.vpcId,
this.resource = new elasticloadbalancingv2_generated_1.CfnTargetGroup(this, 'Resource', {
name: baseProps.targetGroupName,
targetGroupAttributes: new cdk.Token(() => util_1.renderAttributes(this.attributes)),
targetType: new cdk.Token(() => this.targetType),
targets: new cdk.Token(() => this.targetsJson),
vpcId: baseProps.vpc.vpcId,
// HEALTH CHECK
healthCheckIntervalSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.intervalSecs), healthCheckPath: new cdk.Token(() => this.healthCheck && this.healthCheck.path), healthCheckPort: new cdk.Token(() => this.healthCheck && this.healthCheck.port), healthCheckProtocol: new cdk.Token(() => this.healthCheck && this.healthCheck.protocol), healthCheckTimeoutSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.timeoutSeconds), healthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyThresholdCount), unhealthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.unhealthyThresholdCount), matcher: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {
healthCheckIntervalSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.intervalSecs),
healthCheckPath: new cdk.Token(() => this.healthCheck && this.healthCheck.path),
healthCheckPort: new cdk.Token(() => this.healthCheck && this.healthCheck.port),
healthCheckProtocol: new cdk.Token(() => this.healthCheck && this.healthCheck.protocol),
healthCheckTimeoutSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.timeoutSeconds),
healthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyThresholdCount),
unhealthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.unhealthyThresholdCount),
matcher: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {
httpCode: this.healthCheck.healthyHttpCodes
} : undefined) }, additionalProps));
} : undefined),
...additionalProps
});
this.targetGroupLoadBalancerArns = this.resource.targetGroupLoadBalancerArns;

@@ -108,2 +122,2 @@ this.targetGroupArn = this.resource.ref;

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 codedeploy = require('@aws-cdk/aws-codedeploy-api');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { CfnTargetGroup } from '../elasticloadbalancingv2.generated';\nimport { Protocol, TargetType } from './enums';\nimport { Attributes, renderAttributes } from './util';\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  readonly vpc: ec2.IVpcNetwork;\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 deregistrationDelaySec?: number;\n\n  /**\n   * Health check configuration\n   *\n   * @default No health check\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   * The approximate number of seconds between health checks for an individual target.\n   *\n   * @default 30\n   */\n  readonly intervalSecs?: number;\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 only if the protocol of the target group\n   * is TCP.\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 5 for ALBs, 10 or 6 for NLBs\n   */\n  readonly timeoutSeconds?: number;\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   * 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 cdk.Construct implements ITargetGroup, codedeploy.ILoadBalancer {\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 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: string;\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   * 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<any>();\n\n  /**\n   * The types of the directly registered members of this target group\n   */\n  private targetType?: TargetType;\n\n  /**\n   * The target group resource\n   */\n  private readonly resource: CfnTargetGroup;\n\n  constructor(scope: cdk.Construct, id: string, baseProps: BaseTargetGroupProps, additionalProps: any) {\n    super(scope, id);\n\n    if (baseProps.deregistrationDelaySec !== undefined) {\n      this.setAttribute('deregistration_delay.timeout_seconds', baseProps.deregistrationDelaySec.toString());\n    }\n\n    this.healthCheck = baseProps.healthCheck || {};\n    this.targetType = baseProps.targetType;\n\n    this.resource = new CfnTargetGroup(this, 'Resource', {\n      name: baseProps.targetGroupName,\n      targetGroupAttributes: new cdk.Token(() => renderAttributes(this.attributes)),\n      targetType: new cdk.Token(() => this.targetType),\n      targets: new cdk.Token(() => this.targetsJson),\n      vpcId: baseProps.vpc.vpcId,\n\n      // HEALTH CHECK\n      healthCheckIntervalSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.intervalSecs),\n      healthCheckPath: new cdk.Token(() => this.healthCheck && this.healthCheck.path),\n      healthCheckPort: new cdk.Token(() => this.healthCheck && this.healthCheck.port),\n      healthCheckProtocol: new cdk.Token(() => this.healthCheck && this.healthCheck.protocol),\n      healthCheckTimeoutSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.timeoutSeconds),\n      healthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyThresholdCount),\n      unhealthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.unhealthyThresholdCount),\n      matcher: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {\n        httpCode: this.healthCheck.healthyHttpCodes\n      } : undefined),\n\n      ...additionalProps\n    });\n\n    this.targetGroupLoadBalancerArns = this.resource.targetGroupLoadBalancerArns;\n    this.targetGroupArn = this.resource.ref;\n    this.targetGroupFullName = this.resource.targetGroupFullName;\n    this.loadBalancerArns = this.resource.targetGroupLoadBalancerArns.toString();\n    this.targetGroupName = this.resource.targetGroupName;\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   * Export this target group\n   */\n  public export(): TargetGroupImportProps {\n    return {\n      targetGroupArn: new cdk.CfnOutput(this, 'TargetGroupArn', { value: this.targetGroupArn }).makeImportValue().toString(),\n      defaultPort: new cdk.CfnOutput(this, 'Port', { value: this.defaultPort }).makeImportValue().toString(),\n    };\n  }\n\n  public asCodeDeployLoadBalancer(): codedeploy.ILoadBalancerProps {\n    return {\n      generation: codedeploy.LoadBalancerGeneration.Second,\n      name: this.targetGroupName,\n    };\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 (props.targetJson) {\n      this.targetsJson.push(props.targetJson);\n    }\n  }\n}\n\n/**\n * Properties to reference an existing target group\n */\nexport interface TargetGroupImportProps {\n  /**\n   * ARN of the target group\n   */\n  readonly targetGroupArn: string;\n\n  /**\n   * Port target group is listening on\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 * A target group\n */\nexport interface ITargetGroup extends cdk.IConstruct {\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   * Export this target group\n   */\n  export(): TargetGroupImportProps;\n\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"]}
//# 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 codedeploy = require('@aws-cdk/aws-codedeploy-api');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport cdk = require('@aws-cdk/cdk');\nimport { CfnTargetGroup } from '../elasticloadbalancingv2.generated';\nimport { Protocol, TargetType } from './enums';\nimport { Attributes, renderAttributes } from './util';\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  readonly vpc: ec2.IVpcNetwork;\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 deregistrationDelaySec?: number;\n\n  /**\n   * Health check configuration\n   *\n   * @default No health check\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   * The approximate number of seconds between health checks for an individual target.\n   *\n   * @default 30\n   */\n  readonly intervalSecs?: number;\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 only if the protocol of the target group\n   * is TCP.\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 5 for ALBs, 10 or 6 for NLBs\n   */\n  readonly timeoutSeconds?: number;\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   * 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 cdk.Construct implements ITargetGroup, codedeploy.ILoadBalancer {\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 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: string;\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   * 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<any>();\n\n  /**\n   * The types of the directly registered members of this target group\n   */\n  private targetType?: TargetType;\n\n  /**\n   * The target group resource\n   */\n  private readonly resource: CfnTargetGroup;\n\n  constructor(scope: cdk.Construct, id: string, baseProps: BaseTargetGroupProps, additionalProps: any) {\n    super(scope, id);\n\n    if (baseProps.deregistrationDelaySec !== undefined) {\n      this.setAttribute('deregistration_delay.timeout_seconds', baseProps.deregistrationDelaySec.toString());\n    }\n\n    this.healthCheck = baseProps.healthCheck || {};\n    this.targetType = baseProps.targetType;\n\n    this.resource = new CfnTargetGroup(this, 'Resource', {\n      name: baseProps.targetGroupName,\n      targetGroupAttributes: new cdk.Token(() => renderAttributes(this.attributes)),\n      targetType: new cdk.Token(() => this.targetType),\n      targets: new cdk.Token(() => this.targetsJson),\n      vpcId: baseProps.vpc.vpcId,\n\n      // HEALTH CHECK\n      healthCheckIntervalSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.intervalSecs),\n      healthCheckPath: new cdk.Token(() => this.healthCheck && this.healthCheck.path),\n      healthCheckPort: new cdk.Token(() => this.healthCheck && this.healthCheck.port),\n      healthCheckProtocol: new cdk.Token(() => this.healthCheck && this.healthCheck.protocol),\n      healthCheckTimeoutSeconds: new cdk.Token(() => this.healthCheck && this.healthCheck.timeoutSeconds),\n      healthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyThresholdCount),\n      unhealthyThresholdCount: new cdk.Token(() => this.healthCheck && this.healthCheck.unhealthyThresholdCount),\n      matcher: new cdk.Token(() => this.healthCheck && this.healthCheck.healthyHttpCodes !== undefined ? {\n        httpCode: this.healthCheck.healthyHttpCodes\n      } : undefined),\n\n      ...additionalProps\n    });\n\n    this.targetGroupLoadBalancerArns = this.resource.targetGroupLoadBalancerArns;\n    this.targetGroupArn = this.resource.ref;\n    this.targetGroupFullName = this.resource.targetGroupFullName;\n    this.loadBalancerArns = this.resource.targetGroupLoadBalancerArns.toString();\n    this.targetGroupName = this.resource.targetGroupName;\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   * Export this target group\n   */\n  public export(): TargetGroupImportProps {\n    return {\n      targetGroupArn: new cdk.CfnOutput(this, 'TargetGroupArn', { value: this.targetGroupArn }).makeImportValue().toString(),\n      defaultPort: new cdk.CfnOutput(this, 'Port', { value: this.defaultPort }).makeImportValue().toString(),\n    };\n  }\n\n  public asCodeDeployLoadBalancer(): codedeploy.ILoadBalancerProps {\n    return {\n      generation: codedeploy.LoadBalancerGeneration.Second,\n      name: this.targetGroupName,\n    };\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 (props.targetJson) {\n      this.targetsJson.push(props.targetJson);\n    }\n  }\n}\n\n/**\n * Properties to reference an existing target group\n */\nexport interface TargetGroupImportProps {\n  /**\n   * ARN of the target group\n   */\n  readonly targetGroupArn: string;\n\n  /**\n   * Port target group is listening on\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 * A target group\n */\nexport interface ITargetGroup extends cdk.IConstruct {\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   * Export this target group\n   */\n  export(): TargetGroupImportProps;\n\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"]}
{
"name": "@aws-cdk/aws-elasticloadbalancingv2",
"version": "0.28.0",
"version": "0.29.0",
"description": "The CDK Construct Library for AWS::ElasticLoadBalancingV2",

@@ -32,3 +32,4 @@ "main": "lib/index.js",

"type": "git",
"url": "https://github.com/awslabs/aws-cdk.git"
"url": "https://github.com/awslabs/aws-cdk.git",
"directory": "packages/@aws-cdk/aws-elasticloadbalancingv2"
},

@@ -62,25 +63,26 @@ "scripts": {

"devDependencies": {
"@aws-cdk/assert": "^0.28.0",
"cdk-build-tools": "^0.28.0",
"cdk-integ-tools": "^0.28.0",
"cfn2ts": "^0.28.0",
"pkglint": "^0.28.0"
"@aws-cdk/assert": "^0.29.0",
"cdk-build-tools": "^0.29.0",
"cdk-integ-tools": "^0.29.0",
"cfn2ts": "^0.29.0",
"pkglint": "^0.29.0"
},
"dependencies": {
"@aws-cdk/aws-cloudwatch": "^0.28.0",
"@aws-cdk/aws-codedeploy-api": "^0.28.0",
"@aws-cdk/aws-ec2": "^0.28.0",
"@aws-cdk/aws-iam": "^0.28.0",
"@aws-cdk/aws-route53": "^0.28.0",
"@aws-cdk/aws-s3": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0"
"@aws-cdk/aws-cloudwatch": "^0.29.0",
"@aws-cdk/aws-codedeploy-api": "^0.29.0",
"@aws-cdk/aws-ec2": "^0.29.0",
"@aws-cdk/aws-iam": "^0.29.0",
"@aws-cdk/aws-route53": "^0.29.0",
"@aws-cdk/aws-s3": "^0.29.0",
"@aws-cdk/cdk": "^0.29.0"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-cloudwatch": "^0.28.0",
"@aws-cdk/aws-codedeploy-api": "^0.28.0",
"@aws-cdk/aws-ec2": "^0.28.0",
"@aws-cdk/aws-route53": "^0.28.0",
"@aws-cdk/aws-s3": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0"
"@aws-cdk/aws-cloudwatch": "^0.29.0",
"@aws-cdk/aws-codedeploy-api": "^0.29.0",
"@aws-cdk/aws-ec2": "^0.29.0",
"@aws-cdk/aws-iam": "^0.29.0",
"@aws-cdk/aws-route53": "^0.29.0",
"@aws-cdk/aws-s3": "^0.29.0",
"@aws-cdk/cdk": "^0.29.0"
},

@@ -97,2 +99,2 @@ "engines": {

}
}
}

@@ -8,2 +8,3 @@ import { Test } from 'nodeunit';

'Access logging'(test: Test): void;
'access logging with prefix'(test: Test): void;
'Exercise metrics'(test: Test): void;

@@ -10,0 +11,0 @@ 'loadBalancerName'(test: Test): void;

@@ -106,2 +106,3 @@ "use strict";

// THEN
// verify that the LB attributes reference the bucket
assert_1.expect(stack).to(assert_1.haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {

@@ -119,2 +120,3 @@ LoadBalancerAttributes: [

}));
// verify the bucket policy allows the ALB to put objects in the bucket
assert_1.expect(stack).to(assert_1.haveResource('AWS::S3::BucketPolicy', {

@@ -125,3 +127,3 @@ PolicyDocument: {

{
Action: "s3:PutObject",
Action: ["s3:PutObject*", "s3:Abort*"],
Effect: 'Allow',

@@ -134,4 +136,50 @@ Principal: { AWS: { "Fn::Join": ["", ["arn:", { Ref: "AWS::Partition" }, ":iam::127311923021:root"]] } },

}));
// verify the ALB depends on the bucket *and* the bucket policy
assert_1.expect(stack).to(assert_1.haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {
DependsOn: ['AccessLoggingBucketPolicy700D7CC6', 'AccessLoggingBucketA6D88F29']
}, assert_1.ResourcePart.CompleteDefinition));
test.done();
},
'access logging with prefix'(test) {
// GIVEN
const stack = new cdk.Stack(undefined, undefined, { env: { region: 'us-east-1' } });
const vpc = new ec2.VpcNetwork(stack, 'Stack');
const bucket = new s3.Bucket(stack, 'AccessLoggingBucket');
const lb = new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });
// WHEN
lb.logAccessLogs(bucket, 'prefix-of-access-logs');
// THEN
// verify that the LB attributes reference the bucket
assert_1.expect(stack).to(assert_1.haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {
LoadBalancerAttributes: [
{
Key: "access_logs.s3.enabled",
Value: "true"
},
{
Key: "access_logs.s3.bucket",
Value: { Ref: "AccessLoggingBucketA6D88F29" }
},
{
Key: "access_logs.s3.prefix",
Value: "prefix-of-access-logs"
}
],
}));
// verify the bucket policy allows the ALB to put objects in the bucket
assert_1.expect(stack).to(assert_1.haveResource('AWS::S3::BucketPolicy', {
PolicyDocument: {
Version: '2012-10-17',
Statement: [
{
Action: ["s3:PutObject*", "s3:Abort*"],
Effect: 'Allow',
Principal: { AWS: { "Fn::Join": ["", ["arn:", { Ref: "AWS::Partition" }, ":iam::127311923021:root"]] } },
Resource: { "Fn::Join": ["", [{ "Fn::GetAtt": ["AccessLoggingBucketA6D88F29", "Arn"] }, "/prefix-of-access-logs*"]] }
}
]
}
}));
test.done();
},
'Exercise metrics'(test) {

@@ -190,2 +238,2 @@ // GIVEN

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.load-balancer.js","sourceRoot":"","sources":["test.load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, ResourcePart } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport elbv2 = require('../../lib');\n\nexport = {\n  'Trivial construction: internet facing'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', {\n      vpc,\n      internetFacing: true,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      Scheme: \"internet-facing\",\n      Subnets: [\n        { Ref: \"StackPublicSubnet1Subnet0AD81D22\" },\n        { Ref: \"StackPublicSubnet2Subnet3C7D2288\" },\n        { Ref: \"StackPublicSubnet3SubnetCC1055D9\" }\n      ],\n      Type: \"application\"\n    }));\n\n    test.done();\n  },\n\n  'internet facing load balancer has dependency on IGW'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', {\n      vpc,\n      internetFacing: true,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      DependsOn: [\n        'StackPublicSubnet1DefaultRoute16154E3D',\n        'StackPublicSubnet2DefaultRoute0319539B',\n        'StackPublicSubnet3DefaultRouteBC0DA152'\n      ]\n    }, ResourcePart.CompleteDefinition));\n\n    test.done();\n  },\n\n  'Trivial construction: internal'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      Scheme: \"internal\",\n      Subnets: [\n        { Ref: \"StackPrivateSubnet1Subnet47AC2BC7\" },\n        { Ref: \"StackPrivateSubnet2SubnetA2F8EDD8\" },\n        { Ref: \"StackPrivateSubnet3Subnet28548F2E\" }\n      ],\n      Type: \"application\"\n    }));\n\n    test.done();\n  },\n\n  'Attributes'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', {\n      vpc,\n      deletionProtection: true,\n      http2Enabled: false,\n      idleTimeoutSecs: 1000,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      LoadBalancerAttributes: [\n        {\n          Key: \"deletion_protection.enabled\",\n          Value: \"true\"\n        },\n        {\n          Key: \"routing.http2.enabled\",\n          Value: \"false\"\n        },\n        {\n          Key: \"idle_timeout.timeout_seconds\",\n          Value: \"1000\"\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'Access logging'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack(undefined, undefined, { env: { region: 'us-east-1' }});\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n    const bucket = new s3.Bucket(stack, 'AccessLoggingBucket');\n    const lb = new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });\n\n    // WHEN\n    lb.logAccessLogs(bucket);\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      LoadBalancerAttributes: [\n        {\n          Key: \"access_logs.s3.enabled\",\n          Value: \"true\"\n        },\n        {\n          Key: \"access_logs.s3.bucket\",\n          Value: { Ref: \"AccessLoggingBucketA6D88F29\" }\n        }\n      ],\n    }));\n    expect(stack).to(haveResource('AWS::S3::BucketPolicy', {\n      PolicyDocument: {\n        Version: '2012-10-17',\n        Statement: [\n          {\n            Action: \"s3:PutObject\",\n            Effect: 'Allow',\n            Principal: { AWS: { \"Fn::Join\": [ \"\", [ \"arn:\", { Ref: \"AWS::Partition\" }, \":iam::127311923021:root\" ] ] } },\n            Resource: { \"Fn::Join\": [ \"\", [ { \"Fn::GetAtt\": [ \"AccessLoggingBucketA6D88F29\", \"Arn\" ] }, \"/*\" ] ] }\n          }\n        ]\n      }\n    }));\n\n    test.done();\n  },\n\n  'Exercise metrics'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n    const lb = new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });\n\n    // WHEN\n    const metrics = [];\n    metrics.push(lb.metricActiveConnectionCount());\n    metrics.push(lb.metricClientTlsNegotiationErrorCount());\n    metrics.push(lb.metricConsumedLCUs());\n    metrics.push(lb.metricElbAuthError());\n    metrics.push(lb.metricElbAuthFailure());\n    metrics.push(lb.metricElbAuthLatency());\n    metrics.push(lb.metricElbAuthSuccess());\n    metrics.push(lb.metricHttpCodeElb(elbv2.HttpCodeElb.Elb3xxCount));\n    metrics.push(lb.metricHttpCodeTarget(elbv2.HttpCodeTarget.Target3xxCount));\n    metrics.push(lb.metricHttpFixedResponseCount());\n    metrics.push(lb.metricHttpRedirectCount());\n    metrics.push(lb.metricHttpRedirectUrlLimitExceededCount());\n    metrics.push(lb.metricIPv6ProcessedBytes());\n    metrics.push(lb.metricIPv6RequestCount());\n    metrics.push(lb.metricNewConnectionCount());\n    metrics.push(lb.metricProcessedBytes());\n    metrics.push(lb.metricRejectedConnectionCount());\n    metrics.push(lb.metricRequestCount());\n    metrics.push(lb.metricRuleEvaluations());\n    metrics.push(lb.metricTargetConnectionErrorCount());\n    metrics.push(lb.metricTargetResponseTime());\n    metrics.push(lb.metricTargetTLSNegotiationErrorCount());\n\n    for (const metric of metrics) {\n      test.equal('AWS/ApplicationELB', metric.namespace);\n      test.deepEqual(stack.node.resolve(metric.dimensions), {\n        LoadBalancer: { 'Fn::GetAtt': ['LB8A12904C', 'LoadBalancerFullName'] }\n      });\n    }\n\n    test.done();\n  },\n\n  'loadBalancerName'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'ALB', {\n      loadBalancerName: 'myLoadBalancer',\n      vpc\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      Name: 'myLoadBalancer'\n    }));\n    test.done();\n  },\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.load-balancer.js","sourceRoot":"","sources":["test.load-balancer.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, ResourcePart } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport elbv2 = require('../../lib');\n\nexport = {\n  'Trivial construction: internet facing'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', {\n      vpc,\n      internetFacing: true,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      Scheme: \"internet-facing\",\n      Subnets: [\n        { Ref: \"StackPublicSubnet1Subnet0AD81D22\" },\n        { Ref: \"StackPublicSubnet2Subnet3C7D2288\" },\n        { Ref: \"StackPublicSubnet3SubnetCC1055D9\" }\n      ],\n      Type: \"application\"\n    }));\n\n    test.done();\n  },\n\n  'internet facing load balancer has dependency on IGW'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', {\n      vpc,\n      internetFacing: true,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      DependsOn: [\n        'StackPublicSubnet1DefaultRoute16154E3D',\n        'StackPublicSubnet2DefaultRoute0319539B',\n        'StackPublicSubnet3DefaultRouteBC0DA152'\n      ]\n    }, ResourcePart.CompleteDefinition));\n\n    test.done();\n  },\n\n  'Trivial construction: internal'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      Scheme: \"internal\",\n      Subnets: [\n        { Ref: \"StackPrivateSubnet1Subnet47AC2BC7\" },\n        { Ref: \"StackPrivateSubnet2SubnetA2F8EDD8\" },\n        { Ref: \"StackPrivateSubnet3Subnet28548F2E\" }\n      ],\n      Type: \"application\"\n    }));\n\n    test.done();\n  },\n\n  'Attributes'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'LB', {\n      vpc,\n      deletionProtection: true,\n      http2Enabled: false,\n      idleTimeoutSecs: 1000,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      LoadBalancerAttributes: [\n        {\n          Key: \"deletion_protection.enabled\",\n          Value: \"true\"\n        },\n        {\n          Key: \"routing.http2.enabled\",\n          Value: \"false\"\n        },\n        {\n          Key: \"idle_timeout.timeout_seconds\",\n          Value: \"1000\"\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'Access logging'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack(undefined, undefined, { env: { region: 'us-east-1' }});\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n    const bucket = new s3.Bucket(stack, 'AccessLoggingBucket');\n    const lb = new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });\n\n    // WHEN\n    lb.logAccessLogs(bucket);\n\n    // THEN\n\n    // verify that the LB attributes reference the bucket\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      LoadBalancerAttributes: [\n        {\n          Key: \"access_logs.s3.enabled\",\n          Value: \"true\"\n        },\n        {\n          Key: \"access_logs.s3.bucket\",\n          Value: { Ref: \"AccessLoggingBucketA6D88F29\" }\n        }\n      ],\n    }));\n\n    // verify the bucket policy allows the ALB to put objects in the bucket\n    expect(stack).to(haveResource('AWS::S3::BucketPolicy', {\n      PolicyDocument: {\n        Version: '2012-10-17',\n        Statement: [\n          {\n            Action: [ \"s3:PutObject*\", \"s3:Abort*\" ],\n            Effect: 'Allow',\n            Principal: { AWS: { \"Fn::Join\": [ \"\", [ \"arn:\", { Ref: \"AWS::Partition\" }, \":iam::127311923021:root\" ] ] } },\n            Resource: { \"Fn::Join\": [ \"\", [ { \"Fn::GetAtt\": [ \"AccessLoggingBucketA6D88F29\", \"Arn\" ] }, \"/*\" ] ] }\n          }\n        ]\n      }\n    }));\n\n    // verify the ALB depends on the bucket *and* the bucket policy\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      DependsOn: [ 'AccessLoggingBucketPolicy700D7CC6', 'AccessLoggingBucketA6D88F29' ]\n    }, ResourcePart.CompleteDefinition));\n\n    test.done();\n  },\n\n  'access logging with prefix'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack(undefined, undefined, { env: { region: 'us-east-1' }});\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n    const bucket = new s3.Bucket(stack, 'AccessLoggingBucket');\n    const lb = new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });\n\n    // WHEN\n    lb.logAccessLogs(bucket, 'prefix-of-access-logs');\n\n    // THEN\n    // verify that the LB attributes reference the bucket\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      LoadBalancerAttributes: [\n        {\n          Key: \"access_logs.s3.enabled\",\n          Value: \"true\"\n        },\n        {\n          Key: \"access_logs.s3.bucket\",\n          Value: { Ref: \"AccessLoggingBucketA6D88F29\" }\n        },\n        {\n          Key: \"access_logs.s3.prefix\",\n          Value: \"prefix-of-access-logs\"\n        }\n      ],\n    }));\n\n    // verify the bucket policy allows the ALB to put objects in the bucket\n    expect(stack).to(haveResource('AWS::S3::BucketPolicy', {\n      PolicyDocument: {\n        Version: '2012-10-17',\n        Statement: [\n          {\n            Action: [ \"s3:PutObject*\", \"s3:Abort*\" ],\n            Effect: 'Allow',\n            Principal: { AWS: { \"Fn::Join\": [ \"\", [ \"arn:\", { Ref: \"AWS::Partition\" }, \":iam::127311923021:root\" ] ] } },\n            Resource: { \"Fn::Join\": [ \"\", [ { \"Fn::GetAtt\": [ \"AccessLoggingBucketA6D88F29\", \"Arn\" ] }, \"/prefix-of-access-logs*\" ] ] }\n          }\n        ]\n      }\n    }));\n\n    test.done();\n  },\n\n  'Exercise metrics'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n    const lb = new elbv2.ApplicationLoadBalancer(stack, 'LB', { vpc });\n\n    // WHEN\n    const metrics = [];\n    metrics.push(lb.metricActiveConnectionCount());\n    metrics.push(lb.metricClientTlsNegotiationErrorCount());\n    metrics.push(lb.metricConsumedLCUs());\n    metrics.push(lb.metricElbAuthError());\n    metrics.push(lb.metricElbAuthFailure());\n    metrics.push(lb.metricElbAuthLatency());\n    metrics.push(lb.metricElbAuthSuccess());\n    metrics.push(lb.metricHttpCodeElb(elbv2.HttpCodeElb.Elb3xxCount));\n    metrics.push(lb.metricHttpCodeTarget(elbv2.HttpCodeTarget.Target3xxCount));\n    metrics.push(lb.metricHttpFixedResponseCount());\n    metrics.push(lb.metricHttpRedirectCount());\n    metrics.push(lb.metricHttpRedirectUrlLimitExceededCount());\n    metrics.push(lb.metricIPv6ProcessedBytes());\n    metrics.push(lb.metricIPv6RequestCount());\n    metrics.push(lb.metricNewConnectionCount());\n    metrics.push(lb.metricProcessedBytes());\n    metrics.push(lb.metricRejectedConnectionCount());\n    metrics.push(lb.metricRequestCount());\n    metrics.push(lb.metricRuleEvaluations());\n    metrics.push(lb.metricTargetConnectionErrorCount());\n    metrics.push(lb.metricTargetResponseTime());\n    metrics.push(lb.metricTargetTLSNegotiationErrorCount());\n\n    for (const metric of metrics) {\n      test.equal('AWS/ApplicationELB', metric.namespace);\n      test.deepEqual(stack.node.resolve(metric.dimensions), {\n        LoadBalancer: { 'Fn::GetAtt': ['LB8A12904C', 'LoadBalancerFullName'] }\n      });\n    }\n\n    test.done();\n  },\n\n  'loadBalancerName'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const vpc = new ec2.VpcNetwork(stack, 'Stack');\n\n    // WHEN\n    new elbv2.ApplicationLoadBalancer(stack, 'ALB', {\n      loadBalancerName: 'myLoadBalancer',\n      vpc\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ElasticLoadBalancingV2::LoadBalancer', {\n      Name: 'myLoadBalancer'\n    }));\n    test.done();\n  },\n};\n"]}

Sorry, the diff of this file is not supported yet

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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc