cdk-dms-replication 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 +13491 -0
- package/API.md +8606 -0
- package/LICENSE +202 -0
- package/README.md +883 -0
- package/cdk.context.json +1 -0
- package/integ/sample-app.ts +229 -0
- package/lib/dms-roles.d.ts +14 -0
- package/lib/dms-roles.js +42 -0
- package/lib/endpoint-settings.d.ts +419 -0
- package/lib/endpoint-settings.js +3 -0
- package/lib/endpoint.d.ts +143 -0
- package/lib/endpoint.js +402 -0
- package/lib/enums.d.ts +231 -0
- package/lib/enums.js +266 -0
- package/lib/index.d.ts +9 -0
- package/lib/index.js +49 -0
- package/lib/migration-pipeline.d.ts +253 -0
- package/lib/migration-pipeline.js +218 -0
- package/lib/replication-instance.d.ts +99 -0
- package/lib/replication-instance.js +93 -0
- package/lib/replication-task.d.ts +72 -0
- package/lib/replication-task.js +46 -0
- package/lib/serverless-pipeline.d.ts +196 -0
- package/lib/serverless-pipeline.js +271 -0
- package/lib/table-mappings.d.ts +178 -0
- package/lib/table-mappings.js +283 -0
- package/lib/task-settings.d.ts +228 -0
- package/lib/task-settings.js +291 -0
- package/package.json +170 -0
- package/scripts/sync-instance-classes.js +213 -0
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
import * as cdk from 'aws-cdk-lib';
|
|
2
|
+
import { DatePartitionDelimiter, DatePartitionSequence, EncodingType, EncryptionMode, KafkaSecurityProtocol, MessageFormat, MongoAuthMechanism, MongoAuthType, MongoNestingLevel, MySqlTargetDbType, ParquetVersion, PostgresCdcPlugin, S3DataFormat, SqlServerSafeguardPolicy } from './enums';
|
|
3
|
+
/** Settings for MySQL and MariaDB endpoints. */
|
|
4
|
+
export interface MySqlSettings {
|
|
5
|
+
/** SQL to run after connecting to the endpoint. */
|
|
6
|
+
readonly afterConnectScript?: string;
|
|
7
|
+
/** Remove metadata from source that differs from target during full load. */
|
|
8
|
+
readonly cleanSourceMetadataOnMismatch?: boolean;
|
|
9
|
+
/** Interval in seconds between polls for source events during CDC. */
|
|
10
|
+
readonly eventsPollInterval?: number;
|
|
11
|
+
/** Maximum file size (in KB) for CSV files created during full load. */
|
|
12
|
+
readonly maxFileSize?: number;
|
|
13
|
+
/** Number of parallel threads to use for a full load. */
|
|
14
|
+
readonly parallelLoadThreads?: number;
|
|
15
|
+
/** ARN of the IAM role that provides access to the Secrets Manager secret. */
|
|
16
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
17
|
+
/** Full ARN or name of the secret in AWS Secrets Manager containing the endpoint connection details. */
|
|
18
|
+
readonly secretsManagerSecretId?: string;
|
|
19
|
+
/** Specifies the time zone for source MySQL. */
|
|
20
|
+
readonly serverTimezone?: string;
|
|
21
|
+
/** For a MySQL target, specifies how tables are created. */
|
|
22
|
+
readonly targetDbType?: MySqlTargetDbType;
|
|
23
|
+
}
|
|
24
|
+
/** Settings for PostgreSQL and Aurora PostgreSQL endpoints. */
|
|
25
|
+
export interface PostgreSqlSettings {
|
|
26
|
+
/** SQL to run after connecting. */
|
|
27
|
+
readonly afterConnectScript?: string;
|
|
28
|
+
/** Whether DMS captures DDL events and creates a replication slot. */
|
|
29
|
+
readonly captureDdls?: boolean;
|
|
30
|
+
/** Schema in which the operational DDL database artifacts are created. */
|
|
31
|
+
readonly ddlArtifactsSchema?: string;
|
|
32
|
+
/** Sets the client statement timeout for the PostgreSQL instance. */
|
|
33
|
+
readonly executeTimeout?: number;
|
|
34
|
+
/** Whether DMS fails tasks that attempt to truncate a LOB. */
|
|
35
|
+
readonly failTasksOnLobTruncation?: boolean;
|
|
36
|
+
/** Whether DMS enables heartbeat signals. */
|
|
37
|
+
readonly heartbeatEnable?: boolean;
|
|
38
|
+
/** The number of seconds between heartbeat signal calls. */
|
|
39
|
+
readonly heartbeatFrequency?: number;
|
|
40
|
+
/** Schema to store the heartbeat table. */
|
|
41
|
+
readonly heartbeatSchema?: string;
|
|
42
|
+
/** When true, maps boolean as boolean instead of varchar(5). */
|
|
43
|
+
readonly mapBooleanAsBoolean?: boolean;
|
|
44
|
+
/** Maximum file size (in KB) for CSV files created during full load. */
|
|
45
|
+
readonly maxFileSize?: number;
|
|
46
|
+
/** CDC plugin to use. */
|
|
47
|
+
readonly pluginName?: PostgresCdcPlugin;
|
|
48
|
+
/** ARN of the IAM role that provides access to Secrets Manager. */
|
|
49
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
50
|
+
/** Full ARN or name of the Secrets Manager secret. */
|
|
51
|
+
readonly secretsManagerSecretId?: string;
|
|
52
|
+
/** Name of the logical replication slot created for CDC. */
|
|
53
|
+
readonly slotName?: string;
|
|
54
|
+
}
|
|
55
|
+
/** Settings for Oracle endpoints. */
|
|
56
|
+
export interface OracleSettings {
|
|
57
|
+
/** Set to true to access the supplemental log directly. */
|
|
58
|
+
readonly accessAlternateDirectly?: boolean;
|
|
59
|
+
/** Whether DMS adds supplemental logging. */
|
|
60
|
+
readonly addSupplementalLogging?: boolean;
|
|
61
|
+
/** Additional archived redo log destination ID. */
|
|
62
|
+
readonly additionalArchivedLogDestId?: number;
|
|
63
|
+
/** Allows DMS to access SELECT on nested tables. */
|
|
64
|
+
readonly allowSelectNestedTables?: boolean;
|
|
65
|
+
/** Destination ID of the archived redo log. */
|
|
66
|
+
readonly archivedLogDestId?: number;
|
|
67
|
+
/** Reads changes only from archived redo logs (no online redo). */
|
|
68
|
+
readonly archivedLogsOnly?: boolean;
|
|
69
|
+
/** ASM password. */
|
|
70
|
+
readonly asmPassword?: cdk.SecretValue;
|
|
71
|
+
/** ASM server address. */
|
|
72
|
+
readonly asmServer?: string;
|
|
73
|
+
/** ASM user name. */
|
|
74
|
+
readonly asmUser?: string;
|
|
75
|
+
/** Semantics for char length: BYTE or CHAR. */
|
|
76
|
+
readonly charLengthSemantics?: string;
|
|
77
|
+
/** Whether DMS uses direct path full load. */
|
|
78
|
+
readonly directPathNoLog?: boolean;
|
|
79
|
+
/** Whether to load in parallel using direct path. */
|
|
80
|
+
readonly directPathParallelLoad?: boolean;
|
|
81
|
+
/** Specifies whether Oracle homogeneous tablespace migration is enabled. */
|
|
82
|
+
readonly enableHomogenousTablespace?: boolean;
|
|
83
|
+
/** Extra archived log destination IDs (up to 10). */
|
|
84
|
+
readonly extraArchivedLogDestIds?: number[];
|
|
85
|
+
/** Whether tasks fail if a LOB column is truncated. */
|
|
86
|
+
readonly failTasksOnLobTruncation?: boolean;
|
|
87
|
+
/** Precision to use when converting Oracle NUMBER to Amazon Redshift NUMERIC. */
|
|
88
|
+
readonly numberDatatypeScale?: number;
|
|
89
|
+
/** Path prefix used for the location of the online redo log. */
|
|
90
|
+
readonly oraclePathPrefix?: string;
|
|
91
|
+
/** Number of threads for parallel ASM reading. */
|
|
92
|
+
readonly parallelAsmReadThreads?: number;
|
|
93
|
+
/** Number of read-ahead blocks. */
|
|
94
|
+
readonly readAheadBlocks?: number;
|
|
95
|
+
/** Read the tablespace name from the online redo log. */
|
|
96
|
+
readonly readTableSpaceName?: boolean;
|
|
97
|
+
/** Retry interval in seconds when no archivelog is found. */
|
|
98
|
+
readonly retryInterval?: number;
|
|
99
|
+
/** ARN of IAM role for accessing Secrets Manager (main secret). */
|
|
100
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
101
|
+
/** ARN of IAM role for accessing the ASM Secrets Manager secret. */
|
|
102
|
+
readonly secretsManagerOracleAsmAccessRoleArn?: string;
|
|
103
|
+
/** Full ARN of the ASM secret in Secrets Manager. */
|
|
104
|
+
readonly secretsManagerOracleAsmSecretId?: string;
|
|
105
|
+
/** Full ARN of the main Secrets Manager secret. */
|
|
106
|
+
readonly secretsManagerSecretId?: string;
|
|
107
|
+
/** Name of the transparent data encryption (TDE) wallet. */
|
|
108
|
+
readonly securityDbEncryptionName?: string;
|
|
109
|
+
/** Use an alternate folder for online redo logs. */
|
|
110
|
+
readonly useAlternateFolderForOnline?: boolean;
|
|
111
|
+
/** Use B-file for large object replication. */
|
|
112
|
+
readonly useBFile?: boolean;
|
|
113
|
+
/** Use direct path full load. */
|
|
114
|
+
readonly useDirectPathFullLoad?: boolean;
|
|
115
|
+
/** Use LogMiner for CDC. */
|
|
116
|
+
readonly useLogminerReader?: boolean;
|
|
117
|
+
/** Use a path prefix for the location of the online redo log. */
|
|
118
|
+
readonly usePathPrefix?: string;
|
|
119
|
+
}
|
|
120
|
+
/** Settings for Microsoft SQL Server endpoints. */
|
|
121
|
+
export interface SqlServerSettings {
|
|
122
|
+
/** Maximum number of bytes per BCP packet. */
|
|
123
|
+
readonly bcpPacketSize?: number;
|
|
124
|
+
/** Filegroup in SQL Server for control tables. */
|
|
125
|
+
readonly controlTablesFileGroup?: string;
|
|
126
|
+
/** Whether to query a single AlwaysOn node. */
|
|
127
|
+
readonly querySingleAlwaysOnNode?: boolean;
|
|
128
|
+
/** Whether to use backup files for CDC. */
|
|
129
|
+
readonly readBackupOnly?: boolean;
|
|
130
|
+
/** Safeguard policy for SQL Server CDC. */
|
|
131
|
+
readonly safeguardPolicy?: SqlServerSafeguardPolicy;
|
|
132
|
+
/** ARN of IAM role for Secrets Manager. */
|
|
133
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
134
|
+
/** Full ARN or name of the Secrets Manager secret. */
|
|
135
|
+
readonly secretsManagerSecretId?: string;
|
|
136
|
+
/** Use BCP full load. */
|
|
137
|
+
readonly useBcpFullLoad?: boolean;
|
|
138
|
+
/** Use third-party backup device. */
|
|
139
|
+
readonly useThirdPartyBackupDevice?: boolean;
|
|
140
|
+
/** Trim spaces from CHAR/VARCHAR columns. */
|
|
141
|
+
readonly trimSpaceInChar?: boolean;
|
|
142
|
+
/** Controls how DMS accesses the SQL Server transaction log. */
|
|
143
|
+
readonly tlogAccessMode?: string;
|
|
144
|
+
}
|
|
145
|
+
/** Settings for SAP Adaptive Server Enterprise (Sybase) endpoints. */
|
|
146
|
+
export interface SapAseSettings {
|
|
147
|
+
/** ARN of IAM role for Secrets Manager. */
|
|
148
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
149
|
+
/** Full ARN or name of the Secrets Manager secret. */
|
|
150
|
+
readonly secretsManagerSecretId?: string;
|
|
151
|
+
}
|
|
152
|
+
/** Settings for IBM Db2 LUW endpoints. */
|
|
153
|
+
export interface Db2Settings {
|
|
154
|
+
/** Maximum number of bytes per read operation. */
|
|
155
|
+
readonly maxKBytesPerRead?: number;
|
|
156
|
+
/** Enables ongoing replication (CDC) for Db2. */
|
|
157
|
+
readonly setDataCaptureChanges?: boolean;
|
|
158
|
+
/** Current LSN as of which DMS should start reading. */
|
|
159
|
+
readonly currentLsn?: string;
|
|
160
|
+
/** ARN of IAM role for Secrets Manager. */
|
|
161
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
162
|
+
/** Full ARN or name of the Secrets Manager secret. */
|
|
163
|
+
readonly secretsManagerSecretId?: string;
|
|
164
|
+
}
|
|
165
|
+
/** Settings shared by MongoDB and DocumentDB endpoints. */
|
|
166
|
+
export interface MongoDbSettings {
|
|
167
|
+
/** Authentication mechanism for the MongoDB endpoint. */
|
|
168
|
+
readonly authMechanism?: MongoAuthMechanism;
|
|
169
|
+
/** Database that MongoDB uses to authenticate. */
|
|
170
|
+
readonly authSource?: string;
|
|
171
|
+
/** Authentication type. */
|
|
172
|
+
readonly authType?: MongoAuthType;
|
|
173
|
+
/** Number of documents to preview to determine data structure. */
|
|
174
|
+
readonly docsToInvestigate?: number;
|
|
175
|
+
/** Specifies the document ID, which DMS includes as the primary key. */
|
|
176
|
+
readonly extractDocId?: boolean;
|
|
177
|
+
/** Nesting level for MongoDB documents. */
|
|
178
|
+
readonly nestingLevel?: MongoNestingLevel;
|
|
179
|
+
/** ARN of IAM role for Secrets Manager. */
|
|
180
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
181
|
+
/** Full ARN or name of the Secrets Manager secret. */
|
|
182
|
+
readonly secretsManagerSecretId?: string;
|
|
183
|
+
}
|
|
184
|
+
/** Settings for Amazon S3 endpoints (source or target). */
|
|
185
|
+
export interface S3Settings {
|
|
186
|
+
/** S3 bucket name. */
|
|
187
|
+
readonly bucketName: string;
|
|
188
|
+
/** Folder path prefix within the bucket. */
|
|
189
|
+
readonly bucketFolder?: string;
|
|
190
|
+
/** IAM role ARN that DMS uses to access the S3 bucket. */
|
|
191
|
+
readonly serviceAccessRoleArn: string;
|
|
192
|
+
/** Whether DMS adds a column name field to CSV output. */
|
|
193
|
+
readonly addColumnName?: boolean;
|
|
194
|
+
/** Include CDC inserts and updates in the target. */
|
|
195
|
+
readonly cdcInsertsAndUpdates?: boolean;
|
|
196
|
+
/** Include only inserts (not updates or deletes) in the target. */
|
|
197
|
+
readonly cdcInsertsOnly?: boolean;
|
|
198
|
+
/** Maximum interval in seconds between CDC mini-batches (1-360). */
|
|
199
|
+
readonly cdcMaxBatchInterval?: number;
|
|
200
|
+
/** Minimum file size (in KB) to trigger a CDC file write. */
|
|
201
|
+
readonly cdcMinFileSize?: number;
|
|
202
|
+
/** CDC path in the source S3 bucket. */
|
|
203
|
+
readonly cdcPath?: string;
|
|
204
|
+
/** Column delimiter character for CSV output. Default: comma. */
|
|
205
|
+
readonly csvDelimiter?: string;
|
|
206
|
+
/** String used for null values when no-sup-value applies. */
|
|
207
|
+
readonly csvNoSupValue?: string;
|
|
208
|
+
/** String used for null values in CSV output. */
|
|
209
|
+
readonly csvNullValue?: string;
|
|
210
|
+
/** Row delimiter for CSV output. Default: newline. */
|
|
211
|
+
readonly csvRowDelimiter?: string;
|
|
212
|
+
/** Output data format: CSV or Parquet. */
|
|
213
|
+
readonly dataFormat?: S3DataFormat;
|
|
214
|
+
/** Date partition delimiter. */
|
|
215
|
+
readonly datePartitionDelimiter?: DatePartitionDelimiter;
|
|
216
|
+
/** Whether to partition output files by date. */
|
|
217
|
+
readonly datePartitionEnabled?: boolean;
|
|
218
|
+
/** Date partition sequence. */
|
|
219
|
+
readonly datePartitionSequence?: DatePartitionSequence;
|
|
220
|
+
/** Dictionary page size (in bytes) for Parquet. */
|
|
221
|
+
readonly dictPageSizeLimit?: number;
|
|
222
|
+
/** Whether to enable statistics for Parquet row groups. */
|
|
223
|
+
readonly enableStatistics?: boolean;
|
|
224
|
+
/** Encoding type for Parquet. */
|
|
225
|
+
readonly encodingType?: EncodingType;
|
|
226
|
+
/** Encryption mode for data at rest in S3. */
|
|
227
|
+
readonly encryptionMode?: EncryptionMode;
|
|
228
|
+
/** JSON structure defining external tables (for S3 source). */
|
|
229
|
+
readonly externalTableDefinition?: string;
|
|
230
|
+
/** Number of header rows to ignore in the S3 source. */
|
|
231
|
+
readonly ignoreHeaderRows?: number;
|
|
232
|
+
/** Whether to include the operation column for full-load rows. */
|
|
233
|
+
readonly includeOpForFullLoad?: boolean;
|
|
234
|
+
/** Maximum file size (in KB) for data files. */
|
|
235
|
+
readonly maxFileSize?: number;
|
|
236
|
+
/** Whether timestamps in Parquet use milliseconds instead of microseconds. */
|
|
237
|
+
readonly parquetTimestampInMillisecond?: boolean;
|
|
238
|
+
/** Parquet format version. */
|
|
239
|
+
readonly parquetVersion?: ParquetVersion;
|
|
240
|
+
/** Whether DMS preserves transaction boundaries (for CDC). */
|
|
241
|
+
readonly preserveTransactions?: boolean;
|
|
242
|
+
/** Whether to use RFC 4180 compliant CSV format. */
|
|
243
|
+
readonly rfc4180?: boolean;
|
|
244
|
+
/** Number of rows per Parquet row group. */
|
|
245
|
+
readonly rowGroupLength?: number;
|
|
246
|
+
/** KMS key ARN for SSE-KMS encryption. */
|
|
247
|
+
readonly serverSideEncryptionKmsKeyId?: string;
|
|
248
|
+
/** Column name for operation timestamps. */
|
|
249
|
+
readonly timestampColumnName?: string;
|
|
250
|
+
/** Whether to use CSV no-sup-value. */
|
|
251
|
+
readonly useCsvNoSupValue?: boolean;
|
|
252
|
+
/** Whether to use the task start time instead of transaction start time for full load. */
|
|
253
|
+
readonly useTaskStartTimeForFullLoadTimestamp?: boolean;
|
|
254
|
+
}
|
|
255
|
+
/** Settings for Amazon DynamoDB target endpoints. */
|
|
256
|
+
export interface DynamoDbSettings {
|
|
257
|
+
/** ARN of the IAM role that provides DMS access to DynamoDB. */
|
|
258
|
+
readonly serviceAccessRoleArn: string;
|
|
259
|
+
}
|
|
260
|
+
/** Settings for Amazon Redshift target endpoints. */
|
|
261
|
+
export interface RedshiftSettings {
|
|
262
|
+
/** Whether to accept dates in a specific format. */
|
|
263
|
+
readonly acceptAnyDate?: boolean;
|
|
264
|
+
/** SQL to run after connecting. */
|
|
265
|
+
readonly afterConnectScript?: string;
|
|
266
|
+
/** S3 intermediate bucket folder path. */
|
|
267
|
+
readonly bucketFolder?: string;
|
|
268
|
+
/** S3 bucket name used for the intermediate storage. */
|
|
269
|
+
readonly bucketName?: string;
|
|
270
|
+
/** Whether to enable case-sensitive column names. */
|
|
271
|
+
readonly caseSensitiveNames?: boolean;
|
|
272
|
+
/** Whether to enable automatic compression. */
|
|
273
|
+
readonly compUpdate?: boolean;
|
|
274
|
+
/** Timeout in seconds for database connections. */
|
|
275
|
+
readonly connectionTimeout?: number;
|
|
276
|
+
/** Date format for the DATEFORMAT option. */
|
|
277
|
+
readonly dateFormat?: string;
|
|
278
|
+
/** Whether to load empty strings as NULL. */
|
|
279
|
+
readonly emptyAsNull?: boolean;
|
|
280
|
+
/** Encryption mode for data at rest. */
|
|
281
|
+
readonly encryptionMode?: EncryptionMode;
|
|
282
|
+
/** Whether to allow explicit ID values in the COPY command. */
|
|
283
|
+
readonly explicitIds?: boolean;
|
|
284
|
+
/** Number of upload streams for parallel loading. */
|
|
285
|
+
readonly fileTransferUploadStreams?: number;
|
|
286
|
+
/** Timeout (in seconds) for loading data. */
|
|
287
|
+
readonly loadTimeout?: number;
|
|
288
|
+
/** Maximum file size (in KB) for each intermediate file. */
|
|
289
|
+
readonly maxFileSize?: number;
|
|
290
|
+
/** Whether to remove quoted data. */
|
|
291
|
+
readonly removeQuotes?: boolean;
|
|
292
|
+
/** Character to use to replace invalid UTF-8 characters. */
|
|
293
|
+
readonly replaceInvalidChars?: string;
|
|
294
|
+
/** Character to replace a specific character with. */
|
|
295
|
+
readonly replaceChars?: string;
|
|
296
|
+
/** ARN of IAM role for accessing Secrets Manager. */
|
|
297
|
+
readonly secretsManagerAccessRoleArn?: string;
|
|
298
|
+
/** Full ARN or name of the Secrets Manager secret. */
|
|
299
|
+
readonly secretsManagerSecretId?: string;
|
|
300
|
+
/** KMS key ARN for SSE-KMS. */
|
|
301
|
+
readonly serverSideEncryptionKmsKeyId?: string;
|
|
302
|
+
/** ARN of the IAM role that provides DMS access to the S3 staging bucket. */
|
|
303
|
+
readonly serviceAccessRoleArn?: string;
|
|
304
|
+
/** Date format for the TIMEFORMAT option. */
|
|
305
|
+
readonly timeFormat?: string;
|
|
306
|
+
/** Whether to remove trailing blanks from VARCHAR columns. */
|
|
307
|
+
readonly trimBlanks?: boolean;
|
|
308
|
+
/** Whether to truncate VARCHAR columns to the maximum length. */
|
|
309
|
+
readonly truncateColumns?: boolean;
|
|
310
|
+
/** Size of the write buffer (in KB). */
|
|
311
|
+
readonly writeBufferSize?: number;
|
|
312
|
+
}
|
|
313
|
+
/** Settings for Amazon Kinesis Data Streams target endpoints. */
|
|
314
|
+
export interface KinesisSettings {
|
|
315
|
+
/** ARN of the Kinesis stream. */
|
|
316
|
+
readonly streamArn: string;
|
|
317
|
+
/** ARN of the IAM role that provides DMS access to Kinesis. */
|
|
318
|
+
readonly serviceAccessRoleArn: string;
|
|
319
|
+
/** Whether to include control details in messages. */
|
|
320
|
+
readonly includeControlDetails?: boolean;
|
|
321
|
+
/** Whether to include null and empty columns in messages. */
|
|
322
|
+
readonly includeNullAndEmpty?: boolean;
|
|
323
|
+
/** Whether to include the partition value in messages. */
|
|
324
|
+
readonly includePartitionValue?: boolean;
|
|
325
|
+
/** Whether to include table ALTER operations in messages. */
|
|
326
|
+
readonly includeTableAlterOperations?: boolean;
|
|
327
|
+
/** Whether to include transaction details in messages. */
|
|
328
|
+
readonly includeTransactionDetails?: boolean;
|
|
329
|
+
/** Message format. */
|
|
330
|
+
readonly messageFormat?: MessageFormat;
|
|
331
|
+
/** Whether to omit the hex prefix from binary values. */
|
|
332
|
+
readonly noHexPrefix?: boolean;
|
|
333
|
+
/** Whether to include the schema name in the partition key. */
|
|
334
|
+
readonly partitionIncludeSchemaTable?: boolean;
|
|
335
|
+
}
|
|
336
|
+
/** Settings for Apache Kafka (and Amazon MSK) target endpoints. */
|
|
337
|
+
export interface KafkaSettings {
|
|
338
|
+
/** Kafka broker(s), e.g. "b-1.msk-cluster.abc123.kafka.us-east-1.amazonaws.com:9092". */
|
|
339
|
+
readonly broker: string;
|
|
340
|
+
/** Topic name to publish to. */
|
|
341
|
+
readonly topic?: string;
|
|
342
|
+
/** Whether to include control details in messages. */
|
|
343
|
+
readonly includeControlDetails?: boolean;
|
|
344
|
+
/** Whether to include null and empty columns in messages. */
|
|
345
|
+
readonly includeNullAndEmpty?: boolean;
|
|
346
|
+
/** Whether to include the partition value in messages. */
|
|
347
|
+
readonly includePartitionValue?: boolean;
|
|
348
|
+
/** Whether to include table ALTER operations. */
|
|
349
|
+
readonly includeTableAlterOperations?: boolean;
|
|
350
|
+
/** Whether to include transaction details. */
|
|
351
|
+
readonly includeTransactionDetails?: boolean;
|
|
352
|
+
/** Message format. */
|
|
353
|
+
readonly messageFormat?: MessageFormat;
|
|
354
|
+
/** Maximum message size in bytes. */
|
|
355
|
+
readonly messageMaxBytes?: number;
|
|
356
|
+
/** Whether to omit the hex prefix from binary values. */
|
|
357
|
+
readonly noHexPrefix?: boolean;
|
|
358
|
+
/** Whether to include the schema name in the partition key. */
|
|
359
|
+
readonly partitionIncludeSchemaTable?: boolean;
|
|
360
|
+
/** Security protocol for the Kafka connection. */
|
|
361
|
+
readonly securityProtocol?: KafkaSecurityProtocol;
|
|
362
|
+
/** SASL username. */
|
|
363
|
+
readonly saslUsername?: string;
|
|
364
|
+
/** SASL password. */
|
|
365
|
+
readonly saslPassword?: cdk.SecretValue;
|
|
366
|
+
/** ARN of the Secrets Manager secret holding the CA certificate. */
|
|
367
|
+
readonly sslCaCertificateArn?: string;
|
|
368
|
+
/** ARN of the Secrets Manager secret holding the client certificate. */
|
|
369
|
+
readonly sslClientCertificateArn?: string;
|
|
370
|
+
/** ARN of the Secrets Manager secret holding the client key. */
|
|
371
|
+
readonly sslClientKeyArn?: string;
|
|
372
|
+
/** Password for the client key. */
|
|
373
|
+
readonly sslClientKeyPassword?: cdk.SecretValue;
|
|
374
|
+
}
|
|
375
|
+
/** Settings for Amazon OpenSearch Service target endpoints. */
|
|
376
|
+
export interface OpenSearchSettings {
|
|
377
|
+
/** Endpoint URL of the OpenSearch cluster (e.g. https://my-domain.us-east-1.es.amazonaws.com). */
|
|
378
|
+
readonly endpointUri: string;
|
|
379
|
+
/** ARN of the IAM role that provides DMS access to OpenSearch. */
|
|
380
|
+
readonly serviceAccessRoleArn: string;
|
|
381
|
+
/** Number of seconds to retry on errors before failing. */
|
|
382
|
+
readonly errorRetryDuration?: number;
|
|
383
|
+
/** Maximum percentage of records that may fail before the task is stopped. */
|
|
384
|
+
readonly fullLoadErrorPercentage?: number;
|
|
385
|
+
}
|
|
386
|
+
/** Settings for Amazon Neptune target endpoints. */
|
|
387
|
+
export interface NeptuneSettings {
|
|
388
|
+
/** S3 bucket where DMS stages the migration data. */
|
|
389
|
+
readonly s3BucketName: string;
|
|
390
|
+
/** Folder within the S3 bucket for Neptune staging data. */
|
|
391
|
+
readonly s3BucketFolder: string;
|
|
392
|
+
/** ARN of the IAM role that provides DMS access to S3 and Neptune. */
|
|
393
|
+
readonly serviceAccessRoleArn: string;
|
|
394
|
+
/** Number of seconds to retry on errors before failing the task. */
|
|
395
|
+
readonly errorRetryDuration?: number;
|
|
396
|
+
/** Whether IAM auth is enabled on the Neptune cluster. */
|
|
397
|
+
readonly iamAuthEnabled?: boolean;
|
|
398
|
+
/** Maximum number of files per request to the Neptune bulk-load API. */
|
|
399
|
+
readonly maxFileSize?: number;
|
|
400
|
+
/** Maximum number of retries on endpoint exceptions. */
|
|
401
|
+
readonly maxRetryCount?: number;
|
|
402
|
+
}
|
|
403
|
+
/** Settings for Amazon ElastiCache for Redis target endpoints. */
|
|
404
|
+
export interface RedisSettings {
|
|
405
|
+
/** Redis server name or cluster endpoint. */
|
|
406
|
+
readonly serverName: string;
|
|
407
|
+
/** Redis port. Default: 6379. */
|
|
408
|
+
readonly port?: number;
|
|
409
|
+
/** SSL security protocol. */
|
|
410
|
+
readonly sslSecurityProtocol?: string;
|
|
411
|
+
/** Authentication type: none, auth-token, or auth-role. */
|
|
412
|
+
readonly authType?: string;
|
|
413
|
+
/** IAM role ARN for auth-role authentication. */
|
|
414
|
+
readonly authUserName?: string;
|
|
415
|
+
/** Auth token for auth-token authentication. */
|
|
416
|
+
readonly authPassword?: cdk.SecretValue;
|
|
417
|
+
/** ARN of the SSL CA certificate stored in Secrets Manager. */
|
|
418
|
+
readonly sslCaCertificateArn?: string;
|
|
419
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"endpoint-settings.js","sourceRoot":"","sources":["../src/endpoint-settings.ts"],"names":[],"mappings":"","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport {\n  DatePartitionDelimiter,\n  DatePartitionSequence,\n  EncodingType,\n  EncryptionMode,\n  KafkaSecurityProtocol,\n  MessageFormat,\n  MongoAuthMechanism,\n  MongoAuthType,\n  MongoNestingLevel,\n  MySqlTargetDbType,\n  ParquetVersion,\n  PostgresCdcPlugin,\n  S3DataFormat,\n  SqlServerSafeguardPolicy,\n} from './enums';\n\n// ---------------------------------------------------------------------------\n// MySQL / MariaDB\n// ---------------------------------------------------------------------------\n\n/** Settings for MySQL and MariaDB endpoints. */\nexport interface MySqlSettings {\n  /** SQL to run after connecting to the endpoint. */\n  readonly afterConnectScript?: string;\n  /** Remove metadata from source that differs from target during full load. */\n  readonly cleanSourceMetadataOnMismatch?: boolean;\n  /** Interval in seconds between polls for source events during CDC. */\n  readonly eventsPollInterval?: number;\n  /** Maximum file size (in KB) for CSV files created during full load. */\n  readonly maxFileSize?: number;\n  /** Number of parallel threads to use for a full load. */\n  readonly parallelLoadThreads?: number;\n  /** ARN of the IAM role that provides access to the Secrets Manager secret. */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** Full ARN or name of the secret in AWS Secrets Manager containing the endpoint connection details. */\n  readonly secretsManagerSecretId?: string;\n  /** Specifies the time zone for source MySQL. */\n  readonly serverTimezone?: string;\n  /** For a MySQL target, specifies how tables are created. */\n  readonly targetDbType?: MySqlTargetDbType;\n}\n\n// ---------------------------------------------------------------------------\n// PostgreSQL / Aurora PostgreSQL\n// ---------------------------------------------------------------------------\n\n/** Settings for PostgreSQL and Aurora PostgreSQL endpoints. */\nexport interface PostgreSqlSettings {\n  /** SQL to run after connecting. */\n  readonly afterConnectScript?: string;\n  /** Whether DMS captures DDL events and creates a replication slot. */\n  readonly captureDdls?: boolean;\n  /** Schema in which the operational DDL database artifacts are created. */\n  readonly ddlArtifactsSchema?: string;\n  /** Sets the client statement timeout for the PostgreSQL instance. */\n  readonly executeTimeout?: number;\n  /** Whether DMS fails tasks that attempt to truncate a LOB. */\n  readonly failTasksOnLobTruncation?: boolean;\n  /** Whether DMS enables heartbeat signals. */\n  readonly heartbeatEnable?: boolean;\n  /** The number of seconds between heartbeat signal calls. */\n  readonly heartbeatFrequency?: number;\n  /** Schema to store the heartbeat table. */\n  readonly heartbeatSchema?: string;\n  /** When true, maps boolean as boolean instead of varchar(5). */\n  readonly mapBooleanAsBoolean?: boolean;\n  /** Maximum file size (in KB) for CSV files created during full load. */\n  readonly maxFileSize?: number;\n  /** CDC plugin to use. */\n  readonly pluginName?: PostgresCdcPlugin;\n  /** ARN of the IAM role that provides access to Secrets Manager. */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** Full ARN or name of the Secrets Manager secret. */\n  readonly secretsManagerSecretId?: string;\n  /** Name of the logical replication slot created for CDC. */\n  readonly slotName?: string;\n}\n\n// ---------------------------------------------------------------------------\n// Oracle\n// ---------------------------------------------------------------------------\n\n/** Settings for Oracle endpoints. */\nexport interface OracleSettings {\n  /** Set to true to access the supplemental log directly. */\n  readonly accessAlternateDirectly?: boolean;\n  /** Whether DMS adds supplemental logging. */\n  readonly addSupplementalLogging?: boolean;\n  /** Additional archived redo log destination ID. */\n  readonly additionalArchivedLogDestId?: number;\n  /** Allows DMS to access SELECT on nested tables. */\n  readonly allowSelectNestedTables?: boolean;\n  /** Destination ID of the archived redo log. */\n  readonly archivedLogDestId?: number;\n  /** Reads changes only from archived redo logs (no online redo). */\n  readonly archivedLogsOnly?: boolean;\n  /** ASM password. */\n  readonly asmPassword?: cdk.SecretValue;\n  /** ASM server address. */\n  readonly asmServer?: string;\n  /** ASM user name. */\n  readonly asmUser?: string;\n  /** Semantics for char length: BYTE or CHAR. */\n  readonly charLengthSemantics?: string;\n  /** Whether DMS uses direct path full load. */\n  readonly directPathNoLog?: boolean;\n  /** Whether to load in parallel using direct path. */\n  readonly directPathParallelLoad?: boolean;\n  /** Specifies whether Oracle homogeneous tablespace migration is enabled. */\n  readonly enableHomogenousTablespace?: boolean;\n  /** Extra archived log destination IDs (up to 10). */\n  readonly extraArchivedLogDestIds?: number[];\n  /** Whether tasks fail if a LOB column is truncated. */\n  readonly failTasksOnLobTruncation?: boolean;\n  /** Precision to use when converting Oracle NUMBER to Amazon Redshift NUMERIC. */\n  readonly numberDatatypeScale?: number;\n  /** Path prefix used for the location of the online redo log. */\n  readonly oraclePathPrefix?: string;\n  /** Number of threads for parallel ASM reading. */\n  readonly parallelAsmReadThreads?: number;\n  /** Number of read-ahead blocks. */\n  readonly readAheadBlocks?: number;\n  /** Read the tablespace name from the online redo log. */\n  readonly readTableSpaceName?: boolean;\n  /** Retry interval in seconds when no archivelog is found. */\n  readonly retryInterval?: number;\n  /** ARN of IAM role for accessing Secrets Manager (main secret). */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** ARN of IAM role for accessing the ASM Secrets Manager secret. */\n  readonly secretsManagerOracleAsmAccessRoleArn?: string;\n  /** Full ARN of the ASM secret in Secrets Manager. */\n  readonly secretsManagerOracleAsmSecretId?: string;\n  /** Full ARN of the main Secrets Manager secret. */\n  readonly secretsManagerSecretId?: string;\n  /** Name of the transparent data encryption (TDE) wallet. */\n  readonly securityDbEncryptionName?: string;\n  /** Use an alternate folder for online redo logs. */\n  readonly useAlternateFolderForOnline?: boolean;\n  /** Use B-file for large object replication. */\n  readonly useBFile?: boolean;\n  /** Use direct path full load. */\n  readonly useDirectPathFullLoad?: boolean;\n  /** Use LogMiner for CDC. */\n  readonly useLogminerReader?: boolean;\n  /** Use a path prefix for the location of the online redo log. */\n  readonly usePathPrefix?: string;\n}\n\n// ---------------------------------------------------------------------------\n// SQL Server\n// ---------------------------------------------------------------------------\n\n/** Settings for Microsoft SQL Server endpoints. */\nexport interface SqlServerSettings {\n  /** Maximum number of bytes per BCP packet. */\n  readonly bcpPacketSize?: number;\n  /** Filegroup in SQL Server for control tables. */\n  readonly controlTablesFileGroup?: string;\n  /** Whether to query a single AlwaysOn node. */\n  readonly querySingleAlwaysOnNode?: boolean;\n  /** Whether to use backup files for CDC. */\n  readonly readBackupOnly?: boolean;\n  /** Safeguard policy for SQL Server CDC. */\n  readonly safeguardPolicy?: SqlServerSafeguardPolicy;\n  /** ARN of IAM role for Secrets Manager. */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** Full ARN or name of the Secrets Manager secret. */\n  readonly secretsManagerSecretId?: string;\n  /** Use BCP full load. */\n  readonly useBcpFullLoad?: boolean;\n  /** Use third-party backup device. */\n  readonly useThirdPartyBackupDevice?: boolean;\n  /** Trim spaces from CHAR/VARCHAR columns. */\n  readonly trimSpaceInChar?: boolean;\n  /** Controls how DMS accesses the SQL Server transaction log. */\n  readonly tlogAccessMode?: string;\n}\n\n// ---------------------------------------------------------------------------\n// SAP ASE (Sybase)\n// ---------------------------------------------------------------------------\n\n/** Settings for SAP Adaptive Server Enterprise (Sybase) endpoints. */\nexport interface SapAseSettings {\n  /** ARN of IAM role for Secrets Manager. */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** Full ARN or name of the Secrets Manager secret. */\n  readonly secretsManagerSecretId?: string;\n}\n\n// ---------------------------------------------------------------------------\n// IBM Db2 LUW\n// ---------------------------------------------------------------------------\n\n/** Settings for IBM Db2 LUW endpoints. */\nexport interface Db2Settings {\n  /** Maximum number of bytes per read operation. */\n  readonly maxKBytesPerRead?: number;\n  /** Enables ongoing replication (CDC) for Db2. */\n  readonly setDataCaptureChanges?: boolean;\n  /** Current LSN as of which DMS should start reading. */\n  readonly currentLsn?: string;\n  /** ARN of IAM role for Secrets Manager. */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** Full ARN or name of the Secrets Manager secret. */\n  readonly secretsManagerSecretId?: string;\n}\n\n// ---------------------------------------------------------------------------\n// MongoDB / DocumentDB\n// ---------------------------------------------------------------------------\n\n/** Settings shared by MongoDB and DocumentDB endpoints. */\nexport interface MongoDbSettings {\n  /** Authentication mechanism for the MongoDB endpoint. */\n  readonly authMechanism?: MongoAuthMechanism;\n  /** Database that MongoDB uses to authenticate. */\n  readonly authSource?: string;\n  /** Authentication type. */\n  readonly authType?: MongoAuthType;\n  /** Number of documents to preview to determine data structure. */\n  readonly docsToInvestigate?: number;\n  /** Specifies the document ID, which DMS includes as the primary key. */\n  readonly extractDocId?: boolean;\n  /** Nesting level for MongoDB documents. */\n  readonly nestingLevel?: MongoNestingLevel;\n  /** ARN of IAM role for Secrets Manager. */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** Full ARN or name of the Secrets Manager secret. */\n  readonly secretsManagerSecretId?: string;\n}\n\n// ---------------------------------------------------------------------------\n// Amazon S3\n// ---------------------------------------------------------------------------\n\n/** Settings for Amazon S3 endpoints (source or target). */\nexport interface S3Settings {\n  /** S3 bucket name. */\n  readonly bucketName: string;\n  /** Folder path prefix within the bucket. */\n  readonly bucketFolder?: string;\n  /** IAM role ARN that DMS uses to access the S3 bucket. */\n  readonly serviceAccessRoleArn: string;\n  /** Whether DMS adds a column name field to CSV output. */\n  readonly addColumnName?: boolean;\n  /** Include CDC inserts and updates in the target. */\n  readonly cdcInsertsAndUpdates?: boolean;\n  /** Include only inserts (not updates or deletes) in the target. */\n  readonly cdcInsertsOnly?: boolean;\n  /** Maximum interval in seconds between CDC mini-batches (1-360). */\n  readonly cdcMaxBatchInterval?: number;\n  /** Minimum file size (in KB) to trigger a CDC file write. */\n  readonly cdcMinFileSize?: number;\n  /** CDC path in the source S3 bucket. */\n  readonly cdcPath?: string;\n  /** Column delimiter character for CSV output. Default: comma. */\n  readonly csvDelimiter?: string;\n  /** String used for null values when no-sup-value applies. */\n  readonly csvNoSupValue?: string;\n  /** String used for null values in CSV output. */\n  readonly csvNullValue?: string;\n  /** Row delimiter for CSV output. Default: newline. */\n  readonly csvRowDelimiter?: string;\n  /** Output data format: CSV or Parquet. */\n  readonly dataFormat?: S3DataFormat;\n  /** Date partition delimiter. */\n  readonly datePartitionDelimiter?: DatePartitionDelimiter;\n  /** Whether to partition output files by date. */\n  readonly datePartitionEnabled?: boolean;\n  /** Date partition sequence. */\n  readonly datePartitionSequence?: DatePartitionSequence;\n  /** Dictionary page size (in bytes) for Parquet. */\n  readonly dictPageSizeLimit?: number;\n  /** Whether to enable statistics for Parquet row groups. */\n  readonly enableStatistics?: boolean;\n  /** Encoding type for Parquet. */\n  readonly encodingType?: EncodingType;\n  /** Encryption mode for data at rest in S3. */\n  readonly encryptionMode?: EncryptionMode;\n  /** JSON structure defining external tables (for S3 source). */\n  readonly externalTableDefinition?: string;\n  /** Number of header rows to ignore in the S3 source. */\n  readonly ignoreHeaderRows?: number;\n  /** Whether to include the operation column for full-load rows. */\n  readonly includeOpForFullLoad?: boolean;\n  /** Maximum file size (in KB) for data files. */\n  readonly maxFileSize?: number;\n  /** Whether timestamps in Parquet use milliseconds instead of microseconds. */\n  readonly parquetTimestampInMillisecond?: boolean;\n  /** Parquet format version. */\n  readonly parquetVersion?: ParquetVersion;\n  /** Whether DMS preserves transaction boundaries (for CDC). */\n  readonly preserveTransactions?: boolean;\n  /** Whether to use RFC 4180 compliant CSV format. */\n  readonly rfc4180?: boolean;\n  /** Number of rows per Parquet row group. */\n  readonly rowGroupLength?: number;\n  /** KMS key ARN for SSE-KMS encryption. */\n  readonly serverSideEncryptionKmsKeyId?: string;\n  /** Column name for operation timestamps. */\n  readonly timestampColumnName?: string;\n  /** Whether to use CSV no-sup-value. */\n  readonly useCsvNoSupValue?: boolean;\n  /** Whether to use the task start time instead of transaction start time for full load. */\n  readonly useTaskStartTimeForFullLoadTimestamp?: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// Amazon DynamoDB\n// ---------------------------------------------------------------------------\n\n/** Settings for Amazon DynamoDB target endpoints. */\nexport interface DynamoDbSettings {\n  /** ARN of the IAM role that provides DMS access to DynamoDB. */\n  readonly serviceAccessRoleArn: string;\n}\n\n// ---------------------------------------------------------------------------\n// Amazon Redshift\n// ---------------------------------------------------------------------------\n\n/** Settings for Amazon Redshift target endpoints. */\nexport interface RedshiftSettings {\n  /** Whether to accept dates in a specific format. */\n  readonly acceptAnyDate?: boolean;\n  /** SQL to run after connecting. */\n  readonly afterConnectScript?: string;\n  /** S3 intermediate bucket folder path. */\n  readonly bucketFolder?: string;\n  /** S3 bucket name used for the intermediate storage. */\n  readonly bucketName?: string;\n  /** Whether to enable case-sensitive column names. */\n  readonly caseSensitiveNames?: boolean;\n  /** Whether to enable automatic compression. */\n  readonly compUpdate?: boolean;\n  /** Timeout in seconds for database connections. */\n  readonly connectionTimeout?: number;\n  /** Date format for the DATEFORMAT option. */\n  readonly dateFormat?: string;\n  /** Whether to load empty strings as NULL. */\n  readonly emptyAsNull?: boolean;\n  /** Encryption mode for data at rest. */\n  readonly encryptionMode?: EncryptionMode;\n  /** Whether to allow explicit ID values in the COPY command. */\n  readonly explicitIds?: boolean;\n  /** Number of upload streams for parallel loading. */\n  readonly fileTransferUploadStreams?: number;\n  /** Timeout (in seconds) for loading data. */\n  readonly loadTimeout?: number;\n  /** Maximum file size (in KB) for each intermediate file. */\n  readonly maxFileSize?: number;\n  /** Whether to remove quoted data. */\n  readonly removeQuotes?: boolean;\n  /** Character to use to replace invalid UTF-8 characters. */\n  readonly replaceInvalidChars?: string;\n  /** Character to replace a specific character with. */\n  readonly replaceChars?: string;\n  /** ARN of IAM role for accessing Secrets Manager. */\n  readonly secretsManagerAccessRoleArn?: string;\n  /** Full ARN or name of the Secrets Manager secret. */\n  readonly secretsManagerSecretId?: string;\n  /** KMS key ARN for SSE-KMS. */\n  readonly serverSideEncryptionKmsKeyId?: string;\n  /** ARN of the IAM role that provides DMS access to the S3 staging bucket. */\n  readonly serviceAccessRoleArn?: string;\n  /** Date format for the TIMEFORMAT option. */\n  readonly timeFormat?: string;\n  /** Whether to remove trailing blanks from VARCHAR columns. */\n  readonly trimBlanks?: boolean;\n  /** Whether to truncate VARCHAR columns to the maximum length. */\n  readonly truncateColumns?: boolean;\n  /** Size of the write buffer (in KB). */\n  readonly writeBufferSize?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Amazon Kinesis Data Streams\n// ---------------------------------------------------------------------------\n\n/** Settings for Amazon Kinesis Data Streams target endpoints. */\nexport interface KinesisSettings {\n  /** ARN of the Kinesis stream. */\n  readonly streamArn: string;\n  /** ARN of the IAM role that provides DMS access to Kinesis. */\n  readonly serviceAccessRoleArn: string;\n  /** Whether to include control details in messages. */\n  readonly includeControlDetails?: boolean;\n  /** Whether to include null and empty columns in messages. */\n  readonly includeNullAndEmpty?: boolean;\n  /** Whether to include the partition value in messages. */\n  readonly includePartitionValue?: boolean;\n  /** Whether to include table ALTER operations in messages. */\n  readonly includeTableAlterOperations?: boolean;\n  /** Whether to include transaction details in messages. */\n  readonly includeTransactionDetails?: boolean;\n  /** Message format. */\n  readonly messageFormat?: MessageFormat;\n  /** Whether to omit the hex prefix from binary values. */\n  readonly noHexPrefix?: boolean;\n  /** Whether to include the schema name in the partition key. */\n  readonly partitionIncludeSchemaTable?: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// Apache Kafka\n// ---------------------------------------------------------------------------\n\n/** Settings for Apache Kafka (and Amazon MSK) target endpoints. */\nexport interface KafkaSettings {\n  /** Kafka broker(s), e.g. \"b-1.msk-cluster.abc123.kafka.us-east-1.amazonaws.com:9092\". */\n  readonly broker: string;\n  /** Topic name to publish to. */\n  readonly topic?: string;\n  /** Whether to include control details in messages. */\n  readonly includeControlDetails?: boolean;\n  /** Whether to include null and empty columns in messages. */\n  readonly includeNullAndEmpty?: boolean;\n  /** Whether to include the partition value in messages. */\n  readonly includePartitionValue?: boolean;\n  /** Whether to include table ALTER operations. */\n  readonly includeTableAlterOperations?: boolean;\n  /** Whether to include transaction details. */\n  readonly includeTransactionDetails?: boolean;\n  /** Message format. */\n  readonly messageFormat?: MessageFormat;\n  /** Maximum message size in bytes. */\n  readonly messageMaxBytes?: number;\n  /** Whether to omit the hex prefix from binary values. */\n  readonly noHexPrefix?: boolean;\n  /** Whether to include the schema name in the partition key. */\n  readonly partitionIncludeSchemaTable?: boolean;\n  /** Security protocol for the Kafka connection. */\n  readonly securityProtocol?: KafkaSecurityProtocol;\n  /** SASL username. */\n  readonly saslUsername?: string;\n  /** SASL password. */\n  readonly saslPassword?: cdk.SecretValue;\n  /** ARN of the Secrets Manager secret holding the CA certificate. */\n  readonly sslCaCertificateArn?: string;\n  /** ARN of the Secrets Manager secret holding the client certificate. */\n  readonly sslClientCertificateArn?: string;\n  /** ARN of the Secrets Manager secret holding the client key. */\n  readonly sslClientKeyArn?: string;\n  /** Password for the client key. */\n  readonly sslClientKeyPassword?: cdk.SecretValue;\n}\n\n// ---------------------------------------------------------------------------\n// Amazon OpenSearch Service\n// ---------------------------------------------------------------------------\n\n/** Settings for Amazon OpenSearch Service target endpoints. */\nexport interface OpenSearchSettings {\n  /** Endpoint URL of the OpenSearch cluster (e.g. https://my-domain.us-east-1.es.amazonaws.com). */\n  readonly endpointUri: string;\n  /** ARN of the IAM role that provides DMS access to OpenSearch. */\n  readonly serviceAccessRoleArn: string;\n  /** Number of seconds to retry on errors before failing. */\n  readonly errorRetryDuration?: number;\n  /** Maximum percentage of records that may fail before the task is stopped. */\n  readonly fullLoadErrorPercentage?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Amazon Neptune\n// ---------------------------------------------------------------------------\n\n/** Settings for Amazon Neptune target endpoints. */\nexport interface NeptuneSettings {\n  /** S3 bucket where DMS stages the migration data. */\n  readonly s3BucketName: string;\n  /** Folder within the S3 bucket for Neptune staging data. */\n  readonly s3BucketFolder: string;\n  /** ARN of the IAM role that provides DMS access to S3 and Neptune. */\n  readonly serviceAccessRoleArn: string;\n  /** Number of seconds to retry on errors before failing the task. */\n  readonly errorRetryDuration?: number;\n  /** Whether IAM auth is enabled on the Neptune cluster. */\n  readonly iamAuthEnabled?: boolean;\n  /** Maximum number of files per request to the Neptune bulk-load API. */\n  readonly maxFileSize?: number;\n  /** Maximum number of retries on endpoint exceptions. */\n  readonly maxRetryCount?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Amazon ElastiCache for Redis\n// ---------------------------------------------------------------------------\n\n/** Settings for Amazon ElastiCache for Redis target endpoints. */\nexport interface RedisSettings {\n  /** Redis server name or cluster endpoint. */\n  readonly serverName: string;\n  /** Redis port. Default: 6379. */\n  readonly port?: number;\n  /** SSL security protocol. */\n  readonly sslSecurityProtocol?: string;\n  /** Authentication type: none, auth-token, or auth-role. */\n  readonly authType?: string;\n  /** IAM role ARN for auth-role authentication. */\n  readonly authUserName?: string;\n  /** Auth token for auth-token authentication. */\n  readonly authPassword?: cdk.SecretValue;\n  /** ARN of the SSL CA certificate stored in Secrets Manager. */\n  readonly sslCaCertificateArn?: string;\n}\n"]}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import * as cdk from 'aws-cdk-lib';
|
|
2
|
+
import * as dms from 'aws-cdk-lib/aws-dms';
|
|
3
|
+
import { Construct } from 'constructs';
|
|
4
|
+
import { Db2Settings, DynamoDbSettings, KafkaSettings, KinesisSettings, MongoDbSettings, MySqlSettings, NeptuneSettings, OpenSearchSettings, OracleSettings, PostgreSqlSettings, RedisSettings, RedshiftSettings, S3Settings, SapAseSettings, SqlServerSettings } from './endpoint-settings';
|
|
5
|
+
import { EndpointEngine, EndpointType } from './enums';
|
|
6
|
+
/**
|
|
7
|
+
* Minimal contract for a DMS endpoint that can be used as a source or target
|
|
8
|
+
* in a {@link DmsReplicationTask} or {@link DmsMigrationPipeline}.
|
|
9
|
+
*
|
|
10
|
+
* Use this interface when referencing an endpoint created outside of this
|
|
11
|
+
* construct (e.g. by ARN). For endpoints created by this library, use the
|
|
12
|
+
* concrete {@link DmsEndpoint} class directly — it exposes `cfnEndpoint`
|
|
13
|
+
* for L1 escape-hatch access.
|
|
14
|
+
*/
|
|
15
|
+
export interface IDmsEndpoint {
|
|
16
|
+
/** ARN of the DMS endpoint. */
|
|
17
|
+
readonly endpointArn: string;
|
|
18
|
+
}
|
|
19
|
+
/** Props for {@link DmsEndpoint}. */
|
|
20
|
+
export interface DmsEndpointProps {
|
|
21
|
+
/** Whether this is a source or target endpoint. */
|
|
22
|
+
readonly endpointType: EndpointType;
|
|
23
|
+
/** Database engine for this endpoint. */
|
|
24
|
+
readonly engine: EndpointEngine;
|
|
25
|
+
/**
|
|
26
|
+
* Logical identifier of the endpoint (used as the DMS endpoint identifier).
|
|
27
|
+
* Auto-generated from the construct ID if not provided.
|
|
28
|
+
*/
|
|
29
|
+
readonly endpointIdentifier?: string;
|
|
30
|
+
/** Database server hostname or IP address. */
|
|
31
|
+
readonly serverName?: string;
|
|
32
|
+
/** Database port. */
|
|
33
|
+
readonly port?: number;
|
|
34
|
+
/** Database user name. Used when not using Secrets Manager. */
|
|
35
|
+
readonly username?: string;
|
|
36
|
+
/**
|
|
37
|
+
* Database password.
|
|
38
|
+
*
|
|
39
|
+
* @warning The resolved value is stored as **plaintext** in the CloudFormation
|
|
40
|
+
* template and state file. For production workloads, use Secrets Manager
|
|
41
|
+
* instead: set `secretsManagerSecretId` and `secretsManagerAccessRoleArn`
|
|
42
|
+
* in the engine-specific settings (e.g. `mySqlSettings`, `postgreSqlSettings`)
|
|
43
|
+
* and omit this property entirely.
|
|
44
|
+
*/
|
|
45
|
+
readonly password?: cdk.SecretValue;
|
|
46
|
+
/** Database name on the endpoint. */
|
|
47
|
+
readonly databaseName?: string;
|
|
48
|
+
/**
|
|
49
|
+
* Extra connection attributes as a semicolon-separated string.
|
|
50
|
+
* Refer to the DMS documentation for engine-specific attributes.
|
|
51
|
+
*/
|
|
52
|
+
readonly extraConnectionAttributes?: string;
|
|
53
|
+
/**
|
|
54
|
+
* ARN of the SSL certificate authority certificate.
|
|
55
|
+
* Required when sslMode is 'verify-ca' or 'verify-full'.
|
|
56
|
+
*/
|
|
57
|
+
readonly certificateArn?: string;
|
|
58
|
+
/**
|
|
59
|
+
* SSL mode for the connection.
|
|
60
|
+
* @default "none"
|
|
61
|
+
*/
|
|
62
|
+
readonly sslMode?: string;
|
|
63
|
+
/** Settings for MySQL or MariaDB endpoints. */
|
|
64
|
+
readonly mySqlSettings?: MySqlSettings;
|
|
65
|
+
/** Settings for PostgreSQL or Aurora PostgreSQL endpoints. */
|
|
66
|
+
readonly postgreSqlSettings?: PostgreSqlSettings;
|
|
67
|
+
/** Settings for Oracle endpoints. */
|
|
68
|
+
readonly oracleSettings?: OracleSettings;
|
|
69
|
+
/** Settings for Microsoft SQL Server endpoints. */
|
|
70
|
+
readonly sqlServerSettings?: SqlServerSettings;
|
|
71
|
+
/** Settings for SAP ASE (Sybase) endpoints. */
|
|
72
|
+
readonly sapAseSettings?: SapAseSettings;
|
|
73
|
+
/** Settings for IBM Db2 LUW endpoints. */
|
|
74
|
+
readonly db2Settings?: Db2Settings;
|
|
75
|
+
/** Settings for MongoDB or Amazon DocumentDB endpoints. */
|
|
76
|
+
readonly mongoDbSettings?: MongoDbSettings;
|
|
77
|
+
/** Settings for Amazon S3 endpoints. */
|
|
78
|
+
readonly s3Settings?: S3Settings;
|
|
79
|
+
/** Settings for Amazon DynamoDB target endpoints. */
|
|
80
|
+
readonly dynamoDbSettings?: DynamoDbSettings;
|
|
81
|
+
/** Settings for Amazon Redshift target endpoints. */
|
|
82
|
+
readonly redshiftSettings?: RedshiftSettings;
|
|
83
|
+
/** Settings for Amazon Kinesis Data Streams target endpoints. */
|
|
84
|
+
readonly kinesisSettings?: KinesisSettings;
|
|
85
|
+
/** Settings for Apache Kafka (and Amazon MSK) target endpoints. */
|
|
86
|
+
readonly kafkaSettings?: KafkaSettings;
|
|
87
|
+
/** Settings for Amazon OpenSearch Service target endpoints. */
|
|
88
|
+
readonly openSearchSettings?: OpenSearchSettings;
|
|
89
|
+
/** Settings for Amazon Neptune target endpoints. */
|
|
90
|
+
readonly neptuneSettings?: NeptuneSettings;
|
|
91
|
+
/** Settings for Amazon ElastiCache for Redis target endpoints. */
|
|
92
|
+
readonly redisSettings?: RedisSettings;
|
|
93
|
+
/**
|
|
94
|
+
* Removal policy for the endpoint resource.
|
|
95
|
+
* @default cdk.RemovalPolicy.DESTROY
|
|
96
|
+
*/
|
|
97
|
+
readonly removalPolicy?: cdk.RemovalPolicy;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* A DMS endpoint construct supporting every engine that DMS supports.
|
|
101
|
+
*
|
|
102
|
+
* Set `engine` to the desired {@link EndpointEngine} and supply the
|
|
103
|
+
* matching `*Settings` property. All other `*Settings` properties are
|
|
104
|
+
* ignored at runtime.
|
|
105
|
+
*
|
|
106
|
+
* @example
|
|
107
|
+
* // MySQL source
|
|
108
|
+
* new DmsEndpoint(this, 'Source', {
|
|
109
|
+
* endpointType: EndpointType.SOURCE,
|
|
110
|
+
* engine: EndpointEngine.MYSQL,
|
|
111
|
+
* serverName: 'mysql.example.com',
|
|
112
|
+
* port: 3306,
|
|
113
|
+
* username: 'dms_user',
|
|
114
|
+
* password: cdk.SecretValue.ssmSecure('/dms/mysql/password'),
|
|
115
|
+
* databaseName: 'mydb',
|
|
116
|
+
* });
|
|
117
|
+
*/
|
|
118
|
+
export declare class DmsEndpoint extends Construct implements IDmsEndpoint {
|
|
119
|
+
private static readonly TARGET_ONLY_ENGINES;
|
|
120
|
+
private static readonly SOURCE_ONLY_ENGINES;
|
|
121
|
+
private static validateEngineEndpointType;
|
|
122
|
+
/** The underlying CloudFormation endpoint resource. */
|
|
123
|
+
readonly cfnEndpoint: dms.CfnEndpoint;
|
|
124
|
+
/** ARN of the DMS endpoint. */
|
|
125
|
+
readonly endpointArn: string;
|
|
126
|
+
constructor(scope: Construct, id: string, props: DmsEndpointProps);
|
|
127
|
+
private buildMySqlSettings;
|
|
128
|
+
private buildPostgreSqlSettings;
|
|
129
|
+
private buildOracleSettings;
|
|
130
|
+
private buildSqlServerSettings;
|
|
131
|
+
private buildSapAseSettings;
|
|
132
|
+
private buildDb2Settings;
|
|
133
|
+
private buildMongoDbSettings;
|
|
134
|
+
private buildDocDbSettings;
|
|
135
|
+
private buildS3Settings;
|
|
136
|
+
private buildDynamoDbSettings;
|
|
137
|
+
private buildRedshiftSettings;
|
|
138
|
+
private buildKinesisSettings;
|
|
139
|
+
private buildKafkaSettings;
|
|
140
|
+
private buildOpenSearchSettings;
|
|
141
|
+
private buildNeptuneSettings;
|
|
142
|
+
private buildRedisSettings;
|
|
143
|
+
}
|