neoorm 0.1.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.
Files changed (127) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +86 -0
  3. package/dist/bin/neoorm.d.ts +3 -0
  4. package/dist/bin/neoorm.d.ts.map +1 -0
  5. package/dist/bin/neoorm.js +111 -0
  6. package/dist/bin/neoorm.js.map +1 -0
  7. package/dist/codegen/emit-includes.d.ts +3 -0
  8. package/dist/codegen/emit-includes.d.ts.map +1 -0
  9. package/dist/codegen/emit-includes.js +133 -0
  10. package/dist/codegen/emit-includes.js.map +1 -0
  11. package/dist/codegen/generate.d.ts +24 -0
  12. package/dist/codegen/generate.d.ts.map +1 -0
  13. package/dist/codegen/generate.js +156 -0
  14. package/dist/codegen/generate.js.map +1 -0
  15. package/dist/codegen/schema-to-manifest.d.ts +8 -0
  16. package/dist/codegen/schema-to-manifest.d.ts.map +1 -0
  17. package/dist/codegen/schema-to-manifest.js +210 -0
  18. package/dist/codegen/schema-to-manifest.js.map +1 -0
  19. package/dist/config.d.ts +11 -0
  20. package/dist/config.d.ts.map +1 -0
  21. package/dist/config.js +17 -0
  22. package/dist/config.js.map +1 -0
  23. package/dist/dialect/index.d.ts +3 -0
  24. package/dist/dialect/index.d.ts.map +1 -0
  25. package/dist/dialect/index.js +2 -0
  26. package/dist/dialect/index.js.map +1 -0
  27. package/dist/dialect/postgres.d.ts +5 -0
  28. package/dist/dialect/postgres.d.ts.map +1 -0
  29. package/dist/dialect/postgres.js +112 -0
  30. package/dist/dialect/postgres.js.map +1 -0
  31. package/dist/dialect/types.d.ts +79 -0
  32. package/dist/dialect/types.d.ts.map +1 -0
  33. package/dist/dialect/types.js +2 -0
  34. package/dist/dialect/types.js.map +1 -0
  35. package/dist/index.d.ts +10 -0
  36. package/dist/index.d.ts.map +1 -0
  37. package/dist/index.js +7 -0
  38. package/dist/index.js.map +1 -0
  39. package/dist/introspect/pull.d.ts +3 -0
  40. package/dist/introspect/pull.d.ts.map +1 -0
  41. package/dist/introspect/pull.js +91 -0
  42. package/dist/introspect/pull.js.map +1 -0
  43. package/dist/migrate/runner.d.ts +9 -0
  44. package/dist/migrate/runner.d.ts.map +1 -0
  45. package/dist/migrate/runner.js +70 -0
  46. package/dist/migrate/runner.js.map +1 -0
  47. package/dist/runtime/client.d.ts +61 -0
  48. package/dist/runtime/client.d.ts.map +1 -0
  49. package/dist/runtime/client.js +54 -0
  50. package/dist/runtime/client.js.map +1 -0
  51. package/dist/runtime/executor.d.ts +10 -0
  52. package/dist/runtime/executor.d.ts.map +1 -0
  53. package/dist/runtime/executor.js +62 -0
  54. package/dist/runtime/executor.js.map +1 -0
  55. package/dist/runtime/query/compile.d.ts +23 -0
  56. package/dist/runtime/query/compile.d.ts.map +1 -0
  57. package/dist/runtime/query/compile.js +182 -0
  58. package/dist/runtime/query/compile.js.map +1 -0
  59. package/dist/runtime/query/create.d.ts +8 -0
  60. package/dist/runtime/query/create.d.ts.map +1 -0
  61. package/dist/runtime/query/create.js +139 -0
  62. package/dist/runtime/query/create.js.map +1 -0
  63. package/dist/runtime/query/delete.d.ts +12 -0
  64. package/dist/runtime/query/delete.d.ts.map +1 -0
  65. package/dist/runtime/query/delete.js +35 -0
  66. package/dist/runtime/query/delete.js.map +1 -0
  67. package/dist/runtime/query/find.d.ts +21 -0
  68. package/dist/runtime/query/find.d.ts.map +1 -0
  69. package/dist/runtime/query/find.js +172 -0
  70. package/dist/runtime/query/find.js.map +1 -0
  71. package/dist/runtime/query/update.d.ts +17 -0
  72. package/dist/runtime/query/update.d.ts.map +1 -0
  73. package/dist/runtime/query/update.js +63 -0
  74. package/dist/runtime/query/update.js.map +1 -0
  75. package/dist/runtime/types.d.ts +48 -0
  76. package/dist/runtime/types.d.ts.map +1 -0
  77. package/dist/runtime/types.js +2 -0
  78. package/dist/runtime/types.js.map +1 -0
  79. package/dist/schema/column.d.ts +39 -0
  80. package/dist/schema/column.d.ts.map +1 -0
  81. package/dist/schema/column.js +70 -0
  82. package/dist/schema/column.js.map +1 -0
  83. package/dist/schema/define-schema.d.ts +6 -0
  84. package/dist/schema/define-schema.d.ts.map +1 -0
  85. package/dist/schema/define-schema.js +4 -0
  86. package/dist/schema/define-schema.js.map +1 -0
  87. package/dist/schema/index.d.ts +13 -0
  88. package/dist/schema/index.d.ts.map +1 -0
  89. package/dist/schema/index.js +6 -0
  90. package/dist/schema/index.js.map +1 -0
  91. package/dist/schema/many-to-many.d.ts +21 -0
  92. package/dist/schema/many-to-many.d.ts.map +1 -0
  93. package/dist/schema/many-to-many.js +20 -0
  94. package/dist/schema/many-to-many.js.map +1 -0
  95. package/dist/schema/relation-types.d.ts +74 -0
  96. package/dist/schema/relation-types.d.ts.map +1 -0
  97. package/dist/schema/relation-types.js +2 -0
  98. package/dist/schema/relation-types.js.map +1 -0
  99. package/dist/schema/relation.d.ts +24 -0
  100. package/dist/schema/relation.d.ts.map +1 -0
  101. package/dist/schema/relation.js +25 -0
  102. package/dist/schema/relation.js.map +1 -0
  103. package/dist/schema/table.d.ts +28 -0
  104. package/dist/schema/table.d.ts.map +1 -0
  105. package/dist/schema/table.js +23 -0
  106. package/dist/schema/table.js.map +1 -0
  107. package/dist/schema/types.d.ts +115 -0
  108. package/dist/schema/types.d.ts.map +1 -0
  109. package/dist/schema/types.js +2 -0
  110. package/dist/schema/types.js.map +1 -0
  111. package/dist/sql/builder.d.ts +17 -0
  112. package/dist/sql/builder.d.ts.map +1 -0
  113. package/dist/sql/builder.js +51 -0
  114. package/dist/sql/builder.js.map +1 -0
  115. package/dist/sql/index.d.ts +7 -0
  116. package/dist/sql/index.d.ts.map +1 -0
  117. package/dist/sql/index.js +6 -0
  118. package/dist/sql/index.js.map +1 -0
  119. package/dist/sql/template.d.ts +16 -0
  120. package/dist/sql/template.d.ts.map +1 -0
  121. package/dist/sql/template.js +43 -0
  122. package/dist/sql/template.js.map +1 -0
  123. package/dist/utils/case.d.ts +5 -0
  124. package/dist/utils/case.d.ts.map +1 -0
  125. package/dist/utils/case.js +20 -0
  126. package/dist/utils/case.js.map +1 -0
  127. package/package.json +60 -0
@@ -0,0 +1,139 @@
1
+ import { randomUUID } from "node:crypto";
2
+ import { quoteIdentifier } from "../../dialect/postgres.js";
3
+ import { buildInsertQuery, dataToSqlValues, rowToTs, } from "./compile.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
+ async function resolveConnectOrCreate(executor, manifest, targetAccessor, items) {
10
+ const ids = [];
11
+ const targetTable = manifest.tables[targetAccessor];
12
+ if (!targetTable)
13
+ throw new Error(`Unknown table: ${targetAccessor}`);
14
+ for (const item of items) {
15
+ const whereKey = Object.keys(item.where)[0];
16
+ const whereVal = item.where[whereKey];
17
+ if (whereKey && whereVal !== undefined) {
18
+ const col = targetTable.columns.find((c) => c.tsName === whereKey);
19
+ const sqlCol = col ? quoteIdentifier(col.sqlName) : quoteIdentifier(whereKey);
20
+ const existing = await executor.queryOne(`SELECT id FROM ${quoteIdentifier(targetTable.sqlName)} WHERE ${sqlCol} = $1 LIMIT 1`, [whereVal]);
21
+ if (existing) {
22
+ ids.push(String(existing["id"]));
23
+ continue;
24
+ }
25
+ }
26
+ const createData = { ...item.create };
27
+ if (!createData["id"]) {
28
+ createData["id"] = generateId(targetAccessor);
29
+ }
30
+ const { keys, values } = dataToSqlValues(targetTable, createData);
31
+ if (!keys.includes("id")) {
32
+ keys.unshift("id");
33
+ values.unshift(createData["id"]);
34
+ }
35
+ const sql = buildInsertQuery(targetTable, keys);
36
+ const row = await executor.queryOne(sql, values);
37
+ if (row)
38
+ ids.push(String(row["id"]));
39
+ }
40
+ return ids;
41
+ }
42
+ async function insertJunctionRows(executor, manifest, throughAccessor, leftFkCol, rightFkCol, leftId, rightIds, extraData) {
43
+ const throughTable = manifest.tables[throughAccessor];
44
+ if (!throughTable)
45
+ return;
46
+ const leftCol = throughTable.columns.find((c) => c.sqlName === leftFkCol);
47
+ const rightCol = throughTable.columns.find((c) => c.sqlName === rightFkCol);
48
+ if (!leftCol || !rightCol)
49
+ return;
50
+ for (const rightId of rightIds) {
51
+ const data = {
52
+ [leftCol.tsName]: leftId,
53
+ [rightCol.tsName]: rightId,
54
+ ...extraData,
55
+ };
56
+ for (const col of throughTable.columns) {
57
+ if (col.tsName in data)
58
+ continue;
59
+ if (col.defaultNow) {
60
+ data[col.tsName] = new Date();
61
+ }
62
+ }
63
+ const { keys, values } = dataToSqlValues(throughTable, data);
64
+ const sql = buildInsertQuery(throughTable, keys);
65
+ await executor.query(sql, values);
66
+ }
67
+ }
68
+ export async function createRecord(executor, manifest, tableAccessor, args) {
69
+ const table = manifest.tables[tableAccessor];
70
+ if (!table)
71
+ throw new Error(`Unknown table: ${tableAccessor}`);
72
+ return executor.transaction(async (tx) => {
73
+ const scalarData = {};
74
+ const relationWrites = [];
75
+ for (const [key, value] of Object.entries(args.data)) {
76
+ const col = table.columns.find((c) => c.tsName === key);
77
+ if (col) {
78
+ scalarData[key] = value;
79
+ continue;
80
+ }
81
+ const rel = table.relations.find((r) => r.name === key);
82
+ if (rel && value && typeof value === "object") {
83
+ const relValue = value;
84
+ if ("connect" in relValue) {
85
+ relationWrites.push({ relationName: key, type: "connect", value: relValue["connect"] });
86
+ }
87
+ else if ("connectOrCreate" in relValue) {
88
+ relationWrites.push({
89
+ relationName: key,
90
+ type: "connectOrCreate",
91
+ value: relValue["connectOrCreate"],
92
+ });
93
+ }
94
+ }
95
+ }
96
+ if (!scalarData["id"]) {
97
+ scalarData["id"] = generateId(tableAccessor);
98
+ }
99
+ for (const write of relationWrites) {
100
+ if (write.type === "connect") {
101
+ const connect = write.value;
102
+ const rel = table.relations.find((r) => r.name === write.relationName);
103
+ if (rel && rel.cardinality === "one") {
104
+ scalarData[rel.fkColumn] = connect.id;
105
+ }
106
+ }
107
+ }
108
+ const { keys, values } = dataToSqlValues(table, scalarData);
109
+ if (!keys.includes("id")) {
110
+ keys.unshift("id");
111
+ values.unshift(scalarData["id"]);
112
+ }
113
+ const insertSql = buildInsertQuery(table, keys);
114
+ const row = await tx.queryOne(insertSql, values);
115
+ if (!row)
116
+ throw new Error("Insert failed");
117
+ const result = rowToTs(table, row);
118
+ const recordId = String(result["id"]);
119
+ for (const write of relationWrites) {
120
+ if (write.type === "connectOrCreate") {
121
+ const m2m = manifest.manyToMany.find((m) => (m.leftAccessor === tableAccessor && m.as === write.relationName) ||
122
+ (m.rightAccessor === tableAccessor && m.inverse === write.relationName));
123
+ if (m2m) {
124
+ const isLeft = m2m.leftAccessor === tableAccessor;
125
+ const targetAccessor = isLeft ? m2m.rightAccessor : m2m.leftAccessor;
126
+ const items = write.value;
127
+ const ids = await resolveConnectOrCreate(tx, manifest, targetAccessor, items);
128
+ await insertJunctionRows(tx, manifest, m2m.throughAccessor, m2m.leftFkColumn, m2m.rightFkColumn, recordId, ids);
129
+ }
130
+ }
131
+ }
132
+ if (args.with) {
133
+ const [withLoaded] = await loadRelations(tx, manifest, table, [result], args.with);
134
+ return withLoaded ?? result;
135
+ }
136
+ return result;
137
+ });
138
+ }
139
+ //# sourceMappingURL=create.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/runtime/query/create.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
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 deleteRecord(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
5
+ where: Record<string, unknown>;
6
+ with?: Record<string, WithInput>;
7
+ }): Promise<Record<string, unknown> | null>;
8
+ export declare function deleteManyRecords(executor: Executor, manifest: Manifest, tableAccessor: string, args?: {
9
+ where?: Record<string, unknown>;
10
+ }): Promise<number>;
11
+ export declare function deleteById(executor: Executor, manifest: Manifest, tableAccessor: string, id: string): Promise<Record<string, unknown> | null>;
12
+ //# sourceMappingURL=delete.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/delete.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAQ/C,OAAO,EAAiB,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AAE1D,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,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CA0BzC;AAED,wBAAsB,iBAAiB,CACrC,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,CAajB;AAED,wBAAsB,UAAU,CAC9B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,EAAE,EAAE,MAAM,GACT,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAEzC"}
@@ -0,0 +1,35 @@
1
+ import { postgresDialect } from "../../dialect/postgres.js";
2
+ import { buildDeleteQuery, buildDeleteManyQuery, compileWhere, rowToTs, } from "./compile.js";
3
+ import { loadRelations } from "./find.js";
4
+ export async function deleteRecord(executor, manifest, tableAccessor, args) {
5
+ const table = manifest.tables[tableAccessor];
6
+ if (!table)
7
+ throw new Error(`Unknown table: ${tableAccessor}`);
8
+ const { sql: whereSql, params } = compileWhere(table, args.where, postgresDialect);
9
+ if (!whereSql) {
10
+ throw new Error("Delete requires a where clause");
11
+ }
12
+ const query = buildDeleteQuery(table, whereSql);
13
+ const row = await executor.queryOne(query, params);
14
+ if (!row)
15
+ return null;
16
+ const result = rowToTs(table, row);
17
+ if (args.with) {
18
+ const [withLoaded] = await loadRelations(executor, manifest, table, [result], args.with);
19
+ return withLoaded ?? result;
20
+ }
21
+ return result;
22
+ }
23
+ export async function deleteManyRecords(executor, manifest, tableAccessor, args) {
24
+ const table = manifest.tables[tableAccessor];
25
+ if (!table)
26
+ throw new Error(`Unknown table: ${tableAccessor}`);
27
+ const { sql: whereSql, params } = compileWhere(table, args?.where, postgresDialect);
28
+ const query = buildDeleteManyQuery(table, whereSql);
29
+ const result = await executor.query(`${query} RETURNING id`, params);
30
+ return result.length;
31
+ }
32
+ export async function deleteById(executor, manifest, tableAccessor, id) {
33
+ return deleteRecord(executor, manifest, tableAccessor, { where: { id } });
34
+ }
35
+ //# sourceMappingURL=delete.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../src/runtime/query/delete.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,YAAY,EACZ,OAAO,GACR,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,aAAa,EAAkB,MAAM,WAAW,CAAC;AAE1D,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,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,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,YAAY,CAC5C,KAAK,EACL,IAAI,CAAC,KAAK,EACV,eAAe,CAChB,CAAC;IAEF,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;IACpD,CAAC;IAED,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IAChD,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACnD,IAAI,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IAEtB,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAEnC,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,MAAM,CAAC,UAAU,CAAC,GAAG,MAAM,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACzF,OAAO,UAAU,IAAI,MAAM,CAAC;IAC9B,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,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;IAEF,MAAM,KAAK,GAAG,oBAAoB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IACpD,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,KAAK,CAAC,GAAG,KAAK,eAAe,EAAE,MAAM,CAAC,CAAC;IACrE,OAAO,MAAM,CAAC,MAAM,CAAC;AACvB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,QAAkB,EAClB,QAAkB,EAClB,aAAqB,EACrB,EAAU;IAEV,OAAO,YAAY,CAAC,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AAC5E,CAAC"}
@@ -0,0 +1,21 @@
1
+ import type { Manifest, ManifestTable } from "../../dialect/types.js";
2
+ import type { Executor } from "../executor.js";
3
+ export type WithInput = boolean | {
4
+ select?: readonly string[] | Record<string, boolean | undefined>;
5
+ orderBy?: Record<string, string>;
6
+ limit?: number;
7
+ with?: Record<string, WithInput>;
8
+ };
9
+ export declare function loadRelations(executor: Executor, manifest: Manifest, table: ManifestTable, rows: Record<string, unknown>[], withSpec: Record<string, WithInput> | undefined): Promise<Record<string, unknown>[]>;
10
+ export declare function findMany(executor: Executor, manifest: Manifest, tableAccessor: string, args?: {
11
+ where?: Record<string, unknown>;
12
+ orderBy?: Record<string, string>;
13
+ limit?: number;
14
+ offset?: number;
15
+ with?: Record<string, WithInput>;
16
+ }): Promise<Record<string, unknown>[]>;
17
+ export declare function findFirst(executor: Executor, manifest: Manifest, tableAccessor: string, args?: Parameters<typeof findMany>[3]): Promise<Record<string, unknown> | null>;
18
+ export declare function findById(executor: Executor, manifest: Manifest, tableAccessor: string, id: string, args?: {
19
+ with?: Record<string, WithInput>;
20
+ }): Promise<Record<string, unknown> | null>;
21
+ //# sourceMappingURL=find.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"find.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/find.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAwC,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAC5G,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAY/C,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG;IAChC,MAAM,CAAC,EAAE,SAAS,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IACjE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,CAAC;AA0MF,wBAAsB,aAAa,CACjC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,aAAa,EACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,EAC/B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,SAAS,GAC9C,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAQpC;AAED,wBAAsB,QAAQ,CAC5B,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;IAChC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAqBpC;AAED,wBAAsB,SAAS,CAC7B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,CAAC,EAAE,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,GACpC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAMzC;AAED,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,EAAE,EAAE,MAAM,EACV,IAAI,CAAC,EAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAA;CAAE,GAC1C,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAazC"}
@@ -0,0 +1,172 @@
1
+ import { postgresDialect, quoteIdentifier } from "../../dialect/postgres.js";
2
+ import { buildFindManyQuery, buildSelectColumns, compileOrderBy, compileWhere, normalizeSelectColumns, rowToTs, rowsToTs, } from "./compile.js";
3
+ function columnsForSelect(table, withSpec) {
4
+ const nestedSpec = typeof withSpec === "object" ? withSpec : undefined;
5
+ const selectKeys = normalizeSelectColumns(nestedSpec?.select);
6
+ return buildSelectColumns(table, selectKeys ? [...selectKeys] : undefined);
7
+ }
8
+ function findM2M(manifest, tableAccessor, relationName) {
9
+ return manifest.manyToMany.find((m) => (m.leftAccessor === tableAccessor && m.as === relationName) ||
10
+ (m.rightAccessor === tableAccessor && m.inverse === relationName));
11
+ }
12
+ function findRelation(table, name) {
13
+ return table.relations.find((r) => r.name === name);
14
+ }
15
+ function isM2MRelation(manifest, tableAccessor, relationName) {
16
+ return findM2M(manifest, tableAccessor, relationName) !== undefined;
17
+ }
18
+ async function loadOneRelation(executor, manifest, parentTable, parentRows, relationName, withSpec) {
19
+ if (parentRows.length === 0)
20
+ return;
21
+ const m2m = findM2M(manifest, parentTable.accessor, relationName);
22
+ if (m2m) {
23
+ await loadM2MRelation(executor, manifest, parentTable, parentRows, m2m, relationName, withSpec);
24
+ return;
25
+ }
26
+ const relation = findRelation(parentTable, relationName);
27
+ if (!relation)
28
+ return;
29
+ const targetTable = manifest.tables[relation.targetAccessor];
30
+ if (!targetTable)
31
+ return;
32
+ const parentIds = parentRows.map((r) => r["id"]).filter(Boolean);
33
+ if (relation.cardinality === "one") {
34
+ const fkValues = parentRows
35
+ .map((r) => r[relation.fkColumn])
36
+ .filter((v) => v != null);
37
+ if (fkValues.length === 0)
38
+ return;
39
+ const placeholders = fkValues.map((_, i) => `$${i + 1}`).join(", ");
40
+ const idCol = quoteIdentifier("id");
41
+ const selectCols = columnsForSelect(targetTable, withSpec);
42
+ const rows = await executor.query(`SELECT ${selectCols} FROM ${quoteIdentifier(targetTable.sqlName)} WHERE ${idCol} IN (${placeholders})`, fkValues);
43
+ const mapped = rowsToTs(targetTable, rows);
44
+ const byId = new Map(mapped.map((r) => [r["id"], r]));
45
+ for (const parent of parentRows) {
46
+ const fkVal = parent[relation.fkColumn];
47
+ parent[relationName] = fkVal != null ? byId.get(fkVal) ?? null : null;
48
+ }
49
+ }
50
+ else {
51
+ const fkCol = quoteIdentifier(relation.fkSqlColumn);
52
+ const placeholders = parentIds.map((_, i) => `$${i + 1}`).join(", ");
53
+ const selectCols = columnsForSelect(targetTable, withSpec);
54
+ let sql = `SELECT ${selectCols} FROM ${quoteIdentifier(targetTable.sqlName)} WHERE ${fkCol} IN (${placeholders})`;
55
+ const nestedSpec = typeof withSpec === "object" ? withSpec : undefined;
56
+ if (nestedSpec?.orderBy) {
57
+ sql += ` ${compileOrderBy(targetTable, nestedSpec.orderBy)}`;
58
+ }
59
+ if (nestedSpec?.limit !== undefined) {
60
+ sql += ` LIMIT ${nestedSpec.limit}`;
61
+ }
62
+ const rows = await executor.query(sql, parentIds);
63
+ const mapped = rowsToTs(targetTable, rows);
64
+ const grouped = new Map();
65
+ for (const row of mapped) {
66
+ const fkVal = String(row[relation.fkColumn] ?? row[relation.fkSqlColumn.replace(/_([a-z])/g, (_, c) => c.toUpperCase())]);
67
+ const fkKey = Object.keys(row).find((k) => k.endsWith("Id") && row[k] === fkVal) ?? relation.fkColumn;
68
+ const parentFk = row[fkKey] ?? row[relation.fkColumn];
69
+ const key = String(parentFk);
70
+ if (!grouped.has(key))
71
+ grouped.set(key, []);
72
+ grouped.get(key).push(row);
73
+ }
74
+ for (const parent of parentRows) {
75
+ const id = String(parent["id"]);
76
+ parent[relationName] = grouped.get(id) ?? [];
77
+ }
78
+ if (nestedSpec?.with) {
79
+ for (const childRows of grouped.values()) {
80
+ for (const [nestedName, nestedWith] of Object.entries(nestedSpec.with)) {
81
+ await loadOneRelation(executor, manifest, targetTable, childRows, nestedName, nestedWith);
82
+ }
83
+ }
84
+ }
85
+ }
86
+ const nestedSpec = typeof withSpec === "object" ? withSpec : undefined;
87
+ if (nestedSpec?.with && relation.cardinality === "one") {
88
+ const childRows = parentRows
89
+ .map((p) => p[relationName])
90
+ .filter((r) => r != null && typeof r === "object");
91
+ for (const [nestedName, nestedWith] of Object.entries(nestedSpec.with)) {
92
+ await loadOneRelation(executor, manifest, targetTable, childRows, nestedName, nestedWith);
93
+ }
94
+ }
95
+ }
96
+ async function loadM2MRelation(executor, manifest, parentTable, parentRows, m2m, relationName, withSpec) {
97
+ const isLeft = m2m.leftAccessor === parentTable.accessor;
98
+ const targetAccessor = isLeft ? m2m.rightAccessor : m2m.leftAccessor;
99
+ const targetTable = manifest.tables[targetAccessor];
100
+ const throughTable = manifest.tables[m2m.throughAccessor];
101
+ if (!targetTable || !throughTable)
102
+ return;
103
+ const parentFkCol = isLeft ? m2m.leftFkColumn : m2m.rightFkColumn;
104
+ const targetFkCol = isLeft ? m2m.rightFkColumn : m2m.leftFkColumn;
105
+ const parentIds = parentRows.map((r) => r["id"]).filter(Boolean);
106
+ if (parentIds.length === 0)
107
+ return;
108
+ const placeholders = parentIds.map((_, i) => `$${i + 1}`).join(", ");
109
+ const selectCols = targetTable.columns
110
+ .map((c) => quoteIdentifier(c.sqlName))
111
+ .join(", ");
112
+ const sql = `
113
+ SELECT t.*, j.${quoteIdentifier(parentFkCol)} AS _parent_id
114
+ FROM ${quoteIdentifier(throughTable.sqlName)} j
115
+ JOIN ${quoteIdentifier(targetTable.sqlName)} t ON t.${quoteIdentifier("id")} = j.${quoteIdentifier(targetFkCol)}
116
+ WHERE j.${quoteIdentifier(parentFkCol)} IN (${placeholders})
117
+ `.trim();
118
+ const rows = await executor.query(sql, parentIds);
119
+ const grouped = new Map();
120
+ for (const row of rows) {
121
+ const parentId = String(row["_parent_id"]);
122
+ const mapped = rowToTs(targetTable, row);
123
+ if (!grouped.has(parentId))
124
+ grouped.set(parentId, []);
125
+ grouped.get(parentId).push(mapped);
126
+ }
127
+ for (const parent of parentRows) {
128
+ const id = String(parent["id"]);
129
+ parent[relationName] = grouped.get(id) ?? [];
130
+ }
131
+ }
132
+ export async function loadRelations(executor, manifest, table, rows, withSpec) {
133
+ if (!withSpec || rows.length === 0)
134
+ return rows;
135
+ for (const [relationName, spec] of Object.entries(withSpec)) {
136
+ await loadOneRelation(executor, manifest, table, rows, relationName, spec);
137
+ }
138
+ return rows;
139
+ }
140
+ export async function findMany(executor, manifest, tableAccessor, args) {
141
+ const table = manifest.tables[tableAccessor];
142
+ if (!table)
143
+ throw new Error(`Unknown table: ${tableAccessor}`);
144
+ const { sql: whereSql, params } = compileWhere(table, args?.where, postgresDialect);
145
+ const orderSql = compileOrderBy(table, args?.orderBy);
146
+ const query = buildFindManyQuery(table, whereSql, orderSql, args?.limit, args?.offset);
147
+ const rows = await executor.query(query, params);
148
+ const mapped = rowsToTs(table, rows);
149
+ return loadRelations(executor, manifest, table, mapped, args?.with);
150
+ }
151
+ export async function findFirst(executor, manifest, tableAccessor, args) {
152
+ const rows = await findMany(executor, manifest, tableAccessor, {
153
+ ...args,
154
+ limit: 1,
155
+ });
156
+ return rows[0] ?? null;
157
+ }
158
+ export async function findById(executor, manifest, tableAccessor, id, args) {
159
+ const table = manifest.tables[tableAccessor];
160
+ if (!table)
161
+ throw new Error(`Unknown table: ${tableAccessor}`);
162
+ const findArgs = {
163
+ where: { id },
164
+ limit: 1,
165
+ };
166
+ if (args?.with !== undefined) {
167
+ findArgs.with = args.with;
168
+ }
169
+ const rows = await findMany(executor, manifest, tableAccessor, findArgs);
170
+ return rows[0] ?? null;
171
+ }
172
+ //# sourceMappingURL=find.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"find.js","sourceRoot":"","sources":["../../../src/runtime/query/find.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
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 updateRecord(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
5
+ where: Record<string, unknown>;
6
+ data: Record<string, unknown>;
7
+ with?: Record<string, WithInput>;
8
+ }): Promise<Record<string, unknown> | null>;
9
+ export declare function updateManyRecords(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
10
+ where?: Record<string, unknown>;
11
+ data: Record<string, unknown>;
12
+ }): Promise<number>;
13
+ export declare function updateById(executor: Executor, manifest: Manifest, tableAccessor: string, id: string, args: {
14
+ data: Record<string, unknown>;
15
+ with?: Record<string, WithInput>;
16
+ }): Promise<Record<string, unknown> | null>;
17
+ //# sourceMappingURL=update.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/update.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAS/C,OAAO,EAAiB,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AAE1D,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,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAgDzC;AAED,wBAAsB,iBAAiB,CACrC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE;IACJ,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC/B,GACA,OAAO,CAAC,MAAM,CAAC,CAkBjB;AAED,wBAAsB,UAAU,CAC9B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE;IACJ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAMzC"}
@@ -0,0 +1,63 @@
1
+ import { postgresDialect } from "../../dialect/postgres.js";
2
+ import { buildUpdateQuery, buildUpdateManyQuery, compileWhere, dataToSqlValues, rowToTs, } from "./compile.js";
3
+ import { loadRelations } from "./find.js";
4
+ export async function updateRecord(executor, manifest, tableAccessor, args) {
5
+ const table = manifest.tables[tableAccessor];
6
+ if (!table)
7
+ throw new Error(`Unknown table: ${tableAccessor}`);
8
+ const scalarData = {};
9
+ for (const [key, value] of Object.entries(args.data)) {
10
+ const col = table.columns.find((c) => c.tsName === key);
11
+ if (col) {
12
+ scalarData[key] = value;
13
+ }
14
+ else {
15
+ const rel = table.relations.find((r) => r.name === key);
16
+ if (rel && value && typeof value === "object" && "connect" in value) {
17
+ const connect = value.connect;
18
+ if (rel.cardinality === "one") {
19
+ scalarData[rel.fkColumn] = connect.id;
20
+ }
21
+ }
22
+ }
23
+ }
24
+ const { keys, values } = dataToSqlValues(table, scalarData);
25
+ if (keys.length === 0) {
26
+ throw new Error("Update requires at least one scalar field");
27
+ }
28
+ const { sql: whereSql, params: whereParams } = compileWhere(table, args.where, postgresDialect);
29
+ if (!whereSql) {
30
+ throw new Error("Update requires a where clause");
31
+ }
32
+ const query = buildUpdateQuery(table, keys, whereSql);
33
+ const row = await executor.queryOne(query, [...values, ...whereParams]);
34
+ if (!row)
35
+ return null;
36
+ const result = rowToTs(table, row);
37
+ if (args.with) {
38
+ const [withLoaded] = await loadRelations(executor, manifest, table, [result], args.with);
39
+ return withLoaded ?? result;
40
+ }
41
+ return result;
42
+ }
43
+ export async function updateManyRecords(executor, manifest, tableAccessor, args) {
44
+ const table = manifest.tables[tableAccessor];
45
+ if (!table)
46
+ throw new Error(`Unknown table: ${tableAccessor}`);
47
+ const { keys, values } = dataToSqlValues(table, args.data);
48
+ if (keys.length === 0) {
49
+ throw new Error("Update requires at least one scalar field");
50
+ }
51
+ const { sql: whereSql, params: whereParams } = compileWhere(table, args.where, postgresDialect);
52
+ const query = buildUpdateManyQuery(table, keys, whereSql);
53
+ const result = await executor.query(`${query} RETURNING id`, [...values, ...whereParams]);
54
+ return result.length;
55
+ }
56
+ export async function updateById(executor, manifest, tableAccessor, id, args) {
57
+ return updateRecord(executor, manifest, tableAccessor, {
58
+ where: { id },
59
+ data: args.data,
60
+ ...(args.with !== undefined ? { with: args.with } : {}),
61
+ });
62
+ }
63
+ //# sourceMappingURL=update.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update.js","sourceRoot":"","sources":["../../../src/runtime/query/update.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,48 @@
1
+ import type { TableDef } from "../schema/table.js";
2
+ import type { CreateArgs, DeleteArgs, DeleteManyArgs, FindManyArgs, InferSelectRow, UpdateArgs, UpdateInput, UpdateManyArgs, WithInputMap } from "../schema/types.js";
3
+ /** Query args with an explicit generated `with` type (better IDE autocomplete) */
4
+ export type FindManyArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<FindManyArgs<TSchema, TAccessor>, "with"> & {
5
+ with?: TWith;
6
+ };
7
+ export type FindFirstArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = FindManyArgsWith<TSchema, TAccessor, TWith>;
8
+ export type FindByIdArgsWith<TWith> = {
9
+ with?: TWith;
10
+ };
11
+ export type CreateArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<CreateArgs<TSchema, TAccessor>, "with"> & {
12
+ with?: TWith;
13
+ };
14
+ export type UpdateArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<UpdateArgs<TSchema, TAccessor>, "with"> & {
15
+ with?: TWith;
16
+ };
17
+ export type DeleteArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<DeleteArgs<TSchema, TAccessor>, "with"> & {
18
+ with?: TWith;
19
+ };
20
+ export type DefaultWithMap<TTables extends Record<string, TableDef>> = {
21
+ [K in keyof TTables & string]: WithInputMap<TTables, K>;
22
+ };
23
+ export type TypedTableRepository<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith = WithInputMap<TSchema, TAccessor>> = {
24
+ findMany(args?: FindManyArgsWith<TSchema, TAccessor, TWith>): Promise<Array<InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>>>;
25
+ findFirst(args?: FindFirstArgsWith<TSchema, TAccessor, TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
26
+ findById(id: string, args?: FindByIdArgsWith<TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
27
+ create(args: CreateArgsWith<TSchema, TAccessor, TWith>): Promise<InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>>;
28
+ update(args: UpdateArgsWith<TSchema, TAccessor, TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
29
+ updateMany(args: UpdateManyArgs<TSchema, TAccessor>): Promise<number>;
30
+ updateById(id: string, args: {
31
+ data: UpdateInput<TSchema[TAccessor]["_columns"]>;
32
+ with?: TWith;
33
+ }): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
34
+ delete(args: DeleteArgsWith<TSchema, TAccessor, TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
35
+ deleteMany(args?: DeleteManyArgs<TSchema, TAccessor>): Promise<number>;
36
+ deleteById(id: string): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
37
+ };
38
+ export type TypedNeoOrmClient<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>> = {
39
+ sql<T = Record<string, unknown>>(strings: TemplateStringsArray, ...values: unknown[]): Promise<T[]>;
40
+ execute(query: {
41
+ text: string;
42
+ params: unknown[];
43
+ }): Promise<Record<string, unknown>[]>;
44
+ $disconnect(): Promise<void>;
45
+ } & {
46
+ [K in keyof TTables & string]: TypedTableRepository<TTables, K, TIncludes[K]>;
47
+ };
48
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/runtime/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/runtime/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,39 @@
1
+ export type ColumnKind = "id" | "text" | "bool" | "int" | "timestamp" | "fk";
2
+ export type ColumnMeta = {
3
+ kind: ColumnKind;
4
+ nullable: boolean;
5
+ unique: boolean;
6
+ primary: boolean;
7
+ defaultValue?: unknown;
8
+ defaultNow: boolean;
9
+ };
10
+ export type ColumnBuilder<TValue, TMeta extends ColumnMeta = ColumnMeta> = {
11
+ readonly _type: TValue;
12
+ readonly _meta: TMeta;
13
+ notNull(): ColumnBuilder<TValue, Omit<TMeta, "nullable"> & {
14
+ nullable: false;
15
+ }>;
16
+ unique(): ColumnBuilder<TValue, Omit<TMeta, "unique"> & {
17
+ unique: true;
18
+ }>;
19
+ default(value: TValue): ColumnBuilder<TValue, Omit<TMeta, "defaultValue"> & {
20
+ defaultValue: TValue;
21
+ }>;
22
+ defaultNow(): ColumnBuilder<TValue, Omit<TMeta, "defaultNow"> & {
23
+ defaultNow: true;
24
+ }>;
25
+ primary(): ColumnBuilder<TValue, Omit<TMeta, "primary"> & {
26
+ primary: true;
27
+ }>;
28
+ };
29
+ export declare const id: {
30
+ primary(): ColumnBuilder<string, ColumnMeta & {
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>;
39
+ //# sourceMappingURL=column.d.ts.map