rivetkit 2.0.2 → 2.0.4-rc.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 (403) hide show
  1. package/README.md +3 -5
  2. package/dist/browser/client.d.ts +2485 -0
  3. package/dist/browser/client.js +5182 -0
  4. package/dist/browser/client.js.map +1 -0
  5. package/dist/browser/inspector/client.d.ts +130 -0
  6. package/dist/browser/inspector/client.js +2854 -0
  7. package/dist/browser/inspector/client.js.map +1 -0
  8. package/dist/browser/v3-DnYObHH3.d.ts +279 -0
  9. package/dist/inspector.tar.gz +0 -0
  10. package/dist/schemas/actor-inspector/v1.ts +784 -0
  11. package/dist/schemas/actor-inspector/v2.ts +796 -0
  12. package/dist/schemas/actor-inspector/v3.ts +899 -0
  13. package/dist/schemas/actor-persist/v1.ts +225 -0
  14. package/dist/schemas/actor-persist/v2.ts +268 -0
  15. package/dist/schemas/actor-persist/v3.ts +280 -0
  16. package/dist/schemas/actor-persist/v4.ts +406 -0
  17. package/dist/schemas/client-protocol/v1.ts +441 -0
  18. package/dist/schemas/client-protocol/v2.ts +438 -0
  19. package/dist/schemas/client-protocol/v3.ts +554 -0
  20. package/dist/schemas/file-system-driver/v1.ts +108 -0
  21. package/dist/schemas/file-system-driver/v2.ts +142 -0
  22. package/dist/schemas/file-system-driver/v3.ts +167 -0
  23. package/dist/schemas/persist/v1.ts +781 -0
  24. package/dist/schemas/transport/v1.ts +697 -0
  25. package/dist/tsup/actor/errors.cjs +106 -0
  26. package/dist/tsup/actor/errors.cjs.map +1 -0
  27. package/dist/tsup/actor/errors.d.cts +188 -0
  28. package/dist/tsup/actor/errors.d.ts +188 -0
  29. package/dist/tsup/actor/errors.js +106 -0
  30. package/dist/tsup/actor/errors.js.map +1 -0
  31. package/dist/tsup/actor-router-consts-D29T1Z-K.d.cts +24 -0
  32. package/dist/tsup/actor-router-consts-D29T1Z-K.d.ts +24 -0
  33. package/dist/tsup/chunk-325TLXJT.js +1060 -0
  34. package/dist/tsup/chunk-325TLXJT.js.map +1 -0
  35. package/dist/tsup/chunk-424PT5DM.js +23 -0
  36. package/dist/tsup/chunk-424PT5DM.js.map +1 -0
  37. package/dist/tsup/chunk-4JVIG3SS.cjs +6289 -0
  38. package/dist/tsup/chunk-4JVIG3SS.cjs.map +1 -0
  39. package/dist/tsup/chunk-6LJAZ5R4.cjs +96 -0
  40. package/dist/tsup/chunk-6LJAZ5R4.cjs.map +1 -0
  41. package/dist/tsup/chunk-6XU3FMCB.cjs +534 -0
  42. package/dist/tsup/chunk-6XU3FMCB.cjs.map +1 -0
  43. package/dist/tsup/chunk-7HTNH26M.js +509 -0
  44. package/dist/tsup/chunk-7HTNH26M.js.map +1 -0
  45. package/dist/tsup/chunk-AUVH72RE.cjs +5977 -0
  46. package/dist/tsup/chunk-AUVH72RE.cjs.map +1 -0
  47. package/dist/tsup/chunk-D4BYUPNQ.js +645 -0
  48. package/dist/tsup/chunk-D4BYUPNQ.js.map +1 -0
  49. package/dist/tsup/chunk-HDQ2JUQT.cjs +23 -0
  50. package/dist/tsup/chunk-HDQ2JUQT.cjs.map +1 -0
  51. package/dist/tsup/chunk-HHXX2VRM.js +6289 -0
  52. package/dist/tsup/chunk-HHXX2VRM.js.map +1 -0
  53. package/dist/tsup/chunk-JEAEA2PB.js +49 -0
  54. package/dist/tsup/chunk-JEAEA2PB.js.map +1 -0
  55. package/dist/tsup/chunk-JYSEG3VF.cjs +642 -0
  56. package/dist/tsup/chunk-JYSEG3VF.cjs.map +1 -0
  57. package/dist/tsup/chunk-K6DGYILQ.js +2657 -0
  58. package/dist/tsup/chunk-K6DGYILQ.js.map +1 -0
  59. package/dist/tsup/chunk-KJSYAUOM.js +96 -0
  60. package/dist/tsup/chunk-KJSYAUOM.js.map +1 -0
  61. package/dist/tsup/chunk-L47L3ZWJ.cjs +509 -0
  62. package/dist/tsup/chunk-L47L3ZWJ.cjs.map +1 -0
  63. package/dist/tsup/chunk-LXUQ667X.js +2006 -0
  64. package/dist/tsup/chunk-LXUQ667X.js.map +1 -0
  65. package/dist/tsup/chunk-MXNPAB5W.js +5977 -0
  66. package/dist/tsup/chunk-MXNPAB5W.js.map +1 -0
  67. package/dist/tsup/chunk-N4KRDJ56.js +72 -0
  68. package/dist/tsup/chunk-N4KRDJ56.js.map +1 -0
  69. package/dist/tsup/chunk-NIYZDWMW.cjs +2006 -0
  70. package/dist/tsup/chunk-NIYZDWMW.cjs.map +1 -0
  71. package/dist/tsup/chunk-PQZHDKRW.cjs +1060 -0
  72. package/dist/tsup/chunk-PQZHDKRW.cjs.map +1 -0
  73. package/dist/tsup/chunk-PVOE6BU7.cjs +1050 -0
  74. package/dist/tsup/chunk-PVOE6BU7.cjs.map +1 -0
  75. package/dist/tsup/chunk-Q4UD2GA4.cjs +1810 -0
  76. package/dist/tsup/chunk-Q4UD2GA4.cjs.map +1 -0
  77. package/dist/tsup/chunk-QUD664YZ.js +1810 -0
  78. package/dist/tsup/chunk-QUD664YZ.js.map +1 -0
  79. package/dist/tsup/chunk-RTOCTWME.js +1050 -0
  80. package/dist/tsup/chunk-RTOCTWME.js.map +1 -0
  81. package/dist/tsup/chunk-SAZZ4SB2.cjs +2657 -0
  82. package/dist/tsup/chunk-SAZZ4SB2.cjs.map +1 -0
  83. package/dist/tsup/chunk-SR3KQE7Q.cjs +72 -0
  84. package/dist/tsup/chunk-SR3KQE7Q.cjs.map +1 -0
  85. package/dist/tsup/chunk-V2GHLYC6.cjs +49 -0
  86. package/dist/tsup/chunk-V2GHLYC6.cjs.map +1 -0
  87. package/dist/tsup/chunk-V3WG7XTW.cjs +645 -0
  88. package/dist/tsup/chunk-V3WG7XTW.cjs.map +1 -0
  89. package/dist/tsup/chunk-VKVNIQRQ.js +257 -0
  90. package/dist/tsup/chunk-VKVNIQRQ.js.map +1 -0
  91. package/dist/tsup/chunk-WMPW7JYC.js +642 -0
  92. package/dist/tsup/chunk-WMPW7JYC.js.map +1 -0
  93. package/dist/tsup/chunk-Z7HNQ2WF.js +534 -0
  94. package/dist/tsup/chunk-Z7HNQ2WF.js.map +1 -0
  95. package/dist/tsup/chunk-ZFY5J2EP.cjs +257 -0
  96. package/dist/tsup/chunk-ZFY5J2EP.cjs.map +1 -0
  97. package/dist/tsup/client/mod.cjs +33 -0
  98. package/dist/tsup/client/mod.cjs.map +1 -0
  99. package/dist/tsup/client/mod.d.cts +64 -0
  100. package/dist/tsup/client/mod.d.ts +64 -0
  101. package/dist/tsup/client/mod.js +33 -0
  102. package/dist/tsup/client/mod.js.map +1 -0
  103. package/dist/tsup/common/log.cjs +21 -0
  104. package/dist/tsup/common/log.cjs.map +1 -0
  105. package/dist/tsup/common/log.d.cts +34 -0
  106. package/dist/tsup/common/log.d.ts +34 -0
  107. package/dist/tsup/common/log.js +21 -0
  108. package/dist/tsup/common/log.js.map +1 -0
  109. package/dist/tsup/common/websocket.cjs +10 -0
  110. package/dist/tsup/common/websocket.cjs.map +1 -0
  111. package/dist/tsup/common/websocket.d.cts +3 -0
  112. package/dist/tsup/common/websocket.d.ts +3 -0
  113. package/dist/tsup/common/websocket.js +10 -0
  114. package/dist/tsup/common/websocket.js.map +1 -0
  115. package/dist/tsup/config-BiNoIHRs.d.cts +80 -0
  116. package/dist/tsup/config-BiNoIHRs.d.ts +80 -0
  117. package/dist/tsup/config-P3XujgRr.d.ts +2594 -0
  118. package/dist/tsup/config-_gfywqqI.d.cts +2594 -0
  119. package/dist/tsup/context-Bxd8Cx4H.d.cts +75 -0
  120. package/dist/tsup/context-uNA4TRn3.d.ts +75 -0
  121. package/dist/tsup/db/drizzle/mod.cjs +49 -0
  122. package/dist/tsup/db/drizzle/mod.cjs.map +1 -0
  123. package/dist/tsup/db/drizzle/mod.d.cts +17 -0
  124. package/dist/tsup/db/drizzle/mod.d.ts +17 -0
  125. package/dist/tsup/db/drizzle/mod.js +49 -0
  126. package/dist/tsup/db/drizzle/mod.js.map +1 -0
  127. package/dist/tsup/db/mod.cjs +9 -0
  128. package/dist/tsup/db/mod.cjs.map +1 -0
  129. package/dist/tsup/db/mod.d.cts +9 -0
  130. package/dist/tsup/db/mod.d.ts +9 -0
  131. package/dist/tsup/db/mod.js +9 -0
  132. package/dist/tsup/db/mod.js.map +1 -0
  133. package/dist/tsup/driver-BcLvZcKl.d.cts +13 -0
  134. package/dist/tsup/driver-CPGHKXyh.d.ts +13 -0
  135. package/dist/tsup/driver-helpers/mod.cjs +53 -0
  136. package/dist/tsup/driver-helpers/mod.cjs.map +1 -0
  137. package/dist/tsup/driver-helpers/mod.d.cts +47 -0
  138. package/dist/tsup/driver-helpers/mod.d.ts +47 -0
  139. package/dist/tsup/driver-helpers/mod.js +53 -0
  140. package/dist/tsup/driver-helpers/mod.js.map +1 -0
  141. package/dist/tsup/driver-test-suite/mod.cjs +4974 -0
  142. package/dist/tsup/driver-test-suite/mod.cjs.map +1 -0
  143. package/dist/tsup/driver-test-suite/mod.d.cts +73 -0
  144. package/dist/tsup/driver-test-suite/mod.d.ts +73 -0
  145. package/dist/tsup/driver-test-suite/mod.js +4974 -0
  146. package/dist/tsup/driver-test-suite/mod.js.map +1 -0
  147. package/dist/tsup/inspector/mod.cjs +164 -0
  148. package/dist/tsup/inspector/mod.cjs.map +1 -0
  149. package/dist/tsup/inspector/mod.d.cts +130 -0
  150. package/dist/tsup/inspector/mod.d.ts +130 -0
  151. package/dist/tsup/inspector/mod.js +164 -0
  152. package/dist/tsup/inspector/mod.js.map +1 -0
  153. package/dist/tsup/keys-CydblqMh.d.cts +13 -0
  154. package/dist/tsup/keys-CydblqMh.d.ts +13 -0
  155. package/dist/tsup/mod.cjs +82 -0
  156. package/dist/tsup/mod.cjs.map +1 -0
  157. package/dist/tsup/mod.d.cts +126 -0
  158. package/dist/tsup/mod.d.ts +126 -0
  159. package/dist/tsup/mod.js +82 -0
  160. package/dist/tsup/mod.js.map +1 -0
  161. package/dist/tsup/serve-test-suite/mod.cjs +2601 -0
  162. package/dist/tsup/serve-test-suite/mod.cjs.map +1 -0
  163. package/dist/tsup/serve-test-suite/mod.d.cts +9 -0
  164. package/dist/tsup/serve-test-suite/mod.d.ts +9 -0
  165. package/dist/tsup/serve-test-suite/mod.js +2601 -0
  166. package/dist/tsup/serve-test-suite/mod.js.map +1 -0
  167. package/dist/tsup/test/mod.cjs +90 -0
  168. package/dist/tsup/test/mod.cjs.map +1 -0
  169. package/dist/tsup/test/mod.d.cts +26 -0
  170. package/dist/tsup/test/mod.d.ts +26 -0
  171. package/dist/tsup/test/mod.js +90 -0
  172. package/dist/tsup/test/mod.js.map +1 -0
  173. package/dist/tsup/utils-fwx3o3K9.d.cts +18 -0
  174. package/dist/tsup/utils-fwx3o3K9.d.ts +18 -0
  175. package/dist/tsup/utils.cjs +43 -0
  176. package/dist/tsup/utils.cjs.map +1 -0
  177. package/dist/tsup/utils.d.cts +148 -0
  178. package/dist/tsup/utils.d.ts +148 -0
  179. package/dist/tsup/utils.js +43 -0
  180. package/dist/tsup/utils.js.map +1 -0
  181. package/dist/tsup/v3-DnYObHH3.d.cts +279 -0
  182. package/dist/tsup/v3-DnYObHH3.d.ts +279 -0
  183. package/dist/tsup/workflow/mod.cjs +16 -0
  184. package/dist/tsup/workflow/mod.cjs.map +1 -0
  185. package/dist/tsup/workflow/mod.d.cts +25 -0
  186. package/dist/tsup/workflow/mod.d.ts +25 -0
  187. package/dist/tsup/workflow/mod.js +16 -0
  188. package/dist/tsup/workflow/mod.js.map +1 -0
  189. package/package.json +293 -5
  190. package/src/actor/config.ts +1221 -0
  191. package/src/actor/conn/driver.ts +61 -0
  192. package/src/actor/conn/drivers/http.ts +17 -0
  193. package/src/actor/conn/drivers/raw-request.ts +24 -0
  194. package/src/actor/conn/drivers/raw-websocket.ts +65 -0
  195. package/src/actor/conn/drivers/websocket.ts +144 -0
  196. package/src/actor/conn/mod.ts +288 -0
  197. package/src/actor/conn/persisted.ts +81 -0
  198. package/src/actor/conn/state-manager.ts +196 -0
  199. package/src/actor/contexts/action.ts +47 -0
  200. package/src/actor/contexts/base/actor.ts +347 -0
  201. package/src/actor/contexts/base/conn-init.ts +68 -0
  202. package/src/actor/contexts/base/conn.ts +73 -0
  203. package/src/actor/contexts/before-action-response.ts +42 -0
  204. package/src/actor/contexts/before-connect.ts +31 -0
  205. package/src/actor/contexts/connect.ts +42 -0
  206. package/src/actor/contexts/create-conn-state.ts +32 -0
  207. package/src/actor/contexts/create-vars.ts +39 -0
  208. package/src/actor/contexts/create.ts +39 -0
  209. package/src/actor/contexts/destroy.ts +42 -0
  210. package/src/actor/contexts/disconnect.ts +43 -0
  211. package/src/actor/contexts/index.ts +33 -0
  212. package/src/actor/contexts/request.ts +80 -0
  213. package/src/actor/contexts/run.ts +47 -0
  214. package/src/actor/contexts/sleep.ts +42 -0
  215. package/src/actor/contexts/state-change.ts +42 -0
  216. package/src/actor/contexts/wake.ts +42 -0
  217. package/src/actor/contexts/websocket.ts +80 -0
  218. package/src/actor/database.ts +13 -0
  219. package/src/actor/definition.ts +64 -0
  220. package/src/actor/driver.ts +114 -0
  221. package/src/actor/errors.ts +556 -0
  222. package/src/actor/instance/connection-manager.ts +574 -0
  223. package/src/actor/instance/event-manager.ts +314 -0
  224. package/src/actor/instance/keys.ts +146 -0
  225. package/src/actor/instance/kv.ts +241 -0
  226. package/src/actor/instance/mod.ts +1658 -0
  227. package/src/actor/instance/persisted.ts +67 -0
  228. package/src/actor/instance/queue-manager.ts +603 -0
  229. package/src/actor/instance/queue.ts +345 -0
  230. package/src/actor/instance/schedule-manager.ts +392 -0
  231. package/src/actor/instance/state-manager.ts +542 -0
  232. package/src/actor/instance/traces-driver.ts +128 -0
  233. package/src/actor/keys.test.ts +275 -0
  234. package/src/actor/keys.ts +89 -0
  235. package/src/actor/log.ts +6 -0
  236. package/src/actor/mod.ts +110 -0
  237. package/src/actor/protocol/old.ts +416 -0
  238. package/src/actor/protocol/serde.ts +222 -0
  239. package/src/actor/router-endpoints.ts +400 -0
  240. package/src/actor/router-websocket-endpoints.test.ts +54 -0
  241. package/src/actor/router-websocket-endpoints.ts +405 -0
  242. package/src/actor/router.ts +380 -0
  243. package/src/actor/schedule.ts +17 -0
  244. package/src/actor/schema.ts +291 -0
  245. package/src/actor/utils.test.ts +48 -0
  246. package/src/actor/utils.ts +158 -0
  247. package/src/client/actor-common.ts +32 -0
  248. package/src/client/actor-conn.ts +1262 -0
  249. package/src/client/actor-handle.ts +344 -0
  250. package/src/client/actor-query.ts +112 -0
  251. package/src/client/client.ts +558 -0
  252. package/src/client/config.ts +151 -0
  253. package/src/client/errors.ts +76 -0
  254. package/src/client/log.ts +5 -0
  255. package/src/client/mod.browser.ts +2 -0
  256. package/src/client/mod.ts +70 -0
  257. package/src/client/queue.ts +146 -0
  258. package/src/client/raw-utils.ts +149 -0
  259. package/src/client/test.ts +44 -0
  260. package/src/client/utils.ts +252 -0
  261. package/src/common/actor-router-consts.ts +59 -0
  262. package/src/common/cors.ts +57 -0
  263. package/src/common/eventsource-interface.ts +47 -0
  264. package/src/common/eventsource.ts +44 -0
  265. package/src/common/inline-websocket-adapter.ts +154 -0
  266. package/src/common/log-levels.ts +27 -0
  267. package/src/common/log.ts +229 -0
  268. package/src/common/logfmt.ts +221 -0
  269. package/src/common/network.ts +2 -0
  270. package/src/common/router.ts +174 -0
  271. package/src/common/utils.ts +339 -0
  272. package/src/common/websocket-interface.ts +7 -0
  273. package/src/common/websocket.ts +43 -0
  274. package/src/db/config.ts +100 -0
  275. package/src/db/drizzle/mod.ts +226 -0
  276. package/src/db/drizzle/sqlite-core.ts +22 -0
  277. package/src/db/mod.ts +125 -0
  278. package/src/db/shared.ts +92 -0
  279. package/src/db/sqlite-vfs.ts +12 -0
  280. package/src/devtools-loader/index.ts +33 -0
  281. package/src/devtools-loader/log.ts +5 -0
  282. package/src/driver-helpers/mod.ts +33 -0
  283. package/src/driver-helpers/utils.ts +54 -0
  284. package/src/driver-test-suite/log.ts +5 -0
  285. package/src/driver-test-suite/mod.ts +293 -0
  286. package/src/driver-test-suite/test-inline-client-driver.ts +307 -0
  287. package/src/driver-test-suite/tests/access-control.ts +218 -0
  288. package/src/driver-test-suite/tests/action-features.ts +203 -0
  289. package/src/driver-test-suite/tests/actor-conn-hibernation.ts +152 -0
  290. package/src/driver-test-suite/tests/actor-conn-state.ts +300 -0
  291. package/src/driver-test-suite/tests/actor-conn.ts +596 -0
  292. package/src/driver-test-suite/tests/actor-db-raw.ts +73 -0
  293. package/src/driver-test-suite/tests/actor-db.ts +477 -0
  294. package/src/driver-test-suite/tests/actor-destroy.ts +294 -0
  295. package/src/driver-test-suite/tests/actor-driver.ts +18 -0
  296. package/src/driver-test-suite/tests/actor-error-handling.ts +150 -0
  297. package/src/driver-test-suite/tests/actor-handle.ts +312 -0
  298. package/src/driver-test-suite/tests/actor-inline-client.ts +163 -0
  299. package/src/driver-test-suite/tests/actor-inspector.ts +264 -0
  300. package/src/driver-test-suite/tests/actor-kv.ts +65 -0
  301. package/src/driver-test-suite/tests/actor-metadata.ts +116 -0
  302. package/src/driver-test-suite/tests/actor-onstatechange.ts +95 -0
  303. package/src/driver-test-suite/tests/actor-queue.ts +325 -0
  304. package/src/driver-test-suite/tests/actor-run.ts +181 -0
  305. package/src/driver-test-suite/tests/actor-schedule.ts +97 -0
  306. package/src/driver-test-suite/tests/actor-sleep.ts +415 -0
  307. package/src/driver-test-suite/tests/actor-state.ts +54 -0
  308. package/src/driver-test-suite/tests/actor-stateless.ts +70 -0
  309. package/src/driver-test-suite/tests/actor-vars.ts +97 -0
  310. package/src/driver-test-suite/tests/actor-workflow.ts +118 -0
  311. package/src/driver-test-suite/tests/manager-driver.ts +388 -0
  312. package/src/driver-test-suite/tests/raw-http-direct-registry.ts +227 -0
  313. package/src/driver-test-suite/tests/raw-http-request-properties.ts +454 -0
  314. package/src/driver-test-suite/tests/raw-http.ts +359 -0
  315. package/src/driver-test-suite/tests/raw-websocket-direct-registry.ts +393 -0
  316. package/src/driver-test-suite/tests/raw-websocket.ts +513 -0
  317. package/src/driver-test-suite/tests/request-access.ts +240 -0
  318. package/src/driver-test-suite/utils.ts +80 -0
  319. package/src/drivers/default.ts +38 -0
  320. package/src/drivers/engine/actor-driver.ts +1027 -0
  321. package/src/drivers/engine/config.ts +43 -0
  322. package/src/drivers/engine/log.ts +5 -0
  323. package/src/drivers/engine/mod.ts +36 -0
  324. package/src/drivers/file-system/actor.ts +102 -0
  325. package/src/drivers/file-system/global-state.ts +1445 -0
  326. package/src/drivers/file-system/kv-limits.ts +70 -0
  327. package/src/drivers/file-system/log.ts +5 -0
  328. package/src/drivers/file-system/manager.ts +300 -0
  329. package/src/drivers/file-system/mod.ts +78 -0
  330. package/src/drivers/file-system/sqlite-runtime.ts +210 -0
  331. package/src/drivers/file-system/utils.ts +125 -0
  332. package/src/engine-process/constants.ts +2 -0
  333. package/src/engine-process/log.ts +5 -0
  334. package/src/engine-process/mod.ts +464 -0
  335. package/src/globals.d.ts +35 -0
  336. package/src/inspector/actor-inspector.ts +352 -0
  337. package/src/inspector/config.ts +49 -0
  338. package/src/inspector/handler.ts +273 -0
  339. package/src/inspector/log.ts +5 -0
  340. package/src/inspector/mod.browser.ts +8 -0
  341. package/src/inspector/mod.ts +4 -0
  342. package/src/inspector/serve-ui.ts +40 -0
  343. package/src/inspector/transport.ts +18 -0
  344. package/src/inspector/utils.ts +32 -0
  345. package/src/manager/driver.ts +106 -0
  346. package/src/manager/gateway.ts +668 -0
  347. package/src/manager/log.ts +5 -0
  348. package/src/manager/mod.ts +2 -0
  349. package/src/manager/protocol/mod.ts +22 -0
  350. package/src/manager/protocol/query.ts +85 -0
  351. package/src/manager/router-schema.ts +22 -0
  352. package/src/manager/router.ts +660 -0
  353. package/src/manager-api/actors.ts +83 -0
  354. package/src/manager-api/common.ts +4 -0
  355. package/src/mod.ts +24 -0
  356. package/src/registry/config/driver.ts +21 -0
  357. package/src/registry/config/index.ts +510 -0
  358. package/src/registry/config/legacy-runner.ts +157 -0
  359. package/src/registry/config/runner.ts +21 -0
  360. package/src/registry/config/serverless.ts +94 -0
  361. package/src/registry/index.ts +194 -0
  362. package/src/registry/log.ts +5 -0
  363. package/src/remote-manager-driver/actor-http-client.ts +84 -0
  364. package/src/remote-manager-driver/actor-websocket-client.ts +81 -0
  365. package/src/remote-manager-driver/api-endpoints.ts +159 -0
  366. package/src/remote-manager-driver/api-utils.ts +69 -0
  367. package/src/remote-manager-driver/log.ts +5 -0
  368. package/src/remote-manager-driver/metadata.ts +64 -0
  369. package/src/remote-manager-driver/mod.ts +414 -0
  370. package/src/remote-manager-driver/ws-proxy.ts +189 -0
  371. package/src/schemas/actor-inspector/mod.ts +1 -0
  372. package/src/schemas/actor-inspector/versioned.ts +233 -0
  373. package/src/schemas/actor-persist/mod.ts +1 -0
  374. package/src/schemas/actor-persist/versioned.ts +217 -0
  375. package/src/schemas/client-protocol/mod.ts +1 -0
  376. package/src/schemas/client-protocol/versioned.ts +330 -0
  377. package/src/schemas/client-protocol-zod/mod.ts +118 -0
  378. package/src/schemas/file-system-driver/mod.ts +1 -0
  379. package/src/schemas/file-system-driver/versioned.ts +135 -0
  380. package/src/schemas/persist/mod.ts +1 -0
  381. package/src/schemas/transport/mod.ts +1 -0
  382. package/src/serde.ts +138 -0
  383. package/src/serve-test-suite/mod.ts +148 -0
  384. package/src/serverless/configure.ts +82 -0
  385. package/src/serverless/log.ts +5 -0
  386. package/src/serverless/router.test.ts +299 -0
  387. package/src/serverless/router.ts +215 -0
  388. package/src/test/log.ts +5 -0
  389. package/src/test/mod.ts +99 -0
  390. package/src/utils/crypto.ts +24 -0
  391. package/src/utils/endpoint-parser.test.ts +202 -0
  392. package/src/utils/endpoint-parser.ts +124 -0
  393. package/src/utils/env-vars.ts +78 -0
  394. package/src/utils/node.ts +178 -0
  395. package/src/utils/router.ts +83 -0
  396. package/src/utils/serve.ts +212 -0
  397. package/src/utils.test.ts +34 -0
  398. package/src/utils.ts +437 -0
  399. package/src/workflow/constants.ts +2 -0
  400. package/src/workflow/context.ts +597 -0
  401. package/src/workflow/driver.ts +194 -0
  402. package/src/workflow/inspector.ts +268 -0
  403. package/src/workflow/mod.ts +128 -0
@@ -0,0 +1,194 @@
1
+ import type { RunContext } from "@/actor/contexts/run";
2
+ import type { AnyActorInstance } from "@/actor/instance/mod";
3
+ import { makeWorkflowKey, workflowStoragePrefix } from "@/actor/instance/keys";
4
+ import type {
5
+ EngineDriver,
6
+ KVEntry,
7
+ KVWrite,
8
+ Message,
9
+ WorkflowMessageDriver,
10
+ } from "@rivetkit/workflow-engine";
11
+
12
+ const WORKFLOW_STORAGE_PREFIX = workflowStoragePrefix();
13
+
14
+ function stripWorkflowKey(prefixed: Uint8Array): Uint8Array {
15
+ return prefixed.slice(WORKFLOW_STORAGE_PREFIX.length);
16
+ }
17
+
18
+ class ActorWorkflowMessageDriver implements WorkflowMessageDriver {
19
+ #actor: AnyActorInstance;
20
+ #runCtx: RunContext<any, any, any, any, any, any, any, any>;
21
+
22
+ constructor(
23
+ actor: AnyActorInstance,
24
+ runCtx: RunContext<any, any, any, any, any, any, any, any>,
25
+ ) {
26
+ this.#actor = actor;
27
+ this.#runCtx = runCtx;
28
+ }
29
+
30
+ async addMessage(message: Message): Promise<void> {
31
+ await this.#runCtx.keepAwake(
32
+ this.#actor.queueManager.enqueue(message.name, message.data),
33
+ );
34
+ }
35
+
36
+ async receiveMessages(opts: {
37
+ names?: readonly string[];
38
+ count: number;
39
+ completable: boolean;
40
+ }): Promise<Message[]> {
41
+ const messages = await this.#runCtx.keepAwake(
42
+ this.#actor.queueManager.receive(
43
+ opts.names && opts.names.length > 0 ? [...opts.names] : undefined,
44
+ opts.count,
45
+ 0,
46
+ undefined,
47
+ opts.completable,
48
+ ),
49
+ );
50
+ return messages.map((message) => ({
51
+ id: message.id.toString(),
52
+ name: message.name,
53
+ data: message.body,
54
+ sentAt: message.createdAt,
55
+ ...(opts.completable
56
+ ? {
57
+ complete: async (response?: unknown) => {
58
+ await this.#runCtx.keepAwake(
59
+ this.#actor.queueManager.completeMessage(
60
+ message,
61
+ response,
62
+ ),
63
+ );
64
+ },
65
+ }
66
+ : {}),
67
+ }));
68
+ }
69
+
70
+ async completeMessage(messageId: string, response?: unknown): Promise<void> {
71
+ let parsedId: bigint;
72
+ try {
73
+ parsedId = BigInt(messageId);
74
+ } catch {
75
+ return;
76
+ }
77
+
78
+ await this.#runCtx.keepAwake(
79
+ this.#actor.queueManager.completeMessageById(parsedId, response),
80
+ );
81
+ }
82
+ }
83
+
84
+ export class ActorWorkflowDriver implements EngineDriver {
85
+ readonly workerPollInterval = 100;
86
+ readonly messageDriver: WorkflowMessageDriver;
87
+ #actor: AnyActorInstance;
88
+ #runCtx: RunContext<any, any, any, any, any, any, any, any>;
89
+
90
+ constructor(
91
+ actor: AnyActorInstance,
92
+ runCtx: RunContext<any, any, any, any, any, any, any, any>,
93
+ ) {
94
+ this.#actor = actor;
95
+ this.#runCtx = runCtx;
96
+ this.messageDriver = new ActorWorkflowMessageDriver(actor, runCtx);
97
+ }
98
+
99
+ async get(key: Uint8Array): Promise<Uint8Array | null> {
100
+ const [value] = await this.#runCtx.keepAwake(
101
+ this.#actor.driver.kvBatchGet(this.#actor.id, [
102
+ makeWorkflowKey(key),
103
+ ]),
104
+ );
105
+ return value ?? null;
106
+ }
107
+
108
+ async set(key: Uint8Array, value: Uint8Array): Promise<void> {
109
+ await this.#runCtx.keepAwake(
110
+ this.#actor.driver.kvBatchPut(this.#actor.id, [
111
+ [makeWorkflowKey(key), value],
112
+ ]),
113
+ );
114
+ }
115
+
116
+ async delete(key: Uint8Array): Promise<void> {
117
+ await this.#runCtx.keepAwake(
118
+ this.#actor.driver.kvBatchDelete(this.#actor.id, [
119
+ makeWorkflowKey(key),
120
+ ]),
121
+ );
122
+ }
123
+
124
+ async deletePrefix(prefix: Uint8Array): Promise<void> {
125
+ const entries = await this.#runCtx.keepAwake(
126
+ this.#actor.driver.kvListPrefix(
127
+ this.#actor.id,
128
+ makeWorkflowKey(prefix),
129
+ ),
130
+ );
131
+ if (entries.length === 0) {
132
+ return;
133
+ }
134
+ await this.#runCtx.keepAwake(
135
+ this.#actor.driver.kvBatchDelete(
136
+ this.#actor.id,
137
+ entries.map(([key]) => key),
138
+ ),
139
+ );
140
+ }
141
+
142
+ async list(prefix: Uint8Array): Promise<KVEntry[]> {
143
+ const entries = await this.#runCtx.keepAwake(
144
+ this.#actor.driver.kvListPrefix(
145
+ this.#actor.id,
146
+ makeWorkflowKey(prefix),
147
+ ),
148
+ );
149
+ return entries.map(([key, value]) => ({
150
+ key: stripWorkflowKey(key),
151
+ value,
152
+ }));
153
+ }
154
+
155
+ async batch(writes: KVWrite[]): Promise<void> {
156
+ if (writes.length === 0) return;
157
+
158
+ // Flush actor state together with workflow state to ensure atomicity.
159
+ // If the server crashes after workflow flush, actor state must also be persisted.
160
+ await this.#runCtx.keepAwake(
161
+ Promise.all([
162
+ this.#actor.driver.kvBatchPut(
163
+ this.#actor.id,
164
+ writes.map(({ key, value }) => [makeWorkflowKey(key), value]),
165
+ ),
166
+ this.#actor.stateManager.saveState({
167
+ immediate: true,
168
+ allowStoppingState: true,
169
+ }),
170
+ ]),
171
+ );
172
+ }
173
+
174
+ async setAlarm(_workflowId: string, wakeAt: number): Promise<void> {
175
+ await this.#runCtx.keepAwake(
176
+ this.#actor.driver.setAlarm(this.#actor, wakeAt),
177
+ );
178
+ }
179
+
180
+ async clearAlarm(_workflowId: string): Promise<void> {
181
+ // No dedicated clear alarm support in actor drivers.
182
+ return;
183
+ }
184
+
185
+ waitForMessages(
186
+ messageNames: string[],
187
+ abortSignal: AbortSignal,
188
+ ): Promise<void> {
189
+ return this.#actor.queueManager.waitForNames(
190
+ messageNames.length > 0 ? messageNames : undefined,
191
+ abortSignal,
192
+ );
193
+ }
194
+ }
@@ -0,0 +1,268 @@
1
+ import * as cbor from "cbor-x";
2
+ import { createNanoEvents } from "nanoevents";
3
+ import type {
4
+ BranchStatus,
5
+ BranchStatusType,
6
+ EntryKind,
7
+ EntryStatus,
8
+ Location,
9
+ SleepState,
10
+ WorkflowHistoryEntry,
11
+ WorkflowHistorySnapshot,
12
+ WorkflowEntryMetadataSnapshot,
13
+ } from "@rivetkit/workflow-engine";
14
+ import { encodeWorkflowHistoryTransport } from "@/inspector/transport";
15
+ import type * as inspectorSchema from "@/schemas/actor-inspector/mod";
16
+ import * as transport from "@/schemas/transport/mod";
17
+ import { assertUnreachable, bufferToArrayBuffer } from "@/utils";
18
+
19
+ export interface WorkflowInspectorAdapter {
20
+ getHistory: () => inspectorSchema.WorkflowHistory | null;
21
+ onHistoryUpdated: (
22
+ listener: (history: inspectorSchema.WorkflowHistory) => void,
23
+ ) => () => void;
24
+ }
25
+
26
+ export function createWorkflowInspectorAdapter(): {
27
+ adapter: WorkflowInspectorAdapter;
28
+ update: (snapshot: WorkflowHistorySnapshot) => void;
29
+ } {
30
+ const emitter = createNanoEvents<{
31
+ updated: (history: inspectorSchema.WorkflowHistory) => void;
32
+ }>();
33
+ let history: inspectorSchema.WorkflowHistory | null = null;
34
+
35
+ const adapter: WorkflowInspectorAdapter = {
36
+ getHistory: () => history,
37
+ onHistoryUpdated: (listener) => emitter.on("updated", listener),
38
+ };
39
+
40
+ const update = (snapshot: WorkflowHistorySnapshot) => {
41
+ const transportHistory = toWorkflowHistory(snapshot);
42
+ const next = encodeWorkflowHistoryTransport(transportHistory);
43
+ history = next;
44
+ emitter.emit("updated", next);
45
+ };
46
+
47
+ return { adapter, update };
48
+ }
49
+
50
+ function encodeCbor(value: unknown): ArrayBuffer {
51
+ return bufferToArrayBuffer(cbor.encode(value));
52
+ }
53
+
54
+ function encodeOptionalCbor(value: unknown): ArrayBuffer | null {
55
+ if (value === undefined) {
56
+ return null;
57
+ }
58
+ return encodeCbor(value);
59
+ }
60
+
61
+ function toU64(value: number): bigint {
62
+ return BigInt(Math.max(0, Math.floor(value)));
63
+ }
64
+
65
+ function toWorkflowLocation(
66
+ location: Location,
67
+ ): transport.WorkflowLocation {
68
+ return location.map((segment) => {
69
+ if (typeof segment === "number") {
70
+ return { tag: "WorkflowNameIndex", val: segment };
71
+ }
72
+ return {
73
+ tag: "WorkflowLoopIterationMarker",
74
+ val: {
75
+ loop: segment.loop,
76
+ iteration: segment.iteration,
77
+ },
78
+ };
79
+ });
80
+ }
81
+
82
+ function toWorkflowEntryKind(
83
+ kind: EntryKind,
84
+ ): transport.WorkflowEntryKind {
85
+ switch (kind.type) {
86
+ case "step":
87
+ return {
88
+ tag: "WorkflowStepEntry",
89
+ val: {
90
+ output: encodeOptionalCbor(kind.data.output),
91
+ error: kind.data.error ?? null,
92
+ },
93
+ };
94
+ case "loop":
95
+ return {
96
+ tag: "WorkflowLoopEntry",
97
+ val: {
98
+ state: encodeCbor(kind.data.state),
99
+ iteration: kind.data.iteration,
100
+ output: encodeOptionalCbor(kind.data.output),
101
+ },
102
+ };
103
+ case "sleep":
104
+ return {
105
+ tag: "WorkflowSleepEntry",
106
+ val: {
107
+ deadline: toU64(kind.data.deadline),
108
+ state: toWorkflowSleepState(kind.data.state),
109
+ },
110
+ };
111
+ case "message":
112
+ return {
113
+ tag: "WorkflowMessageEntry",
114
+ val: {
115
+ name: kind.data.name,
116
+ messageData: encodeCbor(kind.data.data),
117
+ },
118
+ };
119
+ case "rollback_checkpoint":
120
+ return {
121
+ tag: "WorkflowRollbackCheckpointEntry",
122
+ val: { name: kind.data.name },
123
+ };
124
+ case "join":
125
+ return {
126
+ tag: "WorkflowJoinEntry",
127
+ val: { branches: toWorkflowBranchStatusMap(kind.data.branches) },
128
+ };
129
+ case "race":
130
+ return {
131
+ tag: "WorkflowRaceEntry",
132
+ val: {
133
+ winner: kind.data.winner ?? null,
134
+ branches: toWorkflowBranchStatusMap(kind.data.branches),
135
+ },
136
+ };
137
+ case "removed":
138
+ return {
139
+ tag: "WorkflowRemovedEntry",
140
+ val: {
141
+ originalType: kind.data.originalType,
142
+ originalName: kind.data.originalName ?? null,
143
+ },
144
+ };
145
+ default:
146
+ assertUnreachable(kind as never);
147
+ }
148
+ }
149
+
150
+ function toWorkflowEntry(
151
+ entry: WorkflowHistoryEntry,
152
+ ): transport.WorkflowEntry {
153
+ return {
154
+ id: entry.id,
155
+ location: toWorkflowLocation(entry.location),
156
+ kind: toWorkflowEntryKind(entry.kind),
157
+ };
158
+ }
159
+
160
+ function toWorkflowEntryStatus(
161
+ status: EntryStatus,
162
+ ): transport.WorkflowEntryStatus {
163
+ switch (status) {
164
+ case "pending":
165
+ return transport.WorkflowEntryStatus.PENDING;
166
+ case "running":
167
+ return transport.WorkflowEntryStatus.RUNNING;
168
+ case "completed":
169
+ return transport.WorkflowEntryStatus.COMPLETED;
170
+ case "failed":
171
+ return transport.WorkflowEntryStatus.FAILED;
172
+ case "exhausted":
173
+ return transport.WorkflowEntryStatus.EXHAUSTED;
174
+ default:
175
+ assertUnreachable(status as never);
176
+ }
177
+ }
178
+
179
+ function toWorkflowSleepState(
180
+ state: SleepState,
181
+ ): transport.WorkflowSleepState {
182
+ switch (state) {
183
+ case "pending":
184
+ return transport.WorkflowSleepState.PENDING;
185
+ case "completed":
186
+ return transport.WorkflowSleepState.COMPLETED;
187
+ case "interrupted":
188
+ return transport.WorkflowSleepState.INTERRUPTED;
189
+ default:
190
+ assertUnreachable(state as never);
191
+ }
192
+ }
193
+
194
+ function toWorkflowBranchStatusType(
195
+ status: BranchStatusType,
196
+ ): transport.WorkflowBranchStatusType {
197
+ switch (status) {
198
+ case "pending":
199
+ return transport.WorkflowBranchStatusType.PENDING;
200
+ case "running":
201
+ return transport.WorkflowBranchStatusType.RUNNING;
202
+ case "completed":
203
+ return transport.WorkflowBranchStatusType.COMPLETED;
204
+ case "failed":
205
+ return transport.WorkflowBranchStatusType.FAILED;
206
+ case "cancelled":
207
+ return transport.WorkflowBranchStatusType.CANCELLED;
208
+ default:
209
+ assertUnreachable(status as never);
210
+ }
211
+ }
212
+
213
+ function toWorkflowBranchStatus(
214
+ status: BranchStatus,
215
+ ): transport.WorkflowBranchStatus {
216
+ return {
217
+ status: toWorkflowBranchStatusType(status.status),
218
+ output: encodeOptionalCbor(status.output),
219
+ error: status.error ?? null,
220
+ };
221
+ }
222
+
223
+ function toWorkflowBranchStatusMap(
224
+ branches: Record<string, BranchStatus>,
225
+ ): ReadonlyMap<string, transport.WorkflowBranchStatus> {
226
+ return new Map(
227
+ Object.entries(branches).map(([name, status]) => [
228
+ name,
229
+ toWorkflowBranchStatus(status),
230
+ ]),
231
+ );
232
+ }
233
+
234
+ function toWorkflowEntryMetadata(
235
+ metadata: WorkflowEntryMetadataSnapshot,
236
+ ): transport.WorkflowEntryMetadata {
237
+ return {
238
+ status: toWorkflowEntryStatus(metadata.status),
239
+ error: metadata.error ?? null,
240
+ attempts: metadata.attempts,
241
+ lastAttemptAt: toU64(metadata.lastAttemptAt),
242
+ createdAt: toU64(metadata.createdAt),
243
+ completedAt:
244
+ metadata.completedAt === undefined
245
+ ? null
246
+ : toU64(metadata.completedAt),
247
+ rollbackCompletedAt:
248
+ metadata.rollbackCompletedAt === undefined
249
+ ? null
250
+ : toU64(metadata.rollbackCompletedAt),
251
+ rollbackError: metadata.rollbackError ?? null,
252
+ };
253
+ }
254
+
255
+ function toWorkflowHistory(
256
+ snapshot: WorkflowHistorySnapshot,
257
+ ): transport.WorkflowHistory {
258
+ const entryMetadata = new Map<string, transport.WorkflowEntryMetadata>();
259
+ for (const [id, metadata] of snapshot.entryMetadata) {
260
+ entryMetadata.set(id, toWorkflowEntryMetadata(metadata));
261
+ }
262
+
263
+ return {
264
+ nameRegistry: snapshot.nameRegistry,
265
+ entries: snapshot.entries.map((entry) => toWorkflowEntry(entry)),
266
+ entryMetadata,
267
+ };
268
+ }
@@ -0,0 +1,128 @@
1
+ import { ACTOR_CONTEXT_INTERNAL_SYMBOL } from "@/actor/contexts/base/actor";
2
+ import type { RunContext } from "@/actor/contexts/run";
3
+ import type { AnyDatabaseProvider } from "@/actor/database";
4
+ import type { AnyActorInstance } from "@/actor/instance/mod";
5
+ import type { EventSchemaConfig, QueueSchemaConfig } from "@/actor/schema";
6
+ import { RUN_FUNCTION_CONFIG_SYMBOL } from "@/actor/config";
7
+ import { stringifyError } from "@/utils";
8
+ import { runWorkflow } from "@rivetkit/workflow-engine";
9
+ import invariant from "invariant";
10
+ import { ActorWorkflowContext } from "./context";
11
+ import { ActorWorkflowDriver } from "./driver";
12
+ import { createWorkflowInspectorAdapter } from "./inspector";
13
+
14
+ export { Loop } from "@rivetkit/workflow-engine";
15
+ export {
16
+ ActorWorkflowContext,
17
+ type WorkflowBranchContextOf,
18
+ type WorkflowContextOf,
19
+ type WorkflowLoopContextOf,
20
+ type WorkflowStepContextOf,
21
+ } from "./context";
22
+
23
+ export function workflow<
24
+ TState,
25
+ TConnParams,
26
+ TConnState,
27
+ TVars,
28
+ TInput,
29
+ TDatabase extends AnyDatabaseProvider,
30
+ TEvents extends EventSchemaConfig = Record<never, never>,
31
+ TQueues extends QueueSchemaConfig = Record<never, never>,
32
+ >(
33
+ fn: (
34
+ ctx: ActorWorkflowContext<
35
+ TState,
36
+ TConnParams,
37
+ TConnState,
38
+ TVars,
39
+ TInput,
40
+ TDatabase,
41
+ TEvents,
42
+ TQueues
43
+ >,
44
+ ) => Promise<unknown>,
45
+ ): (
46
+ c: RunContext<
47
+ TState,
48
+ TConnParams,
49
+ TConnState,
50
+ TVars,
51
+ TInput,
52
+ TDatabase,
53
+ TEvents,
54
+ TQueues
55
+ >,
56
+ ) => Promise<void> {
57
+ const workflowInspector = createWorkflowInspectorAdapter();
58
+
59
+ async function run(
60
+ runCtx: RunContext<
61
+ TState,
62
+ TConnParams,
63
+ TConnState,
64
+ TVars,
65
+ TInput,
66
+ TDatabase,
67
+ TEvents,
68
+ TQueues
69
+ >,
70
+ ): Promise<void> {
71
+ const actor = (
72
+ runCtx as unknown as {
73
+ [ACTOR_CONTEXT_INTERNAL_SYMBOL]?: AnyActorInstance;
74
+ }
75
+ )[ACTOR_CONTEXT_INTERNAL_SYMBOL];
76
+ invariant(actor, "workflow() requires an actor instance");
77
+
78
+ const driver = new ActorWorkflowDriver(actor, runCtx);
79
+
80
+ const handle = runWorkflow(
81
+ actor.id,
82
+ async (ctx) => await fn(new ActorWorkflowContext(ctx, runCtx)),
83
+ undefined,
84
+ driver,
85
+ {
86
+ mode: "live",
87
+ logger: runCtx.log,
88
+ onHistoryUpdated: workflowInspector.update,
89
+ },
90
+ );
91
+
92
+ const onAbort = () => {
93
+ handle.evict();
94
+ };
95
+ if (runCtx.abortSignal.aborted) {
96
+ onAbort();
97
+ } else {
98
+ runCtx.abortSignal.addEventListener("abort", onAbort, {
99
+ once: true,
100
+ });
101
+ }
102
+
103
+ try {
104
+ await handle.result;
105
+ } catch (error) {
106
+ runCtx.log.error({
107
+ msg: "workflow run failed",
108
+ error: stringifyError(error),
109
+ });
110
+ throw error;
111
+ } finally {
112
+ runCtx.abortSignal.removeEventListener("abort", onAbort);
113
+ }
114
+ }
115
+
116
+ const runWithConfig = run as typeof run & {
117
+ [RUN_FUNCTION_CONFIG_SYMBOL]?: {
118
+ icon?: string;
119
+ inspector?: { workflow: typeof workflowInspector.adapter };
120
+ };
121
+ };
122
+ runWithConfig[RUN_FUNCTION_CONFIG_SYMBOL] = {
123
+ icon: "diagram-project",
124
+ inspector: { workflow: workflowInspector.adapter },
125
+ };
126
+
127
+ return runWithConfig;
128
+ }