1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.TmpfsMountOption = exports.DevicePermission = exports.Capability = exports.LinuxParameters = 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 | // keep this import separate from other imports to reduce chance for merge conflicts with v2-main
|
9 | // eslint-disable-next-line no-duplicate-imports, import/order
|
10 | const core_1 = require("@aws-cdk/core");
|
11 | /**
|
12 | * Linux-specific options that are applied to the container.
|
13 | */
|
14 | class LinuxParameters extends core_1.Construct {
|
15 | /**
|
16 | * Constructs a new instance of the LinuxParameters class.
|
17 | */
|
18 | constructor(scope, id, props = {}) {
|
19 | super(scope, id);
|
20 | /**
|
21 | * Capabilities to be added
|
22 | */
|
23 | this.capAdd = new Array();
|
24 | /**
|
25 | * Capabilities to be dropped
|
26 | */
|
27 | this.capDrop = new Array();
|
28 | /**
|
29 | * Device mounts
|
30 | */
|
31 | this.devices = new Array();
|
32 | /**
|
33 | * TmpFs mounts
|
34 | */
|
35 | this.tmpfs = new Array();
|
36 | try {
|
37 | jsiiDeprecationWarnings._aws_cdk_aws_ecs_LinuxParametersProps(props);
|
38 | }
|
39 | catch (error) {
|
40 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
41 | Error.captureStackTrace(error, LinuxParameters);
|
42 | }
|
43 | throw error;
|
44 | }
|
45 | this.sharedMemorySize = props.sharedMemorySize;
|
46 | this.initProcessEnabled = props.initProcessEnabled;
|
47 | }
|
48 | /**
|
49 | * Adds one or more Linux capabilities to the Docker configuration of a container.
|
50 | *
|
51 | * Only works with EC2 launch type.
|
52 | */
|
53 | addCapabilities(...cap) {
|
54 | try {
|
55 | jsiiDeprecationWarnings._aws_cdk_aws_ecs_Capability(cap);
|
56 | }
|
57 | catch (error) {
|
58 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
59 | Error.captureStackTrace(error, this.addCapabilities);
|
60 | }
|
61 | throw error;
|
62 | }
|
63 | this.capAdd.push(...cap);
|
64 | }
|
65 | /**
|
66 | * Removes one or more Linux capabilities to the Docker configuration of a container.
|
67 | *
|
68 | * Only works with EC2 launch type.
|
69 | */
|
70 | dropCapabilities(...cap) {
|
71 | try {
|
72 | jsiiDeprecationWarnings._aws_cdk_aws_ecs_Capability(cap);
|
73 | }
|
74 | catch (error) {
|
75 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
76 | Error.captureStackTrace(error, this.dropCapabilities);
|
77 | }
|
78 | throw error;
|
79 | }
|
80 | this.capDrop.push(...cap);
|
81 | }
|
82 | /**
|
83 | * Adds one or more host devices to a container.
|
84 | */
|
85 | addDevices(...device) {
|
86 | try {
|
87 | jsiiDeprecationWarnings._aws_cdk_aws_ecs_Device(device);
|
88 | }
|
89 | catch (error) {
|
90 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
91 | Error.captureStackTrace(error, this.addDevices);
|
92 | }
|
93 | throw error;
|
94 | }
|
95 | this.devices.push(...device);
|
96 | }
|
97 | /**
|
98 | * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container.
|
99 | *
|
100 | * Only works with EC2 launch type.
|
101 | */
|
102 | addTmpfs(...tmpfs) {
|
103 | try {
|
104 | jsiiDeprecationWarnings._aws_cdk_aws_ecs_Tmpfs(tmpfs);
|
105 | }
|
106 | catch (error) {
|
107 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
108 | Error.captureStackTrace(error, this.addTmpfs);
|
109 | }
|
110 | throw error;
|
111 | }
|
112 | this.tmpfs.push(...tmpfs);
|
113 | }
|
114 | /**
|
115 | * Renders the Linux parameters to a CloudFormation object.
|
116 | */
|
117 | renderLinuxParameters() {
|
118 | return {
|
119 | initProcessEnabled: this.initProcessEnabled,
|
120 | sharedMemorySize: this.sharedMemorySize,
|
121 | capabilities: {
|
122 | add: cdk.Lazy.list({ produce: () => this.capAdd }, { omitEmpty: true }),
|
123 | drop: cdk.Lazy.list({ produce: () => this.capDrop }, { omitEmpty: true }),
|
124 | },
|
125 | devices: cdk.Lazy.any({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }),
|
126 | tmpfs: cdk.Lazy.any({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true }),
|
127 | };
|
128 | }
|
129 | }
|
130 | exports.LinuxParameters = LinuxParameters;
|
131 | _a = JSII_RTTI_SYMBOL_1;
|
132 | LinuxParameters[_a] = { fqn: "@aws-cdk/aws-ecs.LinuxParameters", version: "1.197.0" };
|
133 | function renderDevice(device) {
|
134 | return {
|
135 | containerPath: device.containerPath,
|
136 | hostPath: device.hostPath,
|
137 | permissions: device.permissions,
|
138 | };
|
139 | }
|
140 | function renderTmpfs(tmpfs) {
|
141 | return {
|
142 | containerPath: tmpfs.containerPath,
|
143 | size: tmpfs.size,
|
144 | mountOptions: tmpfs.mountOptions,
|
145 | };
|
146 | }
|
147 | /**
|
148 | * A Linux capability
|
149 | */
|
150 | var Capability;
|
151 | (function (Capability) {
|
152 | Capability["ALL"] = "ALL";
|
153 | Capability["AUDIT_CONTROL"] = "AUDIT_CONTROL";
|
154 | Capability["AUDIT_WRITE"] = "AUDIT_WRITE";
|
155 | Capability["BLOCK_SUSPEND"] = "BLOCK_SUSPEND";
|
156 | Capability["CHOWN"] = "CHOWN";
|
157 | Capability["DAC_OVERRIDE"] = "DAC_OVERRIDE";
|
158 | Capability["DAC_READ_SEARCH"] = "DAC_READ_SEARCH";
|
159 | Capability["FOWNER"] = "FOWNER";
|
160 | Capability["FSETID"] = "FSETID";
|
161 | Capability["IPC_LOCK"] = "IPC_LOCK";
|
162 | Capability["IPC_OWNER"] = "IPC_OWNER";
|
163 | Capability["KILL"] = "KILL";
|
164 | Capability["LEASE"] = "LEASE";
|
165 | Capability["LINUX_IMMUTABLE"] = "LINUX_IMMUTABLE";
|
166 | Capability["MAC_ADMIN"] = "MAC_ADMIN";
|
167 | Capability["MAC_OVERRIDE"] = "MAC_OVERRIDE";
|
168 | Capability["MKNOD"] = "MKNOD";
|
169 | Capability["NET_ADMIN"] = "NET_ADMIN";
|
170 | Capability["NET_BIND_SERVICE"] = "NET_BIND_SERVICE";
|
171 | Capability["NET_BROADCAST"] = "NET_BROADCAST";
|
172 | Capability["NET_RAW"] = "NET_RAW";
|
173 | Capability["SETFCAP"] = "SETFCAP";
|
174 | Capability["SETGID"] = "SETGID";
|
175 | Capability["SETPCAP"] = "SETPCAP";
|
176 | Capability["SETUID"] = "SETUID";
|
177 | Capability["SYS_ADMIN"] = "SYS_ADMIN";
|
178 | Capability["SYS_BOOT"] = "SYS_BOOT";
|
179 | Capability["SYS_CHROOT"] = "SYS_CHROOT";
|
180 | Capability["SYS_MODULE"] = "SYS_MODULE";
|
181 | Capability["SYS_NICE"] = "SYS_NICE";
|
182 | Capability["SYS_PACCT"] = "SYS_PACCT";
|
183 | Capability["SYS_PTRACE"] = "SYS_PTRACE";
|
184 | Capability["SYS_RAWIO"] = "SYS_RAWIO";
|
185 | Capability["SYS_RESOURCE"] = "SYS_RESOURCE";
|
186 | Capability["SYS_TIME"] = "SYS_TIME";
|
187 | Capability["SYS_TTY_CONFIG"] = "SYS_TTY_CONFIG";
|
188 | Capability["SYSLOG"] = "SYSLOG";
|
189 | Capability["WAKE_ALARM"] = "WAKE_ALARM";
|
190 | })(Capability = exports.Capability || (exports.Capability = {}));
|
191 | /**
|
192 | * Permissions for device access
|
193 | */
|
194 | var DevicePermission;
|
195 | (function (DevicePermission) {
|
196 | /**
|
197 | * Read
|
198 | */
|
199 | DevicePermission["READ"] = "read";
|
200 | /**
|
201 | * Write
|
202 | */
|
203 | DevicePermission["WRITE"] = "write";
|
204 | /**
|
205 | * Make a node
|
206 | */
|
207 | DevicePermission["MKNOD"] = "mknod";
|
208 | })(DevicePermission = exports.DevicePermission || (exports.DevicePermission = {}));
|
209 | /**
|
210 | * The supported options for a tmpfs mount for a container.
|
211 | */
|
212 | var TmpfsMountOption;
|
213 | (function (TmpfsMountOption) {
|
214 | TmpfsMountOption["DEFAULTS"] = "defaults";
|
215 | TmpfsMountOption["RO"] = "ro";
|
216 | TmpfsMountOption["RW"] = "rw";
|
217 | TmpfsMountOption["SUID"] = "suid";
|
218 | TmpfsMountOption["NOSUID"] = "nosuid";
|
219 | TmpfsMountOption["DEV"] = "dev";
|
220 | TmpfsMountOption["NODEV"] = "nodev";
|
221 | TmpfsMountOption["EXEC"] = "exec";
|
222 | TmpfsMountOption["NOEXEC"] = "noexec";
|
223 | TmpfsMountOption["SYNC"] = "sync";
|
224 | TmpfsMountOption["ASYNC"] = "async";
|
225 | TmpfsMountOption["DIRSYNC"] = "dirsync";
|
226 | TmpfsMountOption["REMOUNT"] = "remount";
|
227 | TmpfsMountOption["MAND"] = "mand";
|
228 | TmpfsMountOption["NOMAND"] = "nomand";
|
229 | TmpfsMountOption["ATIME"] = "atime";
|
230 | TmpfsMountOption["NOATIME"] = "noatime";
|
231 | TmpfsMountOption["DIRATIME"] = "diratime";
|
232 | TmpfsMountOption["NODIRATIME"] = "nodiratime";
|
233 | TmpfsMountOption["BIND"] = "bind";
|
234 | TmpfsMountOption["RBIND"] = "rbind";
|
235 | TmpfsMountOption["UNBINDABLE"] = "unbindable";
|
236 | TmpfsMountOption["RUNBINDABLE"] = "runbindable";
|
237 | TmpfsMountOption["PRIVATE"] = "private";
|
238 | TmpfsMountOption["RPRIVATE"] = "rprivate";
|
239 | TmpfsMountOption["SHARED"] = "shared";
|
240 | TmpfsMountOption["RSHARED"] = "rshared";
|
241 | TmpfsMountOption["SLAVE"] = "slave";
|
242 | TmpfsMountOption["RSLAVE"] = "rslave";
|
243 | TmpfsMountOption["RELATIME"] = "relatime";
|
244 | TmpfsMountOption["NORELATIME"] = "norelatime";
|
245 | TmpfsMountOption["STRICTATIME"] = "strictatime";
|
246 | TmpfsMountOption["NOSTRICTATIME"] = "nostrictatime";
|
247 | TmpfsMountOption["MODE"] = "mode";
|
248 | TmpfsMountOption["UID"] = "uid";
|
249 | TmpfsMountOption["GID"] = "gid";
|
250 | TmpfsMountOption["NR_INODES"] = "nr_inodes";
|
251 | TmpfsMountOption["NR_BLOCKS"] = "nr_blocks";
|
252 | TmpfsMountOption["MPOL"] = "mpol";
|
253 | })(TmpfsMountOption = exports.TmpfsMountOption || (exports.TmpfsMountOption = {}));
|
254 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linux-parameters.js","sourceRoot":"","sources":["linux-parameters.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnTaskDefinition } from './ecs.generated';\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 * The properties for defining Linux-specific options that are applied to the container.\n */\nexport interface LinuxParametersProps {\n  /**\n   * Specifies whether to run an init process inside the container that forwards signals and reaps processes.\n   *\n   * @default false\n   */\n  readonly initProcessEnabled?: boolean;\n\n  /**\n   * The value for the size (in MiB) of the /dev/shm volume.\n   *\n   * @default No shared memory.\n   */\n  readonly sharedMemorySize?: number;\n}\n\n/**\n * Linux-specific options that are applied to the container.\n */\nexport class LinuxParameters extends CoreConstruct {\n  /**\n   * Whether the init process is enabled\n   */\n  private readonly initProcessEnabled?: boolean;\n\n  /**\n   * The shared memory size. Not valid for Fargate launch type\n   */\n  private readonly sharedMemorySize?: number;\n\n  /**\n   * Capabilities to be added\n   */\n  private readonly capAdd = new Array<Capability>();\n\n  /**\n   * Capabilities to be dropped\n   */\n  private readonly capDrop = new Array<Capability>();\n\n  /**\n   * Device mounts\n   */\n  private readonly devices = new Array<Device>();\n\n  /**\n   * TmpFs mounts\n   */\n  private readonly tmpfs = new Array<Tmpfs>();\n\n  /**\n   * Constructs a new instance of the LinuxParameters class.\n   */\n  constructor(scope: Construct, id: string, props: LinuxParametersProps = {}) {\n    super(scope, id);\n\n    this.sharedMemorySize = props.sharedMemorySize;\n    this.initProcessEnabled = props.initProcessEnabled;\n  }\n\n  /**\n   * Adds one or more Linux capabilities to the Docker configuration of a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addCapabilities(...cap: Capability[]) {\n    this.capAdd.push(...cap);\n  }\n\n  /**\n   * Removes one or more Linux capabilities to the Docker configuration of a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public dropCapabilities(...cap: Capability[]) {\n    this.capDrop.push(...cap);\n  }\n\n  /**\n   * Adds one or more host devices to a container.\n   */\n  public addDevices(...device: Device[]) {\n    this.devices.push(...device);\n  }\n\n  /**\n   * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addTmpfs(...tmpfs: Tmpfs[]) {\n    this.tmpfs.push(...tmpfs);\n  }\n\n  /**\n   * Renders the Linux parameters to a CloudFormation object.\n   */\n  public renderLinuxParameters(): CfnTaskDefinition.LinuxParametersProperty {\n    return {\n      initProcessEnabled: this.initProcessEnabled,\n      sharedMemorySize: this.sharedMemorySize,\n      capabilities: {\n        add: cdk.Lazy.list({ produce: () => this.capAdd }, { omitEmpty: true }),\n        drop: cdk.Lazy.list({ produce: () => this.capDrop }, { omitEmpty: true }),\n      },\n      devices: cdk.Lazy.any({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }),\n      tmpfs: cdk.Lazy.any({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true }),\n    };\n  }\n}\n\n/**\n * A container instance host device.\n */\nexport interface Device {\n  /**\n   * The path inside the container at which to expose the host device.\n   *\n   * @default Same path as the host\n   */\n  readonly containerPath?: string,\n\n  /**\n   * The path for the device on the host container instance.\n   */\n  readonly hostPath: string,\n\n  /**\n   * The explicit permissions to provide to the container for the device.\n   * By default, the container has permissions for read, write, and mknod for the device.\n   *\n   * @default Readonly\n   */\n  readonly permissions?: DevicePermission[]\n}\n\nfunction renderDevice(device: Device): CfnTaskDefinition.DeviceProperty {\n  return {\n    containerPath: device.containerPath,\n    hostPath: device.hostPath,\n    permissions: device.permissions,\n  };\n}\n\n/**\n * The details of a tmpfs mount for a container.\n */\nexport interface Tmpfs {\n  /**\n   * The absolute file path where the tmpfs volume is to be mounted.\n   */\n  readonly containerPath: string,\n\n  /**\n   * The size (in MiB) of the tmpfs volume.\n   */\n  readonly size: number,\n\n  /**\n   * The list of tmpfs volume mount options. For more information, see\n   * [TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html).\n   */\n  readonly mountOptions?: TmpfsMountOption[],\n}\n\nfunction renderTmpfs(tmpfs: Tmpfs): CfnTaskDefinition.TmpfsProperty {\n  return {\n    containerPath: tmpfs.containerPath,\n    size: tmpfs.size,\n    mountOptions: tmpfs.mountOptions,\n  };\n}\n\n/**\n * A Linux capability\n */\nexport enum Capability {\n  ALL = 'ALL',\n  AUDIT_CONTROL = 'AUDIT_CONTROL',\n  AUDIT_WRITE = 'AUDIT_WRITE',\n  BLOCK_SUSPEND = 'BLOCK_SUSPEND',\n  CHOWN = 'CHOWN',\n  DAC_OVERRIDE = 'DAC_OVERRIDE',\n  DAC_READ_SEARCH = 'DAC_READ_SEARCH',\n  FOWNER = 'FOWNER',\n  FSETID = 'FSETID',\n  IPC_LOCK = 'IPC_LOCK',\n  IPC_OWNER = 'IPC_OWNER',\n  KILL = 'KILL',\n  LEASE = 'LEASE',\n  LINUX_IMMUTABLE = 'LINUX_IMMUTABLE',\n  MAC_ADMIN = 'MAC_ADMIN',\n  MAC_OVERRIDE = 'MAC_OVERRIDE',\n  MKNOD = 'MKNOD',\n  NET_ADMIN = 'NET_ADMIN',\n  NET_BIND_SERVICE = 'NET_BIND_SERVICE',\n  NET_BROADCAST = 'NET_BROADCAST',\n  NET_RAW = 'NET_RAW',\n  SETFCAP = 'SETFCAP',\n  SETGID = 'SETGID',\n  SETPCAP = 'SETPCAP',\n  SETUID = 'SETUID',\n  SYS_ADMIN = 'SYS_ADMIN',\n  SYS_BOOT = 'SYS_BOOT',\n  SYS_CHROOT = 'SYS_CHROOT',\n  SYS_MODULE = 'SYS_MODULE',\n  SYS_NICE = 'SYS_NICE',\n  SYS_PACCT = 'SYS_PACCT',\n  SYS_PTRACE = 'SYS_PTRACE',\n  SYS_RAWIO = 'SYS_RAWIO',\n  SYS_RESOURCE = 'SYS_RESOURCE',\n  SYS_TIME = 'SYS_TIME',\n  SYS_TTY_CONFIG = 'SYS_TTY_CONFIG',\n  SYSLOG = 'SYSLOG',\n  WAKE_ALARM = 'WAKE_ALARM'\n}\n\n/**\n * Permissions for device access\n */\nexport enum DevicePermission {\n  /**\n   * Read\n   */\n  READ = 'read',\n\n  /**\n   * Write\n   */\n  WRITE = 'write',\n\n  /**\n   * Make a node\n   */\n  MKNOD = 'mknod',\n}\n\n/**\n * The supported options for a tmpfs mount for a container.\n */\nexport enum TmpfsMountOption {\n  DEFAULTS = 'defaults',\n  RO = 'ro',\n  RW = 'rw',\n  SUID = 'suid',\n  NOSUID = 'nosuid',\n  DEV = 'dev',\n  NODEV = 'nodev',\n  EXEC = 'exec',\n  NOEXEC = 'noexec',\n  SYNC = 'sync',\n  ASYNC = 'async',\n  DIRSYNC = 'dirsync',\n  REMOUNT = 'remount',\n  MAND = 'mand',\n  NOMAND = 'nomand',\n  ATIME = 'atime',\n  NOATIME = 'noatime',\n  DIRATIME = 'diratime',\n  NODIRATIME = 'nodiratime',\n  BIND = 'bind',\n  RBIND = 'rbind',\n  UNBINDABLE = 'unbindable',\n  RUNBINDABLE = 'runbindable',\n  PRIVATE = 'private',\n  RPRIVATE = 'rprivate',\n  SHARED = 'shared',\n  RSHARED = 'rshared',\n  SLAVE = 'slave',\n  RSLAVE = 'rslave',\n  RELATIME = 'relatime',\n  NORELATIME = 'norelatime',\n  STRICTATIME = 'strictatime',\n  NOSTRICTATIME = 'nostrictatime',\n  MODE = 'mode',\n  UID = 'uid',\n  GID = 'gid',\n  NR_INODES = 'nr_inodes',\n  NR_BLOCKS = 'nr_blocks',\n  MPOL = 'mpol'\n}\n"]} |
\ | No newline at end of file |