@dsqlbase/migration 0.1.0 → 0.1.3
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 +21 -0
- package/dist/base.d.ts +87 -0
- package/dist/base.d.ts.map +1 -0
- package/dist/base.js +53 -0
- package/dist/base.js.map +1 -0
- package/dist/ddl/ast.d.ts +267 -0
- package/dist/ddl/ast.d.ts.map +1 -0
- package/dist/ddl/ast.js +10 -0
- package/dist/ddl/ast.js.map +1 -0
- package/dist/ddl/factory.d.ts +88 -0
- package/dist/ddl/factory.d.ts.map +1 -0
- package/dist/ddl/factory.js +186 -0
- package/dist/ddl/factory.js.map +1 -0
- package/dist/ddl/index.d.ts +5 -0
- package/dist/ddl/index.d.ts.map +1 -0
- package/dist/ddl/index.js +4 -0
- package/dist/ddl/index.js.map +1 -0
- package/dist/ddl/printer.d.ts +21 -0
- package/dist/ddl/printer.d.ts.map +1 -0
- package/dist/ddl/printer.js +278 -0
- package/dist/ddl/printer.js.map +1 -0
- package/dist/ddl/schema.d.ts +33 -0
- package/dist/ddl/schema.d.ts.map +1 -0
- package/dist/ddl/schema.js +133 -0
- package/dist/ddl/schema.js.map +1 -0
- package/dist/executor.d.ts +29 -0
- package/dist/executor.d.ts.map +1 -0
- package/dist/executor.js +93 -0
- package/dist/executor.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/introspection/introspect.d.ts +8 -0
- package/dist/introspection/introspect.d.ts.map +1 -0
- package/dist/introspection/introspect.js +14 -0
- package/dist/introspection/introspect.js.map +1 -0
- package/dist/introspection/normalizer.d.ts +96 -0
- package/dist/introspection/normalizer.d.ts.map +1 -0
- package/dist/introspection/normalizer.js +187 -0
- package/dist/introspection/normalizer.js.map +1 -0
- package/dist/introspection/query.d.ts +3 -0
- package/dist/introspection/query.d.ts.map +1 -0
- package/dist/introspection/query.js +284 -0
- package/dist/introspection/query.js.map +1 -0
- package/dist/reconciliation/diffs/base.d.ts +19 -0
- package/dist/reconciliation/diffs/base.d.ts.map +1 -0
- package/dist/reconciliation/diffs/base.js +58 -0
- package/dist/reconciliation/diffs/base.js.map +1 -0
- package/dist/reconciliation/diffs/column.d.ts +42 -0
- package/dist/reconciliation/diffs/column.d.ts.map +1 -0
- package/dist/reconciliation/diffs/column.js +48 -0
- package/dist/reconciliation/diffs/column.js.map +1 -0
- package/dist/reconciliation/diffs/constraint.d.ts +9 -0
- package/dist/reconciliation/diffs/constraint.d.ts.map +1 -0
- package/dist/reconciliation/diffs/constraint.js +122 -0
- package/dist/reconciliation/diffs/constraint.js.map +1 -0
- package/dist/reconciliation/diffs/domain.d.ts +17 -0
- package/dist/reconciliation/diffs/domain.d.ts.map +1 -0
- package/dist/reconciliation/diffs/domain.js +30 -0
- package/dist/reconciliation/diffs/domain.js.map +1 -0
- package/dist/reconciliation/diffs/indexes.d.ts +18 -0
- package/dist/reconciliation/diffs/indexes.d.ts.map +1 -0
- package/dist/reconciliation/diffs/indexes.js +59 -0
- package/dist/reconciliation/diffs/indexes.js.map +1 -0
- package/dist/reconciliation/diffs/sequence.d.ts +19 -0
- package/dist/reconciliation/diffs/sequence.d.ts.map +1 -0
- package/dist/reconciliation/diffs/sequence.js +17 -0
- package/dist/reconciliation/diffs/sequence.js.map +1 -0
- package/dist/reconciliation/diffs/table.d.ts +6 -0
- package/dist/reconciliation/diffs/table.d.ts.map +1 -0
- package/dist/reconciliation/diffs/table.js +52 -0
- package/dist/reconciliation/diffs/table.js.map +1 -0
- package/dist/reconciliation/operations/base.d.ts +54 -0
- package/dist/reconciliation/operations/base.d.ts.map +1 -0
- package/dist/reconciliation/operations/base.js +27 -0
- package/dist/reconciliation/operations/base.js.map +1 -0
- package/dist/reconciliation/operations/domain.d.ts +7 -0
- package/dist/reconciliation/operations/domain.d.ts.map +1 -0
- package/dist/reconciliation/operations/domain.js +88 -0
- package/dist/reconciliation/operations/domain.js.map +1 -0
- package/dist/reconciliation/operations/index.d.ts +6 -0
- package/dist/reconciliation/operations/index.d.ts.map +1 -0
- package/dist/reconciliation/operations/index.js +35 -0
- package/dist/reconciliation/operations/index.js.map +1 -0
- package/dist/reconciliation/operations/schema.d.ts +7 -0
- package/dist/reconciliation/operations/schema.d.ts.map +1 -0
- package/dist/reconciliation/operations/schema.js +41 -0
- package/dist/reconciliation/operations/schema.js.map +1 -0
- package/dist/reconciliation/operations/sequence.d.ts +7 -0
- package/dist/reconciliation/operations/sequence.d.ts.map +1 -0
- package/dist/reconciliation/operations/sequence.js +75 -0
- package/dist/reconciliation/operations/sequence.js.map +1 -0
- package/dist/reconciliation/operations/table.d.ts +9 -0
- package/dist/reconciliation/operations/table.d.ts.map +1 -0
- package/dist/reconciliation/operations/table.js +513 -0
- package/dist/reconciliation/operations/table.js.map +1 -0
- package/dist/reconciliation/planner.d.ts +3 -0
- package/dist/reconciliation/planner.d.ts.map +1 -0
- package/dist/reconciliation/planner.js +125 -0
- package/dist/reconciliation/planner.js.map +1 -0
- package/dist/reconciliation/reconcile.d.ts +22 -0
- package/dist/reconciliation/reconcile.d.ts.map +1 -0
- package/dist/reconciliation/reconcile.js +48 -0
- package/dist/reconciliation/reconcile.js.map +1 -0
- package/dist/runner.d.ts +41 -0
- package/dist/runner.d.ts.map +1 -0
- package/dist/runner.js +69 -0
- package/dist/runner.js.map +1 -0
- package/dist/validation/context.d.ts +32 -0
- package/dist/validation/context.d.ts.map +1 -0
- package/dist/validation/context.js +25 -0
- package/dist/validation/context.js.map +1 -0
- package/dist/validation/index.d.ts +3 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +2 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/rules/global.d.ts +5 -0
- package/dist/validation/rules/global.d.ts.map +1 -0
- package/dist/validation/rules/global.js +35 -0
- package/dist/validation/rules/global.js.map +1 -0
- package/dist/validation/rules/schema.d.ts +4 -0
- package/dist/validation/rules/schema.d.ts.map +1 -0
- package/dist/validation/rules/schema.js +12 -0
- package/dist/validation/rules/schema.js.map +1 -0
- package/dist/validation/rules/sequence.d.ts +4 -0
- package/dist/validation/rules/sequence.d.ts.map +1 -0
- package/dist/validation/rules/sequence.js +13 -0
- package/dist/validation/rules/sequence.js.map +1 -0
- package/dist/validation/rules/table.d.ts +12 -0
- package/dist/validation/rules/table.d.ts.map +1 -0
- package/dist/validation/rules/table.js +164 -0
- package/dist/validation/rules/table.js.map +1 -0
- package/dist/validation/validate.d.ts +13 -0
- package/dist/validation/validate.d.ts.map +1 -0
- package/dist/validation/validate.js +42 -0
- package/dist/validation/validate.js.map +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { identifierTooLong } from "./global.js";
|
|
2
|
+
export const tableNoPrimaryKey = (table, context) => {
|
|
3
|
+
const hasColumnPk = table.columns.some((col) => col.primaryKey);
|
|
4
|
+
const hasTablePk = table.constraints?.some((c) => c.kind === "PRIMARY_KEY_CONSTRAINT");
|
|
5
|
+
if (hasColumnPk || hasTablePk)
|
|
6
|
+
return;
|
|
7
|
+
context.report({
|
|
8
|
+
level: "error",
|
|
9
|
+
code: "TABLE_NO_PRIMARY_KEY",
|
|
10
|
+
message: `Table "${table.name}" has no primary key.`,
|
|
11
|
+
path: [table.namespace, table.name],
|
|
12
|
+
hint: `Mark a column with .primaryKey() or declare a composite primary key constraint.`,
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
export const unknownColumnReference = (table, context) => {
|
|
16
|
+
const columnNames = new Set(table.columns.map((c) => c.name));
|
|
17
|
+
for (const constraint of table.constraints ?? []) {
|
|
18
|
+
if (constraint.kind === "CHECK_CONSTRAINT")
|
|
19
|
+
continue;
|
|
20
|
+
for (const colName of constraint.columns) {
|
|
21
|
+
if (!columnNames.has(colName)) {
|
|
22
|
+
context.report({
|
|
23
|
+
level: "error",
|
|
24
|
+
code: "UNKNOWN_COLUMN_REFERENCE",
|
|
25
|
+
message: `Constraint "${constraint.name}" on table "${table.name}" references unknown column "${colName}".`,
|
|
26
|
+
path: [table.namespace, table.name, "constraints", constraint.name],
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
for (const colName of constraint.include ?? []) {
|
|
31
|
+
if (!columnNames.has(colName)) {
|
|
32
|
+
context.report({
|
|
33
|
+
level: "error",
|
|
34
|
+
code: "UNKNOWN_COLUMN_REFERENCE",
|
|
35
|
+
message: `Constraint "${constraint.name}" on table "${table.name}" includes unknown column "${colName}".`,
|
|
36
|
+
path: [table.namespace, table.name, "constraints", constraint.name],
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
for (const index of table.indexes ?? []) {
|
|
42
|
+
for (const ic of index.columns) {
|
|
43
|
+
if (!columnNames.has(ic.column)) {
|
|
44
|
+
context.report({
|
|
45
|
+
level: "error",
|
|
46
|
+
code: "UNKNOWN_COLUMN_REFERENCE",
|
|
47
|
+
message: `Index "${index.name}" on table "${table.name}" references unknown column "${ic.column}".`,
|
|
48
|
+
path: [table.namespace, table.name, "indexes", index.name],
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
for (const colName of index.include ?? []) {
|
|
53
|
+
if (!columnNames.has(colName)) {
|
|
54
|
+
context.report({
|
|
55
|
+
level: "error",
|
|
56
|
+
code: "UNKNOWN_COLUMN_REFERENCE",
|
|
57
|
+
message: `Index "${index.name}" on table "${table.name}" includes unknown column "${colName}".`,
|
|
58
|
+
path: [table.namespace, table.name, "indexes", index.name],
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
export const emptyConstraintColumns = (table, context) => {
|
|
65
|
+
for (const constraint of table.constraints ?? []) {
|
|
66
|
+
if (constraint.kind === "CHECK_CONSTRAINT")
|
|
67
|
+
continue;
|
|
68
|
+
if (constraint.columns.length === 0) {
|
|
69
|
+
context.report({
|
|
70
|
+
level: "error",
|
|
71
|
+
code: "EMPTY_CONSTRAINT_COLUMNS",
|
|
72
|
+
message: `Constraint "${constraint.name}" on table "${table.name}" has no columns.`,
|
|
73
|
+
path: [table.namespace, table.name, "constraints", constraint.name],
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
export const tableIdentifiersTooLong = (table, context) => {
|
|
79
|
+
for (const column of table.columns) {
|
|
80
|
+
identifierTooLong(column, context);
|
|
81
|
+
}
|
|
82
|
+
for (const index of table.indexes ?? []) {
|
|
83
|
+
identifierTooLong(index, context);
|
|
84
|
+
}
|
|
85
|
+
for (const constraint of table.constraints ?? []) {
|
|
86
|
+
identifierTooLong(constraint, context);
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
function pkColumns(table) {
|
|
90
|
+
const tablePk = table.constraints?.find((c) => c.kind === "PRIMARY_KEY_CONSTRAINT");
|
|
91
|
+
if (tablePk)
|
|
92
|
+
return [...tablePk.columns];
|
|
93
|
+
const columnPk = table.columns.filter((c) => c.primaryKey).map((c) => c.name);
|
|
94
|
+
return columnPk.length > 0 ? columnPk : null;
|
|
95
|
+
}
|
|
96
|
+
function sameColumnSet(a, b) {
|
|
97
|
+
if (a.length !== b.length)
|
|
98
|
+
return false;
|
|
99
|
+
const set = new Set(a);
|
|
100
|
+
return b.every((col) => set.has(col));
|
|
101
|
+
}
|
|
102
|
+
export const redundantUniqueOnPk = (table, context) => {
|
|
103
|
+
const pk = pkColumns(table);
|
|
104
|
+
if (!pk)
|
|
105
|
+
return;
|
|
106
|
+
for (const constraint of table.constraints ?? []) {
|
|
107
|
+
if (constraint.kind !== "UNIQUE_CONSTRAINT")
|
|
108
|
+
continue;
|
|
109
|
+
if (sameColumnSet(constraint.columns, pk)) {
|
|
110
|
+
context.report({
|
|
111
|
+
level: "warning",
|
|
112
|
+
code: "REDUNDANT_UNIQUE_ON_PK",
|
|
113
|
+
message: `UNIQUE constraint "${constraint.name}" covers the same columns as the primary key.`,
|
|
114
|
+
path: [table.namespace, table.name, "constraints", constraint.name],
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
for (const index of table.indexes ?? []) {
|
|
119
|
+
if (!index.unique)
|
|
120
|
+
continue;
|
|
121
|
+
const cols = index.columns.map((ic) => ic.column);
|
|
122
|
+
if (sameColumnSet(cols, pk)) {
|
|
123
|
+
context.report({
|
|
124
|
+
level: "warning",
|
|
125
|
+
code: "REDUNDANT_UNIQUE_ON_PK",
|
|
126
|
+
message: `Unique index "${index.name}" covers the same columns as the primary key.`,
|
|
127
|
+
path: [table.namespace, table.name, "indexes", index.name],
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
};
|
|
132
|
+
export const duplicateIndexCoverage = (table, context) => {
|
|
133
|
+
const indexes = table.indexes ?? [];
|
|
134
|
+
const seen = new Map();
|
|
135
|
+
for (const index of indexes) {
|
|
136
|
+
const key = index.columns.map((ic) => ic.column).join(",");
|
|
137
|
+
const prev = seen.get(key);
|
|
138
|
+
if (prev) {
|
|
139
|
+
context.report({
|
|
140
|
+
level: "warning",
|
|
141
|
+
code: "DUPLICATE_INDEX_COVERAGE",
|
|
142
|
+
message: `Index "${index.name}" covers the same columns as index "${prev}".`,
|
|
143
|
+
path: [table.namespace, table.name, "indexes", index.name],
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
seen.set(key, index.name);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
};
|
|
151
|
+
export const varcharWithoutLength = (table, context) => {
|
|
152
|
+
for (const column of table.columns) {
|
|
153
|
+
if (column.dataType === "varchar") {
|
|
154
|
+
context.report({
|
|
155
|
+
level: "warning",
|
|
156
|
+
code: "VARCHAR_WITHOUT_LENGTH",
|
|
157
|
+
message: `Column "${column.name}" on table "${table.name}" uses varchar without a length modifier.`,
|
|
158
|
+
path: [table.namespace, table.name, "columns", column.name],
|
|
159
|
+
hint: `Prefer varchar(n) with an explicit length, or use text.`,
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
};
|
|
164
|
+
//# sourceMappingURL=table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table.js","sourceRoot":"","sources":["../../../src/validation/rules/table.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { SerializedSchema } from "../base.js";
|
|
2
|
+
import { ValidationResult, ValidationRules } from "./context.js";
|
|
3
|
+
export declare const globalRules: readonly [import("./context.js").GlobalRule];
|
|
4
|
+
export declare const defaultRules: ValidationRules;
|
|
5
|
+
/**
|
|
6
|
+
* Validates a serialized schema definition against the expected structure and constraints.
|
|
7
|
+
*
|
|
8
|
+
* This function checks for the presence of required fields, correct data types, and adherence to any specified rules.
|
|
9
|
+
*
|
|
10
|
+
* @param definition Serialized schema definition
|
|
11
|
+
*/
|
|
12
|
+
export declare function validateDefinition<T extends SerializedSchema>(definition: T, rules?: ValidationRules): ValidationResult;
|
|
13
|
+
//# sourceMappingURL=validate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../../src/validation/validate.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,EAA2B,gBAAgB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAc1F,eAAO,MAAM,WAAW,8CAAmD,CAAC;AAE5E,eAAO,MAAM,YAAY,EAAE,eAchB,CAAC;AAEZ;;;;;;GAMG;AAEH,wBAAgB,kBAAkB,CAAC,CAAC,SAAS,gBAAgB,EAC3D,UAAU,EAAE,CAAC,EACb,KAAK,GAAE,eAA8B,GACpC,gBAAgB,CAgBlB"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { ValidationContext } from "./context.js";
|
|
2
|
+
import { identifierTooLong, noDuplicateObjectNames } from "./rules/global.js";
|
|
3
|
+
import { reservedNamespace } from "./rules/schema.js";
|
|
4
|
+
import { invalidSequenceCache } from "./rules/sequence.js";
|
|
5
|
+
import { duplicateIndexCoverage, emptyConstraintColumns, redundantUniqueOnPk, tableIdentifiersTooLong, tableNoPrimaryKey, unknownColumnReference, varcharWithoutLength, } from "./rules/table.js";
|
|
6
|
+
export const globalRules = Object.freeze([noDuplicateObjectNames]);
|
|
7
|
+
export const defaultRules = Object.freeze({
|
|
8
|
+
SCHEMA: [reservedNamespace],
|
|
9
|
+
DOMAIN: [identifierTooLong],
|
|
10
|
+
TABLE: [
|
|
11
|
+
tableNoPrimaryKey,
|
|
12
|
+
unknownColumnReference,
|
|
13
|
+
emptyConstraintColumns,
|
|
14
|
+
identifierTooLong,
|
|
15
|
+
tableIdentifiersTooLong,
|
|
16
|
+
redundantUniqueOnPk,
|
|
17
|
+
duplicateIndexCoverage,
|
|
18
|
+
varcharWithoutLength,
|
|
19
|
+
],
|
|
20
|
+
SEQUENCE: [identifierTooLong, invalidSequenceCache],
|
|
21
|
+
});
|
|
22
|
+
/**
|
|
23
|
+
* Validates a serialized schema definition against the expected structure and constraints.
|
|
24
|
+
*
|
|
25
|
+
* This function checks for the presence of required fields, correct data types, and adherence to any specified rules.
|
|
26
|
+
*
|
|
27
|
+
* @param definition Serialized schema definition
|
|
28
|
+
*/
|
|
29
|
+
export function validateDefinition(definition, rules = defaultRules) {
|
|
30
|
+
const context = new ValidationContext(definition);
|
|
31
|
+
for (const rule of globalRules) {
|
|
32
|
+
rule(definition, context);
|
|
33
|
+
}
|
|
34
|
+
for (const node of definition) {
|
|
35
|
+
const nodeRules = rules[node.kind] ?? [];
|
|
36
|
+
for (const rule of nodeRules) {
|
|
37
|
+
rule(node, context);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return context.getResults();
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=validate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.js","sourceRoot":"","sources":["../../src/validation/validate.ts"],"names":[],"mappings":"AAEA,OAAO,EAAQ,iBAAiB,EAAqC,MAAM,cAAc,CAAC;AAC1F,OAAO,EAAE,iBAAiB,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC9E,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EACL,sBAAsB,EACtB,sBAAsB,EACtB,mBAAmB,EACnB,uBAAuB,EACvB,iBAAiB,EACjB,sBAAsB,EACtB,oBAAoB,GACrB,MAAM,kBAAkB,CAAC;AAE1B,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,sBAAsB,CAAU,CAAC,CAAC;AAE5E,MAAM,CAAC,MAAM,YAAY,GAAoB,MAAM,CAAC,MAAM,CAAC;IACzD,MAAM,EAAE,CAAC,iBAAiB,CAAC;IAC3B,MAAM,EAAE,CAAC,iBAAiB,CAAC;IAC3B,KAAK,EAAE;QACL,iBAAiB;QACjB,sBAAsB;QACtB,sBAAsB;QACtB,iBAAiB;QACjB,uBAAuB;QACvB,mBAAmB;QACnB,sBAAsB;QACtB,oBAAoB;KACrB;IACD,QAAQ,EAAE,CAAC,iBAAiB,EAAE,oBAAoB,CAAC;CAC3C,CAAC,CAAC;AAEZ;;;;;;GAMG;AAEH,MAAM,UAAU,kBAAkB,CAChC,UAAa,EACb,QAAyB,YAAY;IAErC,MAAM,OAAO,GAAG,IAAI,iBAAiB,CAAC,UAAU,CAAC,CAAC;IAElD,KAAK,MAAM,IAAI,IAAI,WAAW,EAAE,CAAC;QAC/B,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IAC5B,CAAC;IAED,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;QAC9B,MAAM,SAAS,GAA2B,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QAEjE,KAAK,MAAM,IAAI,IAAI,SAAS,EAAE,CAAC;YAC7B,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACtB,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC,UAAU,EAAE,CAAC;AAC9B,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dsqlbase/migration",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.3",
|
|
4
4
|
"description": "Migration tools for DSQLBase",
|
|
5
5
|
"sideEffects": false,
|
|
6
6
|
"type": "module",
|
|
@@ -42,6 +42,6 @@
|
|
|
42
42
|
"lint": "eslint src --ext .ts"
|
|
43
43
|
},
|
|
44
44
|
"dependencies": {
|
|
45
|
-
"@dsqlbase/core": "^0.1.
|
|
45
|
+
"@dsqlbase/core": "^0.1.3"
|
|
46
46
|
}
|
|
47
47
|
}
|