dbdock 1.1.15 → 1.1.17

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.
Files changed (43) hide show
  1. package/README.md +473 -580
  2. package/dist/cli/commands/analyze.d.ts +1 -0
  3. package/dist/cli/commands/analyze.js +135 -0
  4. package/dist/cli/commands/analyze.js.map +1 -0
  5. package/dist/cli/commands/cross-migrate.d.ts +11 -0
  6. package/dist/cli/commands/cross-migrate.js +307 -0
  7. package/dist/cli/commands/cross-migrate.js.map +1 -0
  8. package/dist/cli/index.js +20 -0
  9. package/dist/cli/index.js.map +1 -1
  10. package/dist/migration/analyzers/mongodb.analyzer.d.ts +3 -0
  11. package/dist/migration/analyzers/mongodb.analyzer.js +208 -0
  12. package/dist/migration/analyzers/mongodb.analyzer.js.map +1 -0
  13. package/dist/migration/analyzers/postgres.analyzer.d.ts +3 -0
  14. package/dist/migration/analyzers/postgres.analyzer.js +176 -0
  15. package/dist/migration/analyzers/postgres.analyzer.js.map +1 -0
  16. package/dist/migration/config.manager.d.ts +3 -0
  17. package/dist/migration/config.manager.js +80 -0
  18. package/dist/migration/config.manager.js.map +1 -0
  19. package/dist/migration/engines/migration.engine.d.ts +6 -0
  20. package/dist/migration/engines/migration.engine.js +62 -0
  21. package/dist/migration/engines/migration.engine.js.map +1 -0
  22. package/dist/migration/engines/mongo-to-postgres.engine.d.ts +2 -0
  23. package/dist/migration/engines/mongo-to-postgres.engine.js +409 -0
  24. package/dist/migration/engines/mongo-to-postgres.engine.js.map +1 -0
  25. package/dist/migration/engines/postgres-to-mongo.engine.d.ts +2 -0
  26. package/dist/migration/engines/postgres-to-mongo.engine.js +192 -0
  27. package/dist/migration/engines/postgres-to-mongo.engine.js.map +1 -0
  28. package/dist/migration/mappers/mongo-to-postgres.mapper.d.ts +2 -0
  29. package/dist/migration/mappers/mongo-to-postgres.mapper.js +263 -0
  30. package/dist/migration/mappers/mongo-to-postgres.mapper.js.map +1 -0
  31. package/dist/migration/mappers/postgres-to-mongo.mapper.d.ts +2 -0
  32. package/dist/migration/mappers/postgres-to-mongo.mapper.js +174 -0
  33. package/dist/migration/mappers/postgres-to-mongo.mapper.js.map +1 -0
  34. package/dist/migration/reference.detector.d.ts +2 -0
  35. package/dist/migration/reference.detector.js +57 -0
  36. package/dist/migration/reference.detector.js.map +1 -0
  37. package/dist/migration/type.mapper.d.ts +12 -0
  38. package/dist/migration/type.mapper.js +197 -0
  39. package/dist/migration/type.mapper.js.map +1 -0
  40. package/dist/migration/types.d.ts +183 -0
  41. package/dist/migration/types.js +11 -0
  42. package/dist/migration/types.js.map +1 -0
  43. package/package.json +11 -2
@@ -0,0 +1 @@
1
+ export declare function analyzeCommand(url: string): Promise<void>;
@@ -0,0 +1,135 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.analyzeCommand = analyzeCommand;
7
+ const ora_1 = __importDefault(require("ora"));
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ const logger_1 = require("../utils/logger");
10
+ const migration_engine_1 = require("../../migration/engines/migration.engine");
11
+ async function analyzeCommand(url) {
12
+ console.log('');
13
+ console.log(chalk_1.default.bold(' DBDock - Database Analysis'));
14
+ console.log(chalk_1.default.gray(' ─'.repeat(30)));
15
+ console.log('');
16
+ let parsed;
17
+ try {
18
+ parsed = (0, migration_engine_1.parseDatabaseUrl)(url);
19
+ }
20
+ catch (error) {
21
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
22
+ process.exit(1);
23
+ }
24
+ logger_1.logger.info(`Database: ${chalk_1.default.cyan(parsed.type === 'mongodb' ? 'MongoDB' : 'PostgreSQL')} — ${parsed.database}`);
25
+ logger_1.logger.info(`Host: ${parsed.host}:${parsed.port}`);
26
+ console.log('');
27
+ const spinner = (0, ora_1.default)('Analyzing database structure...').start();
28
+ try {
29
+ const analysis = await (0, migration_engine_1.analyzeDatabase)(url);
30
+ spinner.succeed('Analysis complete');
31
+ console.log('');
32
+ if (analysis.type === 'mongodb') {
33
+ displayMongoAnalysis(analysis);
34
+ }
35
+ else {
36
+ displayPostgresAnalysis(analysis);
37
+ }
38
+ }
39
+ catch (error) {
40
+ spinner.fail('Analysis failed');
41
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
42
+ process.exit(1);
43
+ }
44
+ }
45
+ function displayMongoAnalysis(analysis) {
46
+ console.log(chalk_1.default.bold(` Found ${chalk_1.default.cyan(String(analysis.collections.length))} collections, ${chalk_1.default.cyan(formatNumber(analysis.totalDocuments))} total documents`));
47
+ console.log('');
48
+ for (const collection of analysis.collections) {
49
+ console.log(chalk_1.default.bold(` ${chalk_1.default.green(collection.name)} ${chalk_1.default.gray(`(${formatNumber(collection.documentCount)} docs)`)}`));
50
+ for (let i = 0; i < collection.fields.length; i++) {
51
+ const field = collection.fields[i];
52
+ const isLast = i === collection.fields.length - 1;
53
+ const prefix = isLast ? ' └─' : ' ├─';
54
+ displayMongoField(field, prefix, isLast ? ' ' : ' │ ');
55
+ }
56
+ console.log('');
57
+ }
58
+ }
59
+ function displayMongoField(field, prefix, childPrefix) {
60
+ const typeEntries = Object.entries(field.types).filter(([t]) => t !== 'null' && t !== 'undefined');
61
+ const typeStr = typeEntries
62
+ .map(([t, c]) => {
63
+ if (typeEntries.length > 1)
64
+ return `${t}(${c})`;
65
+ return t;
66
+ })
67
+ .join(', ');
68
+ let extra = '';
69
+ if (field.frequency < 100) {
70
+ extra += chalk_1.default.yellow(` [${field.frequency.toFixed(0)}% present]`);
71
+ }
72
+ if (field.isArray) {
73
+ extra += chalk_1.default.blue(` [array: ${field.arrayElementType || 'mixed'}]`);
74
+ }
75
+ if (field.isObjectId && field.name !== '_id') {
76
+ extra += chalk_1.default.magenta(` → ref${field.possibleReference ? `: ${field.possibleReference}` : ''}`);
77
+ }
78
+ if (typeEntries.length > 1) {
79
+ extra += chalk_1.default.red(' ⚠ mixed types');
80
+ }
81
+ console.log(`${prefix} ${chalk_1.default.white(field.name)} ${chalk_1.default.gray(`(${typeStr})`)}${extra}`);
82
+ if (field.nestedFields && field.isNestedObject && !field.isArray) {
83
+ for (let i = 0; i < field.nestedFields.length; i++) {
84
+ const nested = field.nestedFields[i];
85
+ const isLast = i === field.nestedFields.length - 1;
86
+ const nPrefix = childPrefix + (isLast ? ' └─' : ' ├─');
87
+ const nChildPrefix = childPrefix + (isLast ? ' ' : ' │ ');
88
+ displayMongoField(nested, nPrefix, nChildPrefix);
89
+ }
90
+ }
91
+ }
92
+ function displayPostgresAnalysis(analysis) {
93
+ console.log(chalk_1.default.bold(` Found ${chalk_1.default.cyan(String(analysis.tables.length))} tables, ${chalk_1.default.cyan(formatNumber(analysis.totalRows))} total rows`));
94
+ console.log('');
95
+ for (const table of analysis.tables) {
96
+ console.log(chalk_1.default.bold(` ${chalk_1.default.green(table.name)} ${chalk_1.default.gray(`(${formatNumber(table.rowCount)} rows)`)}`));
97
+ for (let i = 0; i < table.columns.length; i++) {
98
+ const col = table.columns[i];
99
+ const isLast = i === table.columns.length - 1 && table.foreignKeys.length === 0;
100
+ const prefix = isLast ? ' └─' : ' ├─';
101
+ let extra = '';
102
+ if (col.isPrimaryKey)
103
+ extra += chalk_1.default.yellow(' PK');
104
+ if (col.isUnique && !col.isPrimaryKey)
105
+ extra += chalk_1.default.blue(' UNIQUE');
106
+ if (!col.isNullable)
107
+ extra += chalk_1.default.gray(' NOT NULL');
108
+ if (col.columnDefault)
109
+ extra += chalk_1.default.gray(` DEFAULT ${col.columnDefault}`);
110
+ const fk = table.foreignKeys.find((f) => f.columnName === col.name);
111
+ if (fk) {
112
+ extra += chalk_1.default.magenta(` → ${fk.referencedTable}.${fk.referencedColumn}`);
113
+ }
114
+ console.log(`${prefix} ${chalk_1.default.white(col.name)} ${chalk_1.default.gray(`(${col.dataType})`)}${extra}`);
115
+ }
116
+ if (table.indexes.length > 0) {
117
+ const nonPkIndexes = table.indexes.filter((idx) => !idx.isPrimary);
118
+ for (let i = 0; i < nonPkIndexes.length; i++) {
119
+ const idx = nonPkIndexes[i];
120
+ const isLast = i === nonPkIndexes.length - 1;
121
+ const prefix = isLast ? ' └─' : ' ├─';
122
+ console.log(`${prefix} ${chalk_1.default.gray('idx:')} ${idx.name} ${chalk_1.default.gray(`(${idx.columns.join(', ')})`)}${idx.isUnique ? chalk_1.default.blue(' UNIQUE') : ''}`);
123
+ }
124
+ }
125
+ console.log('');
126
+ }
127
+ }
128
+ function formatNumber(n) {
129
+ if (n >= 1000000)
130
+ return `${(n / 1000000).toFixed(1)}M`;
131
+ if (n >= 1000)
132
+ return `${(n / 1000).toFixed(1)}K`;
133
+ return String(n);
134
+ }
135
+ //# sourceMappingURL=analyze.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyze.js","sourceRoot":"","sources":["../../../src/cli/commands/analyze.ts"],"names":[],"mappings":";;;;;AAaA,wCAyCC;AAtDD,8CAAsB;AACtB,kDAA0B;AAC1B,4CAAyC;AACzC,+EAGkD;AAO3C,KAAK,UAAU,cAAc,CAAC,GAAW;IAC9C,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC,CAAC;IACxD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1C,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,IAAI,MAAM,CAAC;IACX,IAAI,CAAC;QACH,MAAM,GAAG,IAAA,mCAAgB,EAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,eAAM,CAAC,KAAK,CACV,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CACvD,CAAC;QACF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,eAAM,CAAC,IAAI,CACT,aAAa,eAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,MAAM,CAAC,QAAQ,EAAE,CACrG,CAAC;IACF,eAAM,CAAC,IAAI,CAAC,SAAS,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;IACnD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,MAAM,OAAO,GAAG,IAAA,aAAG,EAAC,iCAAiC,CAAC,CAAC,KAAK,EAAE,CAAC;IAE/D,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,IAAA,kCAAe,EAAC,GAAG,CAAC,CAAC;QAC5C,OAAO,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;QACrC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAEhB,IAAI,QAAQ,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAChC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;aAAM,CAAC;YACN,uBAAuB,CAAC,QAAQ,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAChC,eAAM,CAAC,KAAK,CACV,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CACvD,CAAC;QACF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC;AAED,SAAS,oBAAoB,CAAC,QAA6B;IACzD,OAAO,CAAC,GAAG,CACT,eAAK,CAAC,IAAI,CACR,WAAW,eAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,iBAAiB,eAAK,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,kBAAkB,CAC/I,CACF,CAAC;IACF,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,KAAK,MAAM,UAAU,IAAI,QAAQ,CAAC,WAAW,EAAE,CAAC;QAC9C,OAAO,CAAC,GAAG,CACT,eAAK,CAAC,IAAI,CACR,KAAK,eAAK,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,eAAK,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,CACtG,CACF,CAAC;QAEF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAClD,MAAM,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACnC,MAAM,MAAM,GAAG,CAAC,KAAK,UAAU,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;YAClD,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;YACxC,iBAAiB,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC7D,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;AACH,CAAC;AAED,SAAS,iBAAiB,CACxB,KAAqB,EACrB,MAAc,EACd,WAAmB;IAEnB,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CACpD,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,MAAM,IAAI,CAAC,KAAK,WAAW,CAC3C,CAAC;IACF,MAAM,OAAO,GAAG,WAAW;SACxB,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE;QACd,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC;YAAE,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC;QAChD,OAAO,CAAC,CAAC;IACX,CAAC,CAAC;SACD,IAAI,CAAC,IAAI,CAAC,CAAC;IAEd,IAAI,KAAK,GAAG,EAAE,CAAC;IACf,IAAI,KAAK,CAAC,SAAS,GAAG,GAAG,EAAE,CAAC;QAC1B,KAAK,IAAI,eAAK,CAAC,MAAM,CAAC,KAAK,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;IACrE,CAAC;IACD,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;QAClB,KAAK,IAAI,eAAK,CAAC,IAAI,CAAC,YAAY,KAAK,CAAC,gBAAgB,IAAI,OAAO,GAAG,CAAC,CAAC;IACxE,CAAC;IACD,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;QAC7C,KAAK,IAAI,eAAK,CAAC,OAAO,CACpB,SAAS,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CACzE,CAAC;IACJ,CAAC;IACD,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,KAAK,IAAI,eAAK,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;IACvC,CAAC;IAED,OAAO,CAAC,GAAG,CACT,GAAG,MAAM,IAAI,eAAK,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,eAAK,CAAC,IAAI,CAAC,IAAI,OAAO,GAAG,CAAC,GAAG,KAAK,EAAE,CAC7E,CAAC;IAEF,IAAI,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC,cAAc,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACjE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACnD,MAAM,MAAM,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACrC,MAAM,MAAM,GAAG,CAAC,KAAK,KAAK,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;YACnD,MAAM,OAAO,GAAG,WAAW,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACzD,MAAM,YAAY,GAAG,WAAW,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YAC9D,iBAAiB,CAAC,MAAM,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;AACH,CAAC;AAED,SAAS,uBAAuB,CAAC,QAA0B;IACzD,OAAO,CAAC,GAAG,CACT,eAAK,CAAC,IAAI,CACR,WAAW,eAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,eAAK,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,aAAa,CAC3H,CACF,CAAC;IACF,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,KAAK,MAAM,KAAK,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpC,OAAO,CAAC,GAAG,CACT,eAAK,CAAC,IAAI,CACR,KAAK,eAAK,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,eAAK,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CACvF,CACF,CAAC;QAEF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9C,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC7B,MAAM,MAAM,GACV,CAAC,KAAK,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,CAAC;YACnE,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;YAExC,IAAI,KAAK,GAAG,EAAE,CAAC;YACf,IAAI,GAAG,CAAC,YAAY;gBAAE,KAAK,IAAI,eAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnD,IAAI,GAAG,CAAC,QAAQ,IAAI,CAAC,GAAG,CAAC,YAAY;gBAAE,KAAK,IAAI,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACtE,IAAI,CAAC,GAAG,CAAC,UAAU;gBAAE,KAAK,IAAI,eAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtD,IAAI,GAAG,CAAC,aAAa;gBAAE,KAAK,IAAI,eAAK,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC;YAE5E,MAAM,EAAE,GAAG,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC;YACpE,IAAI,EAAE,EAAE,CAAC;gBACP,KAAK,IAAI,eAAK,CAAC,OAAO,CACpB,MAAM,EAAE,CAAC,eAAe,IAAI,EAAE,CAAC,gBAAgB,EAAE,CAClD,CAAC;YACJ,CAAC;YAED,OAAO,CAAC,GAAG,CACT,GAAG,MAAM,IAAI,eAAK,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,eAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,QAAQ,GAAG,CAAC,GAAG,KAAK,EAAE,CAChF,CAAC;QACJ,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7B,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACnE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC7C,MAAM,GAAG,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC5B,MAAM,MAAM,GAAG,CAAC,KAAK,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;gBAC7C,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;gBACxC,OAAO,CAAC,GAAG,CACT,GAAG,MAAM,IAAI,eAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,IAAI,IAAI,eAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CACvI,CAAC;YACJ,CAAC;QACH,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;AACH,CAAC;AAED,SAAS,YAAY,CAAC,CAAS;IAC7B,IAAI,CAAC,IAAI,OAAO;QAAE,OAAO,GAAG,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;IACxD,IAAI,CAAC,IAAI,IAAI;QAAE,OAAO,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;IAClD,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;AACnB,CAAC"}
@@ -0,0 +1,11 @@
1
+ interface MigrateOptions {
2
+ dryRun?: boolean;
3
+ incremental?: boolean;
4
+ since?: string;
5
+ config?: string;
6
+ exportConfig?: string;
7
+ batchSize?: number;
8
+ maxDepth?: number;
9
+ }
10
+ export declare function crossMigrateCommand(sourceUrl: string, targetUrl: string, options: MigrateOptions): Promise<void>;
11
+ export {};
@@ -0,0 +1,307 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.crossMigrateCommand = crossMigrateCommand;
7
+ const ora_1 = __importDefault(require("ora"));
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ const inquirer_1 = __importDefault(require("inquirer"));
10
+ const logger_1 = require("../utils/logger");
11
+ const migration_engine_1 = require("../../migration/engines/migration.engine");
12
+ const config_manager_1 = require("../../migration/config.manager");
13
+ const types_1 = require("../../migration/types");
14
+ async function crossMigrateCommand(sourceUrl, targetUrl, options) {
15
+ console.log('');
16
+ console.log(chalk_1.default.bold(' DBDock - Cross-Database Migration'));
17
+ console.log(chalk_1.default.gray(' ─'.repeat(30)));
18
+ console.log('');
19
+ if (options.config) {
20
+ await runFromConfig(options.config, sourceUrl, targetUrl, options);
21
+ return;
22
+ }
23
+ let sourceParsed, targetParsed;
24
+ try {
25
+ sourceParsed = (0, migration_engine_1.parseDatabaseUrl)(sourceUrl);
26
+ targetParsed = (0, migration_engine_1.parseDatabaseUrl)(targetUrl);
27
+ }
28
+ catch (error) {
29
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
30
+ process.exit(1);
31
+ }
32
+ if (sourceParsed.type === targetParsed.type) {
33
+ logger_1.logger.error(`Source and target are both ${sourceParsed.type}. Cross-database migration requires different database types.`);
34
+ logger_1.logger.info('For same-database copies, use: dbdock copydb <source> <target>');
35
+ process.exit(1);
36
+ }
37
+ const sourceLabel = sourceParsed.type === 'mongodb' ? 'MongoDB' : 'PostgreSQL';
38
+ const targetLabel = targetParsed.type === 'mongodb' ? 'MongoDB' : 'PostgreSQL';
39
+ logger_1.logger.info(`Source: ${chalk_1.default.cyan(sourceLabel)} — ${sourceParsed.database}`);
40
+ logger_1.logger.info(`Target: ${chalk_1.default.cyan(targetLabel)} — ${targetParsed.database}`);
41
+ if (options.dryRun) {
42
+ logger_1.logger.info(`Mode: ${chalk_1.default.yellow('Dry Run')} (no changes to target)`);
43
+ }
44
+ if (options.incremental) {
45
+ logger_1.logger.info(`Mode: ${chalk_1.default.yellow('Incremental')}${options.since ? ` since ${options.since}` : ''}`);
46
+ }
47
+ console.log('');
48
+ const spinner = (0, ora_1.default)('Analyzing source database...').start();
49
+ let analysis;
50
+ try {
51
+ analysis = await (0, migration_engine_1.analyzeDatabase)(sourceUrl);
52
+ }
53
+ catch (error) {
54
+ spinner.fail('Failed to analyze source database');
55
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
56
+ process.exit(1);
57
+ }
58
+ if (analysis.type === 'mongodb') {
59
+ spinner.succeed(`Source analyzed: ${analysis.collections.length} collections, ${formatNumber(analysis.totalDocuments)} documents`);
60
+ }
61
+ else {
62
+ spinner.succeed(`Source analyzed: ${analysis.tables.length} tables, ${formatNumber(analysis.totalRows)} rows`);
63
+ }
64
+ console.log('');
65
+ const migrationOptions = {
66
+ ...types_1.DEFAULT_MIGRATION_OPTIONS,
67
+ dryRun: options.dryRun || false,
68
+ incremental: options.incremental || false,
69
+ since: options.since,
70
+ batchSize: options.batchSize || types_1.DEFAULT_MIGRATION_OPTIONS.batchSize,
71
+ maxNestingDepth: options.maxDepth || types_1.DEFAULT_MIGRATION_OPTIONS.maxNestingDepth,
72
+ };
73
+ const plan = (0, migration_engine_1.generateMigrationPlan)(analysis, sourceUrl, targetUrl, migrationOptions);
74
+ displayMigrationPlan(plan);
75
+ if (options.exportConfig) {
76
+ try {
77
+ (0, config_manager_1.exportConfig)(plan, options.exportConfig);
78
+ logger_1.logger.success(`Config exported to ${options.exportConfig}`);
79
+ }
80
+ catch (error) {
81
+ logger_1.logger.error(`Failed to export config: ${error instanceof Error ? error.message : String(error)}`);
82
+ }
83
+ return;
84
+ }
85
+ const { action } = await inquirer_1.default.prompt([
86
+ {
87
+ type: 'list',
88
+ name: 'action',
89
+ message: 'Accept mapping?',
90
+ choices: [
91
+ { name: 'Yes — execute migration', value: 'accept' },
92
+ { name: 'Export config file — save and edit later', value: 'export' },
93
+ { name: 'Cancel', value: 'cancel' },
94
+ ],
95
+ },
96
+ ]);
97
+ if (action === 'cancel') {
98
+ logger_1.logger.warn('Migration cancelled');
99
+ return;
100
+ }
101
+ if (action === 'export') {
102
+ const { path } = await inquirer_1.default.prompt([
103
+ {
104
+ type: 'input',
105
+ name: 'path',
106
+ message: 'Config file path:',
107
+ default: './migration.yaml',
108
+ },
109
+ ]);
110
+ try {
111
+ (0, config_manager_1.exportConfig)(plan, path);
112
+ logger_1.logger.success(`Config exported to ${path}`);
113
+ logger_1.logger.info(`Re-run with: dbdock migrate --config ${path} "${(0, migration_engine_1.maskUrl)(sourceUrl)}" "${(0, migration_engine_1.maskUrl)(targetUrl)}"`);
114
+ }
115
+ catch (error) {
116
+ logger_1.logger.error(`Failed to export: ${error instanceof Error ? error.message : String(error)}`);
117
+ }
118
+ return;
119
+ }
120
+ console.log('');
121
+ await executeMigrationWithProgress(plan);
122
+ }
123
+ async function runFromConfig(configPath, sourceUrl, targetUrl, options) {
124
+ const spinner = (0, ora_1.default)(`Loading config from ${configPath}...`).start();
125
+ let plan;
126
+ try {
127
+ plan = (0, config_manager_1.importConfig)(configPath);
128
+ plan.source.url = sourceUrl;
129
+ plan.target.url = targetUrl;
130
+ if (options.dryRun !== undefined)
131
+ plan.options.dryRun = options.dryRun;
132
+ if (options.incremental !== undefined)
133
+ plan.options.incremental = options.incremental;
134
+ if (options.since)
135
+ plan.options.since = options.since;
136
+ if (options.batchSize)
137
+ plan.options.batchSize = options.batchSize;
138
+ spinner.succeed('Config loaded');
139
+ }
140
+ catch (error) {
141
+ spinner.fail('Failed to load config');
142
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
143
+ process.exit(1);
144
+ }
145
+ console.log('');
146
+ displayMigrationPlan(plan);
147
+ const { confirm } = await inquirer_1.default.prompt([
148
+ {
149
+ type: 'confirm',
150
+ name: 'confirm',
151
+ message: 'Execute migration with this config?',
152
+ default: false,
153
+ },
154
+ ]);
155
+ if (!confirm) {
156
+ logger_1.logger.warn('Migration cancelled');
157
+ return;
158
+ }
159
+ console.log('');
160
+ await executeMigrationWithProgress(plan);
161
+ }
162
+ async function executeMigrationWithProgress(plan) {
163
+ const startTime = Date.now();
164
+ const migrationSpinner = (0, ora_1.default)('Starting migration...').start();
165
+ const currentProgress = {};
166
+ try {
167
+ const result = await (0, migration_engine_1.executeMigration)(plan, (table, processed, total) => {
168
+ currentProgress[table] = { processed, total };
169
+ const totalProcessed = Object.values(currentProgress).reduce((s, p) => s + p.processed, 0);
170
+ const totalAll = Object.values(currentProgress).reduce((s, p) => s + p.total, 0);
171
+ const pct = totalAll > 0 ? ((totalProcessed / totalAll) * 100).toFixed(1) : '0';
172
+ migrationSpinner.text = `Migrating... ${pct}% (${table}: ${formatNumber(processed)}/${formatNumber(total)})`;
173
+ });
174
+ const elapsed = ((Date.now() - startTime) / 1000).toFixed(2);
175
+ if (result.success) {
176
+ migrationSpinner.succeed(`Migration completed in ${elapsed}s${plan.options.dryRun ? ' (dry run)' : ''}`);
177
+ }
178
+ else {
179
+ migrationSpinner.warn(`Migration completed with issues in ${elapsed}s`);
180
+ }
181
+ console.log('');
182
+ displayResults(result, plan.options.dryRun);
183
+ }
184
+ catch (error) {
185
+ migrationSpinner.fail('Migration failed');
186
+ logger_1.logger.error(error instanceof Error ? error.message : String(error));
187
+ process.exit(1);
188
+ }
189
+ }
190
+ function displayMigrationPlan(plan) {
191
+ console.log(chalk_1.default.bold(' Proposed Schema Mapping:'));
192
+ console.log('');
193
+ if (plan.direction === 'mongo_to_postgres' && plan.tableMappings) {
194
+ displayTableMappings(plan.tableMappings);
195
+ }
196
+ if (plan.direction === 'postgres_to_mongo' && plan.documentMappings) {
197
+ displayDocumentMappings(plan.documentMappings);
198
+ }
199
+ if (plan.conflicts.length > 0) {
200
+ console.log(chalk_1.default.yellow.bold(` ⚠ Conflicts Found:`));
201
+ console.log('');
202
+ for (const conflict of plan.conflicts) {
203
+ const icon = conflict.type === 'type_mismatch'
204
+ ? '•'
205
+ : conflict.type === 'missing_field'
206
+ ? '•'
207
+ : '•';
208
+ console.log(` ${icon} ${chalk_1.default.white(conflict.location)}: ${conflict.details}`);
209
+ console.log(` ${chalk_1.default.gray('→ Suggestion:')} ${chalk_1.default.cyan(conflict.suggestion)}`);
210
+ }
211
+ console.log('');
212
+ }
213
+ }
214
+ function displayTableMappings(mappings) {
215
+ for (const mapping of mappings) {
216
+ console.log(chalk_1.default.bold(` ${chalk_1.default.green(mapping.sourceCollection)} → ${chalk_1.default.cyan(mapping.targetTable)}`));
217
+ for (const field of mapping.fields) {
218
+ const arrow = field.transform
219
+ ? chalk_1.default.yellow(`→ (${field.transform})`)
220
+ : '→';
221
+ const nullable = field.nullable ? chalk_1.default.gray(' nullable') : '';
222
+ const pk = field.isPrimaryKey ? chalk_1.default.yellow(' PK') : '';
223
+ const unique = field.isUnique && !field.isPrimaryKey ? chalk_1.default.blue(' UNIQUE') : '';
224
+ console.log(` ├─ ${field.sourceField} ${arrow} ${mapping.targetTable}.${field.targetColumn} ${chalk_1.default.gray(`(${field.targetType})`)}${pk}${unique}${nullable}`);
225
+ }
226
+ for (const nested of mapping.nestedMappings) {
227
+ const strategy = nested.strategy === 'table'
228
+ ? chalk_1.default.blue(`${nested.relationType} relation`)
229
+ : chalk_1.default.magenta('jsonb');
230
+ console.log(` ├─ ${nested.sourceField} {} → ${chalk_1.default.cyan(nested.targetTable)} ${strategy}`);
231
+ if (nested.fields && nested.strategy === 'table') {
232
+ for (const f of nested.fields.filter((f) => f.sourceField !== 'id' && !f.sourceField.includes('_id'))) {
233
+ console.log(` │ ├─ ${f.sourceField.split('.').pop()} → ${f.targetColumn} ${chalk_1.default.gray(`(${f.targetType})`)}`);
234
+ }
235
+ }
236
+ }
237
+ for (const arr of mapping.arrayMappings) {
238
+ const strategyLabel = arr.strategy === 'child_table'
239
+ ? chalk_1.default.blue('child table')
240
+ : arr.strategy === 'array_column'
241
+ ? chalk_1.default.magenta(`${arr.elementType}[]`)
242
+ : chalk_1.default.yellow('junction table');
243
+ console.log(` ├─ ${arr.sourceField} [] → ${chalk_1.default.cyan(arr.targetTable)} ${strategyLabel}`);
244
+ }
245
+ for (const ref of mapping.detectedReferences) {
246
+ console.log(` ├─ ${ref.sourceField} ${chalk_1.default.magenta(`→ FK: ${ref.targetCollection}.id`)}`);
247
+ }
248
+ console.log('');
249
+ }
250
+ }
251
+ function displayDocumentMappings(mappings) {
252
+ for (const mapping of mappings) {
253
+ console.log(chalk_1.default.bold(` ${chalk_1.default.green(mapping.primaryTable)} → ${chalk_1.default.cyan(mapping.targetCollection)} collection`));
254
+ for (const [pgCol, mongoField] of Object.entries(mapping.fieldMappings)) {
255
+ if (pgCol.startsWith('_'))
256
+ continue;
257
+ console.log(` ├─ ${pgCol} → ${mongoField}`);
258
+ }
259
+ for (const embed of mapping.embeddings) {
260
+ const type = embed.isArray ? 'embed array' : 'embed object';
261
+ console.log(` ├─ ${chalk_1.default.cyan(embed.sourceTable)} → ${chalk_1.default.blue(`${type} as ${embed.embedAs}`)}`);
262
+ }
263
+ for (const ref of mapping.references) {
264
+ console.log(` ├─ ${chalk_1.default.cyan(ref.sourceTable)} → ${chalk_1.default.magenta(`separate collection with ${ref.refField} ref`)}`);
265
+ }
266
+ console.log('');
267
+ }
268
+ }
269
+ function displayResults(result, isDryRun) {
270
+ if (isDryRun) {
271
+ console.log(chalk_1.default.bold(' Dry Run Results:'));
272
+ }
273
+ else {
274
+ console.log(chalk_1.default.bold(' Migration Results:'));
275
+ }
276
+ console.log(chalk_1.default.gray(' ─'.repeat(20)));
277
+ for (const table of result.tables) {
278
+ const icon = table.status === 'success'
279
+ ? chalk_1.default.green('✔')
280
+ : table.status === 'partial'
281
+ ? chalk_1.default.yellow('⚠')
282
+ : chalk_1.default.red('✗');
283
+ const counts = `${formatNumber(table.sourceCount)} → ${formatNumber(table.targetCount)}`;
284
+ const failed = table.failedCount > 0
285
+ ? chalk_1.default.red(` (${table.failedCount} failed)`)
286
+ : '';
287
+ console.log(` ${icon} ${table.name}: ${counts}${failed}`);
288
+ }
289
+ console.log('');
290
+ if (result.totalErrors > 0) {
291
+ logger_1.logger.warn(`${result.totalErrors} rows failed (see _migration_errors${isDryRun ? '' : ' table'})`);
292
+ }
293
+ if (result.success) {
294
+ logger_1.logger.success(isDryRun
295
+ ? 'All foreign keys valid — dry run passed'
296
+ : 'Migration completed successfully');
297
+ }
298
+ console.log('');
299
+ }
300
+ function formatNumber(n) {
301
+ if (n >= 1000000)
302
+ return `${(n / 1000000).toFixed(1)}M`;
303
+ if (n >= 1000)
304
+ return `${(n / 1000).toFixed(1)}K`;
305
+ return String(n);
306
+ }
307
+ //# sourceMappingURL=cross-migrate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cross-migrate.js","sourceRoot":"","sources":["../../../src/cli/commands/cross-migrate.ts"],"names":[],"mappings":"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"}
package/dist/cli/index.js CHANGED
@@ -13,6 +13,8 @@ const cleanup_1 = require("./commands/cleanup");
13
13
  const status_1 = require("./commands/status");
14
14
  const migrate_config_1 = require("./commands/migrate-config");
15
15
  const copydb_1 = require("./commands/copydb");
16
+ const analyze_1 = require("./commands/analyze");
17
+ const cross_migrate_1 = require("./commands/cross-migrate");
16
18
  const fs_1 = require("fs");
17
19
  const path_1 = require("path");
18
20
  const packageJson = JSON.parse((0, fs_1.readFileSync)((0, path_1.join)(__dirname, '../../package.json'), 'utf-8'));
@@ -93,5 +95,23 @@ program
93
95
  .option('--data-only', 'Copy data only (no schema)')
94
96
  .option('--verbose', 'Show detailed pg_dump/pg_restore output')
95
97
  .action(copydb_1.copydbCommand);
98
+ program
99
+ .command('analyze')
100
+ .description('Analyze a database structure (MongoDB or PostgreSQL)')
101
+ .argument('<url>', 'Database connection URL (mongodb:// or postgresql://)')
102
+ .action(analyze_1.analyzeCommand);
103
+ program
104
+ .command('migrate')
105
+ .description('Cross-database migration between MongoDB and PostgreSQL')
106
+ .argument('<source>', 'Source database URL')
107
+ .argument('<target>', 'Target database URL')
108
+ .option('--dry-run', 'Run migration into temporary schema for validation')
109
+ .option('--incremental', 'Only migrate new/changed data')
110
+ .option('--since <date>', 'Incremental cutoff date (ISO format)')
111
+ .option('--config <path>', 'Use a saved migration config file')
112
+ .option('--export-config <path>', 'Export migration plan to config file')
113
+ .option('--batch-size <number>', 'Documents per batch (default: 1000)', parseInt)
114
+ .option('--max-depth <number>', 'Max nesting depth before jsonb (default: 2)', parseInt)
115
+ .action(cross_migrate_1.crossMigrateCommand);
96
116
  program.parse();
97
117
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { MongoAnalysisResult, ParsedDatabaseUrl } from '../types';
2
+ export declare function parseMongoUrl(urlString: string): ParsedDatabaseUrl;
3
+ export declare function analyzeMongoDB(connectionUrl: string, sampleSize?: number): Promise<MongoAnalysisResult>;