@aws-cdk/aws-ecs
Version:
The CDK Construct Library for AWS::ECS
521 lines • 88.1 kB
JavaScript
"use strict";
var _a, _b;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Protocol = exports.ContainerDependencyCondition = exports.UlimitName = exports.ContainerDefinition = exports.Secret = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cdk = require("@aws-cdk/core");
const task_definition_1 = require("./base/task-definition");
// keep this import separate from other imports to reduce chance for merge conflicts with v2-main
// eslint-disable-next-line no-duplicate-imports, import/order
const core_1 = require("@aws-cdk/core");
/**
* A secret environment variable.
*/
class Secret {
/**
* Creates an environment variable value from a parameter stored in AWS
* Systems Manager Parameter Store.
*/
static fromSsmParameter(parameter) {
return {
arn: parameter.parameterArn,
grantRead: grantee => parameter.grantRead(grantee),
};
}
/**
* Creates a environment variable value from a secret stored in AWS Secrets
* Manager.
*
* @param secret the secret stored in AWS Secrets Manager
* @param field the name of the field with the value that you want to set as
* the environment variable value. Only values in JSON format are supported.
* If you do not specify a JSON field, then the full content of the secret is
* used.
*/
static fromSecretsManager(secret, field) {
return {
arn: field ? `${secret.secretArn}:${field}::` : secret.secretArn,
hasField: !!field,
grantRead: grantee => secret.grantRead(grantee),
};
}
/**
* Creates a environment variable value from a secret stored in AWS Secrets
* Manager.
*
* @param secret the secret stored in AWS Secrets Manager
* @param versionInfo the version information to reference the secret
* @param field the name of the field with the value that you want to set as
* the environment variable value. Only values in JSON format are supported.
* If you do not specify a JSON field, then the full content of the secret is
* used.
*/
static fromSecretsManagerVersion(secret, versionInfo, field) {
var _c, _d;
jsiiDeprecationWarnings._aws_cdk_aws_ecs_SecretVersionInfo(versionInfo);
return {
arn: `${secret.secretArn}:${field !== null && field !== void 0 ? field : ''}:${(_c = versionInfo.versionStage) !== null && _c !== void 0 ? _c : ''}:${(_d = versionInfo.versionId) !== null && _d !== void 0 ? _d : ''}`,
hasField: !!field,
grantRead: grantee => secret.grantRead(grantee),
};
}
}
exports.Secret = Secret;
_a = JSII_RTTI_SYMBOL_1;
Secret[_a] = { fqn: "@aws-cdk/aws-ecs.Secret", version: "1.149.0" };
/**
* A container definition is used in a task definition to describe the containers that are launched as part of a task.
*/
class ContainerDefinition extends core_1.Construct {
/**
* Constructs a new instance of the ContainerDefinition class.
*/
constructor(scope, id, props) {
var _c, _d;
super(scope, id);
this.props = props;
/**
* The mount points for data volumes in your container.
*/
this.mountPoints = new Array();
/**
* The list of port mappings for the container. Port mappings allow containers to access ports
* on the host container instance to send or receive traffic.
*/
this.portMappings = new Array();
/**
* The data volumes to mount from another container in the same task definition.
*/
this.volumesFrom = new Array();
/**
* An array of ulimits to set in the container.
*/
this.ulimits = new Array();
/**
* An array dependencies defined for container startup and shutdown.
*/
this.containerDependencies = new Array();
/**
* The inference accelerators referenced by this container.
*/
this.inferenceAcceleratorResources = [];
/**
* The configured container links
*/
this.links = new Array();
jsiiDeprecationWarnings._aws_cdk_aws_ecs_ContainerDefinitionProps(props);
if (props.memoryLimitMiB !== undefined && props.memoryReservationMiB !== undefined) {
if (props.memoryLimitMiB < props.memoryReservationMiB) {
throw new Error('MemoryLimitMiB should not be less than MemoryReservationMiB.');
}
}
this.essential = (_c = props.essential) !== null && _c !== void 0 ? _c : true;
this.taskDefinition = props.taskDefinition;
this.memoryLimitSpecified = props.memoryLimitMiB !== undefined || props.memoryReservationMiB !== undefined;
this.linuxParameters = props.linuxParameters;
this.containerName = (_d = props.containerName) !== null && _d !== void 0 ? _d : this.node.id;
this.imageConfig = props.image.bind(this, this);
this.imageName = this.imageConfig.imageName;
if (props.logging) {
this.logDriverConfig = props.logging.bind(this, this);
}
if (props.secrets) {
this.secrets = [];
for (const [name, secret] of Object.entries(props.secrets)) {
if (secret.hasField) {
this.referencesSecretJsonField = true;
}
secret.grantRead(this.taskDefinition.obtainExecutionRole());
this.secrets.push({
name,
valueFrom: secret.arn,
});
}
}
if (props.environment) {
this.environment = { ...props.environment };
}
else {
this.environment = {};
}
if (props.environmentFiles) {
this.environmentFiles = [];
for (const environmentFile of props.environmentFiles) {
this.environmentFiles.push(environmentFile.bind(this));
}
}
props.taskDefinition._linkContainer(this);
if (props.portMappings) {
this.addPortMappings(...props.portMappings);
}
if (props.inferenceAcceleratorResources) {
this.addInferenceAcceleratorResource(...props.inferenceAcceleratorResources);
}
}
/**
* This method adds a link which allows containers to communicate with each other without the need for port mappings.
*
* This parameter is only supported if the task definition is using the bridge network mode.
* Warning: The --link flag is a legacy feature of Docker. It may eventually be removed.
*/
addLink(container, alias) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_ContainerDefinition(container);
if (this.taskDefinition.networkMode !== task_definition_1.NetworkMode.BRIDGE) {
throw new Error('You must use network mode Bridge to add container links.');
}
if (alias !== undefined) {
this.links.push(`${container.containerName}:${alias}`);
}
else {
this.links.push(`${container.containerName}`);
}
}
/**
* This method adds one or more mount points for data volumes to the container.
*/
addMountPoints(...mountPoints) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_MountPoint(mountPoints);
this.mountPoints.push(...mountPoints);
}
/**
* This method mounts temporary disk space to the container.
*
* This adds the correct container mountPoint and task definition volume.
*/
addScratch(scratch) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_ScratchSpace(scratch);
const mountPoint = {
containerPath: scratch.containerPath,
readOnly: scratch.readOnly,
sourceVolume: scratch.name,
};
const volume = {
host: {
sourcePath: scratch.sourcePath,
},
name: scratch.name,
};
this.taskDefinition.addVolume(volume);
this.addMountPoints(mountPoint);
}
/**
* This method adds one or more port mappings to the container.
*/
addPortMappings(...portMappings) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_PortMapping(portMappings);
this.portMappings.push(...portMappings.map(pm => {
if (this.taskDefinition.networkMode === task_definition_1.NetworkMode.AWS_VPC || this.taskDefinition.networkMode === task_definition_1.NetworkMode.HOST) {
if (pm.containerPort !== pm.hostPort && pm.hostPort !== undefined) {
throw new Error(`Host port (${pm.hostPort}) must be left out or equal to container port ${pm.containerPort} for network mode ${this.taskDefinition.networkMode}`);
}
}
if (this.taskDefinition.networkMode === task_definition_1.NetworkMode.BRIDGE) {
if (pm.hostPort === undefined) {
pm = {
...pm,
hostPort: 0,
};
}
}
return pm;
}));
}
/**
* This method adds an environment variable to the container.
*/
addEnvironment(name, value) {
this.environment[name] = value;
}
/**
* This method adds one or more resources to the container.
*/
addInferenceAcceleratorResource(...inferenceAcceleratorResources) {
this.inferenceAcceleratorResources.push(...inferenceAcceleratorResources.map(resource => {
for (const inferenceAccelerator of this.taskDefinition.inferenceAccelerators) {
if (resource === inferenceAccelerator.deviceName) {
return resource;
}
}
throw new Error(`Resource value ${resource} in container definition doesn't match any inference accelerator device name in the task definition.`);
}));
}
/**
* This method adds one or more ulimits to the container.
*/
addUlimits(...ulimits) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_Ulimit(ulimits);
this.ulimits.push(...ulimits);
}
/**
* This method adds one or more container dependencies to the container.
*/
addContainerDependencies(...containerDependencies) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_ContainerDependency(containerDependencies);
this.containerDependencies.push(...containerDependencies);
}
/**
* This method adds one or more volumes to the container.
*/
addVolumesFrom(...volumesFrom) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_VolumeFrom(volumesFrom);
this.volumesFrom.push(...volumesFrom);
}
/**
* This method adds the specified statement to the IAM task execution policy in the task definition.
*/
addToExecutionPolicy(statement) {
this.taskDefinition.addToExecutionRolePolicy(statement);
}
/**
* Returns the host port for the requested container port if it exists
*/
findPortMapping(containerPort, protocol) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_Protocol(protocol);
for (const portMapping of this.portMappings) {
const p = portMapping.protocol || Protocol.TCP;
const c = portMapping.containerPort;
if (c === containerPort && p === protocol) {
return portMapping;
}
}
return undefined;
}
/**
* The inbound rules associated with the security group the task or service will use.
*
* This property is only used for tasks that use the awsvpc network mode.
*/
get ingressPort() {
if (this.portMappings.length === 0) {
throw new Error(`Container ${this.containerName} hasn't defined any ports. Call addPortMappings().`);
}
const defaultPortMapping = this.portMappings[0];
if (defaultPortMapping.hostPort !== undefined && defaultPortMapping.hostPort !== 0) {
return defaultPortMapping.hostPort;
}
if (this.taskDefinition.networkMode === task_definition_1.NetworkMode.BRIDGE) {
return 0;
}
return defaultPortMapping.containerPort;
}
/**
* The port the container will listen on.
*/
get containerPort() {
if (this.portMappings.length === 0) {
throw new Error(`Container ${this.containerName} hasn't defined any ports. Call addPortMappings().`);
}
const defaultPortMapping = this.portMappings[0];
return defaultPortMapping.containerPort;
}
/**
* Render this container definition to a CloudFormation object
*
* @param _taskDefinition [disable-awslint:ref-via-interface] (unused but kept to avoid breaking change)
*/
renderContainerDefinition(_taskDefinition) {
jsiiDeprecationWarnings._aws_cdk_aws_ecs_TaskDefinition(_taskDefinition);
return {
command: this.props.command,
cpu: this.props.cpu,
disableNetworking: this.props.disableNetworking,
dependsOn: cdk.Lazy.any({ produce: () => this.containerDependencies.map(renderContainerDependency) }, { omitEmptyArray: true }),
dnsSearchDomains: this.props.dnsSearchDomains,
dnsServers: this.props.dnsServers,
dockerLabels: this.props.dockerLabels,
dockerSecurityOptions: this.props.dockerSecurityOptions,
entryPoint: this.props.entryPoint,
essential: this.essential,
hostname: this.props.hostname,
image: this.imageConfig.imageName,
memory: this.props.memoryLimitMiB,
memoryReservation: this.props.memoryReservationMiB,
mountPoints: cdk.Lazy.any({ produce: () => this.mountPoints.map(renderMountPoint) }, { omitEmptyArray: true }),
name: this.containerName,
portMappings: cdk.Lazy.any({ produce: () => this.portMappings.map(renderPortMapping) }, { omitEmptyArray: true }),
privileged: this.props.privileged,
readonlyRootFilesystem: this.props.readonlyRootFilesystem,
repositoryCredentials: this.imageConfig.repositoryCredentials,
startTimeout: this.props.startTimeout && this.props.startTimeout.toSeconds(),
stopTimeout: this.props.stopTimeout && this.props.stopTimeout.toSeconds(),
ulimits: cdk.Lazy.any({ produce: () => this.ulimits.map(renderUlimit) }, { omitEmptyArray: true }),
user: this.props.user,
volumesFrom: cdk.Lazy.any({ produce: () => this.volumesFrom.map(renderVolumeFrom) }, { omitEmptyArray: true }),
workingDirectory: this.props.workingDirectory,
logConfiguration: this.logDriverConfig,
environment: this.environment && Object.keys(this.environment).length ? renderKV(this.environment, 'name', 'value') : undefined,
environmentFiles: this.environmentFiles && renderEnvironmentFiles(cdk.Stack.of(this).partition, this.environmentFiles),
secrets: this.secrets,
extraHosts: this.props.extraHosts && renderKV(this.props.extraHosts, 'hostname', 'ipAddress'),
healthCheck: this.props.healthCheck && renderHealthCheck(this.props.healthCheck),
links: cdk.Lazy.list({ produce: () => this.links }, { omitEmpty: true }),
linuxParameters: this.linuxParameters && this.linuxParameters.renderLinuxParameters(),
resourceRequirements: (!this.props.gpuCount && this.inferenceAcceleratorResources.length == 0) ? undefined :
renderResourceRequirements(this.props.gpuCount, this.inferenceAcceleratorResources),
systemControls: this.props.systemControls && renderSystemControls(this.props.systemControls),
};
}
}
exports.ContainerDefinition = ContainerDefinition;
_b = JSII_RTTI_SYMBOL_1;
ContainerDefinition[_b] = { fqn: "@aws-cdk/aws-ecs.ContainerDefinition", version: "1.149.0" };
function renderKV(env, keyName, valueName) {
const ret = [];
for (const [key, value] of Object.entries(env)) {
ret.push({ [keyName]: key, [valueName]: value });
}
return ret;
}
function renderEnvironmentFiles(partition, environmentFiles) {
const ret = [];
for (const environmentFile of environmentFiles) {
const s3Location = environmentFile.s3Location;
if (!s3Location) {
throw Error('Environment file must specify an S3 location');
}
ret.push({
type: environmentFile.fileType,
value: `arn:${partition}:s3:::${s3Location.bucketName}/${s3Location.objectKey}`,
});
}
return ret;
}
function renderHealthCheck(hc) {
var _c, _d, _e, _f, _g, _h;
return {
command: getHealthCheckCommand(hc),
interval: (_d = (_c = hc.interval) === null || _c === void 0 ? void 0 : _c.toSeconds()) !== null && _d !== void 0 ? _d : 30,
retries: (_e = hc.retries) !== null && _e !== void 0 ? _e : 3,
startPeriod: (_f = hc.startPeriod) === null || _f === void 0 ? void 0 : _f.toSeconds(),
timeout: (_h = (_g = hc.timeout) === null || _g === void 0 ? void 0 : _g.toSeconds()) !== null && _h !== void 0 ? _h : 5,
};
}
function getHealthCheckCommand(hc) {
const cmd = hc.command;
const hcCommand = new Array();
if (cmd.length === 0) {
throw new Error('At least one argument must be supplied for health check command.');
}
if (cmd.length === 1) {
hcCommand.push('CMD-SHELL', cmd[0]);
return hcCommand;
}
if (cmd[0] !== 'CMD' && cmd[0] !== 'CMD-SHELL') {
hcCommand.push('CMD');
}
return hcCommand.concat(cmd);
}
function renderResourceRequirements(gpuCount = 0, inferenceAcceleratorResources = []) {
const ret = [];
for (const resource of inferenceAcceleratorResources) {
ret.push({
type: 'InferenceAccelerator',
value: resource,
});
}
if (gpuCount > 0) {
ret.push({
type: 'GPU',
value: gpuCount.toString(),
});
}
return ret;
}
/**
* Type of resource to set a limit on
*/
var UlimitName;
(function (UlimitName) {
UlimitName["CORE"] = "core";
UlimitName["CPU"] = "cpu";
UlimitName["DATA"] = "data";
UlimitName["FSIZE"] = "fsize";
UlimitName["LOCKS"] = "locks";
UlimitName["MEMLOCK"] = "memlock";
UlimitName["MSGQUEUE"] = "msgqueue";
UlimitName["NICE"] = "nice";
UlimitName["NOFILE"] = "nofile";
UlimitName["NPROC"] = "nproc";
UlimitName["RSS"] = "rss";
UlimitName["RTPRIO"] = "rtprio";
UlimitName["RTTIME"] = "rttime";
UlimitName["SIGPENDING"] = "sigpending";
UlimitName["STACK"] = "stack";
})(UlimitName = exports.UlimitName || (exports.UlimitName = {}));
function renderUlimit(ulimit) {
return {
name: ulimit.name,
softLimit: ulimit.softLimit,
hardLimit: ulimit.hardLimit,
};
}
var ContainerDependencyCondition;
(function (ContainerDependencyCondition) {
/**
* This condition emulates the behavior of links and volumes today.
* It validates that a dependent container is started before permitting other containers to start.
*/
ContainerDependencyCondition["START"] = "START";
/**
* This condition validates that a dependent container runs to completion (exits) before permitting other containers to start.
* This can be useful for nonessential containers that run a script and then exit.
*/
ContainerDependencyCondition["COMPLETE"] = "COMPLETE";
/**
* This condition is the same as COMPLETE, but it also requires that the container exits with a zero status.
*/
ContainerDependencyCondition["SUCCESS"] = "SUCCESS";
/**
* This condition validates that the dependent container passes its Docker health check before permitting other containers to start.
* This requires that the dependent container has health checks configured. This condition is confirmed only at task startup.
*/
ContainerDependencyCondition["HEALTHY"] = "HEALTHY";
})(ContainerDependencyCondition = exports.ContainerDependencyCondition || (exports.ContainerDependencyCondition = {}));
function renderContainerDependency(containerDependency) {
return {
containerName: containerDependency.container.containerName,
condition: containerDependency.condition || ContainerDependencyCondition.HEALTHY,
};
}
/**
* Network protocol
*/
var Protocol;
(function (Protocol) {
/**
* TCP
*/
Protocol["TCP"] = "tcp";
/**
* UDP
*/
Protocol["UDP"] = "udp";
})(Protocol = exports.Protocol || (exports.Protocol = {}));
function renderPortMapping(pm) {
return {
containerPort: pm.containerPort,
hostPort: pm.hostPort,
protocol: pm.protocol || Protocol.TCP,
};
}
function renderMountPoint(mp) {
return {
containerPath: mp.containerPath,
readOnly: mp.readOnly,
sourceVolume: mp.sourceVolume,
};
}
function renderVolumeFrom(vf) {
return {
sourceContainer: vf.sourceContainer,
readOnly: vf.readOnly,
};
}
function renderSystemControls(systemControls) {
return systemControls.map(sc => ({
namespace: sc.namespace,
value: sc.value,
}));
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container-definition.js","sourceRoot":"","sources":["container-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import * as iam from '@aws-cdk/aws-iam';\nimport * as secretsmanager from '@aws-cdk/aws-secretsmanager';\nimport * as ssm from '@aws-cdk/aws-ssm';\nimport * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { NetworkMode, TaskDefinition } from './base/task-definition';\nimport { ContainerImage, ContainerImageConfig } from './container-image';\nimport { CfnTaskDefinition } from './ecs.generated';\nimport { EnvironmentFile, EnvironmentFileConfig } from './environment-file';\nimport { LinuxParameters } from './linux-parameters';\nimport { LogDriver, LogDriverConfig } from './log-drivers/log-driver';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct as CoreConstruct } from '@aws-cdk/core';\n\n/**\n * Specify the secret's version id or version stage\n */\nexport interface SecretVersionInfo {\n  /**\n   * version id of the secret\n   *\n   * @default - use default version id\n   */\n  readonly versionId?: string;\n  /**\n   * version stage of the secret\n   *\n   * @default - use default version stage\n   */\n  readonly versionStage?: string;\n}\n\n/**\n * A secret environment variable.\n */\nexport abstract class Secret {\n  /**\n   * Creates an environment variable value from a parameter stored in AWS\n   * Systems Manager Parameter Store.\n   */\n  public static fromSsmParameter(parameter: ssm.IParameter): Secret {\n    return {\n      arn: parameter.parameterArn,\n      grantRead: grantee => parameter.grantRead(grantee),\n    };\n  }\n\n  /**\n   * Creates a environment variable value from a secret stored in AWS Secrets\n   * Manager.\n   *\n   * @param secret the secret stored in AWS Secrets Manager\n   * @param field the name of the field with the value that you want to set as\n   * the environment variable value. Only values in JSON format are supported.\n   * If you do not specify a JSON field, then the full content of the secret is\n   * used.\n   */\n  public static fromSecretsManager(secret: secretsmanager.ISecret, field?: string): Secret {\n    return {\n      arn: field ? `${secret.secretArn}:${field}::` : secret.secretArn,\n      hasField: !!field,\n      grantRead: grantee => secret.grantRead(grantee),\n    };\n  }\n\n  /**\n   * Creates a environment variable value from a secret stored in AWS Secrets\n   * Manager.\n   *\n   * @param secret the secret stored in AWS Secrets Manager\n   * @param versionInfo the version information to reference the secret\n   * @param field the name of the field with the value that you want to set as\n   * the environment variable value. Only values in JSON format are supported.\n   * If you do not specify a JSON field, then the full content of the secret is\n   * used.\n   */\n  public static fromSecretsManagerVersion(secret: secretsmanager.ISecret, versionInfo: SecretVersionInfo, field?: string): Secret {\n    return {\n      arn: `${secret.secretArn}:${field ?? ''}:${versionInfo.versionStage ?? ''}:${versionInfo.versionId ?? ''}`,\n      hasField: !!field,\n      grantRead: grantee => secret.grantRead(grantee),\n    };\n  }\n\n  /**\n   * The ARN of the secret\n   */\n  public abstract readonly arn: string;\n\n  /**\n   * Whether this secret uses a specific JSON field\n   */\n  public abstract readonly hasField?: boolean;\n\n  /**\n   * Grants reading the secret to a principal\n   */\n  public abstract grantRead(grantee: iam.IGrantable): iam.Grant;\n}\n\n/*\n * The options for creating a container definition.\n */\nexport interface ContainerDefinitionOptions {\n  /**\n   * The image used to start a container.\n   *\n   * This string is passed directly to the Docker daemon.\n   * Images in the Docker Hub registry are available by default.\n   * Other repositories are specified with either repository-url/image:tag or repository-url/image@digest.\n   * TODO: Update these to specify using classes of IContainerImage\n   */\n  readonly image: ContainerImage;\n\n  /**\n   * The name of the container.\n   *\n   * @default - id of node associated with ContainerDefinition.\n   */\n  readonly containerName?: string;\n\n  /**\n   * The command that is passed to the container.\n   *\n   * If you provide a shell command as a single string, you have to quote command-line arguments.\n   *\n   * @default - CMD value built into container image.\n   */\n  readonly command?: string[];\n\n  /**\n   * The minimum number of CPU units to reserve for the container.\n   *\n   * @default - No minimum CPU units reserved.\n   */\n  readonly cpu?: number;\n\n  /**\n   * Specifies whether networking is disabled within the container.\n   *\n   * When this parameter is true, networking is disabled within the container.\n   *\n   * @default false\n   */\n  readonly disableNetworking?: boolean;\n\n  /**\n   * A list of DNS search domains that are presented to the container.\n   *\n   * @default - No search domains.\n   */\n  readonly dnsSearchDomains?: string[];\n\n  /**\n   * A list of DNS servers that are presented to the container.\n   *\n   * @default - Default DNS servers.\n   */\n  readonly dnsServers?: string[];\n\n  /**\n   * A key/value map of labels to add to the container.\n   *\n   * @default - No labels.\n   */\n  readonly dockerLabels?: { [key: string]: string };\n\n  /**\n   * A list of strings to provide custom labels for SELinux and AppArmor multi-level security systems.\n   *\n   * @default - No security labels.\n   */\n  readonly dockerSecurityOptions?: string[];\n\n  /**\n   * The ENTRYPOINT value to pass to the container.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#entrypoint\n   *\n   * @default - Entry point configured in container.\n   */\n  readonly entryPoint?: string[];\n\n  /**\n   * The environment variables to pass to the container.\n   *\n   * @default - No environment variables.\n   */\n  readonly environment?: { [key: string]: string };\n\n  /**\n   * The environment files to pass to the container.\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/taskdef-envfiles.html\n   *\n   * @default - No environment files.\n   */\n  readonly environmentFiles?: EnvironmentFile[];\n\n  /**\n   * The secret environment variables to pass to the container.\n   *\n   * @default - No secret environment variables.\n   */\n  readonly secrets?: { [key: string]: Secret };\n\n  /**\n   * Time duration (in seconds) to wait before giving up on resolving dependencies for a container.\n   *\n   * @default - none\n   */\n  readonly startTimeout?: cdk.Duration;\n\n  /**\n   * Time duration (in seconds) to wait before the container is forcefully killed if it doesn't exit normally on its own.\n   *\n   * @default - none\n   */\n  readonly stopTimeout?: cdk.Duration;\n\n  /**\n   * Specifies whether the container is marked essential.\n   *\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   *\n   * If this parameter is omitted, a container is assumed to be essential.\n   *\n   * @default true\n   */\n  readonly essential?: boolean;\n\n  /**\n   * A list of hostnames and IP address mappings to append to the /etc/hosts file on the container.\n   *\n   * @default - No extra hosts.\n   */\n  readonly extraHosts?: { [name: string]: string };\n\n  /**\n   * The health check command and associated configuration parameters for the container.\n   *\n   * @default - Health check configuration from container.\n   */\n  readonly healthCheck?: HealthCheck;\n\n  /**\n   * The hostname to use for your container.\n   *\n   * @default - Automatic hostname.\n   */\n  readonly hostname?: string;\n\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   *\n   * If your container attempts to exceed the allocated memory, the container\n   * is terminated.\n   *\n   * At least one of memoryLimitMiB and memoryReservationMiB is required for non-Fargate services.\n   *\n   * @default - No memory limit.\n   */\n  readonly memoryLimitMi