@lyku/lockstep-pg 1.3.1 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -59
- package/package.json +31 -31
- package/pipeline.svg +1 -0
- package/src/buildTableIndexCommand.d.ts.map +1 -1
- package/src/buildTableIndexCommand.js +21 -6
- package/src/buildTableIndexCommand.js.map +1 -1
- package/src/buildTableTriggerCommands.d.ts +13 -1
- package/src/buildTableTriggerCommands.d.ts.map +1 -1
- package/src/buildTableTriggerCommands.js +33 -14
- package/src/buildTableTriggerCommands.js.map +1 -1
- package/src/createTable.d.ts.map +1 -1
- package/src/createTable.js +16 -2
- package/src/createTable.js.map +1 -1
- package/src/dateToPostgresString.js +2 -2
- package/src/dateToPostgresString.js.map +1 -1
- package/src/diff.d.ts +12 -0
- package/src/diff.d.ts.map +1 -1
- package/src/diff.js +113 -6
- package/src/diff.js.map +1 -1
- package/src/drift.d.ts +8 -11
- package/src/drift.d.ts.map +1 -1
- package/src/drift.js +1 -298
- package/src/drift.js.map +1 -1
- package/src/form.d.ts.map +1 -1
- package/src/form.js +43 -2
- package/src/form.js.map +1 -1
- package/src/generateSql.d.ts.map +1 -1
- package/src/generateSql.js +69 -8
- package/src/generateSql.js.map +1 -1
- package/src/index.d.ts +3 -3
- package/src/index.d.ts.map +1 -1
- package/src/index.js +2 -4
- package/src/index.js.map +1 -1
- package/src/introspect.d.ts +12 -0
- package/src/introspect.d.ts.map +1 -1
- package/src/introspect.js +195 -34
- package/src/introspect.js.map +1 -1
- package/src/mapColumnType.d.ts.map +1 -1
- package/src/mapColumnType.js +6 -0
- package/src/mapColumnType.js.map +1 -1
- package/src/mapSnowflakeType.d.ts +9 -0
- package/src/mapSnowflakeType.d.ts.map +1 -0
- package/src/mapSnowflakeType.js +19 -0
- package/src/mapSnowflakeType.js.map +1 -0
- package/src/migrate.d.ts +11 -9
- package/src/migrate.d.ts.map +1 -1
- package/src/migrate.js +28 -345
- package/src/migrate.js.map +1 -1
- package/src/seed.d.ts.map +1 -1
- package/src/seed.js +6 -1
- package/src/seed.js.map +1 -1
package/src/generateSql.js
CHANGED
|
@@ -47,9 +47,22 @@ function columnTypeToSql(col) {
|
|
|
47
47
|
case 'jsonb':
|
|
48
48
|
sql = 'JSONB';
|
|
49
49
|
break;
|
|
50
|
-
case 'array':
|
|
51
|
-
|
|
50
|
+
case 'array': {
|
|
51
|
+
const itemTypeMap = {
|
|
52
|
+
text: 'TEXT',
|
|
53
|
+
bigint: 'BIGINT',
|
|
54
|
+
integer: 'INTEGER',
|
|
55
|
+
smallint: 'SMALLINT',
|
|
56
|
+
boolean: 'BOOLEAN',
|
|
57
|
+
'double precision': 'DOUBLE PRECISION',
|
|
58
|
+
real: 'REAL',
|
|
59
|
+
};
|
|
60
|
+
const pgItemType = col.arrayItemType
|
|
61
|
+
? (itemTypeMap[col.arrayItemType] ?? col.arrayItemType.toUpperCase())
|
|
62
|
+
: null;
|
|
63
|
+
sql = pgItemType ? `${pgItemType}[]` : 'JSONB';
|
|
52
64
|
break;
|
|
65
|
+
}
|
|
53
66
|
case 'json':
|
|
54
67
|
sql = 'JSON';
|
|
55
68
|
break;
|
|
@@ -184,6 +197,13 @@ export function operationToSql(op) {
|
|
|
184
197
|
else {
|
|
185
198
|
toType = op.toType.toUpperCase();
|
|
186
199
|
castType = op.toType;
|
|
200
|
+
// Preserve length for fixed/variable char types — `CHAR` alone is char(1),
|
|
201
|
+
// which silently truncates (e.g. a char(6) hex color). Emit CHAR(6)/VARCHAR(n).
|
|
202
|
+
if (op.toLength != null &&
|
|
203
|
+
(op.toType === 'char' || op.toType === 'varchar')) {
|
|
204
|
+
toType = `${toType}(${op.toLength})`;
|
|
205
|
+
castType = `${castType}(${op.toLength})`;
|
|
206
|
+
}
|
|
187
207
|
}
|
|
188
208
|
return [
|
|
189
209
|
`-- WARNING: Type change from ${op.fromType} to ${op.toType} - verify data compatibility`,
|
|
@@ -215,6 +235,15 @@ export function operationToSql(op) {
|
|
|
215
235
|
}
|
|
216
236
|
case 'update_check_constraint': {
|
|
217
237
|
const constraintName = `${op.tableName}_${op.columnName}_check`;
|
|
238
|
+
// Never emit `CHECK (... IN ())` — an empty value set is invalid SQL and would
|
|
239
|
+
// reject every row. If the model has no enumerated values, drop the stale CHECK
|
|
240
|
+
// rather than generate a constraint nothing can satisfy.
|
|
241
|
+
if (op.newValues.length === 0) {
|
|
242
|
+
return [
|
|
243
|
+
`-- Drop CHECK constraint for "${op.columnName}" (model has no enumerated values): [${op.oldValues.join(', ')}] -> []`,
|
|
244
|
+
`ALTER TABLE "${op.tableName}" DROP CONSTRAINT IF EXISTS "${constraintName}";`,
|
|
245
|
+
];
|
|
246
|
+
}
|
|
218
247
|
const newValues = op.newValues.map((v) => `'${v}'`).join(', ');
|
|
219
248
|
return [
|
|
220
249
|
`-- Update CHECK constraint for "${op.columnName}": [${op.oldValues.join(', ')}] -> [${op.newValues.join(', ')}]`,
|
|
@@ -223,11 +252,21 @@ export function operationToSql(op) {
|
|
|
223
252
|
];
|
|
224
253
|
}
|
|
225
254
|
case 'add_index': {
|
|
226
|
-
const
|
|
255
|
+
const colSpecs = op.index.fullColumns ?? op.index.columns;
|
|
256
|
+
const idxCols = colSpecs
|
|
257
|
+
.map((c) => {
|
|
258
|
+
const parts = c.split(' ');
|
|
259
|
+
const colName = parts[0];
|
|
260
|
+
const modifiers = parts.slice(1).join(' ');
|
|
261
|
+
return modifiers ? `"${colName}" ${modifiers}` : `"${colName}"`;
|
|
262
|
+
})
|
|
263
|
+
.join(', ');
|
|
227
264
|
const unique = op.index.unique ? 'UNIQUE ' : '';
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
265
|
+
let sql = `CREATE ${unique}INDEX IF NOT EXISTS "${op.index.name}" ON "${op.tableName}" (${idxCols})`;
|
|
266
|
+
if (op.index.where) {
|
|
267
|
+
sql += ` WHERE ${op.index.where}`;
|
|
268
|
+
}
|
|
269
|
+
return [`${sql};`];
|
|
231
270
|
}
|
|
232
271
|
case 'drop_index':
|
|
233
272
|
return [`DROP INDEX IF EXISTS "${op.indexName}";`];
|
|
@@ -239,7 +278,9 @@ export function operationToSql(op) {
|
|
|
239
278
|
];
|
|
240
279
|
}
|
|
241
280
|
case 'drop_unique_constraint': {
|
|
242
|
-
|
|
281
|
+
// Prefer the real DB constraint name (e.g. "<table>_<col>_key"); the convention
|
|
282
|
+
// "<table>_<col>_unique" is only a fallback and often won't match the real name.
|
|
283
|
+
const constraintName = op.constraintName ?? `${op.tableName}_${op.columns.join('_')}_unique`;
|
|
243
284
|
return [
|
|
244
285
|
`ALTER TABLE "${op.tableName}" DROP CONSTRAINT IF EXISTS "${constraintName}";`,
|
|
245
286
|
];
|
|
@@ -254,6 +295,20 @@ export function operationToSql(op) {
|
|
|
254
295
|
return [
|
|
255
296
|
`ALTER TABLE "${op.tableName}" DROP CONSTRAINT IF EXISTS "${op.constraintName}";`,
|
|
256
297
|
];
|
|
298
|
+
case 'drop_sequence':
|
|
299
|
+
return [
|
|
300
|
+
`-- Orphaned sequence from bigserial → snowflake migration on "${op.tableName}"."${op.columnName}"`,
|
|
301
|
+
`DROP SEQUENCE IF EXISTS "${op.sequenceName}";`,
|
|
302
|
+
];
|
|
303
|
+
case 'create_sequence':
|
|
304
|
+
// The SET DEFAULT itself is emitted by the paired alter_column_default
|
|
305
|
+
// op that follows. Here we only ensure the sequence exists (and is
|
|
306
|
+
// owned by the column so it drops with it). IF NOT EXISTS makes this a
|
|
307
|
+
// no-op for normal serial columns whose sequence already exists.
|
|
308
|
+
return [
|
|
309
|
+
`CREATE SEQUENCE IF NOT EXISTS "${op.sequenceName}";`,
|
|
310
|
+
`ALTER SEQUENCE "${op.sequenceName}" OWNED BY "${op.tableName}"."${op.columnName}";`,
|
|
311
|
+
];
|
|
257
312
|
}
|
|
258
313
|
}
|
|
259
314
|
/**
|
|
@@ -269,7 +324,8 @@ export function generateMigrationSql(ops, _includeDestructive = false) {
|
|
|
269
324
|
op.type === 'drop_column' ||
|
|
270
325
|
op.type === 'drop_index' ||
|
|
271
326
|
op.type === 'drop_unique_constraint' ||
|
|
272
|
-
op.type === 'drop_foreign_key'
|
|
327
|
+
op.type === 'drop_foreign_key' ||
|
|
328
|
+
op.type === 'drop_sequence';
|
|
273
329
|
if (isDestructive) {
|
|
274
330
|
destructiveLines.push(...sql, '');
|
|
275
331
|
}
|
|
@@ -284,6 +340,10 @@ export function generateMigrationSql(ops, _includeDestructive = false) {
|
|
|
284
340
|
`-- Generated: ${timestamp}`,
|
|
285
341
|
'',
|
|
286
342
|
'BEGIN;',
|
|
343
|
+
// Make the migration self-sufficient regardless of the applying
|
|
344
|
+
// connection's search_path (e.g. an empty one — LYK-1213). The engine is
|
|
345
|
+
// public-scoped, so pin it for the transaction.
|
|
346
|
+
'SET LOCAL search_path TO public;',
|
|
287
347
|
'',
|
|
288
348
|
...safeLines,
|
|
289
349
|
'COMMIT;',
|
|
@@ -296,6 +356,7 @@ export function generateMigrationSql(ops, _includeDestructive = false) {
|
|
|
296
356
|
'-- WARNING: These operations will DELETE data!',
|
|
297
357
|
'',
|
|
298
358
|
'BEGIN;',
|
|
359
|
+
'SET LOCAL search_path TO public;',
|
|
299
360
|
'',
|
|
300
361
|
...destructiveLines,
|
|
301
362
|
'COMMIT;',
|
package/src/generateSql.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generateSql.js","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/generateSql.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"generateSql.js","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/generateSql.ts"],"names":[],"mappings":"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"}
|
package/src/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export {
|
|
2
|
-
export
|
|
3
|
-
export {
|
|
1
|
+
export type { DataformConfig } from './drift';
|
|
2
|
+
export { generateMigration } from './migrate';
|
|
3
|
+
export type { MigrationResult } from './migrate';
|
|
4
4
|
export { generateCreateTablesSql } from './form';
|
|
5
5
|
export { generateSeedSql } from './seed';
|
|
6
6
|
export { introspectTable, introspectDatabase, modelToIntrospected, normalizeDbType, } from './introspect';
|
package/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/index.ts"],"names":[],"mappings":"AACA,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/index.ts"],"names":[],"mappings":"AACA,YAAY,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAG9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAC9C,YAAY,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAGjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,QAAQ,CAAC;AAGjD,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAGzC,OAAO,EACN,eAAe,EACf,kBAAkB,EAClB,mBAAmB,EACnB,eAAe,GACf,MAAM,cAAc,CAAC;AACtB,YAAY,EACX,kBAAkB,EAClB,iBAAiB,EACjB,sBAAsB,EACtB,iBAAiB,GACjB,MAAM,cAAc,CAAC;AAGtB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAC;AACvE,YAAY,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAG5C,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAGrE,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
|
package/src/index.js
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
//
|
|
2
|
-
export {
|
|
3
|
-
// Migration generation (drift-based)
|
|
4
|
-
export { driftToSql, generateMigration } from './migrate';
|
|
1
|
+
// Migration generation — single engine: introspect → diffDatabase → generateMigrationSql
|
|
2
|
+
export { generateMigration } from './migrate';
|
|
5
3
|
// Table creation SQL
|
|
6
4
|
export { generateCreateTablesSql } from './form';
|
|
7
5
|
// Seed data generation
|
package/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/index.ts"],"names":[],"mappings":"AAGA,yFAAyF;AACzF,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAG9C,qBAAqB;AACrB,OAAO,EAAE,uBAAuB,EAAE,MAAM,QAAQ,CAAC;AAEjD,uBAAuB;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAEzC,gBAAgB;AAChB,OAAO,EACN,eAAe,EACf,kBAAkB,EAClB,mBAAmB,EACnB,eAAe,GACf,MAAM,cAAc,CAAC;AAQtB,cAAc;AACd,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAC;AAGvE,sCAAsC;AACtC,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAErE,wBAAwB;AACxB,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
|
package/src/introspect.d.ts
CHANGED
|
@@ -18,6 +18,9 @@ export interface IntrospectedIndex {
|
|
|
18
18
|
columns: string[];
|
|
19
19
|
unique: boolean;
|
|
20
20
|
definition: string;
|
|
21
|
+
where?: string;
|
|
22
|
+
/** Column specs with modifiers (e.g. "id DESC"), for SQL generation */
|
|
23
|
+
fullColumns?: string[];
|
|
21
24
|
}
|
|
22
25
|
export interface IntrospectedForeignKey {
|
|
23
26
|
column: string;
|
|
@@ -31,6 +34,15 @@ export interface IntrospectedTable {
|
|
|
31
34
|
indexes: IntrospectedIndex[];
|
|
32
35
|
primaryKey: string[];
|
|
33
36
|
uniqueConstraints: string[][];
|
|
37
|
+
/**
|
|
38
|
+
* DB-side unique constraints with their real Postgres names (undefined for the code/model
|
|
39
|
+
* side, which has no real names). Used so drop_unique_constraint can target the actual
|
|
40
|
+
* constraint (e.g. "<table>_<col>_key") instead of a reconstructed "<table>_<col>_unique".
|
|
41
|
+
*/
|
|
42
|
+
uniqueConstraintNames?: Array<{
|
|
43
|
+
name: string;
|
|
44
|
+
columns: string[];
|
|
45
|
+
}>;
|
|
34
46
|
foreignKeys: IntrospectedForeignKey[];
|
|
35
47
|
}
|
|
36
48
|
/**
|
package/src/introspect.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"introspect.d.ts","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/introspect.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAC;AAC5B,OAAO,KAAK,EACX,kBAAkB,EAClB,mBAAmB,EAEnB,MAAM,qBAAqB,CAAC;AAE7B,MAAM,WAAW,kBAAkB;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,OAAO,CAAC;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAC5B,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,MAAM,WAAW,iBAAiB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"introspect.d.ts","sourceRoot":"","sources":["../../../../libs/lockstep-pg/src/introspect.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAC;AAC5B,OAAO,KAAK,EACX,kBAAkB,EAClB,mBAAmB,EAEnB,MAAM,qBAAqB,CAAC;AAE7B,MAAM,WAAW,kBAAkB;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,OAAO,CAAC;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAC5B,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,MAAM,WAAW,iBAAiB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,uEAAuE;IACvE,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;CACvB;AAED,MAAM,WAAW,sBAAsB;IACtC,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,iBAAiB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC;IACzC,OAAO,EAAE,iBAAiB,EAAE,CAAC;IAC7B,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,iBAAiB,EAAE,MAAM,EAAE,EAAE,CAAC;IAC9B;;;;OAIG;IACH,qBAAqB,CAAC,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;IACnE,WAAW,EAAE,sBAAsB,EAAE,CAAC;CACtC;AA4DD;;GAEG;AACH,wBAAgB,eAAe,CAC9B,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,GACb;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,CAyDhD;AAuFD;;GAEG;AACH,wBAAsB,eAAe,CACpC,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,MAAM,GACf,OAAO,CAAC,iBAAiB,CAAC,CAsM5B;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CACvC,MAAM,EAAE,MAAM,GACZ,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAgBzC;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAClC,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,kBAAkB,CAAC,mBAAmB,CAAC,GAC5C,iBAAiB,CAwPnB"}
|
package/src/introspect.js
CHANGED
|
@@ -95,12 +95,58 @@ export function normalizeDbType(pgType, udtName) {
|
|
|
95
95
|
/**
|
|
96
96
|
* Extract enum values from a CHECK constraint clause
|
|
97
97
|
*/
|
|
98
|
+
/** Return the content of the first balanced parenthesised group, or null if none. */
|
|
99
|
+
function extractBalancedParenGroup(s) {
|
|
100
|
+
const start = s.indexOf('(');
|
|
101
|
+
if (start === -1)
|
|
102
|
+
return null;
|
|
103
|
+
let depth = 0;
|
|
104
|
+
for (let i = start; i < s.length; i++) {
|
|
105
|
+
const ch = s.charAt(i);
|
|
106
|
+
if (ch === '(')
|
|
107
|
+
depth++;
|
|
108
|
+
else if (ch === ')') {
|
|
109
|
+
depth--;
|
|
110
|
+
if (depth === 0)
|
|
111
|
+
return s.slice(start + 1, i);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
return null;
|
|
115
|
+
}
|
|
116
|
+
/** Split on top-level commas (commas not nested inside parentheses). */
|
|
117
|
+
function splitTopLevel(s) {
|
|
118
|
+
const parts = [];
|
|
119
|
+
let depth = 0;
|
|
120
|
+
let cur = '';
|
|
121
|
+
for (const ch of s) {
|
|
122
|
+
if (ch === '(')
|
|
123
|
+
depth++;
|
|
124
|
+
else if (ch === ')')
|
|
125
|
+
depth--;
|
|
126
|
+
if (ch === ',' && depth === 0) {
|
|
127
|
+
parts.push(cur);
|
|
128
|
+
cur = '';
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
cur += ch;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
if (cur.trim())
|
|
135
|
+
parts.push(cur);
|
|
136
|
+
return parts;
|
|
137
|
+
}
|
|
98
138
|
function extractEnumValues(checkClause) {
|
|
99
139
|
// Match patterns like:
|
|
100
140
|
// CHECK ((col = ANY (ARRAY['a'::text, 'b'::text])))
|
|
101
141
|
// CHECK (col IN ('a', 'b', 'c'))
|
|
102
142
|
// CHECK (("col" = ANY (ARRAY['a'::text, 'b'::text])))
|
|
103
|
-
|
|
143
|
+
// CHECK (("col" = 'a'::text)) -- Postgres collapses a single-value IN to equality.
|
|
144
|
+
// Match a true equality `= '` only — NOT comparisons like `>= '`, `<= '`, `!= '`
|
|
145
|
+
// (e.g. a numeric minimum `stock >= '-1'` must NOT be read as an enum).
|
|
146
|
+
const singleEquality = /(?:^|[^<>!])=\s*'/.test(checkClause);
|
|
147
|
+
if (!checkClause.includes(' IN (') &&
|
|
148
|
+
!checkClause.includes('ANY') &&
|
|
149
|
+
!singleEquality) {
|
|
104
150
|
return null;
|
|
105
151
|
}
|
|
106
152
|
const values = [];
|
|
@@ -156,9 +202,17 @@ export async function introspectTable(client, tableName) {
|
|
|
156
202
|
JOIN pg_attribute att ON att.attnum = ANY(con.conkey) AND att.attrelid = con.conrelid
|
|
157
203
|
WHERE con.conrelid = $1::regclass
|
|
158
204
|
AND con.contype = 'c'
|
|
159
|
-
`, [`"${tableName}"`]);
|
|
205
|
+
`, [`public."${tableName}"`]);
|
|
160
206
|
const checkConstraints = new Map();
|
|
161
207
|
for (const row of checkResult.rows) {
|
|
208
|
+
// A column can carry multiple CHECKs (e.g. an enum IN(...) plus a length check).
|
|
209
|
+
// Prefer the one that yields enum values so enumValues isn't lost to last-write-wins.
|
|
210
|
+
const existing = checkConstraints.get(row.column_name);
|
|
211
|
+
if (existing &&
|
|
212
|
+
extractEnumValues(existing.check_clause) &&
|
|
213
|
+
!extractEnumValues(row.check_clause)) {
|
|
214
|
+
continue;
|
|
215
|
+
}
|
|
162
216
|
checkConstraints.set(row.column_name, row);
|
|
163
217
|
}
|
|
164
218
|
// Build columns map
|
|
@@ -189,23 +243,35 @@ export async function introspectTable(client, tableName) {
|
|
|
189
243
|
// Parse index definition to extract columns
|
|
190
244
|
// Format: CREATE [UNIQUE] INDEX name ON table USING btree (col1, col2)
|
|
191
245
|
const isUnique = row.indexdef.includes('UNIQUE');
|
|
192
|
-
|
|
246
|
+
// Extract the index key list as a BALANCED paren group (the first '(' to its match),
|
|
247
|
+
// so expression indexes like (lower(email)) aren't truncated at the inner ')'.
|
|
248
|
+
const colsPart = extractBalancedParenGroup(row.indexdef);
|
|
193
249
|
const indexColumns = [];
|
|
194
|
-
if (
|
|
195
|
-
const colsPart
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
250
|
+
if (colsPart !== null) {
|
|
251
|
+
for (const part of splitTopLevel(colsPart)) {
|
|
252
|
+
const trimmed = part.trim();
|
|
253
|
+
// Leading identifier (optionally quoted); the !includes('(') guard below keeps
|
|
254
|
+
// expression indexes out of this branch, so trailing modifiers don't matter here.
|
|
255
|
+
const plain = trimmed.match(/^"?([A-Za-z_][A-Za-z0-9_]*)"?/);
|
|
256
|
+
if (plain && !trimmed.includes('(')) {
|
|
257
|
+
indexColumns.push(plain[1]);
|
|
258
|
+
}
|
|
259
|
+
else {
|
|
260
|
+
// Expression index, e.g. lower(email) — recover the first column identifier.
|
|
261
|
+
const inner = trimmed.match(/\(\s*"?([A-Za-z_][A-Za-z0-9_]*)"?/);
|
|
262
|
+
indexColumns.push(inner ? inner[1] : trimmed.replace(/"/g, '').split(' ')[0]);
|
|
263
|
+
}
|
|
202
264
|
}
|
|
203
265
|
}
|
|
266
|
+
// Capture the partial-index predicate (CREATE INDEX ... (col) WHERE (...)) so the diff
|
|
267
|
+
// can detect partial-index drift instead of silently dropping it.
|
|
268
|
+
const whereMatch = row.indexdef.match(/\bWHERE\b\s+(.+)$/i);
|
|
204
269
|
indexes.push({
|
|
205
270
|
name: row.indexname,
|
|
206
271
|
columns: indexColumns,
|
|
207
272
|
unique: isUnique,
|
|
208
273
|
definition: row.indexdef,
|
|
274
|
+
...(whereMatch ? { where: whereMatch[1].trim() } : {}),
|
|
209
275
|
});
|
|
210
276
|
}
|
|
211
277
|
// Get primary key
|
|
@@ -215,7 +281,7 @@ export async function introspectTable(client, tableName) {
|
|
|
215
281
|
JOIN pg_attribute a ON a.attrelid = i.indrelid AND a.attnum = ANY(i.indkey)
|
|
216
282
|
WHERE i.indrelid = $1::regclass AND i.indisprimary
|
|
217
283
|
ORDER BY array_position(i.indkey, a.attnum)
|
|
218
|
-
`, [`"${tableName}"`]);
|
|
284
|
+
`, [`public."${tableName}"`]);
|
|
219
285
|
const primaryKey = pkResult.rows.map((r) => r.column_name);
|
|
220
286
|
// Get unique constraints (excluding primary key)
|
|
221
287
|
const uniqueResult = await client.query(`
|
|
@@ -225,7 +291,7 @@ export async function introspectTable(client, tableName) {
|
|
|
225
291
|
WHERE con.conrelid = $1::regclass
|
|
226
292
|
AND con.contype = 'u'
|
|
227
293
|
ORDER BY con.conname, array_position(con.conkey, att.attnum)
|
|
228
|
-
`, [`"${tableName}"`]);
|
|
294
|
+
`, [`public."${tableName}"`]);
|
|
229
295
|
const uniqueByConstraint = new Map();
|
|
230
296
|
for (const row of uniqueResult.rows) {
|
|
231
297
|
const cols = uniqueByConstraint.get(row.constraint_name) ?? [];
|
|
@@ -233,6 +299,7 @@ export async function introspectTable(client, tableName) {
|
|
|
233
299
|
uniqueByConstraint.set(row.constraint_name, cols);
|
|
234
300
|
}
|
|
235
301
|
const uniqueConstraints = Array.from(uniqueByConstraint.values());
|
|
302
|
+
const uniqueConstraintNames = Array.from(uniqueByConstraint.entries()).map(([name, columns]) => ({ name, columns }));
|
|
236
303
|
// Get foreign key constraints
|
|
237
304
|
const fkResult = await client.query(`
|
|
238
305
|
SELECT
|
|
@@ -261,6 +328,7 @@ export async function introspectTable(client, tableName) {
|
|
|
261
328
|
indexes,
|
|
262
329
|
primaryKey,
|
|
263
330
|
uniqueConstraints,
|
|
331
|
+
uniqueConstraintNames,
|
|
264
332
|
foreignKeys,
|
|
265
333
|
};
|
|
266
334
|
}
|
|
@@ -291,12 +359,20 @@ export function modelToIntrospected(tableName, model) {
|
|
|
291
359
|
const columns = new Map();
|
|
292
360
|
if ('properties' in schema) {
|
|
293
361
|
const required = new Set('required' in schema ? schema.required : []);
|
|
294
|
-
|
|
362
|
+
// Managed (infra) columns live on the table model, not schema.properties, but are
|
|
363
|
+
// emitted into the DDL by buildTableCreationCommand — so the introspected model must
|
|
364
|
+
// include them too, else the diff sees them as extra DB columns and drops them
|
|
365
|
+
// (e.g. synced<T>'s `sequence`). They're nullable-with-default (never in `required`).
|
|
366
|
+
const managedCols = Object.entries((model.managedColumns ?? {}));
|
|
367
|
+
for (const [colName, colSchema] of [
|
|
368
|
+
...Object.entries(schema.properties),
|
|
369
|
+
...managedCols,
|
|
370
|
+
]) {
|
|
295
371
|
const col = colSchema;
|
|
296
372
|
let type = col.type;
|
|
297
373
|
let arrayItemType = null;
|
|
298
374
|
// Normalize type names
|
|
299
|
-
if (type === 'bigserial')
|
|
375
|
+
if (type === 'bigserial' || type === 'snowflake')
|
|
300
376
|
type = 'bigint';
|
|
301
377
|
if (type === 'serial')
|
|
302
378
|
type = 'integer';
|
|
@@ -314,8 +390,19 @@ export function modelToIntrospected(tableName, model) {
|
|
|
314
390
|
type = 'varchar';
|
|
315
391
|
if (type === 'character' || type === 'bpchar')
|
|
316
392
|
type = 'char';
|
|
317
|
-
// Enums are stored as text
|
|
318
|
-
|
|
393
|
+
// Enums are stored as text. Text columns with an enumerating pattern
|
|
394
|
+
// (^(a|b|c)$ — e.g. visibilityColumn) also carry their allowed values, so
|
|
395
|
+
// extract them too. Otherwise the diff sees the DB's real CHECK values vs the
|
|
396
|
+
// model's "no values" and tries to rewrite the constraint to an (invalid) empty set.
|
|
397
|
+
let enumValues = col.type === 'enum' && col.enum ? [...col.enum] : null;
|
|
398
|
+
if (enumValues === null &&
|
|
399
|
+
col.type === 'text' &&
|
|
400
|
+
'pattern' in col &&
|
|
401
|
+
typeof col.pattern === 'string') {
|
|
402
|
+
const patternMatch = col.pattern.match(/^\^\(([^)]+)\)\$$/);
|
|
403
|
+
if (patternMatch)
|
|
404
|
+
enumValues = patternMatch[1].split('|');
|
|
405
|
+
}
|
|
319
406
|
if (col.type === 'enum')
|
|
320
407
|
type = 'text';
|
|
321
408
|
if (col.type === 'array') {
|
|
@@ -342,18 +429,39 @@ export function modelToIntrospected(tableName, model) {
|
|
|
342
429
|
}
|
|
343
430
|
}
|
|
344
431
|
}
|
|
432
|
+
// serial/bigserial carry an implicit nextval() default from their backing sequence
|
|
433
|
+
// (Postgres names it "<table>_<col>_seq"); model it so the round-trip doesn't try to
|
|
434
|
+
// drop the sequence. normalizeDefault strips the ::regclass cast on both sides.
|
|
435
|
+
let defaultValue = null;
|
|
436
|
+
if ('default' in col && col.default !== undefined) {
|
|
437
|
+
const d = col.default;
|
|
438
|
+
if (typeof d === 'object' &&
|
|
439
|
+
d !== null &&
|
|
440
|
+
'sql' in d) {
|
|
441
|
+
defaultValue = d['sql'];
|
|
442
|
+
}
|
|
443
|
+
else if (typeof d === 'string') {
|
|
444
|
+
defaultValue = `'${d}'`;
|
|
445
|
+
}
|
|
446
|
+
else {
|
|
447
|
+
defaultValue = String(d);
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
else if (col.type === 'serial' || col.type === 'bigserial') {
|
|
451
|
+
const seq = `${tableName}_${colName}_seq`;
|
|
452
|
+
const quotedSeq = /[^a-z0-9_]/.test(seq) ? `"${seq}"` : seq;
|
|
453
|
+
defaultValue = `nextval('${quotedSeq}'::regclass)`;
|
|
454
|
+
}
|
|
345
455
|
columns.set(colName, {
|
|
346
456
|
name: colName,
|
|
347
457
|
type,
|
|
348
458
|
nullable: !required.has(colName),
|
|
349
|
-
default:
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
? col.
|
|
354
|
-
:
|
|
355
|
-
: null,
|
|
356
|
-
maxLength: 'maxLength' in col ? col.maxLength : null,
|
|
459
|
+
default: defaultValue,
|
|
460
|
+
maxLength: 'maxLength' in col
|
|
461
|
+
? col.maxLength
|
|
462
|
+
: 'length' in col
|
|
463
|
+
? col.length
|
|
464
|
+
: null,
|
|
357
465
|
checkConstraint: null, // We don't store the full clause
|
|
358
466
|
enumValues,
|
|
359
467
|
arrayItemType,
|
|
@@ -376,10 +484,41 @@ export function modelToIntrospected(tableName, model) {
|
|
|
376
484
|
}
|
|
377
485
|
else {
|
|
378
486
|
const objIdx = idx;
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
487
|
+
if (objIdx.raw !== undefined) {
|
|
488
|
+
// Expression / functional index. The diff matches it by name; recover the
|
|
489
|
+
// underlying columns from the raw SQL for the columns field (best-effort).
|
|
490
|
+
const recovered = splitTopLevel(objIdx.raw).map((part) => {
|
|
491
|
+
const t = part.trim();
|
|
492
|
+
const plain = t.match(/^"?([A-Za-z_][A-Za-z0-9_]*)"?/);
|
|
493
|
+
if (plain && !t.includes('('))
|
|
494
|
+
return plain[1];
|
|
495
|
+
const inner = t.match(/\(\s*"?([A-Za-z_][A-Za-z0-9_]*)"?/);
|
|
496
|
+
return inner ? inner[1] : t.replace(/"/g, '').split(' ')[0];
|
|
497
|
+
});
|
|
498
|
+
indexes.push({
|
|
499
|
+
name: objIdx.name ?? `idx_${tableName}_expr`,
|
|
500
|
+
columns: recovered,
|
|
501
|
+
unique: false,
|
|
502
|
+
definition: '',
|
|
503
|
+
...(objIdx.where ? { where: objIdx.where } : {}),
|
|
504
|
+
});
|
|
505
|
+
continue;
|
|
506
|
+
}
|
|
507
|
+
const rawCols = Array.isArray(objIdx.columns)
|
|
508
|
+
? objIdx.columns
|
|
509
|
+
: [objIdx.columns];
|
|
510
|
+
cols = rawCols.map((c) => c.split(' ')[0]);
|
|
382
511
|
name = objIdx.name ?? `idx_${tableName}_${cols.join('_')}`;
|
|
512
|
+
const hasModifiers = rawCols.some((c) => c.includes(' '));
|
|
513
|
+
indexes.push({
|
|
514
|
+
name,
|
|
515
|
+
columns: cols,
|
|
516
|
+
unique: false,
|
|
517
|
+
definition: '',
|
|
518
|
+
where: objIdx.where,
|
|
519
|
+
...(hasModifiers ? { fullColumns: rawCols } : {}),
|
|
520
|
+
});
|
|
521
|
+
continue;
|
|
383
522
|
}
|
|
384
523
|
indexes.push({
|
|
385
524
|
name,
|
|
@@ -395,18 +534,40 @@ export function modelToIntrospected(tableName, model) {
|
|
|
395
534
|
? model.primaryKey
|
|
396
535
|
: [model.primaryKey]
|
|
397
536
|
: [];
|
|
398
|
-
// Unique constraints
|
|
537
|
+
// Unique constraints. `unique` on a table model is a SINGLE constraint: either one
|
|
538
|
+
// column ('a') or one composite (['a','b']). A flat string[] is ONE composite — NOT
|
|
539
|
+
// one unique per column (that split was the bug behind phantom mutedUsers_userId_unique
|
|
540
|
+
// etc.). The legacy nested form ([['a','b'], ['c']] = multiple constraints) is also accepted.
|
|
399
541
|
const uniqueConstraints = [];
|
|
400
542
|
if (model.unique) {
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
543
|
+
const u = model.unique;
|
|
544
|
+
if (typeof u === 'string') {
|
|
545
|
+
uniqueConstraints.push([u]);
|
|
546
|
+
}
|
|
547
|
+
else if (Array.isArray(u)) {
|
|
548
|
+
if (u.every((x) => typeof x === 'string')) {
|
|
549
|
+
uniqueConstraints.push([...u]);
|
|
404
550
|
}
|
|
405
|
-
else
|
|
406
|
-
|
|
551
|
+
else {
|
|
552
|
+
for (const c of u) {
|
|
553
|
+
uniqueConstraints.push(typeof c === 'string' ? [c] : [...c]);
|
|
554
|
+
}
|
|
407
555
|
}
|
|
408
556
|
}
|
|
409
557
|
}
|
|
558
|
+
// Column-level `unique: true` — a single-column unique declared on the property itself.
|
|
559
|
+
// buildTableCreationCommand emits these as an inline UNIQUE, so the model's introspected
|
|
560
|
+
// form must report them too, else the round-trip sees a phantom drop_unique_constraint.
|
|
561
|
+
const props = 'properties' in schema
|
|
562
|
+
? schema.properties
|
|
563
|
+
: {};
|
|
564
|
+
for (const [colName, colSchema] of Object.entries(props)) {
|
|
565
|
+
if (colSchema &&
|
|
566
|
+
colSchema.unique === true &&
|
|
567
|
+
!uniqueConstraints.some((c) => c.length === 1 && c[0] === colName)) {
|
|
568
|
+
uniqueConstraints.push([colName]);
|
|
569
|
+
}
|
|
570
|
+
}
|
|
410
571
|
// Foreign keys — model format: { columnName: { referencedTable: referencedColumn } }
|
|
411
572
|
const foreignKeys = [];
|
|
412
573
|
if (model.foreignKeys) {
|