@aws-mdaa/datawarehouse 1.3.0 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -3
- package/SCHEMA.md +7457 -546
- package/lib/config-schema.json +2730 -212
- package/lib/datawarehouse-config.d.ts +143 -148
- package/lib/datawarehouse-config.js +2 -2
- package/package.json +19 -20
|
@@ -9,282 +9,277 @@ import { Stack } from 'aws-cdk-lib';
|
|
|
9
9
|
import { ConfigurationElement } from '@aws-mdaa/config';
|
|
10
10
|
export interface DataWarehouseConfigContents extends MdaaBaseConfigContents {
|
|
11
11
|
/**
|
|
12
|
-
*
|
|
13
|
-
* Required admin username for the Redshift cluster providing administrative access to the data warehouse. Defines the master user account for cluster administration, database management, and initial user provisioning.
|
|
12
|
+
* Admin username for the Redshift cluster. A secret is automatically generated for the password.
|
|
14
13
|
*
|
|
15
14
|
* Use cases: Cluster administration; Database management; Initial user provisioning
|
|
16
15
|
*
|
|
17
|
-
* AWS:
|
|
16
|
+
* AWS: Redshift cluster master username
|
|
18
17
|
*
|
|
19
|
-
* Validation:
|
|
20
|
-
|
|
18
|
+
* Validation: Required; valid Redshift username
|
|
19
|
+
*/
|
|
21
20
|
readonly adminUsername: string;
|
|
22
21
|
/**
|
|
23
|
-
*
|
|
24
|
-
* Required number of days between automatic admin password rotations for enhanced security compliance. Enables automated credential management and compliance with password rotation policies for improved cluster security posture.
|
|
22
|
+
* Days between automatic admin password rotations via Secrets Manager.
|
|
25
23
|
*
|
|
26
|
-
* Use cases: Automated credential rotation; Security
|
|
24
|
+
* Use cases: Automated credential rotation; Security compliance; Password policy enforcement
|
|
27
25
|
*
|
|
28
|
-
* AWS:
|
|
26
|
+
* AWS: Redshift admin password rotation via Secrets Manager
|
|
29
27
|
*
|
|
30
|
-
* Validation:
|
|
31
|
-
|
|
28
|
+
* Validation: Required; positive integer
|
|
29
|
+
*/
|
|
32
30
|
readonly adminPasswordRotationDays: number;
|
|
33
31
|
/**
|
|
34
|
-
*
|
|
35
|
-
*
|
|
32
|
+
* SAML or OIDC federation configurations for federated Redshift access.
|
|
33
|
+
* Each federation creates an IAM role with SAML trust for dynamic credential generation
|
|
34
|
+
* and group-based cluster access.
|
|
36
35
|
*
|
|
37
|
-
* Use cases: SAML federation setup;
|
|
36
|
+
* Use cases: SAML federation setup; SSO integration; Federated cluster access
|
|
38
37
|
*
|
|
39
|
-
* AWS:
|
|
38
|
+
* AWS: IAM SAML identity provider roles for Redshift federated access
|
|
40
39
|
*
|
|
41
|
-
* Validation:
|
|
42
|
-
|
|
40
|
+
* Validation: Optional; array of valid FederationProps
|
|
41
|
+
*/
|
|
43
42
|
readonly federations?: FederationProps[];
|
|
44
43
|
/**
|
|
45
|
-
*
|
|
46
|
-
* Required array of admin role references with full access to cluster resources including KMS keys and S3 buckets. Provides administrative permissions for data warehouse management, security administration, and resource access control.
|
|
44
|
+
* Admin roles granted full access to cluster resources including KMS keys and S3 buckets.
|
|
47
45
|
*
|
|
48
46
|
* Use cases: Administrative access control; Security management; Resource administration
|
|
49
47
|
*
|
|
50
|
-
* AWS:
|
|
48
|
+
* AWS: IAM roles with full Redshift cluster and resource access
|
|
51
49
|
*
|
|
52
|
-
* Validation:
|
|
53
|
-
|
|
50
|
+
* Validation: Required; array of valid MdaaRoleRef
|
|
51
|
+
*/
|
|
54
52
|
readonly dataAdminRoles: MdaaRoleRef[];
|
|
55
53
|
/**
|
|
56
|
-
*
|
|
57
|
-
* Optional array of user role references with access to data warehouse S3 buckets for data loading and unloading operations. Enables controlled access to warehouse storage resources for ETL operations and data management workflows.
|
|
54
|
+
* Roles granted read/write access to the data warehouse S3 bucket for data loading/unloading.
|
|
58
55
|
*
|
|
59
|
-
* Use cases:
|
|
56
|
+
* Use cases: ETL data loading; Data unloading operations; Bucket access for analytics
|
|
60
57
|
*
|
|
61
|
-
* AWS:
|
|
58
|
+
* AWS: IAM roles with S3 bucket access for Redshift data operations
|
|
62
59
|
*
|
|
63
|
-
* Validation:
|
|
64
|
-
|
|
60
|
+
* Validation: Optional; array of valid MdaaRoleRef
|
|
61
|
+
*/
|
|
65
62
|
readonly warehouseBucketUserRoles?: MdaaRoleRef[];
|
|
66
63
|
/**
|
|
67
|
-
*
|
|
68
|
-
*
|
|
64
|
+
* External execution roles associated with the Redshift cluster for cross-service operations.
|
|
65
|
+
* If a role also needs warehouse bucket access, add it to warehouseBucketUserRoles explicitly.
|
|
69
66
|
*
|
|
70
|
-
* Use cases: Cross-service
|
|
67
|
+
* Use cases: Cross-service integrations; External data access; Glue/Lambda integration
|
|
71
68
|
*
|
|
72
|
-
* AWS:
|
|
69
|
+
* AWS: IAM execution roles associated with the Redshift cluster
|
|
73
70
|
*
|
|
74
|
-
* Validation:
|
|
75
|
-
|
|
71
|
+
* Validation: Optional; array of valid MdaaRoleRef; roles must be assumable by Redshift
|
|
72
|
+
*/
|
|
76
73
|
readonly executionRoles?: MdaaRoleRef[];
|
|
77
74
|
/**
|
|
78
|
-
*
|
|
79
|
-
*
|
|
75
|
+
* VPC ID for Redshift cluster deployment. The cluster is deployed within this VPC
|
|
76
|
+
* with network access controlled by security groups.
|
|
80
77
|
*
|
|
81
|
-
* Use cases:
|
|
78
|
+
* Use cases: Network isolation; VPC-based deployment; Secure networking
|
|
82
79
|
*
|
|
83
|
-
* AWS:
|
|
80
|
+
* AWS: VPC for Redshift cluster network configuration
|
|
84
81
|
*
|
|
85
|
-
* Validation:
|
|
86
|
-
|
|
82
|
+
* Validation: Required; valid VPC ID
|
|
83
|
+
*/
|
|
87
84
|
readonly vpcId: string;
|
|
88
85
|
/**
|
|
89
|
-
*
|
|
90
|
-
*
|
|
86
|
+
* Subnet IDs for Redshift cluster node placement. For automatic cluster relocation,
|
|
87
|
+
* specify at least one subnet per AZ.
|
|
91
88
|
*
|
|
92
|
-
* Use cases:
|
|
89
|
+
* Use cases: Multi-AZ placement; Subnet-specific deployment; Cluster relocation support
|
|
93
90
|
*
|
|
94
|
-
* AWS:
|
|
91
|
+
* AWS: VPC subnets for Redshift subnet group
|
|
95
92
|
*
|
|
96
|
-
* Validation:
|
|
97
|
-
|
|
93
|
+
* Validation: Required; array of valid subnet IDs in the specified VPC
|
|
94
|
+
*/
|
|
98
95
|
readonly subnetIds: string[];
|
|
99
96
|
/**
|
|
100
|
-
*
|
|
101
|
-
*
|
|
97
|
+
* Security group ingress rules defining allowed inbound connections to the cluster port.
|
|
98
|
+
* Supports IPv4 CIDR blocks and security group references. All other traffic is blocked.
|
|
102
99
|
*
|
|
103
100
|
* Use cases: Network access control; Client connectivity; Security group management
|
|
104
101
|
*
|
|
105
|
-
* AWS:
|
|
102
|
+
* AWS: VPC security group ingress rules for Redshift cluster
|
|
106
103
|
*
|
|
107
|
-
* Validation:
|
|
108
|
-
|
|
104
|
+
* Validation: Required; object with optional ipv4 and/or sg arrays
|
|
105
|
+
*/
|
|
109
106
|
readonly securityGroupIngress: {
|
|
110
107
|
ipv4?: string[];
|
|
111
108
|
sg?: string[];
|
|
112
109
|
};
|
|
113
110
|
/**
|
|
114
|
-
*
|
|
115
|
-
* Required node type specification determining compute and storage capacity for cluster nodes. Controls the underlying EC2 instance type and affects performance, storage, and cost characteristics of the data warehouse.
|
|
111
|
+
* Redshift node type determining compute and storage capacity (e.g., RA3_4XLARGE).
|
|
116
112
|
*
|
|
117
|
-
* Use cases: Performance
|
|
113
|
+
* Use cases: Performance sizing; Cost optimization; Workload-specific capacity
|
|
118
114
|
*
|
|
119
|
-
* AWS:
|
|
115
|
+
* AWS: Redshift node type (instance type)
|
|
120
116
|
*
|
|
121
|
-
* Validation:
|
|
122
|
-
|
|
117
|
+
* Validation: Required; valid Redshift node type string
|
|
118
|
+
*/
|
|
123
119
|
readonly nodeType: string;
|
|
124
120
|
/**
|
|
125
|
-
*
|
|
126
|
-
* Required number of nodes for the Redshift cluster determining total compute capacity and parallel processing capability. Controls cluster size and affects performance, cost, and data distribution characteristics.
|
|
121
|
+
* Number of nodes in the Redshift cluster.
|
|
127
122
|
*
|
|
128
|
-
* Use cases: Cluster sizing; Performance scaling; Cost
|
|
123
|
+
* Use cases: Cluster sizing; Performance scaling; Cost management
|
|
129
124
|
*
|
|
130
|
-
* AWS:
|
|
125
|
+
* AWS: Redshift cluster node count
|
|
131
126
|
*
|
|
132
|
-
* Validation:
|
|
133
|
-
|
|
127
|
+
* Validation: Required; positive integer
|
|
128
|
+
*/
|
|
134
129
|
readonly numberOfNodes: number;
|
|
135
130
|
/**
|
|
136
|
-
*
|
|
137
|
-
*
|
|
131
|
+
* Enable audit logging to a dedicated S3 bucket. The audit bucket uses SSE-S3 encryption
|
|
132
|
+
* (not KMS) due to Redshift audit logging requirements.
|
|
138
133
|
*
|
|
139
|
-
* Use cases: Compliance auditing; Security monitoring;
|
|
134
|
+
* Use cases: Compliance auditing; Security monitoring; User activity tracking
|
|
140
135
|
*
|
|
141
|
-
* AWS:
|
|
136
|
+
* AWS: Redshift audit logging to S3 with SSE-S3 encryption
|
|
142
137
|
*
|
|
143
|
-
* Validation:
|
|
144
|
-
|
|
138
|
+
* Validation: Required; boolean
|
|
139
|
+
*/
|
|
145
140
|
readonly enableAuditLoggingToS3: boolean;
|
|
146
141
|
/**
|
|
147
|
-
*
|
|
148
|
-
* Optional cluster port number for client connections enabling custom port configuration and network security. Defines the TCP port on which the Redshift cluster accepts client connections, supporting custom networking requirements and security configurations.
|
|
142
|
+
* TCP port for client connections to the cluster.
|
|
149
143
|
*
|
|
150
|
-
* Use cases: Custom port configuration; Network security;
|
|
144
|
+
* Use cases: Custom port configuration; Network security; Port standardization
|
|
151
145
|
*
|
|
152
|
-
* AWS:
|
|
146
|
+
* AWS: Redshift cluster listening port
|
|
153
147
|
*
|
|
154
|
-
* Validation:
|
|
155
|
-
|
|
148
|
+
* Validation: Optional; valid port number
|
|
149
|
+
* @default 5440
|
|
150
|
+
*/
|
|
156
151
|
readonly clusterPort?: number;
|
|
157
152
|
/**
|
|
158
|
-
*
|
|
159
|
-
*
|
|
153
|
+
* Multi-node cluster flag. When true, creates a multi-node cluster for distributed processing;
|
|
154
|
+
* when false, creates a single-node cluster for development or small workloads.
|
|
160
155
|
*
|
|
161
|
-
* Use cases: Cluster architecture selection;
|
|
156
|
+
* Use cases: Cluster architecture selection; Dev vs production deployment; Cost optimization
|
|
162
157
|
*
|
|
163
|
-
* AWS:
|
|
158
|
+
* AWS: Redshift cluster type (single-node or multi-node)
|
|
164
159
|
*
|
|
165
|
-
* Validation:
|
|
166
|
-
|
|
160
|
+
* Validation: Optional; boolean
|
|
161
|
+
*/
|
|
167
162
|
readonly multiNode?: boolean;
|
|
168
163
|
/**
|
|
169
|
-
*
|
|
170
|
-
*
|
|
164
|
+
* Weekly maintenance window in ddd:hh24:mi-ddd:hh24:mi format (UTC).
|
|
165
|
+
* Example: 'Sun:23:45-Mon:00:15'.
|
|
171
166
|
*
|
|
172
|
-
* Use cases: Maintenance scheduling; Business continuity;
|
|
167
|
+
* Use cases: Maintenance scheduling; Business continuity; Downtime management
|
|
173
168
|
*
|
|
174
|
-
* AWS:
|
|
169
|
+
* AWS: Redshift preferred maintenance window
|
|
175
170
|
*
|
|
176
|
-
* Validation:
|
|
177
|
-
|
|
171
|
+
* Validation: Required; valid time window format
|
|
172
|
+
*/
|
|
178
173
|
readonly preferredMaintenanceWindow: string;
|
|
179
174
|
/**
|
|
180
|
-
*
|
|
181
|
-
*
|
|
175
|
+
* Additional cluster parameter group parameters for performance tuning.
|
|
176
|
+
* Security-sensitive values are automatically overridden for compliance (e.g., SSL enforcement).
|
|
182
177
|
*
|
|
183
|
-
* Use cases: Performance tuning;
|
|
178
|
+
* Use cases: Performance tuning; Custom cluster configuration; Workload optimization
|
|
184
179
|
*
|
|
185
|
-
* AWS:
|
|
180
|
+
* AWS: Redshift parameter group parameters
|
|
186
181
|
*
|
|
187
|
-
* Validation:
|
|
188
|
-
|
|
182
|
+
* Validation: Optional; string key-value pairs
|
|
183
|
+
*/
|
|
189
184
|
readonly parameterGroupParams?: Record<string, string>;
|
|
190
185
|
/**
|
|
191
|
-
*
|
|
192
|
-
* Optional workload management configuration for query performance optimization and resource allocation. Defines WLM configuration elements for managing query queues, memory allocation, and concurrency for optimal cluster performance.
|
|
186
|
+
* Workload management (WLM) configuration for query queue management and resource allocation.
|
|
193
187
|
*
|
|
194
|
-
* Use cases: Query performance optimization;
|
|
188
|
+
* Use cases: Query performance optimization; Concurrency control; Resource allocation
|
|
195
189
|
*
|
|
196
|
-
* AWS:
|
|
190
|
+
* AWS: Redshift WLM configuration
|
|
197
191
|
*
|
|
198
|
-
* Validation:
|
|
199
|
-
|
|
192
|
+
* Validation: Optional; array of valid ConfigurationElement
|
|
193
|
+
*/
|
|
200
194
|
readonly workloadManagement?: ConfigurationElement[];
|
|
201
195
|
/**
|
|
202
|
-
*
|
|
203
|
-
*
|
|
196
|
+
* Additional KMS key ARNs allowed to write to the cluster bucket.
|
|
197
|
+
* Useful for allowing Glue jobs or other services to write encrypted data to the warehouse bucket.
|
|
204
198
|
*
|
|
205
|
-
* Use cases:
|
|
199
|
+
* Use cases: Cross-service encryption; Glue job integration; Multi-key bucket access
|
|
206
200
|
*
|
|
207
|
-
* AWS:
|
|
201
|
+
* AWS: KMS key ARNs for warehouse bucket encryption
|
|
208
202
|
*
|
|
209
|
-
* Validation:
|
|
210
|
-
|
|
203
|
+
* Validation: Optional; array of valid KMS key ARNs
|
|
204
|
+
*/
|
|
211
205
|
readonly additionalBucketKmsKeyArns?: string[];
|
|
212
206
|
/**
|
|
213
|
-
*
|
|
214
|
-
*
|
|
207
|
+
* Scheduled actions for automated cluster pause/resume operations.
|
|
208
|
+
* Each action specifies a target action (pauseCluster/resumeCluster), cron schedule,
|
|
209
|
+
* and active time window.
|
|
215
210
|
*
|
|
216
|
-
* Use cases: Cost optimization; Automated operations;
|
|
211
|
+
* Use cases: Cost optimization via scheduled pause; Automated operations; Business-hours scheduling
|
|
217
212
|
*
|
|
218
|
-
* AWS:
|
|
213
|
+
* AWS: Redshift scheduled actions for cluster lifecycle management
|
|
219
214
|
*
|
|
220
|
-
* Validation:
|
|
221
|
-
|
|
215
|
+
* Validation: Optional; array of valid ScheduledActionProps
|
|
216
|
+
*/
|
|
222
217
|
readonly scheduledActions?: ScheduledActionProps[];
|
|
223
218
|
/**
|
|
224
|
-
*
|
|
225
|
-
*
|
|
219
|
+
* Database users created in Redshift with credentials stored in Secrets Manager.
|
|
220
|
+
* Supports automated secret rotation on a configurable cycle.
|
|
226
221
|
*
|
|
227
|
-
* Use cases: Automated user provisioning; Credential management;
|
|
222
|
+
* Use cases: Automated user provisioning; Credential management; Secret rotation
|
|
228
223
|
*
|
|
229
|
-
* AWS:
|
|
224
|
+
* AWS: Redshift database users with Secrets Manager credential storage and rotation
|
|
230
225
|
*
|
|
231
|
-
* Validation:
|
|
232
|
-
|
|
226
|
+
* Validation: Optional; array of valid DatabaseUsersProps
|
|
227
|
+
*/
|
|
233
228
|
readonly databaseUsers?: DatabaseUsersProps[];
|
|
234
229
|
/**
|
|
235
|
-
*
|
|
236
|
-
*
|
|
230
|
+
* Control whether a dedicated S3 bucket is created for warehouse data operations
|
|
231
|
+
* (loading, unloading, backup).
|
|
237
232
|
*
|
|
238
|
-
* Use cases: Storage resource management; Data operations;
|
|
233
|
+
* Use cases: Storage resource management; Data operations; Bucket lifecycle control
|
|
239
234
|
*
|
|
240
|
-
* AWS:
|
|
235
|
+
* AWS: S3 bucket for Redshift data warehouse operations
|
|
241
236
|
*
|
|
242
|
-
* Validation:
|
|
243
|
-
|
|
237
|
+
* Validation: Optional; boolean
|
|
238
|
+
* @default true
|
|
239
|
+
*/
|
|
244
240
|
readonly createWarehouseBucket?: boolean;
|
|
245
241
|
/**
|
|
246
|
-
*
|
|
247
|
-
* Optional retention period for automated snapshots enabling backup management and data protection. Specifies the number of days automated snapshots are retained for point-in-time recovery and data protection requirements.
|
|
242
|
+
* Number of days automated snapshots are retained (1-35). Set to 0 to disable.
|
|
248
243
|
*
|
|
249
|
-
* Use cases: Backup management;
|
|
244
|
+
* Use cases: Backup management; Point-in-time recovery; Data protection compliance
|
|
250
245
|
*
|
|
251
|
-
* AWS:
|
|
246
|
+
* AWS: Redshift automated snapshot retention
|
|
252
247
|
*
|
|
253
|
-
* Validation:
|
|
254
|
-
|
|
248
|
+
* Validation: Optional; integer 0-35
|
|
249
|
+
* @default 1
|
|
250
|
+
*/
|
|
255
251
|
readonly automatedSnapshotRetentionDays?: number;
|
|
256
252
|
/**
|
|
257
|
-
*
|
|
258
|
-
*
|
|
253
|
+
* Event notification configuration for cluster and scheduled action monitoring.
|
|
254
|
+
* Configures SNS notifications with email delivery, severity filtering, and event category selection.
|
|
259
255
|
*
|
|
260
|
-
* Use cases: Operational monitoring; Event alerting; Cluster status tracking
|
|
256
|
+
* Use cases: Operational monitoring; Event alerting; Cluster status tracking
|
|
261
257
|
*
|
|
262
|
-
* AWS:
|
|
258
|
+
* AWS: SNS notifications for Redshift cluster events
|
|
263
259
|
*
|
|
264
|
-
* Validation:
|
|
265
|
-
|
|
260
|
+
* Validation: Optional; valid EventNotificationsProps
|
|
261
|
+
*/
|
|
266
262
|
readonly eventNotifications?: EventNotificationsProps;
|
|
267
263
|
/**
|
|
268
|
-
*
|
|
269
|
-
* Optional database name for initial database creation enabling custom database naming and organization. Specifies the name of the initial database created in the cluster, supporting custom naming conventions and database organization.
|
|
264
|
+
* Initial database name created in the cluster.
|
|
270
265
|
*
|
|
271
|
-
* Use cases: Custom database naming;
|
|
266
|
+
* Use cases: Custom database naming; Initial database setup
|
|
272
267
|
*
|
|
273
|
-
* AWS:
|
|
268
|
+
* AWS: Redshift initial database
|
|
274
269
|
*
|
|
275
|
-
* Validation:
|
|
276
|
-
|
|
270
|
+
* Validation: Optional; valid database name
|
|
271
|
+
* @default "default_db"
|
|
272
|
+
*/
|
|
277
273
|
readonly dbName?: string;
|
|
278
274
|
/**
|
|
279
|
-
*
|
|
280
|
-
* Optional snapshot identifier for cluster restoration from existing snapshot enabling disaster recovery and data migration. Specifies the snapshot ID to restore the cluster from, supporting disaster recovery scenarios and data migration operations.
|
|
275
|
+
* Snapshot identifier for cluster restoration. Only provide when restoring from an existing snapshot.
|
|
281
276
|
*
|
|
282
|
-
* Use cases: Disaster recovery; Data migration; Cluster restoration
|
|
277
|
+
* Use cases: Disaster recovery; Data migration; Cluster restoration
|
|
283
278
|
*
|
|
284
|
-
* AWS:
|
|
279
|
+
* AWS: Redshift snapshot for cluster restoration
|
|
285
280
|
*
|
|
286
|
-
* Validation:
|
|
287
|
-
|
|
281
|
+
* Validation: Optional; valid snapshot identifier
|
|
282
|
+
*/
|
|
288
283
|
readonly snapshotIdentifier?: string;
|
|
289
284
|
/**
|
|
290
285
|
* ownerAccount Refers to snapshot owner account. Applicable if restoring the cluster from snapshot and snapshot belongs to another account
|
|
@@ -316,7 +311,7 @@ export declare class DataWarehouseConfigParser extends MdaaAppConfigParser<DataW
|
|
|
316
311
|
readonly parameterGroupParams: Record<string, string>;
|
|
317
312
|
readonly workloadManagement: ConfigurationElement[];
|
|
318
313
|
readonly additionalBucketKmsKeyArns?: string[];
|
|
319
|
-
static readonly defaultClusterPort =
|
|
314
|
+
static readonly defaultClusterPort = 5440;
|
|
320
315
|
readonly scheduledActions: ScheduledActionProps[];
|
|
321
316
|
readonly createWarehouseBucket?: boolean;
|
|
322
317
|
readonly automatedSnapshotRetentionDays?: number;
|
|
@@ -44,5 +44,5 @@ class DataWarehouseConfigParser extends app_1.MdaaAppConfigParser {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
exports.DataWarehouseConfigParser = DataWarehouseConfigParser;
|
|
47
|
-
DataWarehouseConfigParser.defaultClusterPort =
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datawarehouse-config.js","sourceRoot":"","sources":["datawarehouse-config.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { MdaaAppConfigParser, MdaaAppConfigParserProps, MdaaBaseConfigContents } from '@aws-mdaa/app';\nimport {\n  FederationProps,\n  ScheduledActionProps,\n  DatabaseUsersProps,\n  EventNotificationsProps,\n} from '@aws-mdaa/datawarehouse-l3-construct';\nimport { MdaaRoleRef } from '@aws-mdaa/iam-role-helper';\nimport { Schema } from 'ajv';\nimport { Stack } from 'aws-cdk-lib';\nimport * as configSchema from './config-schema.json';\nimport { ConfigurationElement } from '@aws-mdaa/config';\n\nexport interface DataWarehouseConfigContents extends MdaaBaseConfigContents {\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required admin username for the Redshift cluster providing administrative access to the data warehouse. Defines the master user account for cluster administration, database management, and initial user provisioning.\n   *\n   * Use cases: Cluster administration; Database management; Initial user provisioning\n   *\n   * AWS: Amazon Redshift cluster master username for administrative access and database management\n   *\n   * Validation: Must be valid Redshift username; required; used for cluster administrative access\n   **/\n  readonly adminUsername: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required number of days between automatic admin password rotations for enhanced security compliance. Enables automated credential management and compliance with password rotation policies for improved cluster security posture.\n   *\n   * Use cases: Automated credential rotation; Security policy compliance; Password management automation\n   *\n   * AWS: Amazon Redshift automatic password rotation configuration for security management\n   *\n   * Validation: Must be positive integer; required; defines password rotation frequency for security compliance\n   **/\n  readonly adminPasswordRotationDays: number;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional array of federation configurations for SAML or OIDC identity provider integration with the data warehouse. Enables federated access to Redshift through external identity providers for centralized identity management and SSO capabilities.\n   *\n   * Use cases: SAML federation setup; OIDC provider integration; Centralized identity management for data warehouse access\n   *\n   * AWS: AWS IAM identity provider configuration for federated Redshift access and SSO integration\n   *\n   * Validation: Must be array of valid FederationProps if provided; enables federated authentication when specified\n   **/\n  readonly federations?: FederationProps[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required array of admin role references with full access to cluster resources including KMS keys and S3 buckets. Provides administrative permissions for data warehouse management, security administration, and resource access control.\n   *\n   * Use cases: Administrative access control; Security management; Resource administration\n   *\n   * AWS: AWS IAM roles with full Redshift cluster and resource access permissions\n   *\n   * Validation: Must be array of valid MdaaRoleRef objects; required; roles receive full cluster access\n   **/\n  readonly dataAdminRoles: MdaaRoleRef[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional array of user role references with access to data warehouse S3 buckets for data loading and unloading operations. Enables controlled access to warehouse storage resources for ETL operations and data management workflows.\n   *\n   * Use cases: Data loading operations; ETL workflow access; Controlled storage access\n   *\n   * AWS: AWS IAM roles with S3 bucket access for Redshift data operations\n   *\n   * Validation: Must be array of valid MdaaRoleRef objects if provided; roles receive bucket access permissions\n   **/\n  readonly warehouseBucketUserRoles?: MdaaRoleRef[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional array of external execution role references for Redshift cluster operations and integrations. Enables cluster to assume external roles for cross-service operations, data access, and integration with other AWS services.\n   *\n   * Use cases: Cross-service operations; External data access; Service integration workflows\n   *\n   * AWS: AWS IAM roles for Redshift cluster cross-service operations and integrations\n   *\n   * Validation: Must be array of valid MdaaRoleRef objects if provided; roles must be assumable by Redshift service\n   **/\n  readonly executionRoles?: MdaaRoleRef[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required VPC ID for Redshift cluster deployment providing network isolation and security controls. Ensures cluster operates within the specified VPC for secure networking and integration with other VPC resources.\n   *\n   * Use cases: VPC network isolation; Secure networking; VPC resource integration\n   *\n   * AWS: Amazon VPC for Redshift cluster network isolation and security controls\n   *\n   * Validation: Must be valid VPC ID; required; VPC must exist and be accessible\n   **/\n  readonly vpcId: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required array of subnet IDs for Redshift cluster node placement within the VPC. Defines the network subnets where cluster nodes will be deployed for secure VPC connectivity and availability zone distribution.\n   *\n   * Use cases: VPC network placement; Subnet-specific deployment; Multi-AZ cluster distribution\n   *\n   * AWS: Amazon VPC subnets for Redshift cluster node placement and network configuration\n   *\n   * Validation: Must be array of valid subnet IDs; required; subnets must exist in specified VPC\n   **/\n  readonly subnetIds: string[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required security group ingress configuration defining allowed inbound connections to the cluster. Specifies IPv4 CIDR blocks and security group IDs that can connect to the cluster port for controlled network access.\n   *\n   * Use cases: Network access control; Client connectivity; Security group management\n   *\n   * AWS: Amazon VPC security group ingress rules for Redshift cluster access control\n   *\n   * Validation: Must be object with ipv4 and/or sg arrays; required; defines allowed inbound connections\n   *   **/\n  readonly securityGroupIngress: { ipv4?: string[]; sg?: string[] };\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required node type specification determining compute and storage capacity for cluster nodes. Controls the underlying EC2 instance type and affects performance, storage, and cost characteristics of the data warehouse.\n   *\n   * Use cases: Performance optimization; Cost management; Workload-specific sizing\n   *\n   * AWS: Amazon Redshift node type for compute and storage capacity configuration\n   *\n   * Validation: Must be valid Redshift node type; required; determines cluster compute and storage capacity\n   **/\n  readonly nodeType: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required number of nodes for the Redshift cluster determining total compute capacity and parallel processing capability. Controls cluster size and affects performance, cost, and data distribution characteristics.\n   *\n   * Use cases: Cluster sizing; Performance scaling; Cost optimization\n   *\n   * AWS: Amazon Redshift cluster node count for compute capacity and parallel processing\n   *\n   * Validation: Must be positive integer; required; determines cluster size and processing capacity\n   **/\n  readonly numberOfNodes: number;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required flag enabling audit logging to S3 for compliance and security monitoring. When enabled, creates dedicated S3 bucket for Redshift audit logs with SSE-S3 encryption as required by Redshift audit logging constraints.\n   *\n   * Use cases: Compliance auditing; Security monitoring; Audit trail management\n   *\n   * AWS: Amazon Redshift audit logging to S3 for compliance and security monitoring\n   *\n   * Validation: Boolean value; required; creates SSE-S3 encrypted audit bucket when enabled\n   **/\n  readonly enableAuditLoggingToS3: boolean;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional cluster port number for client connections enabling custom port configuration and network security. Defines the TCP port on which the Redshift cluster accepts client connections, supporting custom networking requirements and security configurations.\n   *\n   * Use cases: Custom port configuration; Network security; Client connection management; Port standardization\n   *\n   * AWS: Amazon Redshift cluster port configuration for client connection management\n   *\n   * Validation: Must be valid port number if specified; defaults to 54390; must be accessible through security groups\n   **/\n  readonly clusterPort?: number;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional flag controlling cluster node configuration for single-node or multi-node deployment. When true, creates multi-node cluster for distributed processing; when false, creates single-node cluster for development or small workloads.\n   *\n   * Use cases: Cluster architecture selection; Development vs production deployment; Cost optimization; Performance scaling\n   *\n   * AWS: Amazon Redshift cluster type configuration for single-node or multi-node deployment\n   *\n   * Validation: Boolean value; determines cluster architecture and node distribution; affects performance and cost\n   **/\n  readonly multiNode?: boolean;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required preferred maintenance window for automated cluster maintenance operations. Specifies the weekly time range during which system maintenance can occur, minimizing impact on business operations and ensuring predictable maintenance scheduling.\n   *\n   * Use cases: Maintenance scheduling; Business continuity; Operational planning; Downtime management\n   *\n   * AWS: Amazon Redshift preferred maintenance window for automated system maintenance\n   *\n   * Validation: Must be valid time window format (e.g., 'Sun:23:45-Mon:00:15'); required; defines maintenance scheduling\n   **/\n  readonly preferredMaintenanceWindow: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional parameter group parameters for cluster configuration customization enabling performance tuning and operational optimization. Provides additional cluster parameters while security-sensitive values are automatically overridden for compliance and security.\n   *\n   * Use cases: Performance tuning; Operational optimization; Custom cluster configuration; Workload-specific settings\n   *\n   * AWS: Amazon Redshift parameter group configuration for cluster customization and optimization\n   *\n   * Validation: Must be object with string key-value pairs if provided; security-sensitive values will be overridden\n   *   **/\n  readonly parameterGroupParams?: Record<string, string>;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional workload management configuration for query performance optimization and resource allocation. Defines WLM configuration elements for managing query queues, memory allocation, and concurrency for optimal cluster performance.\n   *\n   * Use cases: Query performance optimization; Resource allocation; Workload management; Concurrency control\n   *\n   * AWS: Amazon Redshift workload management configuration for query optimization and resource control\n   *\n   * Validation: Must be array of valid ConfigurationElement objects if provided; defines WLM configuration\n   **/\n  readonly workloadManagement?: ConfigurationElement[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional additional KMS key ARNs for cluster bucket encryption enabling multi-key encryption scenarios and cross-account access. Provides additional KMS keys that can be used for writing to the cluster bucket beyond the default cluster encryption key.\n   *\n   * Use cases: Multi-key encryption; Cross-account access; Additional encryption keys; Flexible key management\n   *\n   * AWS: AWS KMS key ARNs for additional cluster bucket encryption and access control\n   *\n   * Validation: Must be array of valid KMS key ARNs if provided; keys must be accessible for bucket operations\n   **/\n  readonly additionalBucketKmsKeyArns?: string[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional scheduled actions for automated cluster pause and resume operations enabling cost optimization and operational automation. Defines scheduled pause and resume actions for the cluster to optimize costs during non-business hours.\n   *\n   * Use cases: Cost optimization; Automated operations; Scheduled maintenance; Resource management\n   *\n   * AWS: Amazon Redshift scheduled actions for automated cluster pause and resume operations\n   *\n   * Validation: Must be array of valid ScheduledActionProps if provided; defines automated cluster operations\n   **/\n  readonly scheduledActions?: ScheduledActionProps[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional database users for automated user creation and credential management enabling secure user provisioning and rotation. Creates database users in Redshift with automated credential storage and rotation through Secrets Manager and SSM.\n   *\n   * Use cases: Automated user provisioning; Credential management; Security automation; User lifecycle management\n   *\n   * AWS: Amazon Redshift database users with Secrets Manager and SSM integration for credential management\n   *\n   * Validation: Must be array of valid DatabaseUsersProps if provided; enables automated user and credential management\n   *   **/\n  readonly databaseUsers?: DatabaseUsersProps[];\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional flag controlling data warehouse bucket creation for cluster storage operations. When enabled (default), creates dedicated S3 bucket for data warehouse operations including data loading, unloading, and backup storage.\n   *\n   * Use cases: Storage resource management; Data operations; Backup storage; ETL operations\n   *\n   * AWS: Amazon S3 bucket creation for Redshift data warehouse storage operations\n   *\n   * Validation: Boolean value; defaults to true; creates dedicated warehouse bucket when enabled\n   **/\n  readonly createWarehouseBucket?: boolean;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional retention period for automated snapshots enabling backup management and data protection. Specifies the number of days automated snapshots are retained for point-in-time recovery and data protection requirements.\n   *\n   * Use cases: Backup management; Data protection; Point-in-time recovery; Compliance requirements\n   *\n   * AWS: Amazon Redshift automated snapshot retention for backup management and data protection\n   *\n   * Validation: Must be positive integer if specified; defines snapshot retention period for backup management\n   **/\n  readonly automatedSnapshotRetentionDays?: number;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional event notification configuration for cluster and scheduled action monitoring enabling operational awareness and alerting. Configures SNS notifications for cluster events and scheduled action status for operational monitoring.\n   *\n   * Use cases: Operational monitoring; Event alerting; Cluster status tracking; Automated notifications\n   *\n   * AWS: Amazon SNS notifications for Redshift cluster events and operational monitoring\n   *\n   * Validation: Must be valid EventNotificationsProps if provided; enables cluster event monitoring and alerting\n   **/\n  readonly eventNotifications?: EventNotificationsProps;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional database name for initial database creation enabling custom database naming and organization. Specifies the name of the initial database created in the cluster, supporting custom naming conventions and database organization.\n   *\n   * Use cases: Custom database naming; Database organization; Initial database setup; Naming conventions\n   *\n   * AWS: Amazon Redshift initial database name for cluster database creation and organization\n   *\n   * Validation: Must be valid database name if specified; defaults to \"default_db\"; used for initial database creation\n   **/\n  readonly dbName?: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional snapshot identifier for cluster restoration from existing snapshot enabling disaster recovery and data migration. Specifies the snapshot ID to restore the cluster from, supporting disaster recovery scenarios and data migration operations.\n   *\n   * Use cases: Disaster recovery; Data migration; Cluster restoration; Backup recovery\n   *\n   * AWS: Amazon Redshift snapshot identifier for cluster restoration and disaster recovery\n   *\n   * Validation: Must be valid snapshot identifier if specified; only provide when restoring from snapshot\n   **/\n  readonly snapshotIdentifier?: string;\n  /**\n   * ownerAccount Refers to snapshot owner account. Applicable if restoring the cluster from snapshot and snapshot belongs to another account\n   * Optional - By default, snapshots are searched within current account\n   */\n  readonly snapshotOwnerAccount?: number;\n\n  readonly redshiftManageMasterPassword?: boolean;\n}\n\nexport class DataWarehouseConfigParser extends MdaaAppConfigParser<DataWarehouseConfigContents> {\n  public readonly adminUsername: string;\n  public readonly adminPasswordRotationDays: number;\n  public readonly federations: FederationProps[];\n  public readonly databaseUsers: DatabaseUsersProps[];\n  public readonly dataAdminRoleRefs: MdaaRoleRef[];\n  public readonly warehouseBucketUserRoleRefs?: MdaaRoleRef[];\n  public readonly executionRoleRefs?: MdaaRoleRef[];\n  public readonly vpcId: string;\n  public readonly clusterPort: number;\n  public readonly subnetIds: string[];\n  public readonly nodeType: string;\n  public readonly enableAuditLoggingToS3: boolean;\n  public readonly numberOfNodes: number;\n  public readonly multiNode?: boolean;\n  public readonly preferredMaintenanceWindow: string;\n  public readonly securityGroupIngress: { ipv4?: string[]; sg?: string[] };\n  public readonly parameterGroupParams: Record<string, string>;\n  public readonly workloadManagement: ConfigurationElement[];\n  public readonly additionalBucketKmsKeyArns?: string[];\n  public static readonly defaultClusterPort = 54390;\n  public readonly scheduledActions: ScheduledActionProps[];\n  public readonly createWarehouseBucket?: boolean;\n  public readonly automatedSnapshotRetentionDays?: number;\n  public readonly eventNotifications?: EventNotificationsProps;\n  public readonly dbName?: string;\n  public readonly snapshotIdentifier?: string;\n  public readonly snapshotOwnerAccount?: number;\n  public readonly redshiftManageMasterPassword?: boolean;\n\n  constructor(stack: Stack, props: MdaaAppConfigParserProps) {\n    super(stack, props, configSchema as Schema);\n\n    this.adminUsername = this.configContents.adminUsername;\n    this.adminPasswordRotationDays = this.configContents.adminPasswordRotationDays;\n    this.federations = this.configContents.federations ? this.configContents.federations : [];\n    this.dataAdminRoleRefs = this.configContents.dataAdminRoles;\n    this.warehouseBucketUserRoleRefs = this.configContents.warehouseBucketUserRoles;\n    this.executionRoleRefs = this.configContents.executionRoles;\n    this.vpcId = this.configContents.vpcId;\n    this.subnetIds = this.configContents.subnetIds;\n    this.securityGroupIngress = this.configContents.securityGroupIngress;\n    this.nodeType = this.configContents.nodeType;\n    this.numberOfNodes = this.configContents.numberOfNodes;\n    this.enableAuditLoggingToS3 = this.configContents.enableAuditLoggingToS3;\n    this.clusterPort = this.configContents.clusterPort\n      ? this.configContents.clusterPort\n      : DataWarehouseConfigParser.defaultClusterPort;\n    this.multiNode = this.configContents.multiNode;\n    this.preferredMaintenanceWindow = this.configContents.preferredMaintenanceWindow;\n    this.parameterGroupParams = this.configContents.parameterGroupParams\n      ? this.configContents.parameterGroupParams\n      : {};\n    this.workloadManagement = this.configContents.workloadManagement ? this.configContents.workloadManagement : [];\n    this.additionalBucketKmsKeyArns = this.configContents.additionalBucketKmsKeyArns;\n    this.scheduledActions = this.configContents.scheduledActions ? this.configContents.scheduledActions : [];\n    this.databaseUsers = this.configContents.databaseUsers ? this.configContents.databaseUsers : [];\n    this.createWarehouseBucket = this.configContents.createWarehouseBucket;\n    this.automatedSnapshotRetentionDays = this.configContents.automatedSnapshotRetentionDays;\n    this.eventNotifications = this.configContents.eventNotifications;\n    this.dbName = this.configContents.dbName;\n    this.snapshotIdentifier = this.configContents.snapshotIdentifier;\n    this.snapshotOwnerAccount = this.configContents.snapshotOwnerAccount;\n    this.redshiftManageMasterPassword = this.configContents.redshiftManageMasterPassword;\n  }\n}\n"]}
|
|
47
|
+
DataWarehouseConfigParser.defaultClusterPort = 5440;
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datawarehouse-config.js","sourceRoot":"","sources":["datawarehouse-config.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { MdaaAppConfigParser, MdaaAppConfigParserProps, MdaaBaseConfigContents } from '@aws-mdaa/app';\nimport {\n  FederationProps,\n  ScheduledActionProps,\n  DatabaseUsersProps,\n  EventNotificationsProps,\n} from '@aws-mdaa/datawarehouse-l3-construct';\nimport { MdaaRoleRef } from '@aws-mdaa/iam-role-helper';\nimport { Schema } from 'ajv';\nimport { Stack } from 'aws-cdk-lib';\nimport * as configSchema from './config-schema.json';\nimport { ConfigurationElement } from '@aws-mdaa/config';\n\nexport interface DataWarehouseConfigContents extends MdaaBaseConfigContents {\n  /**\n   * Admin username for the Redshift cluster. A secret is automatically generated for the password.\n   *\n   * Use cases: Cluster administration; Database management; Initial user provisioning\n   *\n   * AWS: Redshift cluster master username\n   *\n   * Validation: Required; valid Redshift username\n   */\n  readonly adminUsername: string;\n  /**\n   * Days between automatic admin password rotations via Secrets Manager.\n   *\n   * Use cases: Automated credential rotation; Security compliance; Password policy enforcement\n   *\n   * AWS: Redshift admin password rotation via Secrets Manager\n   *\n   * Validation: Required; positive integer\n   */\n  readonly adminPasswordRotationDays: number;\n  /**\n   * SAML or OIDC federation configurations for federated Redshift access.\n   * Each federation creates an IAM role with SAML trust for dynamic credential generation\n   * and group-based cluster access.\n   *\n   * Use cases: SAML federation setup; SSO integration; Federated cluster access\n   *\n   * AWS: IAM SAML identity provider roles for Redshift federated access\n   *\n   * Validation: Optional; array of valid FederationProps\n   */\n  readonly federations?: FederationProps[];\n  /**\n   * Admin roles granted full access to cluster resources including KMS keys and S3 buckets.\n   *\n   * Use cases: Administrative access control; Security management; Resource administration\n   *\n   * AWS: IAM roles with full Redshift cluster and resource access\n   *\n   * Validation: Required; array of valid MdaaRoleRef\n   */\n  readonly dataAdminRoles: MdaaRoleRef[];\n  /**\n   * Roles granted read/write access to the data warehouse S3 bucket for data loading/unloading.\n   *\n   * Use cases: ETL data loading; Data unloading operations; Bucket access for analytics\n   *\n   * AWS: IAM roles with S3 bucket access for Redshift data operations\n   *\n   * Validation: Optional; array of valid MdaaRoleRef\n   */\n  readonly warehouseBucketUserRoles?: MdaaRoleRef[];\n  /**\n   * External execution roles associated with the Redshift cluster for cross-service operations.\n   * If a role also needs warehouse bucket access, add it to warehouseBucketUserRoles explicitly.\n   *\n   * Use cases: Cross-service integrations; External data access; Glue/Lambda integration\n   *\n   * AWS: IAM execution roles associated with the Redshift cluster\n   *\n   * Validation: Optional; array of valid MdaaRoleRef; roles must be assumable by Redshift\n   */\n  readonly executionRoles?: MdaaRoleRef[];\n  /**\n   * VPC ID for Redshift cluster deployment. The cluster is deployed within this VPC\n   * with network access controlled by security groups.\n   *\n   * Use cases: Network isolation; VPC-based deployment; Secure networking\n   *\n   * AWS: VPC for Redshift cluster network configuration\n   *\n   * Validation: Required; valid VPC ID\n   */\n  readonly vpcId: string;\n  /**\n   * Subnet IDs for Redshift cluster node placement. For automatic cluster relocation,\n   * specify at least one subnet per AZ.\n   *\n   * Use cases: Multi-AZ placement; Subnet-specific deployment; Cluster relocation support\n   *\n   * AWS: VPC subnets for Redshift subnet group\n   *\n   * Validation: Required; array of valid subnet IDs in the specified VPC\n   */\n  readonly subnetIds: string[];\n  /**\n   * Security group ingress rules defining allowed inbound connections to the cluster port.\n   * Supports IPv4 CIDR blocks and security group references. All other traffic is blocked.\n   *\n   * Use cases: Network access control; Client connectivity; Security group management\n   *\n   * AWS: VPC security group ingress rules for Redshift cluster\n   *\n   * Validation: Required; object with optional ipv4 and/or sg arrays\n   */\n  readonly securityGroupIngress: { ipv4?: string[]; sg?: string[] };\n  /**\n   * Redshift node type determining compute and storage capacity (e.g., RA3_4XLARGE).\n   *\n   * Use cases: Performance sizing; Cost optimization; Workload-specific capacity\n   *\n   * AWS: Redshift node type (instance type)\n   *\n   * Validation: Required; valid Redshift node type string\n   */\n  readonly nodeType: string;\n  /**\n   * Number of nodes in the Redshift cluster.\n   *\n   * Use cases: Cluster sizing; Performance scaling; Cost management\n   *\n   * AWS: Redshift cluster node count\n   *\n   * Validation: Required; positive integer\n   */\n  readonly numberOfNodes: number;\n  /**\n   * Enable audit logging to a dedicated S3 bucket. The audit bucket uses SSE-S3 encryption\n   * (not KMS) due to Redshift audit logging requirements.\n   *\n   * Use cases: Compliance auditing; Security monitoring; User activity tracking\n   *\n   * AWS: Redshift audit logging to S3 with SSE-S3 encryption\n   *\n   * Validation: Required; boolean\n   */\n  readonly enableAuditLoggingToS3: boolean;\n  /**\n   * TCP port for client connections to the cluster.\n   *\n   * Use cases: Custom port configuration; Network security; Port standardization\n   *\n   * AWS: Redshift cluster listening port\n   *\n   * Validation: Optional; valid port number\n   * @default 5440\n   */\n  readonly clusterPort?: number;\n  /**\n   * Multi-node cluster flag. When true, creates a multi-node cluster for distributed processing;\n   * when false, creates a single-node cluster for development or small workloads.\n   *\n   * Use cases: Cluster architecture selection; Dev vs production deployment; Cost optimization\n   *\n   * AWS: Redshift cluster type (single-node or multi-node)\n   *\n   * Validation: Optional; boolean\n   */\n  readonly multiNode?: boolean;\n  /**\n   * Weekly maintenance window in ddd:hh24:mi-ddd:hh24:mi format (UTC).\n   * Example: 'Sun:23:45-Mon:00:15'.\n   *\n   * Use cases: Maintenance scheduling; Business continuity; Downtime management\n   *\n   * AWS: Redshift preferred maintenance window\n   *\n   * Validation: Required; valid time window format\n   */\n  readonly preferredMaintenanceWindow: string;\n  /**\n   * Additional cluster parameter group parameters for performance tuning.\n   * Security-sensitive values are automatically overridden for compliance (e.g., SSL enforcement).\n   *\n   * Use cases: Performance tuning; Custom cluster configuration; Workload optimization\n   *\n   * AWS: Redshift parameter group parameters\n   *\n   * Validation: Optional; string key-value pairs\n   */\n  readonly parameterGroupParams?: Record<string, string>;\n  /**\n   * Workload management (WLM) configuration for query queue management and resource allocation.\n   *\n   * Use cases: Query performance optimization; Concurrency control; Resource allocation\n   *\n   * AWS: Redshift WLM configuration\n   *\n   * Validation: Optional; array of valid ConfigurationElement\n   */\n  readonly workloadManagement?: ConfigurationElement[];\n  /**\n   * Additional KMS key ARNs allowed to write to the cluster bucket.\n   * Useful for allowing Glue jobs or other services to write encrypted data to the warehouse bucket.\n   *\n   * Use cases: Cross-service encryption; Glue job integration; Multi-key bucket access\n   *\n   * AWS: KMS key ARNs for warehouse bucket encryption\n   *\n   * Validation: Optional; array of valid KMS key ARNs\n   */\n  readonly additionalBucketKmsKeyArns?: string[];\n  /**\n   * Scheduled actions for automated cluster pause/resume operations.\n   * Each action specifies a target action (pauseCluster/resumeCluster), cron schedule,\n   * and active time window.\n   *\n   * Use cases: Cost optimization via scheduled pause; Automated operations; Business-hours scheduling\n   *\n   * AWS: Redshift scheduled actions for cluster lifecycle management\n   *\n   * Validation: Optional; array of valid ScheduledActionProps\n   */\n  readonly scheduledActions?: ScheduledActionProps[];\n  /**\n   * Database users created in Redshift with credentials stored in Secrets Manager.\n   * Supports automated secret rotation on a configurable cycle.\n   *\n   * Use cases: Automated user provisioning; Credential management; Secret rotation\n   *\n   * AWS: Redshift database users with Secrets Manager credential storage and rotation\n   *\n   * Validation: Optional; array of valid DatabaseUsersProps\n   */\n  readonly databaseUsers?: DatabaseUsersProps[];\n  /**\n   * Control whether a dedicated S3 bucket is created for warehouse data operations\n   * (loading, unloading, backup).\n   *\n   * Use cases: Storage resource management; Data operations; Bucket lifecycle control\n   *\n   * AWS: S3 bucket for Redshift data warehouse operations\n   *\n   * Validation: Optional; boolean\n   * @default true\n   */\n  readonly createWarehouseBucket?: boolean;\n  /**\n   * Number of days automated snapshots are retained (1-35). Set to 0 to disable.\n   *\n   * Use cases: Backup management; Point-in-time recovery; Data protection compliance\n   *\n   * AWS: Redshift automated snapshot retention\n   *\n   * Validation: Optional; integer 0-35\n   * @default 1\n   */\n  readonly automatedSnapshotRetentionDays?: number;\n  /**\n   * Event notification configuration for cluster and scheduled action monitoring.\n   * Configures SNS notifications with email delivery, severity filtering, and event category selection.\n   *\n   * Use cases: Operational monitoring; Event alerting; Cluster status tracking\n   *\n   * AWS: SNS notifications for Redshift cluster events\n   *\n   * Validation: Optional; valid EventNotificationsProps\n   */\n  readonly eventNotifications?: EventNotificationsProps;\n  /**\n   * Initial database name created in the cluster.\n   *\n   * Use cases: Custom database naming; Initial database setup\n   *\n   * AWS: Redshift initial database\n   *\n   * Validation: Optional; valid database name\n   * @default \"default_db\"\n   */\n  readonly dbName?: string;\n  /**\n   * Snapshot identifier for cluster restoration. Only provide when restoring from an existing snapshot.\n   *\n   * Use cases: Disaster recovery; Data migration; Cluster restoration\n   *\n   * AWS: Redshift snapshot for cluster restoration\n   *\n   * Validation: Optional; valid snapshot identifier\n   */\n  readonly snapshotIdentifier?: string;\n  /**\n   * ownerAccount Refers to snapshot owner account. Applicable if restoring the cluster from snapshot and snapshot belongs to another account\n   * Optional - By default, snapshots are searched within current account\n   */\n  readonly snapshotOwnerAccount?: number;\n\n  readonly redshiftManageMasterPassword?: boolean;\n}\n\nexport class DataWarehouseConfigParser extends MdaaAppConfigParser<DataWarehouseConfigContents> {\n  public readonly adminUsername: string;\n  public readonly adminPasswordRotationDays: number;\n  public readonly federations: FederationProps[];\n  public readonly databaseUsers: DatabaseUsersProps[];\n  public readonly dataAdminRoleRefs: MdaaRoleRef[];\n  public readonly warehouseBucketUserRoleRefs?: MdaaRoleRef[];\n  public readonly executionRoleRefs?: MdaaRoleRef[];\n  public readonly vpcId: string;\n  public readonly clusterPort: number;\n  public readonly subnetIds: string[];\n  public readonly nodeType: string;\n  public readonly enableAuditLoggingToS3: boolean;\n  public readonly numberOfNodes: number;\n  public readonly multiNode?: boolean;\n  public readonly preferredMaintenanceWindow: string;\n  public readonly securityGroupIngress: { ipv4?: string[]; sg?: string[] };\n  public readonly parameterGroupParams: Record<string, string>;\n  public readonly workloadManagement: ConfigurationElement[];\n  public readonly additionalBucketKmsKeyArns?: string[];\n  public static readonly defaultClusterPort = 5440;\n  public readonly scheduledActions: ScheduledActionProps[];\n  public readonly createWarehouseBucket?: boolean;\n  public readonly automatedSnapshotRetentionDays?: number;\n  public readonly eventNotifications?: EventNotificationsProps;\n  public readonly dbName?: string;\n  public readonly snapshotIdentifier?: string;\n  public readonly snapshotOwnerAccount?: number;\n  public readonly redshiftManageMasterPassword?: boolean;\n\n  constructor(stack: Stack, props: MdaaAppConfigParserProps) {\n    super(stack, props, configSchema as Schema);\n\n    this.adminUsername = this.configContents.adminUsername;\n    this.adminPasswordRotationDays = this.configContents.adminPasswordRotationDays;\n    this.federations = this.configContents.federations ? this.configContents.federations : [];\n    this.dataAdminRoleRefs = this.configContents.dataAdminRoles;\n    this.warehouseBucketUserRoleRefs = this.configContents.warehouseBucketUserRoles;\n    this.executionRoleRefs = this.configContents.executionRoles;\n    this.vpcId = this.configContents.vpcId;\n    this.subnetIds = this.configContents.subnetIds;\n    this.securityGroupIngress = this.configContents.securityGroupIngress;\n    this.nodeType = this.configContents.nodeType;\n    this.numberOfNodes = this.configContents.numberOfNodes;\n    this.enableAuditLoggingToS3 = this.configContents.enableAuditLoggingToS3;\n    this.clusterPort = this.configContents.clusterPort\n      ? this.configContents.clusterPort\n      : DataWarehouseConfigParser.defaultClusterPort;\n    this.multiNode = this.configContents.multiNode;\n    this.preferredMaintenanceWindow = this.configContents.preferredMaintenanceWindow;\n    this.parameterGroupParams = this.configContents.parameterGroupParams\n      ? this.configContents.parameterGroupParams\n      : {};\n    this.workloadManagement = this.configContents.workloadManagement ? this.configContents.workloadManagement : [];\n    this.additionalBucketKmsKeyArns = this.configContents.additionalBucketKmsKeyArns;\n    this.scheduledActions = this.configContents.scheduledActions ? this.configContents.scheduledActions : [];\n    this.databaseUsers = this.configContents.databaseUsers ? this.configContents.databaseUsers : [];\n    this.createWarehouseBucket = this.configContents.createWarehouseBucket;\n    this.automatedSnapshotRetentionDays = this.configContents.automatedSnapshotRetentionDays;\n    this.eventNotifications = this.configContents.eventNotifications;\n    this.dbName = this.configContents.dbName;\n    this.snapshotIdentifier = this.configContents.snapshotIdentifier;\n    this.snapshotOwnerAccount = this.configContents.snapshotOwnerAccount;\n    this.redshiftManageMasterPassword = this.configContents.redshiftManageMasterPassword;\n  }\n}\n"]}
|