@aws-mdaa/ecs-constructs 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,19 @@
1
+ # Construct Overview
2
+
3
+ Opinionated implementation of the Layer 2 CDK Constructs.
4
+
5
+ ## Security/Compliance
6
+
7
+ ### ECS Clusters
8
+ * Enforce Cluster Name
9
+ * Enforces KMS CMK encryption at rest
10
+ * Enforces container insights
11
+ * Enforces CloudWatch logging
12
+
13
+ ### Fargate Services
14
+ * Enforce Fargate Name
15
+ * Enforces non-public IP
16
+
17
+ ### Container Definitions
18
+ * Enforce Definition Name
19
+ * Enforces CloudWatch logging
@@ -0,0 +1,50 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+ import { MdaaConstructProps } from '@aws-mdaa/construct';
6
+ import { IVpc } from 'aws-cdk-lib/aws-ec2';
7
+ import { AddCapacityOptions, CloudMapNamespaceOptions, Cluster } from 'aws-cdk-lib/aws-ecs';
8
+ import { IKey } from 'aws-cdk-lib/aws-kms';
9
+ import { ILogGroup } from 'aws-cdk-lib/aws-logs';
10
+ import { Construct } from 'constructs';
11
+ /**
12
+ * Properties for creating a Compliance ECS cluster
13
+ */
14
+ export interface MdaaECSClusterProps extends MdaaConstructProps {
15
+ readonly clusterName?: string;
16
+ /**
17
+ * Q-ENHANCED-PROPERTY
18
+ * Required VPC for ECS cluster deployment providing network isolation and security controls for containerized applications. Defines the network environment where ECS instances and ENIs will be deployed for secure container networking and connectivity.
19
+ *
20
+ * Use cases: Network isolation; VPC integration; Secure networking; Container connectivity
21
+ *
22
+ * AWS: Amazon VPC for ECS cluster network isolation and secure container deployment
23
+ *
24
+ * Validation: Must be valid IVpc interface; required for ECS cluster network deployment and security
25
+ * * See: https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html
26
+ **/
27
+ readonly vpc: IVpc;
28
+ readonly defaultCloudMapNamespace?: CloudMapNamespaceOptions;
29
+ /**
30
+ * Q-ENHANCED-PROPERTY
31
+ * Optional EC2 capacity configuration for ECS cluster compute resources enabling container hosting and scaling capabilities. Provides EC2-based compute capacity for container workloads with auto-scaling and resource management capabilities.
32
+ *
33
+ * Use cases: EC2 capacity; Container hosting; Compute scaling; Resource management
34
+ *
35
+ * AWS: Amazon EC2 capacity for ECS cluster compute resources and container hosting
36
+ *
37
+ * Validation: Must be valid AddCapacityOptions if provided; enables EC2-based container compute capacity
38
+ * **/
39
+ readonly capacity?: AddCapacityOptions;
40
+ readonly enableFargateCapacityProviders?: boolean;
41
+ readonly kmsKey: IKey;
42
+ readonly logGroup: ILogGroup;
43
+ }
44
+ /**
45
+ * A construct for creating a compliant ECS cluster resource.
46
+ */
47
+ export declare class MdaaECSCluster extends Cluster {
48
+ private static setProps;
49
+ constructor(scope: Construct, id: string, props: MdaaECSClusterProps);
50
+ }
package/lib/cluster.js ADDED
@@ -0,0 +1,53 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+
6
+ "use strict";
7
+ var _a;
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.MdaaECSCluster = void 0;
10
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
11
+
12
+ const construct_1 = require("@aws-mdaa/construct"); //NOSONAR
13
+ const aws_ecs_1 = require("aws-cdk-lib/aws-ecs");
14
+ /**
15
+ * A construct for creating a compliant ECS cluster resource.
16
+ */
17
+ class MdaaECSCluster extends aws_ecs_1.Cluster {
18
+ static setProps(props) {
19
+ const overrideProps = {
20
+ clusterName: props.naming.resourceName(props.clusterName, 255),
21
+ containerInsights: true,
22
+ executeCommandConfiguration: {
23
+ kmsKey: props.kmsKey,
24
+ logConfiguration: {
25
+ cloudWatchEncryptionEnabled: true,
26
+ cloudWatchLogGroup: props.logGroup,
27
+ },
28
+ logging: aws_ecs_1.ExecuteCommandLogging.OVERRIDE,
29
+ },
30
+ };
31
+ const allProps = {
32
+ ...props,
33
+ ...overrideProps,
34
+ };
35
+ return allProps;
36
+ }
37
+ constructor(scope, id, props) {
38
+ super(scope, id, MdaaECSCluster.setProps(props));
39
+ new construct_1.MdaaParamAndOutput(this, {
40
+ ...{
41
+ resourceType: 'cluster',
42
+ resourceId: props.clusterName,
43
+ name: 'arn',
44
+ value: this.clusterArn,
45
+ },
46
+ ...props,
47
+ }, scope);
48
+ }
49
+ }
50
+ exports.MdaaECSCluster = MdaaECSCluster;
51
+ _a = JSII_RTTI_SYMBOL_1;
52
+ MdaaECSCluster[_a] = { fqn: "@aws-mdaa/ecs-constructs.MdaaECSCluster", version: "1.2.0" };
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2x1c3Rlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNsdXN0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7O0dBR0c7QUFFSCxtREFBNkUsQ0FBQyxTQUFTO0FBRXZGLGlEQU02QjtBQXVDN0I7O0dBRUc7QUFDSCxNQUFhLGNBQWUsU0FBUSxpQkFBTztJQUNqQyxNQUFNLENBQUMsUUFBUSxDQUFDLEtBQTBCO1FBQ2hELE1BQU0sYUFBYSxHQUFHO1lBQ3BCLFdBQVcsRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLEdBQUcsQ0FBQztZQUM5RCxpQkFBaUIsRUFBRSxJQUFJO1lBQ3ZCLDJCQUEyQixFQUFFO2dCQUMzQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07Z0JBQ3BCLGdCQUFnQixFQUFFO29CQUNoQiwyQkFBMkIsRUFBRSxJQUFJO29CQUNqQyxrQkFBa0IsRUFBRSxLQUFLLENBQUMsUUFBUTtpQkFDbkM7Z0JBQ0QsT0FBTyxFQUFFLCtCQUFxQixDQUFDLFFBQVE7YUFDeEM7U0FDRixDQUFDO1FBQ0YsTUFBTSxRQUFRLEdBQWlCO1lBQzdCLEdBQUcsS0FBSztZQUNSLEdBQUcsYUFBYTtTQUNqQixDQUFDO1FBQ0YsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztJQUVELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMEI7UUFDbEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsY0FBYyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBRWpELElBQUksOEJBQWtCLENBQ3BCLElBQUksRUFDSjtZQUNFLEdBQUc7Z0JBQ0QsWUFBWSxFQUFFLFNBQVM7Z0JBQ3ZCLFVBQVUsRUFBRSxLQUFLLENBQUMsV0FBVztnQkFDN0IsSUFBSSxFQUFFLEtBQUs7Z0JBQ1gsS0FBSyxFQUFFLElBQUksQ0FBQyxVQUFVO2FBQ3ZCO1lBQ0QsR0FBRyxLQUFLO1NBQ1QsRUFDRCxLQUFLLENBQ04sQ0FBQztJQUNKLENBQUM7O0FBckNILHdDQXNDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qIVxuICogQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuICovXG5cbmltcG9ydCB7IE1kYWFDb25zdHJ1Y3RQcm9wcywgTWRhYVBhcmFtQW5kT3V0cHV0IH0gZnJvbSAnQGF3cy1tZGFhL2NvbnN0cnVjdCc7IC8vTk9TT05BUlxuaW1wb3J0IHsgSVZwYyB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1lYzInO1xuaW1wb3J0IHtcbiAgQWRkQ2FwYWNpdHlPcHRpb25zLFxuICBDbG91ZE1hcE5hbWVzcGFjZU9wdGlvbnMsXG4gIENsdXN0ZXIsXG4gIENsdXN0ZXJQcm9wcyxcbiAgRXhlY3V0ZUNvbW1hbmRMb2dnaW5nLFxufSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcbmltcG9ydCB7IElLZXkgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3Mta21zJztcbmltcG9ydCB7IElMb2dHcm91cCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1sb2dzJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGNyZWF0aW5nIGEgQ29tcGxpYW5jZSBFQ1MgY2x1c3RlclxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1kYWFFQ1NDbHVzdGVyUHJvcHMgZXh0ZW5kcyBNZGFhQ29uc3RydWN0UHJvcHMge1xuICByZWFkb25seSBjbHVzdGVyTmFtZT86IHN0cmluZztcbiAgLyoqXG4gICAqIFEtRU5IQU5DRUQtUFJPUEVSVFlcbiAgICogUmVxdWlyZWQgVlBDIGZvciBFQ1MgY2x1c3RlciBkZXBsb3ltZW50IHByb3ZpZGluZyBuZXR3b3JrIGlzb2xhdGlvbiBhbmQgc2VjdXJpdHkgY29udHJvbHMgZm9yIGNvbnRhaW5lcml6ZWQgYXBwbGljYXRpb25zLiBEZWZpbmVzIHRoZSBuZXR3b3JrIGVudmlyb25tZW50IHdoZXJlIEVDUyBpbnN0YW5jZXMgYW5kIEVOSXMgd2lsbCBiZSBkZXBsb3llZCBmb3Igc2VjdXJlIGNvbnRhaW5lciBuZXR3b3JraW5nIGFuZCBjb25uZWN0aXZpdHkuXG4gICAqXG4gICAqIFVzZSBjYXNlczogTmV0d29yayBpc29sYXRpb247IFZQQyBpbnRlZ3JhdGlvbjsgU2VjdXJlIG5ldHdvcmtpbmc7IENvbnRhaW5lciBjb25uZWN0aXZpdHlcbiAgICpcbiAgICogQVdTOiBBbWF6b24gVlBDIGZvciBFQ1MgY2x1c3RlciBuZXR3b3JrIGlzb2xhdGlvbiBhbmQgc2VjdXJlIGNvbnRhaW5lciBkZXBsb3ltZW50XG4gICAqXG4gICAqIFZhbGlkYXRpb246IE11c3QgYmUgdmFsaWQgSVZwYyBpbnRlcmZhY2U7IHJlcXVpcmVkIGZvciBFQ1MgY2x1c3RlciBuZXR3b3JrIGRlcGxveW1lbnQgYW5kIHNlY3VyaXR5XG4gICAqICAgKiBTZWU6IGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9jZGsvYXBpL3YyL2RvY3MvYXdzLWNkay1saWIuYXdzX2VjMi5JVnBjLmh0bWxcbiAgICoqL1xuICByZWFkb25seSB2cGM6IElWcGM7XG4gIHJlYWRvbmx5IGRlZmF1bHRDbG91ZE1hcE5hbWVzcGFjZT86IENsb3VkTWFwTmFtZXNwYWNlT3B0aW9ucztcbiAgLyoqXG4gICAqIFEtRU5IQU5DRUQtUFJPUEVSVFlcbiAgICogT3B0aW9uYWwgRUMyIGNhcGFjaXR5IGNvbmZpZ3VyYXRpb24gZm9yIEVDUyBjbHVzdGVyIGNvbXB1dGUgcmVzb3VyY2VzIGVuYWJsaW5nIGNvbnRhaW5lciBob3N0aW5nIGFuZCBzY2FsaW5nIGNhcGFiaWxpdGllcy4gUHJvdmlkZXMgRUMyLWJhc2VkIGNvbXB1dGUgY2FwYWNpdHkgZm9yIGNvbnRhaW5lciB3b3JrbG9hZHMgd2l0aCBhdXRvLXNjYWxpbmcgYW5kIHJlc291cmNlIG1hbmFnZW1lbnQgY2FwYWJpbGl0aWVzLlxuICAgKlxuICAgKiBVc2UgY2FzZXM6IEVDMiBjYXBhY2l0eTsgQ29udGFpbmVyIGhvc3Rpbmc7IENvbXB1dGUgc2NhbGluZzsgUmVzb3VyY2UgbWFuYWdlbWVudFxuICAgKlxuICAgKiBBV1M6IEFtYXpvbiBFQzIgY2FwYWNpdHkgZm9yIEVDUyBjbHVzdGVyIGNvbXB1dGUgcmVzb3VyY2VzIGFuZCBjb250YWluZXIgaG9zdGluZ1xuICAgKlxuICAgKiBWYWxpZGF0aW9uOiBNdXN0IGJlIHZhbGlkIEFkZENhcGFjaXR5T3B0aW9ucyBpZiBwcm92aWRlZDsgZW5hYmxlcyBFQzItYmFzZWQgY29udGFpbmVyIGNvbXB1dGUgY2FwYWNpdHlcbiAgICogICAqKi9cbiAgcmVhZG9ubHkgY2FwYWNpdHk/OiBBZGRDYXBhY2l0eU9wdGlvbnM7XG4gIHJlYWRvbmx5IGVuYWJsZUZhcmdhdGVDYXBhY2l0eVByb3ZpZGVycz86IGJvb2xlYW47XG4gIHJlYWRvbmx5IGttc0tleTogSUtleTtcbiAgcmVhZG9ubHkgbG9nR3JvdXA6IElMb2dHcm91cDtcbn1cblxuLyoqXG4gKiBBIGNvbnN0cnVjdCBmb3IgY3JlYXRpbmcgYSBjb21wbGlhbnQgRUNTIGNsdXN0ZXIgcmVzb3VyY2UuXG4gKi9cbmV4cG9ydCBjbGFzcyBNZGFhRUNTQ2x1c3RlciBleHRlbmRzIENsdXN0ZXIge1xuICBwcml2YXRlIHN0YXRpYyBzZXRQcm9wcyhwcm9wczogTWRhYUVDU0NsdXN0ZXJQcm9wcyk6IENsdXN0ZXJQcm9wcyB7XG4gICAgY29uc3Qgb3ZlcnJpZGVQcm9wcyA9IHtcbiAgICAgIGNsdXN0ZXJOYW1lOiBwcm9wcy5uYW1pbmcucmVzb3VyY2VOYW1lKHByb3BzLmNsdXN0ZXJOYW1lLCAyNTUpLFxuICAgICAgY29udGFpbmVySW5zaWdodHM6IHRydWUsXG4gICAgICBleGVjdXRlQ29tbWFuZENvbmZpZ3VyYXRpb246IHtcbiAgICAgICAga21zS2V5OiBwcm9wcy5rbXNLZXksXG4gICAgICAgIGxvZ0NvbmZpZ3VyYXRpb246IHtcbiAgICAgICAgICBjbG91ZFdhdGNoRW5jcnlwdGlvbkVuYWJsZWQ6IHRydWUsXG4gICAgICAgICAgY2xvdWRXYXRjaExvZ0dyb3VwOiBwcm9wcy5sb2dHcm91cCxcbiAgICAgICAgfSxcbiAgICAgICAgbG9nZ2luZzogRXhlY3V0ZUNvbW1hbmRMb2dnaW5nLk9WRVJSSURFLFxuICAgICAgfSxcbiAgICB9O1xuICAgIGNvbnN0IGFsbFByb3BzOiBDbHVzdGVyUHJvcHMgPSB7XG4gICAgICAuLi5wcm9wcyxcbiAgICAgIC4uLm92ZXJyaWRlUHJvcHMsXG4gICAgfTtcbiAgICByZXR1cm4gYWxsUHJvcHM7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogTWRhYUVDU0NsdXN0ZXJQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwgTWRhYUVDU0NsdXN0ZXIuc2V0UHJvcHMocHJvcHMpKTtcblxuICAgIG5ldyBNZGFhUGFyYW1BbmRPdXRwdXQoXG4gICAgICB0aGlzLFxuICAgICAge1xuICAgICAgICAuLi57XG4gICAgICAgICAgcmVzb3VyY2VUeXBlOiAnY2x1c3RlcicsXG4gICAgICAgICAgcmVzb3VyY2VJZDogcHJvcHMuY2x1c3Rlck5hbWUsXG4gICAgICAgICAgbmFtZTogJ2FybicsXG4gICAgICAgICAgdmFsdWU6IHRoaXMuY2x1c3RlckFybixcbiAgICAgICAgfSxcbiAgICAgICAgLi4ucHJvcHMsXG4gICAgICB9LFxuICAgICAgc2NvcGUsXG4gICAgKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,208 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+ import { MdaaConstructProps } from '@aws-mdaa/construct';
6
+ import { Duration } from 'aws-cdk-lib';
7
+ import { ContainerDefinition, ContainerImage, EnvironmentFile, HealthCheck, LinuxParameters, PortMapping, Secret, SystemControl, TaskDefinition, Ulimit } from 'aws-cdk-lib/aws-ecs';
8
+ import { ILogGroup } from 'aws-cdk-lib/aws-logs';
9
+ import { Construct } from 'constructs';
10
+ /**
11
+ * Properties for creating a Compliance ECS containerdefinition
12
+ */
13
+ export interface MdaaECSContainerDefinitionProps extends MdaaConstructProps {
14
+ readonly taskDefinition: TaskDefinition;
15
+ readonly image: ContainerImage;
16
+ readonly containerName?: string;
17
+ /**
18
+ * Q-ENHANCED-PROPERTY
19
+ * Optional command array for container execution overriding the default CMD built into the container image. Provides custom command execution for container startup and application initialization with proper command-line argument handling.
20
+ *
21
+ * Use cases: Custom command execution; Application startup; Command override; Container initialization
22
+ *
23
+ * AWS: Docker container command for custom execution and application startup configuration
24
+ *
25
+ * Validation: Must be array of command strings if provided; overrides container image CMD when specified
26
+ **/
27
+ readonly command?: string[];
28
+ readonly cpu?: number;
29
+ readonly disableNetworking?: boolean;
30
+ readonly dnsSearchDomains?: string[];
31
+ readonly dnsServers?: string[];
32
+ readonly dockerLabels?: {
33
+ [key: string]: string;
34
+ };
35
+ readonly dockerSecurityOptions?: string[];
36
+ readonly entryPoint?: string[];
37
+ /**
38
+ * Q-ENHANCED-PROPERTY
39
+ * Optional environment variables map for container configuration enabling application configuration and runtime parameter passing. Provides environment variables for container applications with secure configuration management and runtime customization.
40
+ *
41
+ * Use cases: Application configuration; Runtime parameters; Environment setup; Configuration management
42
+ *
43
+ * AWS: Container environment variables for application configuration and runtime parameter management
44
+ *
45
+ * Validation: Must be object with string keys and values if provided; enables application configuration
46
+ * **/
47
+ readonly environment?: {
48
+ [key: string]: string;
49
+ };
50
+ readonly environmentFiles?: EnvironmentFile[];
51
+ readonly secrets?: {
52
+ [key: string]: Secret;
53
+ };
54
+ /**
55
+ * Time duration (in seconds) to wait before giving up on resolving dependencies for a container.
56
+ * @default - none
57
+ */
58
+ readonly startTimeout?: Duration;
59
+ /**
60
+ * Time duration (in seconds) to wait before the container is forcefully killed if it doesn't exit normally on its own.
61
+ * @default - none
62
+ */
63
+ readonly stopTimeout?: Duration;
64
+ /**
65
+ * Specifies whether the container is marked essential.
66
+ * If the essential parameter of a container is marked as true, and that container fails
67
+ * or stops for any reason, all other containers that are part of the task are stopped.
68
+ * If the essential parameter of a container is marked as false, then its failure does not
69
+ * affect the rest of the containers in a task. All tasks must have at least one essential container.
70
+ * If this parameter is omitted, a container is assumed to be essential.
71
+ * @default true
72
+ */
73
+ readonly essential?: boolean;
74
+ /**
75
+ * A list of hostnames and IP address mappings to append to the /etc/hosts file on the container.
76
+ * @default - No extra hosts.
77
+ */
78
+ readonly extraHosts?: {
79
+ [name: string]: string;
80
+ };
81
+ /**
82
+ * The health check command and associated configuration parameters for the container.
83
+ * @default - Health check configuration from container.
84
+ */
85
+ readonly healthCheck?: HealthCheck;
86
+ /**
87
+ * The hostname to use for your container.
88
+ * @default - Automatic hostname.
89
+ */
90
+ readonly hostname?: string;
91
+ /**
92
+ * The amount (in MiB) of memory to present to the container.
93
+ * If your container attempts to exceed the allocated memory, the container
94
+ * is terminated.
95
+ * At least one of memoryLimitMiB and memoryReservationMiB is required for non-Fargate services.
96
+ * @default - No memory limit.
97
+ */
98
+ readonly memoryLimitMiB?: number;
99
+ /**
100
+ * The soft limit (in MiB) of memory to reserve for the container.
101
+ * When system memory is under heavy contention, Docker attempts to keep the
102
+ * container memory to this soft limit. However, your container can consume more
103
+ * memory when it needs to, up to either the hard limit specified with the memory
104
+ * parameter (if applicable), or all of the available memory on the container
105
+ * instance, whichever comes first.
106
+ * At least one of memoryLimitMiB and memoryReservationMiB is required for non-Fargate services.
107
+ * @default - No memory reserved.
108
+ */
109
+ readonly memoryReservationMiB?: number;
110
+ /**
111
+ * Specifies whether the container is marked as privileged.
112
+ * When this parameter is true, the container is given elevated privileges on the host container instance (similar to the root user).
113
+ * @default false
114
+ */
115
+ readonly privileged?: boolean;
116
+ /**
117
+ * When this parameter is true, the container is given read-only access to its root file system.
118
+ * @default false
119
+ */
120
+ readonly readonlyRootFilesystem?: boolean;
121
+ /**
122
+ * The user name to use inside the container.
123
+ * @default root
124
+ */
125
+ readonly user?: string;
126
+ /**
127
+ * The working directory in which to run commands inside the container.
128
+ * @default /
129
+ */
130
+ readonly workingDirectory?: string;
131
+ /**
132
+ * Linux-specific modifications that are applied to the container, such as Linux kernel capabilities.
133
+ * For more information see [KernelCapabilities](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_KernelCapabilities.html).
134
+ * @default - No Linux parameters.
135
+ */
136
+ readonly linuxParameters?: LinuxParameters;
137
+ /**
138
+ * The number of GPUs assigned to the container.
139
+ * @default - No GPUs assigned.
140
+ */
141
+ readonly gpuCount?: number;
142
+ /**
143
+ * The port mappings to add to the container definition.
144
+ * @default - No ports are mapped.
145
+ */
146
+ readonly portMappings?: PortMapping[];
147
+ /**
148
+ * The inference accelerators referenced by the container.
149
+ * @default - No inference accelerators assigned.
150
+ */
151
+ readonly inferenceAcceleratorResources?: string[];
152
+ /**
153
+ * A list of namespaced kernel parameters to set in the container.
154
+ * @default - No system controls are set.
155
+ * See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ecs-taskdefinition-systemcontrol.html
156
+ * See: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definition_parameters.html#container_definition_systemcontrols
157
+ */
158
+ readonly systemControls?: SystemControl[];
159
+ /**
160
+ * When this parameter is true, a TTY is allocated. This parameter maps to Tty in the "Create a container section" of the
161
+ * Docker Remote API and the --tty option to `docker run`.
162
+ * @default - false
163
+ * See: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definition_parameters.html#container_definition_pseudoterminal
164
+ */
165
+ readonly pseudoTerminal?: boolean;
166
+ /**
167
+ * An array of ulimits to set in the container.
168
+ */
169
+ readonly ulimits?: Ulimit[];
170
+ /**
171
+ * Prefix for the log streams
172
+ * The awslogs-stream-prefix option allows you to associate a log stream
173
+ * with the specified prefix, the container name, and the ID of the Amazon
174
+ * ECS task to which the container belongs. If you specify a prefix with
175
+ * this option, then the log stream takes the following format:
176
+ * prefix-name/container-name/ecs-task-id
177
+ */
178
+ readonly streamPrefix: string;
179
+ /**
180
+ * The log group to log to
181
+ * @default - A log group is automatically created.
182
+ */
183
+ readonly logGroup: ILogGroup;
184
+ /**
185
+ * This option defines a multiline start pattern in Python strftime format.
186
+ * A log message consists of a line that matches the pattern and any
187
+ * following lines that don’t match the pattern. Thus the matched line is
188
+ * the delimiter between log messages.
189
+ * @default - No multiline matching.
190
+ */
191
+ readonly datetimeFormat?: string;
192
+ /**
193
+ * This option defines a multiline start pattern using a regular expression.
194
+ * A log message consists of a line that matches the pattern and any
195
+ * following lines that don’t match the pattern. Thus the matched line is
196
+ * the delimiter between log messages.
197
+ * This option is ignored if datetimeFormat is also configured.
198
+ * @default - No multiline matching.
199
+ */
200
+ readonly multilinePattern?: string;
201
+ }
202
+ /**
203
+ * A construct for creating a compliant ECS containerdefinition resource.
204
+ */
205
+ export declare class MdaaECSContainerDefinition extends ContainerDefinition {
206
+ private static setProps;
207
+ constructor(scope: Construct, id: string, props: MdaaECSContainerDefinitionProps);
208
+ }
@@ -0,0 +1,71 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+
6
+ "use strict";
7
+ var _a;
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.MdaaECSContainerDefinition = void 0;
10
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
11
+
12
+ const construct_1 = require("@aws-mdaa/construct"); //NOSONAR
13
+ const aws_ecs_1 = require("aws-cdk-lib/aws-ecs");
14
+ const construct_2 = require("@aws-mdaa/construct"); //NOSONAR
15
+ /**
16
+ * A construct for creating a compliant ECS containerdefinition resource.
17
+ */
18
+ class MdaaECSContainerDefinition extends aws_ecs_1.ContainerDefinition {
19
+ static setProps(props) {
20
+ const overrideProps = {
21
+ containerName: props.naming.resourceName(props.containerName, 255),
22
+ logging: aws_ecs_1.LogDriver.awsLogs({
23
+ logGroup: props.logGroup,
24
+ streamPrefix: props.streamPrefix,
25
+ datetimeFormat: props.datetimeFormat,
26
+ multilinePattern: props.multilinePattern,
27
+ }),
28
+ };
29
+ const allProps = {
30
+ ...props,
31
+ ...overrideProps,
32
+ };
33
+ return allProps;
34
+ }
35
+ constructor(scope, id, props) {
36
+ super(scope, id, MdaaECSContainerDefinition.setProps(props));
37
+ if (this.taskDefinition.executionRole) {
38
+ construct_2.MdaaNagSuppressions.addCodeResourceSuppressions(this.taskDefinition.executionRole, [
39
+ {
40
+ id: 'AwsSolutions-IAM5',
41
+ reason: 'Access limited to Log Group. Log Stream name not known at deployment time.',
42
+ },
43
+ {
44
+ id: 'NIST.800.53.R5-IAMNoInlinePolicy',
45
+ reason: 'Inline policy is specific to task logging and is appropriate.',
46
+ },
47
+ {
48
+ id: 'HIPAA.Security-IAMNoInlinePolicy',
49
+ reason: 'Inline policy is specific to task logging and is appropriate.',
50
+ },
51
+ {
52
+ id: 'PCI.DSS.321-IAMNoInlinePolicy',
53
+ reason: 'Inline policy is specific to task logging and is appropriate.',
54
+ },
55
+ ], true);
56
+ }
57
+ new construct_1.MdaaParamAndOutput(this, {
58
+ ...{
59
+ resourceType: 'containerdefinition',
60
+ resourceId: props.containerName,
61
+ name: 'name',
62
+ value: this.containerName,
63
+ },
64
+ ...props,
65
+ }, scope);
66
+ }
67
+ }
68
+ exports.MdaaECSContainerDefinition = MdaaECSContainerDefinition;
69
+ _a = JSII_RTTI_SYMBOL_1;
70
+ MdaaECSContainerDefinition[_a] = { fqn: "@aws-mdaa/ecs-constructs.MdaaECSContainerDefinition", version: "1.2.0" };
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container-definition.js","sourceRoot":"","sources":["container-definition.ts"],"names":[],"mappings":";;;;;AAAA;;;GAGG;AAEH,mDAA6E,CAAC,SAAS;AAEvF,iDAa6B;AAE7B,mDAA0D,CAAC,SAAS;AAwMpE;;GAEG;AACH,MAAa,0BAA2B,SAAQ,6BAAmB;IACzD,MAAM,CAAC,QAAQ,CAAC,KAAsC;QAC5D,MAAM,aAAa,GAAG;YACpB,aAAa,EAAE,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,aAAa,EAAE,GAAG,CAAC;YAClE,OAAO,EAAE,mBAAS,CAAC,OAAO,CAAC;gBACzB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,YAAY,EAAE,KAAK,CAAC,YAAY;gBAChC,cAAc,EAAE,KAAK,CAAC,cAAc;gBACpC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;aACzC,CAAC;SACH,CAAC;QACF,MAAM,QAAQ,GAA6B;YACzC,GAAG,KAAK;YACR,GAAG,aAAa;SACjB,CAAC;QACF,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAsC;QAC9E,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,0BAA0B,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAE7D,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;YACtC,+BAAmB,CAAC,2BAA2B,CAC7C,IAAI,CAAC,cAAc,CAAC,aAAa,EACjC;gBACE;oBACE,EAAE,EAAE,mBAAmB;oBACvB,MAAM,EAAE,4EAA4E;iBACrF;gBACD;oBACE,EAAE,EAAE,kCAAkC;oBACtC,MAAM,EAAE,+DAA+D;iBACxE;gBACD;oBACE,EAAE,EAAE,kCAAkC;oBACtC,MAAM,EAAE,+DAA+D;iBACxE;gBACD;oBACE,EAAE,EAAE,+BAA+B;oBACnC,MAAM,EAAE,+DAA+D;iBACxE;aACF,EACD,IAAI,CACL,CAAC;QACJ,CAAC;QAED,IAAI,8BAAkB,CACpB,IAAI,EACJ;YACE,GAAG;gBACD,YAAY,EAAE,qBAAqB;gBACnC,UAAU,EAAE,KAAK,CAAC,aAAa;gBAC/B,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,IAAI,CAAC,aAAa;aAC1B;YACD,GAAG,KAAK;SACT,EACD,KAAK,CACN,CAAC;IACJ,CAAC;;AA3DH,gEA4DC","sourcesContent":["/*!\n * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { MdaaConstructProps, MdaaParamAndOutput } from '@aws-mdaa/construct'; //NOSONAR\nimport { Duration } from 'aws-cdk-lib';\nimport {\n  ContainerDefinition,\n  ContainerDefinitionProps,\n  ContainerImage,\n  EnvironmentFile,\n  HealthCheck,\n  LinuxParameters,\n  LogDriver,\n  PortMapping,\n  Secret,\n  SystemControl,\n  TaskDefinition,\n  Ulimit,\n} from 'aws-cdk-lib/aws-ecs';\nimport { ILogGroup } from 'aws-cdk-lib/aws-logs';\nimport { MdaaNagSuppressions } from '@aws-mdaa/construct'; //NOSONAR\nimport { Construct } from 'constructs';\n\n/**\n * Properties for creating a Compliance ECS containerdefinition\n */\nexport interface MdaaECSContainerDefinitionProps extends MdaaConstructProps {\n  readonly taskDefinition: TaskDefinition;\n  readonly image: ContainerImage;\n  readonly containerName?: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional command array for container execution overriding the default CMD built into the container image. Provides custom command execution for container startup and application initialization with proper command-line argument handling.\n   *\n   * Use cases: Custom command execution; Application startup; Command override; Container initialization\n   *\n   * AWS: Docker container command for custom execution and application startup configuration\n   *\n   * Validation: Must be array of command strings if provided; overrides container image CMD when specified\n   **/\n  readonly command?: string[];\n  readonly cpu?: number;\n  readonly disableNetworking?: boolean;\n  readonly dnsSearchDomains?: string[];\n  readonly dnsServers?: string[];\n  readonly dockerLabels?: {\n    [key: string]: string;\n  };\n  readonly dockerSecurityOptions?: string[];\n  readonly entryPoint?: string[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional environment variables map for container configuration enabling application configuration and runtime parameter passing. Provides environment variables for container applications with secure configuration management and runtime customization.\n   *\n   * Use cases: Application configuration; Runtime parameters; Environment setup; Configuration management\n   *\n   * AWS: Container environment variables for application configuration and runtime parameter management\n   *\n   * Validation: Must be object with string keys and values if provided; enables application configuration\n   *   **/\n  readonly environment?: {\n    [key: string]: string;\n  };\n  readonly environmentFiles?: EnvironmentFile[];\n  readonly secrets?: {\n    [key: string]: Secret;\n  };\n  /**\n   * Time duration (in seconds) to wait before giving up on resolving dependencies for a container.\n   * @default - none\n   */\n  readonly startTimeout?: Duration;\n  /**\n   * Time duration (in seconds) to wait before the container is forcefully killed if it doesn't exit normally on its own.\n   * @default - none\n   */\n  readonly stopTimeout?: Duration;\n  /**\n   * Specifies whether the container is marked essential.\n   * If the essential parameter of a container is marked as true, and that container fails\n   * or stops for any reason, all other containers that are part of the task are stopped.\n   * If the essential parameter of a container is marked as false, then its failure does not\n   * affect the rest of the containers in a task. All tasks must have at least one essential container.\n   * If this parameter is omitted, a container is assumed to be essential.\n   * @default true\n   */\n  readonly essential?: boolean;\n  /**\n   * A list of hostnames and IP address mappings to append to the /etc/hosts file on the container.\n   * @default - No extra hosts.\n   */\n  readonly extraHosts?: {\n    [name: string]: string;\n  };\n  /**\n   * The health check command and associated configuration parameters for the container.\n   * @default - Health check configuration from container.\n   */\n  readonly healthCheck?: HealthCheck;\n  /**\n   * The hostname to use for your container.\n   * @default - Automatic hostname.\n   */\n  readonly hostname?: string;\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   * If your container attempts to exceed the allocated memory, the container\n   * is terminated.\n   * At least one of memoryLimitMiB and memoryReservationMiB is required for non-Fargate services.\n   * @default - No memory limit.\n   */\n  readonly memoryLimitMiB?: number;\n  /**\n   * The soft limit (in MiB) of memory to reserve for the container.\n   * When system memory is under heavy contention, Docker attempts to keep the\n   * container memory to this soft limit. However, your container can consume more\n   * memory when it needs to, up to either the hard limit specified with the memory\n   * parameter (if applicable), or all of the available memory on the container\n   * instance, whichever comes first.\n   * At least one of memoryLimitMiB and memoryReservationMiB is required for non-Fargate services.\n   * @default - No memory reserved.\n   */\n  readonly memoryReservationMiB?: number;\n  /**\n   * Specifies whether the container is marked as privileged.\n   * When this parameter is true, the container is given elevated privileges on the host container instance (similar to the root user).\n   * @default false\n   */\n  readonly privileged?: boolean;\n  /**\n   * When this parameter is true, the container is given read-only access to its root file system.\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n  /**\n   * The user name to use inside the container.\n   * @default root\n   */\n  readonly user?: string;\n  /**\n   * The working directory in which to run commands inside the container.\n   * @default /\n   */\n  readonly workingDirectory?: string;\n  /**\n   * Linux-specific modifications that are applied to the container, such as Linux kernel capabilities.\n   * For more information see [KernelCapabilities](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_KernelCapabilities.html).\n   * @default - No Linux parameters.\n   */\n  readonly linuxParameters?: LinuxParameters;\n  /**\n   * The number of GPUs assigned to the container.\n   * @default - No GPUs assigned.\n   */\n  readonly gpuCount?: number;\n  /**\n   * The port mappings to add to the container definition.\n   * @default - No ports are mapped.\n   */\n  readonly portMappings?: PortMapping[];\n  /**\n   * The inference accelerators referenced by the container.\n   * @default - No inference accelerators assigned.\n   */\n  readonly inferenceAcceleratorResources?: string[];\n  /**\n   * A list of namespaced kernel parameters to set in the container.\n   * @default - No system controls are set.\n   * See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ecs-taskdefinition-systemcontrol.html\n   * See: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definition_parameters.html#container_definition_systemcontrols\n   */\n  readonly systemControls?: SystemControl[];\n  /**\n   * When this parameter is true, a TTY is allocated. This parameter maps to Tty in the \"Create a container section\" of the\n   * Docker Remote API and the --tty option to `docker run`.\n   * @default - false\n   * See: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definition_parameters.html#container_definition_pseudoterminal\n   */\n  readonly pseudoTerminal?: boolean;\n  /**\n   * An array of ulimits to set in the container.\n   */\n  readonly ulimits?: Ulimit[];\n\n  /**\n   * Prefix for the log streams\n   * The awslogs-stream-prefix option allows you to associate a log stream\n   * with the specified prefix, the container name, and the ID of the Amazon\n   * ECS task to which the container belongs. If you specify a prefix with\n   * this option, then the log stream takes the following format:\n   *     prefix-name/container-name/ecs-task-id\n   */\n  readonly streamPrefix: string;\n\n  /**\n   * The log group to log to\n   * @default - A log group is automatically created.\n   */\n  readonly logGroup: ILogGroup;\n\n  /**\n   * This option defines a multiline start pattern in Python strftime format.\n   * A log message consists of a line that matches the pattern and any\n   * following lines that don’t match the pattern. Thus the matched line is\n   * the delimiter between log messages.\n   * @default - No multiline matching.\n   */\n  readonly datetimeFormat?: string;\n\n  /**\n   * This option defines a multiline start pattern using a regular expression.\n   * A log message consists of a line that matches the pattern and any\n   * following lines that don’t match the pattern. Thus the matched line is\n   * the delimiter between log messages.\n   * This option is ignored if datetimeFormat is also configured.\n   * @default - No multiline matching.\n   */\n  readonly multilinePattern?: string;\n}\n\n/**\n * A construct for creating a compliant ECS containerdefinition resource.\n */\nexport class MdaaECSContainerDefinition extends ContainerDefinition {\n  private static setProps(props: MdaaECSContainerDefinitionProps): ContainerDefinitionProps {\n    const overrideProps = {\n      containerName: props.naming.resourceName(props.containerName, 255),\n      logging: LogDriver.awsLogs({\n        logGroup: props.logGroup,\n        streamPrefix: props.streamPrefix,\n        datetimeFormat: props.datetimeFormat,\n        multilinePattern: props.multilinePattern,\n      }),\n    };\n    const allProps: ContainerDefinitionProps = {\n      ...props,\n      ...overrideProps,\n    };\n    return allProps;\n  }\n\n  constructor(scope: Construct, id: string, props: MdaaECSContainerDefinitionProps) {\n    super(scope, id, MdaaECSContainerDefinition.setProps(props));\n\n    if (this.taskDefinition.executionRole) {\n      MdaaNagSuppressions.addCodeResourceSuppressions(\n        this.taskDefinition.executionRole,\n        [\n          {\n            id: 'AwsSolutions-IAM5',\n            reason: 'Access limited to Log Group. Log Stream name not known at deployment time.',\n          },\n          {\n            id: 'NIST.800.53.R5-IAMNoInlinePolicy',\n            reason: 'Inline policy is specific to task logging and is appropriate.',\n          },\n          {\n            id: 'HIPAA.Security-IAMNoInlinePolicy',\n            reason: 'Inline policy is specific to task logging and is appropriate.',\n          },\n          {\n            id: 'PCI.DSS.321-IAMNoInlinePolicy',\n            reason: 'Inline policy is specific to task logging and is appropriate.',\n          },\n        ],\n        true,\n      );\n    }\n\n    new MdaaParamAndOutput(\n      this,\n      {\n        ...{\n          resourceType: 'containerdefinition',\n          resourceId: props.containerName,\n          name: 'name',\n          value: this.containerName,\n        },\n        ...props,\n      },\n      scope,\n    );\n  }\n}\n"]}
@@ -0,0 +1,69 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+ import { MdaaConstructProps } from '@aws-mdaa/construct';
6
+ import { Duration } from 'aws-cdk-lib';
7
+ import { ISecurityGroup, ISubnet } from 'aws-cdk-lib/aws-ec2';
8
+ import { CapacityProviderStrategy, CloudMapOptions, DeploymentCircuitBreaker, DeploymentController, FargateService, ICluster, PropagatedTagSource, ServiceConnectProps, TaskDefinition } from 'aws-cdk-lib/aws-ecs';
9
+ import { Construct } from 'constructs';
10
+ /**
11
+ * Properties for creating a Compliance ECS fargateservice
12
+ */
13
+ export interface MdaaECSFargateServiceProps extends MdaaConstructProps {
14
+ readonly taskDefinition: TaskDefinition;
15
+ /**
16
+ * Q-ENHANCED-PROPERTY
17
+ * Required array of subnets for Fargate service network placement enabling VPC connectivity and network isolation. Defines the network subnets where Fargate tasks will be deployed for secure networking and connectivity within the VPC environment.
18
+ *
19
+ * Use cases: Network placement; VPC connectivity; Subnet distribution; Network isolation
20
+ *
21
+ * AWS: VPC subnets for ECS Fargate service network placement and connectivity
22
+ *
23
+ * Validation: Must be array of valid ISubnet interfaces; required for Fargate service network placement
24
+ * * See: https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.ISubnet.html
25
+ **/
26
+ readonly subnets: ISubnet[];
27
+ /**
28
+ * Q-ENHANCED-PROPERTY
29
+ * Required array of security groups for Fargate service network access control defining inbound and outbound traffic rules. Provides network-level security controls for Fargate tasks ensuring secure communication and access control within the VPC.
30
+ *
31
+ * Use cases: Network security; Access control; Traffic filtering; Security group management
32
+ *
33
+ * AWS: VPC security groups for ECS Fargate service network security and access control
34
+ *
35
+ * Validation: Must be array of valid ISecurityGroup interfaces; required for network security and access control
36
+ * * See: https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.ISecurityGroup.html
37
+ **/
38
+ readonly securityGroups: ISecurityGroup[];
39
+ readonly cluster: ICluster;
40
+ readonly desiredCount?: number;
41
+ readonly serviceName?: string;
42
+ readonly maxHealthyPercent?: number;
43
+ readonly minHealthyPercent?: number;
44
+ readonly healthCheckGracePeriod?: Duration;
45
+ readonly cloudMapOptions?: CloudMapOptions;
46
+ readonly propagateTags: PropagatedTagSource.TASK_DEFINITION | PropagatedTagSource.SERVICE;
47
+ readonly enableECSManagedTags?: boolean;
48
+ readonly deploymentController?: DeploymentController;
49
+ readonly circuitBreaker?: DeploymentCircuitBreaker;
50
+ readonly capacityProviderStrategies?: CapacityProviderStrategy[];
51
+ /**
52
+ * Whether to enable the ability to execute into a container
53
+ * @default - undefined
54
+ */
55
+ readonly enableExecuteCommand?: boolean;
56
+ /**
57
+ * Configuration for Service Connect.
58
+ * @default No ports are advertised via Service Connect on this service, and the service
59
+ * cannot make requests to other services via Service Connect.
60
+ */
61
+ readonly serviceConnectConfiguration?: ServiceConnectProps;
62
+ }
63
+ /**
64
+ * A construct for creating a compliant ECS fargateservice resource.
65
+ */
66
+ export declare class MdaaECSFargateService extends FargateService {
67
+ private static setProps;
68
+ constructor(scope: Construct, id: string, props: MdaaECSFargateServiceProps);
69
+ }
@@ -0,0 +1,58 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+
6
+ "use strict";
7
+ var _a;
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.MdaaECSFargateService = void 0;
10
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
11
+
12
+ const construct_1 = require("@aws-mdaa/construct"); //NOSONAR
13
+ const aws_ecs_1 = require("aws-cdk-lib/aws-ecs");
14
+ /**
15
+ * A construct for creating a compliant ECS fargateservice resource.
16
+ */
17
+ class MdaaECSFargateService extends aws_ecs_1.FargateService {
18
+ static setProps(props) {
19
+ const overrideProps = {
20
+ serviceName: props.naming.resourceName(props.serviceName, 255),
21
+ assignPublicIp: false,
22
+ platformVersion: aws_ecs_1.FargatePlatformVersion.LATEST,
23
+ vpcSubnets: {
24
+ subnets: props.subnets,
25
+ },
26
+ };
27
+ const allProps = {
28
+ ...props,
29
+ ...overrideProps,
30
+ };
31
+ return allProps;
32
+ }
33
+ constructor(scope, id, props) {
34
+ super(scope, id, MdaaECSFargateService.setProps(props));
35
+ new construct_1.MdaaParamAndOutput(this, {
36
+ ...{
37
+ resourceType: 'fargateservice',
38
+ resourceId: props.serviceName,
39
+ name: 'arn',
40
+ value: this.serviceArn,
41
+ },
42
+ ...props,
43
+ }, scope);
44
+ new construct_1.MdaaParamAndOutput(this, {
45
+ ...{
46
+ resourceType: 'fargateservice',
47
+ resourceId: props.serviceName,
48
+ name: 'name',
49
+ value: this.serviceName,
50
+ },
51
+ ...props,
52
+ }, scope);
53
+ }
54
+ }
55
+ exports.MdaaECSFargateService = MdaaECSFargateService;
56
+ _a = JSII_RTTI_SYMBOL_1;
57
+ MdaaECSFargateService[_a] = { fqn: "@aws-mdaa/ecs-constructs.MdaaECSFargateService", version: "1.2.0" };
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFyZ2F0ZS1zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZmFyZ2F0ZS1zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7OztHQUdHO0FBRUgsbURBQTZFLENBQUMsU0FBUztBQUd2RixpREFZNkI7QUF5RDdCOztHQUVHO0FBQ0gsTUFBYSxxQkFBc0IsU0FBUSx3QkFBYztJQUMvQyxNQUFNLENBQUMsUUFBUSxDQUFDLEtBQWlDO1FBQ3ZELE1BQU0sYUFBYSxHQUFHO1lBQ3BCLFdBQVcsRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLEdBQUcsQ0FBQztZQUM5RCxjQUFjLEVBQUUsS0FBSztZQUNyQixlQUFlLEVBQUUsZ0NBQXNCLENBQUMsTUFBTTtZQUM5QyxVQUFVLEVBQUU7Z0JBQ1YsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO2FBQ3ZCO1NBQ0YsQ0FBQztRQUNGLE1BQU0sUUFBUSxHQUF3QjtZQUNwQyxHQUFHLEtBQUs7WUFDUixHQUFHLGFBQWE7U0FDakIsQ0FBQztRQUNGLE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7SUFFRCxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQWlDO1FBQ3pFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLHFCQUFxQixDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBRXhELElBQUksOEJBQWtCLENBQ3BCLElBQUksRUFDSjtZQUNFLEdBQUc7Z0JBQ0QsWUFBWSxFQUFFLGdCQUFnQjtnQkFDOUIsVUFBVSxFQUFFLEtBQUssQ0FBQyxXQUFXO2dCQUM3QixJQUFJLEVBQUUsS0FBSztnQkFDWCxLQUFLLEVBQUUsSUFBSSxDQUFDLFVBQVU7YUFDdkI7WUFDRCxHQUFHLEtBQUs7U0FDVCxFQUNELEtBQUssQ0FDTixDQUFDO1FBQ0YsSUFBSSw4QkFBa0IsQ0FDcEIsSUFBSSxFQUNKO1lBQ0UsR0FBRztnQkFDRCxZQUFZLEVBQUUsZ0JBQWdCO2dCQUM5QixVQUFVLEVBQUUsS0FBSyxDQUFDLFdBQVc7Z0JBQzdCLElBQUksRUFBRSxNQUFNO2dCQUNaLEtBQUssRUFBRSxJQUFJLENBQUMsV0FBVzthQUN4QjtZQUNELEdBQUcsS0FBSztTQUNULEVBQ0QsS0FBSyxDQUNOLENBQUM7SUFDSixDQUFDOztBQTlDSCxzREErQ0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKiFcbiAqIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICogU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbiAqL1xuXG5pbXBvcnQgeyBNZGFhQ29uc3RydWN0UHJvcHMsIE1kYWFQYXJhbUFuZE91dHB1dCB9IGZyb20gJ0Bhd3MtbWRhYS9jb25zdHJ1Y3QnOyAvL05PU09OQVJcbmltcG9ydCB7IER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgSVNlY3VyaXR5R3JvdXAsIElTdWJuZXQgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7XG4gIENhcGFjaXR5UHJvdmlkZXJTdHJhdGVneSxcbiAgQ2xvdWRNYXBPcHRpb25zLFxuICBEZXBsb3ltZW50Q2lyY3VpdEJyZWFrZXIsXG4gIERlcGxveW1lbnRDb250cm9sbGVyLFxuICBGYXJnYXRlUGxhdGZvcm1WZXJzaW9uLFxuICBGYXJnYXRlU2VydmljZSxcbiAgRmFyZ2F0ZVNlcnZpY2VQcm9wcyxcbiAgSUNsdXN0ZXIsXG4gIFByb3BhZ2F0ZWRUYWdTb3VyY2UsXG4gIFNlcnZpY2VDb25uZWN0UHJvcHMsXG4gIFRhc2tEZWZpbml0aW9uLFxufSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGNyZWF0aW5nIGEgQ29tcGxpYW5jZSBFQ1MgZmFyZ2F0ZXNlcnZpY2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNZGFhRUNTRmFyZ2F0ZVNlcnZpY2VQcm9wcyBleHRlbmRzIE1kYWFDb25zdHJ1Y3RQcm9wcyB7XG4gIHJlYWRvbmx5IHRhc2tEZWZpbml0aW9uOiBUYXNrRGVmaW5pdGlvbjtcbiAgLyoqXG4gICAqIFEtRU5IQU5DRUQtUFJPUEVSVFlcbiAgICogUmVxdWlyZWQgYXJyYXkgb2Ygc3VibmV0cyBmb3IgRmFyZ2F0ZSBzZXJ2aWNlIG5ldHdvcmsgcGxhY2VtZW50IGVuYWJsaW5nIFZQQyBjb25uZWN0aXZpdHkgYW5kIG5ldHdvcmsgaXNvbGF0aW9uLiBEZWZpbmVzIHRoZSBuZXR3b3JrIHN1Ym5ldHMgd2hlcmUgRmFyZ2F0ZSB0YXNrcyB3aWxsIGJlIGRlcGxveWVkIGZvciBzZWN1cmUgbmV0d29ya2luZyBhbmQgY29ubmVjdGl2aXR5IHdpdGhpbiB0aGUgVlBDIGVudmlyb25tZW50LlxuICAgKlxuICAgKiBVc2UgY2FzZXM6IE5ldHdvcmsgcGxhY2VtZW50OyBWUEMgY29ubmVjdGl2aXR5OyBTdWJuZXQgZGlzdHJpYnV0aW9uOyBOZXR3b3JrIGlzb2xhdGlvblxuICAgKlxuICAgKiBBV1M6IFZQQyBzdWJuZXRzIGZvciBFQ1MgRmFyZ2F0ZSBzZXJ2aWNlIG5ldHdvcmsgcGxhY2VtZW50IGFuZCBjb25uZWN0aXZpdHlcbiAgICpcbiAgICogVmFsaWRhdGlvbjogTXVzdCBiZSBhcnJheSBvZiB2YWxpZCBJU3VibmV0IGludGVyZmFjZXM7IHJlcXVpcmVkIGZvciBGYXJnYXRlIHNlcnZpY2UgbmV0d29yayBwbGFjZW1lbnRcbiAgICogICAqIFNlZTogaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2Nkay9hcGkvdjIvZG9jcy9hd3MtY2RrLWxpYi5hd3NfZWMyLklTdWJuZXQuaHRtbFxuICAgKiovXG4gIHJlYWRvbmx5IHN1Ym5ldHM6IElTdWJuZXRbXTtcbiAgLyoqXG4gICAqIFEtRU5IQU5DRUQtUFJPUEVSVFlcbiAgICogUmVxdWlyZWQgYXJyYXkgb2Ygc2VjdXJpdHkgZ3JvdXBzIGZvciBGYXJnYXRlIHNlcnZpY2UgbmV0d29yayBhY2Nlc3MgY29udHJvbCBkZWZpbmluZyBpbmJvdW5kIGFuZCBvdXRib3VuZCB0cmFmZmljIHJ1bGVzLiBQcm92aWRlcyBuZXR3b3JrLWxldmVsIHNlY3VyaXR5IGNvbnRyb2xzIGZvciBGYXJnYXRlIHRhc2tzIGVuc3VyaW5nIHNlY3VyZSBjb21tdW5pY2F0aW9uIGFuZCBhY2Nlc3MgY29udHJvbCB3aXRoaW4gdGhlIFZQQy5cbiAgICpcbiAgICogVXNlIGNhc2VzOiBOZXR3b3JrIHNlY3VyaXR5OyBBY2Nlc3MgY29udHJvbDsgVHJhZmZpYyBmaWx0ZXJpbmc7IFNlY3VyaXR5IGdyb3VwIG1hbmFnZW1lbnRcbiAgICpcbiAgICogQVdTOiBWUEMgc2VjdXJpdHkgZ3JvdXBzIGZvciBFQ1MgRmFyZ2F0ZSBzZXJ2aWNlIG5ldHdvcmsgc2VjdXJpdHkgYW5kIGFjY2VzcyBjb250cm9sXG4gICAqXG4gICAqIFZhbGlkYXRpb246IE11c3QgYmUgYXJyYXkgb2YgdmFsaWQgSVNlY3VyaXR5R3JvdXAgaW50ZXJmYWNlczsgcmVxdWlyZWQgZm9yIG5ldHdvcmsgc2VjdXJpdHkgYW5kIGFjY2VzcyBjb250cm9sXG4gICAqICAgKiBTZWU6IGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9jZGsvYXBpL3YyL2RvY3MvYXdzLWNkay1saWIuYXdzX2VjMi5JU2VjdXJpdHlHcm91cC5odG1sXG4gICAqKi9cbiAgcmVhZG9ubHkgc2VjdXJpdHlHcm91cHM6IElTZWN1cml0eUdyb3VwW107XG4gIHJlYWRvbmx5IGNsdXN0ZXI6IElDbHVzdGVyO1xuICByZWFkb25seSBkZXNpcmVkQ291bnQ/OiBudW1iZXI7XG4gIHJlYWRvbmx5IHNlcnZpY2VOYW1lPzogc3RyaW5nO1xuICByZWFkb25seSBtYXhIZWFsdGh5UGVyY2VudD86IG51bWJlcjtcbiAgcmVhZG9ubHkgbWluSGVhbHRoeVBlcmNlbnQ/OiBudW1iZXI7XG4gIHJlYWRvbmx5IGhlYWx0aENoZWNrR3JhY2VQZXJpb2Q/OiBEdXJhdGlvbjtcbiAgcmVhZG9ubHkgY2xvdWRNYXBPcHRpb25zPzogQ2xvdWRNYXBPcHRpb25zO1xuICByZWFkb25seSBwcm9wYWdhdGVUYWdzOiBQcm9wYWdhdGVkVGFnU291cmNlLlRBU0tfREVGSU5JVElPTiB8IFByb3BhZ2F0ZWRUYWdTb3VyY2UuU0VSVklDRTtcbiAgcmVhZG9ubHkgZW5hYmxlRUNTTWFuYWdlZFRhZ3M/OiBib29sZWFuO1xuICByZWFkb25seSBkZXBsb3ltZW50Q29udHJvbGxlcj86IERlcGxveW1lbnRDb250cm9sbGVyO1xuICByZWFkb25seSBjaXJjdWl0QnJlYWtlcj86IERlcGxveW1lbnRDaXJjdWl0QnJlYWtlcjtcbiAgcmVhZG9ubHkgY2FwYWNpdHlQcm92aWRlclN0cmF0ZWdpZXM/OiBDYXBhY2l0eVByb3ZpZGVyU3RyYXRlZ3lbXTtcbiAgLyoqXG4gICAqIFdoZXRoZXIgdG8gZW5hYmxlIHRoZSBhYmlsaXR5IHRvIGV4ZWN1dGUgaW50byBhIGNvbnRhaW5lclxuICAgKiAgQGRlZmF1bHQgLSB1bmRlZmluZWRcbiAgICovXG4gIHJlYWRvbmx5IGVuYWJsZUV4ZWN1dGVDb21tYW5kPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIENvbmZpZ3VyYXRpb24gZm9yIFNlcnZpY2UgQ29ubmVjdC5cbiAgICogQGRlZmF1bHQgTm8gcG9ydHMgYXJlIGFkdmVydGlzZWQgdmlhIFNlcnZpY2UgQ29ubmVjdCBvbiB0aGlzIHNlcnZpY2UsIGFuZCB0aGUgc2VydmljZVxuICAgKiBjYW5ub3QgbWFrZSByZXF1ZXN0cyB0byBvdGhlciBzZXJ2aWNlcyB2aWEgU2VydmljZSBDb25uZWN0LlxuICAgKi9cbiAgcmVhZG9ubHkgc2VydmljZUNvbm5lY3RDb25maWd1cmF0aW9uPzogU2VydmljZUNvbm5lY3RQcm9wcztcbn1cblxuLyoqXG4gKiBBIGNvbnN0cnVjdCBmb3IgY3JlYXRpbmcgYSBjb21wbGlhbnQgRUNTIGZhcmdhdGVzZXJ2aWNlIHJlc291cmNlLlxuICovXG5leHBvcnQgY2xhc3MgTWRhYUVDU0ZhcmdhdGVTZXJ2aWNlIGV4dGVuZHMgRmFyZ2F0ZVNlcnZpY2Uge1xuICBwcml2YXRlIHN0YXRpYyBzZXRQcm9wcyhwcm9wczogTWRhYUVDU0ZhcmdhdGVTZXJ2aWNlUHJvcHMpOiBGYXJnYXRlU2VydmljZVByb3BzIHtcbiAgICBjb25zdCBvdmVycmlkZVByb3BzID0ge1xuICAgICAgc2VydmljZU5hbWU6IHByb3BzLm5hbWluZy5yZXNvdXJjZU5hbWUocHJvcHMuc2VydmljZU5hbWUsIDI1NSksXG4gICAgICBhc3NpZ25QdWJsaWNJcDogZmFsc2UsXG4gICAgICBwbGF0Zm9ybVZlcnNpb246IEZhcmdhdGVQbGF0Zm9ybVZlcnNpb24uTEFURVNULFxuICAgICAgdnBjU3VibmV0czoge1xuICAgICAgICBzdWJuZXRzOiBwcm9wcy5zdWJuZXRzLFxuICAgICAgfSxcbiAgICB9O1xuICAgIGNvbnN0IGFsbFByb3BzOiBGYXJnYXRlU2VydmljZVByb3BzID0ge1xuICAgICAgLi4ucHJvcHMsXG4gICAgICAuLi5vdmVycmlkZVByb3BzLFxuICAgIH07XG4gICAgcmV0dXJuIGFsbFByb3BzO1xuICB9XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IE1kYWFFQ1NGYXJnYXRlU2VydmljZVByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCBNZGFhRUNTRmFyZ2F0ZVNlcnZpY2Uuc2V0UHJvcHMocHJvcHMpKTtcblxuICAgIG5ldyBNZGFhUGFyYW1BbmRPdXRwdXQoXG4gICAgICB0aGlzLFxuICAgICAge1xuICAgICAgICAuLi57XG4gICAgICAgICAgcmVzb3VyY2VUeXBlOiAnZmFyZ2F0ZXNlcnZpY2UnLFxuICAgICAgICAgIHJlc291cmNlSWQ6IHByb3BzLnNlcnZpY2VOYW1lLFxuICAgICAgICAgIG5hbWU6ICdhcm4nLFxuICAgICAgICAgIHZhbHVlOiB0aGlzLnNlcnZpY2VBcm4sXG4gICAgICAgIH0sXG4gICAgICAgIC4uLnByb3BzLFxuICAgICAgfSxcbiAgICAgIHNjb3BlLFxuICAgICk7XG4gICAgbmV3IE1kYWFQYXJhbUFuZE91dHB1dChcbiAgICAgIHRoaXMsXG4gICAgICB7XG4gICAgICAgIC4uLntcbiAgICAgICAgICByZXNvdXJjZVR5cGU6ICdmYXJnYXRlc2VydmljZScsXG4gICAgICAgICAgcmVzb3VyY2VJZDogcHJvcHMuc2VydmljZU5hbWUsXG4gICAgICAgICAgbmFtZTogJ25hbWUnLFxuICAgICAgICAgIHZhbHVlOiB0aGlzLnNlcnZpY2VOYW1lLFxuICAgICAgICB9LFxuICAgICAgICAuLi5wcm9wcyxcbiAgICAgIH0sXG4gICAgICBzY29wZSxcbiAgICApO1xuICB9XG59XG4iXX0=
package/lib/index.d.ts ADDED
@@ -0,0 +1,7 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+ export * from './cluster';
6
+ export * from './fargate-service';
7
+ export * from './container-definition';
package/lib/index.js ADDED
@@ -0,0 +1,26 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+
6
+ "use strict";
7
+
8
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
9
+ if (k2 === undefined) k2 = k;
10
+ var desc = Object.getOwnPropertyDescriptor(m, k);
11
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
12
+ desc = { enumerable: true, get: function() { return m[k]; } };
13
+ }
14
+ Object.defineProperty(o, k2, desc);
15
+ }) : (function(o, m, k, k2) {
16
+ if (k2 === undefined) k2 = k;
17
+ o[k2] = m[k];
18
+ }));
19
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
20
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
21
+ };
22
+ Object.defineProperty(exports, "__esModule", { value: true });
23
+ __exportStar(require("./cluster"), exports);
24
+ __exportStar(require("./fargate-service"), exports);
25
+ __exportStar(require("./container-definition"), exports);
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7OztHQUdHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsNENBQTBCO0FBQzFCLG9EQUFrQztBQUNsQyx5REFBdUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiFcbiAqIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICogU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2NsdXN0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9mYXJnYXRlLXNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250YWluZXItZGVmaW5pdGlvbic7XG4iXX0=