@qlever-llc/trellis 0.8.4 → 0.9.0-rc.10

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 (693) hide show
  1. package/README.md +1 -1
  2. package/bin/trellis-generate.js +0 -0
  3. package/esm/auth/browser/login.d.ts.map +1 -1
  4. package/esm/auth/browser/login.js +46 -3
  5. package/esm/auth/browser/portal.d.ts.map +1 -1
  6. package/esm/auth/browser/portal.js +5 -1
  7. package/esm/auth/browser/session.d.ts +18 -7
  8. package/esm/auth/browser/session.d.ts.map +1 -1
  9. package/esm/auth/browser/session.js +47 -11
  10. package/esm/auth/browser/storage.d.ts +6 -1
  11. package/esm/auth/browser/storage.d.ts.map +1 -1
  12. package/esm/auth/browser/storage.js +15 -3
  13. package/esm/auth/browser.d.ts +2 -2
  14. package/esm/auth/browser.d.ts.map +1 -1
  15. package/esm/auth/browser.js +1 -1
  16. package/esm/auth/device_activation.d.ts +36 -33
  17. package/esm/auth/device_activation.d.ts.map +1 -1
  18. package/esm/auth/device_activation.js +26 -22
  19. package/esm/auth/mod.d.ts +4 -4
  20. package/esm/auth/mod.d.ts.map +1 -1
  21. package/esm/auth/mod.js +2 -2
  22. package/esm/auth/proof.d.ts +3 -1
  23. package/esm/auth/proof.d.ts.map +1 -1
  24. package/esm/auth/proof.js +21 -15
  25. package/esm/auth/protocol.d.ts +2457 -941
  26. package/esm/auth/protocol.d.ts.map +1 -1
  27. package/esm/auth/protocol.js +747 -375
  28. package/esm/auth/schemas.d.ts +25 -4
  29. package/esm/auth/schemas.d.ts.map +1 -1
  30. package/esm/auth/schemas.js +14 -4
  31. package/esm/auth/session_auth.d.ts +1 -1
  32. package/esm/auth/session_auth.d.ts.map +1 -1
  33. package/esm/auth/session_auth.js +7 -1
  34. package/esm/client_connect.d.ts +2 -0
  35. package/esm/client_connect.d.ts.map +1 -1
  36. package/esm/client_connect.js +76 -15
  37. package/esm/contract.d.ts +3 -0
  38. package/esm/contract.d.ts.map +1 -1
  39. package/esm/contract_support/mod.d.ts +422 -43
  40. package/esm/contract_support/mod.d.ts.map +1 -1
  41. package/esm/contract_support/mod.js +734 -33
  42. package/esm/contract_support/protocol.d.ts +20 -5
  43. package/esm/contract_support/protocol.d.ts.map +1 -1
  44. package/esm/contract_support/protocol.js +18 -10
  45. package/esm/contract_support/runtime.d.ts +11 -0
  46. package/esm/contract_support/runtime.d.ts.map +1 -1
  47. package/esm/contract_support/schema_pointers.d.ts.map +1 -1
  48. package/esm/contract_support/schema_pointers.js +32 -14
  49. package/esm/device.d.ts +2 -0
  50. package/esm/device.d.ts.map +1 -1
  51. package/esm/device.js +3 -0
  52. package/esm/errors/AuthError.d.ts +2 -1
  53. package/esm/errors/AuthError.d.ts.map +1 -1
  54. package/esm/errors/AuthError.js +8 -3
  55. package/esm/errors/index.d.ts +4 -4
  56. package/esm/errors/index.d.ts.map +1 -1
  57. package/esm/errors/index.js +1 -0
  58. package/esm/generated-sdk/auth/api.d.ts +27 -9
  59. package/esm/generated-sdk/auth/api.d.ts.map +1 -1
  60. package/esm/generated-sdk/auth/api.js +16 -590
  61. package/esm/generated-sdk/auth/client.d.ts +91 -85
  62. package/esm/generated-sdk/auth/client.d.ts.map +1 -1
  63. package/esm/generated-sdk/auth/contract.d.ts +1 -1
  64. package/esm/generated-sdk/auth/contract.d.ts.map +1 -1
  65. package/esm/generated-sdk/auth/contract.js +4 -2
  66. package/esm/generated-sdk/auth/mod.d.ts +1 -0
  67. package/esm/generated-sdk/auth/mod.d.ts.map +1 -1
  68. package/esm/generated-sdk/auth/owned_api.d.ts +3 -0
  69. package/esm/generated-sdk/auth/owned_api.d.ts.map +1 -0
  70. package/esm/generated-sdk/auth/owned_api.js +594 -0
  71. package/esm/generated-sdk/auth/schemas.d.ts +9959 -5160
  72. package/esm/generated-sdk/auth/schemas.d.ts.map +1 -1
  73. package/esm/generated-sdk/auth/schemas.js +136 -137
  74. package/esm/generated-sdk/auth/types.d.ts +2418 -1557
  75. package/esm/generated-sdk/auth/types.d.ts.map +1 -1
  76. package/esm/generated-sdk/auth/types.js +1 -1
  77. package/esm/generated-sdk/health/api.d.ts +24 -9
  78. package/esm/generated-sdk/health/api.d.ts.map +1 -1
  79. package/esm/generated-sdk/health/api.js +12 -20
  80. package/esm/generated-sdk/health/client.d.ts +2 -1
  81. package/esm/generated-sdk/health/client.d.ts.map +1 -1
  82. package/esm/generated-sdk/health/contract.d.ts.map +1 -1
  83. package/esm/generated-sdk/health/contract.js +2 -0
  84. package/esm/generated-sdk/health/owned_api.d.ts +3 -0
  85. package/esm/generated-sdk/health/owned_api.d.ts.map +1 -0
  86. package/esm/generated-sdk/health/owned_api.js +16 -0
  87. package/esm/generated-sdk/health/types.d.ts +2 -0
  88. package/esm/generated-sdk/health/types.d.ts.map +1 -1
  89. package/esm/generated-sdk/jobs/api.d.ts +33 -9
  90. package/esm/generated-sdk/jobs/api.d.ts.map +1 -1
  91. package/esm/generated-sdk/jobs/api.js +22 -87
  92. package/esm/generated-sdk/jobs/client.d.ts +9 -2
  93. package/esm/generated-sdk/jobs/client.d.ts.map +1 -1
  94. package/esm/generated-sdk/jobs/contract.d.ts +1 -1
  95. package/esm/generated-sdk/jobs/contract.d.ts.map +1 -1
  96. package/esm/generated-sdk/jobs/contract.js +4 -2
  97. package/esm/generated-sdk/jobs/owned_api.d.ts +3 -0
  98. package/esm/generated-sdk/jobs/owned_api.d.ts.map +1 -0
  99. package/esm/generated-sdk/jobs/owned_api.js +118 -0
  100. package/esm/generated-sdk/jobs/schemas.d.ts +336 -123
  101. package/esm/generated-sdk/jobs/schemas.d.ts.map +1 -1
  102. package/esm/generated-sdk/jobs/schemas.js +17 -15
  103. package/esm/generated-sdk/jobs/types.d.ts +144 -34
  104. package/esm/generated-sdk/jobs/types.d.ts.map +1 -1
  105. package/esm/generated-sdk/jobs/types.js +36 -1
  106. package/esm/generated-sdk/state/api.d.ts +27 -9
  107. package/esm/generated-sdk/state/api.d.ts.map +1 -1
  108. package/esm/generated-sdk/state/api.js +16 -71
  109. package/esm/generated-sdk/state/client.d.ts +4 -2
  110. package/esm/generated-sdk/state/client.d.ts.map +1 -1
  111. package/esm/generated-sdk/state/contract.d.ts +1 -1
  112. package/esm/generated-sdk/state/contract.d.ts.map +1 -1
  113. package/esm/generated-sdk/state/contract.js +4 -2
  114. package/esm/generated-sdk/state/owned_api.d.ts +3 -0
  115. package/esm/generated-sdk/state/owned_api.d.ts.map +1 -0
  116. package/esm/generated-sdk/state/owned_api.js +66 -0
  117. package/esm/generated-sdk/state/schemas.d.ts +264 -284
  118. package/esm/generated-sdk/state/schemas.d.ts.map +1 -1
  119. package/esm/generated-sdk/state/schemas.js +6 -6
  120. package/esm/generated-sdk/state/types.d.ts +24 -23
  121. package/esm/generated-sdk/state/types.d.ts.map +1 -1
  122. package/esm/generated-sdk/state/types.js +1 -1
  123. package/esm/generated-sdk/trellis-core/api.d.ts +27 -9
  124. package/esm/generated-sdk/trellis-core/api.d.ts.map +1 -1
  125. package/esm/generated-sdk/trellis-core/api.js +16 -39
  126. package/esm/generated-sdk/trellis-core/client.d.ts +5 -2
  127. package/esm/generated-sdk/trellis-core/client.d.ts.map +1 -1
  128. package/esm/generated-sdk/trellis-core/contract.d.ts +1 -1
  129. package/esm/generated-sdk/trellis-core/contract.d.ts.map +1 -1
  130. package/esm/generated-sdk/trellis-core/contract.js +4 -2
  131. package/esm/generated-sdk/trellis-core/owned_api.d.ts +3 -0
  132. package/esm/generated-sdk/trellis-core/owned_api.d.ts.map +1 -0
  133. package/esm/generated-sdk/trellis-core/owned_api.js +42 -0
  134. package/esm/generated-sdk/trellis-core/schemas.d.ts +259 -11
  135. package/esm/generated-sdk/trellis-core/schemas.d.ts.map +1 -1
  136. package/esm/generated-sdk/trellis-core/schemas.js +5 -3
  137. package/esm/generated-sdk/trellis-core/types.d.ts +56 -1
  138. package/esm/generated-sdk/trellis-core/types.d.ts.map +1 -1
  139. package/esm/generated-sdk/trellis-core/types.js +1 -1
  140. package/esm/helpers.d.ts.map +1 -1
  141. package/esm/index.d.ts +4 -3
  142. package/esm/index.d.ts.map +1 -1
  143. package/esm/index.js +1 -0
  144. package/esm/jobs.d.ts +10 -1
  145. package/esm/jobs.d.ts.map +1 -1
  146. package/esm/jobs.js +16 -1
  147. package/esm/kv.d.ts.map +1 -1
  148. package/esm/kv.js +10 -4
  149. package/esm/models/auth/rpc/Logout.d.ts +4 -4
  150. package/esm/models/auth/rpc/Logout.d.ts.map +1 -1
  151. package/esm/models/auth/rpc/Logout.js +2 -2
  152. package/esm/models/trellis/Page.d.ts +2 -0
  153. package/esm/models/trellis/Page.d.ts.map +1 -0
  154. package/esm/models/trellis/Page.js +1 -0
  155. package/esm/models/trellis/State.d.ts +1 -0
  156. package/esm/models/trellis/State.d.ts.map +1 -1
  157. package/esm/models/trellis/State.js +1 -0
  158. package/esm/models/trellis/rpc/StateList.d.ts +9 -12
  159. package/esm/models/trellis/rpc/StateList.d.ts.map +1 -1
  160. package/esm/models/trellis/rpc/StateList.js +16 -18
  161. package/esm/npm/src/auth/browser/login.d.ts.map +1 -1
  162. package/esm/npm/src/auth/browser/login.js +46 -3
  163. package/esm/npm/src/auth/browser/portal.d.ts.map +1 -1
  164. package/esm/npm/src/auth/browser/portal.js +5 -1
  165. package/esm/npm/src/auth/browser/session.d.ts +18 -7
  166. package/esm/npm/src/auth/browser/session.d.ts.map +1 -1
  167. package/esm/npm/src/auth/browser/session.js +47 -11
  168. package/esm/npm/src/auth/browser/storage.d.ts +6 -1
  169. package/esm/npm/src/auth/browser/storage.d.ts.map +1 -1
  170. package/esm/npm/src/auth/browser/storage.js +15 -3
  171. package/esm/npm/src/auth/browser.d.ts +2 -2
  172. package/esm/npm/src/auth/browser.d.ts.map +1 -1
  173. package/esm/npm/src/auth/browser.js +1 -1
  174. package/esm/npm/src/auth/device_activation.d.ts +36 -33
  175. package/esm/npm/src/auth/device_activation.d.ts.map +1 -1
  176. package/esm/npm/src/auth/device_activation.js +26 -22
  177. package/esm/npm/src/auth/mod.d.ts +4 -4
  178. package/esm/npm/src/auth/mod.d.ts.map +1 -1
  179. package/esm/npm/src/auth/mod.js +2 -2
  180. package/esm/npm/src/auth/proof.d.ts +3 -1
  181. package/esm/npm/src/auth/proof.d.ts.map +1 -1
  182. package/esm/npm/src/auth/proof.js +21 -15
  183. package/esm/npm/src/auth/protocol.d.ts +2457 -941
  184. package/esm/npm/src/auth/protocol.d.ts.map +1 -1
  185. package/esm/npm/src/auth/protocol.js +747 -375
  186. package/esm/npm/src/auth/schemas.d.ts +25 -4
  187. package/esm/npm/src/auth/schemas.d.ts.map +1 -1
  188. package/esm/npm/src/auth/schemas.js +14 -4
  189. package/esm/npm/src/auth/session_auth.d.ts +1 -1
  190. package/esm/npm/src/auth/session_auth.d.ts.map +1 -1
  191. package/esm/npm/src/auth/session_auth.js +7 -1
  192. package/esm/npm/src/client_connect.d.ts +2 -0
  193. package/esm/npm/src/client_connect.d.ts.map +1 -1
  194. package/esm/npm/src/client_connect.js +76 -15
  195. package/esm/npm/src/contract.d.ts +3 -0
  196. package/esm/npm/src/contract.d.ts.map +1 -1
  197. package/esm/npm/src/contract_support/mod.d.ts +422 -43
  198. package/esm/npm/src/contract_support/mod.d.ts.map +1 -1
  199. package/esm/npm/src/contract_support/mod.js +734 -33
  200. package/esm/npm/src/contract_support/protocol.d.ts +20 -5
  201. package/esm/npm/src/contract_support/protocol.d.ts.map +1 -1
  202. package/esm/npm/src/contract_support/protocol.js +18 -10
  203. package/esm/npm/src/contract_support/runtime.d.ts +11 -0
  204. package/esm/npm/src/contract_support/runtime.d.ts.map +1 -1
  205. package/esm/npm/src/contract_support/schema_pointers.d.ts.map +1 -1
  206. package/esm/npm/src/contract_support/schema_pointers.js +32 -14
  207. package/esm/npm/src/device/deno.d.ts.map +1 -1
  208. package/esm/npm/src/device/deno.js +6 -0
  209. package/esm/npm/src/device.d.ts +2 -0
  210. package/esm/npm/src/device.d.ts.map +1 -1
  211. package/esm/npm/src/device.js +3 -0
  212. package/esm/npm/src/errors/AuthError.d.ts +2 -1
  213. package/esm/npm/src/errors/AuthError.d.ts.map +1 -1
  214. package/esm/npm/src/errors/AuthError.js +8 -3
  215. package/esm/npm/src/errors/index.d.ts +4 -4
  216. package/esm/npm/src/errors/index.d.ts.map +1 -1
  217. package/esm/npm/src/errors/index.js +1 -0
  218. package/esm/npm/src/generate.js +39 -26
  219. package/esm/npm/src/helpers.d.ts.map +1 -1
  220. package/esm/npm/src/index.d.ts +4 -3
  221. package/esm/npm/src/index.d.ts.map +1 -1
  222. package/esm/npm/src/index.js +1 -0
  223. package/esm/npm/src/jobs.d.ts +10 -1
  224. package/esm/npm/src/jobs.d.ts.map +1 -1
  225. package/esm/npm/src/jobs.js +16 -1
  226. package/esm/npm/src/kv.d.ts.map +1 -1
  227. package/esm/npm/src/kv.js +10 -4
  228. package/esm/npm/src/models/auth/rpc/Logout.d.ts +4 -4
  229. package/esm/npm/src/models/auth/rpc/Logout.d.ts.map +1 -1
  230. package/esm/npm/src/models/auth/rpc/Logout.js +2 -2
  231. package/esm/npm/src/models/trellis/Page.d.ts +2 -0
  232. package/esm/npm/src/models/trellis/Page.d.ts.map +1 -0
  233. package/esm/npm/src/models/trellis/Page.js +1 -0
  234. package/esm/npm/src/models/trellis/State.d.ts +1 -0
  235. package/esm/npm/src/models/trellis/State.d.ts.map +1 -1
  236. package/esm/npm/src/models/trellis/State.js +1 -0
  237. package/esm/npm/src/models/trellis/rpc/StateList.d.ts +9 -12
  238. package/esm/npm/src/models/trellis/rpc/StateList.d.ts.map +1 -1
  239. package/esm/npm/src/models/trellis/rpc/StateList.js +16 -18
  240. package/esm/npm/src/operations.d.ts +16 -7
  241. package/esm/npm/src/operations.d.ts.map +1 -1
  242. package/esm/npm/src/operations.js +84 -19
  243. package/esm/npm/src/runtime_transport.d.ts +2 -0
  244. package/esm/npm/src/runtime_transport.d.ts.map +1 -1
  245. package/esm/npm/src/runtime_transport.js +1 -0
  246. package/esm/npm/src/server/internal_jobs/active-job.d.ts +2 -1
  247. package/esm/npm/src/server/internal_jobs/active-job.d.ts.map +1 -1
  248. package/esm/npm/src/server/internal_jobs/active-job.js +3 -0
  249. package/esm/npm/src/server/internal_jobs/job-manager.d.ts +4 -1
  250. package/esm/npm/src/server/internal_jobs/job-manager.d.ts.map +1 -1
  251. package/esm/npm/src/server/internal_jobs/job-manager.js +61 -1
  252. package/esm/npm/src/server/internal_jobs/projection.js +1 -0
  253. package/esm/npm/src/server/internal_jobs/runtime-worker.d.ts +13 -1
  254. package/esm/npm/src/server/internal_jobs/runtime-worker.d.ts.map +1 -1
  255. package/esm/npm/src/server/internal_jobs/runtime-worker.js +73 -13
  256. package/esm/npm/src/server/internal_jobs/types.d.ts +19 -0
  257. package/esm/npm/src/server/internal_jobs/types.d.ts.map +1 -1
  258. package/esm/npm/src/server/internal_jobs/types.js +10 -0
  259. package/esm/npm/src/server/runtime.d.ts +1 -0
  260. package/esm/npm/src/server/runtime.d.ts.map +1 -1
  261. package/esm/npm/src/server/service.d.ts +10 -1
  262. package/esm/npm/src/server/service.d.ts.map +1 -1
  263. package/esm/npm/src/server/service.js +210 -64
  264. package/esm/npm/src/server/transfer.d.ts.map +1 -1
  265. package/esm/npm/src/server/transfer.js +4 -0
  266. package/esm/npm/src/server.d.ts.map +1 -1
  267. package/esm/npm/src/server.js +337 -34
  268. package/esm/npm/src/store.d.ts +8 -1
  269. package/esm/npm/src/store.d.ts.map +1 -1
  270. package/esm/npm/src/store.js +46 -8
  271. package/esm/npm/src/transfer.d.ts +3 -0
  272. package/esm/npm/src/transfer.d.ts.map +1 -1
  273. package/esm/npm/src/transfer.js +20 -30
  274. package/esm/npm/src/trellis.d.ts +85 -22
  275. package/esm/npm/src/trellis.d.ts.map +1 -1
  276. package/esm/npm/src/trellis.js +525 -61
  277. package/esm/operations.d.ts +16 -7
  278. package/esm/operations.d.ts.map +1 -1
  279. package/esm/operations.js +84 -19
  280. package/esm/runtime_transport.d.ts +2 -0
  281. package/esm/runtime_transport.d.ts.map +1 -1
  282. package/esm/runtime_transport.js +1 -0
  283. package/esm/store.d.ts +8 -1
  284. package/esm/store.d.ts.map +1 -1
  285. package/esm/store.js +46 -8
  286. package/esm/transfer.d.ts +3 -0
  287. package/esm/transfer.d.ts.map +1 -1
  288. package/esm/transfer.js +20 -30
  289. package/esm/trellis.d.ts +85 -22
  290. package/esm/trellis.d.ts.map +1 -1
  291. package/esm/trellis.js +525 -61
  292. package/package.json +6 -3
  293. package/script/auth/browser/login.d.ts.map +1 -1
  294. package/script/auth/browser/login.js +46 -3
  295. package/script/auth/browser/portal.d.ts.map +1 -1
  296. package/script/auth/browser/portal.js +5 -1
  297. package/script/auth/browser/session.d.ts +18 -7
  298. package/script/auth/browser/session.d.ts.map +1 -1
  299. package/script/auth/browser/session.js +47 -11
  300. package/script/auth/browser/storage.d.ts +6 -1
  301. package/script/auth/browser/storage.d.ts.map +1 -1
  302. package/script/auth/browser/storage.js +15 -3
  303. package/script/auth/browser.d.ts +2 -2
  304. package/script/auth/browser.d.ts.map +1 -1
  305. package/script/auth/browser.js +2 -1
  306. package/script/auth/device_activation.d.ts +36 -33
  307. package/script/auth/device_activation.d.ts.map +1 -1
  308. package/script/auth/device_activation.js +25 -21
  309. package/script/auth/mod.d.ts +4 -4
  310. package/script/auth/mod.d.ts.map +1 -1
  311. package/script/auth/mod.js +132 -137
  312. package/script/auth/proof.d.ts +3 -1
  313. package/script/auth/proof.d.ts.map +1 -1
  314. package/script/auth/proof.js +21 -15
  315. package/script/auth/protocol.d.ts +2457 -941
  316. package/script/auth/protocol.d.ts.map +1 -1
  317. package/script/auth/protocol.js +749 -377
  318. package/script/auth/schemas.d.ts +25 -4
  319. package/script/auth/schemas.d.ts.map +1 -1
  320. package/script/auth/schemas.js +16 -5
  321. package/script/auth/session_auth.d.ts +1 -1
  322. package/script/auth/session_auth.d.ts.map +1 -1
  323. package/script/auth/session_auth.js +7 -1
  324. package/script/client_connect.d.ts +2 -0
  325. package/script/client_connect.d.ts.map +1 -1
  326. package/script/client_connect.js +76 -15
  327. package/script/contract.d.ts +3 -0
  328. package/script/contract.d.ts.map +1 -1
  329. package/script/contract_support/mod.d.ts +422 -43
  330. package/script/contract_support/mod.d.ts.map +1 -1
  331. package/script/contract_support/mod.js +757 -51
  332. package/script/contract_support/protocol.d.ts +20 -5
  333. package/script/contract_support/protocol.d.ts.map +1 -1
  334. package/script/contract_support/protocol.js +20 -11
  335. package/script/contract_support/runtime.d.ts +11 -0
  336. package/script/contract_support/runtime.d.ts.map +1 -1
  337. package/script/contract_support/schema_pointers.d.ts.map +1 -1
  338. package/script/contract_support/schema_pointers.js +32 -14
  339. package/script/device.d.ts +2 -0
  340. package/script/device.d.ts.map +1 -1
  341. package/script/device.js +3 -0
  342. package/script/errors/AuthError.d.ts +2 -1
  343. package/script/errors/AuthError.d.ts.map +1 -1
  344. package/script/errors/AuthError.js +8 -3
  345. package/script/errors/index.d.ts +4 -4
  346. package/script/errors/index.d.ts.map +1 -1
  347. package/script/errors/index.js +1 -0
  348. package/script/generated-sdk/auth/api.d.ts +27 -9
  349. package/script/generated-sdk/auth/api.d.ts.map +1 -1
  350. package/script/generated-sdk/auth/api.js +17 -591
  351. package/script/generated-sdk/auth/client.d.ts +91 -85
  352. package/script/generated-sdk/auth/client.d.ts.map +1 -1
  353. package/script/generated-sdk/auth/contract.d.ts +1 -1
  354. package/script/generated-sdk/auth/contract.d.ts.map +1 -1
  355. package/script/generated-sdk/auth/contract.js +4 -2
  356. package/script/generated-sdk/auth/mod.d.ts +1 -0
  357. package/script/generated-sdk/auth/mod.d.ts.map +1 -1
  358. package/script/generated-sdk/auth/owned_api.d.ts +3 -0
  359. package/script/generated-sdk/auth/owned_api.d.ts.map +1 -0
  360. package/script/generated-sdk/auth/owned_api.js +597 -0
  361. package/script/generated-sdk/auth/schemas.d.ts +9959 -5160
  362. package/script/generated-sdk/auth/schemas.d.ts.map +1 -1
  363. package/script/generated-sdk/auth/schemas.js +139 -140
  364. package/script/generated-sdk/auth/types.d.ts +2418 -1557
  365. package/script/generated-sdk/auth/types.d.ts.map +1 -1
  366. package/script/generated-sdk/auth/types.js +1 -1
  367. package/script/generated-sdk/health/api.d.ts +24 -9
  368. package/script/generated-sdk/health/api.d.ts.map +1 -1
  369. package/script/generated-sdk/health/api.js +13 -21
  370. package/script/generated-sdk/health/client.d.ts +2 -1
  371. package/script/generated-sdk/health/client.d.ts.map +1 -1
  372. package/script/generated-sdk/health/contract.d.ts.map +1 -1
  373. package/script/generated-sdk/health/contract.js +2 -0
  374. package/script/generated-sdk/health/owned_api.d.ts +3 -0
  375. package/script/generated-sdk/health/owned_api.d.ts.map +1 -0
  376. package/script/generated-sdk/health/owned_api.js +19 -0
  377. package/script/generated-sdk/health/types.d.ts +2 -0
  378. package/script/generated-sdk/health/types.d.ts.map +1 -1
  379. package/script/generated-sdk/jobs/api.d.ts +33 -9
  380. package/script/generated-sdk/jobs/api.d.ts.map +1 -1
  381. package/script/generated-sdk/jobs/api.js +23 -88
  382. package/script/generated-sdk/jobs/client.d.ts +9 -2
  383. package/script/generated-sdk/jobs/client.d.ts.map +1 -1
  384. package/script/generated-sdk/jobs/contract.d.ts +1 -1
  385. package/script/generated-sdk/jobs/contract.d.ts.map +1 -1
  386. package/script/generated-sdk/jobs/contract.js +4 -2
  387. package/script/generated-sdk/jobs/owned_api.d.ts +3 -0
  388. package/script/generated-sdk/jobs/owned_api.d.ts.map +1 -0
  389. package/script/generated-sdk/jobs/owned_api.js +154 -0
  390. package/script/generated-sdk/jobs/schemas.d.ts +336 -123
  391. package/script/generated-sdk/jobs/schemas.d.ts.map +1 -1
  392. package/script/generated-sdk/jobs/schemas.js +18 -16
  393. package/script/generated-sdk/jobs/types.d.ts +144 -34
  394. package/script/generated-sdk/jobs/types.d.ts.map +1 -1
  395. package/script/generated-sdk/jobs/types.js +38 -2
  396. package/script/generated-sdk/state/api.d.ts +27 -9
  397. package/script/generated-sdk/state/api.d.ts.map +1 -1
  398. package/script/generated-sdk/state/api.js +17 -72
  399. package/script/generated-sdk/state/client.d.ts +4 -2
  400. package/script/generated-sdk/state/client.d.ts.map +1 -1
  401. package/script/generated-sdk/state/contract.d.ts +1 -1
  402. package/script/generated-sdk/state/contract.d.ts.map +1 -1
  403. package/script/generated-sdk/state/contract.js +4 -2
  404. package/script/generated-sdk/state/owned_api.d.ts +3 -0
  405. package/script/generated-sdk/state/owned_api.d.ts.map +1 -0
  406. package/script/generated-sdk/state/owned_api.js +69 -0
  407. package/script/generated-sdk/state/schemas.d.ts +264 -284
  408. package/script/generated-sdk/state/schemas.d.ts.map +1 -1
  409. package/script/generated-sdk/state/schemas.js +6 -6
  410. package/script/generated-sdk/state/types.d.ts +24 -23
  411. package/script/generated-sdk/state/types.d.ts.map +1 -1
  412. package/script/generated-sdk/state/types.js +1 -1
  413. package/script/generated-sdk/trellis-core/api.d.ts +27 -9
  414. package/script/generated-sdk/trellis-core/api.d.ts.map +1 -1
  415. package/script/generated-sdk/trellis-core/api.js +17 -40
  416. package/script/generated-sdk/trellis-core/client.d.ts +5 -2
  417. package/script/generated-sdk/trellis-core/client.d.ts.map +1 -1
  418. package/script/generated-sdk/trellis-core/contract.d.ts +1 -1
  419. package/script/generated-sdk/trellis-core/contract.d.ts.map +1 -1
  420. package/script/generated-sdk/trellis-core/contract.js +4 -2
  421. package/script/generated-sdk/trellis-core/owned_api.d.ts +3 -0
  422. package/script/generated-sdk/trellis-core/owned_api.d.ts.map +1 -0
  423. package/script/generated-sdk/trellis-core/owned_api.js +45 -0
  424. package/script/generated-sdk/trellis-core/schemas.d.ts +259 -11
  425. package/script/generated-sdk/trellis-core/schemas.d.ts.map +1 -1
  426. package/script/generated-sdk/trellis-core/schemas.js +6 -4
  427. package/script/generated-sdk/trellis-core/types.d.ts +56 -1
  428. package/script/generated-sdk/trellis-core/types.d.ts.map +1 -1
  429. package/script/generated-sdk/trellis-core/types.js +1 -1
  430. package/script/helpers.d.ts.map +1 -1
  431. package/script/index.d.ts +4 -3
  432. package/script/index.d.ts.map +1 -1
  433. package/script/index.js +5 -2
  434. package/script/jobs.d.ts +10 -1
  435. package/script/jobs.d.ts.map +1 -1
  436. package/script/jobs.js +17 -2
  437. package/script/kv.d.ts.map +1 -1
  438. package/script/kv.js +10 -4
  439. package/script/models/auth/rpc/Logout.d.ts +4 -4
  440. package/script/models/auth/rpc/Logout.d.ts.map +1 -1
  441. package/script/models/auth/rpc/Logout.js +3 -3
  442. package/script/models/trellis/Page.d.ts +2 -0
  443. package/script/models/trellis/Page.d.ts.map +1 -0
  444. package/script/models/trellis/Page.js +6 -0
  445. package/script/models/trellis/State.d.ts +1 -0
  446. package/script/models/trellis/State.d.ts.map +1 -1
  447. package/script/models/trellis/State.js +1 -0
  448. package/script/models/trellis/rpc/StateList.d.ts +9 -12
  449. package/script/models/trellis/rpc/StateList.d.ts.map +1 -1
  450. package/script/models/trellis/rpc/StateList.js +16 -18
  451. package/script/npm/src/auth/browser/login.d.ts.map +1 -1
  452. package/script/npm/src/auth/browser/login.js +46 -3
  453. package/script/npm/src/auth/browser/portal.d.ts.map +1 -1
  454. package/script/npm/src/auth/browser/portal.js +5 -1
  455. package/script/npm/src/auth/browser/session.d.ts +18 -7
  456. package/script/npm/src/auth/browser/session.d.ts.map +1 -1
  457. package/script/npm/src/auth/browser/session.js +47 -11
  458. package/script/npm/src/auth/browser/storage.d.ts +6 -1
  459. package/script/npm/src/auth/browser/storage.d.ts.map +1 -1
  460. package/script/npm/src/auth/browser/storage.js +15 -3
  461. package/script/npm/src/auth/browser.d.ts +2 -2
  462. package/script/npm/src/auth/browser.d.ts.map +1 -1
  463. package/script/npm/src/auth/browser.js +2 -1
  464. package/script/npm/src/auth/device_activation.d.ts +36 -33
  465. package/script/npm/src/auth/device_activation.d.ts.map +1 -1
  466. package/script/npm/src/auth/device_activation.js +25 -21
  467. package/script/npm/src/auth/mod.d.ts +4 -4
  468. package/script/npm/src/auth/mod.d.ts.map +1 -1
  469. package/script/npm/src/auth/mod.js +132 -137
  470. package/script/npm/src/auth/proof.d.ts +3 -1
  471. package/script/npm/src/auth/proof.d.ts.map +1 -1
  472. package/script/npm/src/auth/proof.js +21 -15
  473. package/script/npm/src/auth/protocol.d.ts +2457 -941
  474. package/script/npm/src/auth/protocol.d.ts.map +1 -1
  475. package/script/npm/src/auth/protocol.js +749 -377
  476. package/script/npm/src/auth/schemas.d.ts +25 -4
  477. package/script/npm/src/auth/schemas.d.ts.map +1 -1
  478. package/script/npm/src/auth/schemas.js +16 -5
  479. package/script/npm/src/auth/session_auth.d.ts +1 -1
  480. package/script/npm/src/auth/session_auth.d.ts.map +1 -1
  481. package/script/npm/src/auth/session_auth.js +7 -1
  482. package/script/npm/src/client_connect.d.ts +2 -0
  483. package/script/npm/src/client_connect.d.ts.map +1 -1
  484. package/script/npm/src/client_connect.js +76 -15
  485. package/script/npm/src/contract.d.ts +3 -0
  486. package/script/npm/src/contract.d.ts.map +1 -1
  487. package/script/npm/src/contract_support/mod.d.ts +422 -43
  488. package/script/npm/src/contract_support/mod.d.ts.map +1 -1
  489. package/script/npm/src/contract_support/mod.js +757 -51
  490. package/script/npm/src/contract_support/protocol.d.ts +20 -5
  491. package/script/npm/src/contract_support/protocol.d.ts.map +1 -1
  492. package/script/npm/src/contract_support/protocol.js +20 -11
  493. package/script/npm/src/contract_support/runtime.d.ts +11 -0
  494. package/script/npm/src/contract_support/runtime.d.ts.map +1 -1
  495. package/script/npm/src/contract_support/schema_pointers.d.ts.map +1 -1
  496. package/script/npm/src/contract_support/schema_pointers.js +32 -14
  497. package/script/npm/src/device/deno.d.ts.map +1 -1
  498. package/script/npm/src/device/deno.js +6 -0
  499. package/script/npm/src/device.d.ts +2 -0
  500. package/script/npm/src/device.d.ts.map +1 -1
  501. package/script/npm/src/device.js +3 -0
  502. package/script/npm/src/errors/AuthError.d.ts +2 -1
  503. package/script/npm/src/errors/AuthError.d.ts.map +1 -1
  504. package/script/npm/src/errors/AuthError.js +8 -3
  505. package/script/npm/src/errors/index.d.ts +4 -4
  506. package/script/npm/src/errors/index.d.ts.map +1 -1
  507. package/script/npm/src/errors/index.js +1 -0
  508. package/script/npm/src/generate.js +39 -59
  509. package/script/npm/src/helpers.d.ts.map +1 -1
  510. package/script/npm/src/index.d.ts +4 -3
  511. package/script/npm/src/index.d.ts.map +1 -1
  512. package/script/npm/src/index.js +5 -2
  513. package/script/npm/src/jobs.d.ts +10 -1
  514. package/script/npm/src/jobs.d.ts.map +1 -1
  515. package/script/npm/src/jobs.js +17 -2
  516. package/script/npm/src/kv.d.ts.map +1 -1
  517. package/script/npm/src/kv.js +10 -4
  518. package/script/npm/src/models/auth/rpc/Logout.d.ts +4 -4
  519. package/script/npm/src/models/auth/rpc/Logout.d.ts.map +1 -1
  520. package/script/npm/src/models/auth/rpc/Logout.js +3 -3
  521. package/script/npm/src/models/trellis/Page.d.ts +2 -0
  522. package/script/npm/src/models/trellis/Page.d.ts.map +1 -0
  523. package/script/npm/src/models/trellis/Page.js +6 -0
  524. package/script/npm/src/models/trellis/State.d.ts +1 -0
  525. package/script/npm/src/models/trellis/State.d.ts.map +1 -1
  526. package/script/npm/src/models/trellis/State.js +1 -0
  527. package/script/npm/src/models/trellis/rpc/StateList.d.ts +9 -12
  528. package/script/npm/src/models/trellis/rpc/StateList.d.ts.map +1 -1
  529. package/script/npm/src/models/trellis/rpc/StateList.js +16 -18
  530. package/script/npm/src/operations.d.ts +16 -7
  531. package/script/npm/src/operations.d.ts.map +1 -1
  532. package/script/npm/src/operations.js +84 -19
  533. package/script/npm/src/runtime_transport.d.ts +2 -0
  534. package/script/npm/src/runtime_transport.d.ts.map +1 -1
  535. package/script/npm/src/runtime_transport.js +2 -1
  536. package/script/npm/src/server/internal_jobs/active-job.d.ts +2 -1
  537. package/script/npm/src/server/internal_jobs/active-job.d.ts.map +1 -1
  538. package/script/npm/src/server/internal_jobs/active-job.js +3 -0
  539. package/script/npm/src/server/internal_jobs/job-manager.d.ts +4 -1
  540. package/script/npm/src/server/internal_jobs/job-manager.d.ts.map +1 -1
  541. package/script/npm/src/server/internal_jobs/job-manager.js +61 -1
  542. package/script/npm/src/server/internal_jobs/projection.js +1 -0
  543. package/script/npm/src/server/internal_jobs/runtime-worker.d.ts +13 -1
  544. package/script/npm/src/server/internal_jobs/runtime-worker.d.ts.map +1 -1
  545. package/script/npm/src/server/internal_jobs/runtime-worker.js +74 -13
  546. package/script/npm/src/server/internal_jobs/types.d.ts +19 -0
  547. package/script/npm/src/server/internal_jobs/types.d.ts.map +1 -1
  548. package/script/npm/src/server/internal_jobs/types.js +11 -1
  549. package/script/npm/src/server/runtime.d.ts +1 -0
  550. package/script/npm/src/server/runtime.d.ts.map +1 -1
  551. package/script/npm/src/server/service.d.ts +10 -1
  552. package/script/npm/src/server/service.d.ts.map +1 -1
  553. package/script/npm/src/server/service.js +208 -62
  554. package/script/npm/src/server/transfer.d.ts.map +1 -1
  555. package/script/npm/src/server/transfer.js +4 -0
  556. package/script/npm/src/server.d.ts.map +1 -1
  557. package/script/npm/src/server.js +336 -33
  558. package/script/npm/src/store.d.ts +8 -1
  559. package/script/npm/src/store.d.ts.map +1 -1
  560. package/script/npm/src/store.js +46 -8
  561. package/script/npm/src/transfer.d.ts +3 -0
  562. package/script/npm/src/transfer.d.ts.map +1 -1
  563. package/script/npm/src/transfer.js +19 -29
  564. package/script/npm/src/trellis.d.ts +85 -22
  565. package/script/npm/src/trellis.d.ts.map +1 -1
  566. package/script/npm/src/trellis.js +525 -61
  567. package/script/operations.d.ts +16 -7
  568. package/script/operations.d.ts.map +1 -1
  569. package/script/operations.js +84 -19
  570. package/script/runtime_transport.d.ts +2 -0
  571. package/script/runtime_transport.d.ts.map +1 -1
  572. package/script/runtime_transport.js +2 -1
  573. package/script/store.d.ts +8 -1
  574. package/script/store.d.ts.map +1 -1
  575. package/script/store.js +46 -8
  576. package/script/transfer.d.ts +3 -0
  577. package/script/transfer.d.ts.map +1 -1
  578. package/script/transfer.js +19 -29
  579. package/script/trellis.d.ts +85 -22
  580. package/script/trellis.d.ts.map +1 -1
  581. package/script/trellis.js +525 -61
  582. package/src/_dnt.polyfills.ts +274 -0
  583. package/src/_dnt.shims.ts +64 -0
  584. package/src/auth/browser/login.ts +295 -0
  585. package/src/auth/browser/portal.ts +75 -0
  586. package/src/auth/browser/session.ts +197 -0
  587. package/src/auth/browser/storage.ts +105 -0
  588. package/src/auth/browser.ts +82 -0
  589. package/src/auth/device_activation.ts +715 -0
  590. package/src/auth/keys.ts +116 -0
  591. package/src/auth/mod.ts +298 -0
  592. package/src/auth/proof.ts +111 -0
  593. package/src/auth/protocol.ts +1629 -0
  594. package/src/auth/schemas.ts +145 -0
  595. package/src/auth/session_auth.ts +167 -0
  596. package/src/auth/time.ts +15 -0
  597. package/src/auth/trellis_id.ts +9 -0
  598. package/src/auth/types.ts +4 -0
  599. package/src/auth/utils.ts +87 -0
  600. package/src/auth.ts +2 -0
  601. package/src/browser.ts +8 -0
  602. package/src/client.ts +164 -0
  603. package/src/client_connect.ts +1328 -0
  604. package/src/codec.ts +107 -0
  605. package/src/connection.ts +466 -0
  606. package/src/contract.ts +84 -0
  607. package/src/contract_support/canonical.ts +217 -0
  608. package/src/contract_support/mod.ts +5079 -0
  609. package/src/contract_support/protocol.ts +213 -0
  610. package/src/contract_support/runtime.ts +129 -0
  611. package/src/contract_support/schema_pointers.ts +161 -0
  612. package/src/contracts.ts +9 -0
  613. package/src/device/deno.ts +941 -0
  614. package/src/device.ts +989 -0
  615. package/src/env.ts +1 -0
  616. package/src/errors/AuthError.ts +82 -0
  617. package/src/errors/KVError.ts +47 -0
  618. package/src/errors/RemoteError.ts +111 -0
  619. package/src/errors/StoreError.ts +43 -0
  620. package/src/errors/TransferError.ts +43 -0
  621. package/src/errors/TransportError.ts +48 -0
  622. package/src/errors/TrellisError.ts +20 -0
  623. package/src/errors/ValidationError.ts +80 -0
  624. package/src/errors/index.ts +195 -0
  625. package/src/generate.ts +329 -0
  626. package/src/globals.ts +26 -0
  627. package/src/health.ts +28 -0
  628. package/src/helpers.ts +63 -0
  629. package/src/host/mod.ts +9 -0
  630. package/src/host/node.ts +9 -0
  631. package/src/index.ts +233 -0
  632. package/src/jobs.ts +344 -0
  633. package/src/kv.ts +564 -0
  634. package/src/models/auth/rpc/Logout.ts +15 -0
  635. package/src/models/trellis/Page.ts +6 -0
  636. package/src/models/trellis/State.ts +55 -0
  637. package/src/models/trellis/TrellisError.ts +21 -0
  638. package/src/models/trellis/rpc/StateDelete.ts +13 -0
  639. package/src/models/trellis/rpc/StateGet.ts +25 -0
  640. package/src/models/trellis/rpc/StateList.ts +26 -0
  641. package/src/models/trellis/rpc/StatePut.ts +42 -0
  642. package/src/operations.ts +1508 -0
  643. package/src/runtime_transport.ts +132 -0
  644. package/src/sdk/auth.ts +2 -0
  645. package/src/sdk/core.ts +2 -0
  646. package/src/sdk/health.ts +2 -0
  647. package/src/sdk/jobs.ts +2 -0
  648. package/src/sdk/state.ts +2 -0
  649. package/src/server/health.ts +379 -0
  650. package/src/server/health_rpc.ts +51 -0
  651. package/src/server/health_schemas.ts +61 -0
  652. package/src/server/internal_jobs/active-job.ts +115 -0
  653. package/src/server/internal_jobs/bindings.ts +26 -0
  654. package/src/server/internal_jobs/cancellation-registry.ts +71 -0
  655. package/src/server/internal_jobs/heartbeat.ts +120 -0
  656. package/src/server/internal_jobs/job-manager.ts +456 -0
  657. package/src/server/internal_jobs/projection.ts +48 -0
  658. package/src/server/internal_jobs/runtime-worker.ts +741 -0
  659. package/src/server/internal_jobs/types.ts +124 -0
  660. package/src/server/runtime.ts +27 -0
  661. package/src/server/service.ts +2377 -0
  662. package/src/server/subscription.ts +143 -0
  663. package/src/server/transfer.ts +962 -0
  664. package/src/server.ts +1725 -0
  665. package/src/server_logger.ts +10 -0
  666. package/src/service/deno.ts +18 -0
  667. package/src/service/mod.ts +68 -0
  668. package/src/service/node.ts +18 -0
  669. package/src/store.ts +658 -0
  670. package/src/tasks.ts +34 -0
  671. package/src/telemetry/carrier.ts +35 -0
  672. package/src/telemetry/core.ts +31 -0
  673. package/src/telemetry/env.ts +23 -0
  674. package/src/telemetry/mod.ts +26 -0
  675. package/src/telemetry/nats.ts +15 -0
  676. package/src/telemetry/result.ts +20 -0
  677. package/src/telemetry/trace.ts +39 -0
  678. package/src/telemetry/trellis.ts +1 -0
  679. package/src/tracing.ts +28 -0
  680. package/src/transfer.ts +602 -0
  681. package/src/trellis.ts +3650 -0
  682. package/esm/models/trellis/Paginate.d.ts +0 -7
  683. package/esm/models/trellis/Paginate.d.ts.map +0 -1
  684. package/esm/models/trellis/Paginate.js +0 -5
  685. package/esm/npm/src/models/trellis/Paginate.d.ts +0 -7
  686. package/esm/npm/src/models/trellis/Paginate.d.ts.map +0 -1
  687. package/esm/npm/src/models/trellis/Paginate.js +0 -5
  688. package/script/models/trellis/Paginate.d.ts +0 -7
  689. package/script/models/trellis/Paginate.d.ts.map +0 -1
  690. package/script/models/trellis/Paginate.js +0 -11
  691. package/script/npm/src/models/trellis/Paginate.d.ts +0 -7
  692. package/script/npm/src/models/trellis/Paginate.d.ts.map +0 -1
  693. package/script/npm/src/models/trellis/Paginate.js +0 -11
@@ -0,0 +1,741 @@
1
+ import { jetstream, jetstreamManager } from "@nats-io/jetstream";
2
+ import type { ConsumerInfo, JsMsg } from "@nats-io/jetstream";
3
+ import type { NatsConnection, Subscription } from "@nats-io/nats-core";
4
+ import type { JobsQueueBinding, JobsRuntimeBinding } from "./bindings.js";
5
+ import { ActiveJobCancellationRegistry } from "./cancellation-registry.js";
6
+ import { startWorkerHeartbeatLoop } from "./heartbeat.js";
7
+ import type { ActiveJob, JobProcessOutcome } from "./job-manager.js";
8
+ import {
9
+ JobCancellationToken,
10
+ type JobManager,
11
+ JobProcessError,
12
+ } from "./job-manager.js";
13
+ import { isTerminal, jobFromWorkEvent } from "./projection.js";
14
+ import type { Job, JobEvent } from "./types.js";
15
+
16
+ export type WorkerAckAction = "ack" | "nak";
17
+ export type ProjectedWorkDecision = "process" | "skip-ack";
18
+ export type SchemaRef = { schema: string };
19
+ export type PayloadValidationArgs<TResult> = {
20
+ schema?: SchemaRef;
21
+ job: Job<unknown, TResult>;
22
+ };
23
+
24
+ export type ResultValidationArgs<TResult> = {
25
+ schema?: SchemaRef;
26
+ job: Job<unknown, TResult>;
27
+ result: TResult;
28
+ };
29
+
30
+ export class WorkerLoopStopError extends AggregateError {
31
+ constructor(errors: unknown[]) {
32
+ super(errors, "queue worker loop failed");
33
+ this.name = "WorkerLoopStopError";
34
+ }
35
+ }
36
+
37
+ export class WorkerHostStopError extends AggregateError {
38
+ constructor(errors: unknown[]) {
39
+ super(errors, "worker host stop failed");
40
+ this.name = "WorkerHostStopError";
41
+ }
42
+ }
43
+
44
+ export class JobsInfrastructureMissingError extends Error {
45
+ constructor(stream: string, queueType: string) {
46
+ super(
47
+ `Jobs work stream '${stream}' was not found while starting queue '${queueType}'. ` +
48
+ "The built-in Trellis jobs infrastructure is missing or not provisioned for this environment. " +
49
+ `Start Trellis and bootstrap the service again so '${stream}' exists before workers start.`,
50
+ );
51
+ this.name = "JobsInfrastructureMissingError";
52
+ }
53
+ }
54
+
55
+ type WorkMessageLike = {
56
+ data: Uint8Array;
57
+ subject: string;
58
+ info?: { redeliveryCount?: number };
59
+ ack(): void | Promise<void>;
60
+ nak(delay?: number): void | Promise<void>;
61
+ inProgress(): void | Promise<void>;
62
+ };
63
+
64
+ type ConsumerMessagesLike = AsyncIterable<WorkMessageLike> & {
65
+ stop?: () => void;
66
+ close?: () => Promise<void | Error> | void;
67
+ };
68
+
69
+ type WorkerConsumerLike = {
70
+ consume(): Promise<ConsumerMessagesLike>;
71
+ };
72
+
73
+ type CancelMessageLike = {
74
+ subject: string;
75
+ data: Uint8Array;
76
+ };
77
+
78
+ type CancelSubscriptionLike = AsyncIterable<CancelMessageLike> & {
79
+ unsubscribe(): void;
80
+ };
81
+
82
+ type WorkerStopHandle = { stop(): Promise<void> } | void;
83
+
84
+ type ConsumerInfoLike = unknown;
85
+
86
+ type StartNatsConsumerDeps = {
87
+ nats: Pick<NatsConnection, "subscribe">;
88
+ jsm: {
89
+ consumers: {
90
+ add(
91
+ stream: string,
92
+ config: Record<string, unknown>,
93
+ ): Promise<ConsumerInfoLike>;
94
+ info(stream: string, consumer: string): Promise<ConsumerInfoLike>;
95
+ };
96
+ direct?: DirectMessageReader;
97
+ };
98
+ js: {
99
+ consumers: {
100
+ getConsumerFromInfo(info: ConsumerInfoLike): WorkerConsumerLike;
101
+ };
102
+ };
103
+ };
104
+
105
+ type DirectMessageReader = {
106
+ getMessage(
107
+ stream: string,
108
+ query: { last_by_subj: string },
109
+ ): Promise<{ data: Uint8Array } | null>;
110
+ };
111
+
112
+ type StartNatsConnectionDeps = {
113
+ nats: NatsConnection;
114
+ jsm?: undefined;
115
+ js?: undefined;
116
+ };
117
+
118
+ type StartNatsRuntimeDeps = StartNatsConsumerDeps | StartNatsConnectionDeps;
119
+
120
+ function isCustomNatsRuntimeDeps(
121
+ args: StartNatsRuntimeDeps,
122
+ ): args is StartNatsConsumerDeps {
123
+ return args.jsm !== undefined && args.js !== undefined;
124
+ }
125
+
126
+ type StartWorkerArgs = {
127
+ queueType: string;
128
+ workerIndex: number;
129
+ cancellation: JobCancellationToken;
130
+ };
131
+
132
+ type StartWorkerHostOptions = {
133
+ instanceId: string;
134
+ queueTypes?: string[];
135
+ heartbeatPublisher?: {
136
+ publish(subject: string, payload: Uint8Array): void | Promise<void>;
137
+ };
138
+ heartbeatIntervalMs?: number;
139
+ version?: string;
140
+ nowIso?: () => string;
141
+ startWorker: (args: StartWorkerArgs) => Promise<WorkerStopHandle>;
142
+ };
143
+
144
+ type StartNatsWorkerHostOptions<TResult> =
145
+ & Omit<StartWorkerHostOptions, "startWorker">
146
+ & StartNatsRuntimeDeps
147
+ & {
148
+ manager: JobManager<unknown, TResult>;
149
+ getProjectedJob?: (
150
+ job: Job<unknown, TResult>,
151
+ ) => Promise<Job<unknown, TResult> | undefined>;
152
+ getLatestLifecycleEvent?: (
153
+ job: Job<unknown, TResult>,
154
+ ) => Promise<JobEvent | undefined>;
155
+ validatePayload?: (
156
+ args: PayloadValidationArgs<TResult>,
157
+ ) => Promise<void> | void;
158
+ validateResult?: (
159
+ args: ResultValidationArgs<TResult>,
160
+ ) => Promise<void> | void;
161
+ handler: (job: ActiveJob<unknown, TResult>) => Promise<TResult>;
162
+ };
163
+
164
+ type StartQueueWorkerLoopOptions<TResult> = {
165
+ manager: JobManager<unknown, TResult>;
166
+ consumer: WorkerConsumerLike;
167
+ cancelSubscription: CancelSubscriptionLike;
168
+ hostCancellation?: JobCancellationToken;
169
+ getProjectedJob?: (
170
+ job: Job<unknown, TResult>,
171
+ ) => Promise<Job<unknown, TResult> | undefined>;
172
+ getLatestLifecycleEvent?: (
173
+ job: Job<unknown, TResult>,
174
+ ) => Promise<JobEvent | undefined>;
175
+ payloadSchema?: SchemaRef;
176
+ validatePayload?: (
177
+ args: PayloadValidationArgs<TResult>,
178
+ ) => Promise<void> | void;
179
+ resultSchema?: SchemaRef;
180
+ validateResult?: (
181
+ args: ResultValidationArgs<TResult>,
182
+ ) => Promise<void> | void;
183
+ handler: (job: ActiveJob<unknown, TResult>) => Promise<TResult>;
184
+ };
185
+
186
+ type StartNatsQueueWorkerOptions<TResult> =
187
+ & StartNatsRuntimeDeps
188
+ & {
189
+ manager: JobManager<unknown, TResult>;
190
+ binding: JobsRuntimeBinding;
191
+ queueType: string;
192
+ hostCancellation?: JobCancellationToken;
193
+ getProjectedJob?: (
194
+ job: Job<unknown, TResult>,
195
+ ) => Promise<Job<unknown, TResult> | undefined>;
196
+ getLatestLifecycleEvent?: (
197
+ job: Job<unknown, TResult>,
198
+ ) => Promise<JobEvent | undefined>;
199
+ validatePayload?: (
200
+ args: PayloadValidationArgs<TResult>,
201
+ ) => Promise<void> | void;
202
+ validateResult?: (
203
+ args: ResultValidationArgs<TResult>,
204
+ ) => Promise<void> | void;
205
+ handler: (job: ActiveJob<unknown, TResult>) => Promise<TResult>;
206
+ };
207
+
208
+ function toWorkerConsumer(
209
+ consumer: {
210
+ consume(): Promise<
211
+ AsyncIterable<JsMsg> & {
212
+ stop?: () => void;
213
+ close?: () => Promise<void | Error> | void;
214
+ }
215
+ >;
216
+ },
217
+ ): WorkerConsumerLike {
218
+ return {
219
+ async consume(): Promise<ConsumerMessagesLike> {
220
+ const messages = await consumer.consume();
221
+ return {
222
+ stop: messages.stop?.bind(messages),
223
+ close: messages.close?.bind(messages),
224
+ async *[Symbol.asyncIterator]() {
225
+ for await (const msg of messages) {
226
+ yield {
227
+ data: msg.data,
228
+ subject: msg.subject,
229
+ info: {
230
+ redeliveryCount: Math.max(0, msg.info.deliveryCount - 1),
231
+ },
232
+ ack: msg.ack.bind(msg),
233
+ nak: msg.nak.bind(msg),
234
+ inProgress: msg.working.bind(msg),
235
+ };
236
+ }
237
+ },
238
+ };
239
+ },
240
+ };
241
+ }
242
+
243
+ export async function processWorkPayloadWithContextAndHeartbeat<TResult>(
244
+ manager: JobManager<unknown, TResult>,
245
+ payload: Uint8Array,
246
+ cancellation: JobCancellationToken,
247
+ heartbeat: () => Promise<void>,
248
+ handler: (job: ActiveJob<unknown, TResult>) => Promise<TResult>,
249
+ validation?: {
250
+ payloadSchema?: SchemaRef;
251
+ validatePayload?: (
252
+ args: PayloadValidationArgs<TResult>,
253
+ ) => Promise<void> | void;
254
+ resultSchema?: SchemaRef;
255
+ validateResult?: (
256
+ args: ResultValidationArgs<TResult>,
257
+ ) => Promise<void> | void;
258
+ },
259
+ runtime?: { redeliveryCount?: number },
260
+ ): Promise<JobProcessOutcome<TResult> | undefined> {
261
+ const event = parseWorkPayloadEvent(payload);
262
+ if (!event) {
263
+ return undefined;
264
+ }
265
+ const job = jobFromWorkEvent(event) as Job<unknown, TResult> | undefined;
266
+ if (!job) {
267
+ return undefined;
268
+ }
269
+ return await manager.processWithHeartbeat(
270
+ job,
271
+ cancellation,
272
+ heartbeat,
273
+ async (activeJob) => {
274
+ try {
275
+ await validation?.validatePayload?.({
276
+ schema: validation.payloadSchema,
277
+ job: activeJob.job(),
278
+ });
279
+ } catch (error) {
280
+ throw JobProcessError.failed(
281
+ error instanceof Error ? error.message : String(error),
282
+ );
283
+ }
284
+ return await handler(activeJob);
285
+ },
286
+ {
287
+ redeliveryCount: runtime?.redeliveryCount,
288
+ },
289
+ {
290
+ validateResult: validation?.validateResult
291
+ ? (result: TResult, resultJob: Job<unknown, TResult>) =>
292
+ validation.validateResult!({
293
+ schema: validation.resultSchema,
294
+ result,
295
+ job: resultJob,
296
+ })
297
+ : undefined,
298
+ },
299
+ );
300
+ }
301
+
302
+ export function projectedWorkDecision(
303
+ projected: Job | undefined,
304
+ _work: Job,
305
+ ): ProjectedWorkDecision {
306
+ if (!projected) {
307
+ return "process";
308
+ }
309
+ return isTerminal(projected.state) ? "skip-ack" : "process";
310
+ }
311
+
312
+ export function lifecycleWorkDecision(
313
+ latest: JobEvent | undefined,
314
+ ): ProjectedWorkDecision {
315
+ if (!latest) {
316
+ return "process";
317
+ }
318
+ return isTerminal(latest.state) ? "skip-ack" : "process";
319
+ }
320
+
321
+ export function ackActionForOutcome(
322
+ outcome: JobProcessOutcome<unknown> | undefined,
323
+ ): WorkerAckAction {
324
+ if (!outcome) {
325
+ return "ack";
326
+ }
327
+ switch (outcome.outcome) {
328
+ case "retry":
329
+ case "interrupted":
330
+ return "nak";
331
+ default:
332
+ return "ack";
333
+ }
334
+ }
335
+
336
+ export async function startQueueWorkerLoop<TResult>(
337
+ options: StartQueueWorkerLoopOptions<TResult>,
338
+ ): Promise<{ stop(): Promise<void> }> {
339
+ const registry = new ActiveJobCancellationRegistry();
340
+ const activeTokens = new Set<JobCancellationToken>();
341
+ const messages = await options.consumer.consume();
342
+ const hostCancellation = options.hostCancellation;
343
+ const stopConsuming = () => {
344
+ if (typeof messages.stop === "function") {
345
+ messages.stop();
346
+ }
347
+ if (typeof messages.close === "function") {
348
+ void messages.close();
349
+ }
350
+ };
351
+ const cancelActiveForShutdown = () => {
352
+ for (const token of activeTokens) {
353
+ token.cancelForShutdown();
354
+ }
355
+ };
356
+ const hostAbortHandler = () => {
357
+ cancelActiveForShutdown();
358
+ stopConsuming();
359
+ };
360
+ hostCancellation?.signal.addEventListener("abort", hostAbortHandler);
361
+ if (hostCancellation?.signal.aborted) {
362
+ hostAbortHandler();
363
+ }
364
+
365
+ const workTask = (async () => {
366
+ for await (const msg of messages) {
367
+ const event = parseWorkPayloadEvent(msg.data);
368
+ const job = event
369
+ ? jobFromWorkEvent(event) as Job<unknown, TResult> | undefined
370
+ : undefined;
371
+ if (!job) {
372
+ await msg.ack();
373
+ continue;
374
+ }
375
+ const key = `${job.service}.${job.type}.${job.id}`;
376
+ if (hostCancellation?.isHostShutdown()) {
377
+ await msg.nak();
378
+ continue;
379
+ }
380
+ const latestLifecycle = options.getLatestLifecycleEvent
381
+ ? await options.getLatestLifecycleEvent(job)
382
+ : undefined;
383
+ if (hostCancellation?.isHostShutdown()) {
384
+ await msg.nak();
385
+ continue;
386
+ }
387
+ if (lifecycleWorkDecision(latestLifecycle) === "skip-ack") {
388
+ registry.clearPending(key);
389
+ await msg.ack();
390
+ continue;
391
+ }
392
+ if (!latestLifecycle) {
393
+ const projected = options.getProjectedJob
394
+ ? await options.getProjectedJob(job)
395
+ : undefined;
396
+ if (hostCancellation?.isHostShutdown()) {
397
+ await msg.nak();
398
+ continue;
399
+ }
400
+ if (projectedWorkDecision(projected, job) === "skip-ack") {
401
+ registry.clearPending(key);
402
+ await msg.ack();
403
+ continue;
404
+ }
405
+ }
406
+
407
+ const token = new JobCancellationToken();
408
+ if (hostCancellation?.isHostShutdown()) {
409
+ token.cancelForShutdown();
410
+ }
411
+ activeTokens.add(token);
412
+ const guard = registry.register(key, token);
413
+ try {
414
+ const outcome = await processWorkPayloadWithContextAndHeartbeat(
415
+ options.manager,
416
+ msg.data,
417
+ token,
418
+ async () => {
419
+ await msg.inProgress();
420
+ },
421
+ options.handler,
422
+ {
423
+ payloadSchema: options.payloadSchema,
424
+ validatePayload: options.validatePayload,
425
+ resultSchema: options.resultSchema,
426
+ validateResult: options.validateResult,
427
+ },
428
+ {
429
+ redeliveryCount: msg.info?.redeliveryCount,
430
+ },
431
+ );
432
+ if (ackActionForOutcome(outcome) === "ack") {
433
+ await msg.ack();
434
+ } else {
435
+ await msg.nak();
436
+ }
437
+ } finally {
438
+ guard.dispose();
439
+ activeTokens.delete(token);
440
+ }
441
+ }
442
+ })();
443
+ let workFailure: unknown;
444
+ const observedWorkTask = workTask.catch((error) => {
445
+ workFailure = error;
446
+ });
447
+
448
+ const cancelTask = (async () => {
449
+ for await (const msg of options.cancelSubscription) {
450
+ const event = parseWorkPayloadEvent(msg.data);
451
+ if (!event || event.eventType !== "cancelled") {
452
+ continue;
453
+ }
454
+ registry.cancel(`${event.service}.${event.jobType}.${event.jobId}`);
455
+ }
456
+ })();
457
+ let cancelFailure: unknown;
458
+ const observedCancelTask = cancelTask.catch((error) => {
459
+ cancelFailure = error;
460
+ });
461
+
462
+ return {
463
+ async stop(): Promise<void> {
464
+ options.cancelSubscription.unsubscribe();
465
+ cancelActiveForShutdown();
466
+ stopConsuming();
467
+ await Promise.all([observedWorkTask, observedCancelTask]);
468
+ hostCancellation?.signal.removeEventListener("abort", hostAbortHandler);
469
+ const failures = [workFailure, cancelFailure].filter((error) =>
470
+ error !== undefined
471
+ );
472
+ if (failures.length > 0) {
473
+ throw new WorkerLoopStopError(failures);
474
+ }
475
+ },
476
+ };
477
+ }
478
+
479
+ export async function startNatsQueueWorker<TResult>(
480
+ options: StartNatsQueueWorkerOptions<TResult>,
481
+ ): Promise<{ stop(): Promise<void> }> {
482
+ const queue = getQueueBinding(options.binding, options.queueType);
483
+ const jsm = isCustomNatsRuntimeDeps(options)
484
+ ? options.jsm
485
+ : await jetstreamManager(options.nats);
486
+ const js = isCustomNatsRuntimeDeps(options) ? options.js : {
487
+ consumers: {
488
+ getConsumerFromInfo(info: ConsumerInfoLike) {
489
+ return toWorkerConsumer(
490
+ jetstream(options.nats).consumers.getConsumerFromInfo(
491
+ info as ConsumerInfo,
492
+ ),
493
+ );
494
+ },
495
+ },
496
+ };
497
+ const info = await ensureConsumerInfo(jsm, options.binding.workStream, queue);
498
+ const consumer = js.consumers.getConsumerFromInfo(info);
499
+ const cancelSubscription = options.nats.subscribe(
500
+ `${queue.publishPrefix}.*.cancelled`,
501
+ ) as Subscription as CancelSubscriptionLike;
502
+ const direct = jsm.direct;
503
+
504
+ return await startQueueWorkerLoop({
505
+ manager: options.manager,
506
+ consumer,
507
+ cancelSubscription,
508
+ hostCancellation: options.hostCancellation,
509
+ getProjectedJob: options.getProjectedJob,
510
+ getLatestLifecycleEvent: options.getLatestLifecycleEvent ??
511
+ (direct
512
+ ? (job) => getLatestLifecycleEvent(direct, "JOBS", job)
513
+ : undefined),
514
+ payloadSchema: queue.payload,
515
+ validatePayload: options.validatePayload,
516
+ resultSchema: queue.result,
517
+ validateResult: options.validateResult,
518
+ handler: options.handler,
519
+ });
520
+ }
521
+
522
+ export async function startWorkerHostFromBinding(
523
+ binding: JobsRuntimeBinding,
524
+ options: StartWorkerHostOptions,
525
+ ): Promise<{ workerCount(): number; stop(): Promise<void> }> {
526
+ const queueTypes = options.queueTypes ??
527
+ Object.keys(binding.jobs.queues).sort();
528
+ for (const queueType of queueTypes) {
529
+ const queue = binding.jobs.queues[queueType];
530
+ if (!queue) {
531
+ throw new Error(
532
+ `Requested worker queue binding '${queueType}' is missing`,
533
+ );
534
+ }
535
+ if (queue.concurrency < 1) {
536
+ throw new Error(
537
+ `Worker queue '${queueType}' has invalid concurrency ${queue.concurrency}; expected >= 1`,
538
+ );
539
+ }
540
+ }
541
+
542
+ const cancellation = new JobCancellationToken();
543
+ const heartbeatLoops = options.heartbeatPublisher
544
+ ? await Promise.all(queueTypes.map((queueType) => {
545
+ const queue = binding.jobs.queues[queueType];
546
+ if (!queue) {
547
+ throw new Error(`Worker queue '${queueType}' is not configured`);
548
+ }
549
+ return startWorkerHeartbeatLoop({
550
+ publisher: options.heartbeatPublisher!,
551
+ service: binding.jobs.namespace,
552
+ jobType: queueType,
553
+ instanceId: options.instanceId,
554
+ concurrency: queue.concurrency,
555
+ version: options.version,
556
+ intervalMs: options.heartbeatIntervalMs,
557
+ nowIso: options.nowIso,
558
+ });
559
+ }))
560
+ : [];
561
+
562
+ const workers: Array<{ stop(): Promise<void> }> = [];
563
+ for (const queueType of queueTypes) {
564
+ const queue = binding.jobs.queues[queueType];
565
+ if (!queue) {
566
+ throw new Error(`Worker queue '${queueType}' is not configured`);
567
+ }
568
+ for (
569
+ let workerIndex = 0;
570
+ workerIndex < queue.concurrency;
571
+ workerIndex += 1
572
+ ) {
573
+ const handle = await options.startWorker({
574
+ queueType,
575
+ workerIndex,
576
+ cancellation,
577
+ });
578
+ if (
579
+ handle && typeof handle === "object" && "stop" in handle &&
580
+ typeof handle.stop === "function"
581
+ ) {
582
+ workers.push(handle);
583
+ }
584
+ }
585
+ }
586
+
587
+ return {
588
+ workerCount(): number {
589
+ return workers.length;
590
+ },
591
+ async stop(): Promise<void> {
592
+ cancellation.cancelForShutdown();
593
+ const results = await Promise.allSettled([
594
+ ...workers.map((worker) => worker.stop()),
595
+ ...heartbeatLoops.map((loop) => loop.stop()),
596
+ ]);
597
+ const failures = results
598
+ .filter((result): result is PromiseRejectedResult =>
599
+ result.status === "rejected"
600
+ )
601
+ .map((result) => result.reason);
602
+ if (failures.length > 0) {
603
+ throw new WorkerHostStopError(failures);
604
+ }
605
+ },
606
+ };
607
+ }
608
+
609
+ export async function startNatsWorkerHostFromBinding<TResult>(
610
+ binding: JobsRuntimeBinding,
611
+ options: StartNatsWorkerHostOptions<TResult>,
612
+ ): Promise<{ workerCount(): number; stop(): Promise<void> }> {
613
+ return await startWorkerHostFromBinding(binding, {
614
+ instanceId: options.instanceId,
615
+ queueTypes: options.queueTypes,
616
+ heartbeatPublisher: options.heartbeatPublisher,
617
+ heartbeatIntervalMs: options.heartbeatIntervalMs,
618
+ version: options.version,
619
+ nowIso: options.nowIso,
620
+ startWorker: async ({ queueType, cancellation }) => {
621
+ const common = {
622
+ manager: options.manager,
623
+ binding,
624
+ queueType,
625
+ hostCancellation: cancellation,
626
+ getProjectedJob: options.getProjectedJob,
627
+ getLatestLifecycleEvent: options.getLatestLifecycleEvent,
628
+ validatePayload: options.validatePayload,
629
+ validateResult: options.validateResult,
630
+ handler: options.handler,
631
+ };
632
+ return await (isCustomNatsRuntimeDeps(options)
633
+ ? startNatsQueueWorker({
634
+ ...common,
635
+ nats: options.nats,
636
+ jsm: options.jsm,
637
+ js: options.js,
638
+ })
639
+ : startNatsQueueWorker({ ...common, nats: options.nats }));
640
+ },
641
+ });
642
+ }
643
+
644
+ async function ensureConsumerInfo(
645
+ jsm: {
646
+ consumers: {
647
+ add(
648
+ stream: string,
649
+ config: Record<string, unknown>,
650
+ ): Promise<ConsumerInfoLike>;
651
+ info(stream: string, consumer: string): Promise<ConsumerInfoLike>;
652
+ };
653
+ },
654
+ stream: string,
655
+ queue: JobsQueueBinding,
656
+ ): Promise<ConsumerInfoLike> {
657
+ const config = {
658
+ durable_name: queue.consumerName,
659
+ ack_policy: "explicit",
660
+ filter_subject: queue.workSubject,
661
+ ack_wait: queue.ackWaitMs * 1_000_000,
662
+ max_deliver: queue.maxDeliver,
663
+ backoff: queue.backoffMs.map((delay) => delay * 1_000_000),
664
+ };
665
+
666
+ try {
667
+ return await jsm.consumers.add(stream, config);
668
+ } catch (addError) {
669
+ try {
670
+ return await jsm.consumers.info(stream, queue.consumerName);
671
+ } catch (infoError) {
672
+ if (isStreamNotFoundError(addError) || isStreamNotFoundError(infoError)) {
673
+ throw new JobsInfrastructureMissingError(stream, queue.queueType);
674
+ }
675
+ throw infoError;
676
+ }
677
+ }
678
+ }
679
+
680
+ function isStreamNotFoundError(error: unknown): boolean {
681
+ return error instanceof Error && (
682
+ error.name === "StreamNotFoundError" ||
683
+ error.message.includes("stream not found")
684
+ );
685
+ }
686
+
687
+ function getQueueBinding(
688
+ binding: JobsRuntimeBinding,
689
+ queueType: string,
690
+ ): JobsQueueBinding {
691
+ const queue = binding.jobs.queues[queueType];
692
+ if (!queue) {
693
+ throw new Error(`Requested worker queue binding '${queueType}' is missing`);
694
+ }
695
+ if (queue.concurrency < 1) {
696
+ throw new Error(
697
+ `Worker queue '${queueType}' has invalid concurrency ${queue.concurrency}; expected >= 1`,
698
+ );
699
+ }
700
+ return queue;
701
+ }
702
+
703
+ async function getLatestLifecycleEvent(
704
+ direct: DirectMessageReader,
705
+ stream: string,
706
+ job: Job,
707
+ ): Promise<JobEvent | undefined> {
708
+ try {
709
+ const msg = await direct.getMessage(stream, {
710
+ last_by_subj: `trellis.jobs.${job.service}.${job.type}.${job.id}.*`,
711
+ });
712
+ if (!msg) {
713
+ return undefined;
714
+ }
715
+ return parseWorkPayloadEvent(msg.data);
716
+ } catch (error) {
717
+ if (isMessageNotFoundError(error)) {
718
+ return undefined;
719
+ }
720
+ if (isStreamNotFoundError(error)) {
721
+ throw new JobsInfrastructureMissingError(stream, job.type);
722
+ }
723
+ throw error;
724
+ }
725
+ }
726
+
727
+ function isMessageNotFoundError(error: unknown): boolean {
728
+ return error instanceof Error && (
729
+ error.name === "MessageNotFoundError" ||
730
+ error.message.includes("message not found") ||
731
+ error.message.includes("no message found")
732
+ );
733
+ }
734
+
735
+ function parseWorkPayloadEvent(payload: Uint8Array): JobEvent | undefined {
736
+ try {
737
+ return JSON.parse(new TextDecoder().decode(payload)) as JobEvent;
738
+ } catch {
739
+ return undefined;
740
+ }
741
+ }