@fragno-dev/db 0.3.0 → 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 (516) hide show
  1. package/.turbo/turbo-build.log +327 -160
  2. package/CHANGELOG.md +74 -0
  3. package/README.md +24 -0
  4. package/dist/adapters/adapters.d.ts +1 -1
  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/generic-sql-adapter.d.ts +0 -3
  8. package/dist/adapters/generic-sql/generic-sql-adapter.d.ts.map +1 -1
  9. package/dist/adapters/generic-sql/generic-sql-adapter.js +11 -12
  10. package/dist/adapters/generic-sql/generic-sql-adapter.js.map +1 -1
  11. package/dist/adapters/generic-sql/generic-sql-uow-executor.js +46 -6
  12. package/dist/adapters/generic-sql/generic-sql-uow-executor.js.map +1 -1
  13. package/dist/adapters/generic-sql/migration/cold-kysely.js.map +1 -1
  14. package/dist/adapters/generic-sql/migration/dialect/mysql.js +1 -1
  15. package/dist/adapters/generic-sql/migration/dialect/mysql.js.map +1 -1
  16. package/dist/adapters/generic-sql/migration/dialect/postgres.js +1 -1
  17. package/dist/adapters/generic-sql/migration/dialect/postgres.js.map +1 -1
  18. package/dist/adapters/generic-sql/migration/dialect/sqlite.js +185 -19
  19. package/dist/adapters/generic-sql/migration/dialect/sqlite.js.map +1 -1
  20. package/dist/adapters/generic-sql/migration/executor.d.ts.map +1 -1
  21. package/dist/adapters/generic-sql/migration/executor.js +30 -3
  22. package/dist/adapters/generic-sql/migration/executor.js.map +1 -1
  23. package/dist/adapters/generic-sql/migration/prepared-migrations.d.ts.map +1 -1
  24. package/dist/adapters/generic-sql/migration/prepared-migrations.js +3 -3
  25. package/dist/adapters/generic-sql/migration/prepared-migrations.js.map +1 -1
  26. package/dist/adapters/generic-sql/migration/sql-generator.js +1 -1
  27. package/dist/adapters/generic-sql/migration/sql-generator.js.map +1 -1
  28. package/dist/adapters/generic-sql/query/create-sql-query-compiler.js +1 -1
  29. package/dist/adapters/generic-sql/query/create-sql-query-compiler.js.map +1 -1
  30. package/dist/adapters/generic-sql/query/cursor-utils.js.map +1 -1
  31. package/dist/adapters/generic-sql/query/db-now-sql.js +27 -0
  32. package/dist/adapters/generic-sql/query/db-now-sql.js.map +1 -0
  33. package/dist/adapters/generic-sql/query/generic-sql-uow-operation-compiler.js +9 -6
  34. package/dist/adapters/generic-sql/query/generic-sql-uow-operation-compiler.js.map +1 -1
  35. package/dist/adapters/generic-sql/query/select-builder.js.map +1 -1
  36. package/dist/adapters/generic-sql/query/sql-query-compiler.js +37 -9
  37. package/dist/adapters/generic-sql/query/sql-query-compiler.js.map +1 -1
  38. package/dist/adapters/generic-sql/query/where-builder.js +24 -20
  39. package/dist/adapters/generic-sql/query/where-builder.js.map +1 -1
  40. package/dist/adapters/generic-sql/uow-decoder.js +1 -1
  41. package/dist/adapters/generic-sql/uow-decoder.js.map +1 -1
  42. package/dist/adapters/generic-sql/uow-encoder.js +8 -9
  43. package/dist/adapters/generic-sql/uow-encoder.js.map +1 -1
  44. package/dist/adapters/in-memory/condition-evaluator.js +10 -6
  45. package/dist/adapters/in-memory/condition-evaluator.js.map +1 -1
  46. package/dist/adapters/in-memory/in-memory-adapter.d.ts.map +1 -1
  47. package/dist/adapters/in-memory/in-memory-adapter.js +45 -25
  48. package/dist/adapters/in-memory/in-memory-adapter.js.map +1 -1
  49. package/dist/adapters/in-memory/in-memory-uow.js +236 -13
  50. package/dist/adapters/in-memory/in-memory-uow.js.map +1 -1
  51. package/dist/adapters/in-memory/options.d.ts +2 -0
  52. package/dist/adapters/in-memory/options.d.ts.map +1 -1
  53. package/dist/adapters/in-memory/options.js +3 -2
  54. package/dist/adapters/in-memory/options.js.map +1 -1
  55. package/dist/adapters/in-memory/reference-resolution.js.map +1 -1
  56. package/dist/adapters/in-memory/store.js +1 -1
  57. package/dist/adapters/in-memory/store.js.map +1 -1
  58. package/dist/adapters/shared/from-unit-of-work-compiler.js +51 -24
  59. package/dist/adapters/shared/from-unit-of-work-compiler.js.map +1 -1
  60. package/dist/adapters/shared/uow-operation-compiler.js.map +1 -1
  61. package/dist/browser/adapters/adapters.d.ts +61 -0
  62. package/dist/browser/adapters/adapters.d.ts.map +1 -0
  63. package/dist/browser/adapters/generic-sql/migration/executor.d.ts +15 -0
  64. package/dist/browser/adapters/generic-sql/migration/executor.d.ts.map +1 -0
  65. package/dist/browser/adapters/generic-sql/migration/prepared-migrations.d.ts +66 -0
  66. package/dist/browser/adapters/generic-sql/migration/prepared-migrations.d.ts.map +1 -0
  67. package/dist/browser/adapters/generic-sql/sqlite-storage.d.ts +11 -0
  68. package/dist/browser/adapters/generic-sql/sqlite-storage.d.ts.map +1 -0
  69. package/dist/browser/adapters/in-memory/in-memory-adapter.d.ts +5 -0
  70. package/dist/browser/adapters/in-memory/index.d.ts +2 -0
  71. package/dist/browser/adapters/in-memory/options.d.ts +1 -0
  72. package/dist/browser/db-fragment-definition-builder.d.ts +237 -0
  73. package/dist/browser/db-fragment-definition-builder.d.ts.map +1 -0
  74. package/dist/browser/durable-hooks.d.ts +3 -0
  75. package/dist/browser/fragments/internal-fragment.d.ts +317 -0
  76. package/dist/browser/fragments/internal-fragment.d.ts.map +1 -0
  77. package/dist/browser/fragments/internal-fragment.schema.d.ts +1 -0
  78. package/dist/browser/hooks/durable-hooks-logger.d.ts +10 -0
  79. package/dist/browser/hooks/durable-hooks-logger.d.ts.map +1 -0
  80. package/dist/browser/hooks/hooks.d.ts +146 -0
  81. package/dist/browser/hooks/hooks.d.ts.map +1 -0
  82. package/dist/browser/id.js +1 -0
  83. package/dist/browser/internal/adapter-registry.d.ts +4 -0
  84. package/dist/browser/internal/outbox-state.d.ts +2 -0
  85. package/dist/browser/mod.d.ts +15 -0
  86. package/dist/browser/mod.d.ts.map +1 -0
  87. package/dist/browser/mod.js +17 -0
  88. package/dist/browser/mod.js.map +1 -0
  89. package/dist/browser/mod2.d.ts +48 -0
  90. package/dist/browser/mod2.d.ts.map +1 -0
  91. package/dist/browser/naming/sql-naming.d.ts +19 -0
  92. package/dist/browser/naming/sql-naming.d.ts.map +1 -0
  93. package/dist/browser/outbox/outbox.d.ts +21 -0
  94. package/dist/browser/outbox/outbox.d.ts.map +1 -0
  95. package/dist/browser/query/column-defaults.js +1 -0
  96. package/dist/browser/query/condition-builder.d.ts +44 -0
  97. package/dist/browser/query/condition-builder.d.ts.map +1 -0
  98. package/dist/browser/query/condition-builder.js +97 -0
  99. package/dist/browser/query/condition-builder.js.map +1 -0
  100. package/dist/browser/query/cursor.d.ts +105 -0
  101. package/dist/browser/query/cursor.d.ts.map +1 -0
  102. package/dist/browser/query/cursor.js +150 -0
  103. package/dist/browser/query/cursor.js.map +1 -0
  104. package/dist/browser/query/db-now.d.ts +22 -0
  105. package/dist/browser/query/db-now.d.ts.map +1 -0
  106. package/dist/browser/query/db-now.js +33 -0
  107. package/dist/browser/query/db-now.js.map +1 -0
  108. package/dist/browser/query/orm/orm.d.ts +18 -0
  109. package/dist/browser/query/orm/orm.d.ts.map +1 -0
  110. package/dist/browser/query/simple-query-interface.d.ts +108 -0
  111. package/dist/browser/query/simple-query-interface.d.ts.map +1 -0
  112. package/dist/browser/query/unit-of-work/execute-unit-of-work.d.ts +423 -0
  113. package/dist/browser/query/unit-of-work/execute-unit-of-work.d.ts.map +1 -0
  114. package/dist/browser/query/unit-of-work/execute-unit-of-work.js +507 -0
  115. package/dist/browser/query/unit-of-work/execute-unit-of-work.js.map +1 -0
  116. package/dist/browser/query/unit-of-work/retry-policy.d.ts +23 -0
  117. package/dist/browser/query/unit-of-work/retry-policy.d.ts.map +1 -0
  118. package/dist/browser/query/unit-of-work/retry-policy.js +40 -0
  119. package/dist/browser/query/unit-of-work/retry-policy.js.map +1 -0
  120. package/dist/browser/query/unit-of-work/unit-of-work.d.ts +703 -0
  121. package/dist/browser/query/unit-of-work/unit-of-work.d.ts.map +1 -0
  122. package/dist/browser/query/unit-of-work/unit-of-work.js +1206 -0
  123. package/dist/browser/query/unit-of-work/unit-of-work.js.map +1 -0
  124. package/dist/browser/query/value-encoding.js +38 -0
  125. package/dist/browser/query/value-encoding.js.map +1 -0
  126. package/dist/browser/schema/create.d.ts +326 -0
  127. package/dist/browser/schema/create.d.ts.map +1 -0
  128. package/dist/browser/schema/create.js +89 -0
  129. package/dist/browser/schema/create.js.map +1 -0
  130. package/dist/browser/schema/generate-id.js +28 -0
  131. package/dist/browser/schema/generate-id.js.map +1 -0
  132. package/dist/browser/shared/providers.d.ts +6 -0
  133. package/dist/browser/shared/providers.d.ts.map +1 -0
  134. package/dist/browser/sql-driver/connection/connection-provider.d.ts +13 -0
  135. package/dist/browser/sql-driver/connection/connection-provider.d.ts.map +1 -0
  136. package/dist/browser/sql-driver/dialect-adapter/dialect-adapter.d.ts +7 -0
  137. package/dist/browser/sql-driver/dialect-adapter/dialect-adapter.d.ts.map +1 -0
  138. package/dist/browser/sql-driver/driver/runtime-driver.d.ts +23 -0
  139. package/dist/browser/sql-driver/driver/runtime-driver.d.ts.map +1 -0
  140. package/dist/browser/sql-driver/query-executor/plugin.d.ts +17 -0
  141. package/dist/browser/sql-driver/query-executor/plugin.d.ts.map +1 -0
  142. package/dist/browser/sql-driver/query-executor/query-executor.d.ts +36 -0
  143. package/dist/browser/sql-driver/query-executor/query-executor.d.ts.map +1 -0
  144. package/dist/browser/sql-driver/sql-driver-adapter.d.ts +29 -0
  145. package/dist/browser/sql-driver/sql-driver-adapter.d.ts.map +1 -0
  146. package/dist/browser/sql-driver/sql-driver.d.ts +38 -0
  147. package/dist/browser/sql-driver/sql-driver.d.ts.map +1 -0
  148. package/dist/browser/sync/commands.d.ts +15 -0
  149. package/dist/browser/sync/commands.d.ts.map +1 -0
  150. package/dist/browser/sync/commands.js +27 -0
  151. package/dist/browser/sync/commands.js.map +1 -0
  152. package/dist/browser/sync/types.d.ts +63 -0
  153. package/dist/browser/sync/types.d.ts.map +1 -0
  154. package/dist/browser/util/types.d.ts +8 -0
  155. package/dist/browser/util/types.d.ts.map +1 -0
  156. package/dist/browser/with-database.d.ts +29 -0
  157. package/dist/browser/with-database.d.ts.map +1 -0
  158. package/dist/client.d.ts +4 -0
  159. package/dist/client.js +5 -0
  160. package/dist/db-fragment-definition-builder.d.ts +85 -28
  161. package/dist/db-fragment-definition-builder.d.ts.map +1 -1
  162. package/dist/db-fragment-definition-builder.js +374 -46
  163. package/dist/db-fragment-definition-builder.js.map +1 -1
  164. package/dist/dispatchers/cloudflare-do/dispatcher.d.ts +20 -0
  165. package/dist/dispatchers/cloudflare-do/dispatcher.d.ts.map +1 -0
  166. package/dist/dispatchers/cloudflare-do/dispatcher.js +147 -0
  167. package/dist/dispatchers/cloudflare-do/dispatcher.js.map +1 -0
  168. package/dist/dispatchers/cloudflare-do/index.d.ts +5 -20
  169. package/dist/dispatchers/cloudflare-do/index.d.ts.map +1 -1
  170. package/dist/dispatchers/cloudflare-do/index.js +23 -55
  171. package/dist/dispatchers/cloudflare-do/index.js.map +1 -1
  172. package/dist/dispatchers/node/dispatcher.d.ts +14 -0
  173. package/dist/dispatchers/node/dispatcher.d.ts.map +1 -0
  174. package/dist/dispatchers/node/dispatcher.js +80 -0
  175. package/dist/dispatchers/node/dispatcher.js.map +1 -0
  176. package/dist/dispatchers/node/index.d.ts +5 -10
  177. package/dist/dispatchers/node/index.d.ts.map +1 -1
  178. package/dist/dispatchers/node/index.js +21 -53
  179. package/dist/dispatchers/node/index.js.map +1 -1
  180. package/dist/durable-hooks.d.ts +31 -0
  181. package/dist/durable-hooks.d.ts.map +1 -0
  182. package/dist/durable-hooks.js +23 -0
  183. package/dist/durable-hooks.js.map +1 -0
  184. package/dist/fragments/internal-fragment.d.ts +128 -27
  185. package/dist/fragments/internal-fragment.d.ts.map +1 -1
  186. package/dist/fragments/internal-fragment.js +125 -78
  187. package/dist/fragments/internal-fragment.js.map +1 -1
  188. package/dist/fragments/internal-fragment.routes.js +138 -3
  189. package/dist/fragments/internal-fragment.routes.js.map +1 -1
  190. package/dist/fragments/internal-fragment.schema.d.ts +7 -1
  191. package/dist/fragments/internal-fragment.schema.d.ts.map +1 -1
  192. package/dist/fragments/internal-fragment.schema.js +18 -1
  193. package/dist/fragments/internal-fragment.schema.js.map +1 -1
  194. package/dist/hooks/durable-hooks-logger.d.ts +10 -0
  195. package/dist/hooks/durable-hooks-logger.d.ts.map +1 -0
  196. package/dist/hooks/durable-hooks-logger.js +75 -0
  197. package/dist/hooks/durable-hooks-logger.js.map +1 -0
  198. package/dist/hooks/durable-hooks-processor.d.ts +1 -14
  199. package/dist/hooks/durable-hooks-processor.js +58 -10
  200. package/dist/hooks/durable-hooks-processor.js.map +1 -1
  201. package/dist/hooks/durable-hooks-runtime.js +44 -0
  202. package/dist/hooks/durable-hooks-runtime.js.map +1 -0
  203. package/dist/hooks/hooks.d.ts +60 -2
  204. package/dist/hooks/hooks.d.ts.map +1 -1
  205. package/dist/hooks/hooks.js +214 -53
  206. package/dist/hooks/hooks.js.map +1 -1
  207. package/dist/id.d.ts +2 -2
  208. package/dist/id.js +2 -2
  209. package/dist/internal/adapter-registry.d.ts +11 -0
  210. package/dist/internal/adapter-registry.d.ts.map +1 -0
  211. package/dist/internal/adapter-registry.js +135 -0
  212. package/dist/internal/adapter-registry.js.map +1 -0
  213. package/dist/internal/outbox-state.d.ts +2 -0
  214. package/dist/internal/outbox-state.js +26 -0
  215. package/dist/internal/outbox-state.js.map +1 -0
  216. package/dist/migration-engine/auto-from-schema.d.ts +33 -0
  217. package/dist/migration-engine/auto-from-schema.d.ts.map +1 -0
  218. package/dist/migration-engine/auto-from-schema.js +210 -27
  219. package/dist/migration-engine/auto-from-schema.js.map +1 -1
  220. package/dist/migration-engine/generation-engine.d.ts.map +1 -1
  221. package/dist/migration-engine/generation-engine.js +17 -5
  222. package/dist/migration-engine/generation-engine.js.map +1 -1
  223. package/dist/migration-engine/shared.d.ts +113 -0
  224. package/dist/migration-engine/shared.d.ts.map +1 -0
  225. package/dist/migration-engine/shared.js.map +1 -1
  226. package/dist/mod.d.ts +12 -11
  227. package/dist/mod.d.ts.map +1 -1
  228. package/dist/mod.js +10 -10
  229. package/dist/mod.js.map +1 -1
  230. package/dist/naming/sql-naming.d.ts.map +1 -1
  231. package/dist/naming/sql-naming.js.map +1 -1
  232. package/dist/outbox/outbox-builder.js.map +1 -1
  233. package/dist/outbox/outbox.d.ts +3 -1
  234. package/dist/outbox/outbox.d.ts.map +1 -1
  235. package/dist/outbox/outbox.js.map +1 -1
  236. package/dist/query/column-defaults.js.map +1 -1
  237. package/dist/query/condition-builder.d.ts +7 -1
  238. package/dist/query/condition-builder.d.ts.map +1 -1
  239. package/dist/query/condition-builder.js +5 -1
  240. package/dist/query/condition-builder.js.map +1 -1
  241. package/dist/query/cursor-client.d.ts +105 -0
  242. package/dist/query/cursor-client.d.ts.map +1 -0
  243. package/dist/query/cursor-client.js +165 -0
  244. package/dist/query/cursor-client.js.map +1 -0
  245. package/dist/query/cursor.d.ts.map +1 -1
  246. package/dist/query/cursor.js +7 -1
  247. package/dist/query/cursor.js.map +1 -1
  248. package/dist/query/db-now.d.ts +15 -1
  249. package/dist/query/db-now.d.ts.map +1 -1
  250. package/dist/query/db-now.js +30 -2
  251. package/dist/query/db-now.js.map +1 -1
  252. package/dist/query/orm/orm.js.map +1 -1
  253. package/dist/query/serialize/create-sql-serializer.js +2 -2
  254. package/dist/query/serialize/create-sql-serializer.js.map +1 -1
  255. package/dist/query/serialize/dialect/mysql-serializer.js.map +1 -1
  256. package/dist/query/serialize/dialect/postgres-serializer.js.map +1 -1
  257. package/dist/query/serialize/dialect/sqlite-serializer.js +6 -2
  258. package/dist/query/serialize/dialect/sqlite-serializer.js.map +1 -1
  259. package/dist/query/simple-query-interface.d.ts +7 -3
  260. package/dist/query/simple-query-interface.d.ts.map +1 -1
  261. package/dist/query/unit-of-work/execute-unit-of-work.d.ts +37 -2
  262. package/dist/query/unit-of-work/execute-unit-of-work.d.ts.map +1 -1
  263. package/dist/query/unit-of-work/execute-unit-of-work.js +39 -18
  264. package/dist/query/unit-of-work/execute-unit-of-work.js.map +1 -1
  265. package/dist/query/unit-of-work/unit-of-work.d.ts +42 -16
  266. package/dist/query/unit-of-work/unit-of-work.d.ts.map +1 -1
  267. package/dist/query/unit-of-work/unit-of-work.js +50 -6
  268. package/dist/query/unit-of-work/unit-of-work.js.map +1 -1
  269. package/dist/query/value-decoding.js +8 -1
  270. package/dist/query/value-decoding.js.map +1 -1
  271. package/dist/query/value-encoding.js.map +1 -1
  272. package/dist/schema/create.d.ts +69 -25
  273. package/dist/schema/create.d.ts.map +1 -1
  274. package/dist/schema/create.js +91 -16
  275. package/dist/schema/create.js.map +1 -1
  276. package/dist/schema/type-conversion/create-sql-type-mapper.js +1 -1
  277. package/dist/schema/type-conversion/create-sql-type-mapper.js.map +1 -1
  278. package/dist/schema/type-conversion/dialect/sqlite.js.map +1 -1
  279. package/dist/schema/validator.d.ts.map +1 -1
  280. package/dist/schema/validator.js.map +1 -1
  281. package/dist/schema-output/drizzle.d.ts.map +1 -1
  282. package/dist/schema-output/drizzle.js +8 -6
  283. package/dist/schema-output/drizzle.js.map +1 -1
  284. package/dist/schema-output/prisma.d.ts.map +1 -1
  285. package/dist/schema-output/prisma.js +21 -10
  286. package/dist/schema-output/prisma.js.map +1 -1
  287. package/dist/sql-driver/dialects/durable-object-dialect.js +3 -9
  288. package/dist/sql-driver/dialects/durable-object-dialect.js.map +1 -1
  289. package/dist/sql-driver/query-executor/default-query-executor.js.map +1 -1
  290. package/dist/sql-driver/query-executor/query-executor-base.js.map +1 -1
  291. package/dist/sql-driver/sql-driver-adapter.js.map +1 -1
  292. package/dist/sql-driver/sql.js.map +1 -1
  293. package/dist/sync/commands.d.ts +15 -0
  294. package/dist/sync/commands.d.ts.map +1 -0
  295. package/dist/sync/commands.js +27 -0
  296. package/dist/sync/commands.js.map +1 -0
  297. package/dist/sync/index.d.ts +4 -0
  298. package/dist/sync/index.js +4 -0
  299. package/dist/sync/read-tracking.d.ts +25 -0
  300. package/dist/sync/read-tracking.d.ts.map +1 -0
  301. package/dist/sync/read-tracking.js +148 -0
  302. package/dist/sync/read-tracking.js.map +1 -0
  303. package/dist/sync/submit.js +213 -0
  304. package/dist/sync/submit.js.map +1 -0
  305. package/dist/sync/types.d.ts +63 -0
  306. package/dist/sync/types.d.ts.map +1 -0
  307. package/dist/util/default-database-adapter.js +6 -1
  308. package/dist/util/default-database-adapter.js.map +1 -1
  309. package/dist/with-database.d.ts +3 -6
  310. package/dist/with-database.d.ts.map +1 -1
  311. package/dist/with-database.js +7 -15
  312. package/dist/with-database.js.map +1 -1
  313. package/package.json +33 -41
  314. package/src/adapters/adapters.ts +5 -4
  315. package/src/adapters/drizzle/migrate-drizzle.test.ts +46 -9
  316. package/src/adapters/drizzle/migration-parity-drizzle-kit.test.ts +5 -3
  317. package/src/adapters/drizzle/test-utils.ts +2 -1
  318. package/src/adapters/generic-sql/generic-sql-adapter.test.ts +5 -3
  319. package/src/adapters/generic-sql/generic-sql-adapter.ts +21 -24
  320. package/src/adapters/generic-sql/generic-sql-uow-executor.test.ts +1 -0
  321. package/src/adapters/generic-sql/generic-sql-uow-executor.ts +81 -15
  322. package/src/adapters/generic-sql/migration/adapter-migration-parity.test.ts +4 -2
  323. package/src/adapters/generic-sql/migration/cold-kysely.ts +1 -0
  324. package/src/adapters/generic-sql/migration/dialect/mysql.test.ts +3 -2
  325. package/src/adapters/generic-sql/migration/dialect/mysql.ts +1 -0
  326. package/src/adapters/generic-sql/migration/dialect/postgres.test.ts +5 -4
  327. package/src/adapters/generic-sql/migration/dialect/postgres.ts +2 -1
  328. package/src/adapters/generic-sql/migration/dialect/sqlite.test.ts +795 -3
  329. package/src/adapters/generic-sql/migration/dialect/sqlite.ts +385 -57
  330. package/src/adapters/generic-sql/migration/executor.test.ts +52 -0
  331. package/src/adapters/generic-sql/migration/executor.ts +47 -4
  332. package/src/adapters/generic-sql/migration/prepared-migrations.test.ts +117 -14
  333. package/src/adapters/generic-sql/migration/prepared-migrations.ts +9 -8
  334. package/src/adapters/generic-sql/migration/sql-generator.ts +5 -3
  335. package/src/adapters/generic-sql/query/create-sql-query-compiler.ts +3 -3
  336. package/src/adapters/generic-sql/query/cursor-utils.test.ts +3 -2
  337. package/src/adapters/generic-sql/query/cursor-utils.ts +1 -1
  338. package/src/adapters/generic-sql/query/db-now-sql.ts +49 -0
  339. package/src/adapters/generic-sql/query/generic-sql-uow-operation-compiler.test.ts +144 -8
  340. package/src/adapters/generic-sql/query/generic-sql-uow-operation-compiler.ts +16 -17
  341. package/src/adapters/generic-sql/query/select-builder.test.ts +1 -0
  342. package/src/adapters/generic-sql/query/select-builder.ts +2 -2
  343. package/src/adapters/generic-sql/query/sql-query-compiler.test.ts +24 -5
  344. package/src/adapters/generic-sql/query/sql-query-compiler.ts +83 -13
  345. package/src/adapters/generic-sql/query/where-builder.test.ts +7 -5
  346. package/src/adapters/generic-sql/query/where-builder.ts +48 -29
  347. package/src/adapters/generic-sql/sql-adapter-pglite-migrations.test.ts +6 -15
  348. package/src/adapters/generic-sql/sql-adapter-pglite-pagination.test.ts +52 -7
  349. package/src/adapters/generic-sql/sql-adapter-pglite-queries.test.ts +9 -6
  350. package/src/adapters/generic-sql/sql-adapter-sqlite3-driver.test.ts +273 -5
  351. package/src/adapters/generic-sql/sql-adapter-sqlite3-uow.test.ts +123 -6
  352. package/src/adapters/generic-sql/sql-adapter-sqlocal.test.ts +4 -2
  353. package/src/adapters/generic-sql/uow-decoder.test.ts +4 -3
  354. package/src/adapters/generic-sql/uow-decoder.ts +3 -3
  355. package/src/adapters/generic-sql/uow-encoder.test.ts +4 -2
  356. package/src/adapters/generic-sql/uow-encoder.ts +14 -18
  357. package/src/adapters/in-memory/condition-evaluator.test.ts +2 -1
  358. package/src/adapters/in-memory/condition-evaluator.ts +9 -4
  359. package/src/adapters/in-memory/in-memory-adapter.ts +155 -44
  360. package/src/adapters/in-memory/in-memory-uow.mutations.test.ts +50 -2
  361. package/src/adapters/in-memory/in-memory-uow.retrieval.test.ts +158 -3
  362. package/src/adapters/in-memory/in-memory-uow.ts +402 -26
  363. package/src/adapters/in-memory/options.test.ts +1 -0
  364. package/src/adapters/in-memory/options.ts +5 -1
  365. package/src/adapters/in-memory/outbox.test.ts +361 -0
  366. package/src/adapters/in-memory/reference-resolution.test.ts +3 -2
  367. package/src/adapters/in-memory/reference-resolution.ts +2 -2
  368. package/src/adapters/in-memory/sorted-array-index.test.ts +1 -0
  369. package/src/adapters/in-memory/store.test.ts +1 -0
  370. package/src/adapters/in-memory/store.ts +3 -3
  371. package/src/adapters/in-memory/value-normalization.test.ts +1 -0
  372. package/src/adapters/prisma/prisma-adapter-sqlite3.test.ts +51 -7
  373. package/src/adapters/shared/from-unit-of-work-compiler.ts +156 -46
  374. package/src/adapters/shared/uow-operation-compiler.ts +3 -3
  375. package/src/browser/mod.ts +64 -0
  376. package/src/client.ts +19 -0
  377. package/src/db-fragment-definition-builder.test.ts +821 -47
  378. package/src/db-fragment-definition-builder.ts +857 -110
  379. package/src/db-fragment-instantiator.test.ts +114 -90
  380. package/src/db-fragment-integration.test.ts +9 -6
  381. package/src/dispatchers/cloudflare-do/dispatcher.ts +204 -0
  382. package/src/dispatchers/cloudflare-do/index.test.ts +145 -12
  383. package/src/dispatchers/cloudflare-do/index.ts +49 -90
  384. package/src/dispatchers/node/dispatcher.ts +112 -0
  385. package/src/dispatchers/node/index.test.ts +43 -14
  386. package/src/dispatchers/node/index.ts +38 -75
  387. package/src/durable-hooks.test.ts +80 -0
  388. package/src/durable-hooks.ts +67 -0
  389. package/src/fragments/internal-fragment.routes.test.ts +570 -0
  390. package/src/fragments/internal-fragment.routes.ts +297 -5
  391. package/src/fragments/internal-fragment.schema.ts +45 -1
  392. package/src/fragments/internal-fragment.test.ts +223 -251
  393. package/src/fragments/internal-fragment.ts +278 -154
  394. package/src/hooks/durable-hooks-logger.ts +126 -0
  395. package/src/hooks/durable-hooks-processor.pglite.test.ts +87 -0
  396. package/src/hooks/durable-hooks-processor.test.ts +179 -14
  397. package/src/hooks/durable-hooks-processor.ts +120 -14
  398. package/src/hooks/durable-hooks-runtime.test.ts +65 -0
  399. package/src/hooks/durable-hooks-runtime.ts +81 -0
  400. package/src/hooks/hooks.test.ts +314 -53
  401. package/src/hooks/hooks.ts +360 -81
  402. package/src/id.test.ts +34 -0
  403. package/src/id.ts +1 -3
  404. package/src/internal/adapter-registry.test.ts +93 -0
  405. package/src/internal/adapter-registry.ts +239 -0
  406. package/src/internal/outbox-state.ts +43 -0
  407. package/src/migration-engine/auto-from-schema.test.ts +93 -0
  408. package/src/migration-engine/auto-from-schema.ts +360 -42
  409. package/src/migration-engine/create.test.ts +2 -1
  410. package/src/migration-engine/create.ts +1 -1
  411. package/src/migration-engine/generation-engine.test.ts +66 -9
  412. package/src/migration-engine/generation-engine.ts +31 -10
  413. package/src/migration-engine/shared.ts +13 -0
  414. package/src/mod.ts +45 -27
  415. package/src/naming/sql-naming.ts +1 -0
  416. package/src/outbox/outbox-builder.ts +2 -2
  417. package/src/outbox/outbox.test.ts +216 -45
  418. package/src/outbox/outbox.ts +3 -1
  419. package/src/query/column-defaults.ts +1 -1
  420. package/src/query/condition-builder.test.ts +15 -0
  421. package/src/query/condition-builder.ts +7 -0
  422. package/src/query/cursor-client.test.ts +70 -0
  423. package/src/query/cursor-client.ts +263 -0
  424. package/src/query/cursor.test.ts +3 -2
  425. package/src/query/cursor.ts +15 -3
  426. package/src/query/db-now.ts +69 -2
  427. package/src/query/orm/orm.ts +2 -2
  428. package/src/query/query-type.test.ts +2 -1
  429. package/src/query/serialize/create-sql-serializer.ts +3 -3
  430. package/src/query/serialize/dialect/mysql-serializer.ts +1 -1
  431. package/src/query/serialize/dialect/postgres-serializer.ts +1 -1
  432. package/src/query/serialize/dialect/sqlite-serializer.test.ts +39 -2
  433. package/src/query/serialize/dialect/sqlite-serializer.ts +18 -5
  434. package/src/query/simple-query-interface.ts +10 -4
  435. package/src/query/unit-of-work/execute-unit-of-work.test.ts +347 -9
  436. package/src/query/unit-of-work/execute-unit-of-work.ts +63 -20
  437. package/src/query/unit-of-work/retry-policy.test.ts +1 -0
  438. package/src/query/unit-of-work/tx-builder.test.ts +73 -1
  439. package/src/query/unit-of-work/unit-of-work-coordinator.test.ts +5 -4
  440. package/src/query/unit-of-work/unit-of-work-types.test.ts +41 -11
  441. package/src/query/unit-of-work/unit-of-work.test.ts +28 -2
  442. package/src/query/unit-of-work/unit-of-work.ts +105 -19
  443. package/src/query/value-decoding.test.ts +50 -2
  444. package/src/query/value-decoding.ts +17 -4
  445. package/src/query/value-encoding.test.ts +1 -0
  446. package/src/query/value-encoding.ts +1 -1
  447. package/src/schema/create.test.ts +164 -5
  448. package/src/schema/create.ts +222 -24
  449. package/src/schema/generate-id.test.ts +1 -0
  450. package/src/schema/serialize.test.ts +4 -3
  451. package/src/schema/type-conversion/create-sql-type-mapper.ts +1 -1
  452. package/src/schema/type-conversion/dialect/sqlite.ts +2 -2
  453. package/src/schema/type-conversion/type-mapping.test.ts +2 -1
  454. package/src/schema/validator.test.ts +4 -2
  455. package/src/schema/validator.ts +1 -0
  456. package/src/schema-output/drizzle.test.ts +72 -19
  457. package/src/schema-output/drizzle.ts +24 -18
  458. package/src/schema-output/prisma.test.ts +172 -14
  459. package/src/schema-output/prisma.ts +34 -14
  460. package/src/sql-driver/better-sqlite3.test.ts +5 -3
  461. package/src/sql-driver/dialects/durable-object-dialect.ts +3 -8
  462. package/src/sql-driver/query-executor/default-query-executor.ts +1 -1
  463. package/src/sql-driver/query-executor/query-executor-base.ts +1 -1
  464. package/src/sql-driver/query-executor/query-executor.ts +1 -1
  465. package/src/sql-driver/sql-driver-adapter.ts +2 -2
  466. package/src/sql-driver/sql.ts +2 -1
  467. package/src/sql-driver/sqlocal.test.ts +4 -2
  468. package/src/sync/commands.test.ts +39 -0
  469. package/src/sync/commands.ts +51 -0
  470. package/src/sync/conflict-checker.test.ts +450 -0
  471. package/src/sync/conflict-checker.ts +248 -0
  472. package/src/sync/index.ts +14 -0
  473. package/src/sync/plan.ts +9 -0
  474. package/src/sync/read-tracking.test.ts +177 -0
  475. package/src/sync/read-tracking.ts +287 -0
  476. package/src/sync/submit.test.ts +205 -0
  477. package/src/sync/submit.ts +328 -0
  478. package/src/sync/types.ts +80 -0
  479. package/src/util/default-database-adapter.ts +15 -2
  480. package/src/with-database.ts +20 -50
  481. package/tsconfig.json +1 -1
  482. package/tsdown.config.ts +38 -26
  483. package/vitest.config.ts +1 -0
  484. package/dist/hooks/durable-hooks-processor.d.ts.map +0 -1
  485. package/dist/node_modules/.pnpm/rou3@0.7.12/node_modules/rou3/dist/index.js +0 -168
  486. package/dist/node_modules/.pnpm/rou3@0.7.12/node_modules/rou3/dist/index.js.map +0 -1
  487. package/dist/packages/fragno/dist/api/bind-services.js +0 -20
  488. package/dist/packages/fragno/dist/api/bind-services.js.map +0 -1
  489. package/dist/packages/fragno/dist/api/error.js +0 -48
  490. package/dist/packages/fragno/dist/api/error.js.map +0 -1
  491. package/dist/packages/fragno/dist/api/fragment-definition-builder.js +0 -321
  492. package/dist/packages/fragno/dist/api/fragment-definition-builder.js.map +0 -1
  493. package/dist/packages/fragno/dist/api/fragment-instantiator.js +0 -669
  494. package/dist/packages/fragno/dist/api/fragment-instantiator.js.map +0 -1
  495. package/dist/packages/fragno/dist/api/fragno-response.js +0 -73
  496. package/dist/packages/fragno/dist/api/fragno-response.js.map +0 -1
  497. package/dist/packages/fragno/dist/api/internal/response-stream.js +0 -81
  498. package/dist/packages/fragno/dist/api/internal/response-stream.js.map +0 -1
  499. package/dist/packages/fragno/dist/api/internal/route.js +0 -10
  500. package/dist/packages/fragno/dist/api/internal/route.js.map +0 -1
  501. package/dist/packages/fragno/dist/api/mutable-request-state.js +0 -97
  502. package/dist/packages/fragno/dist/api/mutable-request-state.js.map +0 -1
  503. package/dist/packages/fragno/dist/api/request-context-storage.js +0 -43
  504. package/dist/packages/fragno/dist/api/request-context-storage.js.map +0 -1
  505. package/dist/packages/fragno/dist/api/request-input-context.js +0 -185
  506. package/dist/packages/fragno/dist/api/request-input-context.js.map +0 -1
  507. package/dist/packages/fragno/dist/api/request-middleware.js +0 -83
  508. package/dist/packages/fragno/dist/api/request-middleware.js.map +0 -1
  509. package/dist/packages/fragno/dist/api/request-output-context.js +0 -119
  510. package/dist/packages/fragno/dist/api/request-output-context.js.map +0 -1
  511. package/dist/packages/fragno/dist/api/route.js +0 -30
  512. package/dist/packages/fragno/dist/api/route.js.map +0 -1
  513. package/dist/packages/fragno/dist/internal/symbols.js +0 -10
  514. package/dist/packages/fragno/dist/internal/symbols.js.map +0 -1
  515. package/dist/packages/fragno/dist/internal/trace-context.js +0 -12
  516. package/dist/packages/fragno/dist/internal/trace-context.js.map +0 -1
@@ -0,0 +1,80 @@
1
+ import { DurableHooksLogger } from "../../hooks/durable-hooks-logger.js";
2
+
3
+ //#region src/dispatchers/node/dispatcher.ts
4
+ function createDurableHooksDispatcher(options) {
5
+ const pollIntervalMs = options.pollIntervalMs ?? 5e3;
6
+ const onError = options.onError ?? ((error) => {
7
+ DurableHooksLogger.error("Durable hooks dispatcher error", {
8
+ namespace: options.processor.namespace,
9
+ fields: { error: DurableHooksLogger.toErrorMessage(error) }
10
+ });
11
+ });
12
+ let timer;
13
+ let processing = false;
14
+ let queued = false;
15
+ let notifyQueued = false;
16
+ let currentPromise;
17
+ const runProcess = () => {
18
+ if (processing) {
19
+ queued = true;
20
+ return currentPromise ?? Promise.resolve();
21
+ }
22
+ processing = true;
23
+ currentPromise = (async () => {
24
+ do {
25
+ queued = false;
26
+ try {
27
+ await options.processor.processDue();
28
+ } catch (error) {
29
+ onError(error);
30
+ }
31
+ } while (queued);
32
+ processing = false;
33
+ })();
34
+ return currentPromise;
35
+ };
36
+ const poll = async () => {
37
+ try {
38
+ const nextWakeAt = await options.processor.getNextWakeAt();
39
+ if (!nextWakeAt) return;
40
+ if (Date.now() >= nextWakeAt.getTime()) await runProcess();
41
+ } catch (error) {
42
+ onError(error);
43
+ }
44
+ };
45
+ return {
46
+ notify: (_context) => {
47
+ if (notifyQueued) return;
48
+ notifyQueued = true;
49
+ setTimeout(() => {
50
+ notifyQueued = false;
51
+ runProcess();
52
+ }, 0);
53
+ },
54
+ wake: async () => {
55
+ await runProcess();
56
+ },
57
+ drain: async () => {
58
+ try {
59
+ await options.processor.drain();
60
+ } catch (error) {
61
+ onError(error);
62
+ }
63
+ },
64
+ startPolling: () => {
65
+ if (timer) return;
66
+ timer = setInterval(() => {
67
+ poll();
68
+ }, pollIntervalMs);
69
+ },
70
+ stopPolling: () => {
71
+ if (!timer) return;
72
+ clearInterval(timer);
73
+ timer = void 0;
74
+ }
75
+ };
76
+ }
77
+
78
+ //#endregion
79
+ export { createDurableHooksDispatcher };
80
+ //# sourceMappingURL=dispatcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dispatcher.js","names":["timer: ReturnType<typeof setInterval> | undefined","currentPromise: Promise<void> | undefined"],"sources":["../../../src/dispatchers/node/dispatcher.ts"],"sourcesContent":["import { DurableHooksLogger } from \"../../hooks/durable-hooks-logger\";\nimport type { DurableHooksProcessor } from \"../../hooks/durable-hooks-processor\";\nimport type { HookNotifyContext } from \"../../hooks/hooks\";\n\nexport type DurableHooksDispatcher = {\n notify: (context: HookNotifyContext) => void;\n wake: () => Promise<void>;\n drain: () => Promise<void>;\n startPolling: () => void;\n stopPolling: () => void;\n};\n\nexport type DurableHooksDispatcherOptions = {\n processor: DurableHooksProcessor;\n pollIntervalMs?: number;\n onError?: (error: unknown) => void;\n};\n\nexport function createDurableHooksDispatcher(\n options: DurableHooksDispatcherOptions,\n): DurableHooksDispatcher {\n const pollIntervalMs = options.pollIntervalMs ?? 5000;\n const onError =\n options.onError ??\n ((error: unknown) => {\n DurableHooksLogger.error(\"Durable hooks dispatcher error\", {\n namespace: options.processor.namespace,\n fields: { error: DurableHooksLogger.toErrorMessage(error) },\n });\n });\n let timer: ReturnType<typeof setInterval> | undefined;\n let processing = false;\n let queued = false;\n let notifyQueued = false;\n let currentPromise: Promise<void> | undefined;\n\n const runProcess = () => {\n if (processing) {\n queued = true;\n return currentPromise ?? Promise.resolve();\n }\n\n processing = true;\n currentPromise = (async () => {\n do {\n queued = false;\n try {\n await options.processor.processDue();\n } catch (error) {\n onError(error);\n }\n } while (queued);\n processing = false;\n })();\n\n return currentPromise;\n };\n\n const poll = async () => {\n try {\n const nextWakeAt = await options.processor.getNextWakeAt();\n if (!nextWakeAt) {\n return;\n }\n if (Date.now() >= nextWakeAt.getTime()) {\n await runProcess();\n }\n } catch (error) {\n onError(error);\n }\n };\n\n return {\n notify: (_context) => {\n if (notifyQueued) {\n return;\n }\n notifyQueued = true;\n setTimeout(() => {\n notifyQueued = false;\n void runProcess();\n }, 0);\n },\n wake: async () => {\n await runProcess();\n },\n drain: async () => {\n try {\n await options.processor.drain();\n } catch (error) {\n onError(error);\n }\n },\n startPolling: () => {\n if (timer) {\n return;\n }\n\n timer = setInterval(() => {\n void poll();\n }, pollIntervalMs);\n },\n stopPolling: () => {\n if (!timer) {\n return;\n }\n\n clearInterval(timer);\n timer = undefined;\n },\n };\n}\n"],"mappings":";;;AAkBA,SAAgB,6BACd,SACwB;CACxB,MAAM,iBAAiB,QAAQ,kBAAkB;CACjD,MAAM,UACJ,QAAQ,aACN,UAAmB;AACnB,qBAAmB,MAAM,kCAAkC;GACzD,WAAW,QAAQ,UAAU;GAC7B,QAAQ,EAAE,OAAO,mBAAmB,eAAe,MAAM,EAAE;GAC5D,CAAC;;CAEN,IAAIA;CACJ,IAAI,aAAa;CACjB,IAAI,SAAS;CACb,IAAI,eAAe;CACnB,IAAIC;CAEJ,MAAM,mBAAmB;AACvB,MAAI,YAAY;AACd,YAAS;AACT,UAAO,kBAAkB,QAAQ,SAAS;;AAG5C,eAAa;AACb,oBAAkB,YAAY;AAC5B,MAAG;AACD,aAAS;AACT,QAAI;AACF,WAAM,QAAQ,UAAU,YAAY;aAC7B,OAAO;AACd,aAAQ,MAAM;;YAET;AACT,gBAAa;MACX;AAEJ,SAAO;;CAGT,MAAM,OAAO,YAAY;AACvB,MAAI;GACF,MAAM,aAAa,MAAM,QAAQ,UAAU,eAAe;AAC1D,OAAI,CAAC,WACH;AAEF,OAAI,KAAK,KAAK,IAAI,WAAW,SAAS,CACpC,OAAM,YAAY;WAEb,OAAO;AACd,WAAQ,MAAM;;;AAIlB,QAAO;EACL,SAAS,aAAa;AACpB,OAAI,aACF;AAEF,kBAAe;AACf,oBAAiB;AACf,mBAAe;AACf,IAAK,YAAY;MAChB,EAAE;;EAEP,MAAM,YAAY;AAChB,SAAM,YAAY;;EAEpB,OAAO,YAAY;AACjB,OAAI;AACF,UAAM,QAAQ,UAAU,OAAO;YACxB,OAAO;AACd,YAAQ,MAAM;;;EAGlB,oBAAoB;AAClB,OAAI,MACF;AAGF,WAAQ,kBAAkB;AACxB,IAAK,MAAM;MACV,eAAe;;EAEpB,mBAAmB;AACjB,OAAI,CAAC,MACH;AAGF,iBAAc,MAAM;AACpB,WAAQ;;EAEX"}
@@ -1,17 +1,12 @@
1
- import { DurableHooksProcessor } from "../../hooks/durable-hooks-processor.js";
1
+ import { AnyFragnoInstantiatedDatabaseFragment } from "../../mod.js";
2
+ import { DurableHooksDispatcher } from "./dispatcher.js";
2
3
 
3
4
  //#region src/dispatchers/node/index.d.ts
4
- type DurableHooksDispatcher = {
5
- wake: () => Promise<void>;
6
- startPolling: () => void;
7
- stopPolling: () => void;
8
- };
9
- type DurableHooksDispatcherOptions = {
10
- processor: DurableHooksProcessor;
5
+ type DurableHooksProcessorOptions = {
11
6
  pollIntervalMs?: number;
12
7
  onError?: (error: unknown) => void;
13
8
  };
14
- declare function createDurableHooksDispatcher(options: DurableHooksDispatcherOptions): DurableHooksDispatcher;
9
+ declare function createDurableHooksProcessor(fragments: readonly AnyFragnoInstantiatedDatabaseFragment[], options?: DurableHooksProcessorOptions): DurableHooksDispatcher;
15
10
  //#endregion
16
- export { DurableHooksDispatcher, DurableHooksDispatcherOptions, createDurableHooksDispatcher };
11
+ export { type DurableHooksDispatcher, DurableHooksProcessorOptions, createDurableHooksProcessor };
17
12
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","names":[],"sources":["../../../src/dispatchers/node/index.ts"],"sourcesContent":[],"mappings":";;;KAEY,sBAAA;cACE;EADF,YAAA,EAAA,GAAA,GAAA,IAAA;EAMA,WAAA,EAAA,GAAA,GAAA,IAAA;AAMZ,CAAA;KANY,6BAAA;aACC;;;;iBAKG,4BAAA,UACL,gCACR"}
1
+ {"version":3,"file":"index.d.ts","names":[],"sources":["../../../src/dispatchers/node/index.ts"],"sourcesContent":[],"mappings":";;;;KAKY,4BAAA;;EAAA,OAAA,CAAA,EAAA,CAAA,KAAA,EAAA,OAAA,EAAA,GAAA,IAA4B;AAWxC,CAAA;AAEW,iBAFK,2BAAA,CAEL,SAAA,EAAA,SADW,qCACX,EAAA,EAAA,OAAA,CAAA,EAAA,4BAAA,CAAA,EACR,sBADQ"}
@@ -1,59 +1,27 @@
1
+ import { getDurableHooksRuntimeByToken } from "../../hooks/durable-hooks-runtime.js";
2
+ import { createDurableHooksProcessorGroup } from "../../hooks/durable-hooks-processor.js";
3
+ import { createDurableHooksDispatcher } from "./dispatcher.js";
4
+
1
5
  //#region src/dispatchers/node/index.ts
2
- function createDurableHooksDispatcher(options) {
3
- const pollIntervalMs = options.pollIntervalMs ?? 5e3;
4
- const onError = options.onError ?? ((error) => {
5
- console.error("Durable hooks dispatcher error", error);
6
+ function createDurableHooksProcessor(fragments, options = {}) {
7
+ const dispatcher = createDurableHooksDispatcher({
8
+ processor: createDurableHooksProcessorGroup(fragments, { onError: options.onError }),
9
+ pollIntervalMs: options.pollIntervalMs,
10
+ onError: options.onError
6
11
  });
7
- let timer;
8
- let processing = false;
9
- let queued = false;
10
- let currentPromise;
11
- const runProcess = () => {
12
- if (processing) {
13
- queued = true;
14
- return currentPromise ?? Promise.resolve();
15
- }
16
- processing = true;
17
- currentPromise = (async () => {
18
- do {
19
- queued = false;
20
- try {
21
- await options.processor.process();
22
- } catch (error) {
23
- onError(error);
24
- }
25
- } while (queued);
26
- processing = false;
27
- })();
28
- return currentPromise;
29
- };
30
- const poll = async () => {
31
- try {
32
- const nextWakeAt = await options.processor.getNextWakeAt();
33
- if (!nextWakeAt) return;
34
- if (Date.now() >= nextWakeAt.getTime()) await runProcess();
35
- } catch (error) {
36
- onError(error);
37
- }
38
- };
39
- return {
40
- wake: async () => {
41
- await runProcess();
42
- },
43
- startPolling: () => {
44
- if (timer) return;
45
- timer = setInterval(() => {
46
- poll();
47
- }, pollIntervalMs);
48
- },
49
- stopPolling: () => {
50
- if (!timer) return;
51
- clearInterval(timer);
52
- timer = void 0;
53
- }
54
- };
12
+ const notifier = { notify: (context) => {
13
+ dispatcher.notify(context);
14
+ } };
15
+ for (const fragment of fragments) {
16
+ const durableHooksToken = fragment.$internal?.durableHooksToken;
17
+ if (!durableHooksToken) continue;
18
+ const runtime = getDurableHooksRuntimeByToken(durableHooksToken);
19
+ if (!runtime) continue;
20
+ runtime.config.notifier = notifier;
21
+ }
22
+ return dispatcher;
55
23
  }
56
24
 
57
25
  //#endregion
58
- export { createDurableHooksDispatcher };
26
+ export { createDurableHooksProcessor };
59
27
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["timer: ReturnType<typeof setInterval> | undefined","currentPromise: Promise<void> | undefined"],"sources":["../../../src/dispatchers/node/index.ts"],"sourcesContent":["import type { DurableHooksProcessor } from \"../../hooks/durable-hooks-processor\";\n\nexport type DurableHooksDispatcher = {\n wake: () => Promise<void>;\n startPolling: () => void;\n stopPolling: () => void;\n};\n\nexport type DurableHooksDispatcherOptions = {\n processor: DurableHooksProcessor;\n pollIntervalMs?: number;\n onError?: (error: unknown) => void;\n};\n\nexport function createDurableHooksDispatcher(\n options: DurableHooksDispatcherOptions,\n): DurableHooksDispatcher {\n const pollIntervalMs = options.pollIntervalMs ?? 5000;\n const onError =\n options.onError ??\n ((error: unknown) => {\n console.error(\"Durable hooks dispatcher error\", error);\n });\n let timer: ReturnType<typeof setInterval> | undefined;\n let processing = false;\n let queued = false;\n let currentPromise: Promise<void> | undefined;\n\n const runProcess = () => {\n if (processing) {\n queued = true;\n return currentPromise ?? Promise.resolve();\n }\n\n processing = true;\n currentPromise = (async () => {\n do {\n queued = false;\n try {\n await options.processor.process();\n } catch (error) {\n onError(error);\n }\n } while (queued);\n processing = false;\n })();\n\n return currentPromise;\n };\n\n const poll = async () => {\n try {\n const nextWakeAt = await options.processor.getNextWakeAt();\n if (!nextWakeAt) {\n return;\n }\n if (Date.now() >= nextWakeAt.getTime()) {\n await runProcess();\n }\n } catch (error) {\n onError(error);\n }\n };\n\n return {\n wake: async () => {\n await runProcess();\n },\n startPolling: () => {\n if (timer) {\n return;\n }\n\n timer = setInterval(() => {\n void poll();\n }, pollIntervalMs);\n },\n stopPolling: () => {\n if (!timer) {\n return;\n }\n\n clearInterval(timer);\n timer = undefined;\n },\n };\n}\n"],"mappings":";AAcA,SAAgB,6BACd,SACwB;CACxB,MAAM,iBAAiB,QAAQ,kBAAkB;CACjD,MAAM,UACJ,QAAQ,aACN,UAAmB;AACnB,UAAQ,MAAM,kCAAkC,MAAM;;CAE1D,IAAIA;CACJ,IAAI,aAAa;CACjB,IAAI,SAAS;CACb,IAAIC;CAEJ,MAAM,mBAAmB;AACvB,MAAI,YAAY;AACd,YAAS;AACT,UAAO,kBAAkB,QAAQ,SAAS;;AAG5C,eAAa;AACb,oBAAkB,YAAY;AAC5B,MAAG;AACD,aAAS;AACT,QAAI;AACF,WAAM,QAAQ,UAAU,SAAS;aAC1B,OAAO;AACd,aAAQ,MAAM;;YAET;AACT,gBAAa;MACX;AAEJ,SAAO;;CAGT,MAAM,OAAO,YAAY;AACvB,MAAI;GACF,MAAM,aAAa,MAAM,QAAQ,UAAU,eAAe;AAC1D,OAAI,CAAC,WACH;AAEF,OAAI,KAAK,KAAK,IAAI,WAAW,SAAS,CACpC,OAAM,YAAY;WAEb,OAAO;AACd,WAAQ,MAAM;;;AAIlB,QAAO;EACL,MAAM,YAAY;AAChB,SAAM,YAAY;;EAEpB,oBAAoB;AAClB,OAAI,MACF;AAGF,WAAQ,kBAAkB;AACxB,IAAK,MAAM;MACV,eAAe;;EAEpB,mBAAmB;AACjB,OAAI,CAAC,MACH;AAGF,iBAAc,MAAM;AACpB,WAAQ;;EAEX"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../../../src/dispatchers/node/index.ts"],"sourcesContent":["import { createDurableHooksProcessorGroup } from \"../../hooks/durable-hooks-processor\";\nimport { getDurableHooksRuntimeByToken } from \"../../hooks/durable-hooks-runtime\";\nimport type { AnyFragnoInstantiatedDatabaseFragment } from \"../../mod\";\nimport { createDurableHooksDispatcher, type DurableHooksDispatcher } from \"./dispatcher\";\n\nexport type DurableHooksProcessorOptions = {\n pollIntervalMs?: number;\n onError?: (error: unknown) => void;\n};\n\nexport type { DurableHooksDispatcher };\n\ntype DurableHooksInternal = {\n durableHooksToken?: object;\n};\n\nexport function createDurableHooksProcessor(\n fragments: readonly AnyFragnoInstantiatedDatabaseFragment[],\n options: DurableHooksProcessorOptions = {},\n): DurableHooksDispatcher {\n const processor = createDurableHooksProcessorGroup(fragments, {\n onError: options.onError,\n });\n const dispatcher = createDurableHooksDispatcher({\n processor,\n pollIntervalMs: options.pollIntervalMs,\n onError: options.onError,\n });\n\n const notifier = {\n notify: (context: Parameters<typeof dispatcher.notify>[0]) => {\n dispatcher.notify(context);\n },\n };\n\n for (const fragment of fragments) {\n const internal = fragment.$internal as DurableHooksInternal | undefined;\n const durableHooksToken = internal?.durableHooksToken;\n if (!durableHooksToken) {\n continue;\n }\n const runtime = getDurableHooksRuntimeByToken(durableHooksToken);\n if (!runtime) {\n continue;\n }\n runtime.config.notifier = notifier;\n }\n\n return dispatcher;\n}\n"],"mappings":";;;;;AAgBA,SAAgB,4BACd,WACA,UAAwC,EAAE,EAClB;CAIxB,MAAM,aAAa,6BAA6B;EAC9C,WAJgB,iCAAiC,WAAW,EAC5D,SAAS,QAAQ,SAClB,CAAC;EAGA,gBAAgB,QAAQ;EACxB,SAAS,QAAQ;EAClB,CAAC;CAEF,MAAM,WAAW,EACf,SAAS,YAAqD;AAC5D,aAAW,OAAO,QAAQ;IAE7B;AAED,MAAK,MAAM,YAAY,WAAW;EAEhC,MAAM,oBADW,SAAS,WACU;AACpC,MAAI,CAAC,kBACH;EAEF,MAAM,UAAU,8BAA8B,kBAAkB;AAChE,MAAI,CAAC,QACH;AAEF,UAAQ,OAAO,WAAW;;AAG5B,QAAO"}
@@ -0,0 +1,31 @@
1
+ import { FragnoId } from "./schema/create.js";
2
+ import { AnyFragnoInstantiatedDatabaseFragment } from "./mod.js";
3
+ import { InternalFragmentInstance } from "./fragments/internal-fragment.js";
4
+ import { HookStatus } from "./hooks/hooks.js";
5
+
6
+ //#region src/durable-hooks.d.ts
7
+ type DurableHookStatus = HookStatus;
8
+ type DurableHookRecord = {
9
+ id: FragnoId;
10
+ namespace: string;
11
+ hookName: string;
12
+ payload: unknown;
13
+ status: DurableHookStatus;
14
+ attempts: number;
15
+ maxAttempts: number;
16
+ lastAttemptAt: Date | null;
17
+ nextRetryAt: Date | null;
18
+ createdAt: Date;
19
+ error: string | null;
20
+ nonce: string;
21
+ };
22
+ type DurableHooksService = InternalFragmentInstance["services"]["hookService"];
23
+ type DurableHooksAccessor = {
24
+ namespace: string;
25
+ hooksEnabled: boolean;
26
+ hookService: DurableHooksService;
27
+ };
28
+ declare function getDurableHooksService(fragment: AnyFragnoInstantiatedDatabaseFragment): DurableHooksAccessor;
29
+ //#endregion
30
+ export { type AnyFragnoInstantiatedDatabaseFragment, DurableHookRecord, DurableHookStatus, DurableHooksAccessor, DurableHooksService, getDurableHooksService };
31
+ //# sourceMappingURL=durable-hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"durable-hooks.d.ts","names":[],"sources":["../src/durable-hooks.ts"],"sourcesContent":[],"mappings":";;;;;;KAUY,iBAAA,GAAoB;AAApB,KAEA,iBAAA,GAFiB;EAEjB,EAAA,EACN,QADM;EACN,SAAA,EAAA,MAAA;EAII,QAAA,EAAA,MAAA;EAGO,OAAA,EAAA,OAAA;EACF,MAAA,EAJL,iBAIK;EACF,QAAA,EAAA,MAAA;EAAI,WAAA,EAAA,MAAA;EAKL,aAAA,EAPK,IAOL,GAAmB,IAAA;EAEnB,WAAA,EARG,IAQH,GAAA,IAAoB;EAMhB,SAAA,EAbH,IAaG;;;;KARJ,mBAAA,GAAsB;KAEtB,oBAAA;;;eAGG;;iBAGC,sBAAA,WACJ,wCACT"}
@@ -0,0 +1,23 @@
1
+ import { getDurableHooksRuntimeByToken } from "./hooks/durable-hooks-runtime.js";
2
+ import { getInternalFragment } from "./internal/adapter-registry.js";
3
+
4
+ //#region src/durable-hooks.ts
5
+ function getDurableHooksService(fragment) {
6
+ const durableHooksToken = fragment.$internal?.durableHooksToken;
7
+ const runtime = durableHooksToken ? getDurableHooksRuntimeByToken(durableHooksToken) : void 0;
8
+ const deps = fragment.$internal?.deps;
9
+ if (!deps?.databaseAdapter) throw new Error("Database adapter is missing for durable hooks.");
10
+ const namespace = runtime?.config.namespace ?? deps.namespace ?? deps.schema?.name ?? "";
11
+ if (!namespace) throw new Error("Durable hooks namespace is missing.");
12
+ const hookAdapter = deps.databaseAdapter.getHookProcessingAdapter?.() ?? deps.databaseAdapter;
13
+ const internalFragment = runtime?.config.internalFragment ?? getInternalFragment(hookAdapter);
14
+ return {
15
+ namespace,
16
+ hooksEnabled: Boolean(durableHooksToken),
17
+ hookService: internalFragment.services.hookService
18
+ };
19
+ }
20
+
21
+ //#endregion
22
+ export { getDurableHooksService };
23
+ //# sourceMappingURL=durable-hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"durable-hooks.js","names":[],"sources":["../src/durable-hooks.ts"],"sourcesContent":["import type { DatabaseAdapter } from \"./adapters/adapters\";\nimport type { InternalFragmentInstance } from \"./fragments/internal-fragment\";\nimport { getDurableHooksRuntimeByToken } from \"./hooks/durable-hooks-runtime\";\nimport type { HookStatus } from \"./hooks/hooks\";\nimport { getInternalFragment } from \"./internal/adapter-registry\";\nimport type { AnyFragnoInstantiatedDatabaseFragment } from \"./mod\";\nimport type { FragnoId } from \"./schema/create\";\n\nexport type { AnyFragnoInstantiatedDatabaseFragment };\n\nexport type DurableHookStatus = HookStatus;\n\nexport type DurableHookRecord = {\n id: FragnoId;\n namespace: string;\n hookName: string;\n payload: unknown;\n status: DurableHookStatus;\n attempts: number;\n maxAttempts: number;\n lastAttemptAt: Date | null;\n nextRetryAt: Date | null;\n createdAt: Date;\n error: string | null;\n nonce: string;\n};\n\nexport type DurableHooksService = InternalFragmentInstance[\"services\"][\"hookService\"];\n\nexport type DurableHooksAccessor = {\n namespace: string;\n hooksEnabled: boolean;\n hookService: DurableHooksService;\n};\n\nexport function getDurableHooksService(\n fragment: AnyFragnoInstantiatedDatabaseFragment,\n): DurableHooksAccessor {\n const internal = fragment.$internal as { durableHooksToken?: object } | undefined;\n const durableHooksToken = internal?.durableHooksToken;\n const runtime = durableHooksToken ? getDurableHooksRuntimeByToken(durableHooksToken) : undefined;\n const deps = fragment.$internal?.deps as\n | {\n databaseAdapter?: DatabaseAdapter<unknown>;\n namespace?: string | null;\n schema?: { name?: string };\n }\n | undefined;\n\n if (!deps?.databaseAdapter) {\n throw new Error(\"Database adapter is missing for durable hooks.\");\n }\n\n const namespace = runtime?.config.namespace ?? deps.namespace ?? deps.schema?.name ?? \"\";\n if (!namespace) {\n throw new Error(\"Durable hooks namespace is missing.\");\n }\n\n const hookAdapter = deps.databaseAdapter.getHookProcessingAdapter?.() ?? deps.databaseAdapter;\n const internalFragment = runtime?.config.internalFragment ?? getInternalFragment(hookAdapter);\n\n return {\n namespace,\n hooksEnabled: Boolean(durableHooksToken),\n hookService: internalFragment.services.hookService,\n };\n}\n"],"mappings":";;;;AAmCA,SAAgB,uBACd,UACsB;CAEtB,MAAM,oBADW,SAAS,WACU;CACpC,MAAM,UAAU,oBAAoB,8BAA8B,kBAAkB,GAAG;CACvF,MAAM,OAAO,SAAS,WAAW;AAQjC,KAAI,CAAC,MAAM,gBACT,OAAM,IAAI,MAAM,iDAAiD;CAGnE,MAAM,YAAY,SAAS,OAAO,aAAa,KAAK,aAAa,KAAK,QAAQ,QAAQ;AACtF,KAAI,CAAC,UACH,OAAM,IAAI,MAAM,sCAAsC;CAGxD,MAAM,cAAc,KAAK,gBAAgB,4BAA4B,IAAI,KAAK;CAC9E,MAAM,mBAAmB,SAAS,OAAO,oBAAoB,oBAAoB,YAAY;AAE7F,QAAO;EACL;EACA,cAAc,QAAQ,kBAAkB;EACxC,aAAa,iBAAiB,SAAS;EACxC"}
@@ -1,5 +1,6 @@
1
1
  import { DbNow } from "../query/db-now.js";
2
2
  import { AnyColumn, AnyRelation, Column, FragnoId, IdColumn, Index, Schema, Table } from "../schema/create.js";
3
+ import { Cursor } from "../query/cursor.js";
3
4
  import { RetryPolicy } from "../query/unit-of-work/retry-policy.js";
4
5
  import { TxResult } from "../query/unit-of-work/execute-unit-of-work.js";
5
6
  import { DatabaseHandlerContext, DatabaseRequestStorage, DatabaseServiceContext, FragnoPublicConfigWithDatabase, ImplicitDatabaseDependencies } from "../db-fragment-definition-builder.js";
@@ -9,9 +10,33 @@ import * as _fragno_dev_core0 from "@fragno-dev/core";
9
10
  import { InstantiatedFragmentFromDefinition } from "@fragno-dev/core";
10
11
 
11
12
  //#region src/fragments/internal-fragment.d.ts
12
- declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, FragnoPublicConfigWithDatabase, ImplicitDatabaseDependencies<Schema<Record<"fragno_db_settings", Table<Record<string, AnyColumn> & Record<"id", IdColumn<"varchar(30)", string | FragnoId | null, FragnoId>> & Record<"key", Column<"string", string, string>> & Record<"value", Column<"string", string, string>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"unique_key", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["key"]>>>> & Record<"fragno_hooks", Table<Record<string, AnyColumn> & Record<"id", IdColumn<"varchar(30)", string | FragnoId | null, FragnoId>> & Record<"namespace", Column<"string", string, string>> & Record<"hookName", Column<"string", string, string>> & Record<"payload", Column<"json", unknown, unknown>> & Record<"status", Column<"string", string, string>> & Record<"attempts", Column<"integer", number | null, number>> & Record<"maxAttempts", Column<"integer", number | null, number>> & Record<"lastAttemptAt", Column<"timestamp", (DbNow | Date) | null, Date | null>> & Record<"nextRetryAt", Column<"timestamp", (DbNow | Date) | null, Date | null>> & Record<"error", Column<"string", string | null, string | null>> & Record<"createdAt", Column<"timestamp", (DbNow | Date) | null, Date>> & Record<"nonce", Column<"string", string, string>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_namespace_status_retry", Index<readonly [Column<"string", string, string>, Column<"string", string, string>, Column<"timestamp", (DbNow | Date) | null, Date | null>] & AnyColumn[], readonly ["namespace", "status", "nextRetryAt"]>> & Record<"idx_nonce", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["nonce"]>>>> & Record<"fragno_db_outbox", Table<Record<string, AnyColumn> & Record<"id", IdColumn<"varchar(30)", string | FragnoId | null, FragnoId>> & Record<"versionstamp", Column<"string", string, string>> & Record<"uowId", Column<"string", string, string>> & Record<"payload", Column<"json", unknown, unknown>> & Record<"refMap", Column<"json", unknown, unknown>> & Record<"createdAt", Column<"timestamp", (DbNow | Date) | null, Date>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_outbox_versionstamp", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["versionstamp"]>> & Record<"idx_outbox_uow", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["uowId"]>>>>>>, {
13
- getDbNow: () => Promise<Date>;
14
- }, {
13
+ type AdapterRegistry = {
14
+ listSchemas: () => Array<{
15
+ name: string;
16
+ namespace: string | null;
17
+ version: number;
18
+ tables: string[];
19
+ }>;
20
+ listOutboxFragments: () => Array<{
21
+ name: string;
22
+ mountRoute: string;
23
+ }>;
24
+ isOutboxEnabled: () => boolean;
25
+ resolveSyncCommand: (fragmentName: string, schemaName: string, commandName: string) => {
26
+ command: unknown;
27
+ namespace: string | null;
28
+ } | undefined;
29
+ };
30
+ type InternalFragmentConfig = {
31
+ registry?: AdapterRegistry;
32
+ };
33
+ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<InternalFragmentConfig, FragnoPublicConfigWithDatabase, ImplicitDatabaseDependencies<Schema<{
34
+ fragno_db_settings: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"key", Column<"string", string, string>> & Record<"value", Column<"string", string, string>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"unique_key", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["key"]>>>;
35
+ fragno_hooks: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"namespace", Column<"string", string, string>> & Record<"hookName", Column<"string", string, string>> & Record<"payload", Column<"json", unknown, unknown>> & Record<"status", Column<"string", string, string>> & Record<"attempts", Column<"integer", number | null, number>> & Record<"maxAttempts", Column<"integer", number | null, number>> & Record<"lastAttemptAt", Column<"timestamp", (Date | DbNow) | null, Date | null>> & Record<"nextRetryAt", Column<"timestamp", (Date | DbNow) | null, Date | null>> & Record<"error", Column<"string", string | null, string | null>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>> & Record<"nonce", Column<"string", string, string>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_namespace_created_at", Index<readonly [Column<"string", string, string>, Column<"timestamp", (Date | DbNow) | null, Date>, IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>] & AnyColumn[], readonly ["namespace", "createdAt", "id"]>>>;
36
+ fragno_db_outbox: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"versionstamp", Column<"string", string, string>> & Record<"uowId", Column<"string", string, string>> & Record<"payload", Column<"json", unknown, unknown>> & Record<"refMap", Column<"json", unknown, unknown>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_outbox_versionstamp", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["versionstamp"]>> & Record<"idx_outbox_uow", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["uowId"]>>>;
37
+ fragno_db_outbox_mutations: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"entryVersionstamp", Column<"string", string, string>> & Record<"mutationVersionstamp", Column<"string", string, string>> & Record<"uowId", Column<"string", string, string>> & Record<"schema", Column<"string", string, string>> & Record<"table", Column<"string", string, string>> & Record<"externalId", Column<"string", string, string>> & Record<"op", Column<"string", string, string>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_outbox_mutations_entry", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["entryVersionstamp"]>> & Record<"idx_outbox_mutations_key", Index<readonly [Column<"string", string, string>, Column<"string", string, string>, Column<"string", string, string>, Column<"string", string, string>] & AnyColumn[], readonly ["schema", "table", "externalId", "entryVersionstamp"]>> & Record<"idx_outbox_mutations_uow", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["uowId"]>>>;
38
+ fragno_db_sync_requests: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"requestId", Column<"string", string, string>> & Record<"status", Column<"string", string, string>> & Record<"confirmedCommandIds", Column<"json", unknown, unknown>> & Record<"conflictCommandId", Column<"string", string | null, string | null>> & Record<"baseVersionstamp", Column<"string", string | null, string | null>> & Record<"lastVersionstamp", Column<"string", string | null, string | null>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_sync_request_id", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["requestId"]>>>;
39
+ }>>, {}, {
15
40
  settingsService: {
16
41
  /**
17
42
  * Get a setting by namespace and key.
@@ -33,6 +58,14 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
33
58
  key: string;
34
59
  value: string;
35
60
  } | null>;
61
+ /**
62
+ * Set a setting value only if it does not already exist.
63
+ */
64
+ setIfMissing(namespace: string, key: string, value: string): TxResult<void, {
65
+ id: FragnoId;
66
+ key: string;
67
+ value: string;
68
+ } | null>;
36
69
  /**
37
70
  * Delete a setting by ID.
38
71
  */
@@ -48,15 +81,23 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
48
81
  id: FragnoId;
49
82
  hookName: string;
50
83
  payload: unknown;
84
+ status: "pending" | "processing" | "completed" | "failed";
51
85
  attempts: number;
52
86
  maxAttempts: number;
87
+ lastAttemptAt: Date | null;
88
+ nextRetryAt: Date | null;
89
+ createdAt: Date;
53
90
  idempotencyKey: string;
54
91
  }[], {
55
92
  id: FragnoId;
56
93
  hookName: string;
57
94
  payload: unknown;
95
+ status: "pending" | "processing" | "completed" | "failed";
58
96
  attempts: number;
59
97
  maxAttempts: number;
98
+ lastAttemptAt: Date | null;
99
+ nextRetryAt: Date | null;
100
+ createdAt: Date;
60
101
  idempotencyKey: string;
61
102
  }[]>;
62
103
  /**
@@ -64,55 +105,74 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
64
105
  * Returns ready events and marks them as processing in the same transaction.
65
106
  */
66
107
  claimPendingHookEvents(namespace: string): TxResult<{
108
+ status: "processing";
67
109
  id: FragnoId;
68
110
  hookName: string;
69
111
  payload: unknown;
70
112
  attempts: number;
71
113
  maxAttempts: number;
114
+ lastAttemptAt: Date | null;
115
+ nextRetryAt: Date | null;
116
+ createdAt: Date;
72
117
  idempotencyKey: string;
73
118
  }[], {
74
119
  id: FragnoId;
75
120
  hookName: string;
76
121
  payload: unknown;
122
+ status: "pending" | "processing" | "completed" | "failed";
77
123
  attempts: number;
78
124
  maxAttempts: number;
125
+ lastAttemptAt: Date | null;
126
+ nextRetryAt: Date | null;
127
+ createdAt: Date;
79
128
  idempotencyKey: string;
80
129
  }[]>;
81
130
  /**
82
- * Re-queue hook events that have been stuck in processing for too long.
131
+ * Claim stale processing hook events for processing.
132
+ * Returns ready events and marks them as processing in the same transaction.
83
133
  */
84
- requeueStuckProcessingHooks(namespace: string, staleBefore: Date): TxResult<{
85
- id: FragnoId;
86
- hookName: string;
87
- attempts: number;
88
- maxAttempts: number;
89
- lastAttemptAt: Date | null;
90
- nextRetryAt: Date | null;
91
- }[], {
134
+ claimStuckProcessingHookEvents(namespace: string, staleBefore: DbNow): TxResult<{
135
+ events: {
136
+ id: FragnoId;
137
+ hookName: string;
138
+ payload: unknown;
139
+ status: "pending" | "processing" | "completed" | "failed";
140
+ attempts: number;
141
+ maxAttempts: number;
142
+ idempotencyKey: string;
143
+ lastAttemptAt: Date | null;
144
+ nextRetryAt: Date | null;
145
+ createdAt: Date;
146
+ }[];
147
+ stuckEvents: {
148
+ id: FragnoId;
149
+ hookName: string;
150
+ attempts: number;
151
+ maxAttempts: number;
152
+ lastAttemptAt: Date | null;
153
+ nextRetryAt: Date | null;
154
+ }[];
155
+ }, {
92
156
  id: FragnoId;
93
157
  hookName: string;
158
+ payload: unknown;
159
+ status: "pending" | "processing" | "completed" | "failed";
94
160
  attempts: number;
95
161
  maxAttempts: number;
162
+ idempotencyKey: string;
96
163
  lastAttemptAt: Date | null;
97
164
  nextRetryAt: Date | null;
165
+ createdAt: Date;
98
166
  }[]>;
99
- /**
100
- * Get the next time a processing hook becomes stale.
101
- */
102
- getNextProcessingStaleAt(namespace: string, timeoutMinutes: number, now?: Date): TxResult<Date | null, Date | null>;
103
167
  /**
104
168
  * Get the earliest pending hook wake time for a namespace.
105
169
  * Optionally considers processing hooks becoming stale when timeoutMinutes is provided.
106
170
  */
107
- getNextHookWakeAt(namespace: string, timeoutMinutes?: number | false, now?: Date): TxResult<Date | null, Date | null>;
108
- /**
109
- * Mark a hook event as completed.
110
- */
111
- markHookCompleted(eventId: FragnoId): TxResult<void, void>;
171
+ getNextHookWakeAt(namespace: string, timeoutMinutes?: number | false): TxResult<Date | null, Date | null>;
112
172
  /**
113
173
  * Mark a hook event as failed and schedule next retry.
114
174
  */
115
- markHookFailed(eventId: FragnoId, error: string, attempts: number, retryPolicy: RetryPolicy, now?: Date): TxResult<void, void>;
175
+ markHookFailed(eventId: FragnoId, error: string, attempts: number, retryPolicy: RetryPolicy): TxResult<void, void>;
116
176
  /**
117
177
  * Mark a hook event as processing (to prevent concurrent execution).
118
178
  */
@@ -121,11 +181,11 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
121
181
  * Get a hook event by ID (for testing/verification purposes).
122
182
  */
123
183
  getHookById(eventId: FragnoId): TxResult<{
184
+ status: "pending" | "processing" | "completed" | "failed";
124
185
  id: FragnoId;
125
186
  namespace: string;
126
187
  hookName: string;
127
188
  payload: unknown;
128
- status: string;
129
189
  attempts: number;
130
190
  maxAttempts: number;
131
191
  lastAttemptAt: Date | null;
@@ -134,11 +194,11 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
134
194
  createdAt: Date;
135
195
  nonce: string;
136
196
  } | undefined, {
197
+ status: "pending" | "processing" | "completed" | "failed";
137
198
  id: FragnoId;
138
199
  namespace: string;
139
200
  hookName: string;
140
201
  payload: unknown;
141
- status: string;
142
202
  attempts: number;
143
203
  maxAttempts: number;
144
204
  lastAttemptAt: Date | null;
@@ -147,15 +207,56 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
147
207
  createdAt: Date;
148
208
  nonce: string;
149
209
  } | undefined>;
210
+ /**
211
+ * Get hook events for a namespace in newest-first order with pagination.
212
+ */
213
+ getHooksByNamespacePage(namespace: string, options?: {
214
+ cursor?: Cursor | string;
215
+ pageSize?: number;
216
+ }): TxResult<{
217
+ items: {
218
+ status: "pending" | "processing" | "completed" | "failed";
219
+ id: FragnoId;
220
+ namespace: string;
221
+ hookName: string;
222
+ payload: unknown;
223
+ attempts: number;
224
+ maxAttempts: number;
225
+ lastAttemptAt: Date | null;
226
+ nextRetryAt: Date | null;
227
+ error: string | null;
228
+ createdAt: Date;
229
+ nonce: string;
230
+ }[];
231
+ cursor: Cursor | undefined;
232
+ hasNextPage: boolean;
233
+ }, {
234
+ items: {
235
+ status: "pending" | "processing" | "completed" | "failed";
236
+ id: FragnoId;
237
+ namespace: string;
238
+ hookName: string;
239
+ payload: unknown;
240
+ attempts: number;
241
+ maxAttempts: number;
242
+ lastAttemptAt: Date | null;
243
+ nextRetryAt: Date | null;
244
+ error: string | null;
245
+ createdAt: Date;
246
+ nonce: string;
247
+ }[];
248
+ cursor: Cursor | undefined;
249
+ hasNextPage: boolean;
250
+ }>;
150
251
  /**
151
252
  * Get all hook events for a namespace (for testing/verification purposes).
152
253
  */
153
254
  getHooksByNamespace(namespace: string): TxResult<{
255
+ status: "pending" | "processing" | "completed" | "failed";
154
256
  id: FragnoId;
155
257
  namespace: string;
156
258
  hookName: string;
157
259
  payload: unknown;
158
- status: string;
159
260
  attempts: number;
160
261
  maxAttempts: number;
161
262
  lastAttemptAt: Date | null;
@@ -164,11 +265,11 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
164
265
  createdAt: Date;
165
266
  nonce: string;
166
267
  }[], {
268
+ status: "pending" | "processing" | "completed" | "failed";
167
269
  id: FragnoId;
168
270
  namespace: string;
169
271
  hookName: string;
170
272
  payload: unknown;
171
- status: string;
172
273
  attempts: number;
173
274
  maxAttempts: number;
174
275
  lastAttemptAt: Date | null;
@@ -205,7 +306,7 @@ declare const internalFragmentDef: _fragno_dev_core0.FragmentDefinition<{}, Frag
205
306
  createdAt: Date;
206
307
  }[]>;
207
308
  };
208
- }, {}, {}, DatabaseServiceContext<{}>, DatabaseHandlerContext<{}>, DatabaseRequestStorage, {}>;
309
+ }, {}, {}, DatabaseServiceContext<{}>, DatabaseHandlerContext<{}>, DatabaseRequestStorage, readonly []>;
209
310
  /**
210
311
  * Type representing an instantiated internal fragment.
211
312
  * This is the fragment that manages Fragno's internal settings table.
@@ -1 +1 @@
1
- {"version":3,"file":"internal-fragment.d.ts","names":[],"sources":["../../src/fragments/internal-fragment.ts"],"sourcesContent":[],"mappings":"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"}
1
+ {"version":3,"file":"internal-fragment.d.ts","names":[],"sources":["../../src/fragments/internal-fragment.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;KAsBK,eAAA;qBACgB;;;;IADhB,MAAA,EAAA,MAAe,EAAA;EAyCR,CAAA,CAAA;EAiCC,mBAAA,EAAA,GAogBH,GAvkBmB,KAukBnB,CAAA;IApgBsB,IAAA,EAAA,MAAA;IAAA,UAAA,EAAA,MAAA;;;;;;;;KAjCpB,sBAAA;aACC;;cAgCA,uCAAmB,mBAAA,wBAAA,gCAAA;;;;;;;;;;;yCA6BM;UAAR;;;;UAAA;;;;;;;;;;;;;;;;;;;;;;;eA0Db,WAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mEAwG4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2EAmEK,SAAA,aAAA;;;;4BAkG5C,wDAAwD,cAAW;IApWjE;;;IA6BM,kBAAA,CAAA,OAAA,EA+WJ,QA/WI,CAAA,EA+WI,QA/WJ,CAAA,IAAA,EAAA,IAAA,CAAA;;;;yBA4XX;MAlUV,MAAA,EAAA,SAAA,GAAA,YAAA,GAAA,WAAA,GAAA,QAAA;MAAQ,EAAA,UAAA;;;;;;;;;;;;;;;;;;;MAwG4C,aAAA,MAAA,GAAA,IAAA;;;;;;;;;;eAiPzC;;;MA9K8C,KAAA,EAAA;QAAA,MAAA,EAAA,SAAA,GAAA,YAAA,GAAA,WAAA,GAAA,QAAA;QAAA,EAAA,UAAA;QAkG5C,SAAA,EAAA,MAAA;QAAwD,QAAA,EAAA,MAAA;QAAW,OAAA,EAAA,OAAA;QAwC/D,QAAA,EAAA,MAAA;QAAQ,WAAA,EAAA,MAAA;QAaf,aAAA,MAAA,GAAA,IAAA;;;;;;;;;;QAuBC,MAAA,EAAA,SAAA,GAAA,YAAA,GAAA,WAAA,GAAA,QAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;aAhbI,MAAA;IAAA,CAAA,EAAA,EAAA;MA0gBpB,MAAA,EAAA,SAAA,GAAwB,YAC3B,GAAA,WAAA,GAAA,QAD8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAA3B,wBAAA,GAA2B,0CAC9B"}