@robhan-cdk-lib/aws_mwaa 0.0.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/.jsii +7679 -0
- package/API.md +3319 -0
- package/LICENSE +19 -0
- package/README.md +54 -0
- package/lib/environment-base.d.ts +462 -0
- package/lib/environment-base.js +53 -0
- package/lib/environment.d.ts +533 -0
- package/lib/environment.js +230 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +19 -0
- package/lib/validation/environment-base.d.ts +18 -0
- package/lib/validation/environment-base.js +350 -0
- package/package.json +155 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
Copyright (c) 2025 Robert Hanuschke
|
|
2
|
+
|
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
4
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
5
|
+
in the Software without restriction, including without limitation the rights
|
|
6
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
7
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
8
|
+
furnished to do so, subject to the following conditions:
|
|
9
|
+
|
|
10
|
+
The above copyright notice and this permission notice shall be included in all
|
|
11
|
+
copies or substantial portions of the Software.
|
|
12
|
+
|
|
13
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
14
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
15
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
16
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
17
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
18
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
19
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
# @robhan-cdk-lib/aws_aps
|
|
2
|
+
|
|
3
|
+
AWS Cloud Development Kit (CDK) constructs for Amazon Managed Workflows for Apache Airflow (MWAA).
|
|
4
|
+
|
|
5
|
+
In [aws-cdk-lib.aws_mwaa](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_mwaa-readme.html), there currently only exist L1 constructs for Amazon Managed Workflows for Apache Airflow (MWAA).
|
|
6
|
+
|
|
7
|
+
While helpful, they miss convenience like:
|
|
8
|
+
|
|
9
|
+
- advanced parameter checking (min/max number values, string lengths, array lengths...) before CloudFormation deployment
|
|
10
|
+
- proper parameter typing, e.g. enum values instead of strings
|
|
11
|
+
- simply referencing other constructs instead of e.g. ARN strings
|
|
12
|
+
|
|
13
|
+
Those features are implemented here.
|
|
14
|
+
|
|
15
|
+
The CDK maintainers explain that [publishing your own package](https://github.com/aws/aws-cdk/blob/main/CONTRIBUTING.md#publishing-your-own-package) is "by far the strongest signal you can give to the CDK team that a feature should be included within the core aws-cdk packages".
|
|
16
|
+
|
|
17
|
+
This project aims to develop aws_aps constructs to a maturity that can potentially be accepted to the CDK core.
|
|
18
|
+
|
|
19
|
+
It is not supported by AWS and is not endorsed by them. Please file issues in the [GitHub repository](https://github.com/robert-hanuschke/cdk-aws_mwaa/issues) if you find any.
|
|
20
|
+
|
|
21
|
+
## Example use
|
|
22
|
+
|
|
23
|
+
```typescript
|
|
24
|
+
import * as cdk from "aws-cdk-lib";
|
|
25
|
+
import { Construct } from "constructs";
|
|
26
|
+
import {
|
|
27
|
+
AirflowVersion,
|
|
28
|
+
Environment,
|
|
29
|
+
EnvironmentClass,
|
|
30
|
+
} from "@robhan-cdk-lib/aws_mwaa";
|
|
31
|
+
|
|
32
|
+
export class AwsMwaaCdkStack extends cdk.Stack {
|
|
33
|
+
constructor(scope: Construct, id: string, props?: cdk.StackProps) {
|
|
34
|
+
super(scope, id, props);
|
|
35
|
+
|
|
36
|
+
const environment = new Environment(this, "Environment", {
|
|
37
|
+
airflowConfigurationOptions: {
|
|
38
|
+
key: "value",
|
|
39
|
+
},
|
|
40
|
+
name: "myEnvironment",
|
|
41
|
+
airflowVersion: AirflowVersion.V3_0_6,
|
|
42
|
+
environmentClass: EnvironmentClass.MW1_MEDIUM,
|
|
43
|
+
minWebservers: 2,
|
|
44
|
+
maxWebservers: 4,
|
|
45
|
+
minWorkers: 2,
|
|
46
|
+
maxWorkers: 4,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
## License
|
|
53
|
+
|
|
54
|
+
MIT
|
|
@@ -0,0 +1,462 @@
|
|
|
1
|
+
import { IResource, Resource } from 'aws-cdk-lib';
|
|
2
|
+
import { ISecurityGroup, ISubnet } from 'aws-cdk-lib/aws-ec2';
|
|
3
|
+
import { IRole } from 'aws-cdk-lib/aws-iam';
|
|
4
|
+
import { IKey } from 'aws-cdk-lib/aws-kms';
|
|
5
|
+
import { ILogGroup } from 'aws-cdk-lib/aws-logs';
|
|
6
|
+
import { IBucket } from 'aws-cdk-lib/aws-s3';
|
|
7
|
+
export declare enum LogLevel {
|
|
8
|
+
DEBUG = "DEBUG",
|
|
9
|
+
INFO = "INFO",
|
|
10
|
+
WARNING = "WARNING",
|
|
11
|
+
ERROR = "ERROR",
|
|
12
|
+
CRITICAL = "CRITICAL"
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Defines the type of logs to send for the Apache Airflow log type
|
|
16
|
+
* (e.g. DagProcessingLogs).
|
|
17
|
+
*/
|
|
18
|
+
export interface ModuleLoggingConfiguration {
|
|
19
|
+
/**
|
|
20
|
+
* The CloudWatch Logs log group for each type ofApache Airflow log type that you have enabled.
|
|
21
|
+
*/
|
|
22
|
+
readonly cloudWatchLogGroup?: ILogGroup;
|
|
23
|
+
/**
|
|
24
|
+
* Indicates whether to enable the Apache Airflow log type (e.g. DagProcessingLogs) in CloudWatch Logs.
|
|
25
|
+
*/
|
|
26
|
+
readonly enabled?: boolean;
|
|
27
|
+
/**
|
|
28
|
+
* Defines the Apache Airflow logs to send for the log type (e.g. DagProcessingLogs) to CloudWatch Logs.
|
|
29
|
+
*/
|
|
30
|
+
readonly logLevel?: LogLevel;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* The type of Apache Airflow logs to send to CloudWatch Logs.
|
|
34
|
+
*/
|
|
35
|
+
export interface LoggingConfiguration {
|
|
36
|
+
/**
|
|
37
|
+
* Defines the processing logs sent to CloudWatch Logs and the logging level to send.
|
|
38
|
+
*/
|
|
39
|
+
readonly dagProcessingLogs?: ModuleLoggingConfiguration;
|
|
40
|
+
/**
|
|
41
|
+
* Defines the scheduler logs sent to CloudWatch Logs and the logging level to send.
|
|
42
|
+
*/
|
|
43
|
+
readonly schedulerLogs?: ModuleLoggingConfiguration;
|
|
44
|
+
/**
|
|
45
|
+
* Defines the task logs sent to CloudWatch Logs and the logging level to send.
|
|
46
|
+
*/
|
|
47
|
+
readonly taskLogs?: ModuleLoggingConfiguration;
|
|
48
|
+
/**
|
|
49
|
+
* Defines the web server logs sent to CloudWatch Logs and the logging level to send.
|
|
50
|
+
*/
|
|
51
|
+
readonly webServerLogs?: ModuleLoggingConfiguration;
|
|
52
|
+
/**
|
|
53
|
+
* Defines the worker logs sent to CloudWatch Logs and the logging level to send.
|
|
54
|
+
*/
|
|
55
|
+
readonly workerLogs?: ModuleLoggingConfiguration;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* The VPC networking components used to secure and enable network traffic between the AWS resources for your environment.
|
|
59
|
+
*/
|
|
60
|
+
export interface NetworkConfiguration {
|
|
61
|
+
/**
|
|
62
|
+
* A list of one or more security groups. Accepts up to 5 security groups. A security group must be attached to the same VPC as the subnets.
|
|
63
|
+
*/
|
|
64
|
+
readonly securityGroups?: ISecurityGroup[];
|
|
65
|
+
/**
|
|
66
|
+
* A list of subnets. Required to create an environment. Must be private subnets in two different availability zones.
|
|
67
|
+
* A subnet must be attached to the same VPC as the security group.
|
|
68
|
+
*/
|
|
69
|
+
readonly subnets?: ISubnet[];
|
|
70
|
+
}
|
|
71
|
+
export declare enum AirflowVersion {
|
|
72
|
+
V2_7_2 = "2.7.2",
|
|
73
|
+
V2_8_1 = "2.8.1",
|
|
74
|
+
V2_9_2 = "2.9.2",
|
|
75
|
+
V2_10_1 = "2.10.1",
|
|
76
|
+
V2_10_3 = "2.10.3",
|
|
77
|
+
V3_0_6 = "3.0.6"
|
|
78
|
+
}
|
|
79
|
+
export declare enum EndpointManagement {
|
|
80
|
+
CUSTOMER = "CUSTOMER",
|
|
81
|
+
SERVICE = "SERVICE"
|
|
82
|
+
}
|
|
83
|
+
export declare enum EnvironmentClass {
|
|
84
|
+
MW1_MICRO = "mw1.micro",
|
|
85
|
+
MW1_SMALL = "mw1.small",
|
|
86
|
+
MW1_MEDIUM = "mw1.medium",
|
|
87
|
+
MW1_LARGE = "mw1.large",
|
|
88
|
+
MW1_1LARGE = "mw1.1large",
|
|
89
|
+
MW1_2LARGE = "mw1.2large"
|
|
90
|
+
}
|
|
91
|
+
export declare enum WebserverAccessMode {
|
|
92
|
+
PRIVATE_ONLY = "PRIVATE_ONLY",
|
|
93
|
+
PUBLIC_ONLY = "PUBLIC_ONLY"
|
|
94
|
+
}
|
|
95
|
+
export declare enum WorkerReplacementStrategy {
|
|
96
|
+
FORCED = "FORCED",
|
|
97
|
+
GRACEFUL = "GRACEFUL"
|
|
98
|
+
}
|
|
99
|
+
export interface IEnvironment extends IResource {
|
|
100
|
+
/**
|
|
101
|
+
* A list of key-value pairs containing the Airflow configuration options for your environment. For example, core.default_timezone: utc.
|
|
102
|
+
*/
|
|
103
|
+
readonly airflowConfigurationOptions: {
|
|
104
|
+
[key: string]: string;
|
|
105
|
+
};
|
|
106
|
+
/**
|
|
107
|
+
* The version of Apache Airflow to use for the environment. If no value is specified, defaults to the latest version.
|
|
108
|
+
*
|
|
109
|
+
* If you specify a newer version number for an existing environment, the version update requires some service interruption before taking effect.
|
|
110
|
+
*/
|
|
111
|
+
readonly airflowVersion?: AirflowVersion;
|
|
112
|
+
/**
|
|
113
|
+
* The relative path to the DAGs folder on your Amazon S3 bucket. For example, dags.
|
|
114
|
+
*/
|
|
115
|
+
readonly dagS3Path?: string;
|
|
116
|
+
/**
|
|
117
|
+
* Defines whether the VPC endpoints configured for the environment are created, and managed, by the customer or by Amazon MWAA.
|
|
118
|
+
* If set to SERVICE, Amazon MWAA will create and manage the required VPC endpoints in your VPC.
|
|
119
|
+
* If set to CUSTOMER, you must create, and manage, the VPC endpoints in your VPC.
|
|
120
|
+
*/
|
|
121
|
+
readonly endpointManagement?: EndpointManagement;
|
|
122
|
+
/**
|
|
123
|
+
* The environment class type.
|
|
124
|
+
*/
|
|
125
|
+
readonly environmentClass?: EnvironmentClass;
|
|
126
|
+
/**
|
|
127
|
+
* The execution role in IAM that allows MWAA to access AWS resources in your environment.
|
|
128
|
+
*/
|
|
129
|
+
readonly executionRole?: IRole;
|
|
130
|
+
/**
|
|
131
|
+
* The AWS Key Management Service (KMS) key to encrypt and decrypt the data in your environment.
|
|
132
|
+
* You can use an AWS KMS key managed by MWAA, or a customer-managed KMS key (advanced).
|
|
133
|
+
*/
|
|
134
|
+
readonly kmsKey?: IKey;
|
|
135
|
+
/**
|
|
136
|
+
* The Apache Airflow logs being sent to CloudWatch Logs.
|
|
137
|
+
*/
|
|
138
|
+
readonly loggingConfiguration?: LoggingConfiguration;
|
|
139
|
+
/**
|
|
140
|
+
* The maximum number of web servers that you want to run in your environment.
|
|
141
|
+
* Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache
|
|
142
|
+
* Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. For example, in scenarios where your workload requires network
|
|
143
|
+
* calls to the Apache Airflow REST API with a high transaction-per-second (TPS) rate, Amazon MWAA will increase the number of web servers up to
|
|
144
|
+
* the number set in MaxWebserers. As TPS rates decrease Amazon MWAA disposes of the additional web servers, and scales down to the number set in
|
|
145
|
+
* MinxWebserers.
|
|
146
|
+
*
|
|
147
|
+
* Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,
|
|
148
|
+
* which defaults to 1.
|
|
149
|
+
*/
|
|
150
|
+
readonly maxWebservers?: number;
|
|
151
|
+
/**
|
|
152
|
+
* The maximum number of workers that you want to run in your environment.
|
|
153
|
+
* MWAA scales the number of Apache Airflow workers up to the number you specify in the MaxWorkers field. For example, 20. When there are no more
|
|
154
|
+
* tasks running, and no more in the queue, MWAA disposes of the extra workers leaving the one worker that is included with your environment, or
|
|
155
|
+
* the number you specify in MinWorkers.
|
|
156
|
+
*/
|
|
157
|
+
readonly maxWorkers?: number;
|
|
158
|
+
/**
|
|
159
|
+
* The minimum number of web servers that you want to run in your environment.
|
|
160
|
+
* Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache
|
|
161
|
+
* Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. As the transaction-per-second rate, and the network load,
|
|
162
|
+
* decrease, Amazon MWAA disposes of the additional web servers, and scales down to the number set in MinxWebserers.
|
|
163
|
+
*
|
|
164
|
+
* Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,
|
|
165
|
+
* which defaults to 1.
|
|
166
|
+
*/
|
|
167
|
+
readonly minWebservers?: number;
|
|
168
|
+
/**
|
|
169
|
+
* The minimum number of workers that you want to run in your environment. MWAA scales the number of Apache Airflow workers up to the number you
|
|
170
|
+
* specify in the MaxWorkers field. When there are no more tasks running, and no more in the queue, MWAA disposes of the extra workers leaving
|
|
171
|
+
* the worker count you specify in the MinWorkers field. For example, 2.
|
|
172
|
+
*/
|
|
173
|
+
readonly minWorkers?: number;
|
|
174
|
+
/**
|
|
175
|
+
* The name of your Amazon MWAA environment.
|
|
176
|
+
*/
|
|
177
|
+
readonly name: string;
|
|
178
|
+
/**
|
|
179
|
+
* The VPC networking components used to secure and enable network traffic between the AWS resources for your environment.
|
|
180
|
+
*/
|
|
181
|
+
readonly networkConfiguration?: NetworkConfiguration;
|
|
182
|
+
/**
|
|
183
|
+
* The version of the plugins.zip file on your Amazon S3 bucket.
|
|
184
|
+
*/
|
|
185
|
+
readonly pluginsS3ObjectVersion?: string;
|
|
186
|
+
/**
|
|
187
|
+
* The relative path to the plugins.zip file on your Amazon S3 bucket. For example, plugins.zip.
|
|
188
|
+
*/
|
|
189
|
+
readonly pluginsS3Path?: string;
|
|
190
|
+
/**
|
|
191
|
+
* The version of the requirements.txt file on your Amazon S3 bucket.
|
|
192
|
+
*/
|
|
193
|
+
readonly requirementsS3ObjectVersion?: string;
|
|
194
|
+
/**
|
|
195
|
+
* The relative path to the requirements.txt file on your Amazon S3 bucket. For example, requirements.txt.
|
|
196
|
+
*/
|
|
197
|
+
readonly requirementsS3Path?: string;
|
|
198
|
+
/**
|
|
199
|
+
* The number of schedulers that you want to run in your environment.
|
|
200
|
+
*
|
|
201
|
+
* Valid values:
|
|
202
|
+
* v2 - For environments larger than mw1.micro, accepts values from 2 to 5.
|
|
203
|
+
* Defaults to 2 for all environment sizes except mw1.micro, which defaults to 1.
|
|
204
|
+
* v1 - Accepts 1.
|
|
205
|
+
*/
|
|
206
|
+
readonly schedulers?: number;
|
|
207
|
+
/**
|
|
208
|
+
* The Amazon S3 bucket where your DAG code and supporting files are stored.
|
|
209
|
+
*/
|
|
210
|
+
readonly sourceBucket?: IBucket;
|
|
211
|
+
/**
|
|
212
|
+
* The version of the startup shell script in your Amazon S3 bucket.
|
|
213
|
+
* You must specify the version ID that Amazon S3 assigns to the file every time you update the script.
|
|
214
|
+
* Version IDs are Unicode, UTF-8 encoded, URL-ready, opaque strings that are no more than 1,024 bytes long.
|
|
215
|
+
*
|
|
216
|
+
* The following is an example:
|
|
217
|
+
* 3sL4kqtJlcpXroDTDmJ+rmSpXd3dIbrHY+MTRCxf3vjVBH40Nr8X8gdRQBpUMLUo
|
|
218
|
+
*/
|
|
219
|
+
readonly startupScriptS3ObjectVersion?: string;
|
|
220
|
+
/**
|
|
221
|
+
* The relative path to the startup shell script in your Amazon S3 bucket.
|
|
222
|
+
* For example, s3://mwaa-environment/startup.sh.
|
|
223
|
+
* Amazon MWAA runs the script as your environment starts, and before running the Apache Airflow process.
|
|
224
|
+
* You can use this script to install dependencies, modify Apache Airflow configuration options, and set environment variables.
|
|
225
|
+
*/
|
|
226
|
+
readonly startupScriptS3Path?: string;
|
|
227
|
+
/**
|
|
228
|
+
* The Apache Airflow Web server access mode.
|
|
229
|
+
*/
|
|
230
|
+
readonly webserverAccessMode?: WebserverAccessMode;
|
|
231
|
+
/**
|
|
232
|
+
* The day and time of the week to start weekly maintenance updates of your environment in the following format: DAY:HH:MM.
|
|
233
|
+
* For example: TUE:03:30. You can specify a start time in 30 minute increments only.
|
|
234
|
+
*
|
|
235
|
+
* Supported input includes the following:
|
|
236
|
+
* MON|TUE|WED|THU|FRI|SAT|SUN:([01]\\d|2[0-3]):(00|30)
|
|
237
|
+
*/
|
|
238
|
+
readonly weeklyMaintenanceWindowStart?: string;
|
|
239
|
+
/**
|
|
240
|
+
* The ARN for the Amazon MWAA environment.
|
|
241
|
+
*/
|
|
242
|
+
readonly environmentArn: string;
|
|
243
|
+
/**
|
|
244
|
+
* The queue ARN for the environment's Celery Executor. Amazon MWAA uses a Celery Executor to distribute tasks across multiple workers.
|
|
245
|
+
* When you create an environment in a shared VPC, you must provide access to the Celery Executor queue from your VPC.
|
|
246
|
+
*/
|
|
247
|
+
readonly celeryExecutorQueue?: string;
|
|
248
|
+
/**
|
|
249
|
+
* The VPC endpoint for the environment's Amazon RDS database.
|
|
250
|
+
*/
|
|
251
|
+
readonly databaseVpcEndpointService?: string;
|
|
252
|
+
/**
|
|
253
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow DAG processing logs are published.
|
|
254
|
+
*/
|
|
255
|
+
readonly loggingConfigurationDagProcessingLogsCloudWatchLogGroupArn?: string;
|
|
256
|
+
/**
|
|
257
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow Scheduler logs are published.
|
|
258
|
+
*/
|
|
259
|
+
readonly loggingConfigurationSchedulerLogsCloudWatchLogGroupArn?: string;
|
|
260
|
+
/**
|
|
261
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow task logs are published.
|
|
262
|
+
*/
|
|
263
|
+
readonly loggingConfigurationTaskLogsCloudWatchLogGroupArn?: string;
|
|
264
|
+
/**
|
|
265
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow Web server logs are published.
|
|
266
|
+
*/
|
|
267
|
+
readonly loggingConfigurationWebserverLogsCloudWatchLogGroupArn?: string;
|
|
268
|
+
/**
|
|
269
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow Worker logs are published.
|
|
270
|
+
*/
|
|
271
|
+
readonly loggingConfigurationWorkerLogsCloudWatchLogGroupArn?: string;
|
|
272
|
+
/**
|
|
273
|
+
* The URL of your Apache Airflow UI.
|
|
274
|
+
*/
|
|
275
|
+
readonly webserverUrl?: string;
|
|
276
|
+
/**
|
|
277
|
+
* The VPC endpoint for the environment's web server.
|
|
278
|
+
*/
|
|
279
|
+
readonly webserverVpcEndpointService?: string;
|
|
280
|
+
}
|
|
281
|
+
export declare abstract class EnvironmentBase extends Resource implements IEnvironment {
|
|
282
|
+
/**
|
|
283
|
+
* A list of key-value pairs containing the Airflow configuration options for your environment. For example, core.default_timezone: utc.
|
|
284
|
+
*/
|
|
285
|
+
abstract readonly airflowConfigurationOptions: {
|
|
286
|
+
[key: string]: string;
|
|
287
|
+
};
|
|
288
|
+
/**
|
|
289
|
+
* The version of Apache Airflow to use for the environment. If no value is specified, defaults to the latest version.
|
|
290
|
+
*
|
|
291
|
+
* If you specify a newer version number for an existing environment, the version update requires some service interruption before taking effect.
|
|
292
|
+
*/
|
|
293
|
+
abstract readonly airflowVersion?: AirflowVersion;
|
|
294
|
+
/**
|
|
295
|
+
* The relative path to the DAGs folder on your Amazon S3 bucket. For example, dags.
|
|
296
|
+
*/
|
|
297
|
+
abstract readonly dagS3Path?: string;
|
|
298
|
+
/**
|
|
299
|
+
* Defines whether the VPC endpoints configured for the environment are created, and managed, by the customer or by Amazon MWAA.
|
|
300
|
+
* If set to SERVICE, Amazon MWAA will create and manage the required VPC endpoints in your VPC.
|
|
301
|
+
* If set to CUSTOMER, you must create, and manage, the VPC endpoints in your VPC.
|
|
302
|
+
*/
|
|
303
|
+
abstract readonly endpointManagement?: EndpointManagement;
|
|
304
|
+
/**
|
|
305
|
+
* The environment class type.
|
|
306
|
+
*/
|
|
307
|
+
abstract readonly environmentClass?: EnvironmentClass;
|
|
308
|
+
/**
|
|
309
|
+
* The execution role in IAM that allows MWAA to access AWS resources in your environment.
|
|
310
|
+
*/
|
|
311
|
+
abstract readonly executionRole?: IRole;
|
|
312
|
+
/**
|
|
313
|
+
* The AWS Key Management Service (KMS) key to encrypt and decrypt the data in your environment.
|
|
314
|
+
* You can use an AWS KMS key managed by MWAA, or a customer-managed KMS key (advanced).
|
|
315
|
+
*/
|
|
316
|
+
abstract readonly kmsKey?: IKey;
|
|
317
|
+
/**
|
|
318
|
+
* The Apache Airflow logs being sent to CloudWatch Logs.
|
|
319
|
+
*/
|
|
320
|
+
abstract readonly loggingConfiguration?: LoggingConfiguration;
|
|
321
|
+
/**
|
|
322
|
+
* The maximum number of web servers that you want to run in your environment.
|
|
323
|
+
* Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache
|
|
324
|
+
* Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. For example, in scenarios where your workload requires network
|
|
325
|
+
* calls to the Apache Airflow REST API with a high transaction-per-second (TPS) rate, Amazon MWAA will increase the number of web servers up to
|
|
326
|
+
* the number set in MaxWebserers. As TPS rates decrease Amazon MWAA disposes of the additional web servers, and scales down to the number set in
|
|
327
|
+
* MinxWebserers.
|
|
328
|
+
*
|
|
329
|
+
* Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,
|
|
330
|
+
* which defaults to 1.
|
|
331
|
+
*/
|
|
332
|
+
abstract readonly maxWebservers?: number;
|
|
333
|
+
/**
|
|
334
|
+
* The maximum number of workers that you want to run in your environment.
|
|
335
|
+
* MWAA scales the number of Apache Airflow workers up to the number you specify in the MaxWorkers field. For example, 20. When there are no more
|
|
336
|
+
* tasks running, and no more in the queue, MWAA disposes of the extra workers leaving the one worker that is included with your environment, or
|
|
337
|
+
* the number you specify in MinWorkers.
|
|
338
|
+
*/
|
|
339
|
+
abstract readonly maxWorkers?: number;
|
|
340
|
+
/**
|
|
341
|
+
* The minimum number of web servers that you want to run in your environment.
|
|
342
|
+
* Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache
|
|
343
|
+
* Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. As the transaction-per-second rate, and the network load,
|
|
344
|
+
* decrease, Amazon MWAA disposes of the additional web servers, and scales down to the number set in MinxWebserers.
|
|
345
|
+
*
|
|
346
|
+
* Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,
|
|
347
|
+
* which defaults to 1.
|
|
348
|
+
*/
|
|
349
|
+
abstract readonly minWebservers?: number;
|
|
350
|
+
/**
|
|
351
|
+
* The minimum number of workers that you want to run in your environment. MWAA scales the number of Apache Airflow workers up to the number you
|
|
352
|
+
* specify in the MaxWorkers field. When there are no more tasks running, and no more in the queue, MWAA disposes of the extra workers leaving
|
|
353
|
+
* the worker count you specify in the MinWorkers field. For example, 2.
|
|
354
|
+
*/
|
|
355
|
+
abstract readonly minWorkers?: number;
|
|
356
|
+
/**
|
|
357
|
+
* The name of your Amazon MWAA environment.
|
|
358
|
+
*/
|
|
359
|
+
abstract readonly name: string;
|
|
360
|
+
/**
|
|
361
|
+
* The VPC networking components used to secure and enable network traffic between the AWS resources for your environment.
|
|
362
|
+
*/
|
|
363
|
+
abstract readonly networkConfiguration?: NetworkConfiguration;
|
|
364
|
+
/**
|
|
365
|
+
* The version of the plugins.zip file on your Amazon S3 bucket.
|
|
366
|
+
*/
|
|
367
|
+
abstract readonly pluginsS3ObjectVersion?: string;
|
|
368
|
+
/**
|
|
369
|
+
* The relative path to the plugins.zip file on your Amazon S3 bucket. For example, plugins.zip.
|
|
370
|
+
*/
|
|
371
|
+
abstract readonly pluginsS3Path?: string;
|
|
372
|
+
/**
|
|
373
|
+
* The version of the requirements.txt file on your Amazon S3 bucket.
|
|
374
|
+
*/
|
|
375
|
+
abstract readonly requirementsS3ObjectVersion?: string;
|
|
376
|
+
/**
|
|
377
|
+
* The relative path to the requirements.txt file on your Amazon S3 bucket. For example, requirements.txt.
|
|
378
|
+
*/
|
|
379
|
+
abstract readonly requirementsS3Path?: string;
|
|
380
|
+
/**
|
|
381
|
+
* The number of schedulers that you want to run in your environment.
|
|
382
|
+
*
|
|
383
|
+
* Valid values:
|
|
384
|
+
* v2 - For environments larger than mw1.micro, accepts values from 2 to 5.
|
|
385
|
+
* Defaults to 2 for all environment sizes except mw1.micro, which defaults to 1.
|
|
386
|
+
* v1 - Accepts 1.
|
|
387
|
+
*/
|
|
388
|
+
abstract readonly schedulers?: number;
|
|
389
|
+
/**
|
|
390
|
+
* The Amazon S3 bucket where your DAG code and supporting files are stored.
|
|
391
|
+
*/
|
|
392
|
+
abstract readonly sourceBucket?: IBucket;
|
|
393
|
+
/**
|
|
394
|
+
* The version of the startup shell script in your Amazon S3 bucket.
|
|
395
|
+
* You must specify the version ID that Amazon S3 assigns to the file every time you update the script.
|
|
396
|
+
* Version IDs are Unicode, UTF-8 encoded, URL-ready, opaque strings that are no more than 1,024 bytes long.
|
|
397
|
+
*
|
|
398
|
+
* The following is an example:
|
|
399
|
+
* 3sL4kqtJlcpXroDTDmJ+rmSpXd3dIbrHY+MTRCxf3vjVBH40Nr8X8gdRQBpUMLUo
|
|
400
|
+
*/
|
|
401
|
+
abstract readonly startupScriptS3ObjectVersion?: string;
|
|
402
|
+
/**
|
|
403
|
+
* The relative path to the startup shell script in your Amazon S3 bucket.
|
|
404
|
+
* For example, s3://mwaa-environment/startup.sh.
|
|
405
|
+
* Amazon MWAA runs the script as your environment starts, and before running the Apache Airflow process.
|
|
406
|
+
* You can use this script to install dependencies, modify Apache Airflow configuration options, and set environment variables.
|
|
407
|
+
*/
|
|
408
|
+
abstract readonly startupScriptS3Path?: string;
|
|
409
|
+
/**
|
|
410
|
+
* The Apache Airflow Web server access mode.
|
|
411
|
+
*/
|
|
412
|
+
abstract readonly webserverAccessMode?: WebserverAccessMode;
|
|
413
|
+
/**
|
|
414
|
+
* The day and time of the week to start weekly maintenance updates of your environment in the following format: DAY:HH:MM.
|
|
415
|
+
* For example: TUE:03:30. You can specify a start time in 30 minute increments only.
|
|
416
|
+
*
|
|
417
|
+
* Supported input includes the following:
|
|
418
|
+
* MON|TUE|WED|THU|FRI|SAT|SUN:([01]\\d|2[0-3]):(00|30)
|
|
419
|
+
*/
|
|
420
|
+
abstract readonly weeklyMaintenanceWindowStart?: string;
|
|
421
|
+
/**
|
|
422
|
+
* The ARN for the Amazon MWAA environment.
|
|
423
|
+
*/
|
|
424
|
+
abstract readonly environmentArn: string;
|
|
425
|
+
/**
|
|
426
|
+
* The queue ARN for the environment's Celery Executor. Amazon MWAA uses a Celery Executor to distribute tasks across multiple workers.
|
|
427
|
+
* When you create an environment in a shared VPC, you must provide access to the Celery Executor queue from your VPC.
|
|
428
|
+
*/
|
|
429
|
+
abstract readonly celeryExecutorQueue?: string;
|
|
430
|
+
/**
|
|
431
|
+
* The VPC endpoint for the environment's Amazon RDS database.
|
|
432
|
+
*/
|
|
433
|
+
abstract readonly databaseVpcEndpointService?: string;
|
|
434
|
+
/**
|
|
435
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow DAG processing logs are published.
|
|
436
|
+
*/
|
|
437
|
+
abstract readonly loggingConfigurationDagProcessingLogsCloudWatchLogGroupArn?: string;
|
|
438
|
+
/**
|
|
439
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow Scheduler logs are published.
|
|
440
|
+
*/
|
|
441
|
+
abstract readonly loggingConfigurationSchedulerLogsCloudWatchLogGroupArn?: string;
|
|
442
|
+
/**
|
|
443
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow task logs are published.
|
|
444
|
+
*/
|
|
445
|
+
abstract readonly loggingConfigurationTaskLogsCloudWatchLogGroupArn?: string;
|
|
446
|
+
/**
|
|
447
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow Web server logs are published.
|
|
448
|
+
*/
|
|
449
|
+
abstract readonly loggingConfigurationWebserverLogsCloudWatchLogGroupArn?: string;
|
|
450
|
+
/**
|
|
451
|
+
* The ARN for the CloudWatch Logs group where the Apache Airflow Worker logs are published.
|
|
452
|
+
*/
|
|
453
|
+
abstract readonly loggingConfigurationWorkerLogsCloudWatchLogGroupArn?: string;
|
|
454
|
+
/**
|
|
455
|
+
* The URL of your Apache Airflow UI.
|
|
456
|
+
*/
|
|
457
|
+
abstract readonly webserverUrl?: string;
|
|
458
|
+
/**
|
|
459
|
+
* The VPC endpoint for the environment's web server.
|
|
460
|
+
*/
|
|
461
|
+
abstract readonly webserverVpcEndpointService?: string;
|
|
462
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.EnvironmentBase = exports.WorkerReplacementStrategy = exports.WebserverAccessMode = exports.EnvironmentClass = exports.EndpointManagement = exports.AirflowVersion = exports.LogLevel = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
|
+
var LogLevel;
|
|
8
|
+
(function (LogLevel) {
|
|
9
|
+
LogLevel["DEBUG"] = "DEBUG";
|
|
10
|
+
LogLevel["INFO"] = "INFO";
|
|
11
|
+
LogLevel["WARNING"] = "WARNING";
|
|
12
|
+
LogLevel["ERROR"] = "ERROR";
|
|
13
|
+
LogLevel["CRITICAL"] = "CRITICAL";
|
|
14
|
+
})(LogLevel || (exports.LogLevel = LogLevel = {}));
|
|
15
|
+
var AirflowVersion;
|
|
16
|
+
(function (AirflowVersion) {
|
|
17
|
+
AirflowVersion["V2_7_2"] = "2.7.2";
|
|
18
|
+
AirflowVersion["V2_8_1"] = "2.8.1";
|
|
19
|
+
AirflowVersion["V2_9_2"] = "2.9.2";
|
|
20
|
+
AirflowVersion["V2_10_1"] = "2.10.1";
|
|
21
|
+
AirflowVersion["V2_10_3"] = "2.10.3";
|
|
22
|
+
AirflowVersion["V3_0_6"] = "3.0.6";
|
|
23
|
+
})(AirflowVersion || (exports.AirflowVersion = AirflowVersion = {}));
|
|
24
|
+
var EndpointManagement;
|
|
25
|
+
(function (EndpointManagement) {
|
|
26
|
+
EndpointManagement["CUSTOMER"] = "CUSTOMER";
|
|
27
|
+
EndpointManagement["SERVICE"] = "SERVICE";
|
|
28
|
+
})(EndpointManagement || (exports.EndpointManagement = EndpointManagement = {}));
|
|
29
|
+
var EnvironmentClass;
|
|
30
|
+
(function (EnvironmentClass) {
|
|
31
|
+
EnvironmentClass["MW1_MICRO"] = "mw1.micro";
|
|
32
|
+
EnvironmentClass["MW1_SMALL"] = "mw1.small";
|
|
33
|
+
EnvironmentClass["MW1_MEDIUM"] = "mw1.medium";
|
|
34
|
+
EnvironmentClass["MW1_LARGE"] = "mw1.large";
|
|
35
|
+
EnvironmentClass["MW1_1LARGE"] = "mw1.1large";
|
|
36
|
+
EnvironmentClass["MW1_2LARGE"] = "mw1.2large";
|
|
37
|
+
})(EnvironmentClass || (exports.EnvironmentClass = EnvironmentClass = {}));
|
|
38
|
+
var WebserverAccessMode;
|
|
39
|
+
(function (WebserverAccessMode) {
|
|
40
|
+
WebserverAccessMode["PRIVATE_ONLY"] = "PRIVATE_ONLY";
|
|
41
|
+
WebserverAccessMode["PUBLIC_ONLY"] = "PUBLIC_ONLY";
|
|
42
|
+
})(WebserverAccessMode || (exports.WebserverAccessMode = WebserverAccessMode = {}));
|
|
43
|
+
var WorkerReplacementStrategy;
|
|
44
|
+
(function (WorkerReplacementStrategy) {
|
|
45
|
+
WorkerReplacementStrategy["FORCED"] = "FORCED";
|
|
46
|
+
WorkerReplacementStrategy["GRACEFUL"] = "GRACEFUL";
|
|
47
|
+
})(WorkerReplacementStrategy || (exports.WorkerReplacementStrategy = WorkerReplacementStrategy = {}));
|
|
48
|
+
class EnvironmentBase extends aws_cdk_lib_1.Resource {
|
|
49
|
+
}
|
|
50
|
+
exports.EnvironmentBase = EnvironmentBase;
|
|
51
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
52
|
+
EnvironmentBase[_a] = { fqn: "@robhan-cdk-lib/aws_mwaa.EnvironmentBase", version: "0.0.0" };
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment-base.js","sourceRoot":"","sources":["../src/environment-base.ts"],"names":[],"mappings":";;;;;AAAA,6CAAkD;AAOlD,IAAY,QAMX;AAND,WAAY,QAAQ;IAClB,2BAAe,CAAA;IACf,yBAAa,CAAA;IACb,+BAAmB,CAAA;IACnB,2BAAe,CAAA;IACf,iCAAqB,CAAA;AACvB,CAAC,EANW,QAAQ,wBAAR,QAAQ,QAMnB;AAqED,IAAY,cAOX;AAPD,WAAY,cAAc;IACxB,kCAAgB,CAAA;IAChB,kCAAgB,CAAA;IAChB,kCAAgB,CAAA;IAChB,oCAAkB,CAAA;IAClB,oCAAkB,CAAA;IAClB,kCAAgB,CAAA;AAClB,CAAC,EAPW,cAAc,8BAAd,cAAc,QAOzB;AAED,IAAY,kBAGX;AAHD,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;IACrB,yCAAmB,CAAA;AACrB,CAAC,EAHW,kBAAkB,kCAAlB,kBAAkB,QAG7B;AAED,IAAY,gBAOX;AAPD,WAAY,gBAAgB;IAC1B,2CAAuB,CAAA;IACvB,2CAAuB,CAAA;IACvB,6CAAyB,CAAA;IACzB,2CAAuB,CAAA;IACvB,6CAAyB,CAAA;IACzB,6CAAyB,CAAA;AAC3B,CAAC,EAPW,gBAAgB,gCAAhB,gBAAgB,QAO3B;AAED,IAAY,mBAGX;AAHD,WAAY,mBAAmB;IAC7B,oDAA6B,CAAA;IAC7B,kDAA2B,CAAA;AAC7B,CAAC,EAHW,mBAAmB,mCAAnB,mBAAmB,QAG9B;AAED,IAAY,yBAGX;AAHD,WAAY,yBAAyB;IACnC,8CAAiB,CAAA;IACjB,kDAAqB,CAAA;AACvB,CAAC,EAHW,yBAAyB,yCAAzB,yBAAyB,QAGpC;AAyND,MAAsB,eAAgB,SAAQ,sBAAQ;;AAAtD,0CAoNC","sourcesContent":["import { IResource, Resource } from 'aws-cdk-lib';\nimport { ISecurityGroup, ISubnet } from 'aws-cdk-lib/aws-ec2';\nimport { IRole } from 'aws-cdk-lib/aws-iam';\nimport { IKey } from 'aws-cdk-lib/aws-kms';\nimport { ILogGroup } from 'aws-cdk-lib/aws-logs';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\n\nexport enum LogLevel {\n  DEBUG = 'DEBUG',\n  INFO = 'INFO',\n  WARNING = 'WARNING',\n  ERROR = 'ERROR',\n  CRITICAL = 'CRITICAL',\n}\n\n/**\n * Defines the type of logs to send for the Apache Airflow log type\n * (e.g. DagProcessingLogs).\n */\nexport interface ModuleLoggingConfiguration {\n  /**\n   * The CloudWatch Logs log group for each type ofApache Airflow log type that you have enabled.\n   */\n  readonly cloudWatchLogGroup?: ILogGroup;\n\n  /**\n   * Indicates whether to enable the Apache Airflow log type (e.g. DagProcessingLogs) in CloudWatch Logs.\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * Defines the Apache Airflow logs to send for the log type (e.g. DagProcessingLogs) to CloudWatch Logs.\n   */\n  readonly logLevel?: LogLevel;\n}\n\n/**\n * The type of Apache Airflow logs to send to CloudWatch Logs.\n */\nexport interface LoggingConfiguration {\n  /**\n   * Defines the processing logs sent to CloudWatch Logs and the logging level to send.\n   */\n  readonly dagProcessingLogs?: ModuleLoggingConfiguration;\n\n  /**\n   * Defines the scheduler logs sent to CloudWatch Logs and the logging level to send.\n   */\n  readonly schedulerLogs?: ModuleLoggingConfiguration;\n\n  /**\n   * Defines the task logs sent to CloudWatch Logs and the logging level to send.\n   */\n  readonly taskLogs?: ModuleLoggingConfiguration;\n\n  /**\n   * Defines the web server logs sent to CloudWatch Logs and the logging level to send.\n   */\n  readonly webServerLogs?: ModuleLoggingConfiguration;\n\n  /**\n   * Defines the worker logs sent to CloudWatch Logs and the logging level to send.\n   */\n  readonly workerLogs?: ModuleLoggingConfiguration;\n}\n\n/**\n * The VPC networking components used to secure and enable network traffic between the AWS resources for your environment.\n */\nexport interface NetworkConfiguration {\n  /**\n   * A list of one or more security groups. Accepts up to 5 security groups. A security group must be attached to the same VPC as the subnets.\n   */\n  readonly securityGroups?: ISecurityGroup[];\n\n  /**\n   * A list of subnets. Required to create an environment. Must be private subnets in two different availability zones.\n   * A subnet must be attached to the same VPC as the security group.\n   */\n  readonly subnets?: ISubnet[];\n}\n\nexport enum AirflowVersion {\n  V2_7_2 = '2.7.2',\n  V2_8_1 = '2.8.1',\n  V2_9_2 = '2.9.2',\n  V2_10_1 = '2.10.1',\n  V2_10_3 = '2.10.3',\n  V3_0_6 = '3.0.6',\n}\n\nexport enum EndpointManagement {\n  CUSTOMER = 'CUSTOMER',\n  SERVICE = 'SERVICE',\n}\n\nexport enum EnvironmentClass {\n  MW1_MICRO = 'mw1.micro',\n  MW1_SMALL = 'mw1.small',\n  MW1_MEDIUM = 'mw1.medium',\n  MW1_LARGE = 'mw1.large',\n  MW1_1LARGE = 'mw1.1large',\n  MW1_2LARGE = 'mw1.2large',\n}\n\nexport enum WebserverAccessMode {\n  PRIVATE_ONLY = 'PRIVATE_ONLY',\n  PUBLIC_ONLY = 'PUBLIC_ONLY',\n}\n\nexport enum WorkerReplacementStrategy {\n  FORCED = 'FORCED',\n  GRACEFUL = 'GRACEFUL',\n}\n\n\nexport interface IEnvironment extends IResource {\n  /**\n   * A list of key-value pairs containing the Airflow configuration options for your environment. For example, core.default_timezone: utc.\n   */\n  readonly airflowConfigurationOptions: { [key: string]: string };\n\n  /**\n   * The version of Apache Airflow to use for the environment. If no value is specified, defaults to the latest version.\n   *\n   * If you specify a newer version number for an existing environment, the version update requires some service interruption before taking effect.\n   */\n  readonly airflowVersion?: AirflowVersion;\n\n  /**\n   * The relative path to the DAGs folder on your Amazon S3 bucket. For example, dags.\n   */\n  readonly dagS3Path?: string;\n\n  /**\n   * Defines whether the VPC endpoints configured for the environment are created, and managed, by the customer or by Amazon MWAA.\n   * If set to SERVICE, Amazon MWAA will create and manage the required VPC endpoints in your VPC.\n   * If set to CUSTOMER, you must create, and manage, the VPC endpoints in your VPC.\n   */\n  readonly endpointManagement?: EndpointManagement;\n\n  /**\n   * The environment class type.\n   */\n  readonly environmentClass?: EnvironmentClass;\n\n  /**\n   * The execution role in IAM that allows MWAA to access AWS resources in your environment.\n   */\n  readonly executionRole?: IRole;\n\n  /**\n   * The AWS Key Management Service (KMS) key to encrypt and decrypt the data in your environment.\n   * You can use an AWS KMS key managed by MWAA, or a customer-managed KMS key (advanced).\n   */\n  readonly kmsKey?: IKey;\n\n  /**\n   * The Apache Airflow logs being sent to CloudWatch Logs.\n   */\n  readonly loggingConfiguration?: LoggingConfiguration;\n\n  /**\n   * The maximum number of web servers that you want to run in your environment.\n   * Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache\n   * Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. For example, in scenarios where your workload requires network\n   * calls to the Apache Airflow REST API with a high transaction-per-second (TPS) rate, Amazon MWAA will increase the number of web servers up to\n   * the number set in MaxWebserers. As TPS rates decrease Amazon MWAA disposes of the additional web servers, and scales down to the number set in\n   * MinxWebserers.\n   *\n   * Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,\n   * which defaults to 1.\n   */\n  readonly maxWebservers?: number;\n\n  /**\n   * The maximum number of workers that you want to run in your environment.\n   * MWAA scales the number of Apache Airflow workers up to the number you specify in the MaxWorkers field. For example, 20. When there are no more\n   * tasks running, and no more in the queue, MWAA disposes of the extra workers leaving the one worker that is included with your environment, or\n   * the number you specify in MinWorkers.\n   */\n  readonly maxWorkers?: number;\n\n  /**\n   * The minimum number of web servers that you want to run in your environment.\n   * Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache\n   * Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. As the transaction-per-second rate, and the network load,\n   * decrease, Amazon MWAA disposes of the additional web servers, and scales down to the number set in MinxWebserers.\n   *\n   * Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,\n   * which defaults to 1.\n   */\n  readonly minWebservers?: number;\n\n  /**\n   * The minimum number of workers that you want to run in your environment. MWAA scales the number of Apache Airflow workers up to the number you\n   * specify in the MaxWorkers field. When there are no more tasks running, and no more in the queue, MWAA disposes of the extra workers leaving\n   * the worker count you specify in the MinWorkers field. For example, 2.\n   */\n  readonly minWorkers?: number;\n\n  /**\n   * The name of your Amazon MWAA environment.\n   */\n  readonly name: string;\n\n  /**\n   * The VPC networking components used to secure and enable network traffic between the AWS resources for your environment.\n   */\n  readonly networkConfiguration?: NetworkConfiguration;\n\n  /**\n   * The version of the plugins.zip file on your Amazon S3 bucket.\n   */\n  readonly pluginsS3ObjectVersion?: string;\n\n  /**\n   * The relative path to the plugins.zip file on your Amazon S3 bucket. For example, plugins.zip.\n   */\n  readonly pluginsS3Path?: string;\n\n  /**\n   * The version of the requirements.txt file on your Amazon S3 bucket.\n   */\n  readonly requirementsS3ObjectVersion?: string;\n\n  /**\n   * The relative path to the requirements.txt file on your Amazon S3 bucket. For example, requirements.txt.\n   */\n  readonly requirementsS3Path?: string;\n\n  /**\n   * The number of schedulers that you want to run in your environment.\n   *\n   * Valid values:\n   * v2 - For environments larger than mw1.micro, accepts values from 2 to 5.\n   *      Defaults to 2 for all environment sizes except mw1.micro, which defaults to 1.\n   * v1 - Accepts 1.\n   */\n  readonly schedulers?: number;\n\n  /**\n   * The Amazon S3 bucket where your DAG code and supporting files are stored.\n   */\n  readonly sourceBucket?: IBucket;\n\n  /**\n   * The version of the startup shell script in your Amazon S3 bucket.\n   * You must specify the version ID that Amazon S3 assigns to the file every time you update the script.\n   * Version IDs are Unicode, UTF-8 encoded, URL-ready, opaque strings that are no more than 1,024 bytes long.\n   *\n   * The following is an example:\n   *      3sL4kqtJlcpXroDTDmJ+rmSpXd3dIbrHY+MTRCxf3vjVBH40Nr8X8gdRQBpUMLUo\n   */\n  readonly startupScriptS3ObjectVersion?: string;\n\n  /**\n   * The relative path to the startup shell script in your Amazon S3 bucket.\n   * For example, s3://mwaa-environment/startup.sh.\n   * Amazon MWAA runs the script as your environment starts, and before running the Apache Airflow process.\n   * You can use this script to install dependencies, modify Apache Airflow configuration options, and set environment variables.\n   */\n  readonly startupScriptS3Path?: string;\n\n  /**\n   * The Apache Airflow Web server access mode.\n   */\n  readonly webserverAccessMode?: WebserverAccessMode;\n\n  /**\n   * The day and time of the week to start weekly maintenance updates of your environment in the following format: DAY:HH:MM.\n   * For example: TUE:03:30. You can specify a start time in 30 minute increments only.\n   *\n   * Supported input includes the following:\n   *      MON|TUE|WED|THU|FRI|SAT|SUN:([01]\\\\d|2[0-3]):(00|30)\n   */\n  readonly weeklyMaintenanceWindowStart?: string;\n\n  /**\n   * The ARN for the Amazon MWAA environment.\n   */\n  readonly environmentArn: string;\n\n  /**\n   * The queue ARN for the environment's Celery Executor. Amazon MWAA uses a Celery Executor to distribute tasks across multiple workers.\n   * When you create an environment in a shared VPC, you must provide access to the Celery Executor queue from your VPC.\n   */\n  readonly celeryExecutorQueue?: string;\n\n  /**\n   * The VPC endpoint for the environment's Amazon RDS database.\n   */\n  readonly databaseVpcEndpointService?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow DAG processing logs are published.\n   */\n  readonly loggingConfigurationDagProcessingLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow Scheduler logs are published.\n   */\n  readonly loggingConfigurationSchedulerLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow task logs are published.\n   */\n  readonly loggingConfigurationTaskLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow Web server logs are published.\n   */\n  readonly loggingConfigurationWebserverLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow Worker logs are published.\n   */\n  readonly loggingConfigurationWorkerLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The URL of your Apache Airflow UI.\n   */\n  readonly webserverUrl?: string;\n\n  /**\n   * The VPC endpoint for the environment's web server.\n   */\n  readonly webserverVpcEndpointService?: string;\n}\n\nexport abstract class EnvironmentBase extends Resource implements IEnvironment {\n  /**\n   * A list of key-value pairs containing the Airflow configuration options for your environment. For example, core.default_timezone: utc.\n   */\n  public abstract readonly airflowConfigurationOptions: { [key: string]: string };\n\n  /**\n   * The version of Apache Airflow to use for the environment. If no value is specified, defaults to the latest version.\n   *\n   * If you specify a newer version number for an existing environment, the version update requires some service interruption before taking effect.\n   */\n  public abstract readonly airflowVersion?: AirflowVersion;\n\n  /**\n   * The relative path to the DAGs folder on your Amazon S3 bucket. For example, dags.\n   */\n  public abstract readonly dagS3Path?: string;\n\n  /**\n   * Defines whether the VPC endpoints configured for the environment are created, and managed, by the customer or by Amazon MWAA.\n   * If set to SERVICE, Amazon MWAA will create and manage the required VPC endpoints in your VPC.\n   * If set to CUSTOMER, you must create, and manage, the VPC endpoints in your VPC.\n   */\n  public abstract readonly endpointManagement?: EndpointManagement;\n\n  /**\n   * The environment class type.\n   */\n  public abstract readonly environmentClass?: EnvironmentClass;\n\n  /**\n   * The execution role in IAM that allows MWAA to access AWS resources in your environment.\n   */\n  public abstract readonly executionRole?: IRole;\n\n  /**\n   * The AWS Key Management Service (KMS) key to encrypt and decrypt the data in your environment.\n   * You can use an AWS KMS key managed by MWAA, or a customer-managed KMS key (advanced).\n   */\n  public abstract readonly kmsKey?: IKey;\n\n  /**\n   * The Apache Airflow logs being sent to CloudWatch Logs.\n   */\n  public abstract readonly loggingConfiguration?: LoggingConfiguration;\n\n  /**\n   * The maximum number of web servers that you want to run in your environment.\n   * Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache\n   * Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. For example, in scenarios where your workload requires network\n   * calls to the Apache Airflow REST API with a high transaction-per-second (TPS) rate, Amazon MWAA will increase the number of web servers up to\n   * the number set in MaxWebserers. As TPS rates decrease Amazon MWAA disposes of the additional web servers, and scales down to the number set in\n   * MinxWebserers.\n   *\n   * Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,\n   * which defaults to 1.\n   */\n  public abstract readonly maxWebservers?: number;\n\n  /**\n   * The maximum number of workers that you want to run in your environment.\n   * MWAA scales the number of Apache Airflow workers up to the number you specify in the MaxWorkers field. For example, 20. When there are no more\n   * tasks running, and no more in the queue, MWAA disposes of the extra workers leaving the one worker that is included with your environment, or\n   * the number you specify in MinWorkers.\n   */\n  public abstract readonly maxWorkers?: number;\n\n  /**\n   * The minimum number of web servers that you want to run in your environment.\n   * Amazon MWAA scales the number of Apache Airflow web servers up to the number you specify for MaxWebservers when you interact with your Apache\n   * Airflow environment using Apache Airflow REST API, or the Apache Airflow CLI. As the transaction-per-second rate, and the network load,\n   * decrease, Amazon MWAA disposes of the additional web servers, and scales down to the number set in MinxWebserers.\n   *\n   * Valid values: For environments larger than mw1.micro, accepts values from 2 to 5. Defaults to 2 for all environment sizes except mw1.micro,\n   * which defaults to 1.\n   */\n  public abstract readonly minWebservers?: number;\n\n  /**\n   * The minimum number of workers that you want to run in your environment. MWAA scales the number of Apache Airflow workers up to the number you\n   * specify in the MaxWorkers field. When there are no more tasks running, and no more in the queue, MWAA disposes of the extra workers leaving\n   * the worker count you specify in the MinWorkers field. For example, 2.\n   */\n  public abstract readonly minWorkers?: number;\n\n  /**\n   * The name of your Amazon MWAA environment.\n   */\n  public abstract readonly name: string;\n\n  /**\n   * The VPC networking components used to secure and enable network traffic between the AWS resources for your environment.\n   */\n  public abstract readonly networkConfiguration?: NetworkConfiguration;\n\n  /**\n   * The version of the plugins.zip file on your Amazon S3 bucket.\n   */\n  public abstract readonly pluginsS3ObjectVersion?: string;\n\n  /**\n   * The relative path to the plugins.zip file on your Amazon S3 bucket. For example, plugins.zip.\n   */\n  public abstract readonly pluginsS3Path?: string;\n\n  /**\n   * The version of the requirements.txt file on your Amazon S3 bucket.\n   */\n  public abstract readonly requirementsS3ObjectVersion?: string;\n\n  /**\n   * The relative path to the requirements.txt file on your Amazon S3 bucket. For example, requirements.txt.\n   */\n  public abstract readonly requirementsS3Path?: string;\n\n  /**\n   * The number of schedulers that you want to run in your environment.\n   *\n   * Valid values:\n   * v2 - For environments larger than mw1.micro, accepts values from 2 to 5.\n   *      Defaults to 2 for all environment sizes except mw1.micro, which defaults to 1.\n   * v1 - Accepts 1.\n   */\n  public abstract readonly schedulers?: number;\n\n  /**\n   * The Amazon S3 bucket where your DAG code and supporting files are stored.\n   */\n  public abstract readonly sourceBucket?: IBucket;\n\n  /**\n   * The version of the startup shell script in your Amazon S3 bucket.\n   * You must specify the version ID that Amazon S3 assigns to the file every time you update the script.\n   * Version IDs are Unicode, UTF-8 encoded, URL-ready, opaque strings that are no more than 1,024 bytes long.\n   *\n   * The following is an example:\n   *      3sL4kqtJlcpXroDTDmJ+rmSpXd3dIbrHY+MTRCxf3vjVBH40Nr8X8gdRQBpUMLUo\n   */\n  public abstract readonly startupScriptS3ObjectVersion?: string;\n\n  /**\n   * The relative path to the startup shell script in your Amazon S3 bucket.\n   * For example, s3://mwaa-environment/startup.sh.\n   * Amazon MWAA runs the script as your environment starts, and before running the Apache Airflow process.\n   * You can use this script to install dependencies, modify Apache Airflow configuration options, and set environment variables.\n   */\n  public abstract readonly startupScriptS3Path?: string;\n\n  /**\n   * The Apache Airflow Web server access mode.\n   */\n  public abstract readonly webserverAccessMode?: WebserverAccessMode;\n\n  /**\n   * The day and time of the week to start weekly maintenance updates of your environment in the following format: DAY:HH:MM.\n   * For example: TUE:03:30. You can specify a start time in 30 minute increments only.\n   *\n   * Supported input includes the following:\n   *      MON|TUE|WED|THU|FRI|SAT|SUN:([01]\\\\d|2[0-3]):(00|30)\n   */\n  public abstract readonly weeklyMaintenanceWindowStart?: string;\n\n  /**\n   * The ARN for the Amazon MWAA environment.\n   */\n  public abstract readonly environmentArn: string;\n\n  /**\n   * The queue ARN for the environment's Celery Executor. Amazon MWAA uses a Celery Executor to distribute tasks across multiple workers.\n   * When you create an environment in a shared VPC, you must provide access to the Celery Executor queue from your VPC.\n   */\n  public abstract readonly celeryExecutorQueue?: string;\n\n  /**\n   * The VPC endpoint for the environment's Amazon RDS database.\n   */\n  public abstract readonly databaseVpcEndpointService?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow DAG processing logs are published.\n   */\n  public abstract readonly loggingConfigurationDagProcessingLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow Scheduler logs are published.\n   */\n  public abstract readonly loggingConfigurationSchedulerLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow task logs are published.\n   */\n  public abstract readonly loggingConfigurationTaskLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow Web server logs are published.\n   */\n  public abstract readonly loggingConfigurationWebserverLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The ARN for the CloudWatch Logs group where the Apache Airflow Worker logs are published.\n   */\n  public abstract readonly loggingConfigurationWorkerLogsCloudWatchLogGroupArn?: string;\n\n  /**\n   * The URL of your Apache Airflow UI.\n   */\n  public abstract readonly webserverUrl?: string;\n\n  /**\n   * The VPC endpoint for the environment's web server.\n   */\n  public abstract readonly webserverVpcEndpointService?: string;\n}\n"]}
|