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.
@@ -0,0 +1,291 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.TaskSettings = exports.ErrorAction = exports.LoggingLevel = exports.LobMode = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Builder for DMS replication task settings.
8
+ *
9
+ * The DMS task settings JSON controls logging, LOB handling, error handling,
10
+ * full-load tuning, and CDC tuning. This builder exposes the most commonly
11
+ * tuned knobs and produces the JSON string expected by a replication task.
12
+ *
13
+ * @see https://docs.aws.amazon.com/dms/latest/userguide/CHAP_Tasks.CustomizingTasks.TaskSettings.html
14
+ */
15
+ // ---------------------------------------------------------------------------
16
+ // Enums
17
+ // ---------------------------------------------------------------------------
18
+ /** LOB (Large Object) handling mode. */
19
+ var LobMode;
20
+ (function (LobMode) {
21
+ /** No LOB support. */
22
+ LobMode["NONE"] = "none";
23
+ /** All LOBs are migrated as inline data (full LOB mode). */
24
+ LobMode["FULL_LOB"] = "full-lob";
25
+ /** LOBs are truncated at a configurable size. */
26
+ LobMode["LIMITED_LOB"] = "limited-lob";
27
+ })(LobMode || (exports.LobMode = LobMode = {}));
28
+ /** Logging verbosity for DMS task log components. */
29
+ var LoggingLevel;
30
+ (function (LoggingLevel) {
31
+ LoggingLevel["LOGGER_SEVERITY_DEFAULT"] = "LOGGER_SEVERITY_DEFAULT";
32
+ LoggingLevel["LOGGER_SEVERITY_DEBUG"] = "LOGGER_SEVERITY_DEBUG";
33
+ LoggingLevel["LOGGER_SEVERITY_DETAILED_DEBUG"] = "LOGGER_SEVERITY_DETAILED_DEBUG";
34
+ LoggingLevel["LOGGER_SEVERITY_ERROR"] = "LOGGER_SEVERITY_ERROR";
35
+ LoggingLevel["LOGGER_SEVERITY_WARNING"] = "LOGGER_SEVERITY_WARNING";
36
+ })(LoggingLevel || (exports.LoggingLevel = LoggingLevel = {}));
37
+ /** Action to take on a recoverable error. */
38
+ var ErrorAction;
39
+ (function (ErrorAction) {
40
+ /** Ignore the error and continue. */
41
+ ErrorAction["IGNORE"] = "IGNORE";
42
+ /** Ignore the row, continue with the next. */
43
+ ErrorAction["IGNORE_RECORD"] = "IGNORE_RECORD";
44
+ /** Stop the task. */
45
+ ErrorAction["STOP_TASK"] = "STOP_TASK";
46
+ })(ErrorAction || (exports.ErrorAction = ErrorAction = {}));
47
+ // ---------------------------------------------------------------------------
48
+ // Builder
49
+ // ---------------------------------------------------------------------------
50
+ /**
51
+ * Fluent builder for DMS task settings.
52
+ *
53
+ * @example
54
+ * const settings = new TaskSettings()
55
+ * .withLobMode(LobMode.LIMITED_LOB, 32)
56
+ * .withFullLoadSubTasks(16)
57
+ * .withBatchApply(true, 5, 60)
58
+ * .withDataErrorPolicy(ErrorAction.IGNORE_RECORD, 100)
59
+ * .withLogging('SOURCE_UNLOAD', LoggingLevel.LOGGER_SEVERITY_DEFAULT)
60
+ * .toJson();
61
+ */
62
+ class TaskSettings {
63
+ constructor() {
64
+ this.lobMode = LobMode.LIMITED_LOB;
65
+ this.lobMaxSize = 32;
66
+ this.fullLoadSettings = {};
67
+ this.cdcSettings = {};
68
+ this.errorHandlingSettings = {};
69
+ this.loggingEnabled = true;
70
+ this.logComponents = {};
71
+ }
72
+ // -------------------------------------------------------------------------
73
+ // LOB handling
74
+ // -------------------------------------------------------------------------
75
+ /**
76
+ * Configure LOB handling.
77
+ *
78
+ * @param mode How LOBs are handled.
79
+ * @param maxSizeKb Maximum LOB size in KB when mode is LIMITED_LOB. Ignored otherwise.
80
+ */
81
+ withLobMode(mode, maxSizeKb) {
82
+ this.lobMode = mode;
83
+ if (maxSizeKb !== undefined) {
84
+ this.lobMaxSize = maxSizeKb;
85
+ }
86
+ return this;
87
+ }
88
+ // -------------------------------------------------------------------------
89
+ // Full load
90
+ // -------------------------------------------------------------------------
91
+ /**
92
+ * Set the maximum number of tables loaded in parallel.
93
+ * @param count Default 8.
94
+ */
95
+ withFullLoadSubTasks(count) {
96
+ this.fullLoadSettings = { ...this.fullLoadSettings, maxFullLoadSubTasks: count };
97
+ return this;
98
+ }
99
+ /**
100
+ * Set the full-load target table prepare mode.
101
+ * Common values: "DROP_AND_CREATE", "TRUNCATE_BEFORE_LOAD", "DO_NOTHING".
102
+ */
103
+ withTargetTablePrepMode(mode) {
104
+ this.fullLoadSettings = { ...this.fullLoadSettings, targetTablePrepMode: mode };
105
+ return this;
106
+ }
107
+ /**
108
+ * Set the commit rate (number of rows per commit) during full load.
109
+ */
110
+ withCommitRate(rows) {
111
+ this.fullLoadSettings = { ...this.fullLoadSettings, commitRate: rows };
112
+ return this;
113
+ }
114
+ // -------------------------------------------------------------------------
115
+ // CDC / batch apply
116
+ // -------------------------------------------------------------------------
117
+ /**
118
+ * Enable or disable CDC batch apply mode and configure its timeouts.
119
+ *
120
+ * @param enabled Whether batch apply is on.
121
+ * @param minSeconds Minimum seconds before applying a batch (default 1).
122
+ * @param maxSeconds Maximum seconds before applying a batch (default 30).
123
+ */
124
+ withBatchApply(enabled, minSeconds, maxSeconds) {
125
+ this.cdcSettings = {
126
+ ...this.cdcSettings,
127
+ batchApplyEnabled: enabled,
128
+ batchApplyTimeoutMin: minSeconds ?? 1,
129
+ batchApplyTimeoutMax: maxSeconds ?? 30,
130
+ };
131
+ return this;
132
+ }
133
+ // -------------------------------------------------------------------------
134
+ // Error handling
135
+ // -------------------------------------------------------------------------
136
+ /**
137
+ * Configure the action taken on data errors.
138
+ *
139
+ * @param policy Action when a data error is encountered.
140
+ * @param escalationCount After this many errors, apply the escalation policy (0 = immediate).
141
+ * @param escalationPolicy Action after `escalationCount` errors.
142
+ */
143
+ withDataErrorPolicy(policy, escalationCount, escalationPolicy) {
144
+ this.errorHandlingSettings = {
145
+ ...this.errorHandlingSettings,
146
+ dataErrorPolicy: policy,
147
+ dataErrorEscalationCount: escalationCount ?? 0,
148
+ dataErrorEscalationPolicy: escalationPolicy ?? policy,
149
+ };
150
+ return this;
151
+ }
152
+ /**
153
+ * Configure recovery from transient errors.
154
+ *
155
+ * @param count Maximum recovery attempts (-1 = unlimited).
156
+ * @param interval Seconds between attempts.
157
+ */
158
+ withRecovery(count, interval) {
159
+ this.errorHandlingSettings = {
160
+ ...this.errorHandlingSettings,
161
+ recoverableErrorCount: count,
162
+ recoverableErrorInterval: interval ?? 5,
163
+ };
164
+ return this;
165
+ }
166
+ // -------------------------------------------------------------------------
167
+ // Logging
168
+ // -------------------------------------------------------------------------
169
+ /**
170
+ * Enable or disable CloudWatch logging for the task.
171
+ * @default true
172
+ */
173
+ withLoggingEnabled(enabled) {
174
+ this.loggingEnabled = enabled;
175
+ return this;
176
+ }
177
+ /**
178
+ * Set the logging level for a named DMS log component.
179
+ *
180
+ * Common component names: SOURCE_UNLOAD, TARGET_LOAD, TASK_MANAGER,
181
+ * SOURCE_CAPTURE, TARGET_APPLY, REST_SERVER, TRANSFORMATION.
182
+ */
183
+ withLogging(component, level) {
184
+ this.logComponents[component] = level;
185
+ return this;
186
+ }
187
+ // -------------------------------------------------------------------------
188
+ // Output
189
+ // -------------------------------------------------------------------------
190
+ /**
191
+ * Produce the JSON string that DMS expects for `replicationTaskSettings`.
192
+ */
193
+ toJson() {
194
+ const lobSettings = this.lobMode === LobMode.NONE
195
+ ? { SupportLobs: false }
196
+ : {
197
+ SupportLobs: true,
198
+ LobMode: this.lobMode === LobMode.FULL_LOB ? 2 : 1,
199
+ LobMaxSize: this.lobMode === LobMode.LIMITED_LOB ? this.lobMaxSize : 0,
200
+ };
201
+ const logComponentList = Object.entries(this.logComponents).map(([id, level]) => ({
202
+ Id: id,
203
+ Severity: level,
204
+ }));
205
+ const settings = {
206
+ TargetMetadata: {
207
+ SupportLobs: lobSettings.SupportLobs,
208
+ FullLobMode: this.lobMode === LobMode.FULL_LOB,
209
+ LobChunkSize: 0,
210
+ LimitedSizeLobMode: this.lobMode === LobMode.LIMITED_LOB,
211
+ LobMaxSize: lobSettings.LobMaxSize ?? 0,
212
+ },
213
+ FullLoadSettings: {
214
+ TargetTablePrepMode: this.fullLoadSettings.targetTablePrepMode ?? 'DROP_AND_CREATE',
215
+ CreatePkAfterFullLoad: false,
216
+ StopTaskCachedChangesApplied: this.fullLoadSettings.stopTaskCachedChangesApplied ?? false,
217
+ StopTaskCachedChangesNotApplied: false,
218
+ MaxFullLoadSubTasks: this.fullLoadSettings.maxFullLoadSubTasks ?? 8,
219
+ TransactionConsistencyTimeout: this.fullLoadSettings.transactionConsistencyTimeout ?? 600,
220
+ CommitRate: this.fullLoadSettings.commitRate ?? 10000,
221
+ },
222
+ Logging: {
223
+ EnableLogging: this.loggingEnabled,
224
+ LogComponents: logComponentList.length > 0 ? logComponentList : [
225
+ { Id: 'SOURCE_UNLOAD', Severity: LoggingLevel.LOGGER_SEVERITY_DEFAULT },
226
+ { Id: 'TARGET_LOAD', Severity: LoggingLevel.LOGGER_SEVERITY_DEFAULT },
227
+ { Id: 'TASK_MANAGER', Severity: LoggingLevel.LOGGER_SEVERITY_DEFAULT },
228
+ ],
229
+ },
230
+ ControlTablesSettings: {
231
+ historyTimeslotInMinutes: 5,
232
+ StatusTableEnabled: false,
233
+ SuspendedTablesTableEnabled: false,
234
+ historyTableEnabled: false,
235
+ replicationTaskTableEnabled: false,
236
+ statusTableEnabled: false,
237
+ suspendedTablesTableEnabled: false,
238
+ },
239
+ StreamBufferSettings: {
240
+ StreamBufferCount: 3,
241
+ StreamBufferSizeInMB: 8,
242
+ CtrlStreamBufferSizeInMB: 5,
243
+ },
244
+ ChangeProcessingDdlHandlingPolicy: {
245
+ HandleSourceTableDropped: true,
246
+ HandleSourceTableTruncated: true,
247
+ HandleSourceTableAltered: true,
248
+ },
249
+ ErrorBehavior: {
250
+ DataErrorPolicy: this.errorHandlingSettings.dataErrorPolicy ?? ErrorAction.STOP_TASK,
251
+ DataErrorEscalationPolicy: this.errorHandlingSettings.dataErrorEscalationPolicy ?? ErrorAction.STOP_TASK,
252
+ DataErrorEscalationCount: this.errorHandlingSettings.dataErrorEscalationCount ?? 0,
253
+ TableErrorPolicy: this.errorHandlingSettings.tableErrorPolicy ?? ErrorAction.STOP_TASK,
254
+ TableErrorEscalationPolicy: this.errorHandlingSettings.tableErrorEscalationPolicy ?? ErrorAction.STOP_TASK,
255
+ TableErrorEscalationCount: this.errorHandlingSettings.tableErrorEscalationCount ?? 0,
256
+ RecoverableErrorCount: this.errorHandlingSettings.recoverableErrorCount ?? -1,
257
+ RecoverableErrorInterval: this.errorHandlingSettings.recoverableErrorInterval ?? 5,
258
+ RecoverableErrorThrottling: this.errorHandlingSettings.recoverableErrorThrottling ?? true,
259
+ RecoverableErrorThrottlingMax: this.errorHandlingSettings.recoverableErrorThrottlingMax ?? 1800,
260
+ RecoverableErrorStopRetryAfterThrottlingMax: true,
261
+ ApplyErrorDeletePolicy: ErrorAction.IGNORE_RECORD,
262
+ ApplyErrorInsertPolicy: ErrorAction.IGNORE_RECORD,
263
+ ApplyErrorUpdatePolicy: ErrorAction.IGNORE_RECORD,
264
+ ApplyErrorEscalationPolicy: ErrorAction.STOP_TASK,
265
+ ApplyErrorEscalationCount: 0,
266
+ ApplyErrorFailOnTruncationDdl: false,
267
+ FailOnNoTablesCaptured: this.cdcSettings.failOnNoTablesCaptured ?? true,
268
+ FailOnTransactionConsistencyBreached: false,
269
+ FullLoadIgnoreConflicts: true,
270
+ },
271
+ ChangeProcessingTuning: {
272
+ BatchApplyEnabled: this.cdcSettings.batchApplyEnabled ?? false,
273
+ BatchApplyPreserveTransaction: true,
274
+ BatchApplyTimeoutMin: this.cdcSettings.batchApplyTimeoutMin ?? 1,
275
+ BatchApplyTimeoutMax: this.cdcSettings.batchApplyTimeoutMax ?? 30,
276
+ BatchApplyMemoryLimit: this.cdcSettings.batchApplyMemoryLimit ?? 500,
277
+ BatchSplitSize: 0,
278
+ MinTransactionSize: 1000,
279
+ CommitTimeout: 1,
280
+ MemoryLimitTotal: 1024,
281
+ MemoryKeepTime: 60,
282
+ StatementCacheSize: 50,
283
+ },
284
+ };
285
+ return JSON.stringify(settings, null, 2);
286
+ }
287
+ }
288
+ exports.TaskSettings = TaskSettings;
289
+ _a = JSII_RTTI_SYMBOL_1;
290
+ TaskSettings[_a] = { fqn: "cdk-dms-replication.TaskSettings", version: "0.0.0" };
291
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-settings.js","sourceRoot":"","sources":["../src/task-settings.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;GAQG;AAEH,8EAA8E;AAC9E,QAAQ;AACR,8EAA8E;AAE9E,wCAAwC;AACxC,IAAY,OAOX;AAPD,WAAY,OAAO;IACjB,sBAAsB;IACtB,wBAAa,CAAA;IACb,4DAA4D;IAC5D,gCAAqB,CAAA;IACrB,iDAAiD;IACjD,sCAA2B,CAAA;AAC7B,CAAC,EAPW,OAAO,uBAAP,OAAO,QAOlB;AAED,qDAAqD;AACrD,IAAY,YAMX;AAND,WAAY,YAAY;IACtB,mEAAmD,CAAA;IACnD,+DAA+C,CAAA;IAC/C,iFAAiE,CAAA;IACjE,+DAA+C,CAAA;IAC/C,mEAAmD,CAAA;AACrD,CAAC,EANW,YAAY,4BAAZ,YAAY,QAMvB;AAED,6CAA6C;AAC7C,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,qCAAqC;IACrC,gCAAiB,CAAA;IACjB,8CAA8C;IAC9C,8CAA+B,CAAA;IAC/B,qBAAqB;IACrB,sCAAuB,CAAA;AACzB,CAAC,EAPW,WAAW,2BAAX,WAAW,QAOtB;AA0HD,8EAA8E;AAC9E,UAAU;AACV,8EAA8E;AAE9E;;;;;;;;;;;GAWG;AACH,MAAa,YAAY;IAAzB;QACU,YAAO,GAAY,OAAO,CAAC,WAAW,CAAC;QACvC,eAAU,GAAW,EAAE,CAAC;QACxB,qBAAgB,GAAqB,EAAE,CAAC;QACxC,gBAAW,GAAgB,EAAE,CAAC;QAC9B,0BAAqB,GAA0B,EAAE,CAAC;QAClD,mBAAc,GAAY,IAAI,CAAC;QAC/B,kBAAa,GAA2B,EAAE,CAAC;KAoPpD;IAlPC,4EAA4E;IAC5E,eAAe;IACf,4EAA4E;IAE5E;;;;;OAKG;IACH,WAAW,CAAC,IAAa,EAAE,SAAkB;QAC3C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;YAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC9B,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,4EAA4E;IAC5E,YAAY;IACZ,4EAA4E;IAE5E;;;OAGG;IACH,oBAAoB,CAAC,KAAa;QAChC,IAAI,CAAC,gBAAgB,GAAG,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,mBAAmB,EAAE,KAAK,EAAE,CAAC;QACjF,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACH,uBAAuB,CAAC,IAAY;QAClC,IAAI,CAAC,gBAAgB,GAAG,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,mBAAmB,EAAE,IAAI,EAAE,CAAC;QAChF,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,cAAc,CAAC,IAAY;QACzB,IAAI,CAAC,gBAAgB,GAAG,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;QACvE,OAAO,IAAI,CAAC;IACd,CAAC;IAED,4EAA4E;IAC5E,oBAAoB;IACpB,4EAA4E;IAE5E;;;;;;OAMG;IACH,cAAc,CAAC,OAAgB,EAAE,UAAmB,EAAE,UAAmB;QACvE,IAAI,CAAC,WAAW,GAAG;YACjB,GAAG,IAAI,CAAC,WAAW;YACnB,iBAAiB,EAAE,OAAO;YAC1B,oBAAoB,EAAE,UAAU,IAAI,CAAC;YACrC,oBAAoB,EAAE,UAAU,IAAI,EAAE;SACvC,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;IAED,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E;;;;;;OAMG;IACH,mBAAmB,CACjB,MAAmB,EACnB,eAAwB,EACxB,gBAA8B;QAE9B,IAAI,CAAC,qBAAqB,GAAG;YAC3B,GAAG,IAAI,CAAC,qBAAqB;YAC7B,eAAe,EAAE,MAAM;YACvB,wBAAwB,EAAE,eAAe,IAAI,CAAC;YAC9C,yBAAyB,EAAE,gBAAgB,IAAI,MAAM;SACtD,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,KAAa,EAAE,QAAiB;QAC3C,IAAI,CAAC,qBAAqB,GAAG;YAC3B,GAAG,IAAI,CAAC,qBAAqB;YAC7B,qBAAqB,EAAE,KAAK;YAC5B,wBAAwB,EAAE,QAAQ,IAAI,CAAC;SACxC,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;IAED,4EAA4E;IAC5E,UAAU;IACV,4EAA4E;IAE5E;;;OAGG;IACH,kBAAkB,CAAC,OAAgB;QACjC,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,WAAW,CAAC,SAAiB,EAAE,KAAmB;QAChD,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC;QACtC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,4EAA4E;IAC5E,SAAS;IACT,4EAA4E;IAE5E;;OAEG;IACH,MAAM;QACJ,MAAM,WAAW,GACf,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,IAAI;YAC3B,CAAC,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE;YACxB,CAAC,CAAC;gBACA,WAAW,EAAE,IAAI;gBACjB,OAAO,EAAE,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAClD,UAAU,EAAE,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;aACvE,CAAC;QAEN,MAAM,gBAAgB,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;YAChF,EAAE,EAAE,EAAE;YACN,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC,CAAC;QAEJ,MAAM,QAAQ,GAA4B;YACxC,cAAc,EAAE;gBACd,WAAW,EAAE,WAAW,CAAC,WAAW;gBACpC,WAAW,EAAE,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,QAAQ;gBAC9C,YAAY,EAAE,CAAC;gBACf,kBAAkB,EAAE,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,WAAW;gBACxD,UAAU,EAAE,WAAW,CAAC,UAAU,IAAI,CAAC;aACxC;YACD,gBAAgB,EAAE;gBAChB,mBAAmB,EAAE,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,IAAI,iBAAiB;gBACnF,qBAAqB,EAAE,KAAK;gBAC5B,4BAA4B,EAAE,IAAI,CAAC,gBAAgB,CAAC,4BAA4B,IAAI,KAAK;gBACzF,+BAA+B,EAAE,KAAK;gBACtC,mBAAmB,EAAE,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,IAAI,CAAC;gBACnE,6BAA6B,EAAE,IAAI,CAAC,gBAAgB,CAAC,6BAA6B,IAAI,GAAG;gBACzF,UAAU,EAAE,IAAI,CAAC,gBAAgB,CAAC,UAAU,IAAI,KAAK;aACtD;YACD,OAAO,EAAE;gBACP,aAAa,EAAE,IAAI,CAAC,cAAc;gBAClC,aAAa,EAAE,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC;oBAC9D,EAAE,EAAE,EAAE,eAAe,EAAE,QAAQ,EAAE,YAAY,CAAC,uBAAuB,EAAE;oBACvE,EAAE,EAAE,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,CAAC,uBAAuB,EAAE;oBACrE,EAAE,EAAE,EAAE,cAAc,EAAE,QAAQ,EAAE,YAAY,CAAC,uBAAuB,EAAE;iBACvE;aACF;YACD,qBAAqB,EAAE;gBACrB,wBAAwB,EAAE,CAAC;gBAC3B,kBAAkB,EAAE,KAAK;gBACzB,2BAA2B,EAAE,KAAK;gBAClC,mBAAmB,EAAE,KAAK;gBAC1B,2BAA2B,EAAE,KAAK;gBAClC,kBAAkB,EAAE,KAAK;gBACzB,2BAA2B,EAAE,KAAK;aACnC;YACD,oBAAoB,EAAE;gBACpB,iBAAiB,EAAE,CAAC;gBACpB,oBAAoB,EAAE,CAAC;gBACvB,wBAAwB,EAAE,CAAC;aAC5B;YACD,iCAAiC,EAAE;gBACjC,wBAAwB,EAAE,IAAI;gBAC9B,0BAA0B,EAAE,IAAI;gBAChC,wBAAwB,EAAE,IAAI;aAC/B;YACD,aAAa,EAAE;gBACb,eAAe,EAAE,IAAI,CAAC,qBAAqB,CAAC,eAAe,IAAI,WAAW,CAAC,SAAS;gBACpF,yBAAyB,EACvB,IAAI,CAAC,qBAAqB,CAAC,yBAAyB,IAAI,WAAW,CAAC,SAAS;gBAC/E,wBAAwB,EAAE,IAAI,CAAC,qBAAqB,CAAC,wBAAwB,IAAI,CAAC;gBAClF,gBAAgB,EAAE,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,IAAI,WAAW,CAAC,SAAS;gBACtF,0BAA0B,EACxB,IAAI,CAAC,qBAAqB,CAAC,0BAA0B,IAAI,WAAW,CAAC,SAAS;gBAChF,yBAAyB,EAAE,IAAI,CAAC,qBAAqB,CAAC,yBAAyB,IAAI,CAAC;gBACpF,qBAAqB,EAAE,IAAI,CAAC,qBAAqB,CAAC,qBAAqB,IAAI,CAAC,CAAC;gBAC7E,wBAAwB,EAAE,IAAI,CAAC,qBAAqB,CAAC,wBAAwB,IAAI,CAAC;gBAClF,0BAA0B,EACxB,IAAI,CAAC,qBAAqB,CAAC,0BAA0B,IAAI,IAAI;gBAC/D,6BAA6B,EAC3B,IAAI,CAAC,qBAAqB,CAAC,6BAA6B,IAAI,IAAI;gBAClE,2CAA2C,EAAE,IAAI;gBACjD,sBAAsB,EAAE,WAAW,CAAC,aAAa;gBACjD,sBAAsB,EAAE,WAAW,CAAC,aAAa;gBACjD,sBAAsB,EAAE,WAAW,CAAC,aAAa;gBACjD,0BAA0B,EAAE,WAAW,CAAC,SAAS;gBACjD,yBAAyB,EAAE,CAAC;gBAC5B,6BAA6B,EAAE,KAAK;gBACpC,sBAAsB,EAAE,IAAI,CAAC,WAAW,CAAC,sBAAsB,IAAI,IAAI;gBACvE,oCAAoC,EAAE,KAAK;gBAC3C,uBAAuB,EAAE,IAAI;aAC9B;YACD,sBAAsB,EAAE;gBACtB,iBAAiB,EAAE,IAAI,CAAC,WAAW,CAAC,iBAAiB,IAAI,KAAK;gBAC9D,6BAA6B,EAAE,IAAI;gBACnC,oBAAoB,EAAE,IAAI,CAAC,WAAW,CAAC,oBAAoB,IAAI,CAAC;gBAChE,oBAAoB,EAAE,IAAI,CAAC,WAAW,CAAC,oBAAoB,IAAI,EAAE;gBACjE,qBAAqB,EAAE,IAAI,CAAC,WAAW,CAAC,qBAAqB,IAAI,GAAG;gBACpE,cAAc,EAAE,CAAC;gBACjB,kBAAkB,EAAE,IAAI;gBACxB,aAAa,EAAE,CAAC;gBAChB,gBAAgB,EAAE,IAAI;gBACtB,cAAc,EAAE,EAAE;gBAClB,kBAAkB,EAAE,EAAE;aACvB;SACF,CAAC;QAEF,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAC3C,CAAC;;AA1PH,oCA2PC","sourcesContent":["/**\n * Builder for DMS replication task settings.\n *\n * The DMS task settings JSON controls logging, LOB handling, error handling,\n * full-load tuning, and CDC tuning. This builder exposes the most commonly\n * tuned knobs and produces the JSON string expected by a replication task.\n *\n * @see https://docs.aws.amazon.com/dms/latest/userguide/CHAP_Tasks.CustomizingTasks.TaskSettings.html\n */\n\n// ---------------------------------------------------------------------------\n// Enums\n// ---------------------------------------------------------------------------\n\n/** LOB (Large Object) handling mode. */\nexport enum LobMode {\n  /** No LOB support. */\n  NONE = 'none',\n  /** All LOBs are migrated as inline data (full LOB mode). */\n  FULL_LOB = 'full-lob',\n  /** LOBs are truncated at a configurable size. */\n  LIMITED_LOB = 'limited-lob',\n}\n\n/** Logging verbosity for DMS task log components. */\nexport enum LoggingLevel {\n  LOGGER_SEVERITY_DEFAULT = 'LOGGER_SEVERITY_DEFAULT',\n  LOGGER_SEVERITY_DEBUG = 'LOGGER_SEVERITY_DEBUG',\n  LOGGER_SEVERITY_DETAILED_DEBUG = 'LOGGER_SEVERITY_DETAILED_DEBUG',\n  LOGGER_SEVERITY_ERROR = 'LOGGER_SEVERITY_ERROR',\n  LOGGER_SEVERITY_WARNING = 'LOGGER_SEVERITY_WARNING',\n}\n\n/** Action to take on a recoverable error. */\nexport enum ErrorAction {\n  /** Ignore the error and continue. */\n  IGNORE = 'IGNORE',\n  /** Ignore the row, continue with the next. */\n  IGNORE_RECORD = 'IGNORE_RECORD',\n  /** Stop the task. */\n  STOP_TASK = 'STOP_TASK',\n}\n\n// ---------------------------------------------------------------------------\n// Props interfaces\n// ---------------------------------------------------------------------------\n\n/** Logging configuration for a single DMS log component. */\nexport interface LogComponentSettings {\n  /** Logging level for this component. */\n  readonly loggingLevel?: LoggingLevel;\n}\n\n/** Controls how the task handles full-load data. */\nexport interface FullLoadSettings {\n  /**\n   * Maximum number of tables to load in parallel.\n   * @default 8\n   */\n  readonly maxFullLoadSubTasks?: number;\n  /**\n   * Number of rows to load before a commit.\n   * @default 10000\n   */\n  readonly transactionConsistencyTimeout?: number;\n  /**\n   * Whether to create target tables if they don't exist.\n   * @default true\n   */\n  readonly targetTablePrepMode?: string;\n  /**\n   * Whether to stop the task after the full load completes (only relevant for\n   * full-load tasks without CDC).\n   * @default false\n   */\n  readonly stopTaskCachedChangesApplied?: boolean;\n  /** Whether DMS commits the full load in a single transaction. */\n  readonly commitRate?: number;\n}\n\n/** Controls CDC behaviour. */\nexport interface CdcSettings {\n  /**\n   * Offset in seconds from current time to use as the CDC start position.\n   * Ignored when `cdcStartPosition` is set on the task.\n   */\n  readonly enableTestMode?: boolean;\n  /**\n   * Whether DMS applies changes immediately (false) or batches them (true).\n   * @default false\n   */\n  readonly batchApplyEnabled?: boolean;\n  /**\n   * Number of seconds DMS waits before applying batched changes.\n   * Only relevant when `batchApplyEnabled` is true.\n   * @default 1\n   */\n  readonly batchApplyTimeoutMin?: number;\n  /**\n   * Maximum number of seconds DMS waits before applying batched changes.\n   * @default 30\n   */\n  readonly batchApplyTimeoutMax?: number;\n  /** Memory limit (in MB) for the apply task. @default 500 */\n  readonly batchApplyMemoryLimit?: number;\n  /** Whether to preserve transactions during CDC. @default true */\n  readonly failOnNoTablesCaptured?: boolean;\n}\n\n/** Controls error handling behaviour. */\nexport interface ErrorHandlingSettings {\n  /**\n   * Action to take when DMS encounters a data error (e.g. duplicate key).\n   * @default ErrorAction.STOP_TASK\n   */\n  readonly dataErrorPolicy?: ErrorAction;\n  /**\n   * Maximum number of data errors before stopping.\n   * @default 0 (unlimited)\n   */\n  readonly dataErrorEscalationCount?: number;\n  /**\n   * Action to take after `dataErrorEscalationCount` errors are hit.\n   * @default ErrorAction.STOP_TASK\n   */\n  readonly dataErrorEscalationPolicy?: ErrorAction;\n  /**\n   * Action when DMS encounters a table error.\n   * @default ErrorAction.STOP_TASK\n   */\n  readonly tableErrorPolicy?: ErrorAction;\n  /**\n   * Maximum number of table errors before escalation.\n   * @default 0\n   */\n  readonly tableErrorEscalationCount?: number;\n  /**\n   * Action after `tableErrorEscalationCount` table errors.\n   * @default ErrorAction.STOP_TASK\n   */\n  readonly tableErrorEscalationPolicy?: ErrorAction;\n  /**\n   * Whether to recover from recoverable errors.\n   * @default true\n   */\n  readonly recoverableErrorCount?: number;\n  /**\n   * Interval in seconds between recovery attempts.\n   * @default 5\n   */\n  readonly recoverableErrorInterval?: number;\n  /**\n   * Throttle factor applied to recovery intervals.\n   * @default 2\n   */\n  readonly recoverableErrorThrottling?: boolean;\n  /**\n   * Maximum interval (seconds) between recovery attempts.\n   * @default 360\n   */\n  readonly recoverableErrorThrottlingMax?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Builder\n// ---------------------------------------------------------------------------\n\n/**\n * Fluent builder for DMS task settings.\n *\n * @example\n * const settings = new TaskSettings()\n *   .withLobMode(LobMode.LIMITED_LOB, 32)\n *   .withFullLoadSubTasks(16)\n *   .withBatchApply(true, 5, 60)\n *   .withDataErrorPolicy(ErrorAction.IGNORE_RECORD, 100)\n *   .withLogging('SOURCE_UNLOAD', LoggingLevel.LOGGER_SEVERITY_DEFAULT)\n *   .toJson();\n */\nexport class TaskSettings {\n  private lobMode: LobMode = LobMode.LIMITED_LOB;\n  private lobMaxSize: number = 32;\n  private fullLoadSettings: FullLoadSettings = {};\n  private cdcSettings: CdcSettings = {};\n  private errorHandlingSettings: ErrorHandlingSettings = {};\n  private loggingEnabled: boolean = true;\n  private logComponents: Record<string, string> = {};\n\n  // -------------------------------------------------------------------------\n  // LOB handling\n  // -------------------------------------------------------------------------\n\n  /**\n   * Configure LOB handling.\n   *\n   * @param mode       How LOBs are handled.\n   * @param maxSizeKb  Maximum LOB size in KB when mode is LIMITED_LOB. Ignored otherwise.\n   */\n  withLobMode(mode: LobMode, maxSizeKb?: number): TaskSettings {\n    this.lobMode = mode;\n    if (maxSizeKb !== undefined) {\n      this.lobMaxSize = maxSizeKb;\n    }\n    return this;\n  }\n\n  // -------------------------------------------------------------------------\n  // Full load\n  // -------------------------------------------------------------------------\n\n  /**\n   * Set the maximum number of tables loaded in parallel.\n   * @param count Default 8.\n   */\n  withFullLoadSubTasks(count: number): TaskSettings {\n    this.fullLoadSettings = { ...this.fullLoadSettings, maxFullLoadSubTasks: count };\n    return this;\n  }\n\n  /**\n   * Set the full-load target table prepare mode.\n   * Common values: \"DROP_AND_CREATE\", \"TRUNCATE_BEFORE_LOAD\", \"DO_NOTHING\".\n   */\n  withTargetTablePrepMode(mode: string): TaskSettings {\n    this.fullLoadSettings = { ...this.fullLoadSettings, targetTablePrepMode: mode };\n    return this;\n  }\n\n  /**\n   * Set the commit rate (number of rows per commit) during full load.\n   */\n  withCommitRate(rows: number): TaskSettings {\n    this.fullLoadSettings = { ...this.fullLoadSettings, commitRate: rows };\n    return this;\n  }\n\n  // -------------------------------------------------------------------------\n  // CDC / batch apply\n  // -------------------------------------------------------------------------\n\n  /**\n   * Enable or disable CDC batch apply mode and configure its timeouts.\n   *\n   * @param enabled    Whether batch apply is on.\n   * @param minSeconds Minimum seconds before applying a batch (default 1).\n   * @param maxSeconds Maximum seconds before applying a batch (default 30).\n   */\n  withBatchApply(enabled: boolean, minSeconds?: number, maxSeconds?: number): TaskSettings {\n    this.cdcSettings = {\n      ...this.cdcSettings,\n      batchApplyEnabled: enabled,\n      batchApplyTimeoutMin: minSeconds ?? 1,\n      batchApplyTimeoutMax: maxSeconds ?? 30,\n    };\n    return this;\n  }\n\n  // -------------------------------------------------------------------------\n  // Error handling\n  // -------------------------------------------------------------------------\n\n  /**\n   * Configure the action taken on data errors.\n   *\n   * @param policy         Action when a data error is encountered.\n   * @param escalationCount After this many errors, apply the escalation policy (0 = immediate).\n   * @param escalationPolicy Action after `escalationCount` errors.\n   */\n  withDataErrorPolicy(\n    policy: ErrorAction,\n    escalationCount?: number,\n    escalationPolicy?: ErrorAction,\n  ): TaskSettings {\n    this.errorHandlingSettings = {\n      ...this.errorHandlingSettings,\n      dataErrorPolicy: policy,\n      dataErrorEscalationCount: escalationCount ?? 0,\n      dataErrorEscalationPolicy: escalationPolicy ?? policy,\n    };\n    return this;\n  }\n\n  /**\n   * Configure recovery from transient errors.\n   *\n   * @param count    Maximum recovery attempts (-1 = unlimited).\n   * @param interval Seconds between attempts.\n   */\n  withRecovery(count: number, interval?: number): TaskSettings {\n    this.errorHandlingSettings = {\n      ...this.errorHandlingSettings,\n      recoverableErrorCount: count,\n      recoverableErrorInterval: interval ?? 5,\n    };\n    return this;\n  }\n\n  // -------------------------------------------------------------------------\n  // Logging\n  // -------------------------------------------------------------------------\n\n  /**\n   * Enable or disable CloudWatch logging for the task.\n   * @default true\n   */\n  withLoggingEnabled(enabled: boolean): TaskSettings {\n    this.loggingEnabled = enabled;\n    return this;\n  }\n\n  /**\n   * Set the logging level for a named DMS log component.\n   *\n   * Common component names: SOURCE_UNLOAD, TARGET_LOAD, TASK_MANAGER,\n   * SOURCE_CAPTURE, TARGET_APPLY, REST_SERVER, TRANSFORMATION.\n   */\n  withLogging(component: string, level: LoggingLevel): TaskSettings {\n    this.logComponents[component] = level;\n    return this;\n  }\n\n  // -------------------------------------------------------------------------\n  // Output\n  // -------------------------------------------------------------------------\n\n  /**\n   * Produce the JSON string that DMS expects for `replicationTaskSettings`.\n   */\n  toJson(): string {\n    const lobSettings: Record<string, unknown> =\n      this.lobMode === LobMode.NONE\n        ? { SupportLobs: false }\n        : {\n          SupportLobs: true,\n          LobMode: this.lobMode === LobMode.FULL_LOB ? 2 : 1,\n          LobMaxSize: this.lobMode === LobMode.LIMITED_LOB ? this.lobMaxSize : 0,\n        };\n\n    const logComponentList = Object.entries(this.logComponents).map(([id, level]) => ({\n      Id: id,\n      Severity: level,\n    }));\n\n    const settings: Record<string, unknown> = {\n      TargetMetadata: {\n        SupportLobs: lobSettings.SupportLobs,\n        FullLobMode: this.lobMode === LobMode.FULL_LOB,\n        LobChunkSize: 0,\n        LimitedSizeLobMode: this.lobMode === LobMode.LIMITED_LOB,\n        LobMaxSize: lobSettings.LobMaxSize ?? 0,\n      },\n      FullLoadSettings: {\n        TargetTablePrepMode: this.fullLoadSettings.targetTablePrepMode ?? 'DROP_AND_CREATE',\n        CreatePkAfterFullLoad: false,\n        StopTaskCachedChangesApplied: this.fullLoadSettings.stopTaskCachedChangesApplied ?? false,\n        StopTaskCachedChangesNotApplied: false,\n        MaxFullLoadSubTasks: this.fullLoadSettings.maxFullLoadSubTasks ?? 8,\n        TransactionConsistencyTimeout: this.fullLoadSettings.transactionConsistencyTimeout ?? 600,\n        CommitRate: this.fullLoadSettings.commitRate ?? 10000,\n      },\n      Logging: {\n        EnableLogging: this.loggingEnabled,\n        LogComponents: logComponentList.length > 0 ? logComponentList : [\n          { Id: 'SOURCE_UNLOAD', Severity: LoggingLevel.LOGGER_SEVERITY_DEFAULT },\n          { Id: 'TARGET_LOAD', Severity: LoggingLevel.LOGGER_SEVERITY_DEFAULT },\n          { Id: 'TASK_MANAGER', Severity: LoggingLevel.LOGGER_SEVERITY_DEFAULT },\n        ],\n      },\n      ControlTablesSettings: {\n        historyTimeslotInMinutes: 5,\n        StatusTableEnabled: false,\n        SuspendedTablesTableEnabled: false,\n        historyTableEnabled: false,\n        replicationTaskTableEnabled: false,\n        statusTableEnabled: false,\n        suspendedTablesTableEnabled: false,\n      },\n      StreamBufferSettings: {\n        StreamBufferCount: 3,\n        StreamBufferSizeInMB: 8,\n        CtrlStreamBufferSizeInMB: 5,\n      },\n      ChangeProcessingDdlHandlingPolicy: {\n        HandleSourceTableDropped: true,\n        HandleSourceTableTruncated: true,\n        HandleSourceTableAltered: true,\n      },\n      ErrorBehavior: {\n        DataErrorPolicy: this.errorHandlingSettings.dataErrorPolicy ?? ErrorAction.STOP_TASK,\n        DataErrorEscalationPolicy:\n          this.errorHandlingSettings.dataErrorEscalationPolicy ?? ErrorAction.STOP_TASK,\n        DataErrorEscalationCount: this.errorHandlingSettings.dataErrorEscalationCount ?? 0,\n        TableErrorPolicy: this.errorHandlingSettings.tableErrorPolicy ?? ErrorAction.STOP_TASK,\n        TableErrorEscalationPolicy:\n          this.errorHandlingSettings.tableErrorEscalationPolicy ?? ErrorAction.STOP_TASK,\n        TableErrorEscalationCount: this.errorHandlingSettings.tableErrorEscalationCount ?? 0,\n        RecoverableErrorCount: this.errorHandlingSettings.recoverableErrorCount ?? -1,\n        RecoverableErrorInterval: this.errorHandlingSettings.recoverableErrorInterval ?? 5,\n        RecoverableErrorThrottling:\n          this.errorHandlingSettings.recoverableErrorThrottling ?? true,\n        RecoverableErrorThrottlingMax:\n          this.errorHandlingSettings.recoverableErrorThrottlingMax ?? 1800,\n        RecoverableErrorStopRetryAfterThrottlingMax: true,\n        ApplyErrorDeletePolicy: ErrorAction.IGNORE_RECORD,\n        ApplyErrorInsertPolicy: ErrorAction.IGNORE_RECORD,\n        ApplyErrorUpdatePolicy: ErrorAction.IGNORE_RECORD,\n        ApplyErrorEscalationPolicy: ErrorAction.STOP_TASK,\n        ApplyErrorEscalationCount: 0,\n        ApplyErrorFailOnTruncationDdl: false,\n        FailOnNoTablesCaptured: this.cdcSettings.failOnNoTablesCaptured ?? true,\n        FailOnTransactionConsistencyBreached: false,\n        FullLoadIgnoreConflicts: true,\n      },\n      ChangeProcessingTuning: {\n        BatchApplyEnabled: this.cdcSettings.batchApplyEnabled ?? false,\n        BatchApplyPreserveTransaction: true,\n        BatchApplyTimeoutMin: this.cdcSettings.batchApplyTimeoutMin ?? 1,\n        BatchApplyTimeoutMax: this.cdcSettings.batchApplyTimeoutMax ?? 30,\n        BatchApplyMemoryLimit: this.cdcSettings.batchApplyMemoryLimit ?? 500,\n        BatchSplitSize: 0,\n        MinTransactionSize: 1000,\n        CommitTimeout: 1,\n        MemoryLimitTotal: 1024,\n        MemoryKeepTime: 60,\n        StatementCacheSize: 50,\n      },\n    };\n\n    return JSON.stringify(settings, null, 2);\n  }\n}\n"]}
package/package.json ADDED
@@ -0,0 +1,170 @@
1
+ {
2
+ "name": "cdk-dms-replication",
3
+ "description": "L3 CDK Constructs for Amazon Database Migration Service (DMS) — pattern construct bundling replication instance, endpoints, and tasks with secure defaults.",
4
+ "repository": {
5
+ "type": "git",
6
+ "url": "https://github.com/kckempf/cdk-dms-replication.git"
7
+ },
8
+ "scripts": {
9
+ "build": "projen build",
10
+ "bump": "projen bump",
11
+ "clobber": "projen clobber",
12
+ "compat": "projen compat",
13
+ "compile": "projen compile",
14
+ "default": "projen default",
15
+ "docgen": "projen docgen",
16
+ "eject": "projen eject",
17
+ "eslint": "projen eslint",
18
+ "integ": "projen integ",
19
+ "package": "projen package",
20
+ "package-all": "projen package-all",
21
+ "package:dotnet": "projen package:dotnet",
22
+ "package:go": "projen package:go",
23
+ "package:java": "projen package:java",
24
+ "package:js": "projen package:js",
25
+ "package:python": "projen package:python",
26
+ "post-compile": "projen post-compile",
27
+ "post-upgrade": "projen post-upgrade",
28
+ "pre-compile": "projen pre-compile",
29
+ "release": "projen release",
30
+ "test": "projen test",
31
+ "test:watch": "projen test:watch",
32
+ "unbump": "projen unbump",
33
+ "upgrade": "projen upgrade",
34
+ "watch": "projen watch",
35
+ "projen": "projen"
36
+ },
37
+ "author": {
38
+ "name": "Kevin Kempf",
39
+ "email": "kckempf@gmail.com",
40
+ "organization": false
41
+ },
42
+ "devDependencies": {
43
+ "@stylistic/eslint-plugin": "^2",
44
+ "@types/jest": "^30.0.0",
45
+ "@types/node": "^25.6.0",
46
+ "@typescript-eslint/eslint-plugin": "^8",
47
+ "@typescript-eslint/parser": "^8",
48
+ "aws-cdk-lib": "2.100.0",
49
+ "commit-and-tag-version": "^12",
50
+ "constructs": "10.5.1",
51
+ "eslint": "^9",
52
+ "eslint-import-resolver-typescript": "^4.4.4",
53
+ "eslint-plugin-import": "^2.32.0",
54
+ "jest": "^30.3.0",
55
+ "jest-junit": "^16",
56
+ "jsii": "~5.9.0",
57
+ "jsii-diff": "^1.129.0",
58
+ "jsii-docgen": "^10.5.0",
59
+ "jsii-pacmak": "^1.129.0",
60
+ "jsii-rosetta": "~5.9.0",
61
+ "projen": "^0.99.52",
62
+ "ts-jest": "^29.4.9",
63
+ "ts-node": "^10.9.2",
64
+ "typescript": "^6.0.3"
65
+ },
66
+ "peerDependencies": {
67
+ "aws-cdk-lib": "^2.100.0",
68
+ "constructs": "^10.5.1"
69
+ },
70
+ "keywords": [
71
+ "aws",
72
+ "aws-dms",
73
+ "awscdk",
74
+ "cdc",
75
+ "cdk",
76
+ "constructs",
77
+ "database",
78
+ "dms",
79
+ "migration",
80
+ "replication"
81
+ ],
82
+ "devEngines": {
83
+ "packageManager": {
84
+ "name": "npm",
85
+ "onFail": "ignore"
86
+ }
87
+ },
88
+ "main": "lib/index.js",
89
+ "license": "Apache-2.0",
90
+ "homepage": "https://github.com/kckempf/cdk-dms-replication#readme",
91
+ "publishConfig": {
92
+ "access": "public"
93
+ },
94
+ "version": "0.0.0",
95
+ "jest": {
96
+ "coverageProvider": "v8",
97
+ "testMatch": [
98
+ "<rootDir>/@(src|test)/**/*(*.)@(spec|test).ts?(x)",
99
+ "<rootDir>/@(src|test)/**/__tests__/**/*.ts?(x)",
100
+ "<rootDir>/@(projenrc)/**/*(*.)@(spec|test).ts?(x)",
101
+ "<rootDir>/@(projenrc)/**/__tests__/**/*.ts?(x)"
102
+ ],
103
+ "clearMocks": true,
104
+ "collectCoverage": true,
105
+ "coverageReporters": [
106
+ "json",
107
+ "lcov",
108
+ "clover",
109
+ "cobertura",
110
+ "text"
111
+ ],
112
+ "coverageDirectory": "coverage",
113
+ "coveragePathIgnorePatterns": [
114
+ "/node_modules/"
115
+ ],
116
+ "testPathIgnorePatterns": [
117
+ "/node_modules/"
118
+ ],
119
+ "watchPathIgnorePatterns": [
120
+ "/node_modules/"
121
+ ],
122
+ "reporters": [
123
+ "default",
124
+ [
125
+ "jest-junit",
126
+ {
127
+ "outputDirectory": "test-reports"
128
+ }
129
+ ]
130
+ ],
131
+ "transform": {
132
+ "^.+\\.[t]sx?$": [
133
+ "ts-jest",
134
+ {
135
+ "tsconfig": "tsconfig.dev.json"
136
+ }
137
+ ]
138
+ }
139
+ },
140
+ "types": "lib/index.d.ts",
141
+ "stability": "stable",
142
+ "jsii": {
143
+ "outdir": "dist",
144
+ "targets": {
145
+ "java": {
146
+ "package": "io.github.kckempf.cdkdmsreplication",
147
+ "maven": {
148
+ "groupId": "io.github.kckempf",
149
+ "artifactId": "cdk-dms-replication"
150
+ }
151
+ },
152
+ "python": {
153
+ "distName": "cdk-dms-replication",
154
+ "module": "cdk_dms_replication"
155
+ },
156
+ "dotnet": {
157
+ "namespace": "KcKempf.CdkDmsReplication",
158
+ "packageId": "KcKempf.CdkDmsReplication"
159
+ },
160
+ "go": {
161
+ "moduleName": "github.com/kckempf/cdk-dms-replication-go"
162
+ }
163
+ },
164
+ "tsc": {
165
+ "outDir": "lib",
166
+ "rootDir": "src"
167
+ }
168
+ },
169
+ "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\"."
170
+ }