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

@aws-cdk/aws-ecs

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-ecs - npm Package Compare versions

Comparing version 1.4.0 to 1.5.0

8

lib/base/base-service.js

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

serviceName: this.physicalName,
loadBalancers: core_1.Lazy.anyValue({ produce: () => this.loadBalancers }),
loadBalancers: core_1.Lazy.anyValue({ produce: () => this.loadBalancers }, { omitEmptyArray: true }),
deploymentConfiguration: {

@@ -51,4 +51,4 @@ maximumPercent: props.maxHealthyPercent || 200,

/* role: never specified, supplanted by Service Linked Role */
networkConfiguration: core_1.Lazy.anyValue({ produce: () => this.networkConfiguration }),
serviceRegistries: core_1.Lazy.anyValue({ produce: () => this.serviceRegistries }),
networkConfiguration: core_1.Lazy.anyValue({ produce: () => this.networkConfiguration }, { omitEmptyArray: true }),
serviceRegistries: core_1.Lazy.anyValue({ produce: () => this.serviceRegistries }, { omitEmptyArray: true }),
...additionalProps

@@ -276,2 +276,2 @@ });

})(LaunchType = exports.LaunchType || (exports.LaunchType = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-service.js","sourceRoot":"","sources":["base-service.ts"],"names":[],"mappings":"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","sourcesContent":["import appscaling = require('@aws-cdk/aws-applicationautoscaling');\nimport cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport elbv2 = require('@aws-cdk/aws-elasticloadbalancingv2');\nimport iam = require('@aws-cdk/aws-iam');\nimport cloudmap = require('@aws-cdk/aws-servicediscovery');\nimport { Construct, Duration, IResolvable, IResource, Lazy, Resource, Stack } from '@aws-cdk/core';\nimport { NetworkMode, TaskDefinition } from '../base/task-definition';\nimport { ICluster } from '../cluster';\nimport { CfnService } from '../ecs.generated';\nimport { ScalableTaskCount } from './scalable-task-count';\n\n/**\n * The interface for a service.\n */\nexport interface IService extends IResource {\n  /**\n   * The Amazon Resource Name (ARN) of the service.\n   *\n   * @attribute\n   */\n  readonly serviceArn: string;\n}\n\n/**\n * The properties for the base Ec2Service or FargateService service.\n */\nexport interface BaseServiceOptions {\n  /**\n   * The name of the cluster that hosts the service.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The desired number of instantiations of the task definition to keep running on the service.\n   *\n   * @default 1\n   */\n  readonly desiredCount?: number;\n\n  /**\n   * The name of the service.\n   *\n   * @default - CloudFormation-generated name.\n   */\n  readonly serviceName?: string;\n\n  /**\n   * The maximum number of tasks, specified as a percentage of the Amazon ECS\n   * service's DesiredCount value, that can run in a service during a\n   * deployment.\n   *\n   * @default - 100 if daemon, otherwise 200\n   */\n  readonly maxHealthyPercent?: number;\n\n  /**\n   * The minimum number of tasks, specified as a percentage of\n   * the Amazon ECS service's DesiredCount value, that must\n   * continue to run and remain healthy during a deployment.\n   *\n   * @default - 0 if daemon, otherwise 50\n   */\n  readonly minHealthyPercent?: number;\n\n  /**\n   * The period of time, in seconds, that the Amazon ECS service scheduler ignores unhealthy\n   * Elastic Load Balancing target health checks after a task has first started.\n   *\n   * @default - defaults to 60 seconds if at least one load balancer is in-use and it is not already set\n   */\n  readonly healthCheckGracePeriod?: Duration;\n\n  /**\n   * The options for configuring an Amazon ECS service to use service discovery.\n   *\n   * @default - AWS Cloud Map service discovery is not enabled.\n   */\n  readonly cloudMapOptions?: CloudMapOptions;\n}\n\n/**\n * Complete base service properties that are required to be supplied by the implementation\n * of the BaseService class.\n */\nexport interface BaseServiceProps extends BaseServiceOptions {\n  /**\n   * The launch type on which to run your service.\n   *\n   * Valid values are: LaunchType.ECS or LaunchType.FARGATE\n   */\n  readonly launchType: LaunchType;\n}\n\n/**\n * The base class for Ec2Service and FargateService services.\n */\nexport abstract class BaseService extends Resource\n  implements IService, elbv2.IApplicationLoadBalancerTarget, elbv2.INetworkLoadBalancerTarget {\n\n  /**\n   * The security groups which manage the allowed network traffic for the service.\n   */\n  public readonly connections: ec2.Connections = new ec2.Connections();\n\n  /**\n   * The Amazon Resource Name (ARN) of the service.\n   */\n  public readonly serviceArn: string;\n\n  /**\n   * The name of the service.\n   *\n   * @attribute\n   */\n  public readonly serviceName: string;\n\n  /**\n   * The task definition to use for tasks in the service.\n   */\n  public readonly taskDefinition: TaskDefinition;\n\n  /**\n   * The cluster that hosts the service.\n   */\n  public readonly cluster: ICluster;\n\n  /**\n   * The details of the AWS Cloud Map service.\n   */\n  protected cloudmapService?: cloudmap.Service;\n\n  /**\n   * A list of Elastic Load Balancing load balancer objects, containing the load balancer name, the container\n   * name (as it appears in a container definition), and the container port to access from the load balancer.\n   */\n  protected loadBalancers = new Array<CfnService.LoadBalancerProperty>();\n\n  /**\n   * A list of Elastic Load Balancing load balancer objects, containing the load balancer name, the container\n   * name (as it appears in a container definition), and the container port to access from the load balancer.\n   */\n  protected networkConfiguration?: CfnService.NetworkConfigurationProperty;\n\n  /**\n   * The details of the service discovery registries to assign to this service.\n   * For more information, see Service Discovery.\n   */\n  protected serviceRegistries = new Array<CfnService.ServiceRegistryProperty>();\n\n  private readonly resource: CfnService;\n  private scalableTaskCount?: ScalableTaskCount;\n\n  /**\n   * Constructs a new instance of the BaseService class.\n   */\n  constructor(scope: Construct,\n              id: string,\n              props: BaseServiceProps,\n              additionalProps: any,\n              taskDefinition: TaskDefinition) {\n    super(scope, id, {\n      physicalName: props.serviceName,\n    });\n\n    this.taskDefinition = taskDefinition;\n\n    this.resource = new CfnService(this, \"Service\", {\n      desiredCount: props.desiredCount,\n      serviceName: this.physicalName,\n      loadBalancers: Lazy.anyValue({ produce: () => this.loadBalancers }),\n      deploymentConfiguration: {\n        maximumPercent: props.maxHealthyPercent || 200,\n        minimumHealthyPercent: props.minHealthyPercent === undefined ? 50 : props.minHealthyPercent\n      },\n      launchType: props.launchType,\n      healthCheckGracePeriodSeconds: this.evaluateHealthGracePeriod(props.healthCheckGracePeriod),\n      /* role: never specified, supplanted by Service Linked Role */\n      networkConfiguration: Lazy.anyValue({ produce: () => this.networkConfiguration }),\n      serviceRegistries: Lazy.anyValue({ produce: () => this.serviceRegistries }),\n      ...additionalProps\n    });\n\n    this.serviceArn = this.getResourceArnAttribute(this.resource.ref, {\n      service: 'ecs',\n      resource: 'service',\n      resourceName: `${props.cluster.clusterName}/${this.physicalName}`,\n    });\n    this.serviceName = this.getResourceNameAttribute(this.resource.attrName);\n\n    this.cluster = props.cluster;\n\n    if (props.cloudMapOptions) {\n      this.enableCloudMap(props.cloudMapOptions);\n    }\n  }\n\n  /**\n   * This method is called to attach this service to an Application Load Balancer.\n   *\n   * Don't call this function directly. Instead, call listener.addTarget()\n   * to add this service to a load balancer.\n   */\n  public attachToApplicationTargetGroup(targetGroup: elbv2.ApplicationTargetGroup): elbv2.LoadBalancerTargetProps {\n    const ret = this.attachToELBv2(targetGroup);\n\n    // Open up security groups. For dynamic port mapping, we won't know the port range\n    // in advance so we need to open up all ports.\n    const port = this.taskDefinition.defaultContainer!.ingressPort;\n    const portRange = port === 0 ? EPHEMERAL_PORT_RANGE : ec2.Port.tcp(port);\n    targetGroup.registerConnectable(this, portRange);\n\n    return ret;\n  }\n\n  /**\n   * This method is called to attach this service to a Network Load Balancer.\n   *\n   * Don't call this function directly. Instead, call listener.addTarget()\n   * to add this service to a load balancer.\n   */\n  public attachToNetworkTargetGroup(targetGroup: elbv2.NetworkTargetGroup): elbv2.LoadBalancerTargetProps {\n    return this.attachToELBv2(targetGroup);\n  }\n\n  /**\n   * An attribute representing the minimum and maximum task count for an AutoScalingGroup.\n   */\n  public autoScaleTaskCount(props: appscaling.EnableScalingProps) {\n    if (this.scalableTaskCount) {\n      throw new Error('AutoScaling of task count already enabled for this service');\n    }\n\n    return this.scalableTaskCount = new ScalableTaskCount(this, 'TaskCount', {\n      serviceNamespace: appscaling.ServiceNamespace.ECS,\n      resourceId: `service/${this.cluster.clusterName}/${this.serviceName}`,\n      dimension: 'ecs:service:DesiredCount',\n      role: this.makeAutoScalingRole(),\n      ...props\n    });\n  }\n\n  /**\n   * This method returns the specified CloudWatch metric name for this service.\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ECS',\n      metricName,\n      dimensions: { ClusterName: this.cluster.clusterName, ServiceName: this.serviceName },\n      ...props\n    });\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters memory utilization.\n   *\n   * @default average over 5 minutes\n   */\n  public metricMemoryUtilization(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('MemoryUtilization', props);\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters CPU utilization.\n   *\n   * @default average over 5 minutes\n   */\n  public metricCpuUtilization(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('CPUUtilization', props);\n  }\n\n  /**\n   * This method is called to create a networkConfiguration.\n   */\n  // tslint:disable-next-line:max-line-length\n  protected configureAwsVpcNetworking(vpc: ec2.IVpc, assignPublicIp?: boolean, vpcSubnets?: ec2.SubnetSelection, securityGroup?: ec2.ISecurityGroup) {\n    if (vpcSubnets === undefined) {\n      vpcSubnets = { subnetType: assignPublicIp ? ec2.SubnetType.PUBLIC : ec2.SubnetType.PRIVATE };\n    }\n    if (securityGroup === undefined) {\n      securityGroup = new ec2.SecurityGroup(this, 'SecurityGroup', { vpc });\n    }\n    this.connections.addSecurityGroup(securityGroup);\n\n    this.networkConfiguration = {\n      awsvpcConfiguration: {\n        assignPublicIp: assignPublicIp ? 'ENABLED' : 'DISABLED',\n        subnets: vpc.selectSubnets(vpcSubnets).subnetIds,\n        securityGroups: Lazy.listValue({ produce: () => [securityGroup!.securityGroupId] }),\n      }\n    };\n  }\n\n  private renderServiceRegistry(registry: ServiceRegistry): CfnService.ServiceRegistryProperty {\n    return {\n      registryArn: registry.arn,\n      containerName: registry.containerName,\n      containerPort: registry.containerPort,\n    };\n  }\n\n  /**\n   * Shared logic for attaching to an ELBv2\n   */\n  private attachToELBv2(targetGroup: elbv2.ITargetGroup): elbv2.LoadBalancerTargetProps {\n    if (this.taskDefinition.networkMode === NetworkMode.NONE) {\n      throw new Error(\"Cannot use a load balancer if NetworkMode is None. Use Bridge, Host or AwsVpc instead.\");\n    }\n\n    this.loadBalancers.push({\n      targetGroupArn: targetGroup.targetGroupArn,\n      containerName: this.taskDefinition.defaultContainer!.containerName,\n      containerPort: this.taskDefinition.defaultContainer!.containerPort,\n    });\n\n    // Service creation can only happen after the load balancer has\n    // been associated with our target group(s), so add ordering dependency.\n    this.resource.node.addDependency(targetGroup.loadBalancerAttached);\n\n    const targetType = this.taskDefinition.networkMode === NetworkMode.AWS_VPC ? elbv2.TargetType.IP : elbv2.TargetType.INSTANCE;\n    return { targetType };\n  }\n\n  /**\n   * Generate the role that will be used for autoscaling this service\n   */\n  private makeAutoScalingRole(): iam.IRole {\n    // Use a Service Linked Role.\n    return iam.Role.fromRoleArn(this, 'ScalingRole', Stack.of(this).formatArn({\n      service: 'iam',\n      resource: 'role/aws-service-role/ecs.application-autoscaling.amazonaws.com',\n      resourceName: 'AWSServiceRoleForApplicationAutoScaling_ECSService',\n    }));\n  }\n\n  /**\n   * Associate Service Discovery (Cloud Map) service\n   */\n  private addServiceRegistry(registry: ServiceRegistry) {\n    const sr = this.renderServiceRegistry(registry);\n    this.serviceRegistries.push(sr);\n  }\n\n  /**\n   * Enable CloudMap service discovery for the service\n   */\n  private enableCloudMap(options: CloudMapOptions): cloudmap.Service {\n    const sdNamespace = this.cluster.defaultCloudMapNamespace;\n    if (sdNamespace === undefined) {\n      throw new Error(\"Cannot enable service discovery if a Cloudmap Namespace has not been created in the cluster.\");\n    }\n\n    // Determine DNS type based on network mode\n    const networkMode = this.taskDefinition.networkMode;\n    if (networkMode === NetworkMode.NONE) {\n      throw new Error(\"Cannot use a service discovery if NetworkMode is None. Use Bridge, Host or AwsVpc instead.\");\n    }\n\n    // Bridge or host network mode requires SRV records\n    let dnsRecordType = options.dnsRecordType;\n\n    if (networkMode === NetworkMode.BRIDGE || networkMode === NetworkMode.HOST) {\n      if (dnsRecordType ===  undefined) {\n        dnsRecordType = cloudmap.DnsRecordType.SRV;\n      }\n      if (dnsRecordType !== cloudmap.DnsRecordType.SRV) {\n        throw new Error(\"SRV records must be used when network mode is Bridge or Host.\");\n      }\n    }\n\n    // Default DNS record type for AwsVpc network mode is A Records\n    if (networkMode === NetworkMode.AWS_VPC) {\n      if (dnsRecordType ===  undefined) {\n        dnsRecordType = cloudmap.DnsRecordType.A;\n      }\n    }\n\n    // If the task definition that your service task specifies uses the AWSVPC network mode and a type SRV DNS record is\n    // used, you must specify a containerName and containerPort combination\n    const containerName = dnsRecordType === cloudmap.DnsRecordType.SRV ? this.taskDefinition.defaultContainer!.containerName : undefined;\n    const containerPort = dnsRecordType === cloudmap.DnsRecordType.SRV ? this.taskDefinition.defaultContainer!.containerPort : undefined;\n\n    const cloudmapService = new cloudmap.Service(this, 'CloudmapService', {\n      namespace: sdNamespace,\n      name: options.name,\n      dnsRecordType: dnsRecordType!,\n      customHealthCheck: { failureThreshold: options.failureThreshold || 1 }\n    });\n\n    const serviceArn = cloudmapService.serviceArn;\n\n    // add Cloudmap service to the ECS Service's serviceRegistry\n    this.addServiceRegistry({\n      arn: serviceArn,\n      containerName,\n      containerPort\n    });\n\n    this.cloudmapService = cloudmapService;\n\n    return cloudmapService;\n  }\n\n  /**\n   *  Return the default grace period when load balancers are configured and\n   *  healthCheckGracePeriod is not already set\n   */\n  private evaluateHealthGracePeriod(providedHealthCheckGracePeriod?: Duration): IResolvable {\n    return Lazy.anyValue({\n      produce: () => providedHealthCheckGracePeriod !== undefined ? providedHealthCheckGracePeriod.toSeconds() :\n                     this.loadBalancers.length > 0 ? 60 :\n                     undefined\n    });\n  }\n}\n\n/**\n * The port range to open up for dynamic port mapping\n */\nconst EPHEMERAL_PORT_RANGE = ec2.Port.tcpRange(32768, 65535);\n\n/**\n * The options to enabling AWS Cloud Map for an Amazon ECS service.\n */\nexport interface CloudMapOptions {\n  /**\n   * The name of the Cloud Map service to attach to the ECS service.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly name?: string,\n\n  /**\n   * The DNS record type that you want AWS Cloud Map to create. The supported record types are A or SRV.\n   *\n   * @default: A\n   */\n  readonly dnsRecordType?: cloudmap.DnsRecordType.A | cloudmap.DnsRecordType.SRV,\n\n  /**\n   * The amount of time that you want DNS resolvers to cache the settings for this record.\n   *\n   * @default 60\n   */\n  readonly dnsTtl?: Duration;\n\n  /**\n   * The number of 30-second intervals that you want Cloud Map to wait after receiving an UpdateInstanceCustomHealthStatus\n   * request before it changes the health status of a service instance.\n   *\n   * NOTE: This is used for HealthCheckCustomConfig\n   */\n  readonly failureThreshold?: number,\n}\n\n/**\n * Service Registry for ECS service\n */\ninterface ServiceRegistry {\n  /**\n   * Arn of the Cloud Map Service that will register a Cloud Map Instance for your ECS Service\n   */\n  readonly arn: string;\n\n  /**\n   * The container name value, already specified in the task definition, to be used for your service discovery service.\n   * If the task definition that your service task specifies uses the bridge or host network mode,\n   * you must specify a containerName and containerPort combination from the task definition.\n   * If the task definition that your service task specifies uses the awsvpc network mode and a type SRV DNS record is\n   * used, you must specify either a containerName and containerPort combination or a port value, but not both.\n   */\n  readonly containerName?: string;\n\n  /**\n   * The container port value, already specified in the task definition, to be used for your service discovery service.\n   * If the task definition that your service task specifies uses the bridge or host network mode,\n   * you must specify a containerName and containerPort combination from the task definition.\n   * If the task definition that your service task specifies uses the awsvpc network mode and a type SRV DNS record is\n   * used, you must specify either a containerName and containerPort combination or a port value, but not both.\n   */\n  readonly containerPort?: number;\n}\n\n/**\n * The launch type of an ECS service\n */\nexport enum LaunchType {\n  /**\n   * The service will be launched using the EC2 launch type\n   */\n  EC2 = 'EC2',\n\n  /**\n   * The service will be launched using the FARGATE launch type\n   */\n  FARGATE = 'FARGATE'\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-service.js","sourceRoot":"","sources":["base-service.ts"],"names":[],"mappings":"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","sourcesContent":["import appscaling = require('@aws-cdk/aws-applicationautoscaling');\nimport cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport elbv2 = require('@aws-cdk/aws-elasticloadbalancingv2');\nimport iam = require('@aws-cdk/aws-iam');\nimport cloudmap = require('@aws-cdk/aws-servicediscovery');\nimport { Construct, Duration, IResolvable, IResource, Lazy, Resource, Stack } from '@aws-cdk/core';\nimport { NetworkMode, TaskDefinition } from '../base/task-definition';\nimport { ICluster } from '../cluster';\nimport { CfnService } from '../ecs.generated';\nimport { ScalableTaskCount } from './scalable-task-count';\n\n/**\n * The interface for a service.\n */\nexport interface IService extends IResource {\n  /**\n   * The Amazon Resource Name (ARN) of the service.\n   *\n   * @attribute\n   */\n  readonly serviceArn: string;\n}\n\n/**\n * The properties for the base Ec2Service or FargateService service.\n */\nexport interface BaseServiceOptions {\n  /**\n   * The name of the cluster that hosts the service.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The desired number of instantiations of the task definition to keep running on the service.\n   *\n   * @default 1\n   */\n  readonly desiredCount?: number;\n\n  /**\n   * The name of the service.\n   *\n   * @default - CloudFormation-generated name.\n   */\n  readonly serviceName?: string;\n\n  /**\n   * The maximum number of tasks, specified as a percentage of the Amazon ECS\n   * service's DesiredCount value, that can run in a service during a\n   * deployment.\n   *\n   * @default - 100 if daemon, otherwise 200\n   */\n  readonly maxHealthyPercent?: number;\n\n  /**\n   * The minimum number of tasks, specified as a percentage of\n   * the Amazon ECS service's DesiredCount value, that must\n   * continue to run and remain healthy during a deployment.\n   *\n   * @default - 0 if daemon, otherwise 50\n   */\n  readonly minHealthyPercent?: number;\n\n  /**\n   * The period of time, in seconds, that the Amazon ECS service scheduler ignores unhealthy\n   * Elastic Load Balancing target health checks after a task has first started.\n   *\n   * @default - defaults to 60 seconds if at least one load balancer is in-use and it is not already set\n   */\n  readonly healthCheckGracePeriod?: Duration;\n\n  /**\n   * The options for configuring an Amazon ECS service to use service discovery.\n   *\n   * @default - AWS Cloud Map service discovery is not enabled.\n   */\n  readonly cloudMapOptions?: CloudMapOptions;\n}\n\n/**\n * Complete base service properties that are required to be supplied by the implementation\n * of the BaseService class.\n */\nexport interface BaseServiceProps extends BaseServiceOptions {\n  /**\n   * The launch type on which to run your service.\n   *\n   * Valid values are: LaunchType.ECS or LaunchType.FARGATE\n   */\n  readonly launchType: LaunchType;\n}\n\n/**\n * The base class for Ec2Service and FargateService services.\n */\nexport abstract class BaseService extends Resource\n  implements IService, elbv2.IApplicationLoadBalancerTarget, elbv2.INetworkLoadBalancerTarget {\n\n  /**\n   * The security groups which manage the allowed network traffic for the service.\n   */\n  public readonly connections: ec2.Connections = new ec2.Connections();\n\n  /**\n   * The Amazon Resource Name (ARN) of the service.\n   */\n  public readonly serviceArn: string;\n\n  /**\n   * The name of the service.\n   *\n   * @attribute\n   */\n  public readonly serviceName: string;\n\n  /**\n   * The task definition to use for tasks in the service.\n   */\n  public readonly taskDefinition: TaskDefinition;\n\n  /**\n   * The cluster that hosts the service.\n   */\n  public readonly cluster: ICluster;\n\n  /**\n   * The details of the AWS Cloud Map service.\n   */\n  protected cloudmapService?: cloudmap.Service;\n\n  /**\n   * A list of Elastic Load Balancing load balancer objects, containing the load balancer name, the container\n   * name (as it appears in a container definition), and the container port to access from the load balancer.\n   */\n  protected loadBalancers = new Array<CfnService.LoadBalancerProperty>();\n\n  /**\n   * A list of Elastic Load Balancing load balancer objects, containing the load balancer name, the container\n   * name (as it appears in a container definition), and the container port to access from the load balancer.\n   */\n  protected networkConfiguration?: CfnService.NetworkConfigurationProperty;\n\n  /**\n   * The details of the service discovery registries to assign to this service.\n   * For more information, see Service Discovery.\n   */\n  protected serviceRegistries = new Array<CfnService.ServiceRegistryProperty>();\n\n  private readonly resource: CfnService;\n  private scalableTaskCount?: ScalableTaskCount;\n\n  /**\n   * Constructs a new instance of the BaseService class.\n   */\n  constructor(scope: Construct,\n              id: string,\n              props: BaseServiceProps,\n              additionalProps: any,\n              taskDefinition: TaskDefinition) {\n    super(scope, id, {\n      physicalName: props.serviceName,\n    });\n\n    this.taskDefinition = taskDefinition;\n\n    this.resource = new CfnService(this, \"Service\", {\n      desiredCount: props.desiredCount,\n      serviceName: this.physicalName,\n      loadBalancers: Lazy.anyValue({ produce: () => this.loadBalancers }, { omitEmptyArray: true }),\n      deploymentConfiguration: {\n        maximumPercent: props.maxHealthyPercent || 200,\n        minimumHealthyPercent: props.minHealthyPercent === undefined ? 50 : props.minHealthyPercent\n      },\n      launchType: props.launchType,\n      healthCheckGracePeriodSeconds: this.evaluateHealthGracePeriod(props.healthCheckGracePeriod),\n      /* role: never specified, supplanted by Service Linked Role */\n      networkConfiguration: Lazy.anyValue({ produce: () => this.networkConfiguration }, { omitEmptyArray: true }),\n      serviceRegistries: Lazy.anyValue({ produce: () => this.serviceRegistries }, { omitEmptyArray: true }),\n      ...additionalProps\n    });\n\n    this.serviceArn = this.getResourceArnAttribute(this.resource.ref, {\n      service: 'ecs',\n      resource: 'service',\n      resourceName: `${props.cluster.clusterName}/${this.physicalName}`,\n    });\n    this.serviceName = this.getResourceNameAttribute(this.resource.attrName);\n\n    this.cluster = props.cluster;\n\n    if (props.cloudMapOptions) {\n      this.enableCloudMap(props.cloudMapOptions);\n    }\n  }\n\n  /**\n   * This method is called to attach this service to an Application Load Balancer.\n   *\n   * Don't call this function directly. Instead, call listener.addTarget()\n   * to add this service to a load balancer.\n   */\n  public attachToApplicationTargetGroup(targetGroup: elbv2.ApplicationTargetGroup): elbv2.LoadBalancerTargetProps {\n    const ret = this.attachToELBv2(targetGroup);\n\n    // Open up security groups. For dynamic port mapping, we won't know the port range\n    // in advance so we need to open up all ports.\n    const port = this.taskDefinition.defaultContainer!.ingressPort;\n    const portRange = port === 0 ? EPHEMERAL_PORT_RANGE : ec2.Port.tcp(port);\n    targetGroup.registerConnectable(this, portRange);\n\n    return ret;\n  }\n\n  /**\n   * This method is called to attach this service to a Network Load Balancer.\n   *\n   * Don't call this function directly. Instead, call listener.addTarget()\n   * to add this service to a load balancer.\n   */\n  public attachToNetworkTargetGroup(targetGroup: elbv2.NetworkTargetGroup): elbv2.LoadBalancerTargetProps {\n    return this.attachToELBv2(targetGroup);\n  }\n\n  /**\n   * An attribute representing the minimum and maximum task count for an AutoScalingGroup.\n   */\n  public autoScaleTaskCount(props: appscaling.EnableScalingProps) {\n    if (this.scalableTaskCount) {\n      throw new Error('AutoScaling of task count already enabled for this service');\n    }\n\n    return this.scalableTaskCount = new ScalableTaskCount(this, 'TaskCount', {\n      serviceNamespace: appscaling.ServiceNamespace.ECS,\n      resourceId: `service/${this.cluster.clusterName}/${this.serviceName}`,\n      dimension: 'ecs:service:DesiredCount',\n      role: this.makeAutoScalingRole(),\n      ...props\n    });\n  }\n\n  /**\n   * This method returns the specified CloudWatch metric name for this service.\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ECS',\n      metricName,\n      dimensions: { ClusterName: this.cluster.clusterName, ServiceName: this.serviceName },\n      ...props\n    });\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters memory utilization.\n   *\n   * @default average over 5 minutes\n   */\n  public metricMemoryUtilization(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('MemoryUtilization', props);\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters CPU utilization.\n   *\n   * @default average over 5 minutes\n   */\n  public metricCpuUtilization(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('CPUUtilization', props);\n  }\n\n  /**\n   * This method is called to create a networkConfiguration.\n   */\n  // tslint:disable-next-line:max-line-length\n  protected configureAwsVpcNetworking(vpc: ec2.IVpc, assignPublicIp?: boolean, vpcSubnets?: ec2.SubnetSelection, securityGroup?: ec2.ISecurityGroup) {\n    if (vpcSubnets === undefined) {\n      vpcSubnets = { subnetType: assignPublicIp ? ec2.SubnetType.PUBLIC : ec2.SubnetType.PRIVATE };\n    }\n    if (securityGroup === undefined) {\n      securityGroup = new ec2.SecurityGroup(this, 'SecurityGroup', { vpc });\n    }\n    this.connections.addSecurityGroup(securityGroup);\n\n    this.networkConfiguration = {\n      awsvpcConfiguration: {\n        assignPublicIp: assignPublicIp ? 'ENABLED' : 'DISABLED',\n        subnets: vpc.selectSubnets(vpcSubnets).subnetIds,\n        securityGroups: Lazy.listValue({ produce: () => [securityGroup!.securityGroupId] }),\n      }\n    };\n  }\n\n  private renderServiceRegistry(registry: ServiceRegistry): CfnService.ServiceRegistryProperty {\n    return {\n      registryArn: registry.arn,\n      containerName: registry.containerName,\n      containerPort: registry.containerPort,\n    };\n  }\n\n  /**\n   * Shared logic for attaching to an ELBv2\n   */\n  private attachToELBv2(targetGroup: elbv2.ITargetGroup): elbv2.LoadBalancerTargetProps {\n    if (this.taskDefinition.networkMode === NetworkMode.NONE) {\n      throw new Error(\"Cannot use a load balancer if NetworkMode is None. Use Bridge, Host or AwsVpc instead.\");\n    }\n\n    this.loadBalancers.push({\n      targetGroupArn: targetGroup.targetGroupArn,\n      containerName: this.taskDefinition.defaultContainer!.containerName,\n      containerPort: this.taskDefinition.defaultContainer!.containerPort,\n    });\n\n    // Service creation can only happen after the load balancer has\n    // been associated with our target group(s), so add ordering dependency.\n    this.resource.node.addDependency(targetGroup.loadBalancerAttached);\n\n    const targetType = this.taskDefinition.networkMode === NetworkMode.AWS_VPC ? elbv2.TargetType.IP : elbv2.TargetType.INSTANCE;\n    return { targetType };\n  }\n\n  /**\n   * Generate the role that will be used for autoscaling this service\n   */\n  private makeAutoScalingRole(): iam.IRole {\n    // Use a Service Linked Role.\n    return iam.Role.fromRoleArn(this, 'ScalingRole', Stack.of(this).formatArn({\n      service: 'iam',\n      resource: 'role/aws-service-role/ecs.application-autoscaling.amazonaws.com',\n      resourceName: 'AWSServiceRoleForApplicationAutoScaling_ECSService',\n    }));\n  }\n\n  /**\n   * Associate Service Discovery (Cloud Map) service\n   */\n  private addServiceRegistry(registry: ServiceRegistry) {\n    const sr = this.renderServiceRegistry(registry);\n    this.serviceRegistries.push(sr);\n  }\n\n  /**\n   * Enable CloudMap service discovery for the service\n   */\n  private enableCloudMap(options: CloudMapOptions): cloudmap.Service {\n    const sdNamespace = this.cluster.defaultCloudMapNamespace;\n    if (sdNamespace === undefined) {\n      throw new Error(\"Cannot enable service discovery if a Cloudmap Namespace has not been created in the cluster.\");\n    }\n\n    // Determine DNS type based on network mode\n    const networkMode = this.taskDefinition.networkMode;\n    if (networkMode === NetworkMode.NONE) {\n      throw new Error(\"Cannot use a service discovery if NetworkMode is None. Use Bridge, Host or AwsVpc instead.\");\n    }\n\n    // Bridge or host network mode requires SRV records\n    let dnsRecordType = options.dnsRecordType;\n\n    if (networkMode === NetworkMode.BRIDGE || networkMode === NetworkMode.HOST) {\n      if (dnsRecordType ===  undefined) {\n        dnsRecordType = cloudmap.DnsRecordType.SRV;\n      }\n      if (dnsRecordType !== cloudmap.DnsRecordType.SRV) {\n        throw new Error(\"SRV records must be used when network mode is Bridge or Host.\");\n      }\n    }\n\n    // Default DNS record type for AwsVpc network mode is A Records\n    if (networkMode === NetworkMode.AWS_VPC) {\n      if (dnsRecordType ===  undefined) {\n        dnsRecordType = cloudmap.DnsRecordType.A;\n      }\n    }\n\n    // If the task definition that your service task specifies uses the AWSVPC network mode and a type SRV DNS record is\n    // used, you must specify a containerName and containerPort combination\n    const containerName = dnsRecordType === cloudmap.DnsRecordType.SRV ? this.taskDefinition.defaultContainer!.containerName : undefined;\n    const containerPort = dnsRecordType === cloudmap.DnsRecordType.SRV ? this.taskDefinition.defaultContainer!.containerPort : undefined;\n\n    const cloudmapService = new cloudmap.Service(this, 'CloudmapService', {\n      namespace: sdNamespace,\n      name: options.name,\n      dnsRecordType: dnsRecordType!,\n      customHealthCheck: { failureThreshold: options.failureThreshold || 1 }\n    });\n\n    const serviceArn = cloudmapService.serviceArn;\n\n    // add Cloudmap service to the ECS Service's serviceRegistry\n    this.addServiceRegistry({\n      arn: serviceArn,\n      containerName,\n      containerPort\n    });\n\n    this.cloudmapService = cloudmapService;\n\n    return cloudmapService;\n  }\n\n  /**\n   *  Return the default grace period when load balancers are configured and\n   *  healthCheckGracePeriod is not already set\n   */\n  private evaluateHealthGracePeriod(providedHealthCheckGracePeriod?: Duration): IResolvable {\n    return Lazy.anyValue({\n      produce: () => providedHealthCheckGracePeriod !== undefined ? providedHealthCheckGracePeriod.toSeconds() :\n                     this.loadBalancers.length > 0 ? 60 :\n                     undefined\n    });\n  }\n}\n\n/**\n * The port range to open up for dynamic port mapping\n */\nconst EPHEMERAL_PORT_RANGE = ec2.Port.tcpRange(32768, 65535);\n\n/**\n * The options to enabling AWS Cloud Map for an Amazon ECS service.\n */\nexport interface CloudMapOptions {\n  /**\n   * The name of the Cloud Map service to attach to the ECS service.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly name?: string,\n\n  /**\n   * The DNS record type that you want AWS Cloud Map to create. The supported record types are A or SRV.\n   *\n   * @default: A\n   */\n  readonly dnsRecordType?: cloudmap.DnsRecordType.A | cloudmap.DnsRecordType.SRV,\n\n  /**\n   * The amount of time that you want DNS resolvers to cache the settings for this record.\n   *\n   * @default 60\n   */\n  readonly dnsTtl?: Duration;\n\n  /**\n   * The number of 30-second intervals that you want Cloud Map to wait after receiving an UpdateInstanceCustomHealthStatus\n   * request before it changes the health status of a service instance.\n   *\n   * NOTE: This is used for HealthCheckCustomConfig\n   */\n  readonly failureThreshold?: number,\n}\n\n/**\n * Service Registry for ECS service\n */\ninterface ServiceRegistry {\n  /**\n   * Arn of the Cloud Map Service that will register a Cloud Map Instance for your ECS Service\n   */\n  readonly arn: string;\n\n  /**\n   * The container name value, already specified in the task definition, to be used for your service discovery service.\n   * If the task definition that your service task specifies uses the bridge or host network mode,\n   * you must specify a containerName and containerPort combination from the task definition.\n   * If the task definition that your service task specifies uses the awsvpc network mode and a type SRV DNS record is\n   * used, you must specify either a containerName and containerPort combination or a port value, but not both.\n   */\n  readonly containerName?: string;\n\n  /**\n   * The container port value, already specified in the task definition, to be used for your service discovery service.\n   * If the task definition that your service task specifies uses the bridge or host network mode,\n   * you must specify a containerName and containerPort combination from the task definition.\n   * If the task definition that your service task specifies uses the awsvpc network mode and a type SRV DNS record is\n   * used, you must specify either a containerName and containerPort combination or a port value, but not both.\n   */\n  readonly containerPort?: number;\n}\n\n/**\n * The launch type of an ECS service\n */\nexport enum LaunchType {\n  /**\n   * The service will be launched using the EC2 launch type\n   */\n  EC2 = 'EC2',\n\n  /**\n   * The service will be launched using the FARGATE launch type\n   */\n  FARGATE = 'FARGATE'\n}"]}

@@ -63,4 +63,4 @@ "use strict";

const taskDef = new ecs_generated_1.CfnTaskDefinition(this, 'Resource', {
containerDefinitions: core_1.Lazy.anyValue({ produce: () => this.containers.map(x => x.renderContainerDefinition(this)) }),
volumes: core_1.Lazy.anyValue({ produce: () => this.volumes }),
containerDefinitions: core_1.Lazy.anyValue({ produce: () => this.containers.map(x => x.renderContainerDefinition(this)) }, { omitEmptyArray: true }),
volumes: core_1.Lazy.anyValue({ produce: () => this.volumes }, { omitEmptyArray: true }),
executionRoleArn: core_1.Lazy.stringValue({ produce: () => this.executionRole && this.executionRole.roleArn }),

@@ -74,4 +74,4 @@ family: this.family,

networkMode: this.networkMode,
placementConstraints: core_1.Lazy.anyValue({ produce: () => !isFargateCompatible(this.compatibility) && this.placementConstraints.length > 0 ? this.placementConstraints : undefined
}),
placementConstraints: core_1.Lazy.anyValue({ produce: () => !isFargateCompatible(this.compatibility) ? this.placementConstraints : undefined
}, { omitEmptyArray: true }),
cpu: props.cpu,

@@ -256,2 +256,2 @@ memory: props.memoryMiB,

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-definition.js","sourceRoot":"","sources":["task-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport { Construct, IResource, Lazy, Resource } from '@aws-cdk/core';\nimport { ContainerDefinition, ContainerDefinitionOptions } from '../container-definition';\nimport { CfnTaskDefinition } from '../ecs.generated';\nimport { PlacementConstraint } from '../placement';\n\n/**\n * The interface for all task definitions.\n */\nexport interface ITaskDefinition extends IResource {\n  /**\n   * ARN of this task definition\n   * @attribute\n   */\n  readonly taskDefinitionArn: string;\n\n  /**\n   * Execution role for this task definition\n   */\n  readonly executionRole?: iam.IRole;\n\n  /**\n   * What launch types this task definition should be compatible with.\n   */\n  readonly compatibility: Compatibility;\n\n  /**\n   * Return true if the task definition can be run on an EC2 cluster\n   */\n  readonly isEc2Compatible: boolean;\n\n  /**\n   * Return true if the task definition can be run on a Fargate cluster\n   */\n  readonly isFargateCompatible: boolean;\n}\n\n/**\n * The common properties for all task definitions. For more information, see\n * [Task Definition Parameters](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definition_parameters.html).\n */\nexport interface CommonTaskDefinitionProps {\n  /**\n   * The name of a family that this task definition is registered to. A family groups multiple versions of a task definition.\n   *\n   * @default - Automatically generated name.\n   */\n  readonly family?: string;\n\n  /**\n   * The name of the IAM task execution role that grants the ECS agent to call AWS APIs on your behalf.\n   *\n   * The role will be used to retrieve container images from ECR and create CloudWatch log groups.\n   *\n   * @default - An execution role will be automatically created if you use ECR images in your task definition.\n   */\n  readonly executionRole?: iam.IRole;\n\n  /**\n   * The name of the IAM role that grants containers in the task permission to call AWS APIs on your behalf.\n   *\n   * @default - A task role is automatically created for you.\n   */\n  readonly taskRole?: iam.IRole;\n\n  /**\n   * The list of volume definitions for the task. For more information, see\n   * [Task Definition Parameter Volumes](https://docs.aws.amazon.com/AmazonECS/latest/developerguide//task_definition_parameters.html#volumes).\n   *\n   * @default - No volumes are passed to the Docker daemon on a container instance.\n   */\n  readonly volumes?: Volume[];\n}\n\n/**\n * The properties for task definitions.\n */\nexport interface TaskDefinitionProps extends CommonTaskDefinitionProps {\n  /**\n   * The networking mode to use for the containers in the task.\n   *\n   * On Fargate, the only supported networking mode is AwsVpc.\n   *\n   * @default - NetworkMode.Bridge for EC2 tasks, AwsVpc for Fargate tasks.\n   */\n  readonly networkMode?: NetworkMode;\n\n  /**\n   * The placement constraints to use for tasks in the service.\n   *\n   * You can specify a maximum of 10 constraints per task (this limit includes\n   * constraints in the task definition and those specified at run time).\n   *\n   * Not supported in Fargate.\n   *\n   * @default - No placement constraints.\n   */\n  readonly placementConstraints?: PlacementConstraint[];\n\n  /**\n   * The task launch type compatiblity requirement.\n   */\n  readonly compatibility: Compatibility;\n\n  /**\n   * The number of cpu units used by the task.\n   *\n   * If you are using the EC2 launch type, this field is optional and any value can be used.\n   * If you are using the Fargate launch type, this field is required and you must use one of the following values,\n   * which determines your range of valid values for the memory parameter:\n   *\n   * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB)\n   * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB)\n   * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)\n   * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB)\n   * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB)\n   *\n   * @default - CPU units are not specified.\n   */\n  readonly cpu?: string;\n\n  /**\n   * The amount (in MiB) of memory used by the task.\n   *\n   * If using the EC2 launch type, this field is optional and any value can be used.\n   * If using the Fargate launch type, this field is required and you must use one of the following values,\n   * which determines your range of valid values for the cpu parameter:\n   *\n   * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25 vCPU)\n   * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values: 512 (.5 vCPU)\n   * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)\n   * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) - Available cpu values: 2048 (2 vCPU)\n   * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) - Available cpu values: 4096 (4 vCPU)\n   *\n   * @default - Memory used by task is not specified.\n   */\n  readonly memoryMiB?: string;\n}\n\nabstract class TaskDefinitionBase extends Resource implements ITaskDefinition {\n\n  public abstract readonly compatibility: Compatibility;\n  public abstract readonly taskDefinitionArn: string;\n  public abstract readonly executionRole?: iam.IRole;\n\n  /**\n   * Return true if the task definition can be run on an EC2 cluster\n   */\n  public get isEc2Compatible(): boolean {\n    return isEc2Compatible(this.compatibility);\n  }\n\n  /**\n   * Return true if the task definition can be run on a Fargate cluster\n   */\n  public get isFargateCompatible(): boolean {\n    return isFargateCompatible(this.compatibility);\n  }\n}\n\n/**\n * The base class for all task definitions.\n */\nexport class TaskDefinition extends TaskDefinitionBase {\n\n  /**\n   * Imports a task definition from the specified task definition ARN.\n   *\n   * The task will have a compatibility of EC2+Fargate.\n   */\n  public static fromTaskDefinitionArn(scope: Construct, id: string, taskDefinitionArn: string): ITaskDefinition {\n    class Import extends TaskDefinitionBase {\n      public readonly taskDefinitionArn = taskDefinitionArn;\n      public readonly compatibility = Compatibility.EC2_AND_FARGATE;\n      public readonly executionRole?: iam.IRole = undefined;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The name of a family that this task definition is registered to.\n   * A family groups multiple versions of a task definition.\n   */\n  public readonly family: string;\n\n  /**\n   * The full Amazon Resource Name (ARN) of the task definition.\n   * @attribute\n   */\n  public readonly taskDefinitionArn: string;\n\n  /**\n   * The name of the IAM role that grants containers in the task permission to call AWS APIs on your behalf.\n   */\n  public readonly taskRole: iam.IRole;\n\n  /**\n   * The networking mode to use for the containers in the task.\n   */\n  public readonly networkMode: NetworkMode;\n\n  /**\n   * Default container for this task\n   *\n   * Load balancers will send traffic to this container. The first\n   * essential container that is added to this task will become the default\n   * container.\n   */\n  public defaultContainer?: ContainerDefinition;\n\n  /**\n   * The task launch type compatiblity requirement.\n   */\n  public readonly compatibility: Compatibility;\n\n  /**\n   * The container definitions.\n   */\n  protected readonly containers = new Array<ContainerDefinition>();\n\n  /**\n   * All volumes\n   */\n  private readonly volumes: Volume[] = [];\n\n  /**\n   * Placement constraints for task instances\n   */\n  private readonly placementConstraints = new Array<CfnTaskDefinition.TaskDefinitionPlacementConstraintProperty>();\n\n  private _executionRole?: iam.IRole;\n\n  /**\n   * Constructs a new instance of the TaskDefinition class.\n   */\n  constructor(scope: Construct, id: string, props: TaskDefinitionProps) {\n    super(scope, id);\n\n    this.family = props.family || this.node.uniqueId;\n    this.compatibility = props.compatibility;\n\n    if (props.volumes) {\n      props.volumes.forEach(v => this.addVolume(v));\n    }\n\n    this.networkMode = props.networkMode !== undefined ? props.networkMode :\n                       this.isFargateCompatible ? NetworkMode.AWS_VPC : NetworkMode.BRIDGE;\n    if (this.isFargateCompatible && this.networkMode !== NetworkMode.AWS_VPC) {\n      throw new Error(`Fargate tasks can only have AwsVpc network mode, got: ${this.networkMode}`);\n    }\n\n    if (props.placementConstraints && props.placementConstraints.length > 0 && this.isFargateCompatible) {\n      throw new Error('Cannot set placement constraints on tasks that run on Fargate');\n    }\n\n    if (this.isFargateCompatible && (!props.cpu || !props.memoryMiB)) {\n      throw new Error(`Fargate-compatible tasks require both CPU (${props.cpu}) and memory (${props.memoryMiB}) specifications`);\n    }\n\n    this._executionRole = props.executionRole;\n\n    this.taskRole = props.taskRole || new iam.Role(this, 'TaskRole', {\n        assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'),\n    });\n\n    const taskDef = new CfnTaskDefinition(this, 'Resource', {\n      containerDefinitions: Lazy.anyValue({ produce: () => this.containers.map(x => x.renderContainerDefinition(this)) }),\n      volumes: Lazy.anyValue({ produce: () => this.volumes }),\n      executionRoleArn: Lazy.stringValue({ produce: () => this.executionRole && this.executionRole.roleArn }),\n      family: this.family,\n      taskRoleArn: this.taskRole.roleArn,\n      requiresCompatibilities: [\n        ...(isEc2Compatible(props.compatibility) ? [\"EC2\"] : []),\n        ...(isFargateCompatible(props.compatibility) ? [\"FARGATE\"] : []),\n      ],\n      networkMode: this.networkMode,\n      placementConstraints: Lazy.anyValue({ produce: () =>\n        !isFargateCompatible(this.compatibility) && this.placementConstraints.length > 0 ? this.placementConstraints : undefined\n      }),\n      cpu: props.cpu,\n      memory: props.memoryMiB,\n    });\n\n    if (props.placementConstraints) {\n      props.placementConstraints.forEach(pc => this.addPlacementConstraint(pc));\n    }\n\n    this.taskDefinitionArn = taskDef.ref;\n  }\n\n  public get executionRole(): iam.IRole | undefined {\n    return this._executionRole;\n  }\n\n  /**\n   * Adds a policy statement to the task IAM role.\n   */\n  public addToTaskRolePolicy(statement: iam.PolicyStatement) {\n    this.taskRole.addToPolicy(statement);\n  }\n\n  /**\n   * Adds a policy statement to the task execution IAM role.\n   */\n  public addToExecutionRolePolicy(statement: iam.PolicyStatement) {\n    this.obtainExecutionRole().addToPolicy(statement);\n  }\n\n  /**\n   * Adds a new container to the task definition.\n   */\n  public addContainer(id: string, props: ContainerDefinitionOptions) {\n    return new ContainerDefinition(this, id, { taskDefinition: this, ...props });\n  }\n\n  /**\n   * Links a container to this task definition.\n   * @internal\n   */\n  public _linkContainer(container: ContainerDefinition) {\n    this.containers.push(container);\n    if (this.defaultContainer === undefined && container.essential) {\n      this.defaultContainer = container;\n    }\n  }\n\n  /**\n   * Adds a volume to the task definition.\n   */\n  public addVolume(volume: Volume) {\n    this.volumes.push(volume);\n  }\n\n  /**\n   * Adds the specified placement constraint to the task definition.\n   */\n  public addPlacementConstraint(constraint: PlacementConstraint) {\n    if (isFargateCompatible(this.compatibility)) {\n      throw new Error('Cannot set placement constraints on tasks that run on Fargate');\n    }\n    this.placementConstraints.push(...constraint.toJson());\n  }\n\n  /**\n   * Adds the specified extention to the task definition.\n   *\n   * Extension can be used to apply a packaged modification to\n   * a task definition.\n   */\n  public addExtension(extension: ITaskDefinitionExtension) {\n    extension.extend(this);\n  }\n\n  /**\n   * Creates the task execution IAM role if it doesn't already exist.\n   */\n  public obtainExecutionRole(): iam.IRole {\n    if (!this._executionRole) {\n      this._executionRole = new iam.Role(this, 'ExecutionRole', {\n        assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'),\n      });\n    }\n    return this._executionRole;\n  }\n\n  /**\n   * Validates the task definition.\n   */\n  protected validate(): string[] {\n    const ret = super.validate();\n\n    if (isEc2Compatible(this.compatibility)) {\n      // EC2 mode validations\n\n      // Container sizes\n      for (const container of this.containers) {\n        if (!container.memoryLimitSpecified) {\n          ret.push(`ECS Container ${container.containerName} must have at least one of 'memoryLimitMiB' or 'memoryReservationMiB' specified`);\n        }\n      }\n    }\n    return ret;\n  }\n}\n\n/**\n * The networking mode to use for the containers in the task.\n */\nexport enum NetworkMode {\n  /**\n   * The task's containers do not have external connectivity and port mappings can't be specified in the container definition.\n   */\n  NONE = 'none',\n\n  /**\n   * The task utilizes Docker's built-in virtual network which runs inside each container instance.\n   */\n  BRIDGE = 'bridge',\n\n  /**\n   * The task is allocated an elastic network interface.\n   */\n  AWS_VPC = 'awsvpc',\n\n  /**\n   * The task bypasses Docker's built-in virtual network and maps container ports directly to the EC2 instance's network interface directly.\n   *\n   * In this mode, you can't run multiple instantiations of the same task on a\n   * single container instance when port mappings are used.\n   */\n  HOST = 'host',\n}\n\n/**\n * A data volume used in a task definition.\n *\n * For tasks that use a Docker volume, specify a DockerVolumeConfiguration.\n * For tasks that use a bind mount host volume, specify a host and optional sourcePath.\n *\n * For more information, see [Using Data Volumes in Tasks](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/using_data_volumes.html).\n */\nexport interface Volume {\n  /**\n   * This property is specified when you are using bind mount host volumes.\n   *\n   * Bind mount host volumes are supported when you are using either the EC2 or Fargate launch types.\n   * The contents of the host parameter determine whether your bind mount host volume persists on the\n   * host container instance and where it is stored. If the host parameter is empty, then the Docker\n   * daemon assigns a host path for your data volume. However, the data is not guaranteed to persist\n   * after the containers associated with it stop running.\n   */\n  readonly host?: Host;\n\n  /**\n   * The name of the volume.\n   *\n   * Up to 255 letters (uppercase and lowercase), numbers, and hyphens are allowed.\n   * This name is referenced in the sourceVolume parameter of container definition mountPoints.\n   */\n  readonly name: string;\n\n  /**\n   * This property is specified when you are using Docker volumes.\n   *\n   * Docker volumes are only supported when you are using the EC2 launch type.\n   * Windows containers only support the use of the local driver.\n   * To use bind mounts, specify a host instead.\n   */\n  readonly dockerVolumeConfiguration?: DockerVolumeConfiguration;\n}\n\n/**\n * The details on a container instance bind mount host volume.\n */\nexport interface Host {\n  /**\n   * Specifies the path on the host container instance that is presented to the container.\n   * If the sourcePath value does not exist on the host container instance, the Docker daemon creates it.\n   * If the location does exist, the contents of the source path folder are exported.\n   *\n   * This property is not supported for tasks that use the Fargate launch type.\n   */\n  readonly sourcePath?: string;\n}\n\n/**\n * The configuration for a Docker volume. Docker volumes are only supported when you are using the EC2 launch type.\n */\nexport interface DockerVolumeConfiguration {\n  /**\n   * Specifies whether the Docker volume should be created if it does not already exist.\n   * If true is specified, the Docker volume will be created for you.\n   *\n   * @default false\n   */\n  readonly autoprovision?: boolean;\n  /**\n   * The Docker volume driver to use.\n   */\n  readonly driver: string;\n  /**\n   * A map of Docker driver-specific options passed through.\n   *\n   * @default No options\n   */\n  readonly driverOpts?: {[key: string]: string};\n  /**\n   * Custom metadata to add to your Docker volume.\n   *\n   * @default No labels\n   */\n  readonly labels?: string[];\n  /**\n   * The scope for the Docker volume that determines its lifecycle.\n   */\n  readonly scope: Scope;\n}\n\n/**\n * The scope for the Docker volume that determines its lifecycle.\n * Docker volumes that are scoped to a task are automatically provisioned when the task starts and destroyed when the task stops.\n * Docker volumes that are scoped as shared persist after the task stops.\n */\nexport enum Scope {\n  /**\n   * Docker volumes that are scoped to a task are automatically provisioned when the task starts and destroyed when the task stops.\n   */\n  TASK = \"task\",\n\n  /**\n   * Docker volumes that are scoped as shared persist after the task stops.\n   */\n  SHARED = \"shared\"\n}\n\n/**\n * The task launch type compatibility requirement.\n */\nexport enum Compatibility {\n  /**\n   * The task should specify the EC2 launch type.\n   */\n  EC2,\n\n  /**\n   * The task should specify the Fargate launch type.\n   */\n  FARGATE,\n\n  /**\n   * The task can specify either the EC2 or Fargate launch types.\n   */\n  EC2_AND_FARGATE\n}\n\n/**\n * An extension for Task Definitions\n *\n * Classes that want to make changes to a TaskDefinition (such as\n * adding helper containers) can implement this interface, and can\n * then be \"added\" to a TaskDefinition like so:\n *\n *    taskDefinition.addExtension(new MyExtension(\"some_parameter\"));\n */\nexport interface ITaskDefinitionExtension {\n  /**\n   * Apply the extension to the given TaskDefinition\n   *\n   * @param taskDefinition [disable-awslint:ref-via-interface]\n   */\n  extend(taskDefinition: TaskDefinition): void;\n}\n\n/**\n * Return true if the given task definition can be run on an EC2 cluster\n */\nfunction isEc2Compatible(compatibility: Compatibility): boolean {\n  return [Compatibility.EC2, Compatibility.EC2_AND_FARGATE].includes(compatibility);\n}\n\n/**\n * Return true if the given task definition can be run on a Fargate cluster\n */\nfunction isFargateCompatible(compatibility: Compatibility): boolean {\n  return [Compatibility.FARGATE, Compatibility.EC2_AND_FARGATE].includes(compatibility);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-definition.js","sourceRoot":"","sources":["task-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport { Construct, IResource, Lazy, Resource } from '@aws-cdk/core';\nimport { ContainerDefinition, ContainerDefinitionOptions } from '../container-definition';\nimport { CfnTaskDefinition } from '../ecs.generated';\nimport { PlacementConstraint } from '../placement';\n\n/**\n * The interface for all task definitions.\n */\nexport interface ITaskDefinition extends IResource {\n  /**\n   * ARN of this task definition\n   * @attribute\n   */\n  readonly taskDefinitionArn: string;\n\n  /**\n   * Execution role for this task definition\n   */\n  readonly executionRole?: iam.IRole;\n\n  /**\n   * What launch types this task definition should be compatible with.\n   */\n  readonly compatibility: Compatibility;\n\n  /**\n   * Return true if the task definition can be run on an EC2 cluster\n   */\n  readonly isEc2Compatible: boolean;\n\n  /**\n   * Return true if the task definition can be run on a Fargate cluster\n   */\n  readonly isFargateCompatible: boolean;\n}\n\n/**\n * The common properties for all task definitions. For more information, see\n * [Task Definition Parameters](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definition_parameters.html).\n */\nexport interface CommonTaskDefinitionProps {\n  /**\n   * The name of a family that this task definition is registered to. A family groups multiple versions of a task definition.\n   *\n   * @default - Automatically generated name.\n   */\n  readonly family?: string;\n\n  /**\n   * The name of the IAM task execution role that grants the ECS agent to call AWS APIs on your behalf.\n   *\n   * The role will be used to retrieve container images from ECR and create CloudWatch log groups.\n   *\n   * @default - An execution role will be automatically created if you use ECR images in your task definition.\n   */\n  readonly executionRole?: iam.IRole;\n\n  /**\n   * The name of the IAM role that grants containers in the task permission to call AWS APIs on your behalf.\n   *\n   * @default - A task role is automatically created for you.\n   */\n  readonly taskRole?: iam.IRole;\n\n  /**\n   * The list of volume definitions for the task. For more information, see\n   * [Task Definition Parameter Volumes](https://docs.aws.amazon.com/AmazonECS/latest/developerguide//task_definition_parameters.html#volumes).\n   *\n   * @default - No volumes are passed to the Docker daemon on a container instance.\n   */\n  readonly volumes?: Volume[];\n}\n\n/**\n * The properties for task definitions.\n */\nexport interface TaskDefinitionProps extends CommonTaskDefinitionProps {\n  /**\n   * The networking mode to use for the containers in the task.\n   *\n   * On Fargate, the only supported networking mode is AwsVpc.\n   *\n   * @default - NetworkMode.Bridge for EC2 tasks, AwsVpc for Fargate tasks.\n   */\n  readonly networkMode?: NetworkMode;\n\n  /**\n   * The placement constraints to use for tasks in the service.\n   *\n   * You can specify a maximum of 10 constraints per task (this limit includes\n   * constraints in the task definition and those specified at run time).\n   *\n   * Not supported in Fargate.\n   *\n   * @default - No placement constraints.\n   */\n  readonly placementConstraints?: PlacementConstraint[];\n\n  /**\n   * The task launch type compatiblity requirement.\n   */\n  readonly compatibility: Compatibility;\n\n  /**\n   * The number of cpu units used by the task.\n   *\n   * If you are using the EC2 launch type, this field is optional and any value can be used.\n   * If you are using the Fargate launch type, this field is required and you must use one of the following values,\n   * which determines your range of valid values for the memory parameter:\n   *\n   * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB)\n   * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB)\n   * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)\n   * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB)\n   * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB)\n   *\n   * @default - CPU units are not specified.\n   */\n  readonly cpu?: string;\n\n  /**\n   * The amount (in MiB) of memory used by the task.\n   *\n   * If using the EC2 launch type, this field is optional and any value can be used.\n   * If using the Fargate launch type, this field is required and you must use one of the following values,\n   * which determines your range of valid values for the cpu parameter:\n   *\n   * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25 vCPU)\n   * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values: 512 (.5 vCPU)\n   * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)\n   * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) - Available cpu values: 2048 (2 vCPU)\n   * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) - Available cpu values: 4096 (4 vCPU)\n   *\n   * @default - Memory used by task is not specified.\n   */\n  readonly memoryMiB?: string;\n}\n\nabstract class TaskDefinitionBase extends Resource implements ITaskDefinition {\n\n  public abstract readonly compatibility: Compatibility;\n  public abstract readonly taskDefinitionArn: string;\n  public abstract readonly executionRole?: iam.IRole;\n\n  /**\n   * Return true if the task definition can be run on an EC2 cluster\n   */\n  public get isEc2Compatible(): boolean {\n    return isEc2Compatible(this.compatibility);\n  }\n\n  /**\n   * Return true if the task definition can be run on a Fargate cluster\n   */\n  public get isFargateCompatible(): boolean {\n    return isFargateCompatible(this.compatibility);\n  }\n}\n\n/**\n * The base class for all task definitions.\n */\nexport class TaskDefinition extends TaskDefinitionBase {\n\n  /**\n   * Imports a task definition from the specified task definition ARN.\n   *\n   * The task will have a compatibility of EC2+Fargate.\n   */\n  public static fromTaskDefinitionArn(scope: Construct, id: string, taskDefinitionArn: string): ITaskDefinition {\n    class Import extends TaskDefinitionBase {\n      public readonly taskDefinitionArn = taskDefinitionArn;\n      public readonly compatibility = Compatibility.EC2_AND_FARGATE;\n      public readonly executionRole?: iam.IRole = undefined;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The name of a family that this task definition is registered to.\n   * A family groups multiple versions of a task definition.\n   */\n  public readonly family: string;\n\n  /**\n   * The full Amazon Resource Name (ARN) of the task definition.\n   * @attribute\n   */\n  public readonly taskDefinitionArn: string;\n\n  /**\n   * The name of the IAM role that grants containers in the task permission to call AWS APIs on your behalf.\n   */\n  public readonly taskRole: iam.IRole;\n\n  /**\n   * The networking mode to use for the containers in the task.\n   */\n  public readonly networkMode: NetworkMode;\n\n  /**\n   * Default container for this task\n   *\n   * Load balancers will send traffic to this container. The first\n   * essential container that is added to this task will become the default\n   * container.\n   */\n  public defaultContainer?: ContainerDefinition;\n\n  /**\n   * The task launch type compatiblity requirement.\n   */\n  public readonly compatibility: Compatibility;\n\n  /**\n   * The container definitions.\n   */\n  protected readonly containers = new Array<ContainerDefinition>();\n\n  /**\n   * All volumes\n   */\n  private readonly volumes: Volume[] = [];\n\n  /**\n   * Placement constraints for task instances\n   */\n  private readonly placementConstraints = new Array<CfnTaskDefinition.TaskDefinitionPlacementConstraintProperty>();\n\n  private _executionRole?: iam.IRole;\n\n  /**\n   * Constructs a new instance of the TaskDefinition class.\n   */\n  constructor(scope: Construct, id: string, props: TaskDefinitionProps) {\n    super(scope, id);\n\n    this.family = props.family || this.node.uniqueId;\n    this.compatibility = props.compatibility;\n\n    if (props.volumes) {\n      props.volumes.forEach(v => this.addVolume(v));\n    }\n\n    this.networkMode = props.networkMode !== undefined ? props.networkMode :\n                       this.isFargateCompatible ? NetworkMode.AWS_VPC : NetworkMode.BRIDGE;\n    if (this.isFargateCompatible && this.networkMode !== NetworkMode.AWS_VPC) {\n      throw new Error(`Fargate tasks can only have AwsVpc network mode, got: ${this.networkMode}`);\n    }\n\n    if (props.placementConstraints && props.placementConstraints.length > 0 && this.isFargateCompatible) {\n      throw new Error('Cannot set placement constraints on tasks that run on Fargate');\n    }\n\n    if (this.isFargateCompatible && (!props.cpu || !props.memoryMiB)) {\n      throw new Error(`Fargate-compatible tasks require both CPU (${props.cpu}) and memory (${props.memoryMiB}) specifications`);\n    }\n\n    this._executionRole = props.executionRole;\n\n    this.taskRole = props.taskRole || new iam.Role(this, 'TaskRole', {\n        assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'),\n    });\n\n    const taskDef = new CfnTaskDefinition(this, 'Resource', {\n      containerDefinitions: Lazy.anyValue({ produce: () => this.containers.map(x => x.renderContainerDefinition(this)) }, { omitEmptyArray: true }),\n      volumes: Lazy.anyValue({ produce: () => this.volumes }, { omitEmptyArray: true }),\n      executionRoleArn: Lazy.stringValue({ produce: () => this.executionRole && this.executionRole.roleArn }),\n      family: this.family,\n      taskRoleArn: this.taskRole.roleArn,\n      requiresCompatibilities: [\n        ...(isEc2Compatible(props.compatibility) ? [\"EC2\"] : []),\n        ...(isFargateCompatible(props.compatibility) ? [\"FARGATE\"] : []),\n      ],\n      networkMode: this.networkMode,\n      placementConstraints: Lazy.anyValue({ produce: () =>\n        !isFargateCompatible(this.compatibility) ? this.placementConstraints : undefined\n      }, { omitEmptyArray: true }),\n      cpu: props.cpu,\n      memory: props.memoryMiB,\n    });\n\n    if (props.placementConstraints) {\n      props.placementConstraints.forEach(pc => this.addPlacementConstraint(pc));\n    }\n\n    this.taskDefinitionArn = taskDef.ref;\n  }\n\n  public get executionRole(): iam.IRole | undefined {\n    return this._executionRole;\n  }\n\n  /**\n   * Adds a policy statement to the task IAM role.\n   */\n  public addToTaskRolePolicy(statement: iam.PolicyStatement) {\n    this.taskRole.addToPolicy(statement);\n  }\n\n  /**\n   * Adds a policy statement to the task execution IAM role.\n   */\n  public addToExecutionRolePolicy(statement: iam.PolicyStatement) {\n    this.obtainExecutionRole().addToPolicy(statement);\n  }\n\n  /**\n   * Adds a new container to the task definition.\n   */\n  public addContainer(id: string, props: ContainerDefinitionOptions) {\n    return new ContainerDefinition(this, id, { taskDefinition: this, ...props });\n  }\n\n  /**\n   * Links a container to this task definition.\n   * @internal\n   */\n  public _linkContainer(container: ContainerDefinition) {\n    this.containers.push(container);\n    if (this.defaultContainer === undefined && container.essential) {\n      this.defaultContainer = container;\n    }\n  }\n\n  /**\n   * Adds a volume to the task definition.\n   */\n  public addVolume(volume: Volume) {\n    this.volumes.push(volume);\n  }\n\n  /**\n   * Adds the specified placement constraint to the task definition.\n   */\n  public addPlacementConstraint(constraint: PlacementConstraint) {\n    if (isFargateCompatible(this.compatibility)) {\n      throw new Error('Cannot set placement constraints on tasks that run on Fargate');\n    }\n    this.placementConstraints.push(...constraint.toJson());\n  }\n\n  /**\n   * Adds the specified extention to the task definition.\n   *\n   * Extension can be used to apply a packaged modification to\n   * a task definition.\n   */\n  public addExtension(extension: ITaskDefinitionExtension) {\n    extension.extend(this);\n  }\n\n  /**\n   * Creates the task execution IAM role if it doesn't already exist.\n   */\n  public obtainExecutionRole(): iam.IRole {\n    if (!this._executionRole) {\n      this._executionRole = new iam.Role(this, 'ExecutionRole', {\n        assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'),\n      });\n    }\n    return this._executionRole;\n  }\n\n  /**\n   * Validates the task definition.\n   */\n  protected validate(): string[] {\n    const ret = super.validate();\n\n    if (isEc2Compatible(this.compatibility)) {\n      // EC2 mode validations\n\n      // Container sizes\n      for (const container of this.containers) {\n        if (!container.memoryLimitSpecified) {\n          ret.push(`ECS Container ${container.containerName} must have at least one of 'memoryLimitMiB' or 'memoryReservationMiB' specified`);\n        }\n      }\n    }\n    return ret;\n  }\n}\n\n/**\n * The networking mode to use for the containers in the task.\n */\nexport enum NetworkMode {\n  /**\n   * The task's containers do not have external connectivity and port mappings can't be specified in the container definition.\n   */\n  NONE = 'none',\n\n  /**\n   * The task utilizes Docker's built-in virtual network which runs inside each container instance.\n   */\n  BRIDGE = 'bridge',\n\n  /**\n   * The task is allocated an elastic network interface.\n   */\n  AWS_VPC = 'awsvpc',\n\n  /**\n   * The task bypasses Docker's built-in virtual network and maps container ports directly to the EC2 instance's network interface directly.\n   *\n   * In this mode, you can't run multiple instantiations of the same task on a\n   * single container instance when port mappings are used.\n   */\n  HOST = 'host',\n}\n\n/**\n * A data volume used in a task definition.\n *\n * For tasks that use a Docker volume, specify a DockerVolumeConfiguration.\n * For tasks that use a bind mount host volume, specify a host and optional sourcePath.\n *\n * For more information, see [Using Data Volumes in Tasks](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/using_data_volumes.html).\n */\nexport interface Volume {\n  /**\n   * This property is specified when you are using bind mount host volumes.\n   *\n   * Bind mount host volumes are supported when you are using either the EC2 or Fargate launch types.\n   * The contents of the host parameter determine whether your bind mount host volume persists on the\n   * host container instance and where it is stored. If the host parameter is empty, then the Docker\n   * daemon assigns a host path for your data volume. However, the data is not guaranteed to persist\n   * after the containers associated with it stop running.\n   */\n  readonly host?: Host;\n\n  /**\n   * The name of the volume.\n   *\n   * Up to 255 letters (uppercase and lowercase), numbers, and hyphens are allowed.\n   * This name is referenced in the sourceVolume parameter of container definition mountPoints.\n   */\n  readonly name: string;\n\n  /**\n   * This property is specified when you are using Docker volumes.\n   *\n   * Docker volumes are only supported when you are using the EC2 launch type.\n   * Windows containers only support the use of the local driver.\n   * To use bind mounts, specify a host instead.\n   */\n  readonly dockerVolumeConfiguration?: DockerVolumeConfiguration;\n}\n\n/**\n * The details on a container instance bind mount host volume.\n */\nexport interface Host {\n  /**\n   * Specifies the path on the host container instance that is presented to the container.\n   * If the sourcePath value does not exist on the host container instance, the Docker daemon creates it.\n   * If the location does exist, the contents of the source path folder are exported.\n   *\n   * This property is not supported for tasks that use the Fargate launch type.\n   */\n  readonly sourcePath?: string;\n}\n\n/**\n * The configuration for a Docker volume. Docker volumes are only supported when you are using the EC2 launch type.\n */\nexport interface DockerVolumeConfiguration {\n  /**\n   * Specifies whether the Docker volume should be created if it does not already exist.\n   * If true is specified, the Docker volume will be created for you.\n   *\n   * @default false\n   */\n  readonly autoprovision?: boolean;\n  /**\n   * The Docker volume driver to use.\n   */\n  readonly driver: string;\n  /**\n   * A map of Docker driver-specific options passed through.\n   *\n   * @default No options\n   */\n  readonly driverOpts?: {[key: string]: string};\n  /**\n   * Custom metadata to add to your Docker volume.\n   *\n   * @default No labels\n   */\n  readonly labels?: string[];\n  /**\n   * The scope for the Docker volume that determines its lifecycle.\n   */\n  readonly scope: Scope;\n}\n\n/**\n * The scope for the Docker volume that determines its lifecycle.\n * Docker volumes that are scoped to a task are automatically provisioned when the task starts and destroyed when the task stops.\n * Docker volumes that are scoped as shared persist after the task stops.\n */\nexport enum Scope {\n  /**\n   * Docker volumes that are scoped to a task are automatically provisioned when the task starts and destroyed when the task stops.\n   */\n  TASK = \"task\",\n\n  /**\n   * Docker volumes that are scoped as shared persist after the task stops.\n   */\n  SHARED = \"shared\"\n}\n\n/**\n * The task launch type compatibility requirement.\n */\nexport enum Compatibility {\n  /**\n   * The task should specify the EC2 launch type.\n   */\n  EC2,\n\n  /**\n   * The task should specify the Fargate launch type.\n   */\n  FARGATE,\n\n  /**\n   * The task can specify either the EC2 or Fargate launch types.\n   */\n  EC2_AND_FARGATE\n}\n\n/**\n * An extension for Task Definitions\n *\n * Classes that want to make changes to a TaskDefinition (such as\n * adding helper containers) can implement this interface, and can\n * then be \"added\" to a TaskDefinition like so:\n *\n *    taskDefinition.addExtension(new MyExtension(\"some_parameter\"));\n */\nexport interface ITaskDefinitionExtension {\n  /**\n   * Apply the extension to the given TaskDefinition\n   *\n   * @param taskDefinition [disable-awslint:ref-via-interface]\n   */\n  extend(taskDefinition: TaskDefinition): void;\n}\n\n/**\n * Return true if the given task definition can be run on an EC2 cluster\n */\nfunction isEc2Compatible(compatibility: Compatibility): boolean {\n  return [Compatibility.EC2, Compatibility.EC2_AND_FARGATE].includes(compatibility);\n}\n\n/**\n * Return true if the given task definition can be run on a Fargate cluster\n */\nfunction isFargateCompatible(compatibility: Compatibility): boolean {\n  return [Compatibility.FARGATE, Compatibility.EC2_AND_FARGATE].includes(compatibility);\n}\n"]}

@@ -41,3 +41,3 @@ import autoscaling = require('@aws-cdk/aws-autoscaling');

/**
* This method adds attributes from a specified cluster to this cluster.
* Import an existing cluster to the stack from its attributes.
*/

@@ -44,0 +44,0 @@ static fromClusterAttributes(scope: Construct, id: string, attrs: ClusterAttributes): ICluster;

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

/**
* This method adds attributes from a specified cluster to this cluster.
* Import an existing cluster to the stack from its attributes.
*/

@@ -365,2 +365,2 @@ static fromClusterAttributes(scope, id, attrs) {

})(AmiHardwareType = exports.AmiHardwareType || (exports.AmiHardwareType = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["cluster.ts"],"names":[],"mappings":"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","sourcesContent":["import autoscaling = require('@aws-cdk/aws-autoscaling');\nimport cloudwatch = require ('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport iam = require('@aws-cdk/aws-iam');\nimport cloudmap = require('@aws-cdk/aws-servicediscovery');\nimport ssm = require('@aws-cdk/aws-ssm');\nimport {Construct, Duration, IResource, Resource, Stack} from '@aws-cdk/core';\nimport {InstanceDrainHook} from './drain-hook/instance-drain-hook';\nimport {CfnCluster} from './ecs.generated';\n\n/**\n * The properties used to define an ECS cluster.\n */\nexport interface ClusterProps {\n  /**\n   * The name for the cluster.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly clusterName?: string;\n\n  /**\n   * The VPC where your ECS instances will be running or your ENIs will be deployed\n   *\n   * @default - creates a new VPC with two AZs\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * The service discovery namespace created in this cluster\n   *\n   * @default - no service discovery namespace created, you can use `addDefaultCloudMapNamespace` to add a\n   * default service discovery namespace later.\n   */\n  readonly defaultCloudMapNamespace?: CloudMapNamespaceOptions;\n\n  /**\n   * The ec2 capacity to add to the cluster\n   *\n   * @default - no EC2 capacity will be added, you can use `addCapacity` to add capacity later.\n   */\n  readonly capacity?: AddCapacityOptions;\n}\n\n/**\n * A regional grouping of one or more container instances on which you can run tasks and services.\n */\nexport class Cluster extends Resource implements ICluster {\n  /**\n   * This method adds attributes from a specified cluster to this cluster.\n   */\n  public static fromClusterAttributes(scope: Construct, id: string, attrs: ClusterAttributes): ICluster {\n    return new ImportedCluster(scope, id, attrs);\n  }\n\n  /**\n   * Manage the allowed network connections for the cluster with Security Groups.\n   */\n  public readonly connections: ec2.Connections = new ec2.Connections();\n\n  /**\n   * The VPC associated with the cluster.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The Amazon Resource Name (ARN) that identifies the cluster.\n   */\n  public readonly clusterArn: string;\n\n  /**\n   * The name of the cluster.\n   */\n  public readonly clusterName: string;\n\n  /**\n   * The AWS Cloud Map namespace to associate with the cluster.\n   */\n  private _defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * Specifies whether the cluster has EC2 instance capacity.\n   */\n  private _hasEc2Capacity: boolean = false;\n\n  /**\n   * The autoscaling group for added Ec2 capacity\n   */\n  private _autoscalingGroup?: autoscaling.IAutoScalingGroup;\n\n  /**\n   * Constructs a new instance of the Cluster class.\n   */\n  constructor(scope: Construct, id: string, props: ClusterProps = {}) {\n    super(scope, id, {\n      physicalName: props.clusterName,\n    });\n\n    const cluster = new CfnCluster(this, 'Resource', {\n      clusterName: this.physicalName,\n    });\n\n    this.clusterArn = this.getResourceArnAttribute(cluster.attrArn, {\n      service: 'ecs',\n      resource: 'cluster',\n      resourceName: this.physicalName,\n    });\n    this.clusterName = this.getResourceNameAttribute(cluster.ref);\n\n    this.vpc = props.vpc || new ec2.Vpc(this, 'Vpc', { maxAzs: 2 });\n\n    this._defaultCloudMapNamespace = props.defaultCloudMapNamespace !== undefined\n      ? this.addDefaultCloudMapNamespace(props.defaultCloudMapNamespace)\n      : undefined;\n\n    this._autoscalingGroup = props.capacity !== undefined\n      ? this.addCapacity(\"DefaultAutoScalingGroup\", props.capacity)\n      : undefined;\n  }\n\n  /**\n   * Add an AWS Cloud Map DNS namespace for this cluster.\n   * NOTE: HttpNamespaces are not supported, as ECS always requires a DNSConfig when registering an instance to a Cloud\n   * Map service.\n   */\n  public addDefaultCloudMapNamespace(options: CloudMapNamespaceOptions): cloudmap.INamespace {\n    if (this._defaultCloudMapNamespace !== undefined) {\n      throw new Error(\"Can only add default namespace once.\");\n    }\n\n    const namespaceType = options.type !== undefined\n      ? options.type\n      : cloudmap.NamespaceType.DNS_PRIVATE;\n\n    const sdNamespace = namespaceType === cloudmap.NamespaceType.DNS_PRIVATE ?\n      new cloudmap.PrivateDnsNamespace(this, 'DefaultServiceDiscoveryNamespace', {\n        name: options.name,\n        vpc: this.vpc\n      }) :\n      new cloudmap.PublicDnsNamespace(this, 'DefaultServiceDiscoveryNamespace', {\n        name: options.name,\n      });\n\n    this._defaultCloudMapNamespace = sdNamespace;\n\n    return sdNamespace;\n  }\n\n  /**\n   * Getter for namespace added to cluster\n   */\n  public get defaultCloudMapNamespace(): cloudmap.INamespace | undefined {\n    return this._defaultCloudMapNamespace;\n  }\n\n  /**\n   * This method adds compute capacity to a cluster by creating an AutoScalingGroup with the specified options.\n   *\n   * Returns the AutoScalingGroup so you can add autoscaling settings to it.\n   */\n  public addCapacity(id: string, options: AddCapacityOptions): autoscaling.AutoScalingGroup {\n    const autoScalingGroup = new autoscaling.AutoScalingGroup(this, id, {\n      ...options,\n      vpc: this.vpc,\n      machineImage: options.machineImage || new EcsOptimizedAmi(),\n      updateType: options.updateType || autoscaling.UpdateType.REPLACING_UPDATE,\n      instanceType: options.instanceType,\n    });\n\n    this.addAutoScalingGroup(autoScalingGroup, options);\n\n    return autoScalingGroup;\n  }\n\n  /**\n   * This method adds compute capacity to a cluster using the specified AutoScalingGroup.\n   *\n   * @param autoScalingGroup the ASG to add to this cluster.\n   * [disable-awslint:ref-via-interface] is needed in order to install the ECS\n   * agent by updating the ASGs user data.\n   */\n  public addAutoScalingGroup(autoScalingGroup: autoscaling.AutoScalingGroup, options: AddAutoScalingGroupCapacityOptions = {}) {\n    this._hasEc2Capacity = true;\n    this.connections.connections.addSecurityGroup(...autoScalingGroup.connections.securityGroups);\n\n    // Tie instances to cluster\n    autoScalingGroup.addUserData(`echo ECS_CLUSTER=${this.clusterName} >> /etc/ecs/ecs.config`);\n\n    if (!options.canContainersAccessInstanceRole) {\n      // Deny containers access to instance metadata service\n      // Source: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/instance_IAM_role.html\n      autoScalingGroup.addUserData('sudo iptables --insert FORWARD 1 --in-interface docker+ --destination 169.254.169.254/32 --jump DROP');\n      autoScalingGroup.addUserData('sudo service iptables save');\n      // The following is only for AwsVpc networking mode, but doesn't hurt for the other modes.\n      autoScalingGroup.addUserData('echo ECS_AWSVPC_BLOCK_IMDS=true >> /etc/ecs/ecs.config');\n    }\n\n    // ECS instances must be able to do these things\n    // Source: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/instance_IAM_role.html\n    autoScalingGroup.addToRolePolicy(new iam.PolicyStatement({\n      actions: [\n        \"ecs:CreateCluster\",\n        \"ecs:DeregisterContainerInstance\",\n        \"ecs:DiscoverPollEndpoint\",\n        \"ecs:Poll\",\n        \"ecs:RegisterContainerInstance\",\n        \"ecs:StartTelemetrySession\",\n        \"ecs:Submit*\",\n        \"ecr:GetAuthorizationToken\",\n        \"logs:CreateLogStream\",\n        \"logs:PutLogEvents\"\n      ],\n      resources: ['*']\n    }));\n\n    // 0 disables, otherwise forward to underlying implementation which picks the sane default\n    if (!options.taskDrainTime || options.taskDrainTime.toSeconds() !== 0) {\n      new InstanceDrainHook(autoScalingGroup, 'DrainECSHook', {\n        autoScalingGroup,\n        cluster: this,\n        drainTime: options.taskDrainTime\n      });\n    }\n  }\n\n  /**\n   * Getter for autoscaling group added to cluster\n   */\n  public get autoscalingGroup(): autoscaling.IAutoScalingGroup | undefined {\n    return this._autoscalingGroup;\n  }\n\n  /**\n   * Whether the cluster has EC2 capacity associated with it\n   */\n  public get hasEc2Capacity(): boolean {\n    return this._hasEc2Capacity;\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters CPU reservation.\n   *\n   * @default average over 5 minutes\n   */\n  public metricCpuReservation(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('CPUReservation', props);\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters memory reservation.\n   *\n   * @default average over 5 minutes\n   */\n  public metricMemoryReservation(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('MemoryReservation', props );\n  }\n\n  /**\n   * This method returns the specifed CloudWatch metric for this cluster.\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ECS',\n      metricName,\n      dimensions: { ClusterName: this.clusterName },\n      ...props\n    });\n  }\n}\n\n/**\n * ECS-optimized Windows version list\n */\nexport enum WindowsOptimizedVersion {\n  SERVER_2019 = '2019',\n  SERVER_2016 = '2016',\n}\n\n/*\n * TODO:v2.0.0\n *  * remove `export` keyword\n *  * remove @depracted\n */\n/**\n * The properties that define which ECS-optimized AMI is used.\n *\n * @deprecated see {@link EcsOptimizedImage}\n */\nexport interface EcsOptimizedAmiProps {\n  /**\n   * The Amazon Linux generation to use.\n   *\n   * @default AmazonLinuxGeneration.AmazonLinux2\n   */\n  readonly generation?: ec2.AmazonLinuxGeneration;\n\n  /**\n   * The Windows Server version to use.\n   *\n   * @default none, uses Linux generation\n   */\n  readonly windowsVersion?: WindowsOptimizedVersion;\n\n  /**\n   * The ECS-optimized AMI variant to use.\n   *\n   * @default AmiHardwareType.Standard\n   */\n  readonly hardwareType?: AmiHardwareType;\n}\n\n/*\n * TODO:v2.0.0 remove EcsOptimizedAmi\n */\n/**\n * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM\n *\n * @deprecated see {@link EcsOptimizedImage#amazonLinux}, {@link EcsOptimizedImage#amazonLinux} and {@link EcsOptimizedImage#windows}\n */\nexport class EcsOptimizedAmi implements ec2.IMachineImage {\n  private readonly generation?: ec2.AmazonLinuxGeneration;\n  private readonly windowsVersion?: WindowsOptimizedVersion;\n  private readonly hwType: AmiHardwareType;\n\n  private readonly amiParameterName: string;\n\n  /**\n   * Constructs a new instance of the EcsOptimizedAmi class.\n   */\n  constructor(props?: EcsOptimizedAmiProps) {\n    this.hwType = (props && props.hardwareType) || AmiHardwareType.STANDARD;\n    if (props && props.generation) {      // generation defined in the props object\n      if (props.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX && this.hwType !== AmiHardwareType.STANDARD) {\n        throw new Error(`Amazon Linux does not support special hardware type. Use Amazon Linux 2 instead`);\n      } else if (props.windowsVersion) {\n        throw new Error('\"windowsVersion\" and Linux image \"generation\" cannot be both set');\n      } else {\n        this.generation = props.generation;\n      }\n    } else if (props && props.windowsVersion) {\n      if (this.hwType !== AmiHardwareType.STANDARD) {\n        throw new Error('Windows Server does not support special hardware type');\n      } else {\n        this.windowsVersion = props.windowsVersion;\n      }\n    } else {                              // generation not defined in props object\n      // always default to Amazon Linux v2 regardless of HW\n      this.generation = ec2.AmazonLinuxGeneration.AMAZON_LINUX_2;\n    }\n\n    // set the SSM parameter name\n    this.amiParameterName = \"/aws/service/ecs/optimized-ami/\"\n                          + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? \"amazon-linux/\" : \"\" )\n                          + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? \"amazon-linux-2/\" : \"\" )\n                          + ( this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : \"\" )\n                          + ( this.hwType === AmiHardwareType.GPU ? \"gpu/\" : \"\" )\n                          + ( this.hwType === AmiHardwareType.ARM ? \"arm64/\" : \"\" )\n                          + \"recommended/image_id\";\n  }\n\n  /**\n   * Return the correct image\n   */\n  public getImage(scope: Construct): ec2.MachineImageConfig {\n    const ami = ssm.StringParameter.valueForStringParameter(scope, this.amiParameterName);\n    return {\n      imageId: ami,\n      osType: this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX\n    };\n  }\n}\n\n/**\n * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM\n */\nexport class EcsOptimizedImage implements ec2.IMachineImage {\n  /**\n   * Construct an Amazon Linux 2 image from the latest ECS Optimized AMI published in SSM\n   *\n   * @param hardwareType ECS-optimized AMI variant to use\n   */\n  public static amazonLinux2(hardwareType = AmiHardwareType.STANDARD): EcsOptimizedImage {\n    return new EcsOptimizedImage({generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2, hardwareType});\n  }\n\n  /**\n   * Construct an Amazon Linux AMI image from the latest ECS Optimized AMI published in SSM\n   */\n  public static amazonLinux(): EcsOptimizedImage {\n    return new EcsOptimizedImage({generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX});\n  }\n\n  /**\n   * Construct a Windows image from the latest ECS Optimized AMI published in SSM\n   *\n   * @param windowsVersion Windows Version to use\n   */\n  public static windows(windowsVersion: WindowsOptimizedVersion): EcsOptimizedImage {\n    return new EcsOptimizedImage({windowsVersion});\n  }\n\n  private readonly generation?: ec2.AmazonLinuxGeneration;\n  private readonly windowsVersion?: WindowsOptimizedVersion;\n  private readonly hwType?: AmiHardwareType;\n\n  private readonly amiParameterName: string;\n\n  /**\n   * Constructs a new instance of the EcsOptimizedAmi class.\n   */\n  private constructor(props: EcsOptimizedAmiProps) {\n    this.hwType = props && props.hardwareType;\n\n    if (props.windowsVersion) {\n      this.windowsVersion = props.windowsVersion;\n    } else if (props.generation) {\n      this.generation = props.generation;\n    } else {\n      throw new Error('This error should never be thrown');\n    }\n\n    // set the SSM parameter name\n    this.amiParameterName = \"/aws/service/ecs/optimized-ami/\"\n        + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? \"amazon-linux/\" : \"\" )\n        + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? \"amazon-linux-2/\" : \"\" )\n        + ( this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : \"\" )\n        + ( this.hwType === AmiHardwareType.GPU ? \"gpu/\" : \"\" )\n        + ( this.hwType === AmiHardwareType.ARM ? \"arm64/\" : \"\" )\n        + \"recommended/image_id\";\n  }\n\n  /**\n   * Return the correct image\n   */\n  public getImage(scope: Construct): ec2.MachineImageConfig {\n    const ami = ssm.StringParameter.valueForStringParameter(scope, this.amiParameterName);\n    return {\n      imageId: ami,\n      osType: this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX\n    };\n  }\n}\n\n/**\n * A regional grouping of one or more container instances on which you can run tasks and services.\n */\nexport interface ICluster extends IResource {\n  /**\n   * The name of the cluster.\n   * @attribute\n   */\n  readonly clusterName: string;\n\n  /**\n   * The Amazon Resource Name (ARN) that identifies the cluster.\n   * @attribute\n   */\n  readonly clusterArn: string;\n\n  /**\n   * The VPC associated with the cluster.\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * Manage the allowed network connections for the cluster with Security Groups.\n   */\n  readonly connections: ec2.Connections;\n\n  /**\n   * Specifies whether the cluster has EC2 instance capacity.\n   */\n  readonly hasEc2Capacity: boolean;\n\n  /**\n   * The AWS Cloud Map namespace to associate with the cluster.\n   */\n  readonly defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * The autoscaling group added to the cluster if capacity is associated to the cluster\n   */\n  readonly autoscalingGroup?: autoscaling.IAutoScalingGroup;\n}\n\n/**\n * The properties to import from the ECS cluster.\n */\nexport interface ClusterAttributes {\n  /**\n   * The name of the cluster.\n   */\n  readonly clusterName: string;\n\n  /**\n   * The Amazon Resource Name (ARN) that identifies the cluster.\n   *\n   * @default Derived from clusterName\n   */\n  readonly clusterArn?: string;\n\n  /**\n   * The VPC associated with the cluster.\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * The security groups associated with the container instances registered to the cluster.\n   */\n  readonly securityGroups: ec2.ISecurityGroup[];\n\n  /**\n   * Specifies whether the cluster has EC2 instance capacity.\n   *\n   * @default true\n   */\n  readonly hasEc2Capacity?: boolean;\n\n  /**\n   * The AWS Cloud Map namespace to associate with the cluster.\n   *\n   * @default - No default namespace\n   */\n  readonly defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * Autoscaling group added to the cluster if capacity is added\n   *\n   * @default - No default autoscaling group\n   */\n  readonly autoscalingGroup?: autoscaling.IAutoScalingGroup;\n}\n\n/**\n * An Cluster that has been imported\n */\nclass ImportedCluster extends Resource implements ICluster {\n  /**\n   * Name of the cluster\n   */\n  public readonly clusterName: string;\n\n  /**\n   * ARN of the cluster\n   */\n  public readonly clusterArn: string;\n\n  /**\n   * VPC that the cluster instances are running in\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * Security group of the cluster instances\n   */\n  public readonly connections = new ec2.Connections();\n\n  /**\n   * Whether the cluster has EC2 capacity\n   */\n  public readonly hasEc2Capacity: boolean;\n\n  /**\n   * Cloudmap namespace created in the cluster\n   */\n  private _defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * Constructs a new instance of the ImportedCluster class.\n   */\n  constructor(scope: Construct, id: string, props: ClusterAttributes) {\n    super(scope, id);\n    this.clusterName = props.clusterName;\n    this.vpc = props.vpc;\n    this.hasEc2Capacity = props.hasEc2Capacity !== false;\n    this._defaultCloudMapNamespace = props.defaultCloudMapNamespace;\n\n    this.clusterArn = props.clusterArn !== undefined ? props.clusterArn : Stack.of(this).formatArn({\n      service: 'ecs',\n      resource: 'cluster',\n      resourceName: props.clusterName\n    });\n\n    let i = 1;\n    for (const sgProps of props.securityGroups) {\n      this.connections.addSecurityGroup(ec2.SecurityGroup.fromSecurityGroupId(this, `SecurityGroup${i}`, sgProps.securityGroupId));\n      i++;\n    }\n  }\n\n  public get defaultCloudMapNamespace(): cloudmap.INamespace | undefined {\n    return this._defaultCloudMapNamespace;\n  }\n}\n\n/**\n * The properties for adding an AutoScalingGroup.\n */\nexport interface AddAutoScalingGroupCapacityOptions {\n  /**\n   * Specifies whether the containers can access the container instance role.\n   *\n   * @default false\n   */\n  readonly canContainersAccessInstanceRole?: boolean;\n\n  /**\n   * The time period to wait before force terminating an instance that is draining.\n   *\n   * This creates a Lambda function that is used by a lifecycle hook for the\n   * AutoScalingGroup that will delay instance termination until all ECS tasks\n   * have drained from the instance. Set to 0 to disable task draining.\n   *\n   * Set to 0 to disable task draining.\n   *\n   * @default Duration.minutes(5)\n   */\n  readonly taskDrainTime?: Duration;\n}\n\n/**\n * The properties for adding instance capacity to an AutoScalingGroup.\n */\nexport interface AddCapacityOptions extends AddAutoScalingGroupCapacityOptions, autoscaling.CommonAutoScalingGroupProps {\n  /**\n   * The EC2 instance type to use when launching instances into the AutoScalingGroup.\n   */\n  readonly instanceType: ec2.InstanceType;\n\n  /**\n   * The ECS-optimized AMI variant to use. For more information, see\n   * [Amazon ECS-optimized AMIs](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-optimized_AMI.html).\n   *\n   * @default - Amazon Linux 2\n   */\n  readonly machineImage?: ec2.IMachineImage;\n}\n\n/**\n * The options for creating an AWS Cloud Map namespace.\n */\nexport interface CloudMapNamespaceOptions {\n  /**\n   * The name of the namespace, such as example.com.\n   */\n  readonly name: string;\n\n  /**\n   * The type of CloudMap Namespace to create.\n   *\n   * @default PrivateDns\n   */\n  readonly type?: cloudmap.NamespaceType;\n\n  /**\n   * The VPC to associate the namespace with. This property is required for private DNS namespaces.\n   *\n   * @default VPC of the cluster for Private DNS Namespace, otherwise none\n   */\n  readonly vpc?: ec2.IVpc;\n}\n\n/**\n * The ECS-optimized AMI variant to use. For more information, see\n * [Amazon ECS-optimized AMIs](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-optimized_AMI.html).\n */\nexport enum AmiHardwareType {\n\n  /**\n   * Use the standard Amazon ECS-optimized AMI.\n   */\n  STANDARD = 'Standard',\n\n  /**\n   * Use the Amazon ECS GPU-optimized AMI.\n   */\n  GPU = 'GPU',\n\n  /**\n   * Use the Amazon ECS-optimized Amazon Linux 2 (arm64) AMI.\n   */\n  ARM = 'ARM64',\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["cluster.ts"],"names":[],"mappings":";;AAAA,wDAAyD;AACzD,sDAAwD;AACxD,wCAAyC;AACzC,wCAAyC;AACzC,0DAA2D;AAC3D,wCAAyC;AACzC,wCAA8E;AAC9E,0EAAmE;AACnE,mDAA2C;AAoC3C;;GAEG;AACH,MAAa,OAAQ,SAAQ,eAAQ;IA2CnC;;OAEG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,QAAsB,EAAE;QAChE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,CAAC,WAAW;SAChC,CAAC,CAAC;QAzCL;;WAEG;QACa,gBAAW,GAAoB,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;QAsBrE;;WAEG;QACK,oBAAe,GAAY,KAAK,CAAC;QAevC,MAAM,OAAO,GAAG,IAAI,0BAAU,CAAC,IAAI,EAAE,UAAU,EAAE;YAC/C,WAAW,EAAE,IAAI,CAAC,YAAY;SAC/B,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,OAAO,EAAE;YAC9D,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,SAAS;YACnB,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAE9D,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,IAAI,IAAI,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;QAEhE,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC,wBAAwB,KAAK,SAAS;YAC3E,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,wBAAwB,CAAC;YAClE,CAAC,CAAC,SAAS,CAAC;QAEd,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,QAAQ,KAAK,SAAS;YACnD,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,yBAAyB,EAAE,KAAK,CAAC,QAAQ,CAAC;YAC7D,CAAC,CAAC,SAAS,CAAC;IAChB,CAAC;IAtED;;OAEG;IACI,MAAM,CAAC,qBAAqB,CAAC,KAAgB,EAAE,EAAU,EAAE,KAAwB;QACxF,OAAO,IAAI,eAAe,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;IAC/C,CAAC;IAmED;;;;OAIG;IACI,2BAA2B,CAAC,OAAiC;QAClE,IAAI,IAAI,CAAC,yBAAyB,KAAK,SAAS,EAAE;YAChD,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;SACzD;QAED,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,KAAK,SAAS;YAC9C,CAAC,CAAC,OAAO,CAAC,IAAI;YACd,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,CAAC;QAEvC,MAAM,WAAW,GAAG,aAAa,KAAK,QAAQ,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;YACxE,IAAI,QAAQ,CAAC,mBAAmB,CAAC,IAAI,EAAE,kCAAkC,EAAE;gBACzE,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,GAAG,EAAE,IAAI,CAAC,GAAG;aACd,CAAC,CAAC,CAAC;YACJ,IAAI,QAAQ,CAAC,kBAAkB,CAAC,IAAI,EAAE,kCAAkC,EAAE;gBACxE,IAAI,EAAE,OAAO,CAAC,IAAI;aACnB,CAAC,CAAC;QAEL,IAAI,CAAC,yBAAyB,GAAG,WAAW,CAAC;QAE7C,OAAO,WAAW,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,IAAW,wBAAwB;QACjC,OAAO,IAAI,CAAC,yBAAyB,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,EAAU,EAAE,OAA2B;QACxD,MAAM,gBAAgB,GAAG,IAAI,WAAW,CAAC,gBAAgB,CAAC,IAAI,EAAE,EAAE,EAAE;YAClE,GAAG,OAAO;YACV,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,YAAY,EAAE,OAAO,CAAC,YAAY,IAAI,IAAI,eAAe,EAAE;YAC3D,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,WAAW,CAAC,UAAU,CAAC,gBAAgB;YACzE,YAAY,EAAE,OAAO,CAAC,YAAY;SACnC,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC;QAEpD,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED;;;;;;OAMG;IACI,mBAAmB,CAAC,gBAA8C,EAAE,UAA8C,EAAE;QACzH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,gBAAgB,CAAC,GAAG,gBAAgB,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QAE9F,2BAA2B;QAC3B,gBAAgB,CAAC,WAAW,CAAC,oBAAoB,IAAI,CAAC,WAAW,yBAAyB,CAAC,CAAC;QAE5F,IAAI,CAAC,OAAO,CAAC,+BAA+B,EAAE;YAC5C,sDAAsD;YACtD,6FAA6F;YAC7F,gBAAgB,CAAC,WAAW,CAAC,sGAAsG,CAAC,CAAC;YACrI,gBAAgB,CAAC,WAAW,CAAC,4BAA4B,CAAC,CAAC;YAC3D,0FAA0F;YAC1F,gBAAgB,CAAC,WAAW,CAAC,wDAAwD,CAAC,CAAC;SACxF;QAED,gDAAgD;QAChD,6FAA6F;QAC7F,gBAAgB,CAAC,eAAe,CAAC,IAAI,GAAG,CAAC,eAAe,CAAC;YACvD,OAAO,EAAE;gBACP,mBAAmB;gBACnB,iCAAiC;gBACjC,0BAA0B;gBAC1B,UAAU;gBACV,+BAA+B;gBAC/B,2BAA2B;gBAC3B,aAAa;gBACb,2BAA2B;gBAC3B,sBAAsB;gBACtB,mBAAmB;aACpB;YACD,SAAS,EAAE,CAAC,GAAG,CAAC;SACjB,CAAC,CAAC,CAAC;QAEJ,0FAA0F;QAC1F,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,OAAO,CAAC,aAAa,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE;YACrE,IAAI,uCAAiB,CAAC,gBAAgB,EAAE,cAAc,EAAE;gBACtD,gBAAgB;gBAChB,OAAO,EAAE,IAAI;gBACb,SAAS,EAAE,OAAO,CAAC,aAAa;aACjC,CAAC,CAAC;SACJ;IACH,CAAC;IAED;;OAEG;IACH,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED;;;;OAIG;IACI,oBAAoB,CAAC,KAAgC;QAC1D,OAAO,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED;;;;OAIG;IACI,uBAAuB,CAAC,KAAgC;QAC7D,OAAO,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE,KAAK,CAAE,CAAC;IAClD,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,UAAkB,EAAE,KAAgC;QAChE,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC;YAC3B,SAAS,EAAE,SAAS;YACpB,UAAU;YACV,UAAU,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE;YAC7C,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;CACF;AA7ND,0BA6NC;AAED;;GAEG;AACH,IAAY,uBAGX;AAHD,WAAY,uBAAuB;IACjC,+CAAoB,CAAA;IACpB,+CAAoB,CAAA;AACtB,CAAC,EAHW,uBAAuB,GAAvB,+BAAuB,KAAvB,+BAAuB,QAGlC;AAmCD;;GAEG;AACH;;;;GAIG;AACH,MAAa,eAAe;IAO1B;;OAEG;IACH,YAAY,KAA4B;QACtC,IAAI,CAAC,MAAM,GAAG,CAAC,KAAK,IAAI,KAAK,CAAC,YAAY,CAAC,IAAI,eAAe,CAAC,QAAQ,CAAC;QACxE,IAAI,KAAK,IAAI,KAAK,CAAC,UAAU,EAAE,EAAO,yCAAyC;YAC7E,IAAI,KAAK,CAAC,UAAU,KAAK,GAAG,CAAC,qBAAqB,CAAC,YAAY,IAAI,IAAI,CAAC,MAAM,KAAK,eAAe,CAAC,QAAQ,EAAE;gBAC3G,MAAM,IAAI,KAAK,CAAC,iFAAiF,CAAC,CAAC;aACpG;iBAAM,IAAI,KAAK,CAAC,cAAc,EAAE;gBAC/B,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;aACrF;iBAAM;gBACL,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;aACpC;SACF;aAAM,IAAI,KAAK,IAAI,KAAK,CAAC,cAAc,EAAE;YACxC,IAAI,IAAI,CAAC,MAAM,KAAK,eAAe,CAAC,QAAQ,EAAE;gBAC5C,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;aAC1E;iBAAM;gBACL,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;aAC5C;SACF;aAAM,EAA+B,yCAAyC;YAC7E,qDAAqD;YACrD,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,qBAAqB,CAAC,cAAc,CAAC;SAC5D;QAED,6BAA6B;QAC7B,IAAI,CAAC,gBAAgB,GAAG,iCAAiC;cACjC,CAAE,IAAI,CAAC,UAAU,KAAK,GAAG,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAE;cACrF,CAAE,IAAI,CAAC,UAAU,KAAK,GAAG,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAE;cACzF,CAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,IAAI,CAAC,cAAc,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAE;cACpF,CAAE,IAAI,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAE;cACrD,CAAE,IAAI,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAE;cACvD,sBAAsB,CAAC;IACjD,CAAC;IAED;;OAEG;IACI,QAAQ,CAAC,KAAgB;QAC9B,MAAM,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,uBAAuB,CAAC,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACtF,OAAO;YACL,OAAO,EAAE,GAAG;YACZ,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,KAAK;SAC9F,CAAC;IACJ,CAAC;CACF;AAnDD,0CAmDC;AAED;;GAEG;AACH,MAAa,iBAAiB;IAC5B;;;;OAIG;IACI,MAAM,CAAC,YAAY,CAAC,YAAY,GAAG,eAAe,CAAC,QAAQ;QAChE,OAAO,IAAI,iBAAiB,CAAC,EAAC,UAAU,EAAE,GAAG,CAAC,qBAAqB,CAAC,cAAc,EAAE,YAAY,EAAC,CAAC,CAAC;IACrG,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,WAAW;QACvB,OAAO,IAAI,iBAAiB,CAAC,EAAC,UAAU,EAAE,GAAG,CAAC,qBAAqB,CAAC,YAAY,EAAC,CAAC,CAAC;IACrF,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,OAAO,CAAC,cAAuC;QAC3D,OAAO,IAAI,iBAAiB,CAAC,EAAC,cAAc,EAAC,CAAC,CAAC;IACjD,CAAC;IAQD;;OAEG;IACH,YAAoB,KAA2B;QAC7C,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,KAAK,CAAC,YAAY,CAAC;QAE1C,IAAI,KAAK,CAAC,cAAc,EAAE;YACxB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;SAC5C;aAAM,IAAI,KAAK,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;SACpC;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;SACtD;QAED,6BAA6B;QAC7B,IAAI,CAAC,gBAAgB,GAAG,iCAAiC;cACnD,CAAE,IAAI,CAAC,UAAU,KAAK,GAAG,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAE;cACrF,CAAE,IAAI,CAAC,UAAU,KAAK,GAAG,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAE;cACzF,CAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,IAAI,CAAC,cAAc,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAE;cACpF,CAAE,IAAI,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAE;cACrD,CAAE,IAAI,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAE;cACvD,sBAAsB,CAAC;IAC/B,CAAC;IAED;;OAEG;IACI,QAAQ,CAAC,KAAgB;QAC9B,MAAM,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,uBAAuB,CAAC,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACtF,OAAO;YACL,OAAO,EAAE,GAAG;YACZ,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,KAAK;SAC9F,CAAC;IACJ,CAAC;CACF;AAlED,8CAkEC;AA4FD;;GAEG;AACH,MAAM,eAAgB,SAAQ,eAAQ;IA+BpC;;OAEG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAwB;QAChE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAnBnB;;WAEG;QACa,gBAAW,GAAG,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;QAiBlD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC;QACrB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,KAAK,KAAK,CAAC;QACrD,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC,wBAAwB,CAAC;QAEhE,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,YAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;YAC7F,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,SAAS;YACnB,YAAY,EAAE,KAAK,CAAC,WAAW;SAChC,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,cAAc,EAAE;YAC1C,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,GAAG,CAAC,aAAa,CAAC,mBAAmB,CAAC,IAAI,EAAE,gBAAgB,CAAC,EAAE,EAAE,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC;YAC7H,CAAC,EAAE,CAAC;SACL;IACH,CAAC;IAED,IAAW,wBAAwB;QACjC,OAAO,IAAI,CAAC,yBAAyB,CAAC;IACxC,CAAC;CACF;AAqED;;;GAGG;AACH,IAAY,eAgBX;AAhBD,WAAY,eAAe;IAEzB;;OAEG;IACH,wCAAqB,CAAA;IAErB;;OAEG;IACH,8BAAW,CAAA;IAEX;;OAEG;IACH,gCAAa,CAAA;AACf,CAAC,EAhBW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAgB1B","sourcesContent":["import autoscaling = require('@aws-cdk/aws-autoscaling');\nimport cloudwatch = require ('@aws-cdk/aws-cloudwatch');\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport iam = require('@aws-cdk/aws-iam');\nimport cloudmap = require('@aws-cdk/aws-servicediscovery');\nimport ssm = require('@aws-cdk/aws-ssm');\nimport {Construct, Duration, IResource, Resource, Stack} from '@aws-cdk/core';\nimport {InstanceDrainHook} from './drain-hook/instance-drain-hook';\nimport {CfnCluster} from './ecs.generated';\n\n/**\n * The properties used to define an ECS cluster.\n */\nexport interface ClusterProps {\n  /**\n   * The name for the cluster.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly clusterName?: string;\n\n  /**\n   * The VPC where your ECS instances will be running or your ENIs will be deployed\n   *\n   * @default - creates a new VPC with two AZs\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * The service discovery namespace created in this cluster\n   *\n   * @default - no service discovery namespace created, you can use `addDefaultCloudMapNamespace` to add a\n   * default service discovery namespace later.\n   */\n  readonly defaultCloudMapNamespace?: CloudMapNamespaceOptions;\n\n  /**\n   * The ec2 capacity to add to the cluster\n   *\n   * @default - no EC2 capacity will be added, you can use `addCapacity` to add capacity later.\n   */\n  readonly capacity?: AddCapacityOptions;\n}\n\n/**\n * A regional grouping of one or more container instances on which you can run tasks and services.\n */\nexport class Cluster extends Resource implements ICluster {\n  /**\n   * Import an existing cluster to the stack from its attributes.\n   */\n  public static fromClusterAttributes(scope: Construct, id: string, attrs: ClusterAttributes): ICluster {\n    return new ImportedCluster(scope, id, attrs);\n  }\n\n  /**\n   * Manage the allowed network connections for the cluster with Security Groups.\n   */\n  public readonly connections: ec2.Connections = new ec2.Connections();\n\n  /**\n   * The VPC associated with the cluster.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The Amazon Resource Name (ARN) that identifies the cluster.\n   */\n  public readonly clusterArn: string;\n\n  /**\n   * The name of the cluster.\n   */\n  public readonly clusterName: string;\n\n  /**\n   * The AWS Cloud Map namespace to associate with the cluster.\n   */\n  private _defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * Specifies whether the cluster has EC2 instance capacity.\n   */\n  private _hasEc2Capacity: boolean = false;\n\n  /**\n   * The autoscaling group for added Ec2 capacity\n   */\n  private _autoscalingGroup?: autoscaling.IAutoScalingGroup;\n\n  /**\n   * Constructs a new instance of the Cluster class.\n   */\n  constructor(scope: Construct, id: string, props: ClusterProps = {}) {\n    super(scope, id, {\n      physicalName: props.clusterName,\n    });\n\n    const cluster = new CfnCluster(this, 'Resource', {\n      clusterName: this.physicalName,\n    });\n\n    this.clusterArn = this.getResourceArnAttribute(cluster.attrArn, {\n      service: 'ecs',\n      resource: 'cluster',\n      resourceName: this.physicalName,\n    });\n    this.clusterName = this.getResourceNameAttribute(cluster.ref);\n\n    this.vpc = props.vpc || new ec2.Vpc(this, 'Vpc', { maxAzs: 2 });\n\n    this._defaultCloudMapNamespace = props.defaultCloudMapNamespace !== undefined\n      ? this.addDefaultCloudMapNamespace(props.defaultCloudMapNamespace)\n      : undefined;\n\n    this._autoscalingGroup = props.capacity !== undefined\n      ? this.addCapacity(\"DefaultAutoScalingGroup\", props.capacity)\n      : undefined;\n  }\n\n  /**\n   * Add an AWS Cloud Map DNS namespace for this cluster.\n   * NOTE: HttpNamespaces are not supported, as ECS always requires a DNSConfig when registering an instance to a Cloud\n   * Map service.\n   */\n  public addDefaultCloudMapNamespace(options: CloudMapNamespaceOptions): cloudmap.INamespace {\n    if (this._defaultCloudMapNamespace !== undefined) {\n      throw new Error(\"Can only add default namespace once.\");\n    }\n\n    const namespaceType = options.type !== undefined\n      ? options.type\n      : cloudmap.NamespaceType.DNS_PRIVATE;\n\n    const sdNamespace = namespaceType === cloudmap.NamespaceType.DNS_PRIVATE ?\n      new cloudmap.PrivateDnsNamespace(this, 'DefaultServiceDiscoveryNamespace', {\n        name: options.name,\n        vpc: this.vpc\n      }) :\n      new cloudmap.PublicDnsNamespace(this, 'DefaultServiceDiscoveryNamespace', {\n        name: options.name,\n      });\n\n    this._defaultCloudMapNamespace = sdNamespace;\n\n    return sdNamespace;\n  }\n\n  /**\n   * Getter for namespace added to cluster\n   */\n  public get defaultCloudMapNamespace(): cloudmap.INamespace | undefined {\n    return this._defaultCloudMapNamespace;\n  }\n\n  /**\n   * This method adds compute capacity to a cluster by creating an AutoScalingGroup with the specified options.\n   *\n   * Returns the AutoScalingGroup so you can add autoscaling settings to it.\n   */\n  public addCapacity(id: string, options: AddCapacityOptions): autoscaling.AutoScalingGroup {\n    const autoScalingGroup = new autoscaling.AutoScalingGroup(this, id, {\n      ...options,\n      vpc: this.vpc,\n      machineImage: options.machineImage || new EcsOptimizedAmi(),\n      updateType: options.updateType || autoscaling.UpdateType.REPLACING_UPDATE,\n      instanceType: options.instanceType,\n    });\n\n    this.addAutoScalingGroup(autoScalingGroup, options);\n\n    return autoScalingGroup;\n  }\n\n  /**\n   * This method adds compute capacity to a cluster using the specified AutoScalingGroup.\n   *\n   * @param autoScalingGroup the ASG to add to this cluster.\n   * [disable-awslint:ref-via-interface] is needed in order to install the ECS\n   * agent by updating the ASGs user data.\n   */\n  public addAutoScalingGroup(autoScalingGroup: autoscaling.AutoScalingGroup, options: AddAutoScalingGroupCapacityOptions = {}) {\n    this._hasEc2Capacity = true;\n    this.connections.connections.addSecurityGroup(...autoScalingGroup.connections.securityGroups);\n\n    // Tie instances to cluster\n    autoScalingGroup.addUserData(`echo ECS_CLUSTER=${this.clusterName} >> /etc/ecs/ecs.config`);\n\n    if (!options.canContainersAccessInstanceRole) {\n      // Deny containers access to instance metadata service\n      // Source: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/instance_IAM_role.html\n      autoScalingGroup.addUserData('sudo iptables --insert FORWARD 1 --in-interface docker+ --destination 169.254.169.254/32 --jump DROP');\n      autoScalingGroup.addUserData('sudo service iptables save');\n      // The following is only for AwsVpc networking mode, but doesn't hurt for the other modes.\n      autoScalingGroup.addUserData('echo ECS_AWSVPC_BLOCK_IMDS=true >> /etc/ecs/ecs.config');\n    }\n\n    // ECS instances must be able to do these things\n    // Source: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/instance_IAM_role.html\n    autoScalingGroup.addToRolePolicy(new iam.PolicyStatement({\n      actions: [\n        \"ecs:CreateCluster\",\n        \"ecs:DeregisterContainerInstance\",\n        \"ecs:DiscoverPollEndpoint\",\n        \"ecs:Poll\",\n        \"ecs:RegisterContainerInstance\",\n        \"ecs:StartTelemetrySession\",\n        \"ecs:Submit*\",\n        \"ecr:GetAuthorizationToken\",\n        \"logs:CreateLogStream\",\n        \"logs:PutLogEvents\"\n      ],\n      resources: ['*']\n    }));\n\n    // 0 disables, otherwise forward to underlying implementation which picks the sane default\n    if (!options.taskDrainTime || options.taskDrainTime.toSeconds() !== 0) {\n      new InstanceDrainHook(autoScalingGroup, 'DrainECSHook', {\n        autoScalingGroup,\n        cluster: this,\n        drainTime: options.taskDrainTime\n      });\n    }\n  }\n\n  /**\n   * Getter for autoscaling group added to cluster\n   */\n  public get autoscalingGroup(): autoscaling.IAutoScalingGroup | undefined {\n    return this._autoscalingGroup;\n  }\n\n  /**\n   * Whether the cluster has EC2 capacity associated with it\n   */\n  public get hasEc2Capacity(): boolean {\n    return this._hasEc2Capacity;\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters CPU reservation.\n   *\n   * @default average over 5 minutes\n   */\n  public metricCpuReservation(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('CPUReservation', props);\n  }\n\n  /**\n   * This method returns the CloudWatch metric for this clusters memory reservation.\n   *\n   * @default average over 5 minutes\n   */\n  public metricMemoryReservation(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metric('MemoryReservation', props );\n  }\n\n  /**\n   * This method returns the specifed CloudWatch metric for this cluster.\n   */\n  public metric(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/ECS',\n      metricName,\n      dimensions: { ClusterName: this.clusterName },\n      ...props\n    });\n  }\n}\n\n/**\n * ECS-optimized Windows version list\n */\nexport enum WindowsOptimizedVersion {\n  SERVER_2019 = '2019',\n  SERVER_2016 = '2016',\n}\n\n/*\n * TODO:v2.0.0\n *  * remove `export` keyword\n *  * remove @depracted\n */\n/**\n * The properties that define which ECS-optimized AMI is used.\n *\n * @deprecated see {@link EcsOptimizedImage}\n */\nexport interface EcsOptimizedAmiProps {\n  /**\n   * The Amazon Linux generation to use.\n   *\n   * @default AmazonLinuxGeneration.AmazonLinux2\n   */\n  readonly generation?: ec2.AmazonLinuxGeneration;\n\n  /**\n   * The Windows Server version to use.\n   *\n   * @default none, uses Linux generation\n   */\n  readonly windowsVersion?: WindowsOptimizedVersion;\n\n  /**\n   * The ECS-optimized AMI variant to use.\n   *\n   * @default AmiHardwareType.Standard\n   */\n  readonly hardwareType?: AmiHardwareType;\n}\n\n/*\n * TODO:v2.0.0 remove EcsOptimizedAmi\n */\n/**\n * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM\n *\n * @deprecated see {@link EcsOptimizedImage#amazonLinux}, {@link EcsOptimizedImage#amazonLinux} and {@link EcsOptimizedImage#windows}\n */\nexport class EcsOptimizedAmi implements ec2.IMachineImage {\n  private readonly generation?: ec2.AmazonLinuxGeneration;\n  private readonly windowsVersion?: WindowsOptimizedVersion;\n  private readonly hwType: AmiHardwareType;\n\n  private readonly amiParameterName: string;\n\n  /**\n   * Constructs a new instance of the EcsOptimizedAmi class.\n   */\n  constructor(props?: EcsOptimizedAmiProps) {\n    this.hwType = (props && props.hardwareType) || AmiHardwareType.STANDARD;\n    if (props && props.generation) {      // generation defined in the props object\n      if (props.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX && this.hwType !== AmiHardwareType.STANDARD) {\n        throw new Error(`Amazon Linux does not support special hardware type. Use Amazon Linux 2 instead`);\n      } else if (props.windowsVersion) {\n        throw new Error('\"windowsVersion\" and Linux image \"generation\" cannot be both set');\n      } else {\n        this.generation = props.generation;\n      }\n    } else if (props && props.windowsVersion) {\n      if (this.hwType !== AmiHardwareType.STANDARD) {\n        throw new Error('Windows Server does not support special hardware type');\n      } else {\n        this.windowsVersion = props.windowsVersion;\n      }\n    } else {                              // generation not defined in props object\n      // always default to Amazon Linux v2 regardless of HW\n      this.generation = ec2.AmazonLinuxGeneration.AMAZON_LINUX_2;\n    }\n\n    // set the SSM parameter name\n    this.amiParameterName = \"/aws/service/ecs/optimized-ami/\"\n                          + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? \"amazon-linux/\" : \"\" )\n                          + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? \"amazon-linux-2/\" : \"\" )\n                          + ( this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : \"\" )\n                          + ( this.hwType === AmiHardwareType.GPU ? \"gpu/\" : \"\" )\n                          + ( this.hwType === AmiHardwareType.ARM ? \"arm64/\" : \"\" )\n                          + \"recommended/image_id\";\n  }\n\n  /**\n   * Return the correct image\n   */\n  public getImage(scope: Construct): ec2.MachineImageConfig {\n    const ami = ssm.StringParameter.valueForStringParameter(scope, this.amiParameterName);\n    return {\n      imageId: ami,\n      osType: this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX\n    };\n  }\n}\n\n/**\n * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM\n */\nexport class EcsOptimizedImage implements ec2.IMachineImage {\n  /**\n   * Construct an Amazon Linux 2 image from the latest ECS Optimized AMI published in SSM\n   *\n   * @param hardwareType ECS-optimized AMI variant to use\n   */\n  public static amazonLinux2(hardwareType = AmiHardwareType.STANDARD): EcsOptimizedImage {\n    return new EcsOptimizedImage({generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2, hardwareType});\n  }\n\n  /**\n   * Construct an Amazon Linux AMI image from the latest ECS Optimized AMI published in SSM\n   */\n  public static amazonLinux(): EcsOptimizedImage {\n    return new EcsOptimizedImage({generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX});\n  }\n\n  /**\n   * Construct a Windows image from the latest ECS Optimized AMI published in SSM\n   *\n   * @param windowsVersion Windows Version to use\n   */\n  public static windows(windowsVersion: WindowsOptimizedVersion): EcsOptimizedImage {\n    return new EcsOptimizedImage({windowsVersion});\n  }\n\n  private readonly generation?: ec2.AmazonLinuxGeneration;\n  private readonly windowsVersion?: WindowsOptimizedVersion;\n  private readonly hwType?: AmiHardwareType;\n\n  private readonly amiParameterName: string;\n\n  /**\n   * Constructs a new instance of the EcsOptimizedAmi class.\n   */\n  private constructor(props: EcsOptimizedAmiProps) {\n    this.hwType = props && props.hardwareType;\n\n    if (props.windowsVersion) {\n      this.windowsVersion = props.windowsVersion;\n    } else if (props.generation) {\n      this.generation = props.generation;\n    } else {\n      throw new Error('This error should never be thrown');\n    }\n\n    // set the SSM parameter name\n    this.amiParameterName = \"/aws/service/ecs/optimized-ami/\"\n        + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? \"amazon-linux/\" : \"\" )\n        + ( this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? \"amazon-linux-2/\" : \"\" )\n        + ( this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : \"\" )\n        + ( this.hwType === AmiHardwareType.GPU ? \"gpu/\" : \"\" )\n        + ( this.hwType === AmiHardwareType.ARM ? \"arm64/\" : \"\" )\n        + \"recommended/image_id\";\n  }\n\n  /**\n   * Return the correct image\n   */\n  public getImage(scope: Construct): ec2.MachineImageConfig {\n    const ami = ssm.StringParameter.valueForStringParameter(scope, this.amiParameterName);\n    return {\n      imageId: ami,\n      osType: this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX\n    };\n  }\n}\n\n/**\n * A regional grouping of one or more container instances on which you can run tasks and services.\n */\nexport interface ICluster extends IResource {\n  /**\n   * The name of the cluster.\n   * @attribute\n   */\n  readonly clusterName: string;\n\n  /**\n   * The Amazon Resource Name (ARN) that identifies the cluster.\n   * @attribute\n   */\n  readonly clusterArn: string;\n\n  /**\n   * The VPC associated with the cluster.\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * Manage the allowed network connections for the cluster with Security Groups.\n   */\n  readonly connections: ec2.Connections;\n\n  /**\n   * Specifies whether the cluster has EC2 instance capacity.\n   */\n  readonly hasEc2Capacity: boolean;\n\n  /**\n   * The AWS Cloud Map namespace to associate with the cluster.\n   */\n  readonly defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * The autoscaling group added to the cluster if capacity is associated to the cluster\n   */\n  readonly autoscalingGroup?: autoscaling.IAutoScalingGroup;\n}\n\n/**\n * The properties to import from the ECS cluster.\n */\nexport interface ClusterAttributes {\n  /**\n   * The name of the cluster.\n   */\n  readonly clusterName: string;\n\n  /**\n   * The Amazon Resource Name (ARN) that identifies the cluster.\n   *\n   * @default Derived from clusterName\n   */\n  readonly clusterArn?: string;\n\n  /**\n   * The VPC associated with the cluster.\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * The security groups associated with the container instances registered to the cluster.\n   */\n  readonly securityGroups: ec2.ISecurityGroup[];\n\n  /**\n   * Specifies whether the cluster has EC2 instance capacity.\n   *\n   * @default true\n   */\n  readonly hasEc2Capacity?: boolean;\n\n  /**\n   * The AWS Cloud Map namespace to associate with the cluster.\n   *\n   * @default - No default namespace\n   */\n  readonly defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * Autoscaling group added to the cluster if capacity is added\n   *\n   * @default - No default autoscaling group\n   */\n  readonly autoscalingGroup?: autoscaling.IAutoScalingGroup;\n}\n\n/**\n * An Cluster that has been imported\n */\nclass ImportedCluster extends Resource implements ICluster {\n  /**\n   * Name of the cluster\n   */\n  public readonly clusterName: string;\n\n  /**\n   * ARN of the cluster\n   */\n  public readonly clusterArn: string;\n\n  /**\n   * VPC that the cluster instances are running in\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * Security group of the cluster instances\n   */\n  public readonly connections = new ec2.Connections();\n\n  /**\n   * Whether the cluster has EC2 capacity\n   */\n  public readonly hasEc2Capacity: boolean;\n\n  /**\n   * Cloudmap namespace created in the cluster\n   */\n  private _defaultCloudMapNamespace?: cloudmap.INamespace;\n\n  /**\n   * Constructs a new instance of the ImportedCluster class.\n   */\n  constructor(scope: Construct, id: string, props: ClusterAttributes) {\n    super(scope, id);\n    this.clusterName = props.clusterName;\n    this.vpc = props.vpc;\n    this.hasEc2Capacity = props.hasEc2Capacity !== false;\n    this._defaultCloudMapNamespace = props.defaultCloudMapNamespace;\n\n    this.clusterArn = props.clusterArn !== undefined ? props.clusterArn : Stack.of(this).formatArn({\n      service: 'ecs',\n      resource: 'cluster',\n      resourceName: props.clusterName\n    });\n\n    let i = 1;\n    for (const sgProps of props.securityGroups) {\n      this.connections.addSecurityGroup(ec2.SecurityGroup.fromSecurityGroupId(this, `SecurityGroup${i}`, sgProps.securityGroupId));\n      i++;\n    }\n  }\n\n  public get defaultCloudMapNamespace(): cloudmap.INamespace | undefined {\n    return this._defaultCloudMapNamespace;\n  }\n}\n\n/**\n * The properties for adding an AutoScalingGroup.\n */\nexport interface AddAutoScalingGroupCapacityOptions {\n  /**\n   * Specifies whether the containers can access the container instance role.\n   *\n   * @default false\n   */\n  readonly canContainersAccessInstanceRole?: boolean;\n\n  /**\n   * The time period to wait before force terminating an instance that is draining.\n   *\n   * This creates a Lambda function that is used by a lifecycle hook for the\n   * AutoScalingGroup that will delay instance termination until all ECS tasks\n   * have drained from the instance. Set to 0 to disable task draining.\n   *\n   * Set to 0 to disable task draining.\n   *\n   * @default Duration.minutes(5)\n   */\n  readonly taskDrainTime?: Duration;\n}\n\n/**\n * The properties for adding instance capacity to an AutoScalingGroup.\n */\nexport interface AddCapacityOptions extends AddAutoScalingGroupCapacityOptions, autoscaling.CommonAutoScalingGroupProps {\n  /**\n   * The EC2 instance type to use when launching instances into the AutoScalingGroup.\n   */\n  readonly instanceType: ec2.InstanceType;\n\n  /**\n   * The ECS-optimized AMI variant to use. For more information, see\n   * [Amazon ECS-optimized AMIs](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-optimized_AMI.html).\n   *\n   * @default - Amazon Linux 2\n   */\n  readonly machineImage?: ec2.IMachineImage;\n}\n\n/**\n * The options for creating an AWS Cloud Map namespace.\n */\nexport interface CloudMapNamespaceOptions {\n  /**\n   * The name of the namespace, such as example.com.\n   */\n  readonly name: string;\n\n  /**\n   * The type of CloudMap Namespace to create.\n   *\n   * @default PrivateDns\n   */\n  readonly type?: cloudmap.NamespaceType;\n\n  /**\n   * The VPC to associate the namespace with. This property is required for private DNS namespaces.\n   *\n   * @default VPC of the cluster for Private DNS Namespace, otherwise none\n   */\n  readonly vpc?: ec2.IVpc;\n}\n\n/**\n * The ECS-optimized AMI variant to use. For more information, see\n * [Amazon ECS-optimized AMIs](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-optimized_AMI.html).\n */\nexport enum AmiHardwareType {\n\n  /**\n   * Use the standard Amazon ECS-optimized AMI.\n   */\n  STANDARD = 'Standard',\n\n  /**\n   * Use the Amazon ECS GPU-optimized AMI.\n   */\n  GPU = 'GPU',\n\n  /**\n   * Use the Amazon ECS-optimized Amazon Linux 2 (arm64) AMI.\n   */\n  ARM = 'ARM64',\n}\n"]}

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

if (this.taskDefinition.networkMode === task_definition_1.NetworkMode.NONE) {
throw new Error("Cannot use a load balancer if NetworkMode is None. Use Host or AwsVpc instead.");
throw new Error("Cannot use a Classic Load Balancer if NetworkMode is None. Use Host or AwsVpc instead.");
}

@@ -159,2 +159,2 @@ this.loadBalancers.push({

exports.BuiltInAttributes = BuiltInAttributes;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ec2-service.js","sourceRoot":"","sources":["ec2-service.ts"],"names":[],"mappings":"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","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport elb = require('@aws-cdk/aws-elasticloadbalancing');\nimport { Construct, Lazy, Resource } from '@aws-cdk/core';\nimport { BaseService, BaseServiceOptions, IService, LaunchType } from '../base/base-service';\nimport { NetworkMode, TaskDefinition } from '../base/task-definition';\nimport { CfnService } from '../ecs.generated';\nimport { PlacementConstraint, PlacementStrategy } from '../placement';\n\n/**\n * The properties for defining a service using the EC2 launch type.\n */\nexport interface Ec2ServiceProps extends BaseServiceOptions {\n  /**\n   * The task definition to use for tasks in the service.\n   *\n   * [disable-awslint:ref-via-interface]\n   */\n  readonly taskDefinition: TaskDefinition;\n\n  /**\n   * Specifies whether the task's elastic network interface receives a public IP address.\n   * If true, each task will receive a public IP address.\n   *\n   * This property is only used for tasks that use the awsvpc network mode.\n   *\n   * @default - Use subnet default.\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * The subnets to associate with the service.\n   *\n   * This property is only used for tasks that use the awsvpc network mode.\n   *\n   * @default - Private subnets.\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * The security groups to associate with the service. If you do not specify a security group, the default security group for the VPC is used.\n   *\n   * This property is only used for tasks that use the awsvpc network mode.\n   *\n   * @default - A new security group is created.\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The placement constraints to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Constraints](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html).\n   *\n   * @default - No constraints.\n   */\n  readonly placementConstraints?: PlacementConstraint[];\n\n  /**\n   * The placement strategies to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Strategies](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-strategies.html).\n   *\n   * @default - No strategies.\n   */\n  readonly placementStrategies?: PlacementStrategy[];\n\n  /**\n   * Specifies whether the service will use the daemon scheduling strategy.\n   * If true, the service scheduler deploys exactly one task on each container instance in your cluster.\n   *\n   * When you are using this strategy, do not specify a desired number of tasks orany task placement strategies.\n   *\n   * @default false\n   */\n  readonly daemon?: boolean;\n}\n\n/**\n * The interface for a service using the EC2 launch type on an ECS cluster.\n */\nexport interface IEc2Service extends IService {\n\n}\n\n/**\n * This creates a service using the EC2 launch type on an ECS cluster.\n *\n * @resource AWS::ECS::Service\n */\nexport class Ec2Service extends BaseService implements IEc2Service, elb.ILoadBalancerTarget {\n\n  /**\n   * Imports from the specified service ARN.\n   */\n  public static fromEc2ServiceArn(scope: Construct, id: string, ec2ServiceArn: string): IEc2Service {\n    class Import extends Resource implements IEc2Service {\n      public readonly serviceArn = ec2ServiceArn;\n    }\n    return new Import(scope, id);\n  }\n\n  private readonly constraints: CfnService.PlacementConstraintProperty[];\n  private readonly strategies: CfnService.PlacementStrategyProperty[];\n  private readonly daemon: boolean;\n\n  /**\n   * Constructs a new instance of the Ec2Service class.\n   */\n  constructor(scope: Construct, id: string, props: Ec2ServiceProps) {\n    if (props.daemon && props.desiredCount !== undefined) {\n      throw new Error('Daemon mode launches one task on every instance. Don\\'t supply desiredCount.');\n    }\n\n    if (props.daemon && props.maxHealthyPercent !== undefined && props.maxHealthyPercent !== 100) {\n      throw new Error('Maximum percent must be 100 for daemon mode.');\n    }\n\n    if (props.daemon && props.minHealthyPercent !== undefined && props.minHealthyPercent !== 0) {\n      throw new Error('Minimum healthy percent must be 0 for daemon mode.');\n    }\n\n    if (!props.taskDefinition.isEc2Compatible) {\n      throw new Error('Supplied TaskDefinition is not configured for compatibility with EC2');\n    }\n\n    super(scope, id, {\n      ...props,\n      // If daemon, desiredCount must be undefined and that's what we want. Otherwise, default to 1.\n      desiredCount: props.daemon || props.desiredCount !== undefined ? props.desiredCount : 1,\n      maxHealthyPercent: props.daemon && props.maxHealthyPercent === undefined ? 100 : props.maxHealthyPercent,\n      minHealthyPercent: props.daemon && props.minHealthyPercent === undefined ? 0 : props.minHealthyPercent ,\n      launchType: LaunchType.EC2,\n    },\n    {\n      cluster: props.cluster.clusterName,\n      taskDefinition: props.taskDefinition.taskDefinitionArn,\n      placementConstraints: Lazy.anyValue({ produce: () => this.constraints }, { omitEmptyArray: true }),\n      placementStrategies: Lazy.anyValue({ produce: () => this.strategies }, { omitEmptyArray: true }),\n      schedulingStrategy: props.daemon ? 'DAEMON' : 'REPLICA',\n    }, props.taskDefinition);\n\n    this.constraints = [];\n    this.strategies = [];\n    this.daemon = props.daemon || false;\n\n    if (props.taskDefinition.networkMode === NetworkMode.AWS_VPC) {\n      this.configureAwsVpcNetworking(props.cluster.vpc, props.assignPublicIp, props.vpcSubnets, props.securityGroup);\n    } else {\n      // Either None, Bridge or Host networking. Copy SecurityGroup from ASG.\n      validateNoNetworkingProps(props);\n      this.connections.addSecurityGroup(...props.cluster.connections.securityGroups);\n    }\n\n    this.addPlacementConstraints(...props.placementConstraints || []);\n    this.addPlacementStrategies(...props.placementStrategies || []);\n\n    if (!this.taskDefinition.defaultContainer) {\n      throw new Error('A TaskDefinition must have at least one essential container');\n    }\n  }\n\n  /**\n   * Adds one or more placement strategies to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Strategies](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-strategies.html).\n   */\n  public addPlacementStrategies(...strategies: PlacementStrategy[]) {\n    if (strategies.length > 0 && this.daemon) {\n      throw new Error(\"Can't configure placement strategies when daemon=true\");\n    }\n\n    for (const strategy of strategies) {\n      this.strategies.push(...strategy.toJson());\n    }\n  }\n\n  /**\n   * Adds one or more placement strategies to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Constraints](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html).\n   */\n  public addPlacementConstraints(...constraints: PlacementConstraint[]) {\n    for (const constraint of constraints) {\n      this.constraints.push(...constraint.toJson());\n    }\n  }\n\n  /**\n   * Registers the service as a target of a Classic Load Balancer (CLB).\n   *\n   * Don't call this. Call `loadBalancer.addTarget()` instead.\n   */\n  public attachToClassicLB(loadBalancer: elb.LoadBalancer): void {\n    if (this.taskDefinition.networkMode === NetworkMode.BRIDGE) {\n      throw new Error(\"Cannot use a Classic Load Balancer if NetworkMode is Bridge. Use Host or AwsVpc instead.\");\n    }\n    if (this.taskDefinition.networkMode === NetworkMode.NONE) {\n      throw new Error(\"Cannot use a load balancer if NetworkMode is None. Use Host or AwsVpc instead.\");\n    }\n\n    this.loadBalancers.push({\n      loadBalancerName: loadBalancer.loadBalancerName,\n      containerName: this.taskDefinition.defaultContainer!.containerName,\n      containerPort: this.taskDefinition.defaultContainer!.containerPort,\n    });\n  }\n\n  /**\n   * Validates this Ec2Service.\n   */\n  protected validate(): string[] {\n    const ret = super.validate();\n    if (!this.cluster.hasEc2Capacity) {\n      ret.push('Cluster for this service needs Ec2 capacity. Call addXxxCapacity() on the cluster.');\n    }\n    return ret;\n  }\n}\n\n/**\n * Validate combinations of networking arguments\n */\nfunction validateNoNetworkingProps(props: Ec2ServiceProps) {\n  if (props.vpcSubnets !== undefined || props.securityGroup !== undefined || props.assignPublicIp) {\n    throw new Error('vpcSubnets, securityGroup and assignPublicIp can only be used in AwsVpc networking mode');\n  }\n}\n\n/**\n * The built-in container instance attributes\n */\nexport class BuiltInAttributes {\n  /**\n   * The id of the instance.\n   */\n  public static readonly INSTANCE_ID = 'instanceId';\n\n  /**\n   * The AvailabilityZone where the instance is running in.\n   */\n  public static readonly AVAILABILITY_ZONE = 'attribute:ecs.availability-zone';\n\n  /**\n   * The AMI id the instance is using.\n   */\n  public static readonly AMI_ID = 'attribute:ecs.ami-id';\n\n  /**\n   * The EC2 instance type.\n   */\n  public static readonly INSTANCE_TYPE = 'attribute:ecs.instance-type';\n\n  /**\n   * The operating system of the instance.\n   *\n   * Either 'linux' or 'windows'.\n   */\n  public static readonly OS_TYPE = 'attribute:ecs.os-type';\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ec2-service.js","sourceRoot":"","sources":["ec2-service.ts"],"names":[],"mappings":";;AAEA,wCAA0D;AAC1D,uDAA6F;AAC7F,6DAAsE;AA6EtE;;;;GAIG;AACH,MAAa,UAAW,SAAQ,0BAAW;IAEzC;;OAEG;IACI,MAAM,CAAC,iBAAiB,CAAC,KAAgB,EAAE,EAAU,EAAE,aAAqB;QACjF,MAAM,MAAO,SAAQ,eAAQ;YAA7B;;gBACkB,eAAU,GAAG,aAAa,CAAC;YAC7C,CAAC;SAAA;QACD,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IAC/B,CAAC;IAMD;;OAEG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAsB;QAC9D,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,YAAY,KAAK,SAAS,EAAE;YACpD,MAAM,IAAI,KAAK,CAAC,8EAA8E,CAAC,CAAC;SACjG;QAED,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,iBAAiB,KAAK,SAAS,IAAI,KAAK,CAAC,iBAAiB,KAAK,GAAG,EAAE;YAC5F,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QAED,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,iBAAiB,KAAK,SAAS,IAAI,KAAK,CAAC,iBAAiB,KAAK,CAAC,EAAE;YAC1F,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;SACvE;QAED,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,eAAe,EAAE;YACzC,MAAM,IAAI,KAAK,CAAC,sEAAsE,CAAC,CAAC;SACzF;QAED,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,GAAG,KAAK;YACR,8FAA8F;YAC9F,YAAY,EAAE,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACvF,iBAAiB,EAAE,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,iBAAiB,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,iBAAiB;YACxG,iBAAiB,EAAE,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,iBAAiB,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,iBAAiB;YACtG,UAAU,EAAE,yBAAU,CAAC,GAAG;SAC3B,EACD;YACE,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,WAAW;YAClC,cAAc,EAAE,KAAK,CAAC,cAAc,CAAC,iBAAiB;YACtD,oBAAoB,EAAE,WAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC;YAClG,mBAAmB,EAAE,WAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC;YAChG,kBAAkB,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;SACxD,EAAE,KAAK,CAAC,cAAc,CAAC,CAAC;QAEzB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC;QAEpC,IAAI,KAAK,CAAC,cAAc,CAAC,WAAW,KAAK,6BAAW,CAAC,OAAO,EAAE;YAC5D,IAAI,CAAC,yBAAyB,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;SAChH;aAAM;YACL,uEAAuE;YACvE,yBAAyB,CAAC,KAAK,CAAC,CAAC;YACjC,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;SAChF;QAED,IAAI,CAAC,uBAAuB,CAAC,GAAG,KAAK,CAAC,oBAAoB,IAAI,EAAE,CAAC,CAAC;QAClE,IAAI,CAAC,sBAAsB,CAAC,GAAG,KAAK,CAAC,mBAAmB,IAAI,EAAE,CAAC,CAAC;QAEhE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,gBAAgB,EAAE;YACzC,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAC;SAChF;IACH,CAAC;IAED;;;OAGG;IACI,sBAAsB,CAAC,GAAG,UAA+B;QAC9D,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE;YACxC,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;SAC1E;QAED,KAAK,MAAM,QAAQ,IAAI,UAAU,EAAE;YACjC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;SAC5C;IACH,CAAC;IAED;;;OAGG;IACI,uBAAuB,CAAC,GAAG,WAAkC;QAClE,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;YACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;SAC/C;IACH,CAAC;IAED;;;;OAIG;IACI,iBAAiB,CAAC,YAA8B;QACrD,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,KAAK,6BAAW,CAAC,MAAM,EAAE;YAC1D,MAAM,IAAI,KAAK,CAAC,0FAA0F,CAAC,CAAC;SAC7G;QACD,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,KAAK,6BAAW,CAAC,IAAI,EAAE;YACxD,MAAM,IAAI,KAAK,CAAC,wFAAwF,CAAC,CAAC;SAC3G;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YACtB,gBAAgB,EAAE,YAAY,CAAC,gBAAgB;YAC/C,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,gBAAiB,CAAC,aAAa;YAClE,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,gBAAiB,CAAC,aAAa;SACnE,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACO,QAAQ;QAChB,MAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC7B,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE;YAChC,GAAG,CAAC,IAAI,CAAC,oFAAoF,CAAC,CAAC;SAChG;QACD,OAAO,GAAG,CAAC;IACb,CAAC;CACF;AA9HD,gCA8HC;AAED;;GAEG;AACH,SAAS,yBAAyB,CAAC,KAAsB;IACvD,IAAI,KAAK,CAAC,UAAU,KAAK,SAAS,IAAI,KAAK,CAAC,aAAa,KAAK,SAAS,IAAI,KAAK,CAAC,cAAc,EAAE;QAC/F,MAAM,IAAI,KAAK,CAAC,yFAAyF,CAAC,CAAC;KAC5G;AACH,CAAC;AAED;;GAEG;AACH,MAAa,iBAAiB;;AAC5B;;GAEG;AACoB,6BAAW,GAAG,YAAY,CAAC;AAElD;;GAEG;AACoB,mCAAiB,GAAG,iCAAiC,CAAC;AAE7E;;GAEG;AACoB,wBAAM,GAAG,sBAAsB,CAAC;AAEvD;;GAEG;AACoB,+BAAa,GAAG,6BAA6B,CAAC;AAErE;;;;GAIG;AACoB,yBAAO,GAAG,uBAAuB,CAAC;AA1B3D,8CA2BC","sourcesContent":["import ec2 = require('@aws-cdk/aws-ec2');\nimport elb = require('@aws-cdk/aws-elasticloadbalancing');\nimport { Construct, Lazy, Resource } from '@aws-cdk/core';\nimport { BaseService, BaseServiceOptions, IService, LaunchType } from '../base/base-service';\nimport { NetworkMode, TaskDefinition } from '../base/task-definition';\nimport { CfnService } from '../ecs.generated';\nimport { PlacementConstraint, PlacementStrategy } from '../placement';\n\n/**\n * The properties for defining a service using the EC2 launch type.\n */\nexport interface Ec2ServiceProps extends BaseServiceOptions {\n  /**\n   * The task definition to use for tasks in the service.\n   *\n   * [disable-awslint:ref-via-interface]\n   */\n  readonly taskDefinition: TaskDefinition;\n\n  /**\n   * Specifies whether the task's elastic network interface receives a public IP address.\n   * If true, each task will receive a public IP address.\n   *\n   * This property is only used for tasks that use the awsvpc network mode.\n   *\n   * @default - Use subnet default.\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * The subnets to associate with the service.\n   *\n   * This property is only used for tasks that use the awsvpc network mode.\n   *\n   * @default - Private subnets.\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * The security groups to associate with the service. If you do not specify a security group, the default security group for the VPC is used.\n   *\n   * This property is only used for tasks that use the awsvpc network mode.\n   *\n   * @default - A new security group is created.\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The placement constraints to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Constraints](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html).\n   *\n   * @default - No constraints.\n   */\n  readonly placementConstraints?: PlacementConstraint[];\n\n  /**\n   * The placement strategies to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Strategies](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-strategies.html).\n   *\n   * @default - No strategies.\n   */\n  readonly placementStrategies?: PlacementStrategy[];\n\n  /**\n   * Specifies whether the service will use the daemon scheduling strategy.\n   * If true, the service scheduler deploys exactly one task on each container instance in your cluster.\n   *\n   * When you are using this strategy, do not specify a desired number of tasks orany task placement strategies.\n   *\n   * @default false\n   */\n  readonly daemon?: boolean;\n}\n\n/**\n * The interface for a service using the EC2 launch type on an ECS cluster.\n */\nexport interface IEc2Service extends IService {\n\n}\n\n/**\n * This creates a service using the EC2 launch type on an ECS cluster.\n *\n * @resource AWS::ECS::Service\n */\nexport class Ec2Service extends BaseService implements IEc2Service, elb.ILoadBalancerTarget {\n\n  /**\n   * Imports from the specified service ARN.\n   */\n  public static fromEc2ServiceArn(scope: Construct, id: string, ec2ServiceArn: string): IEc2Service {\n    class Import extends Resource implements IEc2Service {\n      public readonly serviceArn = ec2ServiceArn;\n    }\n    return new Import(scope, id);\n  }\n\n  private readonly constraints: CfnService.PlacementConstraintProperty[];\n  private readonly strategies: CfnService.PlacementStrategyProperty[];\n  private readonly daemon: boolean;\n\n  /**\n   * Constructs a new instance of the Ec2Service class.\n   */\n  constructor(scope: Construct, id: string, props: Ec2ServiceProps) {\n    if (props.daemon && props.desiredCount !== undefined) {\n      throw new Error('Daemon mode launches one task on every instance. Don\\'t supply desiredCount.');\n    }\n\n    if (props.daemon && props.maxHealthyPercent !== undefined && props.maxHealthyPercent !== 100) {\n      throw new Error('Maximum percent must be 100 for daemon mode.');\n    }\n\n    if (props.daemon && props.minHealthyPercent !== undefined && props.minHealthyPercent !== 0) {\n      throw new Error('Minimum healthy percent must be 0 for daemon mode.');\n    }\n\n    if (!props.taskDefinition.isEc2Compatible) {\n      throw new Error('Supplied TaskDefinition is not configured for compatibility with EC2');\n    }\n\n    super(scope, id, {\n      ...props,\n      // If daemon, desiredCount must be undefined and that's what we want. Otherwise, default to 1.\n      desiredCount: props.daemon || props.desiredCount !== undefined ? props.desiredCount : 1,\n      maxHealthyPercent: props.daemon && props.maxHealthyPercent === undefined ? 100 : props.maxHealthyPercent,\n      minHealthyPercent: props.daemon && props.minHealthyPercent === undefined ? 0 : props.minHealthyPercent ,\n      launchType: LaunchType.EC2,\n    },\n    {\n      cluster: props.cluster.clusterName,\n      taskDefinition: props.taskDefinition.taskDefinitionArn,\n      placementConstraints: Lazy.anyValue({ produce: () => this.constraints }, { omitEmptyArray: true }),\n      placementStrategies: Lazy.anyValue({ produce: () => this.strategies }, { omitEmptyArray: true }),\n      schedulingStrategy: props.daemon ? 'DAEMON' : 'REPLICA',\n    }, props.taskDefinition);\n\n    this.constraints = [];\n    this.strategies = [];\n    this.daemon = props.daemon || false;\n\n    if (props.taskDefinition.networkMode === NetworkMode.AWS_VPC) {\n      this.configureAwsVpcNetworking(props.cluster.vpc, props.assignPublicIp, props.vpcSubnets, props.securityGroup);\n    } else {\n      // Either None, Bridge or Host networking. Copy SecurityGroup from ASG.\n      validateNoNetworkingProps(props);\n      this.connections.addSecurityGroup(...props.cluster.connections.securityGroups);\n    }\n\n    this.addPlacementConstraints(...props.placementConstraints || []);\n    this.addPlacementStrategies(...props.placementStrategies || []);\n\n    if (!this.taskDefinition.defaultContainer) {\n      throw new Error('A TaskDefinition must have at least one essential container');\n    }\n  }\n\n  /**\n   * Adds one or more placement strategies to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Strategies](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-strategies.html).\n   */\n  public addPlacementStrategies(...strategies: PlacementStrategy[]) {\n    if (strategies.length > 0 && this.daemon) {\n      throw new Error(\"Can't configure placement strategies when daemon=true\");\n    }\n\n    for (const strategy of strategies) {\n      this.strategies.push(...strategy.toJson());\n    }\n  }\n\n  /**\n   * Adds one or more placement strategies to use for tasks in the service. For more information, see\n   * [Amazon ECS Task Placement Constraints](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-placement-constraints.html).\n   */\n  public addPlacementConstraints(...constraints: PlacementConstraint[]) {\n    for (const constraint of constraints) {\n      this.constraints.push(...constraint.toJson());\n    }\n  }\n\n  /**\n   * Registers the service as a target of a Classic Load Balancer (CLB).\n   *\n   * Don't call this. Call `loadBalancer.addTarget()` instead.\n   */\n  public attachToClassicLB(loadBalancer: elb.LoadBalancer): void {\n    if (this.taskDefinition.networkMode === NetworkMode.BRIDGE) {\n      throw new Error(\"Cannot use a Classic Load Balancer if NetworkMode is Bridge. Use Host or AwsVpc instead.\");\n    }\n    if (this.taskDefinition.networkMode === NetworkMode.NONE) {\n      throw new Error(\"Cannot use a Classic Load Balancer if NetworkMode is None. Use Host or AwsVpc instead.\");\n    }\n\n    this.loadBalancers.push({\n      loadBalancerName: loadBalancer.loadBalancerName,\n      containerName: this.taskDefinition.defaultContainer!.containerName,\n      containerPort: this.taskDefinition.defaultContainer!.containerPort,\n    });\n  }\n\n  /**\n   * Validates this Ec2Service.\n   */\n  protected validate(): string[] {\n    const ret = super.validate();\n    if (!this.cluster.hasEc2Capacity) {\n      ret.push('Cluster for this service needs Ec2 capacity. Call addXxxCapacity() on the cluster.');\n    }\n    return ret;\n  }\n}\n\n/**\n * Validate combinations of networking arguments\n */\nfunction validateNoNetworkingProps(props: Ec2ServiceProps) {\n  if (props.vpcSubnets !== undefined || props.securityGroup !== undefined || props.assignPublicIp) {\n    throw new Error('vpcSubnets, securityGroup and assignPublicIp can only be used in AwsVpc networking mode');\n  }\n}\n\n/**\n * The built-in container instance attributes\n */\nexport class BuiltInAttributes {\n  /**\n   * The id of the instance.\n   */\n  public static readonly INSTANCE_ID = 'instanceId';\n\n  /**\n   * The AvailabilityZone where the instance is running in.\n   */\n  public static readonly AVAILABILITY_ZONE = 'attribute:ecs.availability-zone';\n\n  /**\n   * The AMI id the instance is using.\n   */\n  public static readonly AMI_ID = 'attribute:ecs.ami-id';\n\n  /**\n   * The EC2 instance type.\n   */\n  public static readonly INSTANCE_TYPE = 'attribute:ecs.instance-type';\n\n  /**\n   * The operating system of the instance.\n   *\n   * Either 'linux' or 'windows'.\n   */\n  public static readonly OS_TYPE = 'attribute:ecs.os-type';\n}\n"]}

@@ -70,7 +70,7 @@ "use strict";

capabilities: {
add: cdk.Lazy.listValue({ produce: () => this.capAdd }),
drop: cdk.Lazy.listValue({ produce: () => this.capDrop }),
add: cdk.Lazy.listValue({ produce: () => this.capAdd }, { omitEmpty: true }),
drop: cdk.Lazy.listValue({ produce: () => this.capDrop }, { omitEmpty: true }),
},
devices: cdk.Lazy.anyValue({ produce: () => this.devices.map(renderDevice) }),
tmpfs: cdk.Lazy.anyValue({ produce: () => this.tmpfs.map(renderTmpfs) })
devices: cdk.Lazy.anyValue({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }),
tmpfs: cdk.Lazy.anyValue({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true })
};

@@ -201,2 +201,2 @@ }

})(TmpfsMountOption = exports.TmpfsMountOption || (exports.TmpfsMountOption = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linux-parameters.js","sourceRoot":"","sources":["linux-parameters.ts"],"names":[],"mappings":"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","sourcesContent":["import cdk = require('@aws-cdk/core');\nimport { CfnTaskDefinition } from './ecs.generated';\n\n/**\n * The properties for defining Linux-specific options that are applied to the container.\n */\nexport interface LinuxParametersProps {\n  /**\n   * Specifies whether to run an init process inside the container that forwards signals and reaps processes.\n   *\n   * @default false\n   */\n  readonly initProcessEnabled?: boolean;\n\n  /**\n   * The value for the size (in MiB) of the /dev/shm volume.\n   *\n   * @default No shared memory.\n   */\n  readonly sharedMemorySize?: number;\n}\n\n/**\n * Linux-specific options that are applied to the container.\n */\nexport class LinuxParameters extends cdk.Construct {\n  /**\n   * Whether the init process is enabled\n   */\n  private readonly initProcessEnabled?: boolean;\n\n  /**\n   * The shared memory size. Not valid for Fargate launch type\n   */\n  private readonly sharedMemorySize?: number;\n\n  /**\n   * Capabilities to be added\n   */\n  private readonly capAdd = new Array<Capability>();\n\n  /**\n   * Capabilities to be dropped\n   */\n  private readonly capDrop = new Array<Capability>();\n\n  /**\n   * Device mounts\n   */\n  private readonly devices = new Array<Device>();\n\n  /**\n   * TmpFs mounts\n   */\n  private readonly tmpfs = new Array<Tmpfs>();\n\n  /**\n   * Constructs a new instance of the LinuxParameters class.\n   */\n  constructor(scope: cdk.Construct, id: string, props: LinuxParametersProps = {}) {\n    super(scope, id);\n\n    this.sharedMemorySize = props.sharedMemorySize;\n    this.initProcessEnabled = props.initProcessEnabled;\n  }\n\n  /**\n   * Adds one or more Linux capabilities to the Docker configuration of a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addCapabilities(...cap: Capability[]) {\n    this.capAdd.push(...cap);\n  }\n\n  /**\n   * Removes one or more Linux capabilities to the Docker configuration of a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public dropCapabilities(...cap: Capability[]) {\n    this.capDrop.push(...cap);\n  }\n\n  /**\n   * Adds one or more host devices to a container.\n   */\n  public addDevices(...device: Device[]) {\n    this.devices.push(...device);\n  }\n\n  /**\n   * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addTmpfs(...tmpfs: Tmpfs[]) {\n    this.tmpfs.push(...tmpfs);\n  }\n\n  /**\n   * Renders the Linux parameters to a CloudFormation object.\n   */\n  public renderLinuxParameters(): CfnTaskDefinition.LinuxParametersProperty {\n    return {\n      initProcessEnabled: this.initProcessEnabled,\n      sharedMemorySize: this.sharedMemorySize,\n      capabilities: {\n        add: cdk.Lazy.listValue({ produce: () => this.capAdd }),\n        drop: cdk.Lazy.listValue({  produce: () => this.capDrop }),\n      },\n      devices: cdk.Lazy.anyValue({ produce: () => this.devices.map(renderDevice) }),\n      tmpfs: cdk.Lazy.anyValue({ produce: () => this.tmpfs.map(renderTmpfs) })\n    };\n  }\n}\n\n/**\n * A container instance host device.\n */\nexport interface Device {\n  /**\n   * The path inside the container at which to expose the host device.\n   *\n   * @default Same path as the host\n   */\n  readonly containerPath?: string,\n\n  /**\n   * The path for the device on the host container instance.\n   */\n  readonly hostPath: string,\n\n  /**\n   * The explicit permissions to provide to the container for the device.\n   * By default, the container has permissions for read, write, and mknod for the device.\n   *\n   * @default Readonly\n   */\n  readonly permissions?: DevicePermission[]\n}\n\nfunction renderDevice(device: Device): CfnTaskDefinition.DeviceProperty {\n  return {\n    containerPath: device.containerPath,\n    hostPath: device.hostPath,\n    permissions: device.permissions\n  };\n}\n\n/**\n * The details of a tmpfs mount for a container.\n */\nexport interface Tmpfs {\n  /**\n   * The absolute file path where the tmpfs volume is to be mounted.\n   */\n  readonly containerPath: string,\n\n  /**\n   * The size (in MiB) of the tmpfs volume.\n   */\n  readonly size: number,\n\n  /**\n   * The list of tmpfs volume mount options. For more information, see\n   * [TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html).\n   */\n  readonly mountOptions?: TmpfsMountOption[],\n}\n\nfunction renderTmpfs(tmpfs: Tmpfs): CfnTaskDefinition.TmpfsProperty {\n  return {\n    containerPath: tmpfs.containerPath,\n    size: tmpfs.size,\n    mountOptions: tmpfs.mountOptions\n  };\n}\n\n/**\n * A Linux capability\n */\nexport enum Capability {\n  ALL = \"ALL\",\n  AUDIT_CONTROL = \"AUDIT_CONTROL\",\n  AUDIT_WRITE = \"AUDIT_WRITE\",\n  BLOCK_SUSPEND = \"BLOCK_SUSPEND\",\n  CHOWN = \"CHOWN\",\n  DAC_OVERRIDE = \"DAC_OVERRIDE\",\n  DAC_READ_SEARCH = \"DAC_READ_SEARCH\",\n  FOWNER = \"FOWNER\",\n  FSETID = \"FSETID\",\n  IPC_LOCK = \"IPC_LOCK\",\n  IPC_OWNER = \"IPC_OWNER\",\n  KILL = \"KILL\",\n  LEASE = \"LEASE\",\n  LINUX_IMMUTABLE = \"LINUX_IMMUTABLE\",\n  MAC_ADMIN = \"MAC_ADMIN\",\n  MAC_OVERRIDE = \"MAC_OVERRIDE\",\n  MKNOD = \"MKNOD\",\n  NET_ADMIN = \"NET_ADMIN\",\n  NET_BIND_SERVICE = \"NET_BIND_SERVICE\",\n  NET_BROADCAST = \"NET_BROADCAST\",\n  NET_RAW = \"NET_RAW\",\n  SETFCAP = \"SETFCAP\",\n  SETGID = \"SETGID\",\n  SETPCAP = \"SETPCAP\",\n  SETUID = \"SETUID\",\n  SYS_ADMIN = \"SYS_ADMIN\",\n  SYS_BOOT = \"SYS_BOOT\",\n  SYS_CHROOT = \"SYS_CHROOT\",\n  SYS_MODULE = \"SYS_MODULE\",\n  SYS_NICE = \"SYS_NICE\",\n  SYS_PACCT = \"SYS_PACCT\",\n  SYS_PTRACE = \"SYS_PTRACE\",\n  SYS_RAWIO = \"SYS_RAWIO\",\n  SYS_RESOURCE = \"SYS_RESOURCE\",\n  SYS_TIME = \"SYS_TIME\",\n  SYS_TTY_CONFIG = \"SYS_TTY_CONFIG\",\n  SYSLOG = \"SYSLOG\",\n  WAKE_ALARM = \"WAKE_ALARM\"\n}\n\n/**\n * Permissions for device access\n */\nexport enum DevicePermission {\n  /**\n   * Read\n   */\n  READ = \"read\",\n\n  /**\n   * Write\n   */\n  WRITE = \"write\",\n\n  /**\n   * Make a node\n   */\n  MKNOD = \"mknod\",\n}\n\n/**\n * The supported options for a tmpfs mount for a container.\n */\nexport enum TmpfsMountOption {\n  DEFAULTS = \"defaults\",\n  RO = \"ro\",\n  RW = \"rw\",\n  SUID = \"suid\",\n  NOSUID = \"nosuid\",\n  DEV = \"dev\",\n  NODEV = \"nodev\",\n  EXEC = \"exec\",\n  NOEXEC = \"noexec\",\n  SYNC = \"sync\",\n  ASYNC = \"async\",\n  DIRSYNC = \"dirsync\",\n  REMOUNT = \"remount\",\n  MAND = \"mand\",\n  NOMAND = \"nomand\",\n  ATIME = \"atime\",\n  NOATIME = \"noatime\",\n  DIRATIME = \"diratime\",\n  NODIRATIME = \"nodiratime\",\n  BIND = \"bind\",\n  RBIND = \"rbind\",\n  UNBINDABLE = \"unbindable\",\n  RUNBINDABLE = \"runbindable\",\n  PRIVATE = \"private\",\n  RPRIVATE = \"rprivate\",\n  SHARED = \"shared\",\n  RSHARED = \"rshared\",\n  SLAVE = \"slave\",\n  RSLAVE = \"rslave\",\n  RELATIME = \"relatime\",\n  NORELATIME = \"norelatime\",\n  STRICTATIME = \"strictatime\",\n  NOSTRICTATIME = \"nostrictatime\",\n  MODE = \"mode\",\n  UID = \"uid\",\n  GID = \"gid\",\n  NR_INODES = \"nr_inodes\",\n  NR_BLOCKS = \"nr_blocks\",\n  MPOL = \"mpol\"\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linux-parameters.js","sourceRoot":"","sources":["linux-parameters.ts"],"names":[],"mappings":"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","sourcesContent":["import cdk = require('@aws-cdk/core');\nimport { CfnTaskDefinition } from './ecs.generated';\n\n/**\n * The properties for defining Linux-specific options that are applied to the container.\n */\nexport interface LinuxParametersProps {\n  /**\n   * Specifies whether to run an init process inside the container that forwards signals and reaps processes.\n   *\n   * @default false\n   */\n  readonly initProcessEnabled?: boolean;\n\n  /**\n   * The value for the size (in MiB) of the /dev/shm volume.\n   *\n   * @default No shared memory.\n   */\n  readonly sharedMemorySize?: number;\n}\n\n/**\n * Linux-specific options that are applied to the container.\n */\nexport class LinuxParameters extends cdk.Construct {\n  /**\n   * Whether the init process is enabled\n   */\n  private readonly initProcessEnabled?: boolean;\n\n  /**\n   * The shared memory size. Not valid for Fargate launch type\n   */\n  private readonly sharedMemorySize?: number;\n\n  /**\n   * Capabilities to be added\n   */\n  private readonly capAdd = new Array<Capability>();\n\n  /**\n   * Capabilities to be dropped\n   */\n  private readonly capDrop = new Array<Capability>();\n\n  /**\n   * Device mounts\n   */\n  private readonly devices = new Array<Device>();\n\n  /**\n   * TmpFs mounts\n   */\n  private readonly tmpfs = new Array<Tmpfs>();\n\n  /**\n   * Constructs a new instance of the LinuxParameters class.\n   */\n  constructor(scope: cdk.Construct, id: string, props: LinuxParametersProps = {}) {\n    super(scope, id);\n\n    this.sharedMemorySize = props.sharedMemorySize;\n    this.initProcessEnabled = props.initProcessEnabled;\n  }\n\n  /**\n   * Adds one or more Linux capabilities to the Docker configuration of a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addCapabilities(...cap: Capability[]) {\n    this.capAdd.push(...cap);\n  }\n\n  /**\n   * Removes one or more Linux capabilities to the Docker configuration of a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public dropCapabilities(...cap: Capability[]) {\n    this.capDrop.push(...cap);\n  }\n\n  /**\n   * Adds one or more host devices to a container.\n   */\n  public addDevices(...device: Device[]) {\n    this.devices.push(...device);\n  }\n\n  /**\n   * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addTmpfs(...tmpfs: Tmpfs[]) {\n    this.tmpfs.push(...tmpfs);\n  }\n\n  /**\n   * Renders the Linux parameters to a CloudFormation object.\n   */\n  public renderLinuxParameters(): CfnTaskDefinition.LinuxParametersProperty {\n    return {\n      initProcessEnabled: this.initProcessEnabled,\n      sharedMemorySize: this.sharedMemorySize,\n      capabilities: {\n        add: cdk.Lazy.listValue({ produce: () => this.capAdd }, { omitEmpty: true}),\n        drop: cdk.Lazy.listValue({  produce: () => this.capDrop }, { omitEmpty: true}),\n      },\n      devices: cdk.Lazy.anyValue({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }),\n      tmpfs: cdk.Lazy.anyValue({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true })\n    };\n  }\n}\n\n/**\n * A container instance host device.\n */\nexport interface Device {\n  /**\n   * The path inside the container at which to expose the host device.\n   *\n   * @default Same path as the host\n   */\n  readonly containerPath?: string,\n\n  /**\n   * The path for the device on the host container instance.\n   */\n  readonly hostPath: string,\n\n  /**\n   * The explicit permissions to provide to the container for the device.\n   * By default, the container has permissions for read, write, and mknod for the device.\n   *\n   * @default Readonly\n   */\n  readonly permissions?: DevicePermission[]\n}\n\nfunction renderDevice(device: Device): CfnTaskDefinition.DeviceProperty {\n  return {\n    containerPath: device.containerPath,\n    hostPath: device.hostPath,\n    permissions: device.permissions\n  };\n}\n\n/**\n * The details of a tmpfs mount for a container.\n */\nexport interface Tmpfs {\n  /**\n   * The absolute file path where the tmpfs volume is to be mounted.\n   */\n  readonly containerPath: string,\n\n  /**\n   * The size (in MiB) of the tmpfs volume.\n   */\n  readonly size: number,\n\n  /**\n   * The list of tmpfs volume mount options. For more information, see\n   * [TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html).\n   */\n  readonly mountOptions?: TmpfsMountOption[],\n}\n\nfunction renderTmpfs(tmpfs: Tmpfs): CfnTaskDefinition.TmpfsProperty {\n  return {\n    containerPath: tmpfs.containerPath,\n    size: tmpfs.size,\n    mountOptions: tmpfs.mountOptions\n  };\n}\n\n/**\n * A Linux capability\n */\nexport enum Capability {\n  ALL = \"ALL\",\n  AUDIT_CONTROL = \"AUDIT_CONTROL\",\n  AUDIT_WRITE = \"AUDIT_WRITE\",\n  BLOCK_SUSPEND = \"BLOCK_SUSPEND\",\n  CHOWN = \"CHOWN\",\n  DAC_OVERRIDE = \"DAC_OVERRIDE\",\n  DAC_READ_SEARCH = \"DAC_READ_SEARCH\",\n  FOWNER = \"FOWNER\",\n  FSETID = \"FSETID\",\n  IPC_LOCK = \"IPC_LOCK\",\n  IPC_OWNER = \"IPC_OWNER\",\n  KILL = \"KILL\",\n  LEASE = \"LEASE\",\n  LINUX_IMMUTABLE = \"LINUX_IMMUTABLE\",\n  MAC_ADMIN = \"MAC_ADMIN\",\n  MAC_OVERRIDE = \"MAC_OVERRIDE\",\n  MKNOD = \"MKNOD\",\n  NET_ADMIN = \"NET_ADMIN\",\n  NET_BIND_SERVICE = \"NET_BIND_SERVICE\",\n  NET_BROADCAST = \"NET_BROADCAST\",\n  NET_RAW = \"NET_RAW\",\n  SETFCAP = \"SETFCAP\",\n  SETGID = \"SETGID\",\n  SETPCAP = \"SETPCAP\",\n  SETUID = \"SETUID\",\n  SYS_ADMIN = \"SYS_ADMIN\",\n  SYS_BOOT = \"SYS_BOOT\",\n  SYS_CHROOT = \"SYS_CHROOT\",\n  SYS_MODULE = \"SYS_MODULE\",\n  SYS_NICE = \"SYS_NICE\",\n  SYS_PACCT = \"SYS_PACCT\",\n  SYS_PTRACE = \"SYS_PTRACE\",\n  SYS_RAWIO = \"SYS_RAWIO\",\n  SYS_RESOURCE = \"SYS_RESOURCE\",\n  SYS_TIME = \"SYS_TIME\",\n  SYS_TTY_CONFIG = \"SYS_TTY_CONFIG\",\n  SYSLOG = \"SYSLOG\",\n  WAKE_ALARM = \"WAKE_ALARM\"\n}\n\n/**\n * Permissions for device access\n */\nexport enum DevicePermission {\n  /**\n   * Read\n   */\n  READ = \"read\",\n\n  /**\n   * Write\n   */\n  WRITE = \"write\",\n\n  /**\n   * Make a node\n   */\n  MKNOD = \"mknod\",\n}\n\n/**\n * The supported options for a tmpfs mount for a container.\n */\nexport enum TmpfsMountOption {\n  DEFAULTS = \"defaults\",\n  RO = \"ro\",\n  RW = \"rw\",\n  SUID = \"suid\",\n  NOSUID = \"nosuid\",\n  DEV = \"dev\",\n  NODEV = \"nodev\",\n  EXEC = \"exec\",\n  NOEXEC = \"noexec\",\n  SYNC = \"sync\",\n  ASYNC = \"async\",\n  DIRSYNC = \"dirsync\",\n  REMOUNT = \"remount\",\n  MAND = \"mand\",\n  NOMAND = \"nomand\",\n  ATIME = \"atime\",\n  NOATIME = \"noatime\",\n  DIRATIME = \"diratime\",\n  NODIRATIME = \"nodiratime\",\n  BIND = \"bind\",\n  RBIND = \"rbind\",\n  UNBINDABLE = \"unbindable\",\n  RUNBINDABLE = \"runbindable\",\n  PRIVATE = \"private\",\n  RPRIVATE = \"rprivate\",\n  SHARED = \"shared\",\n  RSHARED = \"rshared\",\n  SLAVE = \"slave\",\n  RSLAVE = \"rslave\",\n  RELATIME = \"relatime\",\n  NORELATIME = \"norelatime\",\n  STRICTATIME = \"strictatime\",\n  NOSTRICTATIME = \"nostrictatime\",\n  MODE = \"mode\",\n  UID = \"uid\",\n  GID = \"gid\",\n  NR_INODES = \"nr_inodes\",\n  NR_BLOCKS = \"nr_blocks\",\n  MPOL = \"mpol\"\n}\n"]}
{
"name": "@aws-cdk/aws-ecs",
"version": "1.4.0",
"version": "1.5.0",
"description": "The CDK Construct Library for AWS::ECS",

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

"devDependencies": {
"@aws-cdk/assert": "^1.4.0",
"@aws-cdk/assert": "^1.5.0",
"@types/proxyquire": "^1.3.28",

@@ -75,51 +75,51 @@ "cdk-build-tools": "file:../../../tools/cdk-build-tools",

"dependencies": {
"@aws-cdk/aws-applicationautoscaling": "^1.4.0",
"@aws-cdk/aws-autoscaling": "^1.4.0",
"@aws-cdk/aws-autoscaling-hooktargets": "^1.4.0",
"@aws-cdk/aws-certificatemanager": "^1.4.0",
"@aws-cdk/aws-cloudformation": "^1.4.0",
"@aws-cdk/aws-cloudwatch": "^1.4.0",
"@aws-cdk/aws-ec2": "^1.4.0",
"@aws-cdk/aws-ecr": "^1.4.0",
"@aws-cdk/aws-ecr-assets": "^1.4.0",
"@aws-cdk/aws-elasticloadbalancing": "^1.4.0",
"@aws-cdk/aws-elasticloadbalancingv2": "^1.4.0",
"@aws-cdk/aws-iam": "^1.4.0",
"@aws-cdk/aws-lambda": "^1.4.0",
"@aws-cdk/aws-logs": "^1.4.0",
"@aws-cdk/aws-route53": "^1.4.0",
"@aws-cdk/aws-route53-targets": "^1.4.0",
"@aws-cdk/aws-secretsmanager": "^1.4.0",
"@aws-cdk/aws-servicediscovery": "^1.4.0",
"@aws-cdk/aws-sns": "^1.4.0",
"@aws-cdk/aws-sqs": "^1.4.0",
"@aws-cdk/aws-ssm": "^1.4.0",
"@aws-cdk/core": "^1.4.0",
"@aws-cdk/cx-api": "^1.4.0"
"@aws-cdk/aws-applicationautoscaling": "^1.5.0",
"@aws-cdk/aws-autoscaling": "^1.5.0",
"@aws-cdk/aws-autoscaling-hooktargets": "^1.5.0",
"@aws-cdk/aws-certificatemanager": "^1.5.0",
"@aws-cdk/aws-cloudformation": "^1.5.0",
"@aws-cdk/aws-cloudwatch": "^1.5.0",
"@aws-cdk/aws-ec2": "^1.5.0",
"@aws-cdk/aws-ecr": "^1.5.0",
"@aws-cdk/aws-ecr-assets": "^1.5.0",
"@aws-cdk/aws-elasticloadbalancing": "^1.5.0",
"@aws-cdk/aws-elasticloadbalancingv2": "^1.5.0",
"@aws-cdk/aws-iam": "^1.5.0",
"@aws-cdk/aws-lambda": "^1.5.0",
"@aws-cdk/aws-logs": "^1.5.0",
"@aws-cdk/aws-route53": "^1.5.0",
"@aws-cdk/aws-route53-targets": "^1.5.0",
"@aws-cdk/aws-secretsmanager": "^1.5.0",
"@aws-cdk/aws-servicediscovery": "^1.5.0",
"@aws-cdk/aws-sns": "^1.5.0",
"@aws-cdk/aws-sqs": "^1.5.0",
"@aws-cdk/aws-ssm": "^1.5.0",
"@aws-cdk/core": "^1.5.0",
"@aws-cdk/cx-api": "^1.5.0"
},
"homepage": "https://github.com/aws/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-applicationautoscaling": "^1.4.0",
"@aws-cdk/aws-autoscaling": "^1.4.0",
"@aws-cdk/aws-autoscaling-hooktargets": "^1.4.0",
"@aws-cdk/aws-certificatemanager": "^1.4.0",
"@aws-cdk/aws-cloudformation": "^1.4.0",
"@aws-cdk/aws-cloudwatch": "^1.4.0",
"@aws-cdk/aws-ec2": "^1.4.0",
"@aws-cdk/aws-ecr": "^1.4.0",
"@aws-cdk/aws-ecr-assets": "^1.4.0",
"@aws-cdk/aws-elasticloadbalancing": "^1.4.0",
"@aws-cdk/aws-elasticloadbalancingv2": "^1.4.0",
"@aws-cdk/aws-iam": "^1.4.0",
"@aws-cdk/aws-lambda": "^1.4.0",
"@aws-cdk/aws-logs": "^1.4.0",
"@aws-cdk/aws-route53": "^1.4.0",
"@aws-cdk/aws-route53-targets": "^1.4.0",
"@aws-cdk/aws-secretsmanager": "^1.4.0",
"@aws-cdk/aws-servicediscovery": "^1.4.0",
"@aws-cdk/aws-sns": "^1.4.0",
"@aws-cdk/aws-sqs": "^1.4.0",
"@aws-cdk/aws-ssm": "^1.4.0",
"@aws-cdk/core": "^1.4.0",
"@aws-cdk/cx-api": "^1.4.0"
"@aws-cdk/aws-applicationautoscaling": "^1.5.0",
"@aws-cdk/aws-autoscaling": "^1.5.0",
"@aws-cdk/aws-autoscaling-hooktargets": "^1.5.0",
"@aws-cdk/aws-certificatemanager": "^1.5.0",
"@aws-cdk/aws-cloudformation": "^1.5.0",
"@aws-cdk/aws-cloudwatch": "^1.5.0",
"@aws-cdk/aws-ec2": "^1.5.0",
"@aws-cdk/aws-ecr": "^1.5.0",
"@aws-cdk/aws-ecr-assets": "^1.5.0",
"@aws-cdk/aws-elasticloadbalancing": "^1.5.0",
"@aws-cdk/aws-elasticloadbalancingv2": "^1.5.0",
"@aws-cdk/aws-iam": "^1.5.0",
"@aws-cdk/aws-lambda": "^1.5.0",
"@aws-cdk/aws-logs": "^1.5.0",
"@aws-cdk/aws-route53": "^1.5.0",
"@aws-cdk/aws-route53-targets": "^1.5.0",
"@aws-cdk/aws-secretsmanager": "^1.5.0",
"@aws-cdk/aws-servicediscovery": "^1.5.0",
"@aws-cdk/aws-sns": "^1.5.0",
"@aws-cdk/aws-sqs": "^1.5.0",
"@aws-cdk/aws-ssm": "^1.5.0",
"@aws-cdk/core": "^1.5.0",
"@aws-cdk/cx-api": "^1.5.0"
},

@@ -126,0 +126,0 @@ "engines": {

@@ -360,3 +360,2 @@ {

],
"SecurityGroupIngress": [],
"Tags": [

@@ -523,13 +522,3 @@ {

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"lambda.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "lambda.amazonaws.com"
}

@@ -723,13 +712,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"autoscaling.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "autoscaling.amazonaws.com"
}

@@ -801,13 +780,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"ecs-tasks.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "ecs-tasks.amazonaws.com"
}

@@ -847,4 +816,3 @@ }

]
},
"Volumes": []
}
}

@@ -898,4 +866,3 @@ },

},
"SchedulingStrategy": "REPLICA",
"ServiceRegistries": []
"SchedulingStrategy": "REPLICA"
},

@@ -918,3 +885,2 @@ "DependsOn": [

],
"SecurityGroupIngress": [],
"VpcId": {

@@ -949,3 +915,2 @@ "Ref": "Vpc8378EB38"

"Properties": {
"LoadBalancerAttributes": [],
"Scheme": "internet-facing",

@@ -979,3 +944,2 @@ "SecurityGroups": [

"GroupDescription": "Automatically created Security Group for ELB awsecsintegLBC73915FE",
"SecurityGroupEgress": [],
"SecurityGroupIngress": [

@@ -1031,4 +995,3 @@ {

"Port": 80,
"Protocol": "HTTP",
"Certificates": []
"Protocol": "HTTP"
}

@@ -1041,4 +1004,2 @@ },

"Protocol": "HTTP",
"TargetGroupAttributes": [],
"Targets": [],
"TargetType": "ip",

@@ -1045,0 +1006,0 @@ "VpcId": {

@@ -360,3 +360,2 @@ {

],
"SecurityGroupIngress": [],
"Tags": [

@@ -544,13 +543,3 @@ {

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"lambda.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "lambda.amazonaws.com"
}

@@ -744,13 +733,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"autoscaling.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "autoscaling.amazonaws.com"
}

@@ -822,13 +801,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"ecs-tasks.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "ecs-tasks.amazonaws.com"
}

@@ -869,4 +838,3 @@ }

]
},
"Volumes": []
}
}

@@ -899,4 +867,3 @@ },

],
"SchedulingStrategy": "REPLICA",
"ServiceRegistries": []
"SchedulingStrategy": "REPLICA"
},

@@ -911,3 +878,2 @@ "DependsOn": [

"Properties": {
"LoadBalancerAttributes": [],
"Scheme": "internet-facing",

@@ -941,3 +907,2 @@ "SecurityGroups": [

"GroupDescription": "Automatically created Security Group for ELB awsecsintegecsLB84BFA683",
"SecurityGroupEgress": [],
"SecurityGroupIngress": [

@@ -993,4 +958,3 @@ {

"Port": 80,
"Protocol": "HTTP",
"Certificates": []
"Protocol": "HTTP"
}

@@ -1003,4 +967,2 @@ },

"Protocol": "HTTP",
"TargetGroupAttributes": [],
"Targets": [],
"TargetType": "instance",

@@ -1007,0 +969,0 @@ "VpcId": {

@@ -360,3 +360,2 @@ {

],
"SecurityGroupIngress": [],
"Tags": [

@@ -523,13 +522,3 @@ {

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"lambda.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "lambda.amazonaws.com"
}

@@ -723,13 +712,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"autoscaling.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "autoscaling.amazonaws.com"
}

@@ -810,13 +789,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"ecs-tasks.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "ecs-tasks.amazonaws.com"
}

@@ -857,4 +826,3 @@ }

]
},
"Volumes": []
}
}

@@ -877,3 +845,2 @@ },

"LaunchType": "EC2",
"LoadBalancers": [],
"NetworkConfiguration": {

@@ -954,3 +921,2 @@ "AwsvpcConfiguration": {

],
"SecurityGroupIngress": [],
"VpcId": {

@@ -957,0 +923,0 @@ "Ref": "Vpc8378EB38"

@@ -360,3 +360,2 @@ {

],
"SecurityGroupIngress": [],
"Tags": [

@@ -523,13 +522,3 @@ {

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"lambda.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "lambda.amazonaws.com"
}

@@ -723,13 +712,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"autoscaling.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "autoscaling.amazonaws.com"
}

@@ -810,13 +789,3 @@ }

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"ecs-tasks.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "ecs-tasks.amazonaws.com"
}

@@ -857,4 +826,3 @@ }

]
},
"Volumes": []
}
}

@@ -877,3 +845,2 @@ },

"LaunchType": "EC2",
"LoadBalancers": [],
"SchedulingStrategy": "REPLICA",

@@ -880,0 +847,0 @@ "ServiceRegistries": [

import { Test } from 'nodeunit';
declare const _default: {
"When creating an ECS Service": {
"When creating an EC2 Service": {
"with only required properties set, it correctly sets default properties"(test: Test): void;
"with all properties set"(test: Test): void;
"throws when task definition is not EC2 compatible"(test: Test): void;
"errors if daemon and desiredCount both specified"(test: Test): void;

@@ -21,4 +23,10 @@ "errors if daemon and maximumPercent not 100"(test: Test): void;

"with memberOf placement constraints"(test: Test): void;
"with spreadAcross container instances strategy"(test: Test): void;
"with spreadAcross placement strategy"(test: Test): void;
"can turn PlacementStrategy into json format"(test: Test): void;
"can turn PlacementConstraints into json format"(test: Test): void;
"errors when spreadAcross with no input"(test: Test): void;
"errors with spreadAcross placement strategy if daemon specified"(test: Test): void;
"with no placement constraints"(test: Test): void;
"with no placement strategy if daemon specified"(test: Test): void;
"with random placement strategy"(test: Test): void;

@@ -31,2 +39,16 @@ "errors with random placement strategy if daemon specified"(test: Test): void;

};
"attachToClassicLB": {
"allows network mode of task definition to be host"(test: Test): void;
'allows network mode of task definition to be AwsVpc'(test: Test): void;
'throws when network mode of task definition is bridge'(test: Test): void;
'throws when network mode of task definition is none'(test: Test): void;
};
"attachToApplicationTargetGroup": {
"allows network mode of task definition to be other than none"(test: Test): void;
"throws when network mode of task definition is none"(test: Test): void;
};
"attachToNetworkTargetGroup": {
"allows network mode of task definition to be other than none"(test: Test): void;
"throws when network mode of task definition is none"(test: Test): void;
};
'classic ELB': {

@@ -33,0 +55,0 @@ 'can attach to classic ELB'(test: Test): void;

@@ -5,5 +5,11 @@ import { Test } from 'nodeunit';

"with only required properties set, it correctly sets default properties"(test: Test): void;
"with all properties set"(test: Test): void;
"correctly sets placement constraint"(test: Test): void;
"correctly sets network mode"(test: Test): void;
"correctly sets containers"(test: Test): void;
"correctly sets containers from ECR repository"(test: Test): void;
"all container definition options defined"(test: Test): void;
"correctly sets containers from ECR repository using all props"(test: Test): void;
"correctly sets containers from ECR repository using default props"(test: Test): void;
"correctly sets containers from asset using default props"(test: Test): void;
"correctly sets containers from asset using all props"(test: Test): void;
"correctly sets scratch space"(test: Test): void;

@@ -18,2 +24,3 @@ "correctly sets container dependenices"(test: Test): void;

"correctly sets taskRole"(test: Test): void;
"automatically sets taskRole by default"(test: Test): void;
"correctly sets dockerVolumeConfiguration"(test: Test): void;

@@ -20,0 +27,0 @@ };

@@ -358,13 +358,3 @@ {

"Principal": {
"Service": {
"Fn::Join": [
"",
[
"ecs-tasks.",
{
"Ref": "AWS::URLSuffix"
}
]
]
}
"Service": "ecs-tasks.amazonaws.com"
}

@@ -405,4 +395,3 @@ }

]
},
"Volumes": []
}
}

@@ -455,4 +444,3 @@ },

}
},
"ServiceRegistries": []
}
},

@@ -475,3 +463,2 @@ "DependsOn": [

],
"SecurityGroupIngress": [],
"VpcId": {

@@ -547,4 +534,3 @@ "Ref": "Vpc8378EB38"

"ScalableDimension": "ecs:service:DesiredCount",
"ServiceNamespace": "ecs",
"ScheduledActions": []
"ServiceNamespace": "ecs"
}

@@ -571,3 +557,2 @@ },

"Properties": {
"LoadBalancerAttributes": [],
"Scheme": "internet-facing",

@@ -601,3 +586,2 @@ "SecurityGroups": [

"GroupDescription": "Automatically created Security Group for ELB awsecsintegLBC73915FE",
"SecurityGroupEgress": [],
"SecurityGroupIngress": [

@@ -653,4 +637,3 @@ {

"Port": 80,
"Protocol": "HTTP",
"Certificates": []
"Protocol": "HTTP"
}

@@ -663,4 +646,2 @@ },

"Protocol": "HTTP",
"TargetGroupAttributes": [],
"Targets": [],
"TargetType": "ip",

@@ -667,0 +648,0 @@ "VpcId": {

@@ -5,2 +5,4 @@ import { Test } from 'nodeunit';

"with only required properties set, it correctly sets default properties"(test: Test): void;
"with all properties set"(test: Test): void;
"throws when task definition is not Fargate compatible"(test: Test): void;
"errors when no container specified on task definition"(test: Test): void;

@@ -22,3 +24,2 @@ "allows specifying assignPublicIP as enabled"(test: Test): void;

'allows scaling on custom CloudWatch metric'(test: Test): void;
"allow adding a load balancing target to an application target group"(test: Test): void;
'When enabling service discovery': {

@@ -25,0 +26,0 @@ 'throws if namespace has not been added to cluster'(test: Test): void;

@@ -5,4 +5,6 @@ import { Test } from 'nodeunit';

"with only required properties set, it correctly sets default properties"(test: Test): void;
"with all properties set"(test: Test): void;
'throws when adding placement constraint'(test: Test): void;
};
};
export = _default;
"use strict";
const assert_1 = require("@aws-cdk/assert");
const iam = require("@aws-cdk/aws-iam");
const cdk = require("@aws-cdk/core");

@@ -14,4 +15,2 @@ const ecs = require("../../lib");

Family: "FargateTaskDef",
ContainerDefinitions: [],
Volumes: [],
NetworkMode: ecs.NetworkMode.AWS_VPC,

@@ -22,7 +21,69 @@ RequiresCompatibilities: ["FARGATE"],

}));
// test error if no container defs?
test.done();
},
"with all properties set"(test) {
// GIVEN
const stack = new cdk.Stack();
const taskDefinition = new ecs.FargateTaskDefinition(stack, 'FargateTaskDef', {
cpu: 128,
executionRole: new iam.Role(stack, 'ExecutionRole', {
path: '/',
assumedBy: new iam.CompositePrincipal(new iam.ServicePrincipal("ecs.amazonaws.com"), new iam.ServicePrincipal("ecs-tasks.amazonaws.com"))
}),
family: "myApp",
memoryLimitMiB: 1024,
taskRole: new iam.Role(stack, 'TaskRole', {
assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'),
})
});
taskDefinition.addVolume({
host: {
sourcePath: "/tmp/cache",
},
name: "scratch"
});
// THEN
assert_1.expect(stack).to(assert_1.haveResourceLike("AWS::ECS::TaskDefinition", {
Cpu: "128",
ExecutionRoleArn: {
"Fn::GetAtt": [
"ExecutionRole605A040B",
"Arn"
]
},
Family: "myApp",
Memory: "1024",
NetworkMode: "awsvpc",
RequiresCompatibilities: [
ecs.LaunchType.FARGATE
],
TaskRoleArn: {
"Fn::GetAtt": [
"TaskRole30FC0FBB",
"Arn"
]
},
Volumes: [
{
Host: {
SourcePath: "/tmp/cache"
},
Name: "scratch"
}
]
}));
test.done();
},
'throws when adding placement constraint'(test) {
// GIVEN
const stack = new cdk.Stack();
const taskDefinition = new ecs.FargateTaskDefinition(stack, 'FargateTaskDef');
// THEN
test.throws(() => {
taskDefinition.addPlacementConstraint(ecs.PlacementConstraint.memberOf("attribute:ecs.instance-type =~ t2.*"));
}, /Cannot set placement constraints on tasks that run on Fargate/);
test.done();
}
}
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5mYXJnYXRlLXRhc2stZGVmaW5pdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZmFyZ2F0ZS10YXNrLWRlZmluaXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDRDQUEyRDtBQUMzRCxxQ0FBc0M7QUFFdEMsaUNBQWtDO0FBRWxDLGlCQUFTO0lBQ1AseUNBQXlDLEVBQUU7UUFDekMseUVBQXlFLENBQUMsSUFBVTtZQUNsRixRQUFRO1lBQ1IsTUFBTSxLQUFLLEdBQUcsSUFBSSxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDOUIsSUFBSSxHQUFHLENBQUMscUJBQXFCLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDLENBQUM7WUFFdkQsT0FBTztZQUNQLGVBQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMseUJBQWdCLENBQUMsMEJBQTBCLEVBQUU7Z0JBQzVELE1BQU0sRUFBRSxnQkFBZ0I7Z0JBQ3hCLG9CQUFvQixFQUFFLEVBQUU7Z0JBQ3hCLE9BQU8sRUFBRSxFQUFFO2dCQUNYLFdBQVcsRUFBRSxHQUFHLENBQUMsV0FBVyxDQUFDLE9BQU87Z0JBQ3BDLHVCQUF1QixFQUFFLENBQUMsU0FBUyxDQUFDO2dCQUNwQyxHQUFHLEVBQUUsS0FBSztnQkFDVixNQUFNLEVBQUUsS0FBSzthQUNkLENBQUMsQ0FBQyxDQUFDO1lBRUosbUNBQW1DO1lBQ25DLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNkLENBQUM7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBleHBlY3QsIGhhdmVSZXNvdXJjZUxpa2UgfSBmcm9tICdAYXdzLWNkay9hc3NlcnQnO1xuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NvcmUnKTtcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgZWNzID0gcmVxdWlyZSgnLi4vLi4vbGliJyk7XG5cbmV4cG9ydCA9IHtcbiAgXCJXaGVuIGNyZWF0aW5nIGFuIEZhcmdhdGUgVGFza0RlZmluaXRpb25cIjoge1xuICAgIFwid2l0aCBvbmx5IHJlcXVpcmVkIHByb3BlcnRpZXMgc2V0LCBpdCBjb3JyZWN0bHkgc2V0cyBkZWZhdWx0IHByb3BlcnRpZXNcIih0ZXN0OiBUZXN0KSB7XG4gICAgICAvLyBHSVZFTlxuICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgY2RrLlN0YWNrKCk7XG4gICAgICBuZXcgZWNzLkZhcmdhdGVUYXNrRGVmaW5pdGlvbihzdGFjaywgJ0ZhcmdhdGVUYXNrRGVmJyk7XG5cbiAgICAgIC8vIFRIRU5cbiAgICAgIGV4cGVjdChzdGFjaykudG8oaGF2ZVJlc291cmNlTGlrZShcIkFXUzo6RUNTOjpUYXNrRGVmaW5pdGlvblwiLCB7XG4gICAgICAgIEZhbWlseTogXCJGYXJnYXRlVGFza0RlZlwiLFxuICAgICAgICBDb250YWluZXJEZWZpbml0aW9uczogW10sXG4gICAgICAgIFZvbHVtZXM6IFtdLFxuICAgICAgICBOZXR3b3JrTW9kZTogZWNzLk5ldHdvcmtNb2RlLkFXU19WUEMsXG4gICAgICAgIFJlcXVpcmVzQ29tcGF0aWJpbGl0aWVzOiBbXCJGQVJHQVRFXCJdLFxuICAgICAgICBDcHU6IFwiMjU2XCIsXG4gICAgICAgIE1lbW9yeTogXCI1MTJcIixcbiAgICAgIH0pKTtcblxuICAgICAgLy8gdGVzdCBlcnJvciBpZiBubyBjb250YWluZXIgZGVmcz9cbiAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH0sXG4gIH1cbn07XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5mYXJnYXRlLXRhc2stZGVmaW5pdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZmFyZ2F0ZS10YXNrLWRlZmluaXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDRDQUEyRDtBQUMzRCx3Q0FBeUM7QUFDekMscUNBQXNDO0FBRXRDLGlDQUFrQztBQUVsQyxpQkFBUztJQUNQLHlDQUF5QyxFQUFFO1FBQ3pDLHlFQUF5RSxDQUFDLElBQVU7WUFDbEYsUUFBUTtZQUNSLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQzlCLElBQUksR0FBRyxDQUFDLHFCQUFxQixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO1lBRXZELE9BQU87WUFDUCxlQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLHlCQUFnQixDQUFDLDBCQUEwQixFQUFFO2dCQUM1RCxNQUFNLEVBQUUsZ0JBQWdCO2dCQUN4QixXQUFXLEVBQUUsR0FBRyxDQUFDLFdBQVcsQ0FBQyxPQUFPO2dCQUNwQyx1QkFBdUIsRUFBRSxDQUFDLFNBQVMsQ0FBQztnQkFDcEMsR0FBRyxFQUFFLEtBQUs7Z0JBQ1YsTUFBTSxFQUFFLEtBQUs7YUFDZCxDQUFDLENBQUMsQ0FBQztZQUVKLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNkLENBQUM7UUFFRCx5QkFBeUIsQ0FBQyxJQUFVO1lBQ2xDLFFBQVE7WUFDUixNQUFNLEtBQUssR0FBRyxJQUFJLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUM5QixNQUFNLGNBQWMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBQzVFLEdBQUcsRUFBRSxHQUFHO2dCQUNSLGFBQWEsRUFBRSxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLGVBQWUsRUFBRTtvQkFDbEQsSUFBSSxFQUFFLEdBQUc7b0JBQ1QsU0FBUyxFQUFFLElBQUksR0FBRyxDQUFDLGtCQUFrQixDQUNuQyxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxtQkFBbUIsQ0FBQyxFQUM3QyxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyx5QkFBeUIsQ0FBQyxDQUNwRDtpQkFDRixDQUFDO2dCQUNGLE1BQU0sRUFBRSxPQUFPO2dCQUNmLGNBQWMsRUFBRSxJQUFJO2dCQUNwQixRQUFRLEVBQUUsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUU7b0JBQ3hDLFNBQVMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyx5QkFBeUIsQ0FBQztpQkFDL0QsQ0FBQzthQUNILENBQUMsQ0FBQztZQUVILGNBQWMsQ0FBQyxTQUFTLENBQUM7Z0JBQ3ZCLElBQUksRUFBRTtvQkFDSixVQUFVLEVBQUUsWUFBWTtpQkFDekI7Z0JBQ0QsSUFBSSxFQUFFLFNBQVM7YUFDaEIsQ0FBQyxDQUFDO1lBRUgsT0FBTztZQUNQLGVBQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMseUJBQWdCLENBQUMsMEJBQTBCLEVBQUU7Z0JBQzVELEdBQUcsRUFBRSxLQUFLO2dCQUNWLGdCQUFnQixFQUFFO29CQUNoQixZQUFZLEVBQUU7d0JBQ1osdUJBQXVCO3dCQUN2QixLQUFLO3FCQUNOO2lCQUNGO2dCQUNELE1BQU0sRUFBRSxPQUFPO2dCQUNmLE1BQU0sRUFBRSxNQUFNO2dCQUNkLFdBQVcsRUFBRSxRQUFRO2dCQUNyQix1QkFBdUIsRUFBRTtvQkFDdkIsR0FBRyxDQUFDLFVBQVUsQ0FBQyxPQUFPO2lCQUN2QjtnQkFDRCxXQUFXLEVBQUU7b0JBQ1gsWUFBWSxFQUFFO3dCQUNaLGtCQUFrQjt3QkFDbEIsS0FBSztxQkFDTjtpQkFDRjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1A7d0JBQ0UsSUFBSSxFQUFFOzRCQUNKLFVBQVUsRUFBRSxZQUFZO3lCQUN6Qjt3QkFDRCxJQUFJLEVBQUUsU0FBUztxQkFDaEI7aUJBQ0Y7YUFDRixDQUFDLENBQUMsQ0FBQztZQUVKLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNkLENBQUM7UUFFRCx5Q0FBeUMsQ0FBQyxJQUFVO1lBQ2xELFFBQVE7WUFDUixNQUFNLEtBQUssR0FBRyxJQUFJLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUM5QixNQUFNLGNBQWMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztZQUU5RSxPQUFPO1lBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7Z0JBQ2YsY0FBYyxDQUFDLHNCQUFzQixDQUFDLEdBQUcsQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMscUNBQXFDLENBQUMsQ0FBQyxDQUFDO1lBQ2pILENBQUMsRUFBRSwrREFBK0QsQ0FBQyxDQUFDO1lBRXBFLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNkLENBQUM7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBleHBlY3QsIGhhdmVSZXNvdXJjZUxpa2UgfSBmcm9tICdAYXdzLWNkay9hc3NlcnQnO1xuaW1wb3J0IGlhbSA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2F3cy1pYW0nKTtcbmltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jb3JlJyk7XG5pbXBvcnQgeyBUZXN0IH0gZnJvbSAnbm9kZXVuaXQnO1xuaW1wb3J0IGVjcyA9IHJlcXVpcmUoJy4uLy4uL2xpYicpO1xuXG5leHBvcnQgPSB7XG4gIFwiV2hlbiBjcmVhdGluZyBhbiBGYXJnYXRlIFRhc2tEZWZpbml0aW9uXCI6IHtcbiAgICBcIndpdGggb25seSByZXF1aXJlZCBwcm9wZXJ0aWVzIHNldCwgaXQgY29ycmVjdGx5IHNldHMgZGVmYXVsdCBwcm9wZXJ0aWVzXCIodGVzdDogVGVzdCkge1xuICAgICAgLy8gR0lWRU5cbiAgICAgIGNvbnN0IHN0YWNrID0gbmV3IGNkay5TdGFjaygpO1xuICAgICAgbmV3IGVjcy5GYXJnYXRlVGFza0RlZmluaXRpb24oc3RhY2ssICdGYXJnYXRlVGFza0RlZicpO1xuXG4gICAgICAvLyBUSEVOXG4gICAgICBleHBlY3Qoc3RhY2spLnRvKGhhdmVSZXNvdXJjZUxpa2UoXCJBV1M6OkVDUzo6VGFza0RlZmluaXRpb25cIiwge1xuICAgICAgICBGYW1pbHk6IFwiRmFyZ2F0ZVRhc2tEZWZcIixcbiAgICAgICAgTmV0d29ya01vZGU6IGVjcy5OZXR3b3JrTW9kZS5BV1NfVlBDLFxuICAgICAgICBSZXF1aXJlc0NvbXBhdGliaWxpdGllczogW1wiRkFSR0FURVwiXSxcbiAgICAgICAgQ3B1OiBcIjI1NlwiLFxuICAgICAgICBNZW1vcnk6IFwiNTEyXCIsXG4gICAgICB9KSk7XG5cbiAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH0sXG5cbiAgICBcIndpdGggYWxsIHByb3BlcnRpZXMgc2V0XCIodGVzdDogVGVzdCkge1xuICAgICAgLy8gR0lWRU5cbiAgICAgIGNvbnN0IHN0YWNrID0gbmV3IGNkay5TdGFjaygpO1xuICAgICAgY29uc3QgdGFza0RlZmluaXRpb24gPSBuZXcgZWNzLkZhcmdhdGVUYXNrRGVmaW5pdGlvbihzdGFjaywgJ0ZhcmdhdGVUYXNrRGVmJywge1xuICAgICAgICBjcHU6IDEyOCxcbiAgICAgICAgZXhlY3V0aW9uUm9sZTogbmV3IGlhbS5Sb2xlKHN0YWNrLCAnRXhlY3V0aW9uUm9sZScsIHtcbiAgICAgICAgICBwYXRoOiAnLycsXG4gICAgICAgICAgYXNzdW1lZEJ5OiBuZXcgaWFtLkNvbXBvc2l0ZVByaW5jaXBhbChcbiAgICAgICAgICAgIG5ldyBpYW0uU2VydmljZVByaW5jaXBhbChcImVjcy5hbWF6b25hd3MuY29tXCIpLFxuICAgICAgICAgICAgbmV3IGlhbS5TZXJ2aWNlUHJpbmNpcGFsKFwiZWNzLXRhc2tzLmFtYXpvbmF3cy5jb21cIilcbiAgICAgICAgICApXG4gICAgICAgIH0pLFxuICAgICAgICBmYW1pbHk6IFwibXlBcHBcIixcbiAgICAgICAgbWVtb3J5TGltaXRNaUI6IDEwMjQsXG4gICAgICAgIHRhc2tSb2xlOiBuZXcgaWFtLlJvbGUoc3RhY2ssICdUYXNrUm9sZScsIHtcbiAgICAgICAgICBhc3N1bWVkQnk6IG5ldyBpYW0uU2VydmljZVByaW5jaXBhbCgnZWNzLXRhc2tzLmFtYXpvbmF3cy5jb20nKSxcbiAgICAgICAgfSlcbiAgICAgIH0pO1xuXG4gICAgICB0YXNrRGVmaW5pdGlvbi5hZGRWb2x1bWUoe1xuICAgICAgICBob3N0OiB7XG4gICAgICAgICAgc291cmNlUGF0aDogXCIvdG1wL2NhY2hlXCIsXG4gICAgICAgIH0sXG4gICAgICAgIG5hbWU6IFwic2NyYXRjaFwiXG4gICAgICB9KTtcblxuICAgICAgLy8gVEhFTlxuICAgICAgZXhwZWN0KHN0YWNrKS50byhoYXZlUmVzb3VyY2VMaWtlKFwiQVdTOjpFQ1M6OlRhc2tEZWZpbml0aW9uXCIsIHtcbiAgICAgICAgQ3B1OiBcIjEyOFwiLFxuICAgICAgICBFeGVjdXRpb25Sb2xlQXJuOiB7XG4gICAgICAgICAgXCJGbjo6R2V0QXR0XCI6IFtcbiAgICAgICAgICAgIFwiRXhlY3V0aW9uUm9sZTYwNUEwNDBCXCIsXG4gICAgICAgICAgICBcIkFyblwiXG4gICAgICAgICAgXVxuICAgICAgICB9LFxuICAgICAgICBGYW1pbHk6IFwibXlBcHBcIixcbiAgICAgICAgTWVtb3J5OiBcIjEwMjRcIixcbiAgICAgICAgTmV0d29ya01vZGU6IFwiYXdzdnBjXCIsXG4gICAgICAgIFJlcXVpcmVzQ29tcGF0aWJpbGl0aWVzOiBbXG4gICAgICAgICAgZWNzLkxhdW5jaFR5cGUuRkFSR0FURVxuICAgICAgICBdLFxuICAgICAgICBUYXNrUm9sZUFybjoge1xuICAgICAgICAgIFwiRm46OkdldEF0dFwiOiBbXG4gICAgICAgICAgICBcIlRhc2tSb2xlMzBGQzBGQkJcIixcbiAgICAgICAgICAgIFwiQXJuXCJcbiAgICAgICAgICBdXG4gICAgICAgIH0sXG4gICAgICAgIFZvbHVtZXM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICBIb3N0OiB7XG4gICAgICAgICAgICAgIFNvdXJjZVBhdGg6IFwiL3RtcC9jYWNoZVwiXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgTmFtZTogXCJzY3JhdGNoXCJcbiAgICAgICAgICB9XG4gICAgICAgIF1cbiAgICAgIH0pKTtcblxuICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICd0aHJvd3Mgd2hlbiBhZGRpbmcgcGxhY2VtZW50IGNvbnN0cmFpbnQnKHRlc3Q6IFRlc3QpIHtcbiAgICAgIC8vIEdJVkVOXG4gICAgICBjb25zdCBzdGFjayA9IG5ldyBjZGsuU3RhY2soKTtcbiAgICAgIGNvbnN0IHRhc2tEZWZpbml0aW9uID0gbmV3IGVjcy5GYXJnYXRlVGFza0RlZmluaXRpb24oc3RhY2ssICdGYXJnYXRlVGFza0RlZicpO1xuXG4gICAgICAvLyBUSEVOXG4gICAgICB0ZXN0LnRocm93cygoKSA9PiB7XG4gICAgICAgIHRhc2tEZWZpbml0aW9uLmFkZFBsYWNlbWVudENvbnN0cmFpbnQoZWNzLlBsYWNlbWVudENvbnN0cmFpbnQubWVtYmVyT2YoXCJhdHRyaWJ1dGU6ZWNzLmluc3RhbmNlLXR5cGUgPX4gdDIuKlwiKSk7XG4gICAgICB9LCAvQ2Fubm90IHNldCBwbGFjZW1lbnQgY29uc3RyYWludHMgb24gdGFza3MgdGhhdCBydW4gb24gRmFyZ2F0ZS8pO1xuXG4gICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9XG4gIH1cbn07XG4iXX0=

@@ -7,4 +7,5 @@ import { Test } from 'nodeunit';

'with a defined log group'(test: Test): void;
'without a defined log group'(test: Test): void;
'throws when specifying log retention and log group'(test: Test): void;
};
export = _default;

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

// THEN
assert_1.expect(stack).to(assert_1.haveResource('AWS::Logs::LogGroup', {
RetentionInDays: logs.RetentionDays.TWO_YEARS
}));
assert_1.expect(stack).to(assert_1.haveResourceLike('AWS::ECS::TaskDefinition', {

@@ -110,2 +113,14 @@ ContainerDefinitions: [

},
'without a defined log group'(test) {
// GIVEN
td.addContainer('Container', {
image,
logging: new ecs.AwsLogDriver({
streamPrefix: 'hello',
})
});
// THEN
assert_1.expect(stack).notTo(assert_1.haveResource('AWS::Logs::LogGroup', {}));
test.done();
},
'throws when specifying log retention and log group'(test) {

@@ -123,2 +138,2 @@ // GIVEN

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.aws-log-driver.js","sourceRoot":"","sources":["test.aws-log-driver.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, haveResourceLike } from '@aws-cdk/assert';\nimport logs = require('@aws-cdk/aws-logs');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport ecs = require('../lib');\n\nlet stack: cdk.Stack;\nlet td: ecs.TaskDefinition;\nconst image = ecs.ContainerImage.fromRegistry('test-image');\n\nexport = {\n  'setUp'(cb: () => void) {\n    stack = new cdk.Stack();\n    td = new ecs.FargateTaskDefinition(stack, 'TaskDefinition');\n\n    cb();\n  },\n\n  'create an aws log driver'(test: Test) {\n    // WHEN\n    td.addContainer('Container', {\n      image,\n      logging: new ecs.AwsLogDriver({\n        datetimeFormat: 'format',\n        logRetention: logs.RetentionDays.ONE_MONTH,\n        multilinePattern: 'pattern',\n        streamPrefix: 'hello'\n      })\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::Logs::LogGroup', {\n      RetentionInDays: logs.RetentionDays.ONE_MONTH\n    }));\n\n    expect(stack).to(haveResourceLike('AWS::ECS::TaskDefinition', {\n      ContainerDefinitions: [\n        {\n          LogConfiguration: {\n            LogDriver: 'awslogs',\n            Options: {\n              'awslogs-group': { Ref: 'TaskDefinitionContainerLogGroup4D0A87C1' },\n              'awslogs-stream-prefix': 'hello',\n              'awslogs-region': { Ref: 'AWS::Region' },\n              'awslogs-datetime-format': 'format',\n              'awslogs-multiline-pattern': 'pattern'\n            }\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  \"create an aws log driver using awsLogs\"(test: Test) {\n    // WHEN\n    td.addContainer('Container', {\n      image,\n      logging: ecs.AwsLogDriver.awsLogs({\n        datetimeFormat: 'format',\n        logRetention: logs.RetentionDays.ONE_MONTH,\n        multilinePattern: 'pattern',\n        streamPrefix: 'hello'\n      })\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::Logs::LogGroup', {\n      RetentionInDays: logs.RetentionDays.ONE_MONTH\n    }));\n\n    expect(stack).to(haveResourceLike('AWS::ECS::TaskDefinition', {\n      ContainerDefinitions: [\n        {\n          LogConfiguration: {\n            LogDriver: 'awslogs',\n            Options: {\n              'awslogs-group': { Ref: 'TaskDefinitionContainerLogGroup4D0A87C1' },\n              'awslogs-stream-prefix': 'hello',\n              'awslogs-region': { Ref: 'AWS::Region' },\n              'awslogs-datetime-format': 'format',\n              'awslogs-multiline-pattern': 'pattern'\n            }\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'with a defined log group'(test: Test) {\n    // GIVEN\n    const logGroup = new logs.LogGroup(stack, 'LogGroup');\n\n    // WHEN\n    td.addContainer('Container', {\n      image,\n      logging: new ecs.AwsLogDriver({\n        logGroup,\n        streamPrefix: 'hello'\n      })\n    });\n\n    // THEN\n    expect(stack).to(haveResourceLike('AWS::ECS::TaskDefinition', {\n      ContainerDefinitions: [\n        {\n          LogConfiguration: {\n            LogDriver: 'awslogs',\n            Options: {\n              'awslogs-group': { Ref: 'LogGroupF5B46931' },\n              'awslogs-stream-prefix': 'hello',\n              'awslogs-region': { Ref: 'AWS::Region' }\n            }\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'throws when specifying log retention and log group'(test: Test) {\n    // GIVEN\n    const logGroup = new logs.LogGroup(stack, 'LogGroup');\n\n    // THEN\n    test.throws(() => new ecs.AwsLogDriver({\n      logGroup,\n      logRetention: logs.RetentionDays.FIVE_DAYS,\n      streamPrefix: 'hello'\n    }), /`logGroup`.*`logRetentionDays`/);\n\n    test.done();\n  }\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.aws-log-driver.js","sourceRoot":"","sources":["test.aws-log-driver.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, haveResourceLike } from '@aws-cdk/assert';\nimport logs = require('@aws-cdk/aws-logs');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport ecs = require('../lib');\n\nlet stack: cdk.Stack;\nlet td: ecs.TaskDefinition;\nconst image = ecs.ContainerImage.fromRegistry('test-image');\n\nexport = {\n  'setUp'(cb: () => void) {\n    stack = new cdk.Stack();\n    td = new ecs.FargateTaskDefinition(stack, 'TaskDefinition');\n\n    cb();\n  },\n\n  'create an aws log driver'(test: Test) {\n    // WHEN\n    td.addContainer('Container', {\n      image,\n      logging: new ecs.AwsLogDriver({\n        datetimeFormat: 'format',\n        logRetention: logs.RetentionDays.ONE_MONTH,\n        multilinePattern: 'pattern',\n        streamPrefix: 'hello'\n      })\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::Logs::LogGroup', {\n      RetentionInDays: logs.RetentionDays.ONE_MONTH\n    }));\n\n    expect(stack).to(haveResourceLike('AWS::ECS::TaskDefinition', {\n      ContainerDefinitions: [\n        {\n          LogConfiguration: {\n            LogDriver: 'awslogs',\n            Options: {\n              'awslogs-group': { Ref: 'TaskDefinitionContainerLogGroup4D0A87C1' },\n              'awslogs-stream-prefix': 'hello',\n              'awslogs-region': { Ref: 'AWS::Region' },\n              'awslogs-datetime-format': 'format',\n              'awslogs-multiline-pattern': 'pattern'\n            }\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  \"create an aws log driver using awsLogs\"(test: Test) {\n    // WHEN\n    td.addContainer('Container', {\n      image,\n      logging: ecs.AwsLogDriver.awsLogs({\n        datetimeFormat: 'format',\n        logRetention: logs.RetentionDays.ONE_MONTH,\n        multilinePattern: 'pattern',\n        streamPrefix: 'hello'\n      })\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::Logs::LogGroup', {\n      RetentionInDays: logs.RetentionDays.ONE_MONTH\n    }));\n\n    expect(stack).to(haveResourceLike('AWS::ECS::TaskDefinition', {\n      ContainerDefinitions: [\n        {\n          LogConfiguration: {\n            LogDriver: 'awslogs',\n            Options: {\n              'awslogs-group': { Ref: 'TaskDefinitionContainerLogGroup4D0A87C1' },\n              'awslogs-stream-prefix': 'hello',\n              'awslogs-region': { Ref: 'AWS::Region' },\n              'awslogs-datetime-format': 'format',\n              'awslogs-multiline-pattern': 'pattern'\n            }\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'with a defined log group'(test: Test) {\n    // GIVEN\n    const logGroup = new logs.LogGroup(stack, 'LogGroup');\n\n    // WHEN\n    td.addContainer('Container', {\n      image,\n      logging: new ecs.AwsLogDriver({\n        logGroup,\n        streamPrefix: 'hello'\n      })\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::Logs::LogGroup', {\n      RetentionInDays: logs.RetentionDays.TWO_YEARS\n    }));\n\n    expect(stack).to(haveResourceLike('AWS::ECS::TaskDefinition', {\n      ContainerDefinitions: [\n        {\n          LogConfiguration: {\n            LogDriver: 'awslogs',\n            Options: {\n              'awslogs-group': { Ref: 'LogGroupF5B46931' },\n              'awslogs-stream-prefix': 'hello',\n              'awslogs-region': { Ref: 'AWS::Region' }\n            }\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'without a defined log group'(test: Test) {\n    // GIVEN\n    td.addContainer('Container', {\n      image,\n      logging: new ecs.AwsLogDriver({\n        streamPrefix: 'hello',\n      })\n    });\n\n    // THEN\n    expect(stack).notTo(haveResource('AWS::Logs::LogGroup', {}));\n\n    test.done();\n  },\n\n  'throws when specifying log retention and log group'(test: Test) {\n    // GIVEN\n    const logGroup = new logs.LogGroup(stack, 'LogGroup');\n\n    // THEN\n    test.throws(() => new ecs.AwsLogDriver({\n      logGroup,\n      logRetention: logs.RetentionDays.FIVE_DAYS,\n      streamPrefix: 'hello'\n    }), /`logGroup`.*`logRetentionDays`/);\n\n    test.done();\n  }\n};\n"]}
import { Test } from 'nodeunit';
declare const _default: {
"When creating a Task Definition": {
"add a container using default props"(test: Test): void;
"throws when MemoryLimit is less than MemoryReservationLimit"(test: Test): void;
"With network mode AwsVpc": {
"Host port should be the same as container port"(test: Test): void;
"throws when Host port is different from container port"(test: Test): void;
"Host port is the same as container port"(test: Test): void;
"Host port can be empty "(test: Test): void;
};
"With network mode Host ": {
"Host port should be the same as container port"(test: Test): void;
"throws when Host port is different from container port"(test: Test): void;
"when host port is the same as container port"(test: Test): void;
"Host port can be empty "(test: Test): void;

@@ -14,8 +18,15 @@ "errors when adding links"(test: Test): void;

"With network mode Bridge": {
"when Host port is empty "(test: Test): void;
"when Host port is not empty "(test: Test): void;
"allows adding links"(test: Test): void;
};
};
"Container Port": {
"should return the first container port in PortMappings"(test: Test): void;
"throws when calling containerPort with no PortMappings"(test: Test): void;
};
"Ingress Port": {
"With network mode AwsVpc": {
"Ingress port should be the same as container port"(test: Test): void;
"throws when calling ingressPort with no PortMappings"(test: Test): void;
};

@@ -34,2 +45,3 @@ "With network mode Host ": {

'can set Health Check with defaults'(test: Test): void;
'throws when setting Health Check with no commands'(test: Test): void;
'can specify Health Check values in shell form'(test: Test): void;

@@ -39,3 +51,8 @@ 'can specify Health Check values in array form starting with CMD-SHELL'(test: Test): void;

'can specify private registry credentials'(test: Test): void;
'_linkContainer works properly': {
'when the props passed in is an essential container'(test: Test): void;
'when the props passed in is not an essential container'(test: Test): void;
};
'Can specify linux parameters': {
'with only required properties set, it correctly sets default properties'(test: Test): void;
'before calling addContainer'(test: Test): void;

@@ -42,0 +59,0 @@ 'after calling addContainer'(test: Test): void;

@@ -27,2 +27,4 @@ import { Test } from 'nodeunit';

"allows specifying spot fleet"(test: Test): void;
"allows specifying drain time"(test: Test): void;
"allows containers access to instance metadata service"(test: Test): void;
"allows adding default service discovery namespace"(test: Test): void;

@@ -29,0 +31,0 @@ "allows adding public service discovery namespace"(test: Test): void;

Sorry, the diff of this file is not supported yet

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

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

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

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

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

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

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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc