@uql/core 3.7.13 → 3.8.1
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/CHANGELOG.md +11 -2
- package/README.md +16 -8
- package/dist/browser/uql-browser.min.js +16 -15
- package/dist/browser/uql-browser.min.js.map +1 -1
- package/dist/dialect/abstractDialect.d.ts +7 -2
- package/dist/dialect/abstractDialect.d.ts.map +1 -1
- package/dist/dialect/abstractDialect.js +9 -1
- package/dist/dialect/abstractDialect.js.map +1 -1
- package/dist/dialect/abstractSqlDialect.d.ts +5 -6
- package/dist/dialect/abstractSqlDialect.d.ts.map +1 -1
- package/dist/dialect/abstractSqlDialect.js +14 -13
- package/dist/dialect/abstractSqlDialect.js.map +1 -1
- package/dist/dialect/dialectConfig.d.ts +17 -0
- package/dist/dialect/dialectConfig.d.ts.map +1 -0
- package/dist/dialect/dialectConfig.js +71 -0
- package/dist/dialect/dialectConfig.js.map +1 -0
- package/dist/dialect/index.d.ts +1 -0
- package/dist/dialect/index.d.ts.map +1 -1
- package/dist/dialect/index.js +1 -0
- package/dist/dialect/index.js.map +1 -1
- package/dist/entity/decorator/definition.d.ts.map +1 -1
- package/dist/entity/decorator/definition.js +2 -1
- package/dist/entity/decorator/definition.js.map +1 -1
- package/dist/entity/decorator/index-decorator.d.ts +36 -0
- package/dist/entity/decorator/index-decorator.d.ts.map +1 -0
- package/dist/entity/decorator/index-decorator.js +51 -0
- package/dist/entity/decorator/index-decorator.js.map +1 -0
- package/dist/entity/decorator/index.d.ts +1 -0
- package/dist/entity/decorator/index.d.ts.map +1 -1
- package/dist/entity/decorator/index.js +1 -0
- package/dist/entity/decorator/index.js.map +1 -1
- package/dist/maria/mariaDialect.d.ts +2 -1
- package/dist/maria/mariaDialect.d.ts.map +1 -1
- package/dist/maria/mariaDialect.js +3 -0
- package/dist/maria/mariaDialect.js.map +1 -1
- package/dist/migrate/builder/columnBuilder.d.ts +75 -0
- package/dist/migrate/builder/columnBuilder.d.ts.map +1 -0
- package/dist/migrate/builder/columnBuilder.js +149 -0
- package/dist/migrate/builder/columnBuilder.js.map +1 -0
- package/dist/migrate/builder/expressions.d.ts +87 -0
- package/dist/migrate/builder/expressions.d.ts.map +1 -0
- package/dist/migrate/builder/expressions.js +150 -0
- package/dist/migrate/builder/expressions.js.map +1 -0
- package/dist/migrate/builder/index.d.ts +6 -0
- package/dist/migrate/builder/index.d.ts.map +1 -0
- package/dist/migrate/builder/index.js +6 -0
- package/dist/migrate/builder/index.js.map +1 -0
- package/dist/migrate/builder/migrationBuilder.d.ts +73 -0
- package/dist/migrate/builder/migrationBuilder.d.ts.map +1 -0
- package/dist/migrate/builder/migrationBuilder.js +326 -0
- package/dist/migrate/builder/migrationBuilder.js.map +1 -0
- package/dist/migrate/builder/tableBuilder.d.ts +51 -0
- package/dist/migrate/builder/tableBuilder.d.ts.map +1 -0
- package/dist/migrate/builder/tableBuilder.js +278 -0
- package/dist/migrate/builder/tableBuilder.js.map +1 -0
- package/dist/migrate/builder/types.d.ts +462 -0
- package/dist/migrate/builder/types.d.ts.map +1 -0
- package/dist/migrate/builder/types.js +8 -0
- package/dist/migrate/builder/types.js.map +1 -0
- package/dist/migrate/cli.d.ts +4 -6
- package/dist/migrate/cli.d.ts.map +1 -1
- package/dist/migrate/cli.js +166 -23
- package/dist/migrate/cli.js.map +1 -1
- package/dist/migrate/codegen/entityCodeGenerator.d.ts +137 -0
- package/dist/migrate/codegen/entityCodeGenerator.d.ts.map +1 -0
- package/dist/migrate/codegen/entityCodeGenerator.js +401 -0
- package/dist/migrate/codegen/entityCodeGenerator.js.map +1 -0
- package/dist/migrate/codegen/entityMerger.d.ts +111 -0
- package/dist/migrate/codegen/entityMerger.d.ts.map +1 -0
- package/dist/migrate/codegen/entityMerger.js +291 -0
- package/dist/migrate/codegen/entityMerger.js.map +1 -0
- package/dist/migrate/codegen/index.d.ts +10 -0
- package/dist/migrate/codegen/index.d.ts.map +1 -0
- package/dist/migrate/codegen/index.js +14 -0
- package/dist/migrate/codegen/index.js.map +1 -0
- package/dist/migrate/codegen/migrationCodeGenerator.d.ts +62 -0
- package/dist/migrate/codegen/migrationCodeGenerator.d.ts.map +1 -0
- package/dist/migrate/codegen/migrationCodeGenerator.js +356 -0
- package/dist/migrate/codegen/migrationCodeGenerator.js.map +1 -0
- package/dist/migrate/codegen/smartRelationDetector.d.ts +48 -0
- package/dist/migrate/codegen/smartRelationDetector.d.ts.map +1 -0
- package/dist/migrate/codegen/smartRelationDetector.js +135 -0
- package/dist/migrate/codegen/smartRelationDetector.js.map +1 -0
- package/dist/migrate/drift/driftDetector.d.ts +81 -0
- package/dist/migrate/drift/driftDetector.d.ts.map +1 -0
- package/dist/migrate/drift/driftDetector.js +248 -0
- package/dist/migrate/drift/driftDetector.js.map +1 -0
- package/dist/migrate/drift/index.d.ts +7 -0
- package/dist/migrate/drift/index.d.ts.map +1 -0
- package/dist/migrate/drift/index.js +7 -0
- package/dist/migrate/drift/index.js.map +1 -0
- package/dist/migrate/generator/index.d.ts +1 -3
- package/dist/migrate/generator/index.d.ts.map +1 -1
- package/dist/migrate/generator/index.js +1 -3
- package/dist/migrate/generator/index.js.map +1 -1
- package/dist/migrate/generator/mongoSchemaGenerator.d.ts +29 -3
- package/dist/migrate/generator/mongoSchemaGenerator.d.ts.map +1 -1
- package/dist/migrate/generator/mongoSchemaGenerator.js +86 -4
- package/dist/migrate/generator/mongoSchemaGenerator.js.map +1 -1
- package/dist/migrate/index.d.ts +7 -8
- package/dist/migrate/index.d.ts.map +1 -1
- package/dist/migrate/index.js +11 -9
- package/dist/migrate/index.js.map +1 -1
- package/dist/migrate/introspection/baseSqlIntrospector.d.ts +28 -0
- package/dist/migrate/introspection/baseSqlIntrospector.d.ts.map +1 -0
- package/dist/migrate/introspection/baseSqlIntrospector.js +135 -0
- package/dist/migrate/introspection/baseSqlIntrospector.js.map +1 -0
- package/dist/migrate/introspection/mongoIntrospector.d.ts +6 -0
- package/dist/migrate/introspection/mongoIntrospector.d.ts.map +1 -1
- package/dist/migrate/introspection/mongoIntrospector.js +54 -0
- package/dist/migrate/introspection/mongoIntrospector.js.map +1 -1
- package/dist/migrate/introspection/mysqlIntrospector.d.ts +2 -1
- package/dist/migrate/introspection/mysqlIntrospector.d.ts.map +1 -1
- package/dist/migrate/introspection/mysqlIntrospector.js +8 -6
- package/dist/migrate/introspection/mysqlIntrospector.js.map +1 -1
- package/dist/migrate/introspection/postgresIntrospector.d.ts +2 -1
- package/dist/migrate/introspection/postgresIntrospector.d.ts.map +1 -1
- package/dist/migrate/introspection/postgresIntrospector.js +3 -1
- package/dist/migrate/introspection/postgresIntrospector.js.map +1 -1
- package/dist/migrate/introspection/sqliteIntrospector.d.ts +2 -2
- package/dist/migrate/introspection/sqliteIntrospector.d.ts.map +1 -1
- package/dist/migrate/introspection/sqliteIntrospector.js +3 -4
- package/dist/migrate/introspection/sqliteIntrospector.js.map +1 -1
- package/dist/migrate/migrator.d.ts +29 -0
- package/dist/migrate/migrator.d.ts.map +1 -1
- package/dist/migrate/migrator.js +31 -23
- package/dist/migrate/migrator.js.map +1 -1
- package/dist/migrate/schemaGenerator.d.ts +72 -22
- package/dist/migrate/schemaGenerator.d.ts.map +1 -1
- package/dist/migrate/schemaGenerator.js +385 -153
- package/dist/migrate/schemaGenerator.js.map +1 -1
- package/dist/migrate/sync/index.d.ts +7 -0
- package/dist/migrate/sync/index.d.ts.map +1 -0
- package/dist/migrate/sync/index.js +7 -0
- package/dist/migrate/sync/index.js.map +1 -0
- package/dist/migrate/sync/schemaSync.d.ts +132 -0
- package/dist/migrate/sync/schemaSync.d.ts.map +1 -0
- package/dist/migrate/sync/schemaSync.js +260 -0
- package/dist/migrate/sync/schemaSync.js.map +1 -0
- package/dist/mongo/mongoDialect.d.ts +2 -1
- package/dist/mongo/mongoDialect.d.ts.map +1 -1
- package/dist/mongo/mongoDialect.js +3 -0
- package/dist/mongo/mongoDialect.js.map +1 -1
- package/dist/mysql/mysqlDialect.d.ts +2 -0
- package/dist/mysql/mysqlDialect.d.ts.map +1 -1
- package/dist/mysql/mysqlDialect.js +3 -0
- package/dist/mysql/mysqlDialect.js.map +1 -1
- package/dist/postgres/postgresDialect.js +1 -1
- package/dist/postgres/postgresDialect.js.map +1 -1
- package/dist/schema/canonicalType.d.ts +42 -0
- package/dist/schema/canonicalType.d.ts.map +1 -0
- package/dist/schema/canonicalType.js +524 -0
- package/dist/schema/canonicalType.js.map +1 -0
- package/dist/schema/index.d.ts +28 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +29 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/schemaAST.d.ts +155 -0
- package/dist/schema/schemaAST.d.ts.map +1 -0
- package/dist/schema/schemaAST.js +496 -0
- package/dist/schema/schemaAST.js.map +1 -0
- package/dist/schema/schemaASTBuilder.d.ts +58 -0
- package/dist/schema/schemaASTBuilder.d.ts.map +1 -0
- package/dist/schema/schemaASTBuilder.js +193 -0
- package/dist/schema/schemaASTBuilder.js.map +1 -0
- package/dist/schema/schemaASTDiffer.d.ts +84 -0
- package/dist/schema/schemaASTDiffer.d.ts.map +1 -0
- package/dist/schema/schemaASTDiffer.js +431 -0
- package/dist/schema/schemaASTDiffer.js.map +1 -0
- package/dist/schema/types.d.ts +347 -0
- package/dist/schema/types.d.ts.map +1 -0
- package/dist/schema/types.js +11 -0
- package/dist/schema/types.js.map +1 -0
- package/dist/sqlite/sqliteDialect.js +1 -1
- package/dist/sqlite/sqliteDialect.js.map +1 -1
- package/dist/sqlite/sqliteQuerierPool.js.map +1 -1
- package/dist/type/config.d.ts +6 -0
- package/dist/type/config.d.ts.map +1 -1
- package/dist/type/entity.d.ts +24 -0
- package/dist/type/entity.d.ts.map +1 -1
- package/dist/type/migration.d.ts +50 -4
- package/dist/type/migration.d.ts.map +1 -1
- package/dist/util/field.util.d.ts +0 -1
- package/dist/util/field.util.d.ts.map +1 -1
- package/dist/util/field.util.js +8 -2
- package/dist/util/field.util.js.map +1 -1
- package/dist/util/logger.d.ts.map +1 -1
- package/dist/util/logger.js +2 -1
- package/dist/util/logger.js.map +1 -1
- package/dist/util/string.util.d.ts +24 -0
- package/dist/util/string.util.d.ts.map +1 -1
- package/dist/util/string.util.js +57 -0
- package/dist/util/string.util.js.map +1 -1
- package/package.json +2 -2
- package/dist/migrate/generator/mysqlSchemaGenerator.d.ts +0 -15
- package/dist/migrate/generator/mysqlSchemaGenerator.d.ts.map +0 -1
- package/dist/migrate/generator/mysqlSchemaGenerator.js +0 -88
- package/dist/migrate/generator/mysqlSchemaGenerator.js.map +0 -1
- package/dist/migrate/generator/postgresSchemaGenerator.d.ts +0 -19
- package/dist/migrate/generator/postgresSchemaGenerator.d.ts.map +0 -1
- package/dist/migrate/generator/postgresSchemaGenerator.js +0 -115
- package/dist/migrate/generator/postgresSchemaGenerator.js.map +0 -1
- package/dist/migrate/generator/sqliteSchemaGenerator.d.ts +0 -16
- package/dist/migrate/generator/sqliteSchemaGenerator.d.ts.map +0 -1
- package/dist/migrate/generator/sqliteSchemaGenerator.js +0 -74
- package/dist/migrate/generator/sqliteSchemaGenerator.js.map +0 -1
- package/dist/migrate/type.d.ts +0 -2
- package/dist/migrate/type.d.ts.map +0 -1
- package/dist/migrate/type.js +0 -2
- package/dist/migrate/type.js.map +0 -1
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Drift Detector
|
|
3
|
+
*
|
|
4
|
+
* Detects schema drift between expected schema (from entities) and
|
|
5
|
+
* actual database schema.
|
|
6
|
+
*/
|
|
7
|
+
import { canonicalToSql } from '../../schema/canonicalType.js';
|
|
8
|
+
import { SchemaASTDiffer } from '../../schema/schemaASTDiffer.js';
|
|
9
|
+
/**
|
|
10
|
+
* Detects drift between expected and actual database schemas.
|
|
11
|
+
*/
|
|
12
|
+
export class DriftDetector {
|
|
13
|
+
expectedAST;
|
|
14
|
+
actualAST;
|
|
15
|
+
options;
|
|
16
|
+
dialect;
|
|
17
|
+
constructor(expectedAST, actualAST, options = {}) {
|
|
18
|
+
this.expectedAST = expectedAST;
|
|
19
|
+
this.actualAST = actualAST;
|
|
20
|
+
this.options = {
|
|
21
|
+
checkTypes: options.checkTypes ?? true,
|
|
22
|
+
checkNullable: options.checkNullable ?? true,
|
|
23
|
+
checkIndexes: options.checkIndexes ?? true,
|
|
24
|
+
checkForeignKeys: options.checkForeignKeys ?? true,
|
|
25
|
+
checkDefaults: options.checkDefaults ?? false, // Often differ between SQL and entity
|
|
26
|
+
dialect: options.dialect ?? 'postgres',
|
|
27
|
+
};
|
|
28
|
+
this.dialect = this.options.dialect;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Detect all schema drift.
|
|
32
|
+
*/
|
|
33
|
+
detect() {
|
|
34
|
+
const differ = new SchemaASTDiffer();
|
|
35
|
+
const diff = differ.diff(this.expectedAST, this.actualAST);
|
|
36
|
+
const drifts = [
|
|
37
|
+
...this.detectTableDrifts(diff),
|
|
38
|
+
...this.detectColumnDrifts(diff),
|
|
39
|
+
...this.detectIndexDrifts(diff),
|
|
40
|
+
...this.detectRelationshipDrifts(diff),
|
|
41
|
+
];
|
|
42
|
+
return {
|
|
43
|
+
status: this.calculateStatus(drifts),
|
|
44
|
+
drifts,
|
|
45
|
+
summary: this.createSummary(drifts),
|
|
46
|
+
generatedAt: new Date(),
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Detect table-level drifts (missing/unexpected tables).
|
|
51
|
+
*/
|
|
52
|
+
detectTableDrifts(diff) {
|
|
53
|
+
const drifts = [];
|
|
54
|
+
for (const table of diff.tablesToCreate) {
|
|
55
|
+
drifts.push({
|
|
56
|
+
type: 'missing_table',
|
|
57
|
+
severity: 'critical',
|
|
58
|
+
table: table.name,
|
|
59
|
+
details: `Entity "${table.name}" exists but table not in database`,
|
|
60
|
+
suggestion: 'Run migrations to create table',
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
for (const table of diff.tablesToDrop) {
|
|
64
|
+
drifts.push({
|
|
65
|
+
type: 'unexpected_table',
|
|
66
|
+
severity: 'warning',
|
|
67
|
+
table: table.name,
|
|
68
|
+
details: `Table "${table.name}" exists in database but no matching entity`,
|
|
69
|
+
suggestion: 'Create entity or drop table',
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
return drifts;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Detect column-level drifts.
|
|
76
|
+
*/
|
|
77
|
+
detectColumnDrifts(diff) {
|
|
78
|
+
const drifts = [];
|
|
79
|
+
for (const colDiff of diff.columnDiffs) {
|
|
80
|
+
if (colDiff.type === 'add') {
|
|
81
|
+
drifts.push({
|
|
82
|
+
type: 'missing_column',
|
|
83
|
+
severity: 'critical',
|
|
84
|
+
table: colDiff.table,
|
|
85
|
+
column: colDiff.column,
|
|
86
|
+
details: `Column "${colDiff.column}" expected but not found in database`,
|
|
87
|
+
suggestion: 'Run migration to add column',
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
else if (colDiff.type === 'drop') {
|
|
91
|
+
drifts.push({
|
|
92
|
+
type: 'unexpected_column',
|
|
93
|
+
severity: 'warning',
|
|
94
|
+
table: colDiff.table,
|
|
95
|
+
column: colDiff.column,
|
|
96
|
+
details: `Column "${colDiff.column}" exists in database but not in entity`,
|
|
97
|
+
suggestion: 'Add to entity or create migration to drop',
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
else if (colDiff.type === 'alter') {
|
|
101
|
+
this.addAlterColumnDrifts(colDiff, drifts);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return drifts;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Add drifts for column alterations (type/nullable mismatches).
|
|
108
|
+
*/
|
|
109
|
+
addAlterColumnDrifts(colDiff, drifts) {
|
|
110
|
+
if (this.options.checkTypes && colDiff.expected && colDiff.actual) {
|
|
111
|
+
const expectedType = this.formatType(colDiff.expected.type);
|
|
112
|
+
const actualType = this.formatType(colDiff.actual.type);
|
|
113
|
+
if (expectedType !== actualType) {
|
|
114
|
+
drifts.push({
|
|
115
|
+
type: 'type_mismatch',
|
|
116
|
+
severity: colDiff.isBreaking ? 'critical' : 'warning',
|
|
117
|
+
table: colDiff.table,
|
|
118
|
+
column: colDiff.column,
|
|
119
|
+
expected: expectedType,
|
|
120
|
+
actual: actualType,
|
|
121
|
+
details: `Type mismatch for "${colDiff.column}": expected ${expectedType}, got ${actualType}`,
|
|
122
|
+
suggestion: colDiff.isBreaking
|
|
123
|
+
? 'Data truncation risk! Create migration to fix.'
|
|
124
|
+
: 'Create migration to align types',
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
if (this.options.checkNullable && colDiff.expected && colDiff.actual) {
|
|
129
|
+
if (colDiff.expected.nullable !== colDiff.actual.nullable) {
|
|
130
|
+
drifts.push({
|
|
131
|
+
type: 'constraint_mismatch',
|
|
132
|
+
severity: 'warning',
|
|
133
|
+
table: colDiff.table,
|
|
134
|
+
column: colDiff.column,
|
|
135
|
+
expected: colDiff.expected.nullable ? 'NULLABLE' : 'NOT NULL',
|
|
136
|
+
actual: colDiff.actual.nullable ? 'NULLABLE' : 'NOT NULL',
|
|
137
|
+
details: `Nullable mismatch for "${colDiff.column}"`,
|
|
138
|
+
suggestion: 'Align nullable setting in entity or database',
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Detect index drifts.
|
|
145
|
+
*/
|
|
146
|
+
detectIndexDrifts(diff) {
|
|
147
|
+
if (!this.options.checkIndexes)
|
|
148
|
+
return [];
|
|
149
|
+
const drifts = [];
|
|
150
|
+
for (const idxDiff of diff.indexDiffs) {
|
|
151
|
+
if (idxDiff.type === 'create') {
|
|
152
|
+
drifts.push({
|
|
153
|
+
type: 'missing_index',
|
|
154
|
+
severity: 'warning',
|
|
155
|
+
table: idxDiff.table,
|
|
156
|
+
index: idxDiff.name,
|
|
157
|
+
details: `Index "${idxDiff.name}" expected but not found in database`,
|
|
158
|
+
suggestion: 'Create index via migration',
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
else if (idxDiff.type === 'drop') {
|
|
162
|
+
drifts.push({
|
|
163
|
+
type: 'unexpected_index',
|
|
164
|
+
severity: 'info',
|
|
165
|
+
table: idxDiff.table,
|
|
166
|
+
index: idxDiff.name,
|
|
167
|
+
details: `Index "${idxDiff.name}" exists in database but not defined in entity`,
|
|
168
|
+
suggestion: 'Add @Field({ index }) or create migration to drop',
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
return drifts;
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Detect relationship/FK drifts.
|
|
176
|
+
*/
|
|
177
|
+
detectRelationshipDrifts(diff) {
|
|
178
|
+
if (!this.options.checkForeignKeys)
|
|
179
|
+
return [];
|
|
180
|
+
const drifts = [];
|
|
181
|
+
for (const relDiff of diff.relationshipDiffs) {
|
|
182
|
+
if (relDiff.type === 'create') {
|
|
183
|
+
drifts.push({
|
|
184
|
+
type: 'missing_relationship',
|
|
185
|
+
severity: 'warning',
|
|
186
|
+
table: relDiff.fromTable,
|
|
187
|
+
relationship: relDiff.name,
|
|
188
|
+
details: `FK "${relDiff.name}" expected but not found in database`,
|
|
189
|
+
suggestion: 'Add FK constraint or remove relation from entity',
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
else if (relDiff.type === 'drop') {
|
|
193
|
+
drifts.push({
|
|
194
|
+
type: 'unexpected_relationship',
|
|
195
|
+
severity: 'info',
|
|
196
|
+
table: relDiff.fromTable,
|
|
197
|
+
relationship: relDiff.name,
|
|
198
|
+
details: `FK "${relDiff.name}" exists in database but not in entity`,
|
|
199
|
+
suggestion: 'Add relation to entity or drop FK',
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
return drifts;
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Calculate overall status based on drifts.
|
|
207
|
+
*/
|
|
208
|
+
calculateStatus(drifts) {
|
|
209
|
+
if (drifts.length === 0)
|
|
210
|
+
return 'in_sync';
|
|
211
|
+
const hasCritical = drifts.some((d) => d.severity === 'critical');
|
|
212
|
+
if (hasCritical)
|
|
213
|
+
return 'critical';
|
|
214
|
+
return 'drifted';
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* Create a summary of drifts by severity.
|
|
218
|
+
*/
|
|
219
|
+
createSummary(drifts) {
|
|
220
|
+
return {
|
|
221
|
+
critical: drifts.filter((d) => d.severity === 'critical').length,
|
|
222
|
+
warning: drifts.filter((d) => d.severity === 'warning').length,
|
|
223
|
+
info: drifts.filter((d) => d.severity === 'info').length,
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Format type for display.
|
|
228
|
+
*/
|
|
229
|
+
formatType(type) {
|
|
230
|
+
if (!type)
|
|
231
|
+
return 'unknown';
|
|
232
|
+
return canonicalToSql(type, this.dialect);
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* Create a DriftDetector for comparing expected vs actual schemas.
|
|
237
|
+
*/
|
|
238
|
+
export function createDriftDetector(expectedAST, actualAST, options) {
|
|
239
|
+
return new DriftDetector(expectedAST, actualAST, options);
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Quick check for schema drift.
|
|
243
|
+
*/
|
|
244
|
+
export function detectDrift(expectedAST, actualAST, options) {
|
|
245
|
+
const detector = new DriftDetector(expectedAST, actualAST, options);
|
|
246
|
+
return detector.detect();
|
|
247
|
+
}
|
|
248
|
+
//# sourceMappingURL=driftDetector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"driftDetector.js","sourceRoot":"","sources":["../../../src/migrate/drift/driftDetector.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/migrate/drift/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,mBAAmB,EACnB,aAAa,EACb,KAAK,oBAAoB,EACzB,WAAW,GACZ,MAAM,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/migrate/drift/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,mBAAmB,EACnB,aAAa,EAEb,WAAW,GACZ,MAAM,oBAAoB,CAAC"}
|
|
@@ -1,5 +1,3 @@
|
|
|
1
|
+
export { createSchemaGenerator, SqlSchemaGenerator } from '../schemaGenerator.js';
|
|
1
2
|
export * from './mongoSchemaGenerator.js';
|
|
2
|
-
export { MysqlSchemaGenerator, MysqlSchemaGenerator as MariadbSchemaGenerator } from './mysqlSchemaGenerator.js';
|
|
3
|
-
export * from './postgresSchemaGenerator.js';
|
|
4
|
-
export * from './sqliteSchemaGenerator.js';
|
|
5
3
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/migrate/generator/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/migrate/generator/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAClF,cAAc,2BAA2B,CAAC"}
|
|
@@ -1,5 +1,3 @@
|
|
|
1
|
+
export { createSchemaGenerator, SqlSchemaGenerator } from '../schemaGenerator.js';
|
|
1
2
|
export * from './mongoSchemaGenerator.js';
|
|
2
|
-
export { MysqlSchemaGenerator, MysqlSchemaGenerator as MariadbSchemaGenerator } from './mysqlSchemaGenerator.js';
|
|
3
|
-
export * from './postgresSchemaGenerator.js';
|
|
4
|
-
export * from './sqliteSchemaGenerator.js';
|
|
5
3
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/migrate/generator/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/migrate/generator/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAClF,cAAc,2BAA2B,CAAC"}
|
|
@@ -1,13 +1,39 @@
|
|
|
1
1
|
import { AbstractDialect } from '../../dialect/index.js';
|
|
2
|
-
import type {
|
|
2
|
+
import type { ForeignKeyAction, IndexNode, TableNode } from '../../schema/types.js';
|
|
3
|
+
import type { IndexSchema, NamingStrategy, SchemaDiff, SchemaGenerator, Type } from '../../type/index.js';
|
|
4
|
+
import type { TableDefinition } from '../builder/types.js';
|
|
3
5
|
export declare class MongoSchemaGenerator extends AbstractDialect implements SchemaGenerator {
|
|
6
|
+
constructor(namingStrategy?: NamingStrategy, defaultForeignKeyAction?: ForeignKeyAction);
|
|
4
7
|
generateCreateTable<E>(entity: Type<E>): string;
|
|
5
8
|
generateDropTable<E>(entity: Type<E>): string;
|
|
6
9
|
generateAlterTable(diff: SchemaDiff): string[];
|
|
7
10
|
generateAlterTableDown(diff: SchemaDiff): string[];
|
|
8
11
|
generateCreateIndex(tableName: string, index: IndexSchema): string;
|
|
9
12
|
generateDropIndex(tableName: string, indexName: string): string;
|
|
10
|
-
getSqlType(): string;
|
|
11
|
-
|
|
13
|
+
getSqlType(fieldOptions: any, fieldType?: unknown): string;
|
|
14
|
+
getBooleanType(): string;
|
|
15
|
+
generateColumnDefinitions(): string[];
|
|
16
|
+
generateColumnDefinition(): string;
|
|
17
|
+
generateColumnDefinitionFromSchema(): string;
|
|
18
|
+
generateTableConstraints(): string[];
|
|
19
|
+
generateAlterColumnStatements(): string[];
|
|
20
|
+
getTableOptions(): string;
|
|
21
|
+
generateColumnComment(): string;
|
|
22
|
+
formatDefaultValue(): string;
|
|
23
|
+
generateCreateTableFromNode(table: TableNode): string;
|
|
24
|
+
generateCreateIndexFromNode(index: IndexNode): string;
|
|
25
|
+
generateDropTableFromNode(table: TableNode): string;
|
|
26
|
+
generateCreateTableFromDefinition(table: TableDefinition): string;
|
|
27
|
+
generateDropTableSql(tableName: string): string;
|
|
28
|
+
generateRenameTableSql(oldName: string, newName: string): string;
|
|
29
|
+
generateAddColumnSql(): string;
|
|
30
|
+
generateDropColumnSql(): string;
|
|
31
|
+
generateRenameColumnSql(): string;
|
|
32
|
+
generateAlterColumnSql(): string;
|
|
33
|
+
generateCreateIndexSql(tableName: string, index: IndexSchema): string;
|
|
34
|
+
generateDropIndexSql(tableName: string, indexName: string): string;
|
|
35
|
+
generateAddForeignKeySql(): string;
|
|
36
|
+
generateDropForeignKeySql(): string;
|
|
37
|
+
diffSchema<E>(entity: Type<E>, currentTable: TableNode | undefined): SchemaDiff | undefined;
|
|
12
38
|
}
|
|
13
39
|
//# sourceMappingURL=mongoSchemaGenerator.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mongoSchemaGenerator.d.ts","sourceRoot":"","sources":["../../../src/migrate/generator/mongoSchemaGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,eAAe,EAAE,
|
|
1
|
+
{"version":3,"file":"mongoSchemaGenerator.d.ts","sourceRoot":"","sources":["../../../src/migrate/generator/mongoSchemaGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,KAAK,EAAE,gBAAgB,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AACpF,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,UAAU,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAC1G,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE3D,qBAAa,oBAAqB,SAAQ,eAAgB,YAAW,eAAe;gBACtE,cAAc,CAAC,EAAE,cAAc,EAAE,uBAAuB,CAAC,EAAE,gBAAgB;IAGvF,mBAAmB,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM;IAqB/C,iBAAiB,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM;IAM7C,kBAAkB,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,EAAE;IAU9C,sBAAsB,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,EAAE;IAUlD,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,GAAG,MAAM;IAclE,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;IAQ/D,UAAU,CAAC,YAAY,EAAE,GAAG,EAAE,SAAS,CAAC,EAAE,OAAO,GAAG,MAAM;IAI1D,cAAc,IAAI,MAAM;IAIxB,yBAAyB,IAAI,MAAM,EAAE;IAIrC,wBAAwB,IAAI,MAAM;IAIlC,kCAAkC,IAAI,MAAM;IAI5C,wBAAwB,IAAI,MAAM,EAAE;IAIpC,6BAA6B,IAAI,MAAM,EAAE;IAIzC,eAAe,IAAI,MAAM;IAIzB,qBAAqB,IAAI,MAAM;IAI/B,kBAAkB,IAAI,MAAM;IAI5B,2BAA2B,CAAC,KAAK,EAAE,SAAS,GAAG,MAAM;IAIrD,2BAA2B,CAAC,KAAK,EAAE,SAAS,GAAG,MAAM;IAcrD,yBAAyB,CAAC,KAAK,EAAE,SAAS,GAAG,MAAM;IAInD,iCAAiC,CAAC,KAAK,EAAE,eAAe,GAAG,MAAM;IAIjE,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM;IAI/C,sBAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM;IAIhE,oBAAoB,IAAI,MAAM;IAI9B,qBAAqB,IAAI,MAAM;IAI/B,uBAAuB,IAAI,MAAM;IAIjC,sBAAsB,IAAI,MAAM;IAIhC,sBAAsB,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,GAAG,MAAM;IAIrE,oBAAoB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;IAIlE,wBAAwB,IAAI,MAAM;IAIlC,yBAAyB,IAAI,MAAM;IAInC,UAAU,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,SAAS,GAAG,SAAS,GAAG,UAAU,GAAG,SAAS;CAoC5F"}
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import { AbstractDialect } from '../../dialect/index.js';
|
|
2
2
|
import { getMeta } from '../../entity/index.js';
|
|
3
3
|
export class MongoSchemaGenerator extends AbstractDialect {
|
|
4
|
+
constructor(namingStrategy, defaultForeignKeyAction) {
|
|
5
|
+
super('mongodb', namingStrategy, defaultForeignKeyAction);
|
|
6
|
+
}
|
|
4
7
|
generateCreateTable(entity) {
|
|
5
8
|
const meta = getMeta(entity);
|
|
6
9
|
const collectionName = this.resolveTableName(entity, meta);
|
|
@@ -62,17 +65,96 @@ export class MongoSchemaGenerator extends AbstractDialect {
|
|
|
62
65
|
name: indexName,
|
|
63
66
|
});
|
|
64
67
|
}
|
|
65
|
-
getSqlType() {
|
|
68
|
+
getSqlType(fieldOptions, fieldType) {
|
|
69
|
+
return '';
|
|
70
|
+
}
|
|
71
|
+
getBooleanType() {
|
|
72
|
+
return '';
|
|
73
|
+
}
|
|
74
|
+
generateColumnDefinitions() {
|
|
75
|
+
return [];
|
|
76
|
+
}
|
|
77
|
+
generateColumnDefinition() {
|
|
78
|
+
return '';
|
|
79
|
+
}
|
|
80
|
+
generateColumnDefinitionFromSchema() {
|
|
81
|
+
return '';
|
|
82
|
+
}
|
|
83
|
+
generateTableConstraints() {
|
|
84
|
+
return [];
|
|
85
|
+
}
|
|
86
|
+
generateAlterColumnStatements() {
|
|
87
|
+
return [];
|
|
88
|
+
}
|
|
89
|
+
getTableOptions() {
|
|
90
|
+
return '';
|
|
91
|
+
}
|
|
92
|
+
generateColumnComment() {
|
|
93
|
+
return '';
|
|
94
|
+
}
|
|
95
|
+
formatDefaultValue() {
|
|
96
|
+
return '';
|
|
97
|
+
}
|
|
98
|
+
generateCreateTableFromNode(table) {
|
|
99
|
+
return JSON.stringify({ action: 'createCollection', name: table.name });
|
|
100
|
+
}
|
|
101
|
+
generateCreateIndexFromNode(index) {
|
|
102
|
+
const key = {};
|
|
103
|
+
for (const col of index.columns) {
|
|
104
|
+
key[col.name] = 1;
|
|
105
|
+
}
|
|
106
|
+
return JSON.stringify({
|
|
107
|
+
action: 'createIndex',
|
|
108
|
+
collection: index.table.name,
|
|
109
|
+
name: index.name,
|
|
110
|
+
key,
|
|
111
|
+
options: { unique: index.unique, name: index.name },
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
generateDropTableFromNode(table) {
|
|
115
|
+
return JSON.stringify({ action: 'dropCollection', name: table.name });
|
|
116
|
+
}
|
|
117
|
+
generateCreateTableFromDefinition(table) {
|
|
118
|
+
return JSON.stringify({ action: 'createCollection', name: table.name });
|
|
119
|
+
}
|
|
120
|
+
generateDropTableSql(tableName) {
|
|
121
|
+
return JSON.stringify({ action: 'dropCollection', name: tableName });
|
|
122
|
+
}
|
|
123
|
+
generateRenameTableSql(oldName, newName) {
|
|
124
|
+
return JSON.stringify({ action: 'renameCollection', from: oldName, to: newName });
|
|
125
|
+
}
|
|
126
|
+
generateAddColumnSql() {
|
|
127
|
+
return '';
|
|
128
|
+
}
|
|
129
|
+
generateDropColumnSql() {
|
|
130
|
+
return '';
|
|
131
|
+
}
|
|
132
|
+
generateRenameColumnSql() {
|
|
133
|
+
return '';
|
|
134
|
+
}
|
|
135
|
+
generateAlterColumnSql() {
|
|
136
|
+
return '';
|
|
137
|
+
}
|
|
138
|
+
generateCreateIndexSql(tableName, index) {
|
|
139
|
+
return this.generateCreateIndex(tableName, index);
|
|
140
|
+
}
|
|
141
|
+
generateDropIndexSql(tableName, indexName) {
|
|
142
|
+
return this.generateDropIndex(tableName, indexName);
|
|
143
|
+
}
|
|
144
|
+
generateAddForeignKeySql() {
|
|
145
|
+
return '';
|
|
146
|
+
}
|
|
147
|
+
generateDropForeignKeySql() {
|
|
66
148
|
return '';
|
|
67
149
|
}
|
|
68
|
-
diffSchema(entity,
|
|
150
|
+
diffSchema(entity, currentTable) {
|
|
69
151
|
const meta = getMeta(entity);
|
|
70
152
|
const collectionName = this.resolveTableName(entity, meta);
|
|
71
|
-
if (!
|
|
153
|
+
if (!currentTable) {
|
|
72
154
|
return { tableName: collectionName, type: 'create' };
|
|
73
155
|
}
|
|
74
156
|
const indexesToAdd = [];
|
|
75
|
-
const existingIndexes = new Set(
|
|
157
|
+
const existingIndexes = new Set(currentTable.indexes?.map((i) => i.name) ?? []);
|
|
76
158
|
for (const key in meta.fields) {
|
|
77
159
|
const field = meta.fields[key];
|
|
78
160
|
if (field.index) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mongoSchemaGenerator.js","sourceRoot":"","sources":["../../../src/migrate/generator/mongoSchemaGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"mongoSchemaGenerator.js","sourceRoot":"","sources":["../../../src/migrate/generator/mongoSchemaGenerator.ts"],"names":[],"mappings":"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"}
|
package/dist/migrate/index.d.ts
CHANGED
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
export type { ColumnSchema, Dialect, ForeignKeySchema, IndexSchema, Migration, MigrationDefinition, MigrationResult, MigrationStorage, MigratorOptions, MongoQuerier, SchemaDiff, SchemaGenerator, SchemaIntrospector, SqlDialect, SqlQuerier, SqlQueryDialect, TableSchema, } from '../type/index.js';
|
|
2
2
|
export { type Config, isSqlQuerier } from '../type/index.js';
|
|
3
|
+
export * from './builder/index.js';
|
|
3
4
|
export { loadConfig } from './cli-config.js';
|
|
4
|
-
export
|
|
5
|
-
export
|
|
6
|
-
export
|
|
7
|
-
export {
|
|
8
|
-
export {
|
|
9
|
-
export { SqliteSchemaIntrospector } from './introspection/sqliteIntrospector.js';
|
|
10
|
-
export { defineMigration, Migrator } from './migrator.js';
|
|
11
|
-
export { AbstractSchemaGenerator } from './schemaGenerator.js';
|
|
5
|
+
export * from './codegen/index.js';
|
|
6
|
+
export * from './drift/index.js';
|
|
7
|
+
export * from './introspection/index.js';
|
|
8
|
+
export { type BuilderMigrationDefinition, defineBuilderMigration, defineMigration, Migrator } from './migrator.js';
|
|
9
|
+
export { createSchemaGenerator, MongoSchemaGenerator, SqlSchemaGenerator } from './schemaGenerator.js';
|
|
12
10
|
export { DatabaseMigrationStorage } from './storage/databaseStorage.js';
|
|
13
11
|
export { JsonMigrationStorage } from './storage/jsonStorage.js';
|
|
12
|
+
export * from './sync/index.js';
|
|
14
13
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/migrate/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/migrate/index.ts"],"names":[],"mappings":"AACA,YAAY,EACV,YAAY,EACZ,OAAO,EACP,gBAAgB,EAChB,WAAW,EACX,SAAS,EACT,mBAAmB,EACnB,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,YAAY,EACZ,UAAU,EACV,eAAe,EACf,kBAAkB,EAClB,UAAU,EACV,UAAU,EACV,eAAe,EACf,WAAW,GACZ,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,MAAM,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAG7D,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAG7C,cAAc,oBAAoB,CAAC;AAGnC,cAAc,kBAAkB,CAAC;AAEjC,cAAc,0BAA0B,CAAC;AAEzC,OAAO,EAAE,KAAK,0BAA0B,EAAE,sBAAsB,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEnH,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAGvG,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGhE,cAAc,iBAAiB,CAAC"}
|
package/dist/migrate/index.js
CHANGED
|
@@ -1,18 +1,20 @@
|
|
|
1
|
-
// Core types
|
|
2
1
|
export { isSqlQuerier } from '../type/index.js';
|
|
2
|
+
// Type-safe migration builder
|
|
3
|
+
export * from './builder/index.js';
|
|
3
4
|
export { loadConfig } from './cli-config.js';
|
|
4
|
-
|
|
5
|
-
export
|
|
6
|
-
|
|
5
|
+
// Entity code generation
|
|
6
|
+
export * from './codegen/index.js';
|
|
7
|
+
// Drift detection
|
|
8
|
+
export * from './drift/index.js';
|
|
7
9
|
// Schema introspection
|
|
8
|
-
export
|
|
9
|
-
export { PostgresSchemaIntrospector } from './introspection/postgresIntrospector.js';
|
|
10
|
-
export { SqliteSchemaIntrospector } from './introspection/sqliteIntrospector.js';
|
|
10
|
+
export * from './introspection/index.js';
|
|
11
11
|
// Main migrator
|
|
12
|
-
export { defineMigration, Migrator } from './migrator.js';
|
|
12
|
+
export { defineBuilderMigration, defineMigration, Migrator } from './migrator.js';
|
|
13
13
|
// Schema generators
|
|
14
|
-
export {
|
|
14
|
+
export { createSchemaGenerator, MongoSchemaGenerator, SqlSchemaGenerator } from './schemaGenerator.js';
|
|
15
15
|
// Storage implementations
|
|
16
16
|
export { DatabaseMigrationStorage } from './storage/databaseStorage.js';
|
|
17
17
|
export { JsonMigrationStorage } from './storage/jsonStorage.js';
|
|
18
|
+
// Schema sync
|
|
19
|
+
export * from './sync/index.js';
|
|
18
20
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migrate/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migrate/index.ts"],"names":[],"mappings":"AAoBA,OAAO,EAAe,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAE7D,8BAA8B;AAC9B,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAE7C,yBAAyB;AACzB,cAAc,oBAAoB,CAAC;AAEnC,kBAAkB;AAClB,cAAc,kBAAkB,CAAC;AACjC,uBAAuB;AACvB,cAAc,0BAA0B,CAAC;AACzC,gBAAgB;AAChB,OAAO,EAAmC,sBAAsB,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACnH,oBAAoB;AACpB,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAEvG,0BAA0B;AAC1B,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,cAAc;AACd,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type DialectConfig } from '../../dialect/index.js';
|
|
2
|
+
import { SchemaAST } from '../../schema/schemaAST.js';
|
|
3
|
+
import type { Dialect } from '../../type/index.js';
|
|
4
|
+
import type { TableSchema } from '../../type/migration.js';
|
|
5
|
+
/**
|
|
6
|
+
* Base class for SQL introspectors with shared AST building logic.
|
|
7
|
+
*/
|
|
8
|
+
export declare abstract class BaseSqlIntrospector {
|
|
9
|
+
protected readonly dialect: Dialect;
|
|
10
|
+
protected readonly config: DialectConfig;
|
|
11
|
+
constructor(dialect: Dialect);
|
|
12
|
+
protected escapeId(identifier: string): string;
|
|
13
|
+
/**
|
|
14
|
+
* Introspect entire database schema and return SchemaAST.
|
|
15
|
+
*/
|
|
16
|
+
introspect(): Promise<SchemaAST>;
|
|
17
|
+
abstract getTableNames(): Promise<string[]>;
|
|
18
|
+
abstract getTableSchema(tableName: string): Promise<TableSchema | undefined>;
|
|
19
|
+
/**
|
|
20
|
+
* Build SchemaAST from table schemas.
|
|
21
|
+
*/
|
|
22
|
+
protected buildAST(tableSchemas: TableSchema[]): SchemaAST;
|
|
23
|
+
private buildTables;
|
|
24
|
+
private buildRelationships;
|
|
25
|
+
private buildIndexes;
|
|
26
|
+
private columnSchemaToCanonical;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=baseSqlIntrospector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseSqlIntrospector.d.ts","sourceRoot":"","sources":["../../../src/migrate/introspection/baseSqlIntrospector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,aAAa,EAAoB,MAAM,wBAAwB,CAAC;AAE9E,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAEtD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EAAgB,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAGzE;;GAEG;AACH,8BAAsB,mBAAmB;IAG3B,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,OAAO;IAF/C,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,aAAa,CAAC;gBAEV,OAAO,EAAE,OAAO;IAI/C,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM;IAG9C;;OAEG;IACG,UAAU,IAAI,OAAO,CAAC,SAAS,CAAC;IActC,QAAQ,CAAC,aAAa,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAC3C,QAAQ,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAE5E;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,WAAW,EAAE,GAAG,SAAS;IAW1D,OAAO,CAAC,WAAW;IAoCnB,OAAO,CAAC,kBAAkB;IA4B1B,OAAO,CAAC,YAAY;IAqBpB,OAAO,CAAC,uBAAuB;CAShC"}
|