1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.FargatePlatformVersion = exports.FargateService = void 0;
|
5 | const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const cdk = require("@aws-cdk/core");
|
8 | const core_1 = require("@aws-cdk/core");
|
9 | const base_service_1 = require("../base/base-service");
|
10 | const from_service_attributes_1 = require("../base/from-service-attributes");
|
11 | /**
|
12 | * This creates a service using the Fargate launch type on an ECS cluster.
|
13 | *
|
14 | * @resource AWS::ECS::Service
|
15 | */
|
16 | class FargateService extends base_service_1.BaseService {
|
17 | /**
|
18 | * Constructs a new instance of the FargateService class.
|
19 | */
|
20 | constructor(scope, id, props) {
|
21 | var _b;
|
22 | try {
|
23 | jsiiDeprecationWarnings._aws_cdk_aws_ecs_FargateServiceProps(props);
|
24 | }
|
25 | catch (error) {
|
26 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
27 | Error.captureStackTrace(error, this.constructor);
|
28 | }
|
29 | throw error;
|
30 | }
|
31 | if (!props.taskDefinition.isFargateCompatible) {
|
32 | throw new Error('Supplied TaskDefinition is not configured for compatibility with Fargate');
|
33 | }
|
34 | if (props.securityGroup !== undefined && props.securityGroups !== undefined) {
|
35 | throw new Error('Only one of SecurityGroup or SecurityGroups can be populated.');
|
36 | }
|
37 | if (props.taskDefinition.referencesSecretJsonField
|
38 | && props.platformVersion
|
39 | && SECRET_JSON_FIELD_UNSUPPORTED_PLATFORM_VERSIONS.includes(props.platformVersion)) {
|
40 | throw new Error(`The task definition of this service uses at least one container that references a secret JSON field. This feature requires platform version ${FargatePlatformVersion.VERSION1_4} or later.`);
|
41 | }
|
42 | super(scope, id, {
|
43 | ...props,
|
44 | desiredCount: props.desiredCount,
|
45 | launchType: base_service_1.LaunchType.FARGATE,
|
46 | capacityProviderStrategies: props.capacityProviderStrategies,
|
47 | enableECSManagedTags: props.enableECSManagedTags,
|
48 | }, {
|
49 | cluster: props.cluster.clusterName,
|
50 | taskDefinition: ((_b = props.deploymentController) === null || _b === void 0 ? void 0 : _b.type) === base_service_1.DeploymentControllerType.EXTERNAL ? undefined : props.taskDefinition.taskDefinitionArn,
|
51 | platformVersion: props.platformVersion,
|
52 | }, props.taskDefinition);
|
53 | let securityGroups;
|
54 | if (props.securityGroup !== undefined) {
|
55 | securityGroups = [props.securityGroup];
|
56 | }
|
57 | else if (props.securityGroups !== undefined) {
|
58 | securityGroups = props.securityGroups;
|
59 | }
|
60 | this.configureAwsVpcNetworkingWithSecurityGroups(props.cluster.vpc, props.assignPublicIp, props.vpcSubnets, securityGroups);
|
61 | this.node.addValidation({
|
62 | validate: () => !this.taskDefinition.defaultContainer ? ['A TaskDefinition must have at least one essential container'] : [],
|
63 | });
|
64 | }
|
65 | /**
|
66 | * Imports from the specified service ARN.
|
67 | */
|
68 | static fromFargateServiceArn(scope, id, fargateServiceArn) {
|
69 | class Import extends cdk.Resource {
|
70 | constructor() {
|
71 | super(...arguments);
|
72 | this.serviceArn = fargateServiceArn;
|
73 | this.serviceName = cdk.Stack.of(scope).splitArn(fargateServiceArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName;
|
74 | }
|
75 | }
|
76 | return new Import(scope, id);
|
77 | }
|
78 | /**
|
79 | * Imports from the specified service attrributes.
|
80 | */
|
81 | static fromFargateServiceAttributes(scope, id, attrs) {
|
82 | try {
|
83 | jsiiDeprecationWarnings._aws_cdk_aws_ecs_FargateServiceAttributes(attrs);
|
84 | }
|
85 | catch (error) {
|
86 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
87 | Error.captureStackTrace(error, this.fromFargateServiceAttributes);
|
88 | }
|
89 | throw error;
|
90 | }
|
91 | return from_service_attributes_1.fromServiceAtrributes(scope, id, attrs);
|
92 | }
|
93 | }
|
94 | exports.FargateService = FargateService;
|
95 | _a = JSII_RTTI_SYMBOL_1;
|
96 | FargateService[_a] = { fqn: "@aws-cdk/aws-ecs.FargateService", version: "1.156.1" };
|
97 | /**
|
98 | * The platform version on which to run your service.
|
99 | *
|
100 | * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/platform_versions.html
|
101 | */
|
102 | var FargatePlatformVersion;
|
103 | (function (FargatePlatformVersion) {
|
104 | /**
|
105 | * The latest, recommended platform version.
|
106 | */
|
107 | FargatePlatformVersion["LATEST"] = "LATEST";
|
108 | /**
|
109 | * Version 1.4.0
|
110 | *
|
111 | * Supports EFS endpoints, CAP_SYS_PTRACE Linux capability,
|
112 | * network performance metrics in CloudWatch Container Insights,
|
113 | * consolidated 20 GB ephemeral volume.
|
114 | */
|
115 | FargatePlatformVersion["VERSION1_4"] = "1.4.0";
|
116 | /**
|
117 | * Version 1.3.0
|
118 | *
|
119 | * Supports secrets, task recycling.
|
120 | */
|
121 | FargatePlatformVersion["VERSION1_3"] = "1.3.0";
|
122 | /**
|
123 | * Version 1.2.0
|
124 | *
|
125 | * Supports private registries.
|
126 | */
|
127 | FargatePlatformVersion["VERSION1_2"] = "1.2.0";
|
128 | /**
|
129 | * Version 1.1.0
|
130 | *
|
131 | * Supports task metadata, health checks, service discovery.
|
132 | */
|
133 | FargatePlatformVersion["VERSION1_1"] = "1.1.0";
|
134 | /**
|
135 | * Initial release
|
136 | *
|
137 | * Based on Amazon Linux 2017.09.
|
138 | */
|
139 | FargatePlatformVersion["VERSION1_0"] = "1.0.0";
|
140 | })(FargatePlatformVersion = exports.FargatePlatformVersion || (exports.FargatePlatformVersion = {}));
|
141 | const SECRET_JSON_FIELD_UNSUPPORTED_PLATFORM_VERSIONS = [
|
142 | FargatePlatformVersion.VERSION1_0,
|
143 | FargatePlatformVersion.VERSION1_1,
|
144 | FargatePlatformVersion.VERSION1_2,
|
145 | FargatePlatformVersion.VERSION1_3,
|
146 | ];
|
147 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fargate-service.js","sourceRoot":"","sources":["fargate-service.ts"],"names":[],"mappings":";;;;;;AACA,qCAAqC;AACrC,wCAA0C;AAE1C,uDAAqI;AACrI,6EAAwE;AAyFxE;;;;GAIG;AACH,MAAa,cAAe,SAAQ,0BAAW;IAoB7C;;OAEG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;;;;;;;;;;;QAClE,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,mBAAmB,EAAE;YAC7C,MAAM,IAAI,KAAK,CAAC,0EAA0E,CAAC,CAAC;SAC7F;QAED,IAAI,KAAK,CAAC,aAAa,KAAK,SAAS,IAAI,KAAK,CAAC,cAAc,KAAK,SAAS,EAAE;YAC3E,MAAM,IAAI,KAAK,CAAC,+DAA+D,CAAC,CAAC;SAClF;QAED,IAAI,KAAK,CAAC,cAAc,CAAC,yBAAyB;eAC3C,KAAK,CAAC,eAAe;eACrB,+CAA+C,CAAC,QAAQ,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE;YACtF,MAAM,IAAI,KAAK,CAAC,+IAA+I,sBAAsB,CAAC,UAAU,YAAY,CAAC,CAAC;SAC/M;QACD,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,GAAG,KAAK;YACR,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,UAAU,EAAE,yBAAU,CAAC,OAAO;YAC9B,0BAA0B,EAAE,KAAK,CAAC,0BAA0B;YAC5D,oBAAoB,EAAE,KAAK,CAAC,oBAAoB;SACjD,EAAE;YACD,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,WAAW;YAClC,cAAc,EAAE,OAAA,KAAK,CAAC,oBAAoB,0CAAE,IAAI,MAAK,uCAAwB,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,iBAAiB;YAC3I,eAAe,EAAE,KAAK,CAAC,eAAe;SACvC,EAAE,KAAK,CAAC,cAAc,CAAC,CAAC;QAEzB,IAAI,cAAc,CAAC;QACnB,IAAI,KAAK,CAAC,aAAa,KAAK,SAAS,EAAE;YACrC,cAAc,GAAG,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;SACxC;aAAM,IAAI,KAAK,CAAC,cAAc,KAAK,SAAS,EAAE;YAC7C,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;SACvC;QAED,IAAI,CAAC,2CAA2C,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;QAE5H,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;YACtB,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,6DAA6D,CAAC,CAAC,CAAC,CAAC,EAAE;SAC7H,CAAC,CAAC;KACJ;IA3DD;;OAEG;IACI,MAAM,CAAC,qBAAqB,CAAC,KAAgB,EAAE,EAAU,EAAE,iBAAyB;QACzF,MAAM,MAAO,SAAQ,GAAG,CAAC,QAAQ;YAAjC;;gBACkB,eAAU,GAAG,iBAAiB,CAAC;gBAC/B,gBAAW,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,iBAAiB,EAAE,gBAAS,CAAC,mBAAmB,CAAC,CAAC,YAAsB,CAAC;YACtI,CAAC;SAAA;QACD,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KAC9B;IAED;;OAEG;IACI,MAAM,CAAC,4BAA4B,CAAC,KAAgB,EAAE,EAAU,EAAE,KAA+B;;;;;;;;;;QACtG,OAAO,+CAAqB,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;KAChD;;AAlBH,wCA8DC;;;AAED;;;;GAIG;AACH,IAAY,sBA0CX;AA1CD,WAAY,sBAAsB;IAChC;;OAEG;IACH,2CAAiB,CAAA;IAEjB;;;;;;OAMG;IACH,8CAAoB,CAAA;IAEpB;;;;OAIG;IACH,8CAAoB,CAAA;IAEpB;;;;OAIG;IACH,8CAAoB,CAAA;IAEpB;;;;OAIG;IACH,8CAAoB,CAAA;IAEpB;;;;OAIG;IACH,8CAAoB,CAAA;AACtB,CAAC,EA1CW,sBAAsB,GAAtB,8BAAsB,KAAtB,8BAAsB,QA0CjC;AAED,MAAM,+CAA+C,GAAG;IACtD,sBAAsB,CAAC,UAAU;IACjC,sBAAsB,CAAC,UAAU;IACjC,sBAAsB,CAAC,UAAU;IACjC,sBAAsB,CAAC,UAAU;CAClC,CAAC","sourcesContent":["import * as ec2 from '@aws-cdk/aws-ec2';\nimport * as cdk from '@aws-cdk/core';\nimport { ArnFormat } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { BaseService, BaseServiceOptions, DeploymentControllerType, IBaseService, IService, LaunchType } from '../base/base-service';\nimport { fromServiceAtrributes } from '../base/from-service-attributes';\nimport { TaskDefinition } from '../base/task-definition';\nimport { ICluster } from '../cluster';\n\n/**\n * The properties for defining a service using the Fargate launch type.\n */\nexport interface FargateServiceProps 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   *\n   * If true, each task will receive a public IP address.\n   *\n   * @default false\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * The subnets to associate with the service.\n   *\n   * @default - Public subnets if `assignPublicIp` is set, otherwise the first available one of Private, Isolated, Public, in that order.\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, a new security group is created.\n   *\n   * @default - A new security group is created.\n   * @deprecated use securityGroups instead.\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * The security groups to associate with the service. If you do not specify a security group, a new security group is created.\n   *\n   * @default - A new security group is created.\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * The platform version on which to run your service.\n   *\n   * If one is not specified, the LATEST platform version is used by default. For more information, see\n   * [AWS Fargate Platform Versions](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/platform_versions.html)\n   * in the Amazon Elastic Container Service Developer Guide.\n   *\n   * @default Latest\n   */\n  readonly platformVersion?: FargatePlatformVersion;\n}\n\n/**\n * The interface for a service using the Fargate launch type on an ECS cluster.\n */\nexport interface IFargateService extends IService {\n\n}\n\n/**\n * The properties to import from the service using the Fargate launch type.\n */\nexport interface FargateServiceAttributes {\n  /**\n   * The cluster that hosts the service.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The service ARN.\n   *\n   * @default - either this, or {@link serviceName}, is required\n   */\n  readonly serviceArn?: string;\n\n  /**\n   * The name of the service.\n   *\n   * @default - either this, or {@link serviceArn}, is required\n   */\n  readonly serviceName?: string;\n}\n\n/**\n * This creates a service using the Fargate launch type on an ECS cluster.\n *\n * @resource AWS::ECS::Service\n */\nexport class FargateService extends BaseService implements IFargateService {\n\n  /**\n   * Imports from the specified service ARN.\n   */\n  public static fromFargateServiceArn(scope: Construct, id: string, fargateServiceArn: string): IFargateService {\n    class Import extends cdk.Resource implements IFargateService {\n      public readonly serviceArn = fargateServiceArn;\n      public readonly serviceName = cdk.Stack.of(scope).splitArn(fargateServiceArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName as string;\n    }\n    return new Import(scope, id);\n  }\n\n  /**\n   * Imports from the specified service attrributes.\n   */\n  public static fromFargateServiceAttributes(scope: Construct, id: string, attrs: FargateServiceAttributes): IBaseService {\n    return fromServiceAtrributes(scope, id, attrs);\n  }\n\n  /**\n   * Constructs a new instance of the FargateService class.\n   */\n  constructor(scope: Construct, id: string, props: FargateServiceProps) {\n    if (!props.taskDefinition.isFargateCompatible) {\n      throw new Error('Supplied TaskDefinition is not configured for compatibility with Fargate');\n    }\n\n    if (props.securityGroup !== undefined && props.securityGroups !== undefined) {\n      throw new Error('Only one of SecurityGroup or SecurityGroups can be populated.');\n    }\n\n    if (props.taskDefinition.referencesSecretJsonField\n        && props.platformVersion\n        && SECRET_JSON_FIELD_UNSUPPORTED_PLATFORM_VERSIONS.includes(props.platformVersion)) {\n      throw new Error(`The task definition of this service uses at least one container that references a secret JSON field. This feature requires platform version ${FargatePlatformVersion.VERSION1_4} or later.`);\n    }\n    super(scope, id, {\n      ...props,\n      desiredCount: props.desiredCount,\n      launchType: LaunchType.FARGATE,\n      capacityProviderStrategies: props.capacityProviderStrategies,\n      enableECSManagedTags: props.enableECSManagedTags,\n    }, {\n      cluster: props.cluster.clusterName,\n      taskDefinition: props.deploymentController?.type === DeploymentControllerType.EXTERNAL ? undefined : props.taskDefinition.taskDefinitionArn,\n      platformVersion: props.platformVersion,\n    }, props.taskDefinition);\n\n    let securityGroups;\n    if (props.securityGroup !== undefined) {\n      securityGroups = [props.securityGroup];\n    } else if (props.securityGroups !== undefined) {\n      securityGroups = props.securityGroups;\n    }\n\n    this.configureAwsVpcNetworkingWithSecurityGroups(props.cluster.vpc, props.assignPublicIp, props.vpcSubnets, securityGroups);\n\n    this.node.addValidation({\n      validate: () => !this.taskDefinition.defaultContainer ? ['A TaskDefinition must have at least one essential container'] : [],\n    });\n  }\n}\n\n/**\n * The platform version on which to run your service.\n *\n * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/platform_versions.html\n */\nexport enum FargatePlatformVersion {\n  /**\n   * The latest, recommended platform version.\n   */\n  LATEST = 'LATEST',\n\n  /**\n   * Version 1.4.0\n   *\n   * Supports EFS endpoints, CAP_SYS_PTRACE Linux capability,\n   * network performance metrics in CloudWatch Container Insights,\n   * consolidated 20 GB ephemeral volume.\n   */\n  VERSION1_4 = '1.4.0',\n\n  /**\n   * Version 1.3.0\n   *\n   * Supports secrets, task recycling.\n   */\n  VERSION1_3 = '1.3.0',\n\n  /**\n   * Version 1.2.0\n   *\n   * Supports private registries.\n   */\n  VERSION1_2 = '1.2.0',\n\n  /**\n   * Version 1.1.0\n   *\n   * Supports task metadata, health checks, service discovery.\n   */\n  VERSION1_1 = '1.1.0',\n\n  /**\n   * Initial release\n   *\n   * Based on Amazon Linux 2017.09.\n   */\n  VERSION1_0 = '1.0.0',\n}\n\nconst SECRET_JSON_FIELD_UNSUPPORTED_PLATFORM_VERSIONS = [\n  FargatePlatformVersion.VERSION1_0,\n  FargatePlatformVersion.VERSION1_1,\n  FargatePlatformVersion.VERSION1_2,\n  FargatePlatformVersion.VERSION1_3,\n];\n"]} |
\ | No newline at end of file |