neoorm 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.
- package/dist/bin/neoorm.js +0 -0
- package/dist/codegen/emit-includes.d.ts.map +1 -1
- package/dist/codegen/emit-includes.js +1 -62
- package/dist/codegen/emit-includes.js.map +1 -1
- package/dist/codegen/emit-models.d.ts +3 -0
- package/dist/codegen/emit-models.d.ts.map +1 -0
- package/dist/codegen/emit-models.js +142 -0
- package/dist/codegen/emit-models.js.map +1 -0
- package/dist/codegen/generate.d.ts +4 -2
- package/dist/codegen/generate.d.ts.map +1 -1
- package/dist/codegen/generate.js +49 -15
- package/dist/codegen/generate.js.map +1 -1
- package/dist/codegen/manifest-relations.d.ts +6 -0
- package/dist/codegen/manifest-relations.d.ts.map +1 -0
- package/dist/codegen/manifest-relations.js +70 -0
- package/dist/codegen/manifest-relations.js.map +1 -0
- package/dist/codegen/schema-to-manifest.d.ts +2 -1
- package/dist/codegen/schema-to-manifest.d.ts.map +1 -1
- package/dist/codegen/schema-to-manifest.js +12 -2
- package/dist/codegen/schema-to-manifest.js.map +1 -1
- package/dist/dialect/postgres.d.ts.map +1 -1
- package/dist/dialect/postgres.js +22 -23
- package/dist/dialect/postgres.js.map +1 -1
- package/dist/dialect/types.d.ts +4 -1
- package/dist/dialect/types.d.ts.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/introspect/pull.d.ts.map +1 -1
- package/dist/introspect/pull.js +59 -30
- package/dist/introspect/pull.js.map +1 -1
- package/dist/plugins/builtin.d.ts +11 -0
- package/dist/plugins/builtin.d.ts.map +1 -0
- package/dist/plugins/builtin.js +130 -0
- package/dist/plugins/builtin.js.map +1 -0
- package/dist/plugins/ensure-plugins.d.ts +3 -0
- package/dist/plugins/ensure-plugins.d.ts.map +1 -0
- package/dist/plugins/ensure-plugins.js +19 -0
- package/dist/plugins/ensure-plugins.js.map +1 -0
- package/dist/plugins/index.d.ts +4 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +3 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/postgis/columns.d.ts +25 -0
- package/dist/plugins/postgis/columns.d.ts.map +1 -0
- package/dist/plugins/postgis/columns.js +82 -0
- package/dist/plugins/postgis/columns.js.map +1 -0
- package/dist/plugins/postgis/geojson.d.ts +4 -0
- package/dist/plugins/postgis/geojson.d.ts.map +1 -0
- package/dist/plugins/postgis/geojson.js +22 -0
- package/dist/plugins/postgis/geojson.js.map +1 -0
- package/dist/plugins/postgis/index.d.ts +4 -0
- package/dist/plugins/postgis/index.d.ts.map +1 -0
- package/dist/plugins/postgis/index.js +6 -0
- package/dist/plugins/postgis/index.js.map +1 -0
- package/dist/plugins/postgis/operators.d.ts +5 -0
- package/dist/plugins/postgis/operators.d.ts.map +1 -0
- package/dist/plugins/postgis/operators.js +35 -0
- package/dist/plugins/postgis/operators.js.map +1 -0
- package/dist/plugins/postgis/plugin.d.ts +3 -0
- package/dist/plugins/postgis/plugin.d.ts.map +1 -0
- package/dist/plugins/postgis/plugin.js +7 -0
- package/dist/plugins/postgis/plugin.js.map +1 -0
- package/dist/plugins/registry.d.ts +10 -0
- package/dist/plugins/registry.d.ts.map +1 -0
- package/dist/plugins/registry.js +89 -0
- package/dist/plugins/registry.js.map +1 -0
- package/dist/plugins/types.d.ts +32 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +2 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/runtime/client.d.ts +17 -4
- package/dist/runtime/client.d.ts.map +1 -1
- package/dist/runtime/client.js +8 -0
- package/dist/runtime/client.js.map +1 -1
- package/dist/runtime/query/compile.d.ts +2 -0
- package/dist/runtime/query/compile.d.ts.map +1 -1
- package/dist/runtime/query/compile.js +99 -8
- package/dist/runtime/query/compile.js.map +1 -1
- package/dist/runtime/query/count.d.ts +10 -0
- package/dist/runtime/query/count.d.ts.map +1 -0
- package/dist/runtime/query/count.js +24 -0
- package/dist/runtime/query/count.js.map +1 -0
- package/dist/runtime/query/unique.d.ts +8 -0
- package/dist/runtime/query/unique.d.ts.map +1 -0
- package/dist/runtime/query/unique.js +47 -0
- package/dist/runtime/query/unique.js.map +1 -0
- package/dist/runtime/query/upsert.d.ts +10 -0
- package/dist/runtime/query/upsert.d.ts.map +1 -0
- package/dist/runtime/query/upsert.js +38 -0
- package/dist/runtime/query/upsert.js.map +1 -0
- package/dist/runtime/types.d.ts +27 -14
- package/dist/runtime/types.d.ts.map +1 -1
- package/dist/schema/column.d.ts +5 -11
- package/dist/schema/column.d.ts.map +1 -1
- package/dist/schema/column.js +7 -53
- package/dist/schema/column.js.map +1 -1
- package/dist/schema/index.d.ts +1 -1
- package/dist/schema/index.d.ts.map +1 -1
- package/dist/schema/types.d.ts +13 -0
- package/dist/schema/types.d.ts.map +1 -1
- package/dist/sql/template.d.ts.map +1 -1
- package/dist/sql/template.js.map +1 -1
- package/package.json +30 -12
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { quoteIdentifier } from "../../dialect/postgres.js";
|
|
2
|
+
import { getColumnType } from "../../plugins/registry.js";
|
|
2
3
|
function isOperatorObject(value) {
|
|
3
4
|
return (typeof value === "object" &&
|
|
4
5
|
value !== null &&
|
|
@@ -10,6 +11,33 @@ const operatorParamTransform = {
|
|
|
10
11
|
startsWith: (v) => `${String(v)}%`,
|
|
11
12
|
endsWith: (v) => `%${String(v)}`,
|
|
12
13
|
};
|
|
14
|
+
function pluginWhereOperators(col) {
|
|
15
|
+
if (col.kind === "fk")
|
|
16
|
+
return {};
|
|
17
|
+
return getColumnType(col.kind)?.whereOperators ?? {};
|
|
18
|
+
}
|
|
19
|
+
function serializeColumnValue(col, value) {
|
|
20
|
+
if (col.kind === "fk")
|
|
21
|
+
return value;
|
|
22
|
+
const plugin = getColumnType(col.kind);
|
|
23
|
+
if (plugin?.serializeValue) {
|
|
24
|
+
return plugin.serializeValue(col, value);
|
|
25
|
+
}
|
|
26
|
+
return value;
|
|
27
|
+
}
|
|
28
|
+
function buildValuePlaceholder(col, paramIndex) {
|
|
29
|
+
if (!col || col.kind === "fk")
|
|
30
|
+
return `$${paramIndex}`;
|
|
31
|
+
const plugin = getColumnType(col.kind);
|
|
32
|
+
if (plugin?.writeExpression) {
|
|
33
|
+
return plugin.writeExpression(col, paramIndex);
|
|
34
|
+
}
|
|
35
|
+
return `$${paramIndex}`;
|
|
36
|
+
}
|
|
37
|
+
function buildSetExpression(col, paramIndex) {
|
|
38
|
+
const sqlCol = quoteIdentifier(col?.sqlName ?? "");
|
|
39
|
+
return `${sqlCol} = ${buildValuePlaceholder(col, paramIndex)}`;
|
|
40
|
+
}
|
|
13
41
|
export function compileWhere(table, where, dialect, startParamIndex = 1) {
|
|
14
42
|
if (!where || Object.keys(where).length === 0) {
|
|
15
43
|
return { sql: "", params: [] };
|
|
@@ -22,13 +50,14 @@ export function compileWhere(table, where, dialect, startParamIndex = 1) {
|
|
|
22
50
|
if (!col)
|
|
23
51
|
continue;
|
|
24
52
|
const sqlCol = quoteIdentifier(col.sqlName);
|
|
53
|
+
const spatialOps = pluginWhereOperators(col);
|
|
25
54
|
if (!isOperatorObject(rawValue) || Array.isArray(rawValue)) {
|
|
26
55
|
conditions.push(dialect.whereOperators.equals(sqlCol, paramIndex));
|
|
27
|
-
params.push(rawValue);
|
|
56
|
+
params.push(serializeColumnValue(col, rawValue));
|
|
28
57
|
paramIndex++;
|
|
29
58
|
continue;
|
|
30
59
|
}
|
|
31
|
-
const hasOperator = Object.keys(rawValue).some((k) => k in dialect.whereOperators);
|
|
60
|
+
const hasOperator = Object.keys(rawValue).some((k) => k in dialect.whereOperators || k in spatialOps);
|
|
32
61
|
if (!hasOperator) {
|
|
33
62
|
conditions.push(dialect.whereOperators.equals(sqlCol, paramIndex));
|
|
34
63
|
params.push(rawValue);
|
|
@@ -36,6 +65,14 @@ export function compileWhere(table, where, dialect, startParamIndex = 1) {
|
|
|
36
65
|
continue;
|
|
37
66
|
}
|
|
38
67
|
for (const [op, value] of Object.entries(rawValue)) {
|
|
68
|
+
if (op in spatialOps) {
|
|
69
|
+
const operator = spatialOps[op];
|
|
70
|
+
const compiled = operator.compile(sqlCol, value, col, paramIndex);
|
|
71
|
+
conditions.push(compiled.sql);
|
|
72
|
+
params.push(...compiled.params);
|
|
73
|
+
paramIndex += compiled.params.length;
|
|
74
|
+
continue;
|
|
75
|
+
}
|
|
39
76
|
if (!(op in dialect.whereOperators))
|
|
40
77
|
continue;
|
|
41
78
|
const operator = op;
|
|
@@ -73,11 +110,21 @@ export function normalizeSelectColumns(select) {
|
|
|
73
110
|
.filter(([, enabled]) => enabled === true)
|
|
74
111
|
.map(([key]) => key);
|
|
75
112
|
}
|
|
113
|
+
function selectExpression(col) {
|
|
114
|
+
if (col.kind === "fk") {
|
|
115
|
+
return quoteIdentifier(col.sqlName);
|
|
116
|
+
}
|
|
117
|
+
const plugin = getColumnType(col.kind);
|
|
118
|
+
if (plugin?.selectExpression) {
|
|
119
|
+
return plugin.selectExpression(col);
|
|
120
|
+
}
|
|
121
|
+
return quoteIdentifier(col.sqlName);
|
|
122
|
+
}
|
|
76
123
|
export function buildSelectColumns(table, select) {
|
|
77
124
|
const cols = select && select.length > 0
|
|
78
125
|
? table.columns.filter((c) => select.includes(c.tsName))
|
|
79
126
|
: table.columns;
|
|
80
|
-
return cols.map((c) =>
|
|
127
|
+
return cols.map((c) => selectExpression(c)).join(", ");
|
|
81
128
|
}
|
|
82
129
|
export function buildFindByIdQuery(table, idColumn = "id") {
|
|
83
130
|
const col = table.columns.find((c) => c.tsName === idColumn);
|
|
@@ -98,19 +145,55 @@ export function buildFindManyQuery(table, whereSql, orderSql, limit, offset) {
|
|
|
98
145
|
sql += ` OFFSET ${offset}`;
|
|
99
146
|
return sql;
|
|
100
147
|
}
|
|
148
|
+
export function buildCountQuery(table, whereSql) {
|
|
149
|
+
let sql = `SELECT COUNT(*)::int AS count FROM ${quoteIdentifier(table.sqlName)}`;
|
|
150
|
+
if (whereSql)
|
|
151
|
+
sql += ` ${whereSql}`;
|
|
152
|
+
return sql;
|
|
153
|
+
}
|
|
154
|
+
export function buildUpsertQuery(table, insertKeys, updateKeys, conflictSqlColumns) {
|
|
155
|
+
const insertCols = insertKeys.map((k) => {
|
|
156
|
+
const col = table.columns.find((c) => c.tsName === k);
|
|
157
|
+
return quoteIdentifier(col?.sqlName ?? k);
|
|
158
|
+
});
|
|
159
|
+
const insertPlaceholders = insertKeys
|
|
160
|
+
.map((k, i) => {
|
|
161
|
+
const col = table.columns.find((c) => c.tsName === k);
|
|
162
|
+
return buildValuePlaceholder(col, i + 1);
|
|
163
|
+
})
|
|
164
|
+
.join(", ");
|
|
165
|
+
const selectCols = buildSelectColumns(table);
|
|
166
|
+
const conflictCols = conflictSqlColumns.map((c) => quoteIdentifier(c)).join(", ");
|
|
167
|
+
const updateSets = updateKeys.length > 0
|
|
168
|
+
? updateKeys.map((k) => {
|
|
169
|
+
const col = table.columns.find((c) => c.tsName === k);
|
|
170
|
+
const sqlCol = quoteIdentifier(col?.sqlName ?? k);
|
|
171
|
+
return `${sqlCol} = EXCLUDED.${sqlCol}`;
|
|
172
|
+
})
|
|
173
|
+
: conflictSqlColumns.map((c) => {
|
|
174
|
+
const sqlCol = quoteIdentifier(c);
|
|
175
|
+
return `${sqlCol} = EXCLUDED.${sqlCol}`;
|
|
176
|
+
});
|
|
177
|
+
return `INSERT INTO ${quoteIdentifier(table.sqlName)} (${insertCols.join(", ")}) VALUES (${insertPlaceholders}) ON CONFLICT (${conflictCols}) DO UPDATE SET ${updateSets.join(", ")} RETURNING ${selectCols}`;
|
|
178
|
+
}
|
|
101
179
|
export function buildInsertQuery(table, dataKeys) {
|
|
102
180
|
const cols = dataKeys.map((k) => {
|
|
103
181
|
const col = table.columns.find((c) => c.tsName === k);
|
|
104
182
|
return quoteIdentifier(col?.sqlName ?? k);
|
|
105
183
|
});
|
|
106
|
-
const placeholders = dataKeys
|
|
184
|
+
const placeholders = dataKeys
|
|
185
|
+
.map((k, i) => {
|
|
186
|
+
const col = table.columns.find((c) => c.tsName === k);
|
|
187
|
+
return buildValuePlaceholder(col, i + 1);
|
|
188
|
+
})
|
|
189
|
+
.join(", ");
|
|
107
190
|
const selectCols = buildSelectColumns(table);
|
|
108
191
|
return `INSERT INTO ${quoteIdentifier(table.sqlName)} (${cols.join(", ")}) VALUES (${placeholders}) RETURNING ${selectCols}`;
|
|
109
192
|
}
|
|
110
193
|
export function buildUpdateQuery(table, dataKeys, whereSql) {
|
|
111
194
|
const sets = dataKeys.map((k, i) => {
|
|
112
195
|
const col = table.columns.find((c) => c.tsName === k);
|
|
113
|
-
return
|
|
196
|
+
return buildSetExpression(col, i + 1);
|
|
114
197
|
});
|
|
115
198
|
const selectCols = buildSelectColumns(table);
|
|
116
199
|
const whereOffset = dataKeys.length;
|
|
@@ -141,7 +224,7 @@ export function buildDeleteManyQuery(table, whereSql) {
|
|
|
141
224
|
export function buildUpdateManyQuery(table, dataKeys, whereSql) {
|
|
142
225
|
const sets = dataKeys.map((k, i) => {
|
|
143
226
|
const col = table.columns.find((c) => c.tsName === k);
|
|
144
|
-
return
|
|
227
|
+
return buildSetExpression(col, i + 1);
|
|
145
228
|
});
|
|
146
229
|
const whereOffset = dataKeys.length;
|
|
147
230
|
let sql = `UPDATE ${quoteIdentifier(table.sqlName)} SET ${sets.join(", ")}`;
|
|
@@ -163,7 +246,7 @@ export function dataToSqlValues(table, data) {
|
|
|
163
246
|
if (value === undefined)
|
|
164
247
|
continue;
|
|
165
248
|
keys.push(key);
|
|
166
|
-
values.push(value);
|
|
249
|
+
values.push(serializeColumnValue(col, value));
|
|
167
250
|
}
|
|
168
251
|
return { keys, values };
|
|
169
252
|
}
|
|
@@ -171,7 +254,15 @@ export function rowToTs(table, row) {
|
|
|
171
254
|
const result = {};
|
|
172
255
|
for (const col of table.columns) {
|
|
173
256
|
if (col.sqlName in row) {
|
|
174
|
-
|
|
257
|
+
const raw = row[col.sqlName];
|
|
258
|
+
if (col.kind === "fk") {
|
|
259
|
+
result[col.tsName] = raw;
|
|
260
|
+
continue;
|
|
261
|
+
}
|
|
262
|
+
const plugin = getColumnType(col.kind);
|
|
263
|
+
result[col.tsName] = plugin?.deserializeValue
|
|
264
|
+
? plugin.deserializeValue(col, raw)
|
|
265
|
+
: raw;
|
|
175
266
|
}
|
|
176
267
|
}
|
|
177
268
|
return result;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"compile.js","sourceRoot":"","sources":["../../../src/runtime/query/compile.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"compile.js","sourceRoot":"","sources":["../../../src/runtime/query/compile.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Manifest } from "../../dialect/types.js";
|
|
2
|
+
import type { Executor } from "../executor.js";
|
|
3
|
+
export declare function countRecords(executor: Executor, manifest: Manifest, tableAccessor: string, args?: {
|
|
4
|
+
where?: Record<string, unknown>;
|
|
5
|
+
}): Promise<number>;
|
|
6
|
+
export declare function findUnique(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
|
|
7
|
+
where: Record<string, unknown>;
|
|
8
|
+
with?: Record<string, import("./find.js").WithInput>;
|
|
9
|
+
}): Promise<Record<string, unknown> | null>;
|
|
10
|
+
//# sourceMappingURL=count.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"count.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/count.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAS/C,wBAAsB,YAAY,CAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,CAAC,EAAE;IACL,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC,GACA,OAAO,CAAC,MAAM,CAAC,CAYjB;AAED,wBAAsB,UAAU,CAC9B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE;IACJ,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,WAAW,EAAE,SAAS,CAAC,CAAC;CACtD,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAUzC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { postgresDialect } from "../../dialect/postgres.js";
|
|
2
|
+
import { buildCountQuery, compileWhere, } from "./compile.js";
|
|
3
|
+
import { assertUniqueWhere } from "./unique.js";
|
|
4
|
+
import { findFirst } from "./find.js";
|
|
5
|
+
export async function countRecords(executor, manifest, tableAccessor, args) {
|
|
6
|
+
const table = manifest.tables[tableAccessor];
|
|
7
|
+
if (!table)
|
|
8
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
9
|
+
const { sql: whereSql, params } = compileWhere(table, args?.where, postgresDialect);
|
|
10
|
+
const query = buildCountQuery(table, whereSql);
|
|
11
|
+
const row = await executor.queryOne(query, params);
|
|
12
|
+
return row?.count ?? 0;
|
|
13
|
+
}
|
|
14
|
+
export async function findUnique(executor, manifest, tableAccessor, args) {
|
|
15
|
+
const table = manifest.tables[tableAccessor];
|
|
16
|
+
if (!table)
|
|
17
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
18
|
+
assertUniqueWhere(table, args.where, "findUnique");
|
|
19
|
+
return findFirst(executor, manifest, tableAccessor, {
|
|
20
|
+
where: args.where,
|
|
21
|
+
...(args.with !== undefined ? { with: args.with } : {}),
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=count.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"count.js","sourceRoot":"","sources":["../../../src/runtime/query/count.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EACL,eAAe,EACf,YAAY,GACb,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,QAAkB,EAClB,QAAkB,EAClB,aAAqB,EACrB,IAEC;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC7C,IAAI,CAAC,KAAK;QAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,aAAa,EAAE,CAAC,CAAC;IAE/D,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,YAAY,CAC5C,KAAK,EACL,IAAI,EAAE,KAAK,EACX,eAAe,CAChB,CAAC;IACF,MAAM,KAAK,GAAG,eAAe,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IAC/C,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAoB,KAAK,EAAE,MAAM,CAAC,CAAC;IACtE,OAAO,GAAG,EAAE,KAAK,IAAI,CAAC,CAAC;AACzB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,QAAkB,EAClB,QAAkB,EAClB,aAAqB,EACrB,IAGC;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC7C,IAAI,CAAC,KAAK;QAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,aAAa,EAAE,CAAC,CAAC;IAE/D,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IAEnD,OAAO,SAAS,CAAC,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE;QAClD,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,GAAG,CAAC,IAAI,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACxD,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ManifestTable } from "../../dialect/types.js";
|
|
2
|
+
export type UniqueConstraint = {
|
|
3
|
+
sqlColumns: readonly string[];
|
|
4
|
+
tsKeys: readonly string[];
|
|
5
|
+
};
|
|
6
|
+
export declare function resolveUniqueConstraint(table: ManifestTable, where: Record<string, unknown>): UniqueConstraint | null;
|
|
7
|
+
export declare function assertUniqueWhere(table: ManifestTable, where: Record<string, unknown>, operation: string): UniqueConstraint;
|
|
8
|
+
//# sourceMappingURL=unique.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"unique.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/unique.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAE5D,MAAM,MAAM,gBAAgB,GAAG;IAC7B,UAAU,EAAE,SAAS,MAAM,EAAE,CAAC;IAC9B,MAAM,EAAE,SAAS,MAAM,EAAE,CAAC;CAC3B,CAAC;AAmBF,wBAAgB,uBAAuB,CACrC,KAAK,EAAE,aAAa,EACpB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC7B,gBAAgB,GAAG,IAAI,CA8BzB;AAED,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,aAAa,EACpB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,SAAS,EAAE,MAAM,GAChB,gBAAgB,CAQlB"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
function whereKeys(where) {
|
|
2
|
+
return Object.keys(where).filter((key) => where[key] !== undefined);
|
|
3
|
+
}
|
|
4
|
+
function matchesKeys(keys, whereKeyList) {
|
|
5
|
+
return (keys.length === whereKeyList.length &&
|
|
6
|
+
keys.every((key) => whereKeyList.includes(key)));
|
|
7
|
+
}
|
|
8
|
+
function primaryKeyTsNames(table) {
|
|
9
|
+
return table.primaryKey
|
|
10
|
+
.map((sqlName) => table.columns.find((c) => c.sqlName === sqlName)?.tsName)
|
|
11
|
+
.filter((name) => name !== undefined);
|
|
12
|
+
}
|
|
13
|
+
export function resolveUniqueConstraint(table, where) {
|
|
14
|
+
const whereKeyList = whereKeys(where);
|
|
15
|
+
if (whereKeyList.length === 0)
|
|
16
|
+
return null;
|
|
17
|
+
const pkTsNames = primaryKeyTsNames(table);
|
|
18
|
+
if (matchesKeys(pkTsNames, whereKeyList)) {
|
|
19
|
+
return { sqlColumns: table.primaryKey, tsKeys: pkTsNames };
|
|
20
|
+
}
|
|
21
|
+
if (whereKeyList.length === 1) {
|
|
22
|
+
const key = whereKeyList[0];
|
|
23
|
+
const col = table.columns.find((c) => c.tsName === key);
|
|
24
|
+
if (col && (col.primary || col.unique)) {
|
|
25
|
+
return { sqlColumns: [col.sqlName], tsKeys: [col.tsName] };
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
for (const index of table.indexes) {
|
|
29
|
+
if (!index.unique)
|
|
30
|
+
continue;
|
|
31
|
+
const indexTsNames = index.columns
|
|
32
|
+
.map((sqlName) => table.columns.find((c) => c.sqlName === sqlName)?.tsName)
|
|
33
|
+
.filter((name) => name !== undefined);
|
|
34
|
+
if (matchesKeys(indexTsNames, whereKeyList)) {
|
|
35
|
+
return { sqlColumns: index.columns, tsKeys: indexTsNames };
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
export function assertUniqueWhere(table, where, operation) {
|
|
41
|
+
const constraint = resolveUniqueConstraint(table, where);
|
|
42
|
+
if (!constraint) {
|
|
43
|
+
throw new Error(`${operation} requires a unique \`where\` clause (primary key, @unique column, or composite unique index) for table "${table.accessor}"`);
|
|
44
|
+
}
|
|
45
|
+
return constraint;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=unique.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"unique.js","sourceRoot":"","sources":["../../../src/runtime/query/unique.ts"],"names":[],"mappings":"AAOA,SAAS,SAAS,CAAC,KAA8B;IAC/C,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,SAAS,CAAC,CAAC;AACtE,CAAC;AAED,SAAS,WAAW,CAAC,IAAuB,EAAE,YAA+B;IAC3E,OAAO,CACL,IAAI,CAAC,MAAM,KAAK,YAAY,CAAC,MAAM;QACnC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAChD,CAAC;AACJ,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAoB;IAC7C,OAAO,KAAK,CAAC,UAAU;SACpB,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,EAAE,MAAM,CAAC;SAC1E,MAAM,CAAC,CAAC,IAAI,EAAkB,EAAE,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC;AAC1D,CAAC;AAED,MAAM,UAAU,uBAAuB,CACrC,KAAoB,EACpB,KAA8B;IAE9B,MAAM,YAAY,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IACtC,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAE3C,MAAM,SAAS,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAC3C,IAAI,WAAW,CAAC,SAAS,EAAE,YAAY,CAAC,EAAE,CAAC;QACzC,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;IAC7D,CAAC;IAED,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,YAAY,CAAC,CAAC,CAAE,CAAC;QAC7B,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC;QACxD,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;YACvC,OAAO,EAAE,UAAU,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;QAC7D,CAAC;IACH,CAAC;IAED,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;QAClC,IAAI,CAAC,KAAK,CAAC,MAAM;YAAE,SAAS;QAE5B,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO;aAC/B,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,EAAE,MAAM,CAAC;aAC1E,MAAM,CAAC,CAAC,IAAI,EAAkB,EAAE,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC;QAExD,IAAI,WAAW,CAAC,YAAY,EAAE,YAAY,CAAC,EAAE,CAAC;YAC5C,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC;QAC7D,CAAC;IACH,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,KAAoB,EACpB,KAA8B,EAC9B,SAAiB;IAEjB,MAAM,UAAU,GAAG,uBAAuB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACzD,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,MAAM,IAAI,KAAK,CACb,GAAG,SAAS,2GAA2G,KAAK,CAAC,QAAQ,GAAG,CACzI,CAAC;IACJ,CAAC;IACD,OAAO,UAAU,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Manifest } from "../../dialect/types.js";
|
|
2
|
+
import type { Executor } from "../executor.js";
|
|
3
|
+
import { type WithInput } from "./find.js";
|
|
4
|
+
export declare function upsertRecord(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
|
|
5
|
+
where: Record<string, unknown>;
|
|
6
|
+
create: Record<string, unknown>;
|
|
7
|
+
update: Record<string, unknown>;
|
|
8
|
+
with?: Record<string, WithInput>;
|
|
9
|
+
}): Promise<Record<string, unknown>>;
|
|
10
|
+
//# sourceMappingURL=upsert.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upsert.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/upsert.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAO/C,OAAO,EAAiB,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AAO1D,wBAAsB,YAAY,CAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE;IACJ,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAuClC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { randomUUID } from "node:crypto";
|
|
2
|
+
import { buildUpsertQuery, dataToSqlValues, rowToTs, } from "./compile.js";
|
|
3
|
+
import { assertUniqueWhere } from "./unique.js";
|
|
4
|
+
import { loadRelations } from "./find.js";
|
|
5
|
+
function generateId(tableAccessor) {
|
|
6
|
+
const prefix = tableAccessor.replace(/s$/, "").slice(0, 4);
|
|
7
|
+
return `${prefix}_${randomUUID().slice(0, 8)}`;
|
|
8
|
+
}
|
|
9
|
+
export async function upsertRecord(executor, manifest, tableAccessor, args) {
|
|
10
|
+
const table = manifest.tables[tableAccessor];
|
|
11
|
+
if (!table)
|
|
12
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
13
|
+
const constraint = assertUniqueWhere(table, args.where, "upsert");
|
|
14
|
+
const createData = { ...args.create, ...args.where };
|
|
15
|
+
if (!createData["id"]) {
|
|
16
|
+
createData["id"] = generateId(tableAccessor);
|
|
17
|
+
}
|
|
18
|
+
const { keys: insertKeys, values: insertValues } = dataToSqlValues(table, createData);
|
|
19
|
+
if (!insertKeys.includes("id") && createData["id"] !== undefined) {
|
|
20
|
+
insertKeys.unshift("id");
|
|
21
|
+
insertValues.unshift(createData["id"]);
|
|
22
|
+
}
|
|
23
|
+
const updateKeys = Object.keys(args.update).filter((key) => {
|
|
24
|
+
const col = table.columns.find((c) => c.tsName === key);
|
|
25
|
+
return col !== undefined && !col.primary && args.update[key] !== undefined;
|
|
26
|
+
});
|
|
27
|
+
const upsertSql = buildUpsertQuery(table, insertKeys, updateKeys, constraint.sqlColumns);
|
|
28
|
+
const row = await executor.queryOne(upsertSql, insertValues);
|
|
29
|
+
if (!row)
|
|
30
|
+
throw new Error("Upsert failed");
|
|
31
|
+
const result = rowToTs(table, row);
|
|
32
|
+
if (args.with) {
|
|
33
|
+
const [withLoaded] = await loadRelations(executor, manifest, table, [result], args.with);
|
|
34
|
+
return withLoaded ?? result;
|
|
35
|
+
}
|
|
36
|
+
return result;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=upsert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upsert.js","sourceRoot":"","sources":["../../../src/runtime/query/upsert.ts"],"names":[],"mappings":"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"}
|
package/dist/runtime/types.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { TableDef } from "../schema/table.js";
|
|
2
|
-
import type { CreateArgs, DeleteArgs, DeleteManyArgs, FindManyArgs,
|
|
2
|
+
import type { CountArgs, CreateArgs, DeleteArgs, DeleteManyArgs, FindManyArgs, FindUniqueArgs, UpsertArgs, UpdateArgs, UpdateInput, UpdateManyArgs, WithInputMap } from "../schema/types.js";
|
|
3
3
|
/** Query args with an explicit generated `with` type (better IDE autocomplete) */
|
|
4
4
|
export type FindManyArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<FindManyArgs<TSchema, TAccessor>, "with"> & {
|
|
5
5
|
with?: TWith;
|
|
@@ -8,6 +8,13 @@ export type FindFirstArgsWith<TSchema extends Record<string, TableDef>, TAccesso
|
|
|
8
8
|
export type FindByIdArgsWith<TWith> = {
|
|
9
9
|
with?: TWith;
|
|
10
10
|
};
|
|
11
|
+
export type FindUniqueArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<FindUniqueArgs<TSchema, TAccessor>, "with"> & {
|
|
12
|
+
with?: TWith;
|
|
13
|
+
};
|
|
14
|
+
export type CountArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string> = CountArgs<TSchema, TAccessor>;
|
|
15
|
+
export type UpsertArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<UpsertArgs<TSchema, TAccessor>, "with"> & {
|
|
16
|
+
with?: TWith;
|
|
17
|
+
};
|
|
11
18
|
export type CreateArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<CreateArgs<TSchema, TAccessor>, "with"> & {
|
|
12
19
|
with?: TWith;
|
|
13
20
|
};
|
|
@@ -20,22 +27,28 @@ export type DeleteArgsWith<TSchema extends Record<string, TableDef>, TAccessor e
|
|
|
20
27
|
export type DefaultWithMap<TTables extends Record<string, TableDef>> = {
|
|
21
28
|
[K in keyof TTables & string]: WithInputMap<TTables, K>;
|
|
22
29
|
};
|
|
23
|
-
export type
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
30
|
+
export type DefaultRowPayloadMap<TTables extends Record<string, TableDef>> = {
|
|
31
|
+
[K in keyof TTables & string]: Record<string, unknown>;
|
|
32
|
+
};
|
|
33
|
+
export type TypedTableRepository<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith = WithInputMap<TSchema, TAccessor>, TRowPayload extends Record<string, unknown> = DefaultRowPayloadMap<TSchema>[TAccessor]> = {
|
|
34
|
+
findMany<W extends TWith | undefined = undefined>(args?: FindManyArgsWith<TSchema, TAccessor, W>): Promise<Array<TRowPayload>>;
|
|
35
|
+
findFirst<W extends TWith | undefined = undefined>(args?: FindFirstArgsWith<TSchema, TAccessor, W>): Promise<TRowPayload | null>;
|
|
36
|
+
findUnique<W extends TWith | undefined = undefined>(args: FindUniqueArgsWith<TSchema, TAccessor, W>): Promise<TRowPayload | null>;
|
|
37
|
+
findById<W extends TWith | undefined = undefined>(id: string, args?: FindByIdArgsWith<W>): Promise<TRowPayload | null>;
|
|
38
|
+
create<W extends TWith | undefined = undefined>(args: CreateArgsWith<TSchema, TAccessor, W>): Promise<TRowPayload>;
|
|
39
|
+
upsert<W extends TWith | undefined = undefined>(args: UpsertArgsWith<TSchema, TAccessor, W>): Promise<TRowPayload>;
|
|
40
|
+
update<W extends TWith | undefined = undefined>(args: UpdateArgsWith<TSchema, TAccessor, W>): Promise<TRowPayload | null>;
|
|
29
41
|
updateMany(args: UpdateManyArgs<TSchema, TAccessor>): Promise<number>;
|
|
30
|
-
updateById(id: string, args: {
|
|
42
|
+
updateById<W extends TWith | undefined = undefined>(id: string, args: {
|
|
31
43
|
data: UpdateInput<TSchema[TAccessor]["_columns"]>;
|
|
32
|
-
with?:
|
|
33
|
-
}): Promise<
|
|
34
|
-
delete(args: DeleteArgsWith<TSchema, TAccessor,
|
|
44
|
+
with?: W;
|
|
45
|
+
}): Promise<TRowPayload | null>;
|
|
46
|
+
delete<W extends TWith | undefined = undefined>(args: DeleteArgsWith<TSchema, TAccessor, W>): Promise<TRowPayload | null>;
|
|
35
47
|
deleteMany(args?: DeleteManyArgs<TSchema, TAccessor>): Promise<number>;
|
|
36
|
-
|
|
48
|
+
count(args?: CountArgsWith<TSchema, TAccessor>): Promise<number>;
|
|
49
|
+
deleteById(id: string): Promise<TRowPayload | null>;
|
|
37
50
|
};
|
|
38
|
-
export type TypedNeoOrmClient<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>> = {
|
|
51
|
+
export type TypedNeoOrmClient<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>, TRowPayloads extends Record<keyof TTables & string, Record<string, unknown>> = DefaultRowPayloadMap<TTables>> = {
|
|
39
52
|
sql<T = Record<string, unknown>>(strings: TemplateStringsArray, ...values: unknown[]): Promise<T[]>;
|
|
40
53
|
execute(query: {
|
|
41
54
|
text: string;
|
|
@@ -43,6 +56,6 @@ export type TypedNeoOrmClient<TTables extends Record<string, TableDef>, TInclude
|
|
|
43
56
|
}): Promise<Record<string, unknown>[]>;
|
|
44
57
|
$disconnect(): Promise<void>;
|
|
45
58
|
} & {
|
|
46
|
-
[K in keyof TTables & string]: TypedTableRepository<TTables, K, TIncludes[K]>;
|
|
59
|
+
[K in keyof TTables & string]: TypedTableRepository<TTables, K, TIncludes[K], TRowPayloads[K]>;
|
|
47
60
|
};
|
|
48
61
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/runtime/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAa,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,KAAK,EACV,UAAU,EACV,UAAU,EACV,cAAc,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/runtime/types.ts"],"names":[],"mappings":"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"}
|
package/dist/schema/column.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
export type
|
|
1
|
+
export type CoreColumnKind = "id" | "text" | "bool" | "int" | "timestamp" | "fk";
|
|
2
|
+
export type ColumnKind = CoreColumnKind | (string & {});
|
|
2
3
|
export type ColumnMeta = {
|
|
3
4
|
kind: ColumnKind;
|
|
4
5
|
nullable: boolean;
|
|
@@ -6,6 +7,7 @@ export type ColumnMeta = {
|
|
|
6
7
|
primary: boolean;
|
|
7
8
|
defaultValue?: unknown;
|
|
8
9
|
defaultNow: boolean;
|
|
10
|
+
typeOptions?: Record<string, unknown> | undefined;
|
|
9
11
|
};
|
|
10
12
|
export type ColumnBuilder<TValue, TMeta extends ColumnMeta = ColumnMeta> = {
|
|
11
13
|
readonly _type: TValue;
|
|
@@ -26,14 +28,6 @@ export type ColumnBuilder<TValue, TMeta extends ColumnMeta = ColumnMeta> = {
|
|
|
26
28
|
primary: true;
|
|
27
29
|
}>;
|
|
28
30
|
};
|
|
29
|
-
export declare
|
|
30
|
-
|
|
31
|
-
primary: true;
|
|
32
|
-
nullable: false;
|
|
33
|
-
}>;
|
|
34
|
-
};
|
|
35
|
-
export declare function text(): ColumnBuilder<string | null>;
|
|
36
|
-
export declare function bool(): ColumnBuilder<boolean | null>;
|
|
37
|
-
export declare function int(): ColumnBuilder<number | null>;
|
|
38
|
-
export declare function timestamp(): ColumnBuilder<Date | null>;
|
|
31
|
+
export declare function createColumnBuilder<TValue, TMeta extends ColumnMeta>(meta: TMeta): ColumnBuilder<TValue, TMeta>;
|
|
32
|
+
export { id, text, bool, int, timestamp } from "../plugins/builtin.js";
|
|
39
33
|
//# sourceMappingURL=column.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"column.d.ts","sourceRoot":"","sources":["../../src/schema/column.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,
|
|
1
|
+
{"version":3,"file":"column.d.ts","sourceRoot":"","sources":["../../src/schema/column.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG,IAAI,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK,GAAG,WAAW,GAAG,IAAI,CAAC;AACjF,MAAM,MAAM,UAAU,GAAG,cAAc,GAAG,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;AAExD,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,UAAU,CAAC;IACjB,QAAQ,EAAE,OAAO,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC;IACjB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,CAAC;CACnD,CAAC;AAEF,MAAM,MAAM,aAAa,CAAC,MAAM,EAAE,KAAK,SAAS,UAAU,GAAG,UAAU,IAAI;IACzE,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC;IACtB,OAAO,IAAI,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC,GAAG;QAAE,QAAQ,EAAE,KAAK,CAAA;KAAE,CAAC,CAAC;IAChF,MAAM,IAAI,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG;QAAE,MAAM,EAAE,IAAI,CAAA;KAAE,CAAC,CAAC;IAC1E,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,cAAc,CAAC,GAAG;QAAE,YAAY,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACtG,UAAU,IAAI,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,GAAG;QAAE,UAAU,EAAE,IAAI,CAAA;KAAE,CAAC,CAAC;IACtF,OAAO,IAAI,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,GAAG;QAAE,OAAO,EAAE,IAAI,CAAA;KAAE,CAAC,CAAC;CAC9E,CAAC;AAEF,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,KAAK,SAAS,UAAU,EAClE,IAAI,EAAE,KAAK,GACV,aAAa,CAAC,MAAM,EAAE,KAAK,CAAC,CA+B9B;AAED,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC"}
|