@fragno-dev/db 0.2.2 → 0.4.1

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 (587) hide show
  1. package/.turbo/turbo-build.log +404 -175
  2. package/CHANGELOG.md +109 -0
  3. package/README.md +54 -9
  4. package/dist/adapters/adapters.d.ts +23 -21
  5. package/dist/adapters/adapters.d.ts.map +1 -1
  6. package/dist/adapters/adapters.js.map +1 -1
  7. package/dist/adapters/generic-sql/driver-config.d.ts +16 -1
  8. package/dist/adapters/generic-sql/driver-config.d.ts.map +1 -1
  9. package/dist/adapters/generic-sql/driver-config.js +23 -1
  10. package/dist/adapters/generic-sql/driver-config.js.map +1 -1
  11. package/dist/adapters/generic-sql/generic-sql-adapter.d.ts +24 -9
  12. package/dist/adapters/generic-sql/generic-sql-adapter.d.ts.map +1 -1
  13. package/dist/adapters/generic-sql/generic-sql-adapter.js +60 -22
  14. package/dist/adapters/generic-sql/generic-sql-adapter.js.map +1 -1
  15. package/dist/adapters/generic-sql/generic-sql-uow-executor.js +169 -3
  16. package/dist/adapters/generic-sql/generic-sql-uow-executor.js.map +1 -1
  17. package/dist/adapters/generic-sql/migration/cold-kysely.js.map +1 -1
  18. package/dist/adapters/generic-sql/migration/dialect/mysql.js +25 -6
  19. package/dist/adapters/generic-sql/migration/dialect/mysql.js.map +1 -1
  20. package/dist/adapters/generic-sql/migration/dialect/postgres.js +7 -6
  21. package/dist/adapters/generic-sql/migration/dialect/postgres.js.map +1 -1
  22. package/dist/adapters/generic-sql/migration/dialect/sqlite.js +193 -16
  23. package/dist/adapters/generic-sql/migration/dialect/sqlite.js.map +1 -1
  24. package/dist/adapters/generic-sql/migration/executor.d.ts.map +1 -1
  25. package/dist/adapters/generic-sql/migration/executor.js +30 -3
  26. package/dist/adapters/generic-sql/migration/executor.js.map +1 -1
  27. package/dist/adapters/generic-sql/migration/prepared-migrations.d.ts.map +1 -1
  28. package/dist/adapters/generic-sql/migration/prepared-migrations.js +9 -9
  29. package/dist/adapters/generic-sql/migration/prepared-migrations.js.map +1 -1
  30. package/dist/adapters/generic-sql/migration/sql-generator.js +75 -52
  31. package/dist/adapters/generic-sql/migration/sql-generator.js.map +1 -1
  32. package/dist/adapters/generic-sql/query/create-sql-query-compiler.js +7 -6
  33. package/dist/adapters/generic-sql/query/create-sql-query-compiler.js.map +1 -1
  34. package/dist/adapters/generic-sql/query/cursor-utils.js +42 -4
  35. package/dist/adapters/generic-sql/query/cursor-utils.js.map +1 -1
  36. package/dist/adapters/generic-sql/query/db-now-sql.js +27 -0
  37. package/dist/adapters/generic-sql/query/db-now-sql.js.map +1 -0
  38. package/dist/adapters/generic-sql/query/generic-sql-uow-operation-compiler.js +32 -21
  39. package/dist/adapters/generic-sql/query/generic-sql-uow-operation-compiler.js.map +1 -1
  40. package/dist/adapters/generic-sql/query/select-builder.js +5 -3
  41. package/dist/adapters/generic-sql/query/select-builder.js.map +1 -1
  42. package/dist/adapters/generic-sql/query/sql-query-compiler.js +49 -18
  43. package/dist/adapters/generic-sql/query/sql-query-compiler.js.map +1 -1
  44. package/dist/adapters/generic-sql/query/where-builder.js +43 -29
  45. package/dist/adapters/generic-sql/query/where-builder.js.map +1 -1
  46. package/dist/adapters/generic-sql/sqlite-storage.d.ts +13 -0
  47. package/dist/adapters/generic-sql/sqlite-storage.d.ts.map +1 -0
  48. package/dist/adapters/generic-sql/sqlite-storage.js +15 -0
  49. package/dist/adapters/generic-sql/sqlite-storage.js.map +1 -0
  50. package/dist/adapters/generic-sql/uow-decoder.js +6 -2
  51. package/dist/adapters/generic-sql/uow-decoder.js.map +1 -1
  52. package/dist/adapters/generic-sql/uow-encoder.js +27 -8
  53. package/dist/adapters/generic-sql/uow-encoder.js.map +1 -1
  54. package/dist/adapters/in-memory/condition-evaluator.js +135 -0
  55. package/dist/adapters/in-memory/condition-evaluator.js.map +1 -0
  56. package/dist/adapters/in-memory/errors.d.ts +13 -0
  57. package/dist/adapters/in-memory/errors.d.ts.map +1 -0
  58. package/dist/adapters/in-memory/errors.js +23 -0
  59. package/dist/adapters/in-memory/errors.js.map +1 -0
  60. package/dist/adapters/in-memory/in-memory-adapter.d.ts +27 -0
  61. package/dist/adapters/in-memory/in-memory-adapter.d.ts.map +1 -0
  62. package/dist/adapters/in-memory/in-memory-adapter.js +196 -0
  63. package/dist/adapters/in-memory/in-memory-adapter.js.map +1 -0
  64. package/dist/adapters/in-memory/in-memory-uow.js +871 -0
  65. package/dist/adapters/in-memory/in-memory-uow.js.map +1 -0
  66. package/dist/adapters/in-memory/index.d.ts +4 -0
  67. package/dist/adapters/in-memory/index.js +4 -0
  68. package/dist/adapters/in-memory/options.d.ts +30 -0
  69. package/dist/adapters/in-memory/options.d.ts.map +1 -0
  70. package/dist/adapters/in-memory/options.js +62 -0
  71. package/dist/adapters/in-memory/options.js.map +1 -0
  72. package/dist/adapters/in-memory/reference-resolution.js +26 -0
  73. package/dist/adapters/in-memory/reference-resolution.js.map +1 -0
  74. package/dist/adapters/in-memory/sorted-array-index.js +129 -0
  75. package/dist/adapters/in-memory/sorted-array-index.js.map +1 -0
  76. package/dist/adapters/in-memory/store.js +71 -0
  77. package/dist/adapters/in-memory/store.js.map +1 -0
  78. package/dist/adapters/in-memory/value-comparison.js +28 -0
  79. package/dist/adapters/in-memory/value-comparison.js.map +1 -0
  80. package/dist/adapters/shared/from-unit-of-work-compiler.js +51 -24
  81. package/dist/adapters/shared/from-unit-of-work-compiler.js.map +1 -1
  82. package/dist/adapters/shared/uow-operation-compiler.js +11 -11
  83. package/dist/adapters/shared/uow-operation-compiler.js.map +1 -1
  84. package/dist/adapters/sql/index.d.ts +5 -0
  85. package/dist/adapters/sql/index.js +4 -0
  86. package/dist/browser/adapters/adapters.d.ts +61 -0
  87. package/dist/browser/adapters/adapters.d.ts.map +1 -0
  88. package/dist/browser/adapters/generic-sql/migration/executor.d.ts +15 -0
  89. package/dist/browser/adapters/generic-sql/migration/executor.d.ts.map +1 -0
  90. package/dist/browser/adapters/generic-sql/migration/prepared-migrations.d.ts +66 -0
  91. package/dist/browser/adapters/generic-sql/migration/prepared-migrations.d.ts.map +1 -0
  92. package/dist/browser/adapters/generic-sql/sqlite-storage.d.ts +11 -0
  93. package/dist/browser/adapters/generic-sql/sqlite-storage.d.ts.map +1 -0
  94. package/dist/browser/adapters/in-memory/in-memory-adapter.d.ts +5 -0
  95. package/dist/browser/adapters/in-memory/index.d.ts +2 -0
  96. package/dist/browser/adapters/in-memory/options.d.ts +1 -0
  97. package/dist/browser/db-fragment-definition-builder.d.ts +237 -0
  98. package/dist/browser/db-fragment-definition-builder.d.ts.map +1 -0
  99. package/dist/browser/durable-hooks.d.ts +3 -0
  100. package/dist/browser/fragments/internal-fragment.d.ts +317 -0
  101. package/dist/browser/fragments/internal-fragment.d.ts.map +1 -0
  102. package/dist/browser/fragments/internal-fragment.schema.d.ts +1 -0
  103. package/dist/browser/hooks/durable-hooks-logger.d.ts +10 -0
  104. package/dist/browser/hooks/durable-hooks-logger.d.ts.map +1 -0
  105. package/dist/browser/hooks/hooks.d.ts +146 -0
  106. package/dist/browser/hooks/hooks.d.ts.map +1 -0
  107. package/dist/browser/id.js +1 -0
  108. package/dist/browser/internal/adapter-registry.d.ts +4 -0
  109. package/dist/browser/internal/outbox-state.d.ts +2 -0
  110. package/dist/browser/mod.d.ts +15 -0
  111. package/dist/browser/mod.d.ts.map +1 -0
  112. package/dist/browser/mod.js +17 -0
  113. package/dist/browser/mod.js.map +1 -0
  114. package/dist/browser/mod2.d.ts +48 -0
  115. package/dist/browser/mod2.d.ts.map +1 -0
  116. package/dist/browser/naming/sql-naming.d.ts +19 -0
  117. package/dist/browser/naming/sql-naming.d.ts.map +1 -0
  118. package/dist/browser/outbox/outbox.d.ts +21 -0
  119. package/dist/browser/outbox/outbox.d.ts.map +1 -0
  120. package/dist/browser/query/column-defaults.js +1 -0
  121. package/dist/browser/query/condition-builder.d.ts +44 -0
  122. package/dist/browser/query/condition-builder.d.ts.map +1 -0
  123. package/dist/browser/query/condition-builder.js +97 -0
  124. package/dist/browser/query/condition-builder.js.map +1 -0
  125. package/dist/browser/query/cursor.d.ts +105 -0
  126. package/dist/browser/query/cursor.d.ts.map +1 -0
  127. package/dist/browser/query/cursor.js +150 -0
  128. package/dist/browser/query/cursor.js.map +1 -0
  129. package/dist/browser/query/db-now.d.ts +22 -0
  130. package/dist/browser/query/db-now.d.ts.map +1 -0
  131. package/dist/browser/query/db-now.js +33 -0
  132. package/dist/browser/query/db-now.js.map +1 -0
  133. package/dist/browser/query/orm/orm.d.ts +18 -0
  134. package/dist/browser/query/orm/orm.d.ts.map +1 -0
  135. package/dist/browser/query/simple-query-interface.d.ts +108 -0
  136. package/dist/browser/query/simple-query-interface.d.ts.map +1 -0
  137. package/dist/browser/query/unit-of-work/execute-unit-of-work.d.ts +423 -0
  138. package/dist/browser/query/unit-of-work/execute-unit-of-work.d.ts.map +1 -0
  139. package/dist/browser/query/unit-of-work/execute-unit-of-work.js +507 -0
  140. package/dist/browser/query/unit-of-work/execute-unit-of-work.js.map +1 -0
  141. package/dist/browser/query/unit-of-work/retry-policy.d.ts +23 -0
  142. package/dist/browser/query/unit-of-work/retry-policy.d.ts.map +1 -0
  143. package/dist/browser/query/unit-of-work/retry-policy.js +40 -0
  144. package/dist/browser/query/unit-of-work/retry-policy.js.map +1 -0
  145. package/dist/browser/query/unit-of-work/unit-of-work.d.ts +703 -0
  146. package/dist/browser/query/unit-of-work/unit-of-work.d.ts.map +1 -0
  147. package/dist/browser/query/unit-of-work/unit-of-work.js +1206 -0
  148. package/dist/browser/query/unit-of-work/unit-of-work.js.map +1 -0
  149. package/dist/browser/query/value-encoding.js +38 -0
  150. package/dist/browser/query/value-encoding.js.map +1 -0
  151. package/dist/browser/schema/create.d.ts +326 -0
  152. package/dist/browser/schema/create.d.ts.map +1 -0
  153. package/dist/browser/schema/create.js +89 -0
  154. package/dist/browser/schema/create.js.map +1 -0
  155. package/dist/browser/schema/generate-id.js +28 -0
  156. package/dist/browser/schema/generate-id.js.map +1 -0
  157. package/dist/browser/shared/providers.d.ts +6 -0
  158. package/dist/browser/shared/providers.d.ts.map +1 -0
  159. package/dist/browser/sql-driver/connection/connection-provider.d.ts +13 -0
  160. package/dist/browser/sql-driver/connection/connection-provider.d.ts.map +1 -0
  161. package/dist/browser/sql-driver/dialect-adapter/dialect-adapter.d.ts +7 -0
  162. package/dist/browser/sql-driver/dialect-adapter/dialect-adapter.d.ts.map +1 -0
  163. package/dist/browser/sql-driver/driver/runtime-driver.d.ts +23 -0
  164. package/dist/browser/sql-driver/driver/runtime-driver.d.ts.map +1 -0
  165. package/dist/browser/sql-driver/query-executor/plugin.d.ts +17 -0
  166. package/dist/browser/sql-driver/query-executor/plugin.d.ts.map +1 -0
  167. package/dist/browser/sql-driver/query-executor/query-executor.d.ts +36 -0
  168. package/dist/browser/sql-driver/query-executor/query-executor.d.ts.map +1 -0
  169. package/dist/browser/sql-driver/sql-driver-adapter.d.ts +29 -0
  170. package/dist/browser/sql-driver/sql-driver-adapter.d.ts.map +1 -0
  171. package/dist/browser/sql-driver/sql-driver.d.ts +38 -0
  172. package/dist/browser/sql-driver/sql-driver.d.ts.map +1 -0
  173. package/dist/browser/sync/commands.d.ts +15 -0
  174. package/dist/browser/sync/commands.d.ts.map +1 -0
  175. package/dist/browser/sync/commands.js +27 -0
  176. package/dist/browser/sync/commands.js.map +1 -0
  177. package/dist/browser/sync/types.d.ts +63 -0
  178. package/dist/browser/sync/types.d.ts.map +1 -0
  179. package/dist/browser/util/types.d.ts +8 -0
  180. package/dist/browser/util/types.d.ts.map +1 -0
  181. package/dist/browser/with-database.d.ts +29 -0
  182. package/dist/browser/with-database.d.ts.map +1 -0
  183. package/dist/client.d.ts +4 -0
  184. package/dist/client.js +5 -0
  185. package/dist/db-fragment-definition-builder.d.ts +101 -33
  186. package/dist/db-fragment-definition-builder.d.ts.map +1 -1
  187. package/dist/db-fragment-definition-builder.js +450 -60
  188. package/dist/db-fragment-definition-builder.js.map +1 -1
  189. package/dist/dispatchers/cloudflare-do/dispatcher.d.ts +20 -0
  190. package/dist/dispatchers/cloudflare-do/dispatcher.d.ts.map +1 -0
  191. package/dist/dispatchers/cloudflare-do/dispatcher.js +147 -0
  192. package/dist/dispatchers/cloudflare-do/dispatcher.js.map +1 -0
  193. package/dist/dispatchers/cloudflare-do/index.d.ts +11 -0
  194. package/dist/dispatchers/cloudflare-do/index.d.ts.map +1 -0
  195. package/dist/dispatchers/cloudflare-do/index.js +31 -0
  196. package/dist/dispatchers/cloudflare-do/index.js.map +1 -0
  197. package/dist/dispatchers/node/dispatcher.d.ts +14 -0
  198. package/dist/dispatchers/node/dispatcher.d.ts.map +1 -0
  199. package/dist/dispatchers/node/dispatcher.js +80 -0
  200. package/dist/dispatchers/node/dispatcher.js.map +1 -0
  201. package/dist/dispatchers/node/index.d.ts +12 -0
  202. package/dist/dispatchers/node/index.d.ts.map +1 -0
  203. package/dist/dispatchers/node/index.js +27 -0
  204. package/dist/dispatchers/node/index.js.map +1 -0
  205. package/dist/durable-hooks.d.ts +31 -0
  206. package/dist/durable-hooks.d.ts.map +1 -0
  207. package/dist/durable-hooks.js +23 -0
  208. package/dist/durable-hooks.js.map +1 -0
  209. package/dist/fragments/internal-fragment.d.ts +186 -8
  210. package/dist/fragments/internal-fragment.d.ts.map +1 -1
  211. package/dist/fragments/internal-fragment.js +203 -38
  212. package/dist/fragments/internal-fragment.js.map +1 -1
  213. package/dist/fragments/internal-fragment.routes.js +164 -0
  214. package/dist/fragments/internal-fragment.routes.js.map +1 -0
  215. package/dist/fragments/internal-fragment.schema.d.ts +15 -0
  216. package/dist/fragments/internal-fragment.schema.d.ts.map +1 -0
  217. package/dist/fragments/internal-fragment.schema.js +39 -0
  218. package/dist/fragments/internal-fragment.schema.js.map +1 -0
  219. package/dist/hooks/durable-hooks-logger.d.ts +10 -0
  220. package/dist/hooks/durable-hooks-logger.d.ts.map +1 -0
  221. package/dist/hooks/durable-hooks-logger.js +75 -0
  222. package/dist/hooks/durable-hooks-logger.js.map +1 -0
  223. package/dist/hooks/durable-hooks-processor.d.ts +1 -0
  224. package/dist/hooks/durable-hooks-processor.js +80 -0
  225. package/dist/hooks/durable-hooks-processor.js.map +1 -0
  226. package/dist/hooks/durable-hooks-runtime.js +44 -0
  227. package/dist/hooks/durable-hooks-runtime.js.map +1 -0
  228. package/dist/hooks/hooks.d.ts +100 -1
  229. package/dist/hooks/hooks.d.ts.map +1 -1
  230. package/dist/hooks/hooks.js +254 -27
  231. package/dist/hooks/hooks.js.map +1 -1
  232. package/dist/id.d.ts +2 -2
  233. package/dist/id.js +2 -2
  234. package/dist/internal/adapter-registry.d.ts +11 -0
  235. package/dist/internal/adapter-registry.d.ts.map +1 -0
  236. package/dist/internal/adapter-registry.js +135 -0
  237. package/dist/internal/adapter-registry.js.map +1 -0
  238. package/dist/internal/outbox-state.d.ts +2 -0
  239. package/dist/internal/outbox-state.js +26 -0
  240. package/dist/internal/outbox-state.js.map +1 -0
  241. package/dist/migration-engine/auto-from-schema.d.ts +33 -0
  242. package/dist/migration-engine/auto-from-schema.d.ts.map +1 -0
  243. package/dist/migration-engine/auto-from-schema.js +223 -37
  244. package/dist/migration-engine/auto-from-schema.js.map +1 -1
  245. package/dist/migration-engine/generation-engine.d.ts +16 -10
  246. package/dist/migration-engine/generation-engine.d.ts.map +1 -1
  247. package/dist/migration-engine/generation-engine.js +86 -35
  248. package/dist/migration-engine/generation-engine.js.map +1 -1
  249. package/dist/migration-engine/shared.d.ts +113 -0
  250. package/dist/migration-engine/shared.d.ts.map +1 -0
  251. package/dist/migration-engine/shared.js.map +1 -1
  252. package/dist/mod.d.ts +20 -12
  253. package/dist/mod.d.ts.map +1 -1
  254. package/dist/mod.js +18 -12
  255. package/dist/mod.js.map +1 -1
  256. package/dist/naming/sql-naming.d.ts +19 -0
  257. package/dist/naming/sql-naming.d.ts.map +1 -0
  258. package/dist/naming/sql-naming.js +116 -0
  259. package/dist/naming/sql-naming.js.map +1 -0
  260. package/dist/outbox/outbox-builder.js +156 -0
  261. package/dist/outbox/outbox-builder.js.map +1 -0
  262. package/dist/outbox/outbox.d.ts +54 -0
  263. package/dist/outbox/outbox.d.ts.map +1 -0
  264. package/dist/outbox/outbox.js +37 -0
  265. package/dist/outbox/outbox.js.map +1 -0
  266. package/dist/query/column-defaults.js +20 -4
  267. package/dist/query/column-defaults.js.map +1 -1
  268. package/dist/query/condition-builder.d.ts +7 -1
  269. package/dist/query/condition-builder.d.ts.map +1 -1
  270. package/dist/query/condition-builder.js +5 -1
  271. package/dist/query/condition-builder.js.map +1 -1
  272. package/dist/query/cursor-client.d.ts +105 -0
  273. package/dist/query/cursor-client.d.ts.map +1 -0
  274. package/dist/query/cursor-client.js +165 -0
  275. package/dist/query/cursor-client.js.map +1 -0
  276. package/dist/query/cursor.d.ts +3 -1
  277. package/dist/query/cursor.d.ts.map +1 -1
  278. package/dist/query/cursor.js +51 -14
  279. package/dist/query/cursor.js.map +1 -1
  280. package/dist/query/db-now.d.ts +22 -0
  281. package/dist/query/db-now.d.ts.map +1 -0
  282. package/dist/query/db-now.js +35 -0
  283. package/dist/query/db-now.js.map +1 -0
  284. package/dist/query/orm/orm.js.map +1 -1
  285. package/dist/query/serialize/create-sql-serializer.js +5 -4
  286. package/dist/query/serialize/create-sql-serializer.js.map +1 -1
  287. package/dist/query/serialize/dialect/mysql-serializer.js +12 -6
  288. package/dist/query/serialize/dialect/mysql-serializer.js.map +1 -1
  289. package/dist/query/serialize/dialect/postgres-serializer.js +25 -7
  290. package/dist/query/serialize/dialect/postgres-serializer.js.map +1 -1
  291. package/dist/query/serialize/dialect/sqlite-serializer.js +60 -12
  292. package/dist/query/serialize/dialect/sqlite-serializer.js.map +1 -1
  293. package/dist/query/serialize/sql-serializer.js +2 -2
  294. package/dist/query/serialize/sql-serializer.js.map +1 -1
  295. package/dist/query/simple-query-interface.d.ts +13 -4
  296. package/dist/query/simple-query-interface.d.ts.map +1 -1
  297. package/dist/query/unit-of-work/execute-unit-of-work.d.ts +37 -2
  298. package/dist/query/unit-of-work/execute-unit-of-work.d.ts.map +1 -1
  299. package/dist/query/unit-of-work/execute-unit-of-work.js +50 -24
  300. package/dist/query/unit-of-work/execute-unit-of-work.js.map +1 -1
  301. package/dist/query/unit-of-work/unit-of-work.d.ts +92 -30
  302. package/dist/query/unit-of-work/unit-of-work.d.ts.map +1 -1
  303. package/dist/query/unit-of-work/unit-of-work.js +136 -11
  304. package/dist/query/unit-of-work/unit-of-work.js.map +1 -1
  305. package/dist/query/value-decoding.js +16 -6
  306. package/dist/query/value-decoding.js.map +1 -1
  307. package/dist/query/value-encoding.js +29 -9
  308. package/dist/query/value-encoding.js.map +1 -1
  309. package/dist/schema/create.d.ts +103 -35
  310. package/dist/schema/create.d.ts.map +1 -1
  311. package/dist/schema/create.js +172 -58
  312. package/dist/schema/create.js.map +1 -1
  313. package/dist/schema/generate-id.js +2 -2
  314. package/dist/schema/generate-id.js.map +1 -1
  315. package/dist/schema/type-conversion/create-sql-type-mapper.js +4 -3
  316. package/dist/schema/type-conversion/create-sql-type-mapper.js.map +1 -1
  317. package/dist/schema/type-conversion/dialect/sqlite.js +9 -0
  318. package/dist/schema/type-conversion/dialect/sqlite.js.map +1 -1
  319. package/dist/schema/validator.d.ts +10 -0
  320. package/dist/schema/validator.d.ts.map +1 -0
  321. package/dist/schema/validator.js +123 -0
  322. package/dist/schema/validator.js.map +1 -0
  323. package/dist/schema-output/drizzle.d.ts +30 -0
  324. package/dist/schema-output/drizzle.d.ts.map +1 -0
  325. package/dist/{adapters/drizzle/generate.js → schema-output/drizzle.js} +88 -60
  326. package/dist/schema-output/drizzle.js.map +1 -0
  327. package/dist/schema-output/prisma.d.ts +17 -0
  328. package/dist/schema-output/prisma.d.ts.map +1 -0
  329. package/dist/schema-output/prisma.js +307 -0
  330. package/dist/schema-output/prisma.js.map +1 -0
  331. package/dist/sql-driver/dialects/durable-object-dialect.js +3 -9
  332. package/dist/sql-driver/dialects/durable-object-dialect.js.map +1 -1
  333. package/dist/sql-driver/query-executor/default-query-executor.js.map +1 -1
  334. package/dist/sql-driver/query-executor/query-executor-base.js.map +1 -1
  335. package/dist/sql-driver/sql-driver-adapter.js.map +1 -1
  336. package/dist/sql-driver/sql.js.map +1 -1
  337. package/dist/sync/commands.d.ts +15 -0
  338. package/dist/sync/commands.d.ts.map +1 -0
  339. package/dist/sync/commands.js +27 -0
  340. package/dist/sync/commands.js.map +1 -0
  341. package/dist/sync/index.d.ts +4 -0
  342. package/dist/sync/index.js +4 -0
  343. package/dist/sync/read-tracking.d.ts +25 -0
  344. package/dist/sync/read-tracking.d.ts.map +1 -0
  345. package/dist/sync/read-tracking.js +148 -0
  346. package/dist/sync/read-tracking.js.map +1 -0
  347. package/dist/sync/submit.js +213 -0
  348. package/dist/sync/submit.js.map +1 -0
  349. package/dist/sync/types.d.ts +63 -0
  350. package/dist/sync/types.d.ts.map +1 -0
  351. package/dist/util/default-database-adapter.js +66 -0
  352. package/dist/util/default-database-adapter.js.map +1 -0
  353. package/dist/with-database.d.ts +3 -6
  354. package/dist/with-database.d.ts.map +1 -1
  355. package/dist/with-database.js +8 -7
  356. package/dist/with-database.js.map +1 -1
  357. package/package.json +62 -55
  358. package/src/adapters/adapters.ts +33 -26
  359. package/src/adapters/drizzle/migrate-drizzle.test.ts +99 -41
  360. package/src/adapters/drizzle/migration-parity-drizzle-kit.test.ts +601 -0
  361. package/src/adapters/drizzle/test-utils.ts +13 -8
  362. package/src/adapters/generic-sql/driver-config.ts +38 -0
  363. package/src/adapters/generic-sql/generic-sql-adapter.test.ts +10 -8
  364. package/src/adapters/generic-sql/generic-sql-adapter.ts +117 -34
  365. package/src/adapters/generic-sql/generic-sql-uow-executor.test.ts +55 -0
  366. package/src/adapters/generic-sql/generic-sql-uow-executor.ts +297 -3
  367. package/src/adapters/generic-sql/migration/adapter-migration-parity.test.ts +120 -0
  368. package/src/adapters/generic-sql/migration/cold-kysely.ts +1 -0
  369. package/src/adapters/generic-sql/migration/dialect/mysql.test.ts +27 -8
  370. package/src/adapters/generic-sql/migration/dialect/mysql.ts +47 -8
  371. package/src/adapters/generic-sql/migration/dialect/postgres.test.ts +28 -9
  372. package/src/adapters/generic-sql/migration/dialect/postgres.ts +9 -4
  373. package/src/adapters/generic-sql/migration/dialect/sqlite.test.ts +839 -8
  374. package/src/adapters/generic-sql/migration/dialect/sqlite.ts +396 -53
  375. package/src/adapters/generic-sql/migration/executor.test.ts +52 -0
  376. package/src/adapters/generic-sql/migration/executor.ts +47 -4
  377. package/src/adapters/generic-sql/migration/prepared-migrations.test.ts +238 -46
  378. package/src/adapters/generic-sql/migration/prepared-migrations.ts +21 -13
  379. package/src/adapters/generic-sql/migration/sql-generator.ts +145 -66
  380. package/src/adapters/generic-sql/query/create-sql-query-compiler.ts +11 -8
  381. package/src/adapters/generic-sql/query/cursor-utils.test.ts +272 -0
  382. package/src/adapters/generic-sql/query/cursor-utils.ts +42 -7
  383. package/src/adapters/generic-sql/query/db-now-sql.ts +49 -0
  384. package/src/adapters/generic-sql/query/generic-sql-uow-operation-compiler.test.ts +171 -35
  385. package/src/adapters/generic-sql/query/generic-sql-uow-operation-compiler.ts +53 -40
  386. package/src/adapters/generic-sql/query/select-builder.test.ts +16 -11
  387. package/src/adapters/generic-sql/query/select-builder.ts +7 -3
  388. package/src/adapters/generic-sql/query/sql-query-compiler.test.ts +75 -6
  389. package/src/adapters/generic-sql/query/sql-query-compiler.ts +129 -24
  390. package/src/adapters/generic-sql/query/where-builder.test.ts +96 -20
  391. package/src/adapters/generic-sql/query/where-builder.ts +112 -41
  392. package/src/adapters/{kysely/kysely-adapter-pglite.test.ts → generic-sql/sql-adapter-pglite-migrations.test.ts} +11 -20
  393. package/src/adapters/generic-sql/sql-adapter-pglite-pagination.test.ts +851 -0
  394. package/src/adapters/{drizzle/drizzle-adapter-pglite.test.ts → generic-sql/sql-adapter-pglite-queries.test.ts} +18 -15
  395. package/src/adapters/generic-sql/{test/generic-drizzle-adapter-sqlite3.test.ts → sql-adapter-sqlite3-driver.test.ts} +282 -14
  396. package/src/adapters/{drizzle/drizzle-adapter-sqlite3.test.ts → generic-sql/sql-adapter-sqlite3-uow.test.ts} +129 -12
  397. package/src/adapters/{kysely/kysely-adapter-sqlocal.test.ts → generic-sql/sql-adapter-sqlocal.test.ts} +9 -7
  398. package/src/adapters/generic-sql/sqlite-storage.ts +20 -0
  399. package/src/adapters/generic-sql/uow-decoder.test.ts +5 -4
  400. package/src/adapters/generic-sql/uow-decoder.ts +23 -5
  401. package/src/adapters/generic-sql/uow-encoder.test.ts +36 -3
  402. package/src/adapters/generic-sql/uow-encoder.ts +48 -13
  403. package/src/adapters/in-memory/condition-evaluator.test.ts +194 -0
  404. package/src/adapters/in-memory/condition-evaluator.ts +280 -0
  405. package/src/adapters/in-memory/errors.ts +20 -0
  406. package/src/adapters/in-memory/in-memory-adapter.ts +388 -0
  407. package/src/adapters/in-memory/in-memory-uow.mutations.test.ts +344 -0
  408. package/src/adapters/in-memory/in-memory-uow.retrieval.test.ts +255 -0
  409. package/src/adapters/in-memory/in-memory-uow.ts +1724 -0
  410. package/src/adapters/in-memory/index.ts +3 -0
  411. package/src/adapters/in-memory/options.test.ts +42 -0
  412. package/src/adapters/in-memory/options.ts +91 -0
  413. package/src/adapters/in-memory/outbox.test.ts +361 -0
  414. package/src/adapters/in-memory/reference-resolution.test.ts +51 -0
  415. package/src/adapters/in-memory/reference-resolution.ts +67 -0
  416. package/src/adapters/in-memory/sorted-array-index.test.ts +124 -0
  417. package/src/adapters/in-memory/sorted-array-index.ts +228 -0
  418. package/src/adapters/in-memory/store.test.ts +69 -0
  419. package/src/adapters/in-memory/store.ts +145 -0
  420. package/src/adapters/in-memory/value-comparison.ts +53 -0
  421. package/src/adapters/in-memory/value-normalization.test.ts +58 -0
  422. package/src/adapters/prisma/prisma-adapter-sqlite3.test.ts +1207 -0
  423. package/src/adapters/shared/from-unit-of-work-compiler.ts +159 -47
  424. package/src/adapters/shared/uow-operation-compiler.ts +28 -18
  425. package/src/adapters/sql/index.ts +12 -0
  426. package/src/browser/mod.ts +64 -0
  427. package/src/client.ts +19 -0
  428. package/src/db-fragment-definition-builder.test.ts +845 -53
  429. package/src/db-fragment-definition-builder.ts +911 -95
  430. package/src/db-fragment-instantiator.test.ts +210 -94
  431. package/src/db-fragment-integration.test.ts +17 -12
  432. package/src/dispatchers/cloudflare-do/dispatcher.ts +204 -0
  433. package/src/dispatchers/cloudflare-do/index.test.ts +206 -0
  434. package/src/dispatchers/cloudflare-do/index.ts +63 -0
  435. package/src/dispatchers/node/dispatcher.ts +112 -0
  436. package/src/dispatchers/node/index.test.ts +120 -0
  437. package/src/dispatchers/node/index.ts +50 -0
  438. package/src/durable-hooks.test.ts +80 -0
  439. package/src/durable-hooks.ts +67 -0
  440. package/src/fragments/internal-fragment.routes.test.ts +570 -0
  441. package/src/fragments/internal-fragment.routes.ts +334 -0
  442. package/src/fragments/internal-fragment.schema.ts +95 -0
  443. package/src/fragments/internal-fragment.test.ts +505 -83
  444. package/src/fragments/internal-fragment.ts +453 -70
  445. package/src/hooks/durable-hooks-logger.ts +126 -0
  446. package/src/hooks/durable-hooks-processor.pglite.test.ts +87 -0
  447. package/src/hooks/durable-hooks-processor.test.ts +282 -0
  448. package/src/hooks/durable-hooks-processor.ts +173 -0
  449. package/src/hooks/durable-hooks-runtime.test.ts +65 -0
  450. package/src/hooks/durable-hooks-runtime.ts +81 -0
  451. package/src/hooks/hooks.test.ts +455 -34
  452. package/src/hooks/hooks.ts +501 -34
  453. package/src/id.test.ts +34 -0
  454. package/src/id.ts +1 -3
  455. package/src/internal/adapter-registry.test.ts +93 -0
  456. package/src/internal/adapter-registry.ts +239 -0
  457. package/src/internal/outbox-state.ts +43 -0
  458. package/src/migration-engine/auto-from-schema.test.ts +107 -14
  459. package/src/migration-engine/auto-from-schema.ts +365 -44
  460. package/src/migration-engine/create.test.ts +4 -3
  461. package/src/migration-engine/create.ts +1 -1
  462. package/src/migration-engine/generation-engine.test.ts +292 -110
  463. package/src/migration-engine/generation-engine.ts +117 -66
  464. package/src/migration-engine/shared.ts +14 -0
  465. package/src/mod.ts +95 -39
  466. package/src/naming/sql-naming.ts +181 -0
  467. package/src/outbox/outbox-builder.ts +241 -0
  468. package/src/outbox/outbox.test.ts +424 -0
  469. package/src/outbox/outbox.ts +139 -0
  470. package/src/query/column-defaults.ts +42 -4
  471. package/src/query/condition-builder.test.ts +18 -3
  472. package/src/query/condition-builder.ts +7 -0
  473. package/src/query/cursor-client.test.ts +70 -0
  474. package/src/query/cursor-client.ts +263 -0
  475. package/src/query/cursor.test.ts +119 -20
  476. package/src/query/cursor.ts +88 -27
  477. package/src/query/db-now.ts +73 -0
  478. package/src/query/orm/orm.ts +2 -2
  479. package/src/query/query-type.test.ts +4 -3
  480. package/src/query/serialize/create-sql-serializer.ts +10 -5
  481. package/src/query/serialize/dialect/mysql-serializer.ts +13 -5
  482. package/src/query/serialize/dialect/postgres-serializer.ts +35 -5
  483. package/src/query/serialize/dialect/sqlite-serializer.test.ts +90 -3
  484. package/src/query/serialize/dialect/sqlite-serializer.ts +108 -12
  485. package/src/query/serialize/sql-serializer.ts +4 -4
  486. package/src/query/simple-query-interface.ts +15 -4
  487. package/src/query/unit-of-work/execute-unit-of-work.test.ts +372 -10
  488. package/src/query/unit-of-work/execute-unit-of-work.ts +87 -27
  489. package/src/query/unit-of-work/retry-policy.test.ts +1 -0
  490. package/src/query/unit-of-work/tx-builder.test.ts +73 -1
  491. package/src/query/unit-of-work/unit-of-work-coordinator.test.ts +17 -16
  492. package/src/query/unit-of-work/unit-of-work-types.test.ts +42 -12
  493. package/src/query/unit-of-work/unit-of-work.test.ts +196 -39
  494. package/src/query/unit-of-work/unit-of-work.ts +309 -38
  495. package/src/query/value-decoding.test.ts +63 -4
  496. package/src/query/value-decoding.ts +32 -6
  497. package/src/query/value-encoding.test.ts +86 -2
  498. package/src/query/value-encoding.ts +56 -6
  499. package/src/schema/create.test.ts +293 -47
  500. package/src/schema/create.ts +406 -70
  501. package/src/schema/generate-id.test.ts +3 -2
  502. package/src/schema/generate-id.ts +2 -2
  503. package/src/schema/serialize.test.ts +18 -5
  504. package/src/schema/type-conversion/create-sql-type-mapper.ts +8 -3
  505. package/src/schema/type-conversion/dialect/sqlite.ts +18 -0
  506. package/src/schema/type-conversion/type-mapping.test.ts +26 -1
  507. package/src/schema/validator.test.ts +199 -0
  508. package/src/schema/validator.ts +232 -0
  509. package/src/{adapters/drizzle/generate.test.ts → schema-output/drizzle.test.ts} +232 -129
  510. package/src/{adapters/drizzle/generate.ts → schema-output/drizzle.ts} +155 -99
  511. package/src/schema-output/prisma.test.ts +694 -0
  512. package/src/schema-output/prisma.ts +593 -0
  513. package/src/sql-driver/better-sqlite3.test.ts +5 -3
  514. package/src/sql-driver/dialects/durable-object-dialect.ts +3 -8
  515. package/src/sql-driver/query-executor/default-query-executor.ts +1 -1
  516. package/src/sql-driver/query-executor/query-executor-base.ts +1 -1
  517. package/src/sql-driver/query-executor/query-executor.ts +1 -1
  518. package/src/sql-driver/sql-driver-adapter.ts +2 -2
  519. package/src/sql-driver/sql.ts +2 -1
  520. package/src/sql-driver/sqlocal.test.ts +4 -2
  521. package/src/sync/commands.test.ts +39 -0
  522. package/src/sync/commands.ts +51 -0
  523. package/src/sync/conflict-checker.test.ts +450 -0
  524. package/src/sync/conflict-checker.ts +248 -0
  525. package/src/sync/index.ts +14 -0
  526. package/src/sync/plan.ts +9 -0
  527. package/src/sync/read-tracking.test.ts +177 -0
  528. package/src/sync/read-tracking.ts +287 -0
  529. package/src/sync/submit.test.ts +205 -0
  530. package/src/sync/submit.ts +328 -0
  531. package/src/sync/types.ts +80 -0
  532. package/src/util/default-database-adapter.ts +119 -0
  533. package/src/with-database.ts +20 -31
  534. package/tsconfig.json +1 -1
  535. package/tsdown.config.ts +38 -24
  536. package/vitest.config.ts +1 -0
  537. package/dist/adapters/drizzle/drizzle-adapter.d.ts +0 -20
  538. package/dist/adapters/drizzle/drizzle-adapter.d.ts.map +0 -1
  539. package/dist/adapters/drizzle/drizzle-adapter.js +0 -27
  540. package/dist/adapters/drizzle/drizzle-adapter.js.map +0 -1
  541. package/dist/adapters/drizzle/generate.d.ts +0 -30
  542. package/dist/adapters/drizzle/generate.d.ts.map +0 -1
  543. package/dist/adapters/drizzle/generate.js.map +0 -1
  544. package/dist/adapters/kysely/kysely-adapter.d.ts +0 -19
  545. package/dist/adapters/kysely/kysely-adapter.d.ts.map +0 -1
  546. package/dist/adapters/kysely/kysely-adapter.js +0 -17
  547. package/dist/adapters/kysely/kysely-adapter.js.map +0 -1
  548. package/dist/adapters/shared/table-name-mapper.d.ts +0 -12
  549. package/dist/adapters/shared/table-name-mapper.d.ts.map +0 -1
  550. package/dist/adapters/shared/table-name-mapper.js +0 -43
  551. package/dist/adapters/shared/table-name-mapper.js.map +0 -1
  552. package/dist/node_modules/.pnpm/rou3@0.7.10/node_modules/rou3/dist/index.js +0 -165
  553. package/dist/node_modules/.pnpm/rou3@0.7.10/node_modules/rou3/dist/index.js.map +0 -1
  554. package/dist/packages/fragno/dist/api/bind-services.js +0 -20
  555. package/dist/packages/fragno/dist/api/bind-services.js.map +0 -1
  556. package/dist/packages/fragno/dist/api/error.js +0 -48
  557. package/dist/packages/fragno/dist/api/error.js.map +0 -1
  558. package/dist/packages/fragno/dist/api/fragment-definition-builder.js +0 -320
  559. package/dist/packages/fragno/dist/api/fragment-definition-builder.js.map +0 -1
  560. package/dist/packages/fragno/dist/api/fragment-instantiator.js +0 -525
  561. package/dist/packages/fragno/dist/api/fragment-instantiator.js.map +0 -1
  562. package/dist/packages/fragno/dist/api/fragno-response.js +0 -73
  563. package/dist/packages/fragno/dist/api/fragno-response.js.map +0 -1
  564. package/dist/packages/fragno/dist/api/internal/response-stream.js +0 -81
  565. package/dist/packages/fragno/dist/api/internal/response-stream.js.map +0 -1
  566. package/dist/packages/fragno/dist/api/internal/route.js +0 -10
  567. package/dist/packages/fragno/dist/api/internal/route.js.map +0 -1
  568. package/dist/packages/fragno/dist/api/mutable-request-state.js +0 -97
  569. package/dist/packages/fragno/dist/api/mutable-request-state.js.map +0 -1
  570. package/dist/packages/fragno/dist/api/request-context-storage.js +0 -43
  571. package/dist/packages/fragno/dist/api/request-context-storage.js.map +0 -1
  572. package/dist/packages/fragno/dist/api/request-input-context.js +0 -118
  573. package/dist/packages/fragno/dist/api/request-input-context.js.map +0 -1
  574. package/dist/packages/fragno/dist/api/request-middleware.js +0 -83
  575. package/dist/packages/fragno/dist/api/request-middleware.js.map +0 -1
  576. package/dist/packages/fragno/dist/api/request-output-context.js +0 -119
  577. package/dist/packages/fragno/dist/api/request-output-context.js.map +0 -1
  578. package/dist/packages/fragno/dist/api/route.js +0 -17
  579. package/dist/packages/fragno/dist/api/route.js.map +0 -1
  580. package/dist/packages/fragno/dist/internal/symbols.js +0 -10
  581. package/dist/packages/fragno/dist/internal/symbols.js.map +0 -1
  582. package/dist/schema-generator/schema-generator.d.ts +0 -15
  583. package/dist/schema-generator/schema-generator.d.ts.map +0 -1
  584. package/src/adapters/drizzle/drizzle-adapter.ts +0 -39
  585. package/src/adapters/kysely/kysely-adapter.ts +0 -27
  586. package/src/adapters/shared/table-name-mapper.ts +0 -50
  587. package/src/schema-generator/schema-generator.ts +0 -12
@@ -1,13 +1,37 @@
1
+ import superjson from "superjson";
2
+
3
+ import { SETTINGS_NAMESPACE, internalSchema } from "../../fragments/internal-fragment.schema";
4
+ import { createId } from "../../id";
5
+ import { type SqlNamingStrategy } from "../../naming/sql-naming";
6
+ import {
7
+ type OutboxConfig,
8
+ type OutboxRefLookup,
9
+ type OutboxRefMap,
10
+ encodeVersionstamp,
11
+ parseOutboxVersionValue,
12
+ versionstampToHex,
13
+ } from "../../outbox/outbox";
14
+ import { buildOutboxPlan, finalizeOutboxPayload } from "../../outbox/outbox-builder";
15
+ import { createSQLSerializer } from "../../query/serialize/create-sql-serializer";
1
16
  import type {
2
17
  CompiledMutation,
3
18
  MutationResult,
4
19
  UOWExecutor,
5
20
  } from "../../query/unit-of-work/unit-of-work";
6
- import type { CompiledQuery } from "../../sql-driver/sql-driver";
21
+ import { sql } from "../../sql-driver/sql";
22
+ import type { CompiledQuery, Dialect } from "../../sql-driver/sql-driver";
7
23
  import type { SqlDriverAdapter } from "../../sql-driver/sql-driver-adapter";
8
24
  import type { DriverConfig } from "./driver-config";
25
+ import { createColdKysely } from "./migration/cold-kysely";
9
26
  import { ResultInterpreter } from "./result-interpreter";
10
27
 
28
+ export interface ExecutorOptions {
29
+ dryRun?: boolean;
30
+ dialect: Dialect;
31
+ outbox?: OutboxConfig;
32
+ namingStrategy?: SqlNamingStrategy;
33
+ }
34
+
11
35
  export async function executeRetrieval(
12
36
  adapter: SqlDriverAdapter,
13
37
  retrievalBatch: CompiledQuery[],
@@ -32,6 +56,7 @@ export async function executeMutation(
32
56
  adapter: SqlDriverAdapter,
33
57
  driverConfig: DriverConfig,
34
58
  mutationBatch: CompiledMutation<CompiledQuery>[],
59
+ options: ExecutorOptions,
35
60
  ): Promise<MutationResult> {
36
61
  if (mutationBatch.length === 0) {
37
62
  return { success: true, createdInternalIds: [] };
@@ -39,9 +64,34 @@ export async function executeMutation(
39
64
 
40
65
  const createdInternalIds: (bigint | null)[] = [];
41
66
  const resultInterpreter = new ResultInterpreter(driverConfig);
67
+ const outboxEnabled = options.outbox?.enabled ?? false;
68
+ const shouldInclude = options.outbox?.shouldInclude;
69
+ const namingStrategy = options.namingStrategy ?? driverConfig.defaultNamingStrategy;
70
+
71
+ const outboxOperations = outboxEnabled
72
+ ? mutationBatch.flatMap((mutation) => {
73
+ const operation = mutation.operation;
74
+ if (!operation) {
75
+ return [];
76
+ }
77
+ if (shouldInclude && !shouldInclude(operation)) {
78
+ return [];
79
+ }
80
+ return [operation];
81
+ })
82
+ : [];
83
+
84
+ const outboxPlan = outboxOperations.length > 0 ? buildOutboxPlan(outboxOperations) : null;
85
+ const shouldWriteOutbox = outboxEnabled && outboxPlan !== null && outboxPlan.drafts.length > 0;
42
86
 
43
87
  try {
44
88
  await adapter.transaction(async (tx) => {
89
+ let outboxVersion: bigint | null = null;
90
+
91
+ if (shouldWriteOutbox) {
92
+ outboxVersion = await reserveOutboxVersion(tx, driverConfig, options.dialect);
93
+ }
94
+
45
95
  for (const compiledMutation of mutationBatch) {
46
96
  const result = await tx.executeQuery(compiledMutation.query);
47
97
 
@@ -86,6 +136,36 @@ export async function executeMutation(
86
136
  }
87
137
  }
88
138
  }
139
+
140
+ if (shouldWriteOutbox && outboxPlan && outboxVersion !== null) {
141
+ const uowId = mutationBatch[0]?.uowId;
142
+ if (!uowId) {
143
+ throw new Error("Outbox mutation batch is missing uowId.");
144
+ }
145
+
146
+ const refMap = await resolveOutboxRefMap(
147
+ tx,
148
+ driverConfig,
149
+ outboxPlan.lookups,
150
+ namingStrategy,
151
+ );
152
+ const payload = finalizeOutboxPayload(outboxPlan, outboxVersion);
153
+ const payloadSerialized = superjson.serialize(payload);
154
+ const versionstamp = versionstampToHex(encodeVersionstamp(outboxVersion, 0));
155
+
156
+ await insertOutboxMutationRows(tx, driverConfig, {
157
+ entryVersionstamp: versionstamp,
158
+ uowId,
159
+ mutations: payload.mutations,
160
+ });
161
+ await insertOutboxRow(tx, driverConfig, {
162
+ id: createId(),
163
+ versionstamp,
164
+ uowId,
165
+ payload: payloadSerialized,
166
+ refMap,
167
+ });
168
+ }
89
169
  });
90
170
 
91
171
  return { success: true, createdInternalIds };
@@ -96,6 +176,15 @@ export async function executeMutation(
96
176
  return { success: false };
97
177
  }
98
178
 
179
+ const errorCode =
180
+ typeof error === "object" && error !== null && "code" in error
181
+ ? (error as { code?: unknown }).code
182
+ : undefined;
183
+
184
+ if (errorCode === "40001" || errorCode === "40P01") {
185
+ return { success: false };
186
+ }
187
+
99
188
  // Other database errors should be thrown
100
189
  throw error;
101
190
  }
@@ -104,8 +193,10 @@ export async function executeMutation(
104
193
  export function createExecutor(
105
194
  adapter: SqlDriverAdapter,
106
195
  driverConfig: DriverConfig,
107
- dryRun?: boolean,
196
+ options: ExecutorOptions,
108
197
  ): UOWExecutor<CompiledQuery, unknown> {
198
+ const dryRun = options.dryRun ?? false;
199
+
109
200
  return {
110
201
  async executeRetrievalPhase(retrievalBatch: CompiledQuery[]) {
111
202
  // In dryRun mode, skip execution and return empty results
@@ -124,7 +215,210 @@ export function createExecutor(
124
215
  };
125
216
  }
126
217
 
127
- return executeMutation(adapter, driverConfig, mutationBatch);
218
+ return executeMutation(adapter, driverConfig, mutationBatch, options);
128
219
  },
129
220
  };
130
221
  }
222
+
223
+ async function reserveOutboxVersion(
224
+ tx: SqlDriverAdapter,
225
+ driverConfig: DriverConfig,
226
+ dialect: Dialect,
227
+ ): Promise<bigint> {
228
+ const key = `${SETTINGS_NAMESPACE}.outbox_version`;
229
+ const id = createId();
230
+
231
+ switch (driverConfig.outboxVersionstampStrategy) {
232
+ case "insert-on-conflict-returning": {
233
+ const query =
234
+ driverConfig.databaseType === "postgresql"
235
+ ? sql`
236
+ insert into fragno_db_settings (id, key, value)
237
+ values (${id}, ${key}, '0')
238
+ on conflict (key) do update
239
+ set value = (fragno_db_settings.value::bigint + 1)::text
240
+ returning value;
241
+ `
242
+ : sql`
243
+ insert into fragno_db_settings (id, key, value)
244
+ values (${id}, ${key}, '0')
245
+ on conflict (key) do update
246
+ set value = cast(fragno_db_settings.value as integer) + 1
247
+ returning value;
248
+ `;
249
+
250
+ const result = await tx.executeQuery(query.compile(dialect));
251
+ const value = result.rows[0]?.["value"];
252
+ return parseOutboxVersionValue(value);
253
+ }
254
+ case "update-returning": {
255
+ const query =
256
+ driverConfig.databaseType === "postgresql"
257
+ ? sql`
258
+ update fragno_db_settings
259
+ set value = (fragno_db_settings.value::bigint + 1)::text
260
+ where key = ${key}
261
+ returning value;
262
+ `
263
+ : sql`
264
+ update fragno_db_settings
265
+ set value = cast(fragno_db_settings.value as integer) + 1
266
+ where key = ${key}
267
+ returning value;
268
+ `;
269
+
270
+ const result = await tx.executeQuery(query.compile(dialect));
271
+ const value = result.rows[0]?.["value"];
272
+ if (value === undefined) {
273
+ throw new Error("Outbox version row was not found for update-returning strategy.");
274
+ }
275
+ return parseOutboxVersionValue(value);
276
+ }
277
+ case "insert-on-duplicate-last-insert-id": {
278
+ const insertQuery = sql`
279
+ insert into fragno_db_settings (id, key, value)
280
+ values (${id}, ${key}, LAST_INSERT_ID(0))
281
+ on duplicate key update value = LAST_INSERT_ID(cast(value as unsigned) + 1);
282
+ `;
283
+
284
+ await tx.executeQuery(insertQuery.compile(dialect));
285
+
286
+ const selectQuery = sql`select LAST_INSERT_ID() as value;`;
287
+ const result = await tx.executeQuery(selectQuery.compile(dialect));
288
+ const value = result.rows[0]?.["value"];
289
+ return parseOutboxVersionValue(value);
290
+ }
291
+ }
292
+ }
293
+
294
+ async function resolveOutboxRefMap(
295
+ tx: SqlDriverAdapter,
296
+ driverConfig: DriverConfig,
297
+ lookups: OutboxRefLookup[],
298
+ namingStrategy: SqlNamingStrategy,
299
+ ): Promise<OutboxRefMap | undefined> {
300
+ if (lookups.length === 0) {
301
+ return undefined;
302
+ }
303
+
304
+ const refMap: OutboxRefMap = {};
305
+ const db = createColdKysely(driverConfig.databaseType);
306
+
307
+ for (const lookup of lookups) {
308
+ const namespace = lookup.namespace ?? null;
309
+ const logicalTable = lookup.table.name;
310
+ const schemaName =
311
+ namingStrategy.namespaceScope === "schema" && namespace && namespace.length > 0
312
+ ? namingStrategy.namespaceToSchema(namespace)
313
+ : null;
314
+ const scopedDb = schemaName ? db.withSchema(schemaName) : db;
315
+ const tableName = namingStrategy.tableName(logicalTable, namespace);
316
+ const internalColumn = namingStrategy.columnName(
317
+ lookup.table.getInternalIdColumn().name,
318
+ logicalTable,
319
+ );
320
+ const externalColumn = namingStrategy.columnName(lookup.table.getIdColumn().name, logicalTable);
321
+
322
+ const query = scopedDb
323
+ .selectFrom(tableName)
324
+ .select(externalColumn)
325
+ .where(internalColumn, "=", lookup.internalId)
326
+ .compile();
327
+
328
+ const result = await tx.executeQuery(query);
329
+ const row = result.rows[0] as Record<string, unknown> | undefined;
330
+ const externalId = row?.[externalColumn];
331
+
332
+ if (typeof externalId !== "string") {
333
+ throw new Error(
334
+ `Failed to resolve outbox reference for ${tableName}.${internalColumn}=${String(lookup.internalId)}`,
335
+ );
336
+ }
337
+
338
+ refMap[lookup.key] = externalId;
339
+ }
340
+
341
+ return Object.keys(refMap).length > 0 ? refMap : undefined;
342
+ }
343
+
344
+ async function insertOutboxRow(
345
+ tx: SqlDriverAdapter,
346
+ driverConfig: DriverConfig,
347
+ options: {
348
+ id: string;
349
+ versionstamp: string;
350
+ uowId: string;
351
+ payload: { json: unknown; meta?: Record<string, unknown> };
352
+ refMap?: OutboxRefMap;
353
+ },
354
+ ): Promise<void> {
355
+ const { id, versionstamp, uowId, payload, refMap } = options;
356
+ const refMapValue = refMap ?? null;
357
+ const serializer = createSQLSerializer(driverConfig);
358
+ const outboxTable = internalSchema.tables.fragno_db_outbox;
359
+ const values = { id, versionstamp, uowId, payload, refMap: refMapValue };
360
+ const serializedValues: Record<string, unknown> = {};
361
+ for (const [key, value] of Object.entries(values)) {
362
+ const col = outboxTable.getColumnByName(key);
363
+ if (!col) {
364
+ serializedValues[key] = value;
365
+ continue;
366
+ }
367
+ serializedValues[col.name] = serializer.serialize(value, col);
368
+ }
369
+ const db = createColdKysely(driverConfig.databaseType);
370
+
371
+ const query = db.insertInto("fragno_db_outbox").values(serializedValues).compile();
372
+
373
+ await tx.executeQuery(query);
374
+ }
375
+
376
+ async function insertOutboxMutationRows(
377
+ tx: SqlDriverAdapter,
378
+ driverConfig: DriverConfig,
379
+ options: {
380
+ entryVersionstamp: string;
381
+ uowId: string;
382
+ mutations: {
383
+ versionstamp: string;
384
+ schema: string;
385
+ table: string;
386
+ externalId: string;
387
+ op: string;
388
+ }[];
389
+ },
390
+ ): Promise<void> {
391
+ if (options.mutations.length === 0) {
392
+ return;
393
+ }
394
+
395
+ const serializer = createSQLSerializer(driverConfig);
396
+ const mutationsTable = internalSchema.tables.fragno_db_outbox_mutations;
397
+ const db = createColdKysely(driverConfig.databaseType);
398
+
399
+ for (const mutation of options.mutations) {
400
+ const values = {
401
+ id: createId(),
402
+ entryVersionstamp: options.entryVersionstamp,
403
+ mutationVersionstamp: mutation.versionstamp,
404
+ uowId: options.uowId,
405
+ schema: mutation.schema,
406
+ table: mutation.table,
407
+ externalId: mutation.externalId,
408
+ op: mutation.op,
409
+ };
410
+ const serializedValues: Record<string, unknown> = {};
411
+
412
+ for (const [key, value] of Object.entries(values)) {
413
+ const col = mutationsTable.getColumnByName(key);
414
+ if (!col) {
415
+ serializedValues[key] = value;
416
+ continue;
417
+ }
418
+ serializedValues[col.name] = serializer.serialize(value, col);
419
+ }
420
+
421
+ const query = db.insertInto("fragno_db_outbox_mutations").values(serializedValues).compile();
422
+ await tx.executeQuery(query);
423
+ }
424
+ }
@@ -0,0 +1,120 @@
1
+ import { describe, expect, it } from "vitest";
2
+
3
+ import {
4
+ DummyDriver,
5
+ MysqlAdapter,
6
+ MysqlQueryCompiler,
7
+ PostgresAdapter,
8
+ PostgresQueryCompiler,
9
+ SqliteAdapter,
10
+ SqliteQueryCompiler,
11
+ } from "kysely";
12
+
13
+ import { column, idColumn, referenceColumn, schema } from "../../../schema/create";
14
+ import type { Dialect } from "../../../sql-driver/sql-driver";
15
+ import {
16
+ MySQL2DriverConfig,
17
+ NodePostgresDriverConfig,
18
+ SQLocalDriverConfig,
19
+ } from "../driver-config";
20
+ import { SqlAdapter } from "../generic-sql-adapter";
21
+
22
+ const paritySchema = schema("parity", (s) => {
23
+ return s
24
+ .addTable("users", (t) => {
25
+ return t
26
+ .addColumn("id", idColumn())
27
+ .addColumn("email", column("string"))
28
+ .addColumn(
29
+ "createdAt",
30
+ column("timestamp").defaultTo((b) => b.now()),
31
+ )
32
+ .createIndex("users_email_idx", ["email"], { unique: true });
33
+ })
34
+ .alterTable("users", (t) => {
35
+ return t.addColumn("age", column("integer").nullable()).createIndex("users_age_idx", ["age"]);
36
+ })
37
+ .addTable("posts", (t) => {
38
+ return t
39
+ .addColumn("id", idColumn())
40
+ .addColumn("authorId", referenceColumn())
41
+ .addColumn("title", column("string"))
42
+ .addColumn("isPublished", column("bool").defaultTo(false))
43
+ .createIndex("posts_author_idx", ["authorId"]);
44
+ })
45
+ .addReference("author", {
46
+ type: "one",
47
+ from: { table: "posts", column: "authorId" },
48
+ to: { table: "users", column: "id" },
49
+ });
50
+ });
51
+
52
+ function createDummyDialect(database: "postgresql" | "mysql" | "sqlite"): Dialect {
53
+ switch (database) {
54
+ case "postgresql":
55
+ return {
56
+ createAdapter: () => new PostgresAdapter(),
57
+ createDriver: () => new DummyDriver(),
58
+ createQueryCompiler: () => new PostgresQueryCompiler(),
59
+ };
60
+ case "mysql":
61
+ return {
62
+ createAdapter: () => new MysqlAdapter(),
63
+ createDriver: () => new DummyDriver(),
64
+ createQueryCompiler: () => new MysqlQueryCompiler(),
65
+ };
66
+ case "sqlite":
67
+ return {
68
+ createAdapter: () => new SqliteAdapter(),
69
+ createDriver: () => new DummyDriver(),
70
+ createQueryCompiler: () => new SqliteQueryCompiler(),
71
+ };
72
+ }
73
+ }
74
+
75
+ function getMigrationSql(adapter: SqlAdapter, namespace: string): string[] {
76
+ const prepared = adapter.prepareMigrations(paritySchema, namespace);
77
+ const migration = prepared.compile(0, paritySchema.version, {
78
+ updateVersionInMigration: false,
79
+ });
80
+ return migration.statements.map((statement) => statement.sql);
81
+ }
82
+
83
+ describe("migration SQL parity across SqlAdapter instances", () => {
84
+ const cases = [
85
+ {
86
+ name: "postgresql",
87
+ driverConfig: new NodePostgresDriverConfig(),
88
+ },
89
+ {
90
+ name: "sqlite",
91
+ driverConfig: new SQLocalDriverConfig(),
92
+ },
93
+ {
94
+ name: "mysql",
95
+ driverConfig: new MySQL2DriverConfig(),
96
+ },
97
+ ] as const;
98
+
99
+ for (const testCase of cases) {
100
+ it(`generates identical SQL for ${testCase.name}`, () => {
101
+ const dialect = createDummyDialect(testCase.name);
102
+ const namespace = "parity";
103
+
104
+ const firstAdapter = new SqlAdapter({
105
+ dialect,
106
+ driverConfig: testCase.driverConfig,
107
+ });
108
+
109
+ const secondAdapter = new SqlAdapter({
110
+ dialect,
111
+ driverConfig: testCase.driverConfig,
112
+ });
113
+
114
+ const firstSql = getMigrationSql(firstAdapter, namespace);
115
+ const secondSql = getMigrationSql(secondAdapter, namespace);
116
+
117
+ expect(firstSql).toEqual(secondSql);
118
+ });
119
+ }
120
+ });
@@ -11,6 +11,7 @@ import {
11
11
  SqliteIntrospector,
12
12
  SqliteQueryCompiler,
13
13
  } from "kysely";
14
+
14
15
  import type { SupportedDatabase } from "../driver-config";
15
16
 
16
17
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
@@ -1,5 +1,8 @@
1
1
  import { describe, expect, it } from "vitest";
2
+
2
3
  import type { MigrationOperation } from "../../../../migration-engine/shared";
4
+ import { createNamingResolver, type SqlNamingStrategy } from "../../../../naming/sql-naming";
5
+ import { column, idColumn, schema } from "../../../../schema/create";
3
6
  import { createColdKysely } from "../cold-kysely";
4
7
  import { MySQLSQLGenerator } from "./mysql";
5
8
 
@@ -194,7 +197,7 @@ describe("MySQLSQLGenerator", () => {
194
197
 
195
198
  const sql = compileOne(operation);
196
199
  expect(sql).toMatchInlineSnapshot(
197
- `"create table \`users\` (\`_internalId\` bigint not null primary key auto_increment, \`name\` text not null)"`,
200
+ `"create table \`users\` (\`_internalId\` bigint not null auto_increment, \`name\` text not null, constraint \`users__internalId\` primary key (\`_internalId\`))"`,
198
201
  );
199
202
  });
200
203
  });
@@ -628,6 +631,7 @@ describe("MySQLSQLGenerator", () => {
628
631
  type: "drop-foreign-key",
629
632
  table: "posts",
630
633
  name: "posts_user_id_fk",
634
+ referencedTable: "users",
631
635
  };
632
636
 
633
637
  const sql = compileOne(operation);
@@ -893,10 +897,25 @@ describe("MySQLSQLGenerator", () => {
893
897
  });
894
898
 
895
899
  describe("table name mapping", () => {
896
- const mapper = {
897
- toPhysical: (name: string) => `prefix_${name}`,
898
- toLogical: (name: string) => name.replace("prefix_", ""),
900
+ const mappingSchema = schema("mapping", (s) =>
901
+ s
902
+ .addTable("users", (t) =>
903
+ t.addColumn("id", idColumn()).addColumn("email", column("string")),
904
+ )
905
+ .addTable("posts", (t) =>
906
+ t.addColumn("id", idColumn()).addColumn("user_id", column("string")),
907
+ ),
908
+ );
909
+ const namingStrategy: SqlNamingStrategy = {
910
+ namespaceScope: "suffix",
911
+ namespaceToSchema: (namespace) => namespace,
912
+ tableName: (logicalTable) => `prefix_${logicalTable}`,
913
+ columnName: (logicalColumn) => logicalColumn,
914
+ indexName: (logicalIndex) => `idx_${logicalIndex}`,
915
+ uniqueIndexName: (logicalIndex) => `uidx_${logicalIndex}`,
916
+ foreignKeyName: ({ referenceName }) => referenceName,
899
917
  };
918
+ const resolver = createNamingResolver(mappingSchema, null, namingStrategy);
900
919
 
901
920
  it("should apply table name mapping to create-table", () => {
902
921
  const operation: MigrationOperation = {
@@ -905,7 +924,7 @@ describe("MySQLSQLGenerator", () => {
905
924
  columns: [{ name: "id", type: "integer", isNullable: false, role: "external-id" }],
906
925
  };
907
926
 
908
- const statements = generator.compile([operation], mapper);
927
+ const statements = generator.compile([operation], resolver);
909
928
  expect(statements[1].sql).toMatchInlineSnapshot(
910
929
  `"create table \`prefix_users\` (\`id\` integer not null unique)"`,
911
930
  );
@@ -923,7 +942,7 @@ describe("MySQLSQLGenerator", () => {
923
942
  },
924
943
  };
925
944
 
926
- const statements = generator.compile([operation], mapper);
945
+ const statements = generator.compile([operation], resolver);
927
946
  expect(statements[1].sql).toMatchInlineSnapshot(
928
947
  `"alter table \`prefix_posts\` add constraint \`posts_user_id_fk\` foreign key (\`user_id\`) references \`prefix_users\` (\`id\`) on delete restrict on update restrict"`,
929
948
  );
@@ -938,9 +957,9 @@ describe("MySQLSQLGenerator", () => {
938
957
  unique: true,
939
958
  };
940
959
 
941
- const statements = generator.compile([operation], mapper);
960
+ const statements = generator.compile([operation], resolver);
942
961
  expect(statements[1].sql).toMatchInlineSnapshot(
943
- `"create unique index \`idx_email_prefix_users\` on \`prefix_users\` (\`email\`)"`,
962
+ `"create unique index \`uidx_idx_email\` on \`prefix_users\` (\`email\`)"`,
944
963
  );
945
964
  });
946
965
  });
@@ -1,11 +1,12 @@
1
1
  import { type ColumnDefinitionBuilder, type CompiledQuery, type RawBuilder, sql } from "kysely";
2
+
2
3
  import type {
3
4
  ColumnInfo,
4
5
  ColumnOperation,
5
6
  MigrationOperation,
6
7
  } from "../../../../migration-engine/shared";
7
8
  import { isUpdated } from "../../../../migration-engine/shared";
8
- import type { TableNameMapper } from "../../../shared/table-name-mapper";
9
+ import type { NamingResolver } from "../../../../naming/sql-naming";
9
10
  import { SQLGenerator } from "../sql-generator";
10
11
 
11
12
  const errors = {
@@ -69,7 +70,9 @@ export class MySQLSQLGenerator extends SQLGenerator {
69
70
  */
70
71
  protected override compileUpdateColumn(
71
72
  tableName: string,
73
+ logicalTableName: string,
72
74
  operation: Extract<ColumnOperation, { type: "update-column" }>,
75
+ resolver?: NamingResolver,
73
76
  ): CompiledQuery | CompiledQuery[] {
74
77
  const col = operation.value;
75
78
 
@@ -82,9 +85,13 @@ export class MySQLSQLGenerator extends SQLGenerator {
82
85
  }
83
86
 
84
87
  // MySQL: Use modifyColumn which requires the full column definition
85
- return this.db.schema
88
+ return this.getSchemaBuilder(resolver)
86
89
  .alterTable(tableName)
87
- .modifyColumn(operation.name, sql.raw(this.getDBType(col)), (b) => this.buildColumn(col, b))
90
+ .modifyColumn(
91
+ this.getColumnName(operation.name, logicalTableName, resolver),
92
+ sql.raw(this.getDBType(col)),
93
+ (b) => this.buildColumn(col, b),
94
+ )
88
95
  .compile();
89
96
  }
90
97
 
@@ -93,12 +100,44 @@ export class MySQLSQLGenerator extends SQLGenerator {
93
100
  */
94
101
  protected override compileDropForeignKey(
95
102
  operation: Extract<MigrationOperation, { type: "drop-foreign-key" }>,
96
- mapper?: TableNameMapper,
103
+ resolver?: NamingResolver,
97
104
  ): CompiledQuery {
98
- const { table, name } = operation;
99
- return this.db.schema
100
- .alterTable(this.getTableName(table, mapper))
101
- .dropConstraint(name)
105
+ const { table, name, referencedTable } = operation;
106
+ return this.getSchemaBuilder(resolver)
107
+ .alterTable(this.getTableName(table, resolver))
108
+ .dropConstraint(this.getForeignKeyName(name, table, referencedTable, resolver))
102
109
  .compile();
103
110
  }
111
+
112
+ /**
113
+ * MySQL: add a named primary key constraint for the internal ID column to align naming.
114
+ */
115
+ protected override compileCreateTable(
116
+ operation: Extract<MigrationOperation, { type: "create-table" }>,
117
+ resolver?: NamingResolver,
118
+ ): CompiledQuery {
119
+ const compiled = super.compileCreateTable(operation, resolver);
120
+ const tableName = this.getTableName(operation.name, resolver);
121
+ const internalIdColumn = operation.columns.find((col) => col.role === "internal-id");
122
+
123
+ if (!internalIdColumn) {
124
+ return compiled;
125
+ }
126
+
127
+ const pkColumn = this.getColumnName(internalIdColumn.name, operation.name, resolver);
128
+ const pkName = `${tableName}__${pkColumn.replace(/^_+/, "")}`;
129
+ const escapedPkColumn = pkColumn.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
130
+ const columnRegex = new RegExp("`" + escapedPkColumn + "`([^,]*?)\\bprimary key\\b", "i");
131
+
132
+ let sqlText = compiled.sql.replace(columnRegex, "`" + pkColumn + "`$1");
133
+ sqlText = sqlText.replace(
134
+ /\)\s*$/,
135
+ ", constraint `" + pkName + "` primary key (`" + pkColumn + "`))",
136
+ );
137
+
138
+ return {
139
+ ...compiled,
140
+ sql: sqlText,
141
+ };
142
+ }
104
143
  }