@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
@@ -0,0 +1,593 @@
1
+ import {
2
+ defaultNamingStrategyForDatabase,
3
+ type SupportedDatabase,
4
+ } from "../adapters/generic-sql/driver-config";
5
+ import type { SQLiteStorageMode } from "../adapters/generic-sql/sqlite-storage";
6
+ import { sqliteStorageDefault, sqliteStoragePrisma } from "../adapters/generic-sql/sqlite-storage";
7
+ import { internalSchema } from "../fragments/internal-fragment.schema";
8
+ import {
9
+ sanitizeNamespace,
10
+ createNamingResolver,
11
+ type NamingResolver,
12
+ type SqlNamingStrategy,
13
+ } from "../naming/sql-naming";
14
+ import type { AnyColumn, AnySchema, AnyTable, Relation } from "../schema/create";
15
+ import { parseVarchar } from "../util/parse";
16
+
17
+ export interface GeneratePrismaSchemaOptions {
18
+ sqliteStorageMode?: SQLiteStorageMode;
19
+ namingStrategy?: SqlNamingStrategy;
20
+ }
21
+
22
+ const VALID_IDENTIFIER = /^[A-Za-z_][A-Za-z0-9_]*$/;
23
+
24
+ function isValidIdentifier(name: string): boolean {
25
+ return VALID_IDENTIFIER.test(name);
26
+ }
27
+
28
+ function sanitizeIdentifier(name: string): string {
29
+ const sanitized = name.replace(/[^A-Za-z0-9_]/g, "_");
30
+ if (sanitized.length === 0) {
31
+ return "_";
32
+ }
33
+ if (/^[0-9]/.test(sanitized)) {
34
+ return `_${sanitized}`;
35
+ }
36
+ return sanitized;
37
+ }
38
+
39
+ function ensureUniqueName(base: string, used: Set<string>): string {
40
+ if (!used.has(base)) {
41
+ return base;
42
+ }
43
+ let index = 1;
44
+ let candidate = `${base}_${index}`;
45
+ while (used.has(candidate)) {
46
+ index += 1;
47
+ candidate = `${base}_${index}`;
48
+ }
49
+ return candidate;
50
+ }
51
+
52
+ function toPascalCase(value: string): string {
53
+ return value
54
+ .split(/[_-]+/)
55
+ .filter(Boolean)
56
+ .map((part) => part[0]?.toUpperCase() + part.slice(1))
57
+ .join("");
58
+ }
59
+
60
+ function isVarcharType(value: string): value is `varchar(${number})` {
61
+ return value.startsWith("varchar(");
62
+ }
63
+
64
+ function getModelName(table: AnyTable, namespace: string | null): string {
65
+ const base = toPascalCase(table.name);
66
+ if (!namespace) {
67
+ return base;
68
+ }
69
+ return `${base}_${sanitizeNamespace(namespace)}`;
70
+ }
71
+
72
+ function getPhysicalTableName(table: AnyTable, resolver?: NamingResolver): string {
73
+ return resolver ? resolver.getTableName(table.name) : table.name;
74
+ }
75
+
76
+ function getRelationName(
77
+ namespace: string | null,
78
+ from: string,
79
+ referenceName: string,
80
+ to: string,
81
+ ): string {
82
+ if (!namespace) {
83
+ return `${from}_${referenceName}_${to}`;
84
+ }
85
+ return `${namespace}_${from}_${referenceName}_${to}`;
86
+ }
87
+
88
+ function getForeignKeyMapName(
89
+ table: AnyTable,
90
+ relation: Relation,
91
+ _namespace: string | null,
92
+ resolver?: NamingResolver,
93
+ ): string {
94
+ if (resolver) {
95
+ return resolver.getForeignKeyName({
96
+ logicalTable: table.name,
97
+ logicalReferencedTable: relation.table.name,
98
+ referenceName: relation.name,
99
+ });
100
+ }
101
+ return `${table.name}_${relation.table.name}_${relation.name}_fk`;
102
+ }
103
+
104
+ function getIndexMapName(
105
+ indexName: string,
106
+ tableName: string,
107
+ namespace: string | null,
108
+ resolver?: NamingResolver,
109
+ unique?: boolean,
110
+ ): string {
111
+ if (!resolver) {
112
+ return namespace ? `${indexName}_${namespace}` : indexName;
113
+ }
114
+ return unique
115
+ ? resolver.getUniqueIndexName(indexName, tableName)
116
+ : resolver.getIndexName(indexName, tableName);
117
+ }
118
+
119
+ function getPrismaScalarType(
120
+ column: AnyColumn,
121
+ provider: SupportedDatabase,
122
+ sqliteStorageMode: SQLiteStorageMode,
123
+ ): { type: string; nativeType?: string } {
124
+ const internalIdType = provider === "sqlite" ? "Int" : "BigInt";
125
+
126
+ if (column.role === "internal-id") {
127
+ return { type: internalIdType };
128
+ }
129
+
130
+ if (column.role === "reference") {
131
+ return { type: internalIdType };
132
+ }
133
+
134
+ if (isVarcharType(column.type)) {
135
+ const length = parseVarchar(column.type);
136
+ if (provider === "postgresql" || provider === "mysql") {
137
+ return { type: "String", nativeType: `@db.VarChar(${length})` };
138
+ }
139
+ return { type: "String" };
140
+ }
141
+
142
+ switch (column.type) {
143
+ case "string":
144
+ return { type: "String" };
145
+ case "integer":
146
+ return { type: "Int" };
147
+ case "bigint":
148
+ if (provider === "sqlite" && sqliteStorageMode.bigintStorage === "blob") {
149
+ return { type: "Bytes" };
150
+ }
151
+ return { type: "BigInt" };
152
+ case "bool":
153
+ return { type: "Boolean" };
154
+ case "decimal":
155
+ if (provider === "sqlite") {
156
+ return { type: "Float" };
157
+ }
158
+ return { type: "Decimal" };
159
+ case "binary":
160
+ return { type: "Bytes" };
161
+ case "json":
162
+ if (provider === "postgresql") {
163
+ return { type: "Json", nativeType: "@db.Json" };
164
+ }
165
+ return { type: "Json" };
166
+ case "timestamp":
167
+ if (provider === "sqlite" && sqliteStorageMode.timestampStorage === "epoch-ms") {
168
+ return { type: "Int" };
169
+ }
170
+ return { type: "DateTime" };
171
+ case "date":
172
+ if (provider === "sqlite" && sqliteStorageMode.dateStorage === "epoch-ms") {
173
+ return { type: "Int" };
174
+ }
175
+ if (provider === "postgresql" || provider === "mysql") {
176
+ return { type: "DateTime", nativeType: "@db.Date" };
177
+ }
178
+ return { type: "DateTime" };
179
+ default: {
180
+ const exhaustiveCheck: never = column.type;
181
+ throw new Error(`Unsupported column type: ${exhaustiveCheck}`);
182
+ }
183
+ }
184
+ }
185
+
186
+ function formatDefaultValue(value: unknown): string {
187
+ if (value instanceof Date) {
188
+ return JSON.stringify(value.toISOString());
189
+ }
190
+ if (typeof value === "bigint") {
191
+ return value.toString();
192
+ }
193
+ return JSON.stringify(value);
194
+ }
195
+
196
+ function getColumnDefault(
197
+ column: AnyColumn,
198
+ provider: SupportedDatabase,
199
+ sqliteStorageMode: SQLiteStorageMode,
200
+ ): string | undefined {
201
+ if (!column.default) {
202
+ return undefined;
203
+ }
204
+
205
+ if ("value" in column.default) {
206
+ return `@default(${formatDefaultValue(column.default.value)})`;
207
+ }
208
+
209
+ if ("dbSpecial" in column.default && column.default.dbSpecial === "now") {
210
+ const scalar = getPrismaScalarType(column, provider, sqliteStorageMode);
211
+ if (scalar.type === "DateTime") {
212
+ return "@default(now())";
213
+ }
214
+ if (provider === "sqlite") {
215
+ const storage =
216
+ column.type === "date" ? sqliteStorageMode.dateStorage : sqliteStorageMode.timestampStorage;
217
+ if (storage === "epoch-ms") {
218
+ return `@default(dbgenerated("CURRENT_TIMESTAMP"))`;
219
+ }
220
+ }
221
+ }
222
+
223
+ return undefined;
224
+ }
225
+
226
+ function getColumnFieldName(
227
+ columnName: string,
228
+ usedNames: Set<string>,
229
+ ): { fieldName: string; needsMap: boolean } {
230
+ const isValid = isValidIdentifier(columnName);
231
+ const baseName = isValid ? columnName : sanitizeIdentifier(columnName);
232
+ const fieldName = ensureUniqueName(baseName, usedNames);
233
+ return { fieldName, needsMap: fieldName !== columnName };
234
+ }
235
+
236
+ function getRelationFieldName(baseName: string, usedNames: Set<string>): string {
237
+ const validBase = isValidIdentifier(baseName) ? baseName : sanitizeIdentifier(baseName);
238
+ return ensureUniqueName(validBase, usedNames);
239
+ }
240
+
241
+ function isRelationOptional(relation: Relation, columnFieldNames: Map<string, AnyColumn>): boolean {
242
+ for (const [localColumn] of relation.on) {
243
+ const column = columnFieldNames.get(localColumn);
244
+ if (column?.isNullable) {
245
+ return true;
246
+ }
247
+ }
248
+ return false;
249
+ }
250
+
251
+ function getColumnFieldMappings(table: AnyTable): {
252
+ fieldNameByColumn: Map<string, string>;
253
+ columnByName: Map<string, AnyColumn>;
254
+ } {
255
+ const fieldNameByColumn = new Map<string, string>();
256
+ const columnByName = new Map<string, AnyColumn>();
257
+ const usedNames = new Set<string>();
258
+
259
+ for (const column of Object.values(table.columns)) {
260
+ const { fieldName } = getColumnFieldName(column.name, usedNames);
261
+ usedNames.add(fieldName);
262
+ fieldNameByColumn.set(column.name, fieldName);
263
+ columnByName.set(column.name, column);
264
+ }
265
+
266
+ return { fieldNameByColumn, columnByName };
267
+ }
268
+
269
+ function areInverseRelations(one: Relation, many: Relation): boolean {
270
+ if (one.type !== "one" || many.type !== "many") {
271
+ return false;
272
+ }
273
+ if (one.foreignKey === false || many.foreignKey === false) {
274
+ return false;
275
+ }
276
+ if (one.referencer !== many.table || one.table !== many.referencer) {
277
+ return false;
278
+ }
279
+ return one.on.every(([left, right]) =>
280
+ many.on.some(([manyLeft, manyRight]) => manyLeft === right && manyRight === left),
281
+ );
282
+ }
283
+
284
+ function findMatchingManyRelation(one: Relation): Relation | undefined {
285
+ for (const relation of Object.values(one.table.relations)) {
286
+ if (relation.type !== "many") {
287
+ continue;
288
+ }
289
+ if (relation.foreignKey === false) {
290
+ continue;
291
+ }
292
+ if (areInverseRelations(one, relation)) {
293
+ return relation;
294
+ }
295
+ }
296
+ return undefined;
297
+ }
298
+
299
+ function findMatchingOneRelation(many: Relation): Relation | undefined {
300
+ for (const relation of Object.values(many.table.relations)) {
301
+ if (relation.type !== "one") {
302
+ continue;
303
+ }
304
+ if (relation.foreignKey === false) {
305
+ continue;
306
+ }
307
+ if (areInverseRelations(relation, many)) {
308
+ return relation;
309
+ }
310
+ }
311
+ return undefined;
312
+ }
313
+
314
+ function generateColumnFields(
315
+ table: AnyTable,
316
+ provider: SupportedDatabase,
317
+ sqliteStorageMode: SQLiteStorageMode,
318
+ fieldNameByColumn: Map<string, string>,
319
+ resolver?: NamingResolver,
320
+ ): string[] {
321
+ const lines: string[] = [];
322
+
323
+ for (const column of Object.values(table.columns)) {
324
+ const fieldName = fieldNameByColumn.get(column.name)!;
325
+ const scalar = getPrismaScalarType(column, provider, sqliteStorageMode);
326
+ const isOptional = column.isNullable;
327
+
328
+ const attributes: string[] = [];
329
+
330
+ if (column.role === "internal-id") {
331
+ attributes.push("@id", "@default(autoincrement())");
332
+ }
333
+
334
+ if (column.role === "external-id") {
335
+ attributes.push("@unique", "@default(cuid())");
336
+ }
337
+
338
+ const defaultValue = getColumnDefault(column, provider, sqliteStorageMode);
339
+ if (defaultValue) {
340
+ attributes.push(defaultValue);
341
+ }
342
+
343
+ if (scalar.nativeType) {
344
+ attributes.push(scalar.nativeType);
345
+ }
346
+
347
+ const physicalName = resolver ? resolver.getColumnName(table.name, column.name) : column.name;
348
+ if (fieldName !== physicalName) {
349
+ attributes.push(`@map("${physicalName}")`);
350
+ }
351
+
352
+ const suffix = isOptional ? "?" : "";
353
+ const attrSuffix = attributes.length > 0 ? ` ${attributes.join(" ")}` : "";
354
+ lines.push(` ${fieldName} ${scalar.type}${suffix}${attrSuffix}`);
355
+ }
356
+
357
+ return lines;
358
+ }
359
+
360
+ function generateRelationFields(
361
+ table: AnyTable,
362
+ namespace: string | null,
363
+ fieldNameByColumn: Map<string, string>,
364
+ columnByName: Map<string, AnyColumn>,
365
+ fieldNameByTableColumn: Map<AnyTable, Map<string, string>>,
366
+ resolver?: NamingResolver,
367
+ ): string[] {
368
+ const lines: string[] = [];
369
+ const usedNames = new Set<string>(fieldNameByColumn.values());
370
+ const relations = Object.values(table.relations)
371
+ .slice()
372
+ .sort((a, b) => a.name.localeCompare(b.name));
373
+
374
+ for (const relation of relations) {
375
+ if (relation.type !== "one") {
376
+ continue;
377
+ }
378
+ if (relation.foreignKey === false) {
379
+ continue;
380
+ }
381
+
382
+ const fieldName = getRelationFieldName(relation.name, usedNames);
383
+ usedNames.add(fieldName);
384
+
385
+ const relationName = getRelationName(namespace, table.name, relation.name, relation.table.name);
386
+
387
+ const relatedModel = getModelName(relation.table, namespace);
388
+ const localFields = relation.on.map(([left]) => fieldNameByColumn.get(left) ?? left);
389
+ const referenceFields = relation.on.map(([, right]) => {
390
+ const actualRight = right === "id" ? "_internalId" : right;
391
+ const refFieldNames = fieldNameByTableColumn.get(relation.table);
392
+ return refFieldNames?.get(actualRight) ?? actualRight;
393
+ });
394
+
395
+ const fkMapName = getForeignKeyMapName(table, relation, namespace, resolver);
396
+
397
+ const relationParts = [
398
+ `"${relationName}"`,
399
+ `fields: [${localFields.join(", ")}]`,
400
+ `references: [${referenceFields.join(", ")}]`,
401
+ `map: "${fkMapName}"`,
402
+ ];
403
+
404
+ const optional = isRelationOptional(relation, columnByName);
405
+ const suffix = optional ? "?" : "";
406
+
407
+ lines.push(` ${fieldName} ${relatedModel}${suffix} @relation(${relationParts.join(", ")})`);
408
+ }
409
+
410
+ for (const relation of relations) {
411
+ if (relation.type !== "many") {
412
+ continue;
413
+ }
414
+ if (relation.foreignKey === false) {
415
+ continue;
416
+ }
417
+
418
+ const matchingOne = findMatchingOneRelation(relation);
419
+ const relationName = matchingOne
420
+ ? getRelationName(
421
+ namespace,
422
+ matchingOne.referencer.name,
423
+ matchingOne.name,
424
+ matchingOne.table.name,
425
+ )
426
+ : getRelationName(namespace, relation.referencer.name, relation.name, relation.table.name);
427
+
428
+ const fieldName = getRelationFieldName(relation.name, usedNames);
429
+ usedNames.add(fieldName);
430
+
431
+ const relatedModel = getModelName(relation.table, namespace);
432
+ lines.push(` ${fieldName} ${relatedModel}[] @relation("${relationName}")`);
433
+ }
434
+
435
+ const inverseCandidates: Relation[] = [];
436
+ for (const sourceTable of fieldNameByTableColumn.keys()) {
437
+ for (const rel of Object.values(sourceTable.relations)) {
438
+ if (rel.type === "one" && rel.table === table && rel.foreignKey !== false) {
439
+ inverseCandidates.push(rel);
440
+ }
441
+ }
442
+ }
443
+
444
+ for (const rel of inverseCandidates.sort((a, b) => a.name.localeCompare(b.name))) {
445
+ const matchingMany = findMatchingManyRelation(rel);
446
+ if (matchingMany) {
447
+ continue;
448
+ }
449
+
450
+ const baseName = rel.referencer.name;
451
+ let fieldName = baseName;
452
+ if (usedNames.has(fieldName)) {
453
+ fieldName = `${baseName}_${rel.name}`;
454
+ }
455
+ fieldName = getRelationFieldName(fieldName, usedNames);
456
+ usedNames.add(fieldName);
457
+
458
+ const relationName = getRelationName(namespace, rel.referencer.name, rel.name, rel.table.name);
459
+
460
+ const relatedModel = getModelName(rel.referencer, namespace);
461
+ lines.push(` ${fieldName} ${relatedModel}[] @relation("${relationName}")`);
462
+ }
463
+
464
+ return lines;
465
+ }
466
+
467
+ function generateModel(
468
+ table: AnyTable,
469
+ namespace: string | null,
470
+ provider: SupportedDatabase,
471
+ sqliteStorageMode: SQLiteStorageMode,
472
+ fieldNameByTableColumn: Map<AnyTable, Map<string, string>>,
473
+ columnByTableName: Map<AnyTable, Map<string, AnyColumn>>,
474
+ resolver?: NamingResolver,
475
+ ): string {
476
+ const modelName = getModelName(table, namespace);
477
+ const physicalName = getPhysicalTableName(table, resolver);
478
+
479
+ const fieldNameByColumn = fieldNameByTableColumn.get(table)!;
480
+ const columnByName = columnByTableName.get(table)!;
481
+
482
+ const fieldLines = [
483
+ ...generateColumnFields(table, provider, sqliteStorageMode, fieldNameByColumn, resolver),
484
+ ...generateRelationFields(
485
+ table,
486
+ namespace,
487
+ fieldNameByColumn,
488
+ columnByName,
489
+ fieldNameByTableColumn,
490
+ resolver,
491
+ ),
492
+ ];
493
+
494
+ const indexLines: string[] = [];
495
+ const sortedIndexes = Object.values(table.indexes)
496
+ .slice()
497
+ .sort((a, b) => a.name.localeCompare(b.name));
498
+
499
+ for (const index of sortedIndexes) {
500
+ const fields = index.columnNames
501
+ .map((name) => fieldNameByColumn.get(name as string) ?? name)
502
+ .join(", ");
503
+ const mapName = getIndexMapName(index.name, table.name, namespace, resolver, index.unique);
504
+ const directive = index.unique ? "@@unique" : "@@index";
505
+ indexLines.push(` ${directive}([${fields}], map: "${mapName}")`);
506
+ }
507
+
508
+ indexLines.push(` @@map("${physicalName}")`);
509
+
510
+ const lines = [`model ${modelName} {`, ...fieldLines, ...indexLines, `}`];
511
+ return lines.join("\n");
512
+ }
513
+
514
+ export function generatePrismaSchema(
515
+ fragments: { namespace: string | null; schema: AnySchema }[],
516
+ provider: SupportedDatabase,
517
+ options?: GeneratePrismaSchemaOptions,
518
+ ): string {
519
+ const sqliteStorageMode =
520
+ options?.sqliteStorageMode ??
521
+ (provider === "sqlite" ? sqliteStoragePrisma : sqliteStorageDefault);
522
+ const namingStrategy = options?.namingStrategy ?? defaultNamingStrategyForDatabase(provider);
523
+ const sortedFragments = [...fragments].sort((a, b) => {
524
+ const aInternal = a.schema === internalSchema;
525
+ const bInternal = b.schema === internalSchema;
526
+ if (aInternal) {
527
+ return -1;
528
+ }
529
+ if (bInternal) {
530
+ return 1;
531
+ }
532
+ return a.schema.name.localeCompare(b.schema.name);
533
+ });
534
+
535
+ const namespaces: Array<string | null> = [];
536
+ const seenNamespaces = new Set<string | null>();
537
+ for (const fragment of sortedFragments) {
538
+ if (!seenNamespaces.has(fragment.namespace)) {
539
+ seenNamespaces.add(fragment.namespace);
540
+ namespaces.push(fragment.namespace);
541
+ }
542
+ }
543
+
544
+ const fieldNameByTableColumn = new Map<AnyTable, Map<string, string>>();
545
+ const columnByTableName = new Map<AnyTable, Map<string, AnyColumn>>();
546
+
547
+ for (const fragment of sortedFragments) {
548
+ for (const table of Object.values(fragment.schema.tables)) {
549
+ const mapping = getColumnFieldMappings(table);
550
+ fieldNameByTableColumn.set(table, mapping.fieldNameByColumn);
551
+ columnByTableName.set(table, mapping.columnByName);
552
+ }
553
+ }
554
+
555
+ const headerNamespaces = namespaces.filter(Boolean);
556
+ const headerSuffix = headerNamespaces.length > 0 ? headerNamespaces.join(", ") : "(internal)";
557
+ const lines: string[] = [
558
+ "// Generated by Fragno Prisma adapter.",
559
+ `// Provider: ${provider}`,
560
+ `// Namespaces: ${headerSuffix}`,
561
+ "",
562
+ ];
563
+
564
+ const models: string[] = [];
565
+
566
+ for (const fragment of sortedFragments) {
567
+ const resolver = createNamingResolver(fragment.schema, fragment.namespace, namingStrategy);
568
+ const tables = Object.values(fragment.schema.tables)
569
+ .slice()
570
+ .sort((a, b) => {
571
+ const aName = getPhysicalTableName(a, resolver);
572
+ const bName = getPhysicalTableName(b, resolver);
573
+ return aName.localeCompare(bName);
574
+ });
575
+
576
+ for (const table of tables) {
577
+ models.push(
578
+ generateModel(
579
+ table,
580
+ fragment.namespace,
581
+ provider,
582
+ sqliteStorageMode,
583
+ fieldNameByTableColumn,
584
+ columnByTableName,
585
+ resolver,
586
+ ),
587
+ );
588
+ }
589
+ }
590
+
591
+ lines.push(models.join("\n\n"));
592
+ return lines.join("\n");
593
+ }
@@ -1,9 +1,11 @@
1
- import SQLite from "better-sqlite3";
2
1
  import { describe, expect, it } from "vitest";
3
- import { SqlDriverAdapter } from "./sql-driver-adapter";
2
+
3
+ import SQLite from "better-sqlite3";
4
+ import { SqliteDialect } from "kysely";
5
+
4
6
  import type { GenericSQLPlugin } from "./query-executor/plugin";
5
7
  import { sql } from "./sql";
6
- import { SqliteDialect } from "kysely";
8
+ import { SqlDriverAdapter } from "./sql-driver-adapter";
7
9
 
8
10
  describe("better-sqlite3", () => {
9
11
  it("Should be able to execute queries using better-sqlite3", async () => {
@@ -111,7 +111,6 @@ export class DurableObjectDialect implements Dialect {
111
111
 
112
112
  class DurableObjectDriver implements Driver {
113
113
  #config: DODialectConfig;
114
- #connection: DOConnection | null = null;
115
114
 
116
115
  constructor(config: DODialectConfig) {
117
116
  this.#config = config;
@@ -120,11 +119,7 @@ class DurableObjectDriver implements Driver {
120
119
  async init(): Promise<void> {}
121
120
 
122
121
  async acquireConnection(): Promise<DatabaseConnection> {
123
- // Ensure only one connection exists
124
- if (!this.#connection) {
125
- this.#connection = new DOConnection(this.#config);
126
- }
127
- return this.#connection;
122
+ return new DOConnection(this.#config);
128
123
  }
129
124
 
130
125
  async beginTransaction(conn: DOConnection): Promise<void> {
@@ -140,11 +135,11 @@ class DurableObjectDriver implements Driver {
140
135
  }
141
136
 
142
137
  async releaseConnection(_conn: DOConnection): Promise<void> {
143
- this.#connection = null;
138
+ // No-op
144
139
  }
145
140
 
146
141
  async destroy(): Promise<void> {
147
- this.#connection = null;
142
+ // No-op
148
143
  }
149
144
  }
150
145
 
@@ -7,8 +7,8 @@
7
7
  * Simplified to remove query compilation.
8
8
  */
9
9
 
10
- import type { DatabaseConnection } from "../sql-driver";
11
10
  import type { ConnectionProvider } from "../connection/connection-provider";
11
+ import type { DatabaseConnection } from "../sql-driver";
12
12
  import type { GenericSQLPlugin } from "./plugin";
13
13
  import { QueryExecutorBase } from "./query-executor-base";
14
14
 
@@ -7,8 +7,8 @@
7
7
  * Simplified to remove query compilation, streaming, and batching.
8
8
  */
9
9
 
10
- import type { DatabaseConnection, CompiledQuery, QueryResult } from "../sql-driver";
11
10
  import type { ConnectionProvider } from "../connection/connection-provider";
11
+ import type { DatabaseConnection, CompiledQuery, QueryResult } from "../sql-driver";
12
12
  import type { GenericSQLPlugin } from "./plugin";
13
13
  import type { QueryExecutor } from "./query-executor";
14
14
 
@@ -7,8 +7,8 @@
7
7
  * Simplified to remove query compilation, streaming, and batching.
8
8
  */
9
9
 
10
- import type { CompiledQuery, QueryResult } from "../sql-driver";
11
10
  import type { ConnectionProvider } from "../connection/connection-provider";
11
+ import type { CompiledQuery, QueryResult } from "../sql-driver";
12
12
  import type { GenericSQLPlugin } from "./plugin";
13
13
 
14
14
  /**
@@ -5,13 +5,13 @@
5
5
  * Copyright (c) 2022 Sami Koskimäki
6
6
  */
7
7
 
8
- import type { CompiledQuery, Dialect, QueryResult } from "./sql-driver";
9
8
  import { DefaultConnectionProvider } from "./connection/connection-provider";
10
9
  import { SingleConnectionProvider } from "./connection/single-connection-provider";
11
10
  import { RuntimeDriver } from "./driver/runtime-driver";
11
+ import { DefaultQueryExecutor } from "./query-executor/default-query-executor";
12
12
  import type { GenericSQLPlugin } from "./query-executor/plugin";
13
13
  import type { QueryExecutor } from "./query-executor/query-executor";
14
- import { DefaultQueryExecutor } from "./query-executor/default-query-executor";
14
+ import type { CompiledQuery, Dialect, QueryResult } from "./sql-driver";
15
15
 
16
16
  export class SqlDriverAdapter {
17
17
  readonly #dialect: Dialect;
@@ -1,10 +1,11 @@
1
- import type { CompiledQuery, Dialect } from "./sql-driver";
2
1
  import {
3
2
  sql as kyselySql,
4
3
  type QueryExecutor,
5
4
  type CompiledQuery as KyselyCompiledQuery,
6
5
  } from "kysely";
7
6
 
7
+ import type { CompiledQuery, Dialect } from "./sql-driver";
8
+
8
9
  /**
9
10
  * Wrapper around Kysely's RawBuilder that provides a compile() method with a dialect parameter.
10
11
  */