semola 0.5.2 → 0.5.3

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 (262) hide show
  1. package/README.md +88 -13
  2. package/dist/cron/builder/index.cjs +166 -0
  3. package/dist/cron/builder/index.d.cts +28 -0
  4. package/dist/cron/builder/index.d.cts.map +1 -0
  5. package/dist/cron/builder/index.d.mts +28 -0
  6. package/dist/cron/builder/index.d.mts.map +1 -0
  7. package/dist/cron/builder/index.mjs +163 -0
  8. package/dist/cron/builder/index.mjs.map +1 -0
  9. package/dist/cron/builder/types.cjs +27 -0
  10. package/dist/cron/builder/types.d.cts +79 -0
  11. package/dist/cron/builder/types.d.cts.map +1 -0
  12. package/dist/cron/builder/types.d.mts +79 -0
  13. package/dist/cron/builder/types.d.mts.map +1 -0
  14. package/dist/cron/builder/types.mjs +28 -0
  15. package/dist/cron/builder/types.mjs.map +1 -0
  16. package/dist/cron/core/index.cjs +308 -0
  17. package/dist/cron/core/index.d.cts +39 -0
  18. package/dist/cron/core/index.d.cts.map +1 -0
  19. package/dist/cron/core/index.d.mts +39 -0
  20. package/dist/cron/core/index.d.mts.map +1 -0
  21. package/dist/cron/core/index.mjs +310 -0
  22. package/dist/cron/core/index.mjs.map +1 -0
  23. package/dist/cron/{scanner.cjs → core/scanner.cjs} +2 -2
  24. package/dist/cron/{scanner.mjs → core/scanner.mjs} +2 -2
  25. package/dist/cron/core/scanner.mjs.map +1 -0
  26. package/dist/cron/{types.d.cts → core/types.d.cts} +1 -1
  27. package/dist/cron/core/types.d.cts.map +1 -0
  28. package/dist/cron/{types.d.mts → core/types.d.mts} +1 -1
  29. package/dist/cron/core/types.d.mts.map +1 -0
  30. package/dist/errors/types.d.cts +1 -1
  31. package/dist/errors/types.d.mts +1 -1
  32. package/dist/lib/cache/index.d.cts +3 -3
  33. package/dist/lib/cache/index.d.mts +3 -3
  34. package/dist/lib/cron/index.cjs +12 -275
  35. package/dist/lib/cron/index.d.cts +4 -39
  36. package/dist/lib/cron/index.d.mts +4 -39
  37. package/dist/lib/cron/index.mjs +4 -277
  38. package/dist/lib/errors/index.d.cts +2 -2
  39. package/dist/lib/errors/index.d.cts.map +1 -1
  40. package/dist/lib/errors/index.d.mts +2 -2
  41. package/dist/lib/errors/index.d.mts.map +1 -1
  42. package/dist/lib/errors/index.mjs.map +1 -1
  43. package/dist/lib/i18n/index.cjs +6 -1
  44. package/dist/lib/i18n/index.d.cts.map +1 -1
  45. package/dist/lib/i18n/index.d.mts.map +1 -1
  46. package/dist/lib/i18n/index.mjs +6 -1
  47. package/dist/lib/i18n/index.mjs.map +1 -1
  48. package/dist/lib/logging/index.cjs +18 -0
  49. package/dist/lib/logging/index.d.cts +7 -0
  50. package/dist/lib/logging/index.d.mts +7 -0
  51. package/dist/lib/logging/index.mjs +5 -0
  52. package/dist/lib/orm/index.cjs +20 -0
  53. package/dist/lib/orm/index.d.cts +7 -0
  54. package/dist/lib/orm/index.d.mts +7 -0
  55. package/dist/lib/orm/index.mjs +6 -0
  56. package/dist/lib/prompts/index.d.cts +8 -8
  57. package/dist/lib/prompts/index.d.mts +8 -8
  58. package/dist/lib/pubsub/index.cjs +82 -13
  59. package/dist/lib/pubsub/index.d.cts +14 -5
  60. package/dist/lib/pubsub/index.d.cts.map +1 -1
  61. package/dist/lib/pubsub/index.d.mts +14 -5
  62. package/dist/lib/pubsub/index.d.mts.map +1 -1
  63. package/dist/lib/pubsub/index.mjs +82 -13
  64. package/dist/lib/pubsub/index.mjs.map +1 -1
  65. package/dist/lib/queue/index.d.cts +2 -2
  66. package/dist/lib/queue/index.d.mts +2 -2
  67. package/dist/lib/workflow/index.cjs +534 -0
  68. package/dist/lib/workflow/index.d.cts +7 -0
  69. package/dist/lib/workflow/index.d.cts.map +1 -0
  70. package/dist/lib/workflow/index.d.mts +7 -0
  71. package/dist/lib/workflow/index.d.mts.map +1 -0
  72. package/dist/lib/workflow/index.mjs +535 -0
  73. package/dist/lib/workflow/index.mjs.map +1 -0
  74. package/dist/logging/core/index.cjs +99 -0
  75. package/dist/logging/core/index.d.cts +26 -0
  76. package/dist/logging/core/index.d.cts.map +1 -0
  77. package/dist/logging/core/index.d.mts +26 -0
  78. package/dist/logging/core/index.d.mts.map +1 -0
  79. package/dist/logging/core/index.mjs +99 -0
  80. package/dist/logging/core/index.mjs.map +1 -0
  81. package/dist/logging/core/types.cjs +10 -0
  82. package/dist/logging/core/types.d.cts +22 -0
  83. package/dist/logging/core/types.d.cts.map +1 -0
  84. package/dist/logging/core/types.d.mts +22 -0
  85. package/dist/logging/core/types.d.mts.map +1 -0
  86. package/dist/logging/core/types.mjs +12 -0
  87. package/dist/logging/core/types.mjs.map +1 -0
  88. package/dist/logging/formatter/index.cjs +119 -0
  89. package/dist/logging/formatter/index.d.cts +27 -0
  90. package/dist/logging/formatter/index.d.cts.map +1 -0
  91. package/dist/logging/formatter/index.d.mts +27 -0
  92. package/dist/logging/formatter/index.d.mts.map +1 -0
  93. package/dist/logging/formatter/index.mjs +115 -0
  94. package/dist/logging/formatter/index.mjs.map +1 -0
  95. package/dist/logging/formatter/types.d.cts +5 -0
  96. package/dist/logging/formatter/types.d.cts.map +1 -0
  97. package/dist/logging/formatter/types.d.mts +5 -0
  98. package/dist/logging/formatter/types.d.mts.map +1 -0
  99. package/dist/logging/provider/index.cjs +165 -0
  100. package/dist/logging/provider/index.d.cts +28 -0
  101. package/dist/logging/provider/index.d.cts.map +1 -0
  102. package/dist/logging/provider/index.d.mts +28 -0
  103. package/dist/logging/provider/index.d.mts.map +1 -0
  104. package/dist/logging/provider/index.mjs +165 -0
  105. package/dist/logging/provider/index.mjs.map +1 -0
  106. package/dist/logging/provider/types.d.cts +23 -0
  107. package/dist/logging/provider/types.d.cts.map +1 -0
  108. package/dist/logging/provider/types.d.mts +23 -0
  109. package/dist/logging/provider/types.d.mts.map +1 -0
  110. package/dist/orm/column.cjs +137 -0
  111. package/dist/orm/column.d.cts +121 -0
  112. package/dist/orm/column.d.cts.map +1 -0
  113. package/dist/orm/column.d.mts +121 -0
  114. package/dist/orm/column.d.mts.map +1 -0
  115. package/dist/orm/column.mjs +132 -0
  116. package/dist/orm/column.mjs.map +1 -0
  117. package/dist/orm/dialect/index.cjs +14 -0
  118. package/dist/orm/dialect/index.mjs +16 -0
  119. package/dist/orm/dialect/index.mjs.map +1 -0
  120. package/dist/orm/dialect/mysql.cjs +31 -0
  121. package/dist/orm/dialect/mysql.mjs +33 -0
  122. package/dist/orm/dialect/mysql.mjs.map +1 -0
  123. package/dist/orm/dialect/postgres.cjs +23 -0
  124. package/dist/orm/dialect/postgres.mjs +25 -0
  125. package/dist/orm/dialect/postgres.mjs.map +1 -0
  126. package/dist/orm/dialect/sqlite.cjs +31 -0
  127. package/dist/orm/dialect/sqlite.mjs +33 -0
  128. package/dist/orm/dialect/sqlite.mjs.map +1 -0
  129. package/dist/orm/dialect/utils.cjs +8 -0
  130. package/dist/orm/dialect/utils.mjs +10 -0
  131. package/dist/orm/dialect/utils.mjs.map +1 -0
  132. package/dist/orm/internal/table-columns.cjs +31 -0
  133. package/dist/orm/internal/table-columns.mjs +32 -0
  134. package/dist/orm/internal/table-columns.mjs.map +1 -0
  135. package/dist/orm/internal/table-lookup.cjs +35 -0
  136. package/dist/orm/internal/table-lookup.mjs +35 -0
  137. package/dist/orm/internal/table-lookup.mjs.map +1 -0
  138. package/dist/orm/internal/table-relations.cjs +28 -0
  139. package/dist/orm/internal/table-relations.mjs +29 -0
  140. package/dist/orm/internal/table-relations.mjs.map +1 -0
  141. package/dist/orm/migration/config.cjs +7 -0
  142. package/dist/orm/migration/config.d.cts +7 -0
  143. package/dist/orm/migration/config.d.cts.map +1 -0
  144. package/dist/orm/migration/config.d.mts +7 -0
  145. package/dist/orm/migration/config.d.mts.map +1 -0
  146. package/dist/orm/migration/config.mjs +8 -0
  147. package/dist/orm/migration/config.mjs.map +1 -0
  148. package/dist/orm/migration/types.d.cts +20 -0
  149. package/dist/orm/migration/types.d.cts.map +1 -0
  150. package/dist/orm/migration/types.d.mts +20 -0
  151. package/dist/orm/migration/types.d.mts.map +1 -0
  152. package/dist/orm/orm.cjs +41 -0
  153. package/dist/orm/orm.d.cts +18 -0
  154. package/dist/orm/orm.d.cts.map +1 -0
  155. package/dist/orm/orm.d.mts +18 -0
  156. package/dist/orm/orm.d.mts.map +1 -0
  157. package/dist/orm/orm.mjs +43 -0
  158. package/dist/orm/orm.mjs.map +1 -0
  159. package/dist/orm/relation.cjs +18 -0
  160. package/dist/orm/relation.d.cts +8 -0
  161. package/dist/orm/relation.d.cts.map +1 -0
  162. package/dist/orm/relation.d.mts +8 -0
  163. package/dist/orm/relation.d.mts.map +1 -0
  164. package/dist/orm/relation.mjs +19 -0
  165. package/dist/orm/relation.mjs.map +1 -0
  166. package/dist/orm/runtime/builders/mutations.cjs +29 -0
  167. package/dist/orm/runtime/builders/mutations.mjs +28 -0
  168. package/dist/orm/runtime/builders/mutations.mjs.map +1 -0
  169. package/dist/orm/runtime/builders/select.cjs +18 -0
  170. package/dist/orm/runtime/builders/select.mjs +19 -0
  171. package/dist/orm/runtime/builders/select.mjs.map +1 -0
  172. package/dist/orm/runtime/client.cjs +90 -0
  173. package/dist/orm/runtime/client.mjs +92 -0
  174. package/dist/orm/runtime/client.mjs.map +1 -0
  175. package/dist/orm/runtime/context.cjs +49 -0
  176. package/dist/orm/runtime/context.mjs +51 -0
  177. package/dist/orm/runtime/context.mjs.map +1 -0
  178. package/dist/orm/runtime/dialect/index.cjs +11 -0
  179. package/dist/orm/runtime/dialect/index.mjs +13 -0
  180. package/dist/orm/runtime/dialect/index.mjs.map +1 -0
  181. package/dist/orm/runtime/dialect/mysql.cjs +95 -0
  182. package/dist/orm/runtime/dialect/mysql.mjs +97 -0
  183. package/dist/orm/runtime/dialect/mysql.mjs.map +1 -0
  184. package/dist/orm/runtime/dialect/postgres.cjs +51 -0
  185. package/dist/orm/runtime/dialect/postgres.mjs +53 -0
  186. package/dist/orm/runtime/dialect/postgres.mjs.map +1 -0
  187. package/dist/orm/runtime/dialect/sqlite.cjs +4 -0
  188. package/dist/orm/runtime/dialect/sqlite.mjs +7 -0
  189. package/dist/orm/runtime/dialect/sqlite.mjs.map +1 -0
  190. package/dist/orm/runtime/errors.cjs +19 -0
  191. package/dist/orm/runtime/errors.mjs +21 -0
  192. package/dist/orm/runtime/errors.mjs.map +1 -0
  193. package/dist/orm/runtime/hydrate/many.cjs +46 -0
  194. package/dist/orm/runtime/hydrate/many.mjs +48 -0
  195. package/dist/orm/runtime/hydrate/many.mjs.map +1 -0
  196. package/dist/orm/runtime/hydrate/one.cjs +38 -0
  197. package/dist/orm/runtime/hydrate/one.mjs +40 -0
  198. package/dist/orm/runtime/hydrate/one.mjs.map +1 -0
  199. package/dist/orm/runtime/hydrate.cjs +49 -0
  200. package/dist/orm/runtime/hydrate.mjs +51 -0
  201. package/dist/orm/runtime/hydrate.mjs.map +1 -0
  202. package/dist/orm/runtime/rows.cjs +30 -0
  203. package/dist/orm/runtime/rows.mjs +31 -0
  204. package/dist/orm/runtime/rows.mjs.map +1 -0
  205. package/dist/orm/runtime/utils.cjs +27 -0
  206. package/dist/orm/runtime/utils.mjs +27 -0
  207. package/dist/orm/runtime/utils.mjs.map +1 -0
  208. package/dist/orm/sql/parse-array.cjs +64 -0
  209. package/dist/orm/sql/parse-array.mjs +66 -0
  210. package/dist/orm/sql/parse-array.mjs.map +1 -0
  211. package/dist/orm/sql/plan/select.cjs +36 -0
  212. package/dist/orm/sql/plan/select.mjs +38 -0
  213. package/dist/orm/sql/plan/select.mjs.map +1 -0
  214. package/dist/orm/sql/plan/where/operators.cjs +95 -0
  215. package/dist/orm/sql/plan/where/operators.mjs +97 -0
  216. package/dist/orm/sql/plan/where/operators.mjs.map +1 -0
  217. package/dist/orm/sql/plan/where.cjs +59 -0
  218. package/dist/orm/sql/plan/where.mjs +61 -0
  219. package/dist/orm/sql/plan/where.mjs.map +1 -0
  220. package/dist/orm/sql/serialize/clauses.cjs +36 -0
  221. package/dist/orm/sql/serialize/clauses.mjs +37 -0
  222. package/dist/orm/sql/serialize/clauses.mjs.map +1 -0
  223. package/dist/orm/sql/serialize/joins.cjs +31 -0
  224. package/dist/orm/sql/serialize/joins.mjs +33 -0
  225. package/dist/orm/sql/serialize/joins.mjs.map +1 -0
  226. package/dist/orm/sql/serialize/values.cjs +30 -0
  227. package/dist/orm/sql/serialize/values.mjs +32 -0
  228. package/dist/orm/sql/serialize/values.mjs.map +1 -0
  229. package/dist/orm/sql/serialize/where/predicate.cjs +73 -0
  230. package/dist/orm/sql/serialize/where/predicate.mjs +75 -0
  231. package/dist/orm/sql/serialize/where/predicate.mjs.map +1 -0
  232. package/dist/orm/sql/serialize/where/tree.cjs +26 -0
  233. package/dist/orm/sql/serialize/where/tree.mjs +28 -0
  234. package/dist/orm/sql/serialize/where/tree.mjs.map +1 -0
  235. package/dist/orm/sql/serialize/where.cjs +10 -0
  236. package/dist/orm/sql/serialize/where.mjs +12 -0
  237. package/dist/orm/sql/serialize/where.mjs.map +1 -0
  238. package/dist/orm/sql/serialize.cjs +24 -0
  239. package/dist/orm/sql/serialize.mjs +25 -0
  240. package/dist/orm/sql/serialize.mjs.map +1 -0
  241. package/dist/orm/table.cjs +12 -0
  242. package/dist/orm/table.d.cts +12 -0
  243. package/dist/orm/table.d.cts.map +1 -0
  244. package/dist/orm/table.d.mts +12 -0
  245. package/dist/orm/table.d.mts.map +1 -0
  246. package/dist/orm/table.mjs +14 -0
  247. package/dist/orm/table.mjs.map +1 -0
  248. package/dist/orm/types.d.cts +183 -0
  249. package/dist/orm/types.d.cts.map +1 -0
  250. package/dist/orm/types.d.mts +183 -0
  251. package/dist/orm/types.d.mts.map +1 -0
  252. package/dist/workflow/types.d.cts +83 -0
  253. package/dist/workflow/types.d.cts.map +1 -0
  254. package/dist/workflow/types.d.mts +83 -0
  255. package/dist/workflow/types.d.mts.map +1 -0
  256. package/package.json +29 -3
  257. package/dist/cron/scanner.mjs.map +0 -1
  258. package/dist/cron/types.d.cts.map +0 -1
  259. package/dist/cron/types.d.mts.map +0 -1
  260. package/dist/lib/cron/index.d.cts.map +0 -1
  261. package/dist/lib/cron/index.d.mts.map +0 -1
  262. package/dist/lib/cron/index.mjs.map +0 -1
@@ -0,0 +1,53 @@
1
+ import { expectSingleRow } from "../utils.mjs";
2
+ //#region src/lib/orm/runtime/dialect/postgres.ts
3
+ function createPostgresRuntimeDialect() {
4
+ return {
5
+ async create(context, input) {
6
+ const rows = await context.executeOrThrow(context.insertReturning({
7
+ data: input.data,
8
+ returning: true
9
+ }));
10
+ return expectSingleRow(context.normalizeResultRows(rows), "Insert returned no rows");
11
+ },
12
+ async createMany(context, input) {
13
+ if (input.data.length === 0) return {
14
+ count: 0,
15
+ rows: []
16
+ };
17
+ const rows = input.data.map((item) => context.mapSqlRow(item));
18
+ const createdRows = await context.executeOrThrow(context.insertManyReturning(rows));
19
+ const normalizedRows = context.normalizeResultRows(createdRows);
20
+ return {
21
+ count: normalizedRows.length,
22
+ rows: normalizedRows
23
+ };
24
+ },
25
+ async updateMany(context, input) {
26
+ const rows = await context.executeOrThrow(context.updateReturning({
27
+ where: input.where,
28
+ data: input.data,
29
+ returning: true
30
+ }));
31
+ const normalizedRows = context.normalizeResultRows(rows);
32
+ return {
33
+ count: normalizedRows.length,
34
+ rows: normalizedRows
35
+ };
36
+ },
37
+ async deleteMany(context, input) {
38
+ const rows = await context.executeOrThrow(context.deleteReturning({
39
+ where: input.where,
40
+ returning: true
41
+ }));
42
+ const normalizedRows = context.normalizeResultRows(rows);
43
+ return {
44
+ count: normalizedRows.length,
45
+ rows: normalizedRows
46
+ };
47
+ }
48
+ };
49
+ }
50
+ //#endregion
51
+ export { createPostgresRuntimeDialect };
52
+
53
+ //# sourceMappingURL=postgres.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postgres.mjs","names":[],"sources":["../../../../src/lib/orm/runtime/dialect/postgres.ts"],"sourcesContent":["import type { ColDefs, RelationDefs } from \"../../types.js\";\nimport type { RuntimeDialect } from \"./types.js\";\nimport { expectSingleRow } from \"./utils.js\";\n\nexport function createPostgresRuntimeDialect<\n T extends ColDefs,\n TRels extends RelationDefs,\n>(): RuntimeDialect<T, TRels> {\n return {\n async create(context, input) {\n const rows = await context.executeOrThrow(\n context.insertReturning({ data: input.data, returning: true }),\n );\n\n return expectSingleRow(\n context.normalizeResultRows(rows),\n \"Insert returned no rows\",\n );\n },\n\n async createMany(context, input) {\n if (input.data.length === 0) {\n return { count: 0, rows: [] };\n }\n\n const rows = input.data.map((item) =>\n context.mapSqlRow(item as Record<string, unknown>),\n );\n\n const createdRows = await context.executeOrThrow(\n context.insertManyReturning(rows),\n );\n\n const normalizedRows = context.normalizeResultRows(createdRows);\n\n return {\n count: normalizedRows.length,\n rows: normalizedRows,\n };\n },\n\n async updateMany(context, input) {\n const rows = await context.executeOrThrow(\n context.updateReturning({\n where: input.where,\n data: input.data,\n returning: true,\n }),\n );\n\n const normalizedRows = context.normalizeResultRows(rows);\n\n return {\n count: normalizedRows.length,\n rows: normalizedRows,\n };\n },\n\n async deleteMany(context, input) {\n const rows = await context.executeOrThrow(\n context.deleteReturning({ where: input.where, returning: true }),\n );\n\n const normalizedRows = context.normalizeResultRows(rows);\n\n return {\n count: normalizedRows.length,\n rows: normalizedRows,\n };\n },\n };\n}\n"],"mappings":";;AAIA,SAAgB,+BAGc;AAC5B,QAAO;EACL,MAAM,OAAO,SAAS,OAAO;GAC3B,MAAM,OAAO,MAAM,QAAQ,eACzB,QAAQ,gBAAgB;IAAE,MAAM,MAAM;IAAM,WAAW;IAAM,CAAC,CAC/D;AAED,UAAO,gBACL,QAAQ,oBAAoB,KAAK,EACjC,0BACD;;EAGH,MAAM,WAAW,SAAS,OAAO;AAC/B,OAAI,MAAM,KAAK,WAAW,EACxB,QAAO;IAAE,OAAO;IAAG,MAAM,EAAE;IAAE;GAG/B,MAAM,OAAO,MAAM,KAAK,KAAK,SAC3B,QAAQ,UAAU,KAAgC,CACnD;GAED,MAAM,cAAc,MAAM,QAAQ,eAChC,QAAQ,oBAAoB,KAAK,CAClC;GAED,MAAM,iBAAiB,QAAQ,oBAAoB,YAAY;AAE/D,UAAO;IACL,OAAO,eAAe;IACtB,MAAM;IACP;;EAGH,MAAM,WAAW,SAAS,OAAO;GAC/B,MAAM,OAAO,MAAM,QAAQ,eACzB,QAAQ,gBAAgB;IACtB,OAAO,MAAM;IACb,MAAM,MAAM;IACZ,WAAW;IACZ,CAAC,CACH;GAED,MAAM,iBAAiB,QAAQ,oBAAoB,KAAK;AAExD,UAAO;IACL,OAAO,eAAe;IACtB,MAAM;IACP;;EAGH,MAAM,WAAW,SAAS,OAAO;GAC/B,MAAM,OAAO,MAAM,QAAQ,eACzB,QAAQ,gBAAgB;IAAE,OAAO,MAAM;IAAO,WAAW;IAAM,CAAC,CACjE;GAED,MAAM,iBAAiB,QAAQ,oBAAoB,KAAK;AAExD,UAAO;IACL,OAAO,eAAe;IACtB,MAAM;IACP;;EAEJ"}
@@ -0,0 +1,4 @@
1
+ //#region src/lib/orm/runtime/dialect/sqlite.ts
2
+ const createSqliteRuntimeDialect = require("./postgres.cjs").createPostgresRuntimeDialect;
3
+ //#endregion
4
+ exports.createSqliteRuntimeDialect = createSqliteRuntimeDialect;
@@ -0,0 +1,7 @@
1
+ import { createPostgresRuntimeDialect } from "./postgres.mjs";
2
+ //#region src/lib/orm/runtime/dialect/sqlite.ts
3
+ const createSqliteRuntimeDialect = createPostgresRuntimeDialect;
4
+ //#endregion
5
+ export { createSqliteRuntimeDialect };
6
+
7
+ //# sourceMappingURL=sqlite.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sqlite.mjs","names":[],"sources":["../../../../src/lib/orm/runtime/dialect/sqlite.ts"],"sourcesContent":["import { createPostgresRuntimeDialect } from \"./postgres.js\";\n\nexport const createSqliteRuntimeDialect = createPostgresRuntimeDialect;\n"],"mappings":";;AAEA,MAAa,6BAA6B"}
@@ -0,0 +1,19 @@
1
+ const require_lib_errors_index = require("../../lib/errors/index.cjs");
2
+ require("../dialect/utils.cjs");
3
+ //#region src/lib/orm/runtime/errors.ts
4
+ function toOrmErrorMessage(errorValue) {
5
+ if (errorValue instanceof Error) return errorValue.message;
6
+ if (typeof errorValue === "object" && errorValue !== null) {
7
+ const message = Reflect.get(errorValue, "message");
8
+ if (typeof message === "string") return message;
9
+ }
10
+ return "Unknown ORM error";
11
+ }
12
+ async function executeOrThrow(promise) {
13
+ const [error, data] = await require_lib_errors_index.mightThrow(promise);
14
+ if (error !== null) throw new Error(toOrmErrorMessage(error));
15
+ if (data === null) throw new Error("ORM operation returned no data");
16
+ return data;
17
+ }
18
+ //#endregion
19
+ exports.executeOrThrow = executeOrThrow;
@@ -0,0 +1,21 @@
1
+ import { mightThrow } from "../../lib/errors/index.mjs";
2
+ import "../dialect/utils.mjs";
3
+ //#region src/lib/orm/runtime/errors.ts
4
+ function toOrmErrorMessage(errorValue) {
5
+ if (errorValue instanceof Error) return errorValue.message;
6
+ if (typeof errorValue === "object" && errorValue !== null) {
7
+ const message = Reflect.get(errorValue, "message");
8
+ if (typeof message === "string") return message;
9
+ }
10
+ return "Unknown ORM error";
11
+ }
12
+ async function executeOrThrow(promise) {
13
+ const [error, data] = await mightThrow(promise);
14
+ if (error !== null) throw new Error(toOrmErrorMessage(error));
15
+ if (data === null) throw new Error("ORM operation returned no data");
16
+ return data;
17
+ }
18
+ //#endregion
19
+ export { executeOrThrow };
20
+
21
+ //# sourceMappingURL=errors.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.mjs","names":[],"sources":["../../../src/lib/orm/runtime/errors.ts"],"sourcesContent":["import { mightThrow } from \"../../errors/index.js\";\n\nexport { inferDialectFromUrl } from \"../dialect/utils.js\";\n\nfunction toOrmErrorMessage(errorValue: unknown) {\n if (errorValue instanceof Error) {\n return errorValue.message;\n }\n\n if (typeof errorValue === \"object\" && errorValue !== null) {\n const message = Reflect.get(errorValue, \"message\");\n\n if (typeof message === \"string\") {\n return message;\n }\n }\n\n return \"Unknown ORM error\";\n}\n\nexport async function executeOrThrow<T>(promise: Promise<T>) {\n const [error, data] = await mightThrow(promise);\n\n if (error !== null) {\n throw new Error(toOrmErrorMessage(error));\n }\n\n if (data === null) {\n throw new Error(\"ORM operation returned no data\");\n }\n\n return data;\n}\n"],"mappings":";;;AAIA,SAAS,kBAAkB,YAAqB;AAC9C,KAAI,sBAAsB,MACxB,QAAO,WAAW;AAGpB,KAAI,OAAO,eAAe,YAAY,eAAe,MAAM;EACzD,MAAM,UAAU,QAAQ,IAAI,YAAY,UAAU;AAElD,MAAI,OAAO,YAAY,SACrB,QAAO;;AAIX,QAAO;;AAGT,eAAsB,eAAkB,SAAqB;CAC3D,MAAM,CAAC,OAAO,QAAQ,MAAM,WAAW,QAAQ;AAE/C,KAAI,UAAU,KACZ,OAAM,IAAI,MAAM,kBAAkB,MAAM,CAAC;AAG3C,KAAI,SAAS,KACX,OAAM,IAAI,MAAM,iCAAiC;AAGnD,QAAO"}
@@ -0,0 +1,46 @@
1
+ const require_table_lookup = require("../../internal/table-lookup.cjs");
2
+ const require_table_relations = require("../../internal/table-relations.cjs");
3
+ //#region src/lib/orm/runtime/hydrate/many.ts
4
+ async function hydrateManyRelation(options) {
5
+ const { rows, relationKey, relationForeignKey, table, targetTable, basePk, allRelations, allTables, selectWhereIn } = options;
6
+ let foreignKeySqlName = relationForeignKey;
7
+ if (!foreignKeySqlName) foreignKeySqlName = require_table_relations.findManyForeignKeyByReference(targetTable, basePk.col);
8
+ if (!foreignKeySqlName) foreignKeySqlName = require_table_relations.inferManyForeignKeyFromInverse(table, targetTable, allRelations, allTables);
9
+ if (!foreignKeySqlName) {
10
+ for (const row of rows) Reflect.set(row, relationKey, []);
11
+ return;
12
+ }
13
+ const targetFk = require_table_lookup.findColumnBySqlName(targetTable, foreignKeySqlName);
14
+ if (!targetFk) {
15
+ for (const row of rows) Reflect.set(row, relationKey, []);
16
+ return;
17
+ }
18
+ const baseIds = [];
19
+ for (const row of rows) {
20
+ const id = Reflect.get(row, basePk.jsKey);
21
+ if (id === null || id === void 0) continue;
22
+ baseIds.push(id);
23
+ }
24
+ const targetRows = await selectWhereIn(targetTable, targetFk.col.meta.sqlName, baseIds);
25
+ const grouped = /* @__PURE__ */ new Map();
26
+ for (const targetRow of targetRows) {
27
+ const sourceId = Reflect.get(targetRow, targetFk.jsKey);
28
+ if (sourceId === null || sourceId === void 0) continue;
29
+ const existing = grouped.get(sourceId);
30
+ if (!existing) {
31
+ grouped.set(sourceId, [targetRow]);
32
+ continue;
33
+ }
34
+ existing.push(targetRow);
35
+ }
36
+ for (const row of rows) {
37
+ const id = Reflect.get(row, basePk.jsKey);
38
+ if (id === null || id === void 0) {
39
+ Reflect.set(row, relationKey, []);
40
+ continue;
41
+ }
42
+ Reflect.set(row, relationKey, grouped.get(id) ?? []);
43
+ }
44
+ }
45
+ //#endregion
46
+ exports.hydrateManyRelation = hydrateManyRelation;
@@ -0,0 +1,48 @@
1
+ import { findColumnBySqlName } from "../../internal/table-lookup.mjs";
2
+ import { findManyForeignKeyByReference, inferManyForeignKeyFromInverse } from "../../internal/table-relations.mjs";
3
+ //#region src/lib/orm/runtime/hydrate/many.ts
4
+ async function hydrateManyRelation(options) {
5
+ const { rows, relationKey, relationForeignKey, table, targetTable, basePk, allRelations, allTables, selectWhereIn } = options;
6
+ let foreignKeySqlName = relationForeignKey;
7
+ if (!foreignKeySqlName) foreignKeySqlName = findManyForeignKeyByReference(targetTable, basePk.col);
8
+ if (!foreignKeySqlName) foreignKeySqlName = inferManyForeignKeyFromInverse(table, targetTable, allRelations, allTables);
9
+ if (!foreignKeySqlName) {
10
+ for (const row of rows) Reflect.set(row, relationKey, []);
11
+ return;
12
+ }
13
+ const targetFk = findColumnBySqlName(targetTable, foreignKeySqlName);
14
+ if (!targetFk) {
15
+ for (const row of rows) Reflect.set(row, relationKey, []);
16
+ return;
17
+ }
18
+ const baseIds = [];
19
+ for (const row of rows) {
20
+ const id = Reflect.get(row, basePk.jsKey);
21
+ if (id === null || id === void 0) continue;
22
+ baseIds.push(id);
23
+ }
24
+ const targetRows = await selectWhereIn(targetTable, targetFk.col.meta.sqlName, baseIds);
25
+ const grouped = /* @__PURE__ */ new Map();
26
+ for (const targetRow of targetRows) {
27
+ const sourceId = Reflect.get(targetRow, targetFk.jsKey);
28
+ if (sourceId === null || sourceId === void 0) continue;
29
+ const existing = grouped.get(sourceId);
30
+ if (!existing) {
31
+ grouped.set(sourceId, [targetRow]);
32
+ continue;
33
+ }
34
+ existing.push(targetRow);
35
+ }
36
+ for (const row of rows) {
37
+ const id = Reflect.get(row, basePk.jsKey);
38
+ if (id === null || id === void 0) {
39
+ Reflect.set(row, relationKey, []);
40
+ continue;
41
+ }
42
+ Reflect.set(row, relationKey, grouped.get(id) ?? []);
43
+ }
44
+ }
45
+ //#endregion
46
+ export { hydrateManyRelation };
47
+
48
+ //# sourceMappingURL=many.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"many.mjs","names":[],"sources":["../../../../src/lib/orm/runtime/hydrate/many.ts"],"sourcesContent":["import type { getPrimaryKeyColumn } from \"../../internal/table.js\";\nimport {\n findColumnBySqlName,\n findManyForeignKeyByReference,\n inferManyForeignKeyFromInverse,\n} from \"../../internal/table.js\";\nimport type { Table } from \"../../table.js\";\nimport type { ColDefs, RelationDefs, TableRow } from \"../../types.js\";\nimport type { SelectWhereIn } from \"./types.js\";\n\nexport async function hydrateManyRelation<T extends ColDefs>(options: {\n rows: TableRow<T>[];\n relationKey: string;\n relationForeignKey: string | undefined;\n table: Table<T>;\n targetTable: Table<ColDefs>;\n basePk: NonNullable<ReturnType<typeof getPrimaryKeyColumn>>;\n allRelations: Partial<Record<string, RelationDefs>>;\n allTables: Record<string, Table<ColDefs>>;\n selectWhereIn: SelectWhereIn;\n}) {\n const {\n rows,\n relationKey,\n relationForeignKey,\n table,\n targetTable,\n basePk,\n allRelations,\n allTables,\n selectWhereIn,\n } = options;\n\n let foreignKeySqlName: string | null | undefined = relationForeignKey;\n\n if (!foreignKeySqlName) {\n foreignKeySqlName = findManyForeignKeyByReference(targetTable, basePk.col);\n }\n\n if (!foreignKeySqlName) {\n foreignKeySqlName = inferManyForeignKeyFromInverse(\n table,\n targetTable,\n allRelations,\n allTables,\n );\n }\n\n if (!foreignKeySqlName) {\n for (const row of rows) {\n Reflect.set(row as Record<string, unknown>, relationKey, []);\n }\n\n return;\n }\n\n const targetFk = findColumnBySqlName(targetTable, foreignKeySqlName);\n\n if (!targetFk) {\n for (const row of rows) {\n Reflect.set(row as Record<string, unknown>, relationKey, []);\n }\n\n return;\n }\n\n const baseIds: unknown[] = [];\n\n for (const row of rows) {\n const id = Reflect.get(row as Record<string, unknown>, basePk.jsKey);\n\n if (id === null || id === undefined) {\n continue;\n }\n\n baseIds.push(id);\n }\n\n const targetRows = await selectWhereIn(\n targetTable,\n targetFk.col.meta.sqlName,\n baseIds,\n );\n\n const grouped = new Map<unknown, Record<string, unknown>[]>();\n\n for (const targetRow of targetRows) {\n const sourceId = Reflect.get(targetRow, targetFk.jsKey);\n\n if (sourceId === null || sourceId === undefined) {\n continue;\n }\n\n const existing = grouped.get(sourceId);\n\n if (!existing) {\n grouped.set(sourceId, [targetRow]);\n continue;\n }\n\n existing.push(targetRow);\n }\n\n for (const row of rows) {\n const id = Reflect.get(row as Record<string, unknown>, basePk.jsKey);\n\n if (id === null || id === undefined) {\n Reflect.set(row as Record<string, unknown>, relationKey, []);\n continue;\n }\n\n Reflect.set(\n row as Record<string, unknown>,\n relationKey,\n grouped.get(id) ?? [],\n );\n }\n}\n"],"mappings":";;;AAUA,eAAsB,oBAAuC,SAU1D;CACD,MAAM,EACJ,MACA,aACA,oBACA,OACA,aACA,QACA,cACA,WACA,kBACE;CAEJ,IAAI,oBAA+C;AAEnD,KAAI,CAAC,kBACH,qBAAoB,8BAA8B,aAAa,OAAO,IAAI;AAG5E,KAAI,CAAC,kBACH,qBAAoB,+BAClB,OACA,aACA,cACA,UACD;AAGH,KAAI,CAAC,mBAAmB;AACtB,OAAK,MAAM,OAAO,KAChB,SAAQ,IAAI,KAAgC,aAAa,EAAE,CAAC;AAG9D;;CAGF,MAAM,WAAW,oBAAoB,aAAa,kBAAkB;AAEpE,KAAI,CAAC,UAAU;AACb,OAAK,MAAM,OAAO,KAChB,SAAQ,IAAI,KAAgC,aAAa,EAAE,CAAC;AAG9D;;CAGF,MAAM,UAAqB,EAAE;AAE7B,MAAK,MAAM,OAAO,MAAM;EACtB,MAAM,KAAK,QAAQ,IAAI,KAAgC,OAAO,MAAM;AAEpE,MAAI,OAAO,QAAQ,OAAO,KAAA,EACxB;AAGF,UAAQ,KAAK,GAAG;;CAGlB,MAAM,aAAa,MAAM,cACvB,aACA,SAAS,IAAI,KAAK,SAClB,QACD;CAED,MAAM,0BAAU,IAAI,KAAyC;AAE7D,MAAK,MAAM,aAAa,YAAY;EAClC,MAAM,WAAW,QAAQ,IAAI,WAAW,SAAS,MAAM;AAEvD,MAAI,aAAa,QAAQ,aAAa,KAAA,EACpC;EAGF,MAAM,WAAW,QAAQ,IAAI,SAAS;AAEtC,MAAI,CAAC,UAAU;AACb,WAAQ,IAAI,UAAU,CAAC,UAAU,CAAC;AAClC;;AAGF,WAAS,KAAK,UAAU;;AAG1B,MAAK,MAAM,OAAO,MAAM;EACtB,MAAM,KAAK,QAAQ,IAAI,KAAgC,OAAO,MAAM;AAEpE,MAAI,OAAO,QAAQ,OAAO,KAAA,GAAW;AACnC,WAAQ,IAAI,KAAgC,aAAa,EAAE,CAAC;AAC5D;;AAGF,UAAQ,IACN,KACA,aACA,QAAQ,IAAI,GAAG,IAAI,EAAE,CACtB"}
@@ -0,0 +1,38 @@
1
+ const require_table_lookup = require("../../internal/table-lookup.cjs");
2
+ //#region src/lib/orm/runtime/hydrate/one.ts
3
+ async function hydrateOneRelation(options) {
4
+ const { rows, relationKey, relationForeignKey, table, targetTable, selectWhereIn } = options;
5
+ const targetPk = require_table_lookup.getPrimaryKeyColumn(targetTable);
6
+ if (!targetPk) {
7
+ for (const row of rows) Reflect.set(row, relationKey, null);
8
+ return;
9
+ }
10
+ const sourceFk = require_table_lookup.findColumnBySqlName(table, relationForeignKey);
11
+ if (!sourceFk) {
12
+ for (const row of rows) Reflect.set(row, relationKey, null);
13
+ return;
14
+ }
15
+ const fkValues = /* @__PURE__ */ new Set();
16
+ for (const row of rows) {
17
+ const value = Reflect.get(row, sourceFk.jsKey);
18
+ if (value === null || value === void 0) continue;
19
+ fkValues.add(value);
20
+ }
21
+ const targetRows = await selectWhereIn(targetTable, targetPk.col.meta.sqlName, Array.from(fkValues));
22
+ const byPk = /* @__PURE__ */ new Map();
23
+ for (const targetRow of targetRows) {
24
+ const key = Reflect.get(targetRow, targetPk.jsKey);
25
+ if (key === null || key === void 0) continue;
26
+ byPk.set(key, targetRow);
27
+ }
28
+ for (const row of rows) {
29
+ const sourceKey = Reflect.get(row, sourceFk.jsKey);
30
+ if (sourceKey === null || sourceKey === void 0) {
31
+ Reflect.set(row, relationKey, null);
32
+ continue;
33
+ }
34
+ Reflect.set(row, relationKey, byPk.get(sourceKey) ?? null);
35
+ }
36
+ }
37
+ //#endregion
38
+ exports.hydrateOneRelation = hydrateOneRelation;
@@ -0,0 +1,40 @@
1
+ import { findColumnBySqlName, getPrimaryKeyColumn } from "../../internal/table-lookup.mjs";
2
+ //#region src/lib/orm/runtime/hydrate/one.ts
3
+ async function hydrateOneRelation(options) {
4
+ const { rows, relationKey, relationForeignKey, table, targetTable, selectWhereIn } = options;
5
+ const targetPk = getPrimaryKeyColumn(targetTable);
6
+ if (!targetPk) {
7
+ for (const row of rows) Reflect.set(row, relationKey, null);
8
+ return;
9
+ }
10
+ const sourceFk = findColumnBySqlName(table, relationForeignKey);
11
+ if (!sourceFk) {
12
+ for (const row of rows) Reflect.set(row, relationKey, null);
13
+ return;
14
+ }
15
+ const fkValues = /* @__PURE__ */ new Set();
16
+ for (const row of rows) {
17
+ const value = Reflect.get(row, sourceFk.jsKey);
18
+ if (value === null || value === void 0) continue;
19
+ fkValues.add(value);
20
+ }
21
+ const targetRows = await selectWhereIn(targetTable, targetPk.col.meta.sqlName, Array.from(fkValues));
22
+ const byPk = /* @__PURE__ */ new Map();
23
+ for (const targetRow of targetRows) {
24
+ const key = Reflect.get(targetRow, targetPk.jsKey);
25
+ if (key === null || key === void 0) continue;
26
+ byPk.set(key, targetRow);
27
+ }
28
+ for (const row of rows) {
29
+ const sourceKey = Reflect.get(row, sourceFk.jsKey);
30
+ if (sourceKey === null || sourceKey === void 0) {
31
+ Reflect.set(row, relationKey, null);
32
+ continue;
33
+ }
34
+ Reflect.set(row, relationKey, byPk.get(sourceKey) ?? null);
35
+ }
36
+ }
37
+ //#endregion
38
+ export { hydrateOneRelation };
39
+
40
+ //# sourceMappingURL=one.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"one.mjs","names":[],"sources":["../../../../src/lib/orm/runtime/hydrate/one.ts"],"sourcesContent":["import {\n findColumnBySqlName,\n getPrimaryKeyColumn,\n} from \"../../internal/table.js\";\nimport type { Table } from \"../../table.js\";\nimport type { ColDefs, TableRow } from \"../../types.js\";\nimport type { SelectWhereIn } from \"./types.js\";\n\nexport async function hydrateOneRelation<T extends ColDefs>(options: {\n rows: TableRow<T>[];\n relationKey: string;\n relationForeignKey: string;\n table: Table<T>;\n targetTable: Table<ColDefs>;\n selectWhereIn: SelectWhereIn;\n}) {\n const {\n rows,\n relationKey,\n relationForeignKey,\n table,\n targetTable,\n selectWhereIn,\n } = options;\n\n const targetPk = getPrimaryKeyColumn(targetTable);\n\n if (!targetPk) {\n for (const row of rows) {\n Reflect.set(row as Record<string, unknown>, relationKey, null);\n }\n\n return;\n }\n\n const sourceFk = findColumnBySqlName(table, relationForeignKey);\n\n if (!sourceFk) {\n for (const row of rows) {\n Reflect.set(row as Record<string, unknown>, relationKey, null);\n }\n\n return;\n }\n\n const fkValues = new Set<unknown>();\n\n for (const row of rows) {\n const value = Reflect.get(row as Record<string, unknown>, sourceFk.jsKey);\n\n if (value === null || value === undefined) {\n continue;\n }\n\n fkValues.add(value);\n }\n\n const targetRows = await selectWhereIn(\n targetTable,\n targetPk.col.meta.sqlName,\n Array.from(fkValues),\n );\n\n const byPk = new Map<unknown, Record<string, unknown>>();\n\n for (const targetRow of targetRows) {\n const key = Reflect.get(targetRow, targetPk.jsKey);\n\n if (key === null || key === undefined) {\n continue;\n }\n\n byPk.set(key, targetRow);\n }\n\n for (const row of rows) {\n const sourceKey = Reflect.get(\n row as Record<string, unknown>,\n sourceFk.jsKey,\n );\n\n if (sourceKey === null || sourceKey === undefined) {\n Reflect.set(row as Record<string, unknown>, relationKey, null);\n continue;\n }\n\n Reflect.set(\n row as Record<string, unknown>,\n relationKey,\n byPk.get(sourceKey) ?? null,\n );\n }\n}\n"],"mappings":";;AAQA,eAAsB,mBAAsC,SAOzD;CACD,MAAM,EACJ,MACA,aACA,oBACA,OACA,aACA,kBACE;CAEJ,MAAM,WAAW,oBAAoB,YAAY;AAEjD,KAAI,CAAC,UAAU;AACb,OAAK,MAAM,OAAO,KAChB,SAAQ,IAAI,KAAgC,aAAa,KAAK;AAGhE;;CAGF,MAAM,WAAW,oBAAoB,OAAO,mBAAmB;AAE/D,KAAI,CAAC,UAAU;AACb,OAAK,MAAM,OAAO,KAChB,SAAQ,IAAI,KAAgC,aAAa,KAAK;AAGhE;;CAGF,MAAM,2BAAW,IAAI,KAAc;AAEnC,MAAK,MAAM,OAAO,MAAM;EACtB,MAAM,QAAQ,QAAQ,IAAI,KAAgC,SAAS,MAAM;AAEzE,MAAI,UAAU,QAAQ,UAAU,KAAA,EAC9B;AAGF,WAAS,IAAI,MAAM;;CAGrB,MAAM,aAAa,MAAM,cACvB,aACA,SAAS,IAAI,KAAK,SAClB,MAAM,KAAK,SAAS,CACrB;CAED,MAAM,uBAAO,IAAI,KAAuC;AAExD,MAAK,MAAM,aAAa,YAAY;EAClC,MAAM,MAAM,QAAQ,IAAI,WAAW,SAAS,MAAM;AAElD,MAAI,QAAQ,QAAQ,QAAQ,KAAA,EAC1B;AAGF,OAAK,IAAI,KAAK,UAAU;;AAG1B,MAAK,MAAM,OAAO,MAAM;EACtB,MAAM,YAAY,QAAQ,IACxB,KACA,SAAS,MACV;AAED,MAAI,cAAc,QAAQ,cAAc,KAAA,GAAW;AACjD,WAAQ,IAAI,KAAgC,aAAa,KAAK;AAC9D;;AAGF,UAAQ,IACN,KACA,aACA,KAAK,IAAI,UAAU,IAAI,KACxB"}
@@ -0,0 +1,49 @@
1
+ const require_table_columns = require("../internal/table-columns.cjs");
2
+ const require_table_lookup = require("../internal/table-lookup.cjs");
3
+ const require_many = require("./hydrate/many.cjs");
4
+ const require_one = require("./hydrate/one.cjs");
5
+ //#region src/lib/orm/runtime/hydrate.ts
6
+ function createRelationHydrator(context) {
7
+ const selectWhereIn = async (targetTable, sqlColumnName, values) => {
8
+ if (values.length === 0) return [];
9
+ const columns = require_table_columns.buildSelectColumns(context.sql, targetTable);
10
+ const rows = await context.executeOrThrow(context.sql`SELECT ${columns} FROM ${context.sql(targetTable.tableName)} WHERE ${context.sql(targetTable.tableName)}.${context.sql(sqlColumnName)} IN ${context.sql(values)}`);
11
+ return context.normalizeRowsForTable(targetTable, rows);
12
+ };
13
+ return async (rows, include) => {
14
+ if (!include) return rows;
15
+ const basePk = require_table_lookup.getPrimaryKeyColumn(context.table);
16
+ if (!basePk) return rows;
17
+ for (const [relationKey, enabled] of Object.entries(include)) {
18
+ if (enabled !== true) continue;
19
+ const relation = context.relations[relationKey];
20
+ if (!relation) continue;
21
+ const targetTable = relation.table();
22
+ if (relation.kind === "one") {
23
+ await require_one.hydrateOneRelation({
24
+ rows,
25
+ relationKey,
26
+ relationForeignKey: relation.foreignKey,
27
+ table: context.table,
28
+ targetTable,
29
+ selectWhereIn
30
+ });
31
+ continue;
32
+ }
33
+ await require_many.hydrateManyRelation({
34
+ rows,
35
+ relationKey,
36
+ relationForeignKey: relation.foreignKey,
37
+ table: context.table,
38
+ targetTable,
39
+ basePk,
40
+ allRelations: context.allRelations,
41
+ allTables: context.allTables,
42
+ selectWhereIn
43
+ });
44
+ }
45
+ return rows;
46
+ };
47
+ }
48
+ //#endregion
49
+ exports.createRelationHydrator = createRelationHydrator;
@@ -0,0 +1,51 @@
1
+ import { buildSelectColumns } from "../internal/table-columns.mjs";
2
+ import { getPrimaryKeyColumn } from "../internal/table-lookup.mjs";
3
+ import { hydrateManyRelation } from "./hydrate/many.mjs";
4
+ import { hydrateOneRelation } from "./hydrate/one.mjs";
5
+ //#region src/lib/orm/runtime/hydrate.ts
6
+ function createRelationHydrator(context) {
7
+ const selectWhereIn = async (targetTable, sqlColumnName, values) => {
8
+ if (values.length === 0) return [];
9
+ const columns = buildSelectColumns(context.sql, targetTable);
10
+ const rows = await context.executeOrThrow(context.sql`SELECT ${columns} FROM ${context.sql(targetTable.tableName)} WHERE ${context.sql(targetTable.tableName)}.${context.sql(sqlColumnName)} IN ${context.sql(values)}`);
11
+ return context.normalizeRowsForTable(targetTable, rows);
12
+ };
13
+ return async (rows, include) => {
14
+ if (!include) return rows;
15
+ const basePk = getPrimaryKeyColumn(context.table);
16
+ if (!basePk) return rows;
17
+ for (const [relationKey, enabled] of Object.entries(include)) {
18
+ if (enabled !== true) continue;
19
+ const relation = context.relations[relationKey];
20
+ if (!relation) continue;
21
+ const targetTable = relation.table();
22
+ if (relation.kind === "one") {
23
+ await hydrateOneRelation({
24
+ rows,
25
+ relationKey,
26
+ relationForeignKey: relation.foreignKey,
27
+ table: context.table,
28
+ targetTable,
29
+ selectWhereIn
30
+ });
31
+ continue;
32
+ }
33
+ await hydrateManyRelation({
34
+ rows,
35
+ relationKey,
36
+ relationForeignKey: relation.foreignKey,
37
+ table: context.table,
38
+ targetTable,
39
+ basePk,
40
+ allRelations: context.allRelations,
41
+ allTables: context.allTables,
42
+ selectWhereIn
43
+ });
44
+ }
45
+ return rows;
46
+ };
47
+ }
48
+ //#endregion
49
+ export { createRelationHydrator };
50
+
51
+ //# sourceMappingURL=hydrate.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hydrate.mjs","names":[],"sources":["../../../src/lib/orm/runtime/hydrate.ts"],"sourcesContent":["import { buildSelectColumns, getPrimaryKeyColumn } from \"../internal/table.js\";\nimport type { Table } from \"../table.js\";\nimport type {\n ColDefs,\n FindManyInput,\n RelationDefs,\n TableRow,\n} from \"../types.js\";\nimport { hydrateManyRelation } from \"./hydrate/many.js\";\nimport { hydrateOneRelation } from \"./hydrate/one.js\";\nimport type { HydratorContext } from \"./hydrate/types.js\";\n\nexport function createRelationHydrator<\n T extends ColDefs,\n TRels extends RelationDefs,\n>(context: HydratorContext<T, TRels>) {\n const selectWhereIn = async (\n targetTable: Table<ColDefs>,\n sqlColumnName: string,\n values: unknown[],\n ) => {\n if (values.length === 0) {\n return [];\n }\n\n const columns = buildSelectColumns(context.sql, targetTable);\n const rows = await context.executeOrThrow(\n context.sql`SELECT ${columns} FROM ${context.sql(targetTable.tableName)} WHERE ${context.sql(targetTable.tableName)}.${context.sql(sqlColumnName)} IN ${context.sql(values)}`,\n );\n\n return context.normalizeRowsForTable(\n targetTable,\n rows as Record<string, unknown>[],\n );\n };\n\n return async (\n rows: TableRow<T>[],\n include: FindManyInput<T, TRels>[\"include\"] | undefined,\n ) => {\n if (!include) {\n return rows;\n }\n\n const basePk = getPrimaryKeyColumn(context.table);\n\n if (!basePk) {\n return rows;\n }\n\n for (const [relationKey, enabled] of Object.entries(include)) {\n if (enabled !== true) {\n continue;\n }\n\n const relation = context.relations[relationKey as keyof TRels];\n\n if (!relation) {\n continue;\n }\n\n const targetTable = relation.table();\n\n if (relation.kind === \"one\") {\n await hydrateOneRelation({\n rows,\n relationKey,\n relationForeignKey: relation.foreignKey,\n table: context.table,\n targetTable,\n selectWhereIn,\n });\n\n continue;\n }\n\n await hydrateManyRelation({\n rows,\n relationKey,\n relationForeignKey: relation.foreignKey,\n table: context.table,\n targetTable,\n basePk,\n allRelations: context.allRelations,\n allTables: context.allTables,\n selectWhereIn,\n });\n }\n\n return rows;\n };\n}\n"],"mappings":";;;;;AAYA,SAAgB,uBAGd,SAAoC;CACpC,MAAM,gBAAgB,OACpB,aACA,eACA,WACG;AACH,MAAI,OAAO,WAAW,EACpB,QAAO,EAAE;EAGX,MAAM,UAAU,mBAAmB,QAAQ,KAAK,YAAY;EAC5D,MAAM,OAAO,MAAM,QAAQ,eACzB,QAAQ,GAAG,UAAU,QAAQ,QAAQ,QAAQ,IAAI,YAAY,UAAU,CAAC,SAAS,QAAQ,IAAI,YAAY,UAAU,CAAC,GAAG,QAAQ,IAAI,cAAc,CAAC,MAAM,QAAQ,IAAI,OAAO,GAC5K;AAED,SAAO,QAAQ,sBACb,aACA,KACD;;AAGH,QAAO,OACL,MACA,YACG;AACH,MAAI,CAAC,QACH,QAAO;EAGT,MAAM,SAAS,oBAAoB,QAAQ,MAAM;AAEjD,MAAI,CAAC,OACH,QAAO;AAGT,OAAK,MAAM,CAAC,aAAa,YAAY,OAAO,QAAQ,QAAQ,EAAE;AAC5D,OAAI,YAAY,KACd;GAGF,MAAM,WAAW,QAAQ,UAAU;AAEnC,OAAI,CAAC,SACH;GAGF,MAAM,cAAc,SAAS,OAAO;AAEpC,OAAI,SAAS,SAAS,OAAO;AAC3B,UAAM,mBAAmB;KACvB;KACA;KACA,oBAAoB,SAAS;KAC7B,OAAO,QAAQ;KACf;KACA;KACD,CAAC;AAEF;;AAGF,SAAM,oBAAoB;IACxB;IACA;IACA,oBAAoB,SAAS;IAC7B,OAAO,QAAQ;IACf;IACA;IACA,cAAc,QAAQ;IACtB,WAAW,QAAQ;IACnB;IACD,CAAC;;AAGJ,SAAO"}
@@ -0,0 +1,30 @@
1
+ const require_parse_array = require("../sql/parse-array.cjs");
2
+ //#region src/lib/orm/runtime/rows.ts
3
+ function normalizeRecordForTable(table, row) {
4
+ let normalized = null;
5
+ for (const jsKey in table.columns) {
6
+ const col = table.columns[jsKey];
7
+ if (!col) continue;
8
+ if (!col.meta.isSqlArray) continue;
9
+ const value = Reflect.get(row, jsKey);
10
+ if (Array.isArray(value)) continue;
11
+ if (typeof value !== "string") continue;
12
+ const parsed = require_parse_array.parsePostgresArrayLiteral(value);
13
+ if (!parsed) continue;
14
+ if (!normalized) normalized = { ...row };
15
+ normalized[jsKey] = parsed;
16
+ }
17
+ if (!normalized) return row;
18
+ return normalized;
19
+ }
20
+ function normalizeRows(dialect, table, rows) {
21
+ if (dialect !== "postgres") return rows;
22
+ return rows.map((row) => normalizeRecordForTable(table, row));
23
+ }
24
+ function normalizeRowsForTable(dialect, table, rows) {
25
+ if (dialect !== "postgres") return rows;
26
+ return rows.map((row) => normalizeRecordForTable(table, row));
27
+ }
28
+ //#endregion
29
+ exports.normalizeRows = normalizeRows;
30
+ exports.normalizeRowsForTable = normalizeRowsForTable;
@@ -0,0 +1,31 @@
1
+ import { parsePostgresArrayLiteral } from "../sql/parse-array.mjs";
2
+ //#region src/lib/orm/runtime/rows.ts
3
+ function normalizeRecordForTable(table, row) {
4
+ let normalized = null;
5
+ for (const jsKey in table.columns) {
6
+ const col = table.columns[jsKey];
7
+ if (!col) continue;
8
+ if (!col.meta.isSqlArray) continue;
9
+ const value = Reflect.get(row, jsKey);
10
+ if (Array.isArray(value)) continue;
11
+ if (typeof value !== "string") continue;
12
+ const parsed = parsePostgresArrayLiteral(value);
13
+ if (!parsed) continue;
14
+ if (!normalized) normalized = { ...row };
15
+ normalized[jsKey] = parsed;
16
+ }
17
+ if (!normalized) return row;
18
+ return normalized;
19
+ }
20
+ function normalizeRows(dialect, table, rows) {
21
+ if (dialect !== "postgres") return rows;
22
+ return rows.map((row) => normalizeRecordForTable(table, row));
23
+ }
24
+ function normalizeRowsForTable(dialect, table, rows) {
25
+ if (dialect !== "postgres") return rows;
26
+ return rows.map((row) => normalizeRecordForTable(table, row));
27
+ }
28
+ //#endregion
29
+ export { normalizeRows, normalizeRowsForTable };
30
+
31
+ //# sourceMappingURL=rows.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rows.mjs","names":[],"sources":["../../../src/lib/orm/runtime/rows.ts"],"sourcesContent":["import { parsePostgresArrayLiteral } from \"../sql/parse-array.js\";\nimport type { Table } from \"../table.js\";\nimport type { ColDefs, Dialect, TableRow } from \"../types.js\";\n\nfunction normalizeRecordForTable<T extends ColDefs>(\n table: Table<T>,\n row: Record<string, unknown>,\n) {\n let normalized: Record<string, unknown> | null = null;\n\n for (const jsKey in table.columns) {\n const col = table.columns[jsKey];\n\n if (!col) {\n continue;\n }\n\n if (!col.meta.isSqlArray) {\n continue;\n }\n\n const value = Reflect.get(row, jsKey);\n\n if (Array.isArray(value)) {\n continue;\n }\n\n if (typeof value !== \"string\") {\n continue;\n }\n\n const parsed = parsePostgresArrayLiteral(value);\n\n if (!parsed) {\n continue;\n }\n\n if (!normalized) {\n normalized = { ...row };\n }\n\n normalized[jsKey] = parsed;\n }\n\n if (!normalized) {\n return row;\n }\n\n return normalized;\n}\n\nexport function normalizeRows<T extends ColDefs>(\n dialect: Dialect,\n table: Table<T>,\n rows: TableRow<T>[],\n) {\n if (dialect !== \"postgres\") {\n return rows;\n }\n\n return rows.map((row) => normalizeRecordForTable(table, row) as TableRow<T>);\n}\n\nexport function normalizeRowsForTable(\n dialect: Dialect,\n table: Table<ColDefs>,\n rows: Record<string, unknown>[],\n) {\n if (dialect !== \"postgres\") {\n return rows;\n }\n\n return rows.map((row) => normalizeRecordForTable(table, row));\n}\n"],"mappings":";;AAIA,SAAS,wBACP,OACA,KACA;CACA,IAAI,aAA6C;AAEjD,MAAK,MAAM,SAAS,MAAM,SAAS;EACjC,MAAM,MAAM,MAAM,QAAQ;AAE1B,MAAI,CAAC,IACH;AAGF,MAAI,CAAC,IAAI,KAAK,WACZ;EAGF,MAAM,QAAQ,QAAQ,IAAI,KAAK,MAAM;AAErC,MAAI,MAAM,QAAQ,MAAM,CACtB;AAGF,MAAI,OAAO,UAAU,SACnB;EAGF,MAAM,SAAS,0BAA0B,MAAM;AAE/C,MAAI,CAAC,OACH;AAGF,MAAI,CAAC,WACH,cAAa,EAAE,GAAG,KAAK;AAGzB,aAAW,SAAS;;AAGtB,KAAI,CAAC,WACH,QAAO;AAGT,QAAO;;AAGT,SAAgB,cACd,SACA,OACA,MACA;AACA,KAAI,YAAY,WACd,QAAO;AAGT,QAAO,KAAK,KAAK,QAAQ,wBAAwB,OAAO,IAAI,CAAgB;;AAG9E,SAAgB,sBACd,SACA,OACA,MACA;AACA,KAAI,YAAY,WACd,QAAO;AAGT,QAAO,KAAK,KAAK,QAAQ,wBAAwB,OAAO,IAAI,CAAC"}
@@ -0,0 +1,27 @@
1
+ //#region src/lib/orm/runtime/utils.ts
2
+ async function expectSingleRow(rows, message) {
3
+ if (rows.length === 0) throw new Error(message);
4
+ const first = rows[0];
5
+ if (first === void 0) throw new Error(message);
6
+ return first;
7
+ }
8
+ function mergeRows(rows, data) {
9
+ return rows.map((row) => ({
10
+ ...row,
11
+ ...data
12
+ }));
13
+ }
14
+ function toWhereInput(value) {
15
+ const where = {};
16
+ for (const [key, entry] of Object.entries(value)) {
17
+ if (key === "__proto__") continue;
18
+ if (key === "constructor") continue;
19
+ if (key === "prototype") continue;
20
+ Reflect.set(where, key, entry);
21
+ }
22
+ return where;
23
+ }
24
+ //#endregion
25
+ exports.expectSingleRow = expectSingleRow;
26
+ exports.mergeRows = mergeRows;
27
+ exports.toWhereInput = toWhereInput;
@@ -0,0 +1,27 @@
1
+ //#region src/lib/orm/runtime/utils.ts
2
+ async function expectSingleRow(rows, message) {
3
+ if (rows.length === 0) throw new Error(message);
4
+ const first = rows[0];
5
+ if (first === void 0) throw new Error(message);
6
+ return first;
7
+ }
8
+ function mergeRows(rows, data) {
9
+ return rows.map((row) => ({
10
+ ...row,
11
+ ...data
12
+ }));
13
+ }
14
+ function toWhereInput(value) {
15
+ const where = {};
16
+ for (const [key, entry] of Object.entries(value)) {
17
+ if (key === "__proto__") continue;
18
+ if (key === "constructor") continue;
19
+ if (key === "prototype") continue;
20
+ Reflect.set(where, key, entry);
21
+ }
22
+ return where;
23
+ }
24
+ //#endregion
25
+ export { expectSingleRow, mergeRows, toWhereInput };
26
+
27
+ //# sourceMappingURL=utils.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.mjs","names":[],"sources":["../../../src/lib/orm/runtime/utils.ts"],"sourcesContent":["import type { ColDefs, TableRow, WhereInput } from \"../types.js\";\n\nexport async function expectSingleRow<T>(rows: T[], message: string) {\n if (rows.length === 0) {\n throw new Error(message);\n }\n\n const first = rows[0];\n\n if (first === undefined) {\n throw new Error(message);\n }\n\n return first;\n}\n\nexport function mergeRows<T extends ColDefs>(\n rows: TableRow<T>[],\n data: Partial<Record<string, unknown>>,\n) {\n return rows.map((row) => ({\n ...row,\n ...data,\n }));\n}\n\nexport function toWhereInput<T extends ColDefs>(value: object) {\n const where: WhereInput<T> = {};\n\n for (const [key, entry] of Object.entries(value)) {\n if (key === \"__proto__\") {\n continue;\n }\n\n if (key === \"constructor\") {\n continue;\n }\n\n if (key === \"prototype\") {\n continue;\n }\n\n Reflect.set(where, key, entry);\n }\n\n return where;\n}\n"],"mappings":";AAEA,eAAsB,gBAAmB,MAAW,SAAiB;AACnE,KAAI,KAAK,WAAW,EAClB,OAAM,IAAI,MAAM,QAAQ;CAG1B,MAAM,QAAQ,KAAK;AAEnB,KAAI,UAAU,KAAA,EACZ,OAAM,IAAI,MAAM,QAAQ;AAG1B,QAAO;;AAGT,SAAgB,UACd,MACA,MACA;AACA,QAAO,KAAK,KAAK,SAAS;EACxB,GAAG;EACH,GAAG;EACJ,EAAE;;AAGL,SAAgB,aAAgC,OAAe;CAC7D,MAAM,QAAuB,EAAE;AAE/B,MAAK,MAAM,CAAC,KAAK,UAAU,OAAO,QAAQ,MAAM,EAAE;AAChD,MAAI,QAAQ,YACV;AAGF,MAAI,QAAQ,cACV;AAGF,MAAI,QAAQ,YACV;AAGF,UAAQ,IAAI,OAAO,KAAK,MAAM;;AAGhC,QAAO"}
@@ -0,0 +1,64 @@
1
+ //#region src/lib/orm/sql/parse-array.ts
2
+ function coerceUnquotedToken(token) {
3
+ const trimmed = token.trim();
4
+ if (trimmed === "NULL") return null;
5
+ if (/^-?\d+(\.\d+)?$/.test(trimmed)) return Number(trimmed);
6
+ const lower = trimmed.toLowerCase();
7
+ if (lower === "true") return true;
8
+ if (lower === "false") return false;
9
+ return trimmed;
10
+ }
11
+ function parsePostgresArrayLiteral(value) {
12
+ const trimmed = value.trim();
13
+ if (!trimmed.startsWith("{") || !trimmed.endsWith("}")) return null;
14
+ const inner = trimmed.slice(1, -1);
15
+ if (inner.length === 0) return [];
16
+ const out = [];
17
+ let token = "";
18
+ let index = 0;
19
+ let inQuotes = false;
20
+ let tokenWasQuoted = false;
21
+ while (index < inner.length) {
22
+ const char = inner[index];
23
+ if (inQuotes) {
24
+ if (char === "\\") {
25
+ const next = inner[index + 1];
26
+ if (next) {
27
+ token += next;
28
+ index += 2;
29
+ continue;
30
+ }
31
+ }
32
+ if (char === "\"") {
33
+ inQuotes = false;
34
+ index++;
35
+ continue;
36
+ }
37
+ token += char;
38
+ index++;
39
+ continue;
40
+ }
41
+ if (char === "\"") {
42
+ inQuotes = true;
43
+ tokenWasQuoted = true;
44
+ index++;
45
+ continue;
46
+ }
47
+ if (char === ",") {
48
+ if (tokenWasQuoted) out.push(token);
49
+ else out.push(coerceUnquotedToken(token));
50
+ token = "";
51
+ tokenWasQuoted = false;
52
+ index++;
53
+ continue;
54
+ }
55
+ token += char;
56
+ index++;
57
+ }
58
+ if (inQuotes) return null;
59
+ if (tokenWasQuoted) out.push(token);
60
+ else out.push(coerceUnquotedToken(token));
61
+ return out;
62
+ }
63
+ //#endregion
64
+ exports.parsePostgresArrayLiteral = parsePostgresArrayLiteral;