pipework 0.7.20 → 0.7.22
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 +26 -0
- package/REFERENCE.md +66 -2
- package/dist/REFERENCE.md +66 -2
- package/dist/cli/commands/check.js +10 -10
- package/dist/cli/commands/check.js.map +1 -1
- package/dist/cli/commands/test.d.ts.map +1 -1
- package/dist/cli/commands/test.js +2 -1
- package/dist/cli/commands/test.js.map +1 -1
- package/dist/core/config/discover.d.ts +1 -0
- package/dist/core/config/discover.d.ts.map +1 -1
- package/dist/core/config/discover.js +1 -1
- package/dist/core/config/discover.js.map +1 -1
- package/dist/data/db/advisory-lock.d.ts +6 -1
- package/dist/data/db/advisory-lock.d.ts.map +1 -1
- package/dist/data/db/advisory-lock.js +20 -7
- package/dist/data/db/advisory-lock.js.map +1 -1
- package/dist/data/db/bulk-set.d.ts.map +1 -1
- package/dist/data/db/bulk-set.js +12 -20
- package/dist/data/db/bulk-set.js.map +1 -1
- package/dist/data/db/composed.d.ts +23 -0
- package/dist/data/db/composed.d.ts.map +1 -0
- package/dist/data/db/composed.js +42 -0
- package/dist/data/db/composed.js.map +1 -0
- package/dist/data/db/expressions.d.ts +32 -0
- package/dist/data/db/expressions.d.ts.map +1 -1
- package/dist/data/db/expressions.js +67 -0
- package/dist/data/db/expressions.js.map +1 -1
- package/dist/data/db/filter.d.ts +22 -1
- package/dist/data/db/filter.d.ts.map +1 -1
- package/dist/data/db/filter.js +22 -1
- package/dist/data/db/filter.js.map +1 -1
- package/dist/data/db/namespace.d.ts +26 -0
- package/dist/data/db/namespace.d.ts.map +1 -1
- package/dist/data/db/namespace.js +6 -0
- package/dist/data/db/namespace.js.map +1 -1
- package/dist/data/db/serializable.d.ts +8 -0
- package/dist/data/db/serializable.d.ts.map +1 -0
- package/dist/data/db/serializable.js +44 -0
- package/dist/data/db/serializable.js.map +1 -0
- package/dist/data/db/values.d.ts +10 -0
- package/dist/data/db/values.d.ts.map +1 -0
- package/dist/data/db/values.js +20 -0
- package/dist/data/db/values.js.map +1 -0
- package/dist/data/jsonb/composed.d.ts +8 -0
- package/dist/data/jsonb/composed.d.ts.map +1 -0
- package/dist/data/jsonb/composed.js +15 -0
- package/dist/data/jsonb/composed.js.map +1 -0
- package/dist/data/jsonb/namespace.d.ts +12 -1
- package/dist/data/jsonb/namespace.d.ts.map +1 -1
- package/dist/data/jsonb/namespace.js +12 -1
- package/dist/data/jsonb/namespace.js.map +1 -1
- package/dist/data/jsonb/query.d.ts +4 -0
- package/dist/data/jsonb/query.d.ts.map +1 -1
- package/dist/data/jsonb/query.js +21 -0
- package/dist/data/jsonb/query.js.map +1 -1
- package/dist/data/temporal/close.d.ts.map +1 -1
- package/dist/data/temporal/close.js +3 -2
- package/dist/data/temporal/close.js.map +1 -1
- package/dist/data/temporal/get-current.d.ts.map +1 -1
- package/dist/data/temporal/get-current.js +2 -1
- package/dist/data/temporal/get-current.js.map +1 -1
- package/dist/data/temporal/revise.d.ts.map +1 -1
- package/dist/data/temporal/revise.js +8 -11
- package/dist/data/temporal/revise.js.map +1 -1
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/test/vitest-workspace.d.ts.map +1 -1
- package/dist/test/vitest-workspace.js +2 -1
- package/dist/test/vitest-workspace.js.map +1 -1
- package/dist/workspace/generate.d.ts +1 -1
- package/dist/workspace/generate.d.ts.map +1 -1
- package/dist/workspace/generate.js +12 -6
- package/dist/workspace/generate.js.map +1 -1
- package/dist/workspace/index.d.ts +1 -1
- package/dist/workspace/index.d.ts.map +1 -1
- package/dist/workspace/index.js +1 -1
- package/dist/workspace/index.js.map +1 -1
- package/package.json +24 -16
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"composed.js","sourceRoot":"","sources":["../../../src/data/db/composed.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAC7F,OAAO,EAAE,GAAG,EAAE,MAAM,sCAAsC,CAAA;AAK1D,kFAAkF;AAClF,MAAM,UAAU,GAAG,CAAC,MAAc,EAAE,IAAkB;IACpD,OAAO,QAAQ,CAAO,GAAG,EAAE,EAAE,QAAQ,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAA;AACtD,CAAC;AAED,0CAA0C;AAC1C,MAAM,UAAU,QAAQ,CAAC,UAAqC;IAC5D,OAAO,IAAI,CAAS,UAAU,EAAE,MAAM,CAAC,CAAA;AACzC,CAAC;AAED,2CAA2C;AAC3C,MAAM,UAAU,SAAS,CAAC,UAAqC;IAC7D,OAAO,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAA;AAClC,CAAC;AAED,iDAAiD;AACjD,MAAM,UAAU,aAAa,CAAC,UAAqC;IACjE,OAAO,IAAI,CAAO,UAAU,EAAE,aAAa,CAAC,CAAA;AAC9C,CAAC;AAED,6CAA6C;AAC7C,MAAM,UAAU,WAAW,CAAC,UAAqC;IAC/D,OAAO,IAAI,CAAU,UAAU,EAAE,SAAS,CAAC,CAAA;AAC7C,CAAC;AAED,6CAA6C;AAC7C,MAAM,UAAU,WAAW,CAAC,UAAqC;IAC/D,OAAO,IAAI,CAAS,UAAU,EAAE,SAAS,CAAC,CAAA;AAC5C,CAAC;AAED,6CAA6C;AAC7C,MAAM,UAAU,WAAW,CAAC,UAAqC;IAC/D,OAAO,IAAI,CAAS,UAAU,EAAE,SAAS,CAAC,CAAA;AAC5C,CAAC;AAED,0CAA0C;AAC1C,MAAM,UAAU,QAAQ,CAAC,UAAqC;IAC5D,OAAO,IAAI,CAAS,UAAU,EAAE,MAAM,CAAC,CAAA;AACzC,CAAC;AAED,qHAAqH;AACrH,MAAM,UAAU,YAAY,CAAC,EAAM,EAAE,MAAc,EAAE,KAAW;IAC9D,8HAA8H;IAC9H,MAAM,IAAI,GAAI,EAAU,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IACtE,MAAM,QAAQ,GAAG,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IAC/D,OAAO,SAAS,CAAC,QAAQ,CAAS,MAAM,CAAS,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;AACpE,CAAC"}
|
|
@@ -4,10 +4,42 @@ import type { SQLWrapper } from '../query/sql/sql.js';
|
|
|
4
4
|
export declare function increment(column: Column | SQL, amount: number): SQL<number>;
|
|
5
5
|
/** Returns `column - amount`. Convenience wrapper — equivalent to `increment(column, -amount)`. */
|
|
6
6
|
export declare function decrement(column: Column | SQL, amount: number): SQL<number>;
|
|
7
|
+
/** Returns `left + right` for two SQL expressions. For column + literal number, use `increment`. */
|
|
8
|
+
export declare function add<T = unknown>(left: Column | SQL, right: Column | SQL): SQL<T>;
|
|
9
|
+
/** Returns `left - right` for two SQL expressions. For column - literal number, use `decrement`. */
|
|
10
|
+
export declare function subtract<T = unknown>(left: Column | SQL, right: Column | SQL): SQL<T>;
|
|
7
11
|
/** Wraps an expression with COALESCE — returns `defaultValue` when the expression is NULL. */
|
|
8
12
|
export declare function coalesce<T>(expression: SQL | Column, defaultValue: T): SQL<T>;
|
|
9
13
|
/** Returns a SQL expression for PostgreSQL `now()` — the current transaction timestamp. */
|
|
10
14
|
export declare function now(): SQL<Date>;
|
|
11
15
|
/** Wraps a select query as a scalar subquery expression, usable in `.values()` and `.set()`. */
|
|
12
16
|
export declare function scalar<T>(subquery: SQLWrapper): SQL<T>;
|
|
17
|
+
type IntervalUnit = 'microseconds' | 'milliseconds' | 'seconds' | 'minutes' | 'hours' | 'days' | 'weeks' | 'months' | 'years';
|
|
18
|
+
/** PostgreSQL type cast: `expression::pgType`. */
|
|
19
|
+
export declare function cast<T = unknown>(expression: SQL | Column | SQLWrapper, pgType: string): SQL<T>;
|
|
20
|
+
/** PostgreSQL interval literal: `interval '5 minutes'`. */
|
|
21
|
+
export declare function interval(amount: number, unit: IntervalUnit): SQL;
|
|
22
|
+
/** PostgreSQL `date_trunc('unit', column)` — truncates a timestamp to the given precision. */
|
|
23
|
+
export declare function dateTrunc(unit: 'microseconds' | 'milliseconds' | 'second' | 'minute' | 'hour' | 'day' | 'week' | 'month' | 'quarter' | 'year' | 'decade' | 'century' | 'millennium', column: Column | SQL): SQL<Date>;
|
|
24
|
+
/** PostgreSQL `ROW_NUMBER()` window function. Use with `over()` to apply a window specification. */
|
|
25
|
+
export declare function rowNumber(): SQL<number>;
|
|
26
|
+
/** PostgreSQL `RANK()` window function. Use with `over()` to apply a window specification. */
|
|
27
|
+
export declare function rank(): SQL<number>;
|
|
28
|
+
/** PostgreSQL `DENSE_RANK()` window function. Use with `over()` to apply a window specification. */
|
|
29
|
+
export declare function denseRank(): SQL<number>;
|
|
30
|
+
export interface WindowSpec {
|
|
31
|
+
readonly partitionBy?: Column | SQL | ReadonlyArray<Column | SQL>;
|
|
32
|
+
readonly orderBy?: SQL | ReadonlyArray<SQL>;
|
|
33
|
+
}
|
|
34
|
+
/** Applies a window specification to a window function or aggregate: `fn OVER (PARTITION BY ... ORDER BY ...)`. */
|
|
35
|
+
export declare function over<T>(fn: SQL<T>, spec: WindowSpec): SQL<T>;
|
|
36
|
+
/** PostgreSQL quoted identifier: `"name"`. Promotes `sql.identifier` to a base primitive. */
|
|
37
|
+
export declare function identifier(name: string): SQL;
|
|
38
|
+
/** PostgreSQL `WITH RECURSIVE alias AS (seed UNION ALL step) finalQuery`. If `finalQuery` is omitted, defaults to `SELECT * FROM alias`. */
|
|
39
|
+
export declare function withRecursive(alias: string, seed: SQL, step: SQL, finalQuery?: SQL): SQL;
|
|
40
|
+
/** PostgreSQL `pg_current_wal_lsn()` — returns the current WAL write position on the primary. Internal primitive for replica-aware job execution. */
|
|
41
|
+
export declare function walCurrentLsn(): SQL<string>;
|
|
42
|
+
/** PostgreSQL `pg_last_wal_replay_lsn()` — returns the last replayed WAL position on a replica. Returns NULL on the primary. Internal primitive for replica-aware job execution. */
|
|
43
|
+
export declare function walReplayLsn(): SQL<string>;
|
|
44
|
+
export {};
|
|
13
45
|
//# sourceMappingURL=expressions.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"expressions.d.ts","sourceRoot":"","sources":["../../../src/data/db/expressions.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AAC7C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAErD,uEAAuE;AACvE,wBAAgB,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,MAAM,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAE3E;AAED,mGAAmG;AACnG,wBAAgB,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,MAAM,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAE3E;AAED,8FAA8F;AAC9F,wBAAgB,QAAQ,CAAC,CAAC,EAAE,UAAU,EAAE,GAAG,GAAG,MAAM,EAAE,YAAY,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAE7E;AAED,2FAA2F;AAC3F,wBAAgB,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAE/B;AAED,gGAAgG;AAChG,wBAAgB,MAAM,CAAC,CAAC,EAAE,QAAQ,EAAE,UAAU,GAAG,GAAG,CAAC,CAAC,CAAC,CAEtD"}
|
|
1
|
+
{"version":3,"file":"expressions.d.ts","sourceRoot":"","sources":["../../../src/data/db/expressions.ts"],"names":[],"mappings":"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"}
|
|
@@ -7,6 +7,14 @@ export function increment(column, amount) {
|
|
|
7
7
|
export function decrement(column, amount) {
|
|
8
8
|
return sql `${column} - ${amount}`;
|
|
9
9
|
}
|
|
10
|
+
/** Returns `left + right` for two SQL expressions. For column + literal number, use `increment`. */
|
|
11
|
+
export function add(left, right) {
|
|
12
|
+
return sql `${left} + ${right}`;
|
|
13
|
+
}
|
|
14
|
+
/** Returns `left - right` for two SQL expressions. For column - literal number, use `decrement`. */
|
|
15
|
+
export function subtract(left, right) {
|
|
16
|
+
return sql `${left} - ${right}`;
|
|
17
|
+
}
|
|
10
18
|
/** Wraps an expression with COALESCE — returns `defaultValue` when the expression is NULL. */
|
|
11
19
|
export function coalesce(expression, defaultValue) {
|
|
12
20
|
return sql `coalesce(${expression}, ${defaultValue})`;
|
|
@@ -19,4 +27,63 @@ export function now() {
|
|
|
19
27
|
export function scalar(subquery) {
|
|
20
28
|
return sql `(${subquery})`;
|
|
21
29
|
}
|
|
30
|
+
/** PostgreSQL type cast: `expression::pgType`. */
|
|
31
|
+
export function cast(expression, pgType) {
|
|
32
|
+
return sql `(${expression})::${sql.raw(pgType)}`;
|
|
33
|
+
}
|
|
34
|
+
/** PostgreSQL interval literal: `interval '5 minutes'`. */
|
|
35
|
+
export function interval(amount, unit) {
|
|
36
|
+
return sql `interval '${sql.raw(String(amount))} ${sql.raw(unit)}'`;
|
|
37
|
+
}
|
|
38
|
+
/** PostgreSQL `date_trunc('unit', column)` — truncates a timestamp to the given precision. */
|
|
39
|
+
export function dateTrunc(unit, column) {
|
|
40
|
+
return sql `date_trunc('${sql.raw(unit)}', ${column})`;
|
|
41
|
+
}
|
|
42
|
+
/** PostgreSQL `ROW_NUMBER()` window function. Use with `over()` to apply a window specification. */
|
|
43
|
+
export function rowNumber() {
|
|
44
|
+
return sql `row_number()`;
|
|
45
|
+
}
|
|
46
|
+
/** PostgreSQL `RANK()` window function. Use with `over()` to apply a window specification. */
|
|
47
|
+
export function rank() {
|
|
48
|
+
return sql `rank()`;
|
|
49
|
+
}
|
|
50
|
+
/** PostgreSQL `DENSE_RANK()` window function. Use with `over()` to apply a window specification. */
|
|
51
|
+
export function denseRank() {
|
|
52
|
+
return sql `dense_rank()`;
|
|
53
|
+
}
|
|
54
|
+
/** Applies a window specification to a window function or aggregate: `fn OVER (PARTITION BY ... ORDER BY ...)`. */
|
|
55
|
+
export function over(fn, spec) {
|
|
56
|
+
const parts = [];
|
|
57
|
+
if (spec.partitionBy !== undefined) {
|
|
58
|
+
const cols = Array.isArray(spec.partitionBy) ? spec.partitionBy : [spec.partitionBy];
|
|
59
|
+
parts.push(sql `partition by ${sql.join(cols.map(c => sql `${c}`), sql `, `)}`);
|
|
60
|
+
}
|
|
61
|
+
if (spec.orderBy !== undefined) {
|
|
62
|
+
const cols = Array.isArray(spec.orderBy) ? spec.orderBy : [spec.orderBy];
|
|
63
|
+
parts.push(sql `order by ${sql.join(cols, sql `, `)}`);
|
|
64
|
+
}
|
|
65
|
+
if (parts.length === 0)
|
|
66
|
+
return sql `${fn} over ()`;
|
|
67
|
+
return sql `${fn} over (${sql.join(parts, sql ` `)})`;
|
|
68
|
+
}
|
|
69
|
+
/** PostgreSQL quoted identifier: `"name"`. Promotes `sql.identifier` to a base primitive. */
|
|
70
|
+
export function identifier(name) {
|
|
71
|
+
return sql `${sql.identifier(name)}`;
|
|
72
|
+
}
|
|
73
|
+
/** PostgreSQL `WITH RECURSIVE alias AS (seed UNION ALL step) finalQuery`. If `finalQuery` is omitted, defaults to `SELECT * FROM alias`. */
|
|
74
|
+
export function withRecursive(alias, seed, step, finalQuery) {
|
|
75
|
+
const cte = sql `WITH RECURSIVE ${sql.identifier(alias)} AS (${seed} UNION ALL ${step})`;
|
|
76
|
+
if (finalQuery !== undefined) {
|
|
77
|
+
return sql `${cte} ${finalQuery}`;
|
|
78
|
+
}
|
|
79
|
+
return sql `${cte} SELECT * FROM ${sql.identifier(alias)}`;
|
|
80
|
+
}
|
|
81
|
+
/** PostgreSQL `pg_current_wal_lsn()` — returns the current WAL write position on the primary. Internal primitive for replica-aware job execution. */
|
|
82
|
+
export function walCurrentLsn() {
|
|
83
|
+
return sql `pg_current_wal_lsn()::text`;
|
|
84
|
+
}
|
|
85
|
+
/** PostgreSQL `pg_last_wal_replay_lsn()` — returns the last replayed WAL position on a replica. Returns NULL on the primary. Internal primitive for replica-aware job execution. */
|
|
86
|
+
export function walReplayLsn() {
|
|
87
|
+
return sql `pg_last_wal_replay_lsn()::text`;
|
|
88
|
+
}
|
|
22
89
|
//# sourceMappingURL=expressions.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"expressions.js","sourceRoot":"","sources":["../../../src/data/db/expressions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAA;AAI9B,uEAAuE;AACvE,MAAM,UAAU,SAAS,CAAC,MAAoB,EAAE,MAAc;IAC5D,OAAO,GAAG,CAAQ,GAAG,MAAM,MAAM,MAAM,EAAE,CAAA;AAC3C,CAAC;AAED,mGAAmG;AACnG,MAAM,UAAU,SAAS,CAAC,MAAoB,EAAE,MAAc;IAC5D,OAAO,GAAG,CAAQ,GAAG,MAAM,MAAM,MAAM,EAAE,CAAA;AAC3C,CAAC;AAED,8FAA8F;AAC9F,MAAM,UAAU,QAAQ,CAAI,UAAwB,EAAE,YAAe;IACnE,OAAO,GAAG,CAAG,YAAY,UAAU,KAAK,YAAY,GAAG,CAAA;AACzD,CAAC;AAED,2FAA2F;AAC3F,MAAM,UAAU,GAAG;IACjB,OAAO,GAAG,CAAM,OAAO,CAAA;AACzB,CAAC;AAED,gGAAgG;AAChG,MAAM,UAAU,MAAM,CAAI,QAAoB;IAC5C,OAAO,GAAG,CAAG,IAAI,QAAQ,GAAG,CAAA;AAC9B,CAAC"}
|
|
1
|
+
{"version":3,"file":"expressions.js","sourceRoot":"","sources":["../../../src/data/db/expressions.ts"],"names":[],"mappings":"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"}
|
package/dist/data/db/filter.d.ts
CHANGED
|
@@ -1,12 +1,33 @@
|
|
|
1
1
|
import * as operators from './generated/drizzle-orm/operator.js';
|
|
2
2
|
import * as aggregates from './generated/drizzle-orm/aggregate.js';
|
|
3
|
-
import { increment, decrement, coalesce, now, scalar } from './expressions.js';
|
|
3
|
+
import { increment, decrement, add, subtract, coalesce, now, scalar, cast, interval, dateTrunc, rowNumber, rank, denseRank, over, identifier, withRecursive } from './expressions.js';
|
|
4
|
+
import { ago, castUuid, castJsonb, castTimestamp, castBoolean, castNumeric, castInteger, castText, nextSequence } from './composed.js';
|
|
4
5
|
export declare const filter: {
|
|
5
6
|
readonly increment: typeof increment;
|
|
6
7
|
readonly decrement: typeof decrement;
|
|
8
|
+
readonly add: typeof add;
|
|
9
|
+
readonly subtract: typeof subtract;
|
|
7
10
|
readonly coalesce: typeof coalesce;
|
|
8
11
|
readonly now: typeof now;
|
|
9
12
|
readonly scalar: typeof scalar;
|
|
13
|
+
readonly cast: typeof cast;
|
|
14
|
+
readonly interval: typeof interval;
|
|
15
|
+
readonly dateTrunc: typeof dateTrunc;
|
|
16
|
+
readonly rowNumber: typeof rowNumber;
|
|
17
|
+
readonly rank: typeof rank;
|
|
18
|
+
readonly denseRank: typeof denseRank;
|
|
19
|
+
readonly over: typeof over;
|
|
20
|
+
readonly identifier: typeof identifier;
|
|
21
|
+
readonly withRecursive: typeof withRecursive;
|
|
22
|
+
readonly ago: typeof ago;
|
|
23
|
+
readonly castUuid: typeof castUuid;
|
|
24
|
+
readonly castJsonb: typeof castJsonb;
|
|
25
|
+
readonly castTimestamp: typeof castTimestamp;
|
|
26
|
+
readonly castBoolean: typeof castBoolean;
|
|
27
|
+
readonly castNumeric: typeof castNumeric;
|
|
28
|
+
readonly castInteger: typeof castInteger;
|
|
29
|
+
readonly castText: typeof castText;
|
|
30
|
+
readonly nextSequence: typeof nextSequence;
|
|
10
31
|
readonly except: import("./generated/pg-core/type.js").PgCreateSetOperatorFn;
|
|
11
32
|
readonly exceptAll: import("./generated/pg-core/type.js").PgCreateSetOperatorFn;
|
|
12
33
|
readonly intersect: import("./generated/pg-core/type.js").PgCreateSetOperatorFn;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../../src/data/db/filter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,qCAAqC,CAAA;AAChE,OAAO,KAAK,UAAU,MAAM,sCAAsC,CAAA;AAElE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;
|
|
1
|
+
{"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../../src/data/db/filter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,qCAAqC,CAAA;AAChE,OAAO,KAAK,UAAU,MAAM,sCAAsC,CAAA;AAElE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AACrL,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAEtI,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA6BT,CAAA"}
|
package/dist/data/db/filter.js
CHANGED
|
@@ -1,15 +1,36 @@
|
|
|
1
1
|
import * as operators from './generated/drizzle-orm/operator.js';
|
|
2
2
|
import * as aggregates from './generated/drizzle-orm/aggregate.js';
|
|
3
3
|
import * as setOps from './generated/pg-core/set-operation.js';
|
|
4
|
-
import { increment, decrement, coalesce, now, scalar } from './expressions.js';
|
|
4
|
+
import { increment, decrement, add, subtract, coalesce, now, scalar, cast, interval, dateTrunc, rowNumber, rank, denseRank, over, identifier, withRecursive } from './expressions.js';
|
|
5
|
+
import { ago, castUuid, castJsonb, castTimestamp, castBoolean, castNumeric, castInteger, castText, nextSequence } from './composed.js';
|
|
5
6
|
export const filter = {
|
|
6
7
|
...operators,
|
|
7
8
|
...aggregates,
|
|
8
9
|
...setOps,
|
|
9
10
|
increment,
|
|
10
11
|
decrement,
|
|
12
|
+
add,
|
|
13
|
+
subtract,
|
|
11
14
|
coalesce,
|
|
12
15
|
now,
|
|
13
16
|
scalar,
|
|
17
|
+
cast,
|
|
18
|
+
interval,
|
|
19
|
+
dateTrunc,
|
|
20
|
+
rowNumber,
|
|
21
|
+
rank,
|
|
22
|
+
denseRank,
|
|
23
|
+
over,
|
|
24
|
+
identifier,
|
|
25
|
+
withRecursive,
|
|
26
|
+
ago,
|
|
27
|
+
castUuid,
|
|
28
|
+
castJsonb,
|
|
29
|
+
castTimestamp,
|
|
30
|
+
castBoolean,
|
|
31
|
+
castNumeric,
|
|
32
|
+
castInteger,
|
|
33
|
+
castText,
|
|
34
|
+
nextSequence,
|
|
14
35
|
};
|
|
15
36
|
//# sourceMappingURL=filter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../src/data/db/filter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,qCAAqC,CAAA;AAChE,OAAO,KAAK,UAAU,MAAM,sCAAsC,CAAA;AAClE,OAAO,KAAK,MAAM,MAAM,sCAAsC,CAAA;AAC9D,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;
|
|
1
|
+
{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../src/data/db/filter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,qCAAqC,CAAA;AAChE,OAAO,KAAK,UAAU,MAAM,sCAAsC,CAAA;AAClE,OAAO,KAAK,MAAM,MAAM,sCAAsC,CAAA;AAC9D,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AACrL,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAEtI,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,GAAG,SAAS;IACZ,GAAG,UAAU;IACb,GAAG,MAAM;IACT,SAAS;IACT,SAAS;IACT,GAAG;IACH,QAAQ;IACR,QAAQ;IACR,GAAG;IACH,MAAM;IACN,IAAI;IACJ,QAAQ;IACR,SAAS;IACT,SAAS;IACT,IAAI;IACJ,SAAS;IACT,IAAI;IACJ,UAAU;IACV,aAAa;IACb,GAAG;IACH,QAAQ;IACR,SAAS;IACT,aAAa;IACb,WAAW;IACX,WAAW;IACX,WAAW;IACX,QAAQ;IACR,YAAY;CACJ,CAAA"}
|
|
@@ -2,7 +2,9 @@ import { pipe as getDb } from './db.js';
|
|
|
2
2
|
import { migrateAll, migrateOne } from '../migrate/index.js';
|
|
3
3
|
import { excluded } from './excluded.js';
|
|
4
4
|
import { advisoryLock } from './advisory-lock.js';
|
|
5
|
+
import { serializable } from './serializable.js';
|
|
5
6
|
import { bulkSet } from './bulk-set.js';
|
|
7
|
+
import { values } from './values.js';
|
|
6
8
|
import * as introspection from './generated/drizzle-orm/introspection.js';
|
|
7
9
|
import * as relationOps from './generated/drizzle-orm/relation.js';
|
|
8
10
|
import { define, definitions } from '../domain/index.js';
|
|
@@ -21,8 +23,12 @@ export declare const pipe: typeof getDb & {
|
|
|
21
23
|
excluded: typeof excluded;
|
|
22
24
|
/** Acquires a transaction-scoped advisory lock. Released at commit/rollback. */
|
|
23
25
|
advisoryLock: typeof advisoryLock;
|
|
26
|
+
/** Runs a function in a SERIALIZABLE transaction with automatic retry on serialization failures and deadlocks. */
|
|
27
|
+
serializable: typeof serializable;
|
|
24
28
|
/** Bulk UPDATE ... FROM (VALUES ...) — updates multiple rows with per-row values in a single statement. */
|
|
25
29
|
bulkSet: typeof bulkSet;
|
|
30
|
+
/** Produces a typed VALUES clause for bulk operations — the base primitive for bulkSet and bulkUpsert. */
|
|
31
|
+
values: typeof values;
|
|
26
32
|
/** Field builders for domain definitions — uuid(), text(), integer(), etc. */
|
|
27
33
|
field: {
|
|
28
34
|
uuid(): import("../domain/types.js").FieldDescriptor<string> & import("../domain/field.js").FieldModifiers<string>;
|
|
@@ -56,9 +62,29 @@ export declare const pipe: typeof getDb & {
|
|
|
56
62
|
filter: {
|
|
57
63
|
readonly increment: typeof import("./expressions.js").increment;
|
|
58
64
|
readonly decrement: typeof import("./expressions.js").decrement;
|
|
65
|
+
readonly add: typeof import("./expressions.js").add;
|
|
66
|
+
readonly subtract: typeof import("./expressions.js").subtract;
|
|
59
67
|
readonly coalesce: typeof import("./expressions.js").coalesce;
|
|
60
68
|
readonly now: typeof import("./expressions.js").now;
|
|
61
69
|
readonly scalar: typeof import("./expressions.js").scalar;
|
|
70
|
+
readonly cast: typeof import("./expressions.js").cast;
|
|
71
|
+
readonly interval: typeof import("./expressions.js").interval;
|
|
72
|
+
readonly dateTrunc: typeof import("./expressions.js").dateTrunc;
|
|
73
|
+
readonly rowNumber: typeof import("./expressions.js").rowNumber;
|
|
74
|
+
readonly rank: typeof import("./expressions.js").rank;
|
|
75
|
+
readonly denseRank: typeof import("./expressions.js").denseRank;
|
|
76
|
+
readonly over: typeof import("./expressions.js").over;
|
|
77
|
+
readonly identifier: typeof import("./expressions.js").identifier;
|
|
78
|
+
readonly withRecursive: typeof import("./expressions.js").withRecursive;
|
|
79
|
+
readonly ago: typeof import("./composed.js").ago;
|
|
80
|
+
readonly castUuid: typeof import("./composed.js").castUuid;
|
|
81
|
+
readonly castJsonb: typeof import("./composed.js").castJsonb;
|
|
82
|
+
readonly castTimestamp: typeof import("./composed.js").castTimestamp;
|
|
83
|
+
readonly castBoolean: typeof import("./composed.js").castBoolean;
|
|
84
|
+
readonly castNumeric: typeof import("./composed.js").castNumeric;
|
|
85
|
+
readonly castInteger: typeof import("./composed.js").castInteger;
|
|
86
|
+
readonly castText: typeof import("./composed.js").castText;
|
|
87
|
+
readonly nextSequence: typeof import("./composed.js").nextSequence;
|
|
62
88
|
readonly except: import("./generated/pg-core/type.js").PgCreateSetOperatorFn;
|
|
63
89
|
readonly exceptAll: import("./generated/pg-core/type.js").PgCreateSetOperatorFn;
|
|
64
90
|
readonly intersect: import("./generated/pg-core/type.js").PgCreateSetOperatorFn;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/data/db/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,KAAK,EAAE,MAAM,SAAS,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAE5D,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/data/db/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,KAAK,EAAE,MAAM,SAAS,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAE5D,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAGpC,OAAO,KAAK,aAAa,MAAM,0CAA0C,CAAA;AACzE,OAAO,KAAK,WAAW,MAAM,qCAAqC,CAAA;AAGlE,OAAO,EAAS,MAAM,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAG/D,YAAY,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAE3E,6EAA6E;AAC7E,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAEpC,6EAA6E;AAC7E,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAExC,mJAAmJ;AACnJ,eAAO,MAAM,IAAI;IAUf,oDAAoD;;IAEpD,mDAAmD;;IAGnD,6EAA6E;;IAG7E,gFAAgF;;IAGhF,kHAAkH;;IAGlH,2GAA2G;;IAG3G,0GAA0G;;IAG1G,8EAA8E;;;;;;;;;;;;;;IAE9E,qFAAqF;;IAErF,6DAA6D;;;;;;;;;;;;;IAjC7D,6EAA6E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmC7E,CAAA"}
|
|
@@ -3,7 +3,9 @@ import { migrateAll, migrateOne } from '../migrate/index.js';
|
|
|
3
3
|
import { filter } from './filter.js';
|
|
4
4
|
import { excluded } from './excluded.js';
|
|
5
5
|
import { advisoryLock } from './advisory-lock.js';
|
|
6
|
+
import { serializable } from './serializable.js';
|
|
6
7
|
import { bulkSet } from './bulk-set.js';
|
|
8
|
+
import { values } from './values.js';
|
|
7
9
|
// Auto-generated re-export layers (scaffold-namespace tool)
|
|
8
10
|
import * as introspection from './generated/drizzle-orm/introspection.js';
|
|
9
11
|
import * as relationOps from './generated/drizzle-orm/relation.js';
|
|
@@ -29,8 +31,12 @@ export const pipe = Object.assign(getDb, {
|
|
|
29
31
|
excluded,
|
|
30
32
|
/** Acquires a transaction-scoped advisory lock. Released at commit/rollback. */
|
|
31
33
|
advisoryLock,
|
|
34
|
+
/** Runs a function in a SERIALIZABLE transaction with automatic retry on serialization failures and deadlocks. */
|
|
35
|
+
serializable,
|
|
32
36
|
/** Bulk UPDATE ... FROM (VALUES ...) — updates multiple rows with per-row values in a single statement. */
|
|
33
37
|
bulkSet,
|
|
38
|
+
/** Produces a typed VALUES clause for bulk operations — the base primitive for bulkSet and bulkUpsert. */
|
|
39
|
+
values,
|
|
34
40
|
/** Field builders for domain definitions — uuid(), text(), integer(), etc. */
|
|
35
41
|
field,
|
|
36
42
|
/** Registers a domain definition with table, validators, and factory projections. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/data/db/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,KAAK,EAAE,MAAM,SAAS,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/data/db/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,KAAK,EAAE,MAAM,SAAS,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAEpC,4DAA4D;AAC5D,OAAO,KAAK,aAAa,MAAM,0CAA0C,CAAA;AACzE,OAAO,KAAK,WAAW,MAAM,qCAAqC,CAAA;AAElE,qBAAqB;AACrB,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAK/D,6EAA6E;AAC7E,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAEpC,6EAA6E;AAC7E,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAExC,mJAAmJ;AACnJ,MAAM,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE;IACvC,6EAA6E;IAC7E,MAAM;IAEN,kGAAkG;IAClG,GAAG,aAAa;IAEhB,qDAAqD;IACrD,GAAG,WAAW;IAEd,oDAAoD;IACpD,OAAO,EAAE,UAAU;IACnB,mDAAmD;IACnD,UAAU;IAEV,6EAA6E;IAC7E,QAAQ;IAER,gFAAgF;IAChF,YAAY;IAEZ,kHAAkH;IAClH,YAAY;IAEZ,2GAA2G;IAC3G,OAAO;IAEP,0GAA0G;IAC1G,MAAM;IAEN,8EAA8E;IAC9E,KAAK;IACL,qFAAqF;IACrF,MAAM;IACN,6DAA6D;IAC7D,WAAW;CACZ,CAAC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { DB } from './types.js';
|
|
2
|
+
export interface SerializableOptions {
|
|
3
|
+
readonly maxAttempts?: number;
|
|
4
|
+
readonly backoffMs?: number;
|
|
5
|
+
}
|
|
6
|
+
/** Runs `fn` in a SERIALIZABLE transaction, retrying on serialization failures (40001) and deadlocks (40P01) with exponential backoff. */
|
|
7
|
+
export declare function serializable<T>(db: DB, fn: (tx: DB) => Promise<T>, options?: SerializableOptions): Promise<T>;
|
|
8
|
+
//# sourceMappingURL=serializable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serializable.d.ts","sourceRoot":"","sources":["../../../src/data/db/serializable.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,YAAY,CAAA;AAEpC,MAAM,WAAW,mBAAmB;IAClC,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAC5B;AAiBD,0IAA0I;AAC1I,wBAAsB,YAAY,CAAC,CAAC,EAClC,EAAE,EAAE,EAAE,EACN,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,EAC1B,OAAO,CAAC,EAAE,mBAAmB,GAC5B,OAAO,CAAC,CAAC,CAAC,CA6BZ"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
const PG_SERIALIZATION_FAILURE = '40001';
|
|
2
|
+
const PG_DEADLOCK_DETECTED = '40P01';
|
|
3
|
+
function extractPgCode(err) {
|
|
4
|
+
if (typeof err !== 'object' || err === null)
|
|
5
|
+
return undefined;
|
|
6
|
+
if ('code' in err)
|
|
7
|
+
return err.code;
|
|
8
|
+
if ('cause' in err)
|
|
9
|
+
return extractPgCode(err.cause);
|
|
10
|
+
return undefined;
|
|
11
|
+
}
|
|
12
|
+
function isTransientConcurrencyError(err) {
|
|
13
|
+
const code = extractPgCode(err);
|
|
14
|
+
return code === PG_SERIALIZATION_FAILURE || code === PG_DEADLOCK_DETECTED;
|
|
15
|
+
}
|
|
16
|
+
/** Runs `fn` in a SERIALIZABLE transaction, retrying on serialization failures (40001) and deadlocks (40P01) with exponential backoff. */
|
|
17
|
+
export async function serializable(db, fn, options) {
|
|
18
|
+
const maxAttempts = options?.maxAttempts ?? 3;
|
|
19
|
+
const backoffMs = options?.backoffMs ?? 50;
|
|
20
|
+
if (maxAttempts < 1) {
|
|
21
|
+
throw new Error('[pipework] serializable() requires maxAttempts >= 1.\n\n' +
|
|
22
|
+
' pipe.serializable(db, fn) — default 3 attempts\n' +
|
|
23
|
+
' pipe.serializable(db, fn, { maxAttempts: 5 }) — custom attempts\n');
|
|
24
|
+
}
|
|
25
|
+
let lastError;
|
|
26
|
+
for (let attempt = 0; attempt < maxAttempts; attempt++) {
|
|
27
|
+
if (attempt > 0) {
|
|
28
|
+
await new Promise(resolve => setTimeout(resolve, backoffMs * 2 ** (attempt - 1)));
|
|
29
|
+
}
|
|
30
|
+
try {
|
|
31
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- drizzle's transaction generic requires concrete schema types; the DB alias erases them
|
|
32
|
+
return await db.transaction(fn, { isolationLevel: 'serializable' });
|
|
33
|
+
}
|
|
34
|
+
catch (err) {
|
|
35
|
+
if (isTransientConcurrencyError(err) && attempt < maxAttempts - 1) {
|
|
36
|
+
lastError = err;
|
|
37
|
+
continue;
|
|
38
|
+
}
|
|
39
|
+
throw err;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
throw lastError;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=serializable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serializable.js","sourceRoot":"","sources":["../../../src/data/db/serializable.ts"],"names":[],"mappings":"AAOA,MAAM,wBAAwB,GAAG,OAAO,CAAA;AACxC,MAAM,oBAAoB,GAAG,OAAO,CAAA;AAEpC,SAAS,aAAa,CAAC,GAAY;IACjC,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,IAAI;QAAE,OAAO,SAAS,CAAA;IAC7D,IAAI,MAAM,IAAI,GAAG;QAAE,OAAQ,GAAyB,CAAC,IAAI,CAAA;IACzD,IAAI,OAAO,IAAI,GAAG;QAAE,OAAO,aAAa,CAAE,GAA0B,CAAC,KAAK,CAAC,CAAA;IAC3E,OAAO,SAAS,CAAA;AAClB,CAAC;AAED,SAAS,2BAA2B,CAAC,GAAY;IAC/C,MAAM,IAAI,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;IAC/B,OAAO,IAAI,KAAK,wBAAwB,IAAI,IAAI,KAAK,oBAAoB,CAAA;AAC3E,CAAC;AAED,0IAA0I;AAC1I,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,EAAM,EACN,EAA0B,EAC1B,OAA6B;IAE7B,MAAM,WAAW,GAAG,OAAO,EAAE,WAAW,IAAI,CAAC,CAAA;IAC7C,MAAM,SAAS,GAAG,OAAO,EAAE,SAAS,IAAI,EAAE,CAAA;IAE1C,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;QACpB,MAAM,IAAI,KAAK,CACb,0DAA0D;YAC1D,wEAAwE;YACxE,qEAAqE,CACtE,CAAA;IACH,CAAC;IAED,IAAI,SAAkB,CAAA;IACtB,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,GAAG,WAAW,EAAE,OAAO,EAAE,EAAE,CAAC;QACvD,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;YAChB,MAAM,IAAI,OAAO,CAAO,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,SAAS,GAAG,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;QACzF,CAAC;QACD,IAAI,CAAC;YACH,wJAAwJ;YACxJ,OAAO,MAAO,EAAU,CAAC,WAAW,CAAC,EAAE,EAAE,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC,CAAA;QAC9E,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,2BAA2B,CAAC,GAAG,CAAC,IAAI,OAAO,GAAG,WAAW,GAAG,CAAC,EAAE,CAAC;gBAClE,SAAS,GAAG,GAAG,CAAA;gBACf,SAAQ;YACV,CAAC;YACD,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC;IACD,MAAM,SAAS,CAAA;AACjB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { SQL } from './types.js';
|
|
2
|
+
type PgCastType = 'uuid' | 'text' | 'integer' | 'bigint' | 'boolean' | 'jsonb' | 'timestamptz' | 'timestamp' | 'date' | 'numeric' | 'real' | 'double precision' | 'smallint' | 'interval';
|
|
3
|
+
export interface ValueColumnDef {
|
|
4
|
+
readonly name: string;
|
|
5
|
+
readonly type: PgCastType;
|
|
6
|
+
}
|
|
7
|
+
/** Produces a typed VALUES clause: `(VALUES ($1::uuid, $2::text), ($3::uuid, $4::text))`. Each value is cast to its declared type. JSONB values are JSON-stringified before casting. */
|
|
8
|
+
export declare function values(rows: ReadonlyArray<readonly unknown[]>, columns: readonly ValueColumnDef[]): SQL;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=values.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"values.d.ts","sourceRoot":"","sources":["../../../src/data/db/values.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,YAAY,CAAA;AAErC,KAAK,UAAU,GAAG,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,QAAQ,GAAG,SAAS,GAAG,OAAO,GAAG,aAAa,GAAG,WAAW,GAAG,MAAM,GAAG,SAAS,GAAG,MAAM,GAAG,kBAAkB,GAAG,UAAU,GAAG,UAAU,CAAA;AAEzL,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,IAAI,EAAE,UAAU,CAAA;CAC1B;AAED,wLAAwL;AACxL,wBAAgB,MAAM,CAAC,IAAI,EAAE,aAAa,CAAC,SAAS,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,SAAS,cAAc,EAAE,GAAG,GAAG,CAgBvG"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { sql } from './sql.js';
|
|
2
|
+
/** Produces a typed VALUES clause: `(VALUES ($1::uuid, $2::text), ($3::uuid, $4::text))`. Each value is cast to its declared type. JSONB values are JSON-stringified before casting. */
|
|
3
|
+
export function values(rows, columns) {
|
|
4
|
+
if (rows.length === 0)
|
|
5
|
+
throw new Error('[pipework] values() requires at least one row');
|
|
6
|
+
if (columns.length === 0)
|
|
7
|
+
throw new Error('[pipework] values() requires at least one column definition');
|
|
8
|
+
const valueRows = rows.map(row => {
|
|
9
|
+
const cells = columns.map((col, i) => {
|
|
10
|
+
const val = row[i];
|
|
11
|
+
if (col.type === 'jsonb') {
|
|
12
|
+
return sql `${JSON.stringify(val)}::jsonb`;
|
|
13
|
+
}
|
|
14
|
+
return sql `${val}::${sql.raw(col.type)}`;
|
|
15
|
+
});
|
|
16
|
+
return sql `(${sql.join(cells, sql `, `)})`;
|
|
17
|
+
});
|
|
18
|
+
return sql `(VALUES ${sql.join(valueRows, sql `, `)})`;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=values.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"values.js","sourceRoot":"","sources":["../../../src/data/db/values.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAA;AAU9B,wLAAwL;AACxL,MAAM,UAAU,MAAM,CAAC,IAAuC,EAAE,OAAkC;IAChG,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAA;IACvF,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAA;IAExG,MAAM,SAAS,GAAU,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;QACtC,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;YACnC,MAAM,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAA;YAClB,IAAI,GAAG,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;gBACzB,OAAO,GAAG,CAAA,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAA;YAC3C,CAAC;YACD,OAAO,GAAG,CAAA,GAAG,GAAuC,KAAK,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAA;QAC9E,CAAC,CAAC,CAAA;QACF,OAAO,GAAG,CAAA,IAAI,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAA,IAAI,CAAC,GAAG,CAAA;IAC3C,CAAC,CAAC,CAAA;IAEF,OAAO,GAAG,CAAA,WAAW,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,CAAA,IAAI,CAAC,GAAG,CAAA;AACtD,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SQL, Column } from '../db/types.js';
|
|
2
|
+
/** Extracts a boolean from a JSONB column: `(column->>'key')::boolean`. Supports nested paths. */
|
|
3
|
+
export declare function boolean(column: Column | SQL, ...keys: string[]): SQL<boolean>;
|
|
4
|
+
/** Extracts a number from a JSONB column: `(column->>'key')::numeric`. Supports nested paths. */
|
|
5
|
+
export declare function number(column: Column | SQL, ...keys: string[]): SQL<number>;
|
|
6
|
+
/** Extracts an integer from a JSONB column: `(column->>'key')::integer`. Supports nested paths. */
|
|
7
|
+
export declare function integer(column: Column | SQL, ...keys: string[]): SQL<number>;
|
|
8
|
+
//# sourceMappingURL=composed.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"composed.d.ts","sourceRoot":"","sources":["../../../src/data/jsonb/composed.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAIjD,kGAAkG;AAClG,wBAAgB,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,OAAO,CAAC,CAE7E;AAED,iGAAiG;AACjG,wBAAgB,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAE3E;AAED,mGAAmG;AACnG,wBAAgB,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAE5E"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { cast } from '../db/expressions.js';
|
|
2
|
+
import { pathText } from './query.js';
|
|
3
|
+
/** Extracts a boolean from a JSONB column: `(column->>'key')::boolean`. Supports nested paths. */
|
|
4
|
+
export function boolean(column, ...keys) {
|
|
5
|
+
return cast(pathText(column, ...keys), 'boolean');
|
|
6
|
+
}
|
|
7
|
+
/** Extracts a number from a JSONB column: `(column->>'key')::numeric`. Supports nested paths. */
|
|
8
|
+
export function number(column, ...keys) {
|
|
9
|
+
return cast(pathText(column, ...keys), 'numeric');
|
|
10
|
+
}
|
|
11
|
+
/** Extracts an integer from a JSONB column: `(column->>'key')::integer`. Supports nested paths. */
|
|
12
|
+
export function integer(column, ...keys) {
|
|
13
|
+
return cast(pathText(column, ...keys), 'integer');
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=composed.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"composed.js","sourceRoot":"","sources":["../../../src/data/jsonb/composed.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,kGAAkG;AAClG,MAAM,UAAU,OAAO,CAAC,MAAoB,EAAE,GAAG,IAAc;IAC7D,OAAO,IAAI,CAAU,QAAQ,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,SAAS,CAAC,CAAA;AAC5D,CAAC;AAED,iGAAiG;AACjG,MAAM,UAAU,MAAM,CAAC,MAAoB,EAAE,GAAG,IAAc;IAC5D,OAAO,IAAI,CAAS,QAAQ,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,SAAS,CAAC,CAAA;AAC3D,CAAC;AAED,mGAAmG;AACnG,MAAM,UAAU,OAAO,CAAC,MAAoB,EAAE,GAAG,IAAc;IAC7D,OAAO,IAAI,CAAS,QAAQ,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,SAAS,CAAC,CAAA;AAC3D,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { contains, containedBy, hasKey, text, json } from './query.js';
|
|
1
|
+
import { contains, containedBy, hasKey, text, json, path, pathText } from './query.js';
|
|
2
|
+
import { boolean, number, integer } from './composed.js';
|
|
2
3
|
/** JSONB query operators — typed helpers for PostgreSQL JSONB containment, key checks, and field extraction. */
|
|
3
4
|
export declare const jsonb: {
|
|
4
5
|
/** The @> containment operator — tests whether a JSONB column contains the given value. */
|
|
@@ -11,5 +12,15 @@ export declare const jsonb: {
|
|
|
11
12
|
text: typeof text;
|
|
12
13
|
/** Extracts a JSONB value: `column->'key'`. Returns JSONB — use with jsonb.contains() etc. */
|
|
13
14
|
json: typeof json;
|
|
15
|
+
/** Extracts a nested JSONB value: `column->'a'->'b'`. Returns JSONB. */
|
|
16
|
+
path: typeof path;
|
|
17
|
+
/** Extracts a nested text value: `column->'a'->>'b'`. Intermediate keys use `->`, final uses `->>`. */
|
|
18
|
+
pathText: typeof pathText;
|
|
19
|
+
/** Extracts a boolean: `(column->>'key')::boolean`. Supports nested paths. */
|
|
20
|
+
boolean: typeof boolean;
|
|
21
|
+
/** Extracts a number: `(column->>'key')::numeric`. Supports nested paths. */
|
|
22
|
+
number: typeof number;
|
|
23
|
+
/** Extracts an integer: `(column->>'key')::integer`. Supports nested paths. */
|
|
24
|
+
integer: typeof integer;
|
|
14
25
|
};
|
|
15
26
|
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/data/jsonb/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/data/jsonb/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACtF,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAExD,gHAAgH;AAChH,eAAO,MAAM,KAAK;IAChB,2FAA2F;;IAE3F,mGAAmG;;IAEnG,+FAA+F;;IAE/F,sFAAsF;;IAEtF,8FAA8F;;IAE9F,wEAAwE;;IAExE,uGAAuG;;IAEvG,8EAA8E;;IAE9E,6EAA6E;;IAE7E,+EAA+E;;CAEhF,CAAA"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { contains, containedBy, hasKey, text, json } from './query.js';
|
|
1
|
+
import { contains, containedBy, hasKey, text, json, path, pathText } from './query.js';
|
|
2
|
+
import { boolean, number, integer } from './composed.js';
|
|
2
3
|
/** JSONB query operators — typed helpers for PostgreSQL JSONB containment, key checks, and field extraction. */
|
|
3
4
|
export const jsonb = {
|
|
4
5
|
/** The @> containment operator — tests whether a JSONB column contains the given value. */
|
|
@@ -11,5 +12,15 @@ export const jsonb = {
|
|
|
11
12
|
text,
|
|
12
13
|
/** Extracts a JSONB value: `column->'key'`. Returns JSONB — use with jsonb.contains() etc. */
|
|
13
14
|
json,
|
|
15
|
+
/** Extracts a nested JSONB value: `column->'a'->'b'`. Returns JSONB. */
|
|
16
|
+
path,
|
|
17
|
+
/** Extracts a nested text value: `column->'a'->>'b'`. Intermediate keys use `->`, final uses `->>`. */
|
|
18
|
+
pathText,
|
|
19
|
+
/** Extracts a boolean: `(column->>'key')::boolean`. Supports nested paths. */
|
|
20
|
+
boolean,
|
|
21
|
+
/** Extracts a number: `(column->>'key')::numeric`. Supports nested paths. */
|
|
22
|
+
number,
|
|
23
|
+
/** Extracts an integer: `(column->>'key')::integer`. Supports nested paths. */
|
|
24
|
+
integer,
|
|
14
25
|
};
|
|
15
26
|
//# sourceMappingURL=namespace.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/data/jsonb/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/data/jsonb/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACtF,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAExD,gHAAgH;AAChH,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,2FAA2F;IAC3F,QAAQ;IACR,mGAAmG;IACnG,WAAW;IACX,+FAA+F;IAC/F,MAAM;IACN,sFAAsF;IACtF,IAAI;IACJ,8FAA8F;IAC9F,IAAI;IACJ,wEAAwE;IACxE,IAAI;IACJ,uGAAuG;IACvG,QAAQ;IACR,8EAA8E;IAC9E,OAAO;IACP,6EAA6E;IAC7E,MAAM;IACN,+EAA+E;IAC/E,OAAO;CACR,CAAA"}
|
|
@@ -6,4 +6,8 @@ export declare function hasKey(column: Column | SQL, key: string): SQL<boolean>;
|
|
|
6
6
|
export declare function text(column: Column | SQL, key: string): SQL<string>;
|
|
7
7
|
/** Extracts a JSONB value from a JSONB column: `column->'key'`. Returns JSONB, not text — use with jsonb.contains() etc. */
|
|
8
8
|
export declare function json(column: Column | SQL, key: string): SQL;
|
|
9
|
+
/** Extracts a nested JSONB value: `column->'a'->'b'`. Returns JSONB. For text output, use `pathText`. */
|
|
10
|
+
export declare function path(column: Column | SQL, ...keys: string[]): SQL;
|
|
11
|
+
/** Extracts a nested text value: `column->'a'->>'b'`. Intermediate keys use `->`, final key uses `->>`. */
|
|
12
|
+
export declare function pathText(column: Column | SQL, ...keys: string[]): SQL<string>;
|
|
9
13
|
//# sourceMappingURL=query.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../../src/data/jsonb/query.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAEjD,wBAAgB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,CAE3E;AAED,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,CAE9E;AAED,wBAAgB,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,CAEtE;AAED,4HAA4H;AAC5H,wBAAgB,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAEnE;AAED,4HAA4H;AAC5H,wBAAgB,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,GAAG,CAE3D"}
|
|
1
|
+
{"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../../src/data/jsonb/query.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAEjD,wBAAgB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,CAE3E;AAED,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,KAAK,EAAE,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,CAE9E;AAED,wBAAgB,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,CAEtE;AAED,4HAA4H;AAC5H,wBAAgB,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAEnE;AAED,4HAA4H;AAC5H,wBAAgB,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,GAAG,CAE3D;AAED,yGAAyG;AACzG,wBAAgB,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,GAAG,CAOjE;AAED,2GAA2G;AAC3G,wBAAgB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAO7E"}
|
package/dist/data/jsonb/query.js
CHANGED
|
@@ -16,4 +16,25 @@ export function text(column, key) {
|
|
|
16
16
|
export function json(column, key) {
|
|
17
17
|
return sql `${column}->${key}`;
|
|
18
18
|
}
|
|
19
|
+
/** Extracts a nested JSONB value: `column->'a'->'b'`. Returns JSONB. For text output, use `pathText`. */
|
|
20
|
+
export function path(column, ...keys) {
|
|
21
|
+
if (keys.length === 0)
|
|
22
|
+
return sql `${column}`;
|
|
23
|
+
let result = sql `${column}`;
|
|
24
|
+
for (const key of keys) {
|
|
25
|
+
result = sql `${result}->${key}`;
|
|
26
|
+
}
|
|
27
|
+
return result;
|
|
28
|
+
}
|
|
29
|
+
/** Extracts a nested text value: `column->'a'->>'b'`. Intermediate keys use `->`, final key uses `->>`. */
|
|
30
|
+
export function pathText(column, ...keys) {
|
|
31
|
+
if (keys.length === 0)
|
|
32
|
+
return sql `${column}`;
|
|
33
|
+
if (keys.length === 1)
|
|
34
|
+
return text(column, keys[0]);
|
|
35
|
+
const intermediateKeys = keys.slice(0, -1);
|
|
36
|
+
const finalKey = keys[keys.length - 1];
|
|
37
|
+
const intermediate = path(column, ...intermediateKeys);
|
|
38
|
+
return text(intermediate, finalKey);
|
|
39
|
+
}
|
|
19
40
|
//# sourceMappingURL=query.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/data/jsonb/query.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAA;AAGlC,MAAM,UAAU,QAAQ,CAAC,MAAoB,EAAE,KAAc;IAC3D,OAAO,GAAG,CAAS,GAAG,MAAM,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAA;AACnE,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAoB,EAAE,KAAc;IAC9D,OAAO,GAAG,CAAS,GAAG,MAAM,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAA;AACnE,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,MAAoB,EAAE,GAAW;IACtD,OAAO,GAAG,CAAS,GAAG,MAAM,MAAM,GAAG,EAAE,CAAA;AACzC,CAAC;AAED,4HAA4H;AAC5H,MAAM,UAAU,IAAI,CAAC,MAAoB,EAAE,GAAW;IACpD,OAAO,GAAG,CAAQ,GAAG,MAAM,MAAM,GAAG,EAAE,CAAA;AACxC,CAAC;AAED,4HAA4H;AAC5H,MAAM,UAAU,IAAI,CAAC,MAAoB,EAAE,GAAW;IACpD,OAAO,GAAG,CAAA,GAAG,MAAM,KAAK,GAAG,EAAE,CAAA;AAC/B,CAAC"}
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/data/jsonb/query.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAA;AAGlC,MAAM,UAAU,QAAQ,CAAC,MAAoB,EAAE,KAAc;IAC3D,OAAO,GAAG,CAAS,GAAG,MAAM,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAA;AACnE,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAoB,EAAE,KAAc;IAC9D,OAAO,GAAG,CAAS,GAAG,MAAM,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAA;AACnE,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,MAAoB,EAAE,GAAW;IACtD,OAAO,GAAG,CAAS,GAAG,MAAM,MAAM,GAAG,EAAE,CAAA;AACzC,CAAC;AAED,4HAA4H;AAC5H,MAAM,UAAU,IAAI,CAAC,MAAoB,EAAE,GAAW;IACpD,OAAO,GAAG,CAAQ,GAAG,MAAM,MAAM,GAAG,EAAE,CAAA;AACxC,CAAC;AAED,4HAA4H;AAC5H,MAAM,UAAU,IAAI,CAAC,MAAoB,EAAE,GAAW;IACpD,OAAO,GAAG,CAAA,GAAG,MAAM,KAAK,GAAG,EAAE,CAAA;AAC/B,CAAC;AAED,yGAAyG;AACzG,MAAM,UAAU,IAAI,CAAC,MAAoB,EAAE,GAAG,IAAc;IAC1D,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,GAAG,CAAA,GAAG,MAAM,EAAE,CAAA;IAC5C,IAAI,MAAM,GAAQ,GAAG,CAAA,GAAG,MAAM,EAAE,CAAA;IAChC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,GAAG,GAAG,CAAA,GAAG,MAAM,KAAK,GAAG,EAAE,CAAA;IACjC,CAAC;IACD,OAAO,MAAM,CAAA;AACf,CAAC;AAED,2GAA2G;AAC3G,MAAM,UAAU,QAAQ,CAAC,MAAoB,EAAE,GAAG,IAAc;IAC9D,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,GAAG,CAAQ,GAAG,MAAM,EAAE,CAAA;IACpD,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAE,CAAC,CAAA;IACpD,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAE,CAAA;IACvC,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,gBAAgB,CAAC,CAAA;IACtD,OAAO,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAA;AACrC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"close.d.ts","sourceRoot":"","sources":["../../../src/data/temporal/close.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"close.d.ts","sourceRoot":"","sources":["../../../src/data/temporal/close.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAGjD,wBAAsB,KAAK,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,MAAM,CAAC,CA2BrE"}
|