@dsqlbase/migration 0.1.0 → 0.1.2

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 (138) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/dist/base.d.ts +87 -0
  3. package/dist/base.d.ts.map +1 -0
  4. package/dist/base.js +53 -0
  5. package/dist/base.js.map +1 -0
  6. package/dist/ddl/ast.d.ts +267 -0
  7. package/dist/ddl/ast.d.ts.map +1 -0
  8. package/dist/ddl/ast.js +10 -0
  9. package/dist/ddl/ast.js.map +1 -0
  10. package/dist/ddl/factory.d.ts +88 -0
  11. package/dist/ddl/factory.d.ts.map +1 -0
  12. package/dist/ddl/factory.js +186 -0
  13. package/dist/ddl/factory.js.map +1 -0
  14. package/dist/ddl/index.d.ts +5 -0
  15. package/dist/ddl/index.d.ts.map +1 -0
  16. package/dist/ddl/index.js +4 -0
  17. package/dist/ddl/index.js.map +1 -0
  18. package/dist/ddl/printer.d.ts +21 -0
  19. package/dist/ddl/printer.d.ts.map +1 -0
  20. package/dist/ddl/printer.js +278 -0
  21. package/dist/ddl/printer.js.map +1 -0
  22. package/dist/ddl/schema.d.ts +33 -0
  23. package/dist/ddl/schema.d.ts.map +1 -0
  24. package/dist/ddl/schema.js +133 -0
  25. package/dist/ddl/schema.js.map +1 -0
  26. package/dist/executor.d.ts +29 -0
  27. package/dist/executor.d.ts.map +1 -0
  28. package/dist/executor.js +93 -0
  29. package/dist/executor.js.map +1 -0
  30. package/dist/index.d.ts +7 -0
  31. package/dist/index.d.ts.map +1 -0
  32. package/dist/index.js +7 -0
  33. package/dist/index.js.map +1 -0
  34. package/dist/introspection/introspect.d.ts +8 -0
  35. package/dist/introspection/introspect.d.ts.map +1 -0
  36. package/dist/introspection/introspect.js +14 -0
  37. package/dist/introspection/introspect.js.map +1 -0
  38. package/dist/introspection/normalizer.d.ts +96 -0
  39. package/dist/introspection/normalizer.d.ts.map +1 -0
  40. package/dist/introspection/normalizer.js +187 -0
  41. package/dist/introspection/normalizer.js.map +1 -0
  42. package/dist/introspection/query.d.ts +3 -0
  43. package/dist/introspection/query.d.ts.map +1 -0
  44. package/dist/introspection/query.js +284 -0
  45. package/dist/introspection/query.js.map +1 -0
  46. package/dist/reconciliation/diffs/base.d.ts +19 -0
  47. package/dist/reconciliation/diffs/base.d.ts.map +1 -0
  48. package/dist/reconciliation/diffs/base.js +58 -0
  49. package/dist/reconciliation/diffs/base.js.map +1 -0
  50. package/dist/reconciliation/diffs/column.d.ts +42 -0
  51. package/dist/reconciliation/diffs/column.d.ts.map +1 -0
  52. package/dist/reconciliation/diffs/column.js +48 -0
  53. package/dist/reconciliation/diffs/column.js.map +1 -0
  54. package/dist/reconciliation/diffs/constraint.d.ts +9 -0
  55. package/dist/reconciliation/diffs/constraint.d.ts.map +1 -0
  56. package/dist/reconciliation/diffs/constraint.js +122 -0
  57. package/dist/reconciliation/diffs/constraint.js.map +1 -0
  58. package/dist/reconciliation/diffs/domain.d.ts +17 -0
  59. package/dist/reconciliation/diffs/domain.d.ts.map +1 -0
  60. package/dist/reconciliation/diffs/domain.js +30 -0
  61. package/dist/reconciliation/diffs/domain.js.map +1 -0
  62. package/dist/reconciliation/diffs/indexes.d.ts +18 -0
  63. package/dist/reconciliation/diffs/indexes.d.ts.map +1 -0
  64. package/dist/reconciliation/diffs/indexes.js +59 -0
  65. package/dist/reconciliation/diffs/indexes.js.map +1 -0
  66. package/dist/reconciliation/diffs/sequence.d.ts +19 -0
  67. package/dist/reconciliation/diffs/sequence.d.ts.map +1 -0
  68. package/dist/reconciliation/diffs/sequence.js +17 -0
  69. package/dist/reconciliation/diffs/sequence.js.map +1 -0
  70. package/dist/reconciliation/diffs/table.d.ts +6 -0
  71. package/dist/reconciliation/diffs/table.d.ts.map +1 -0
  72. package/dist/reconciliation/diffs/table.js +52 -0
  73. package/dist/reconciliation/diffs/table.js.map +1 -0
  74. package/dist/reconciliation/operations/base.d.ts +54 -0
  75. package/dist/reconciliation/operations/base.d.ts.map +1 -0
  76. package/dist/reconciliation/operations/base.js +27 -0
  77. package/dist/reconciliation/operations/base.js.map +1 -0
  78. package/dist/reconciliation/operations/domain.d.ts +7 -0
  79. package/dist/reconciliation/operations/domain.d.ts.map +1 -0
  80. package/dist/reconciliation/operations/domain.js +88 -0
  81. package/dist/reconciliation/operations/domain.js.map +1 -0
  82. package/dist/reconciliation/operations/index.d.ts +6 -0
  83. package/dist/reconciliation/operations/index.d.ts.map +1 -0
  84. package/dist/reconciliation/operations/index.js +35 -0
  85. package/dist/reconciliation/operations/index.js.map +1 -0
  86. package/dist/reconciliation/operations/schema.d.ts +7 -0
  87. package/dist/reconciliation/operations/schema.d.ts.map +1 -0
  88. package/dist/reconciliation/operations/schema.js +41 -0
  89. package/dist/reconciliation/operations/schema.js.map +1 -0
  90. package/dist/reconciliation/operations/sequence.d.ts +7 -0
  91. package/dist/reconciliation/operations/sequence.d.ts.map +1 -0
  92. package/dist/reconciliation/operations/sequence.js +75 -0
  93. package/dist/reconciliation/operations/sequence.js.map +1 -0
  94. package/dist/reconciliation/operations/table.d.ts +9 -0
  95. package/dist/reconciliation/operations/table.d.ts.map +1 -0
  96. package/dist/reconciliation/operations/table.js +513 -0
  97. package/dist/reconciliation/operations/table.js.map +1 -0
  98. package/dist/reconciliation/planner.d.ts +3 -0
  99. package/dist/reconciliation/planner.d.ts.map +1 -0
  100. package/dist/reconciliation/planner.js +125 -0
  101. package/dist/reconciliation/planner.js.map +1 -0
  102. package/dist/reconciliation/reconcile.d.ts +22 -0
  103. package/dist/reconciliation/reconcile.d.ts.map +1 -0
  104. package/dist/reconciliation/reconcile.js +48 -0
  105. package/dist/reconciliation/reconcile.js.map +1 -0
  106. package/dist/runner.d.ts +41 -0
  107. package/dist/runner.d.ts.map +1 -0
  108. package/dist/runner.js +69 -0
  109. package/dist/runner.js.map +1 -0
  110. package/dist/validation/context.d.ts +32 -0
  111. package/dist/validation/context.d.ts.map +1 -0
  112. package/dist/validation/context.js +25 -0
  113. package/dist/validation/context.js.map +1 -0
  114. package/dist/validation/index.d.ts +3 -0
  115. package/dist/validation/index.d.ts.map +1 -0
  116. package/dist/validation/index.js +2 -0
  117. package/dist/validation/index.js.map +1 -0
  118. package/dist/validation/rules/global.d.ts +5 -0
  119. package/dist/validation/rules/global.d.ts.map +1 -0
  120. package/dist/validation/rules/global.js +35 -0
  121. package/dist/validation/rules/global.js.map +1 -0
  122. package/dist/validation/rules/schema.d.ts +4 -0
  123. package/dist/validation/rules/schema.d.ts.map +1 -0
  124. package/dist/validation/rules/schema.js +12 -0
  125. package/dist/validation/rules/schema.js.map +1 -0
  126. package/dist/validation/rules/sequence.d.ts +4 -0
  127. package/dist/validation/rules/sequence.d.ts.map +1 -0
  128. package/dist/validation/rules/sequence.js +13 -0
  129. package/dist/validation/rules/sequence.js.map +1 -0
  130. package/dist/validation/rules/table.d.ts +12 -0
  131. package/dist/validation/rules/table.d.ts.map +1 -0
  132. package/dist/validation/rules/table.js +164 -0
  133. package/dist/validation/rules/table.js.map +1 -0
  134. package/dist/validation/validate.d.ts +13 -0
  135. package/dist/validation/validate.d.ts.map +1 -0
  136. package/dist/validation/validate.js +42 -0
  137. package/dist/validation/validate.js.map +1 -0
  138. 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.0",
3
+ "version": "0.1.2",
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.0"
45
+ "@dsqlbase/core": "^0.1.2"
46
46
  }
47
47
  }