@qlever-llc/trellis 0.8.3 → 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 +132 -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 +54 -24
  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 -4
  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 +54 -57
  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
package/src/store.ts ADDED
@@ -0,0 +1,658 @@
1
+ import {
2
+ type ObjectInfo,
3
+ type ObjectResult,
4
+ type ObjectStore,
5
+ type ObjectStoreStatus,
6
+ Objm,
7
+ } from "@nats-io/obj";
8
+ import type { NatsConnection } from "@nats-io/nats-core/internal";
9
+ import {
10
+ AsyncResult,
11
+ Result,
12
+ type Result as ResultType,
13
+ } from "@qlever-llc/result";
14
+ import { StoreError } from "./errors/index.js";
15
+ import type { PageResponse } from "./models/trellis/Page.js";
16
+
17
+ const INTERNAL_CONTENT_TYPE_METADATA_KEY = "__trellis_content_type";
18
+ const DEFAULT_STORE_WAIT_POLL_INTERVAL_MS = 250;
19
+ const MAX_STORE_LIST_LIMIT = 500;
20
+
21
+ export type StoreBody =
22
+ | Uint8Array
23
+ | ReadableStream<Uint8Array>
24
+ | AsyncIterable<Uint8Array>;
25
+
26
+ export type StoreWaitOptions = {
27
+ timeoutMs?: number;
28
+ pollIntervalMs?: number;
29
+ signal?: AbortSignal;
30
+ };
31
+
32
+ export type StoreOpenOptions = {
33
+ ttlMs?: number;
34
+ maxObjectBytes?: number;
35
+ maxTotalBytes?: number;
36
+ bindOnly?: boolean;
37
+ };
38
+
39
+ export type StorePutOptions = {
40
+ contentType?: string;
41
+ metadata?: Record<string, string>;
42
+ };
43
+
44
+ /** Explicit bounded query for listing object metadata in a typed store. */
45
+ export type StoreListOptions = {
46
+ prefix?: string;
47
+ offset?: number;
48
+ limit: number;
49
+ };
50
+
51
+ export type StoreInfo = {
52
+ key: string;
53
+ size: number;
54
+ updatedAt: string;
55
+ digest?: string;
56
+ contentType?: string;
57
+ metadata: Record<string, string>;
58
+ };
59
+
60
+ export type StoreStatus = {
61
+ size: number;
62
+ sealed: boolean;
63
+ ttlMs: number;
64
+ maxObjectBytes?: number;
65
+ maxTotalBytes?: number;
66
+ };
67
+
68
+ function metadataWithContentType(
69
+ options?: StorePutOptions,
70
+ ): Record<string, string> | undefined {
71
+ if (!options?.metadata && !options?.contentType) {
72
+ return undefined;
73
+ }
74
+
75
+ return {
76
+ ...(options?.metadata ?? {}),
77
+ ...(options?.contentType
78
+ ? { [INTERNAL_CONTENT_TYPE_METADATA_KEY]: options.contentType }
79
+ : {}),
80
+ };
81
+ }
82
+
83
+ function storeInfoFromObjectInfo(info: ObjectInfo): StoreInfo {
84
+ const { [INTERNAL_CONTENT_TYPE_METADATA_KEY]: contentType, ...metadata } =
85
+ info.metadata ?? {};
86
+ return {
87
+ key: info.name,
88
+ size: info.size,
89
+ updatedAt: info.mtime,
90
+ ...(info.digest ? { digest: info.digest } : {}),
91
+ ...(contentType ? { contentType } : {}),
92
+ metadata,
93
+ };
94
+ }
95
+
96
+ function streamFromBytes(data: Uint8Array): ReadableStream<Uint8Array> {
97
+ return new ReadableStream<Uint8Array>({
98
+ start(controller) {
99
+ controller.enqueue(data);
100
+ controller.close();
101
+ },
102
+ });
103
+ }
104
+
105
+ function streamFromAsyncIterable(
106
+ iterable: AsyncIterable<Uint8Array>,
107
+ ): ReadableStream<Uint8Array> {
108
+ const iterator = iterable[Symbol.asyncIterator]();
109
+ return new ReadableStream<Uint8Array>({
110
+ async pull(controller) {
111
+ const next = await iterator.next();
112
+ if (next.done) {
113
+ controller.close();
114
+ return;
115
+ }
116
+ controller.enqueue(next.value);
117
+ },
118
+ async cancel(reason) {
119
+ await iterator.return?.(reason);
120
+ },
121
+ });
122
+ }
123
+
124
+ function validateStoreListOptions(
125
+ opts: StoreListOptions,
126
+ ): ResultType<Required<StoreListOptions>, StoreError> {
127
+ if (!Number.isInteger(opts.limit) || opts.limit < 0) {
128
+ return Result.err(
129
+ new StoreError({
130
+ operation: "list",
131
+ context: { reason: "invalid_limit", limit: opts.limit },
132
+ }),
133
+ );
134
+ }
135
+ if (opts.limit > MAX_STORE_LIST_LIMIT) {
136
+ return Result.err(
137
+ new StoreError({
138
+ operation: "list",
139
+ context: {
140
+ reason: "limit_exceeded",
141
+ limit: opts.limit,
142
+ maxLimit: MAX_STORE_LIST_LIMIT,
143
+ },
144
+ }),
145
+ );
146
+ }
147
+
148
+ const offset = opts.offset ?? 0;
149
+ if (!Number.isInteger(offset) || offset < 0) {
150
+ return Result.err(
151
+ new StoreError({
152
+ operation: "list",
153
+ context: { reason: "invalid_offset", offset },
154
+ }),
155
+ );
156
+ }
157
+
158
+ return Result.ok({ prefix: opts.prefix ?? "", offset, limit: opts.limit });
159
+ }
160
+
161
+ function enforceMaxObjectBytes(
162
+ stream: ReadableStream<Uint8Array>,
163
+ maxObjectBytes?: number,
164
+ ): ReadableStream<Uint8Array> {
165
+ if (maxObjectBytes === undefined) {
166
+ return stream;
167
+ }
168
+
169
+ const reader = stream.getReader();
170
+ let totalBytes = 0;
171
+
172
+ return new ReadableStream<Uint8Array>({
173
+ async pull(controller) {
174
+ const next = await reader.read();
175
+ if (next.done) {
176
+ controller.close();
177
+ return;
178
+ }
179
+
180
+ totalBytes += next.value.length;
181
+ if (totalBytes > maxObjectBytes) {
182
+ controller.error(
183
+ new StoreError({
184
+ operation: "put",
185
+ context: {
186
+ reason: "max_object_bytes_exceeded",
187
+ maxObjectBytes,
188
+ attemptedBytes: totalBytes,
189
+ },
190
+ }),
191
+ );
192
+ await reader.cancel();
193
+ return;
194
+ }
195
+
196
+ controller.enqueue(next.value);
197
+ },
198
+ async cancel(reason) {
199
+ await reader.cancel(reason);
200
+ },
201
+ });
202
+ }
203
+
204
+ async function bytesFromStream(
205
+ stream: ReadableStream<Uint8Array>,
206
+ ): Promise<Uint8Array> {
207
+ const reader = stream.getReader();
208
+ const chunks: Uint8Array[] = [];
209
+ let totalLength = 0;
210
+
211
+ while (true) {
212
+ const next = await reader.read();
213
+ if (next.done) {
214
+ break;
215
+ }
216
+ chunks.push(next.value);
217
+ totalLength += next.value.length;
218
+ }
219
+
220
+ const merged = new Uint8Array(totalLength);
221
+ let offset = 0;
222
+ for (const chunk of chunks) {
223
+ merged.set(chunk, offset);
224
+ offset += chunk.length;
225
+ }
226
+ return merged;
227
+ }
228
+
229
+ function isNotFoundStoreError(error: StoreError): boolean {
230
+ return error.getContext().reason === "not_found";
231
+ }
232
+
233
+ function abortedStoreError(key: string, cause: unknown): StoreError {
234
+ return new StoreError({
235
+ operation: "waitFor",
236
+ cause,
237
+ context: { key, reason: "aborted" },
238
+ });
239
+ }
240
+
241
+ async function sleepWithSignal(
242
+ ms: number,
243
+ signal?: AbortSignal,
244
+ ): Promise<void> {
245
+ if (signal?.aborted) {
246
+ throw signal.reason ??
247
+ new DOMException("The operation was aborted", "AbortError");
248
+ }
249
+
250
+ await new Promise<void>((resolve, reject) => {
251
+ const timeoutId = setTimeout(() => {
252
+ cleanup();
253
+ resolve();
254
+ }, ms);
255
+
256
+ const onAbort = () => {
257
+ cleanup();
258
+ reject(
259
+ signal?.reason ??
260
+ new DOMException("The operation was aborted", "AbortError"),
261
+ );
262
+ };
263
+
264
+ const cleanup = () => {
265
+ clearTimeout(timeoutId);
266
+ signal?.removeEventListener("abort", onAbort);
267
+ };
268
+
269
+ signal?.addEventListener("abort", onAbort, { once: true });
270
+ });
271
+ }
272
+
273
+ function streamFromBody(
274
+ body: Exclude<StoreBody, Uint8Array>,
275
+ ): ReadableStream<Uint8Array> {
276
+ return body instanceof ReadableStream ? body : streamFromAsyncIterable(body);
277
+ }
278
+
279
+ async function unwrapObjectInfo(
280
+ store: ObjectStore,
281
+ key: string,
282
+ ): Promise<ResultType<ObjectInfo, StoreError>> {
283
+ try {
284
+ const info = await store.info(key);
285
+ if (info === null || info.deleted) {
286
+ return Result.err(
287
+ new StoreError({
288
+ operation: "get",
289
+ context: { key, reason: "not_found" },
290
+ }),
291
+ );
292
+ }
293
+ return Result.ok(info);
294
+ } catch (cause) {
295
+ return Result.err(
296
+ new StoreError({ operation: "get", cause, context: { key } }),
297
+ );
298
+ }
299
+ }
300
+
301
+ export class TypedStore {
302
+ readonly #store: ObjectStore;
303
+ readonly #options:
304
+ & Required<Pick<StoreOpenOptions, "ttlMs">>
305
+ & Omit<StoreOpenOptions, "ttlMs">;
306
+
307
+ private constructor(store: ObjectStore, options: StoreOpenOptions) {
308
+ this.#store = store;
309
+ this.#options = {
310
+ ttlMs: options.ttlMs ?? 0,
311
+ ...(options.maxObjectBytes !== undefined
312
+ ? { maxObjectBytes: options.maxObjectBytes }
313
+ : {}),
314
+ ...(options.maxTotalBytes !== undefined
315
+ ? { maxTotalBytes: options.maxTotalBytes }
316
+ : {}),
317
+ ...(options.bindOnly !== undefined ? { bindOnly: options.bindOnly } : {}),
318
+ };
319
+ }
320
+
321
+ static open(
322
+ nats: NatsConnection,
323
+ name: string,
324
+ options: StoreOpenOptions = {},
325
+ ): AsyncResult<TypedStore, StoreError> {
326
+ return AsyncResult.from((async () => {
327
+ try {
328
+ const objm = new Objm(nats);
329
+ const store = options.bindOnly
330
+ ? await objm.open(name)
331
+ : await objm.create(name, {
332
+ ...(options.ttlMs && options.ttlMs > 0
333
+ ? { ttl: options.ttlMs * 1_000_000 }
334
+ : {}),
335
+ ...(options.maxTotalBytes !== undefined
336
+ ? { max_bytes: options.maxTotalBytes }
337
+ : {}),
338
+ });
339
+ return Result.ok(new TypedStore(store, options));
340
+ } catch (cause) {
341
+ return Result.err(
342
+ new StoreError({ operation: "open", cause, context: { name } }),
343
+ );
344
+ }
345
+ })());
346
+ }
347
+
348
+ create(
349
+ key: string,
350
+ body: StoreBody,
351
+ options?: StorePutOptions,
352
+ ): AsyncResult<void, StoreError> {
353
+ return AsyncResult.from((async () => {
354
+ const existing = await unwrapObjectInfo(this.#store, key);
355
+ if (existing.isOk()) {
356
+ return Result.err(
357
+ new StoreError({
358
+ operation: "create",
359
+ context: { key, reason: "already_exists" },
360
+ }),
361
+ );
362
+ }
363
+
364
+ return await this.#putInternal("create", key, body, options);
365
+ })());
366
+ }
367
+
368
+ put(
369
+ key: string,
370
+ body: StoreBody,
371
+ options?: StorePutOptions,
372
+ ): AsyncResult<void, StoreError> {
373
+ return AsyncResult.from(this.#putInternal("put", key, body, options));
374
+ }
375
+
376
+ get(key: string): AsyncResult<TypedStoreEntry, StoreError> {
377
+ return AsyncResult.from((async () => {
378
+ const info = await unwrapObjectInfo(this.#store, key);
379
+ return info.map((objectInfo) =>
380
+ new TypedStoreEntry(this.#store, storeInfoFromObjectInfo(objectInfo))
381
+ );
382
+ })());
383
+ }
384
+
385
+ /**
386
+ * Waits for an object key to appear in the store and returns the resulting entry.
387
+ */
388
+ waitFor(
389
+ key: string,
390
+ options: StoreWaitOptions = {},
391
+ ): AsyncResult<TypedStoreEntry, StoreError> {
392
+ return AsyncResult.from((async () => {
393
+ const startedAt = Date.now();
394
+ const pollIntervalMs = options.pollIntervalMs ??
395
+ DEFAULT_STORE_WAIT_POLL_INTERVAL_MS;
396
+
397
+ while (true) {
398
+ if (options.signal?.aborted) {
399
+ return Result.err(abortedStoreError(key, options.signal.reason));
400
+ }
401
+
402
+ const entry = await this.get(key);
403
+ if (entry.isOk()) {
404
+ return entry;
405
+ }
406
+ if (!isNotFoundStoreError(entry.error)) {
407
+ return entry;
408
+ }
409
+
410
+ const remainingTimeoutMs = options.timeoutMs === undefined
411
+ ? undefined
412
+ : options.timeoutMs - (Date.now() - startedAt);
413
+ if (remainingTimeoutMs !== undefined && remainingTimeoutMs <= 0) {
414
+ return Result.err(
415
+ new StoreError({
416
+ operation: "waitFor",
417
+ context: { key, reason: "timeout", timeoutMs: options.timeoutMs },
418
+ }),
419
+ );
420
+ }
421
+
422
+ try {
423
+ await sleepWithSignal(
424
+ remainingTimeoutMs === undefined
425
+ ? pollIntervalMs
426
+ : Math.min(pollIntervalMs, remainingTimeoutMs),
427
+ options.signal,
428
+ );
429
+ } catch (cause) {
430
+ return Result.err(abortedStoreError(key, cause));
431
+ }
432
+ }
433
+ })());
434
+ }
435
+
436
+ delete(key: string): AsyncResult<void, StoreError> {
437
+ return AsyncResult.from((async () => {
438
+ try {
439
+ await this.#store.delete(key);
440
+ return Result.ok(undefined);
441
+ } catch (cause) {
442
+ return Result.err(
443
+ new StoreError({ operation: "delete", cause, context: { key } }),
444
+ );
445
+ }
446
+ })());
447
+ }
448
+
449
+ list(
450
+ opts: StoreListOptions,
451
+ ): AsyncResult<PageResponse<StoreInfo>, StoreError> {
452
+ return AsyncResult.from((async () => {
453
+ const query = validateStoreListOptions(opts);
454
+ if (query.isErr()) return Result.err(query.error);
455
+
456
+ const { prefix, offset, limit } = query.unwrapOrElse(() => {
457
+ throw new Error("unreachable");
458
+ });
459
+ try {
460
+ const objects = await this.#store.list();
461
+ const filtered = objects
462
+ .filter((info) => !info.deleted && info.name.startsWith(prefix))
463
+ .map(storeInfoFromObjectInfo)
464
+ .sort((left, right) => left.key.localeCompare(right.key));
465
+ const entries = filtered.slice(offset, offset + limit);
466
+
467
+ return Result.ok({
468
+ entries,
469
+ count: filtered.length,
470
+ offset,
471
+ limit,
472
+ nextOffset: limit <= 0 || offset + limit >= filtered.length
473
+ ? undefined
474
+ : offset + limit,
475
+ });
476
+ } catch (cause) {
477
+ return Result.err(
478
+ new StoreError({ operation: "list", cause, context: { prefix } }),
479
+ );
480
+ }
481
+ })());
482
+ }
483
+
484
+ status(): AsyncResult<StoreStatus, StoreError> {
485
+ return AsyncResult.from((async () => {
486
+ try {
487
+ const status = await this.#store.status();
488
+ return Result.ok(
489
+ storeStatusFromObjectStoreStatus(status, this.#options),
490
+ );
491
+ } catch (cause) {
492
+ return Result.err(new StoreError({ operation: "status", cause }));
493
+ }
494
+ })());
495
+ }
496
+
497
+ async #putInternal(
498
+ operation: "create" | "put",
499
+ key: string,
500
+ body: StoreBody,
501
+ options?: StorePutOptions,
502
+ ): Promise<ResultType<void, StoreError>> {
503
+ try {
504
+ const metadata = metadataWithContentType(options);
505
+ if (body instanceof Uint8Array) {
506
+ if (
507
+ this.#options.maxObjectBytes !== undefined &&
508
+ body.length > this.#options.maxObjectBytes
509
+ ) {
510
+ return Result.err(
511
+ new StoreError({
512
+ operation,
513
+ context: {
514
+ key,
515
+ reason: "max_object_bytes_exceeded",
516
+ maxObjectBytes: this.#options.maxObjectBytes,
517
+ attemptedBytes: body.length,
518
+ },
519
+ }),
520
+ );
521
+ }
522
+
523
+ await this.#store.putBlob({
524
+ name: key,
525
+ ...(metadata ? { metadata } : {}),
526
+ }, body);
527
+ return Result.ok(undefined);
528
+ }
529
+
530
+ const limitedStream = enforceMaxObjectBytes(
531
+ streamFromBody(body),
532
+ this.#options.maxObjectBytes,
533
+ );
534
+
535
+ await this.#store.put(
536
+ { name: key, ...(metadata ? { metadata } : {}) },
537
+ limitedStream,
538
+ );
539
+ return Result.ok(undefined);
540
+ } catch (cause) {
541
+ return Result.err(new StoreError({ operation, cause, context: { key } }));
542
+ }
543
+ }
544
+ }
545
+
546
+ function storeStatusFromObjectStoreStatus(
547
+ status: ObjectStoreStatus,
548
+ options:
549
+ & Required<Pick<StoreOpenOptions, "ttlMs">>
550
+ & Omit<StoreOpenOptions, "ttlMs">,
551
+ ): StoreStatus {
552
+ return {
553
+ size: status.size,
554
+ sealed: status.sealed,
555
+ ttlMs: status.ttl > 0 ? Math.floor(status.ttl / 1_000_000) : options.ttlMs,
556
+ ...(options.maxObjectBytes !== undefined
557
+ ? { maxObjectBytes: options.maxObjectBytes }
558
+ : {}),
559
+ ...(options.maxTotalBytes !== undefined
560
+ ? { maxTotalBytes: options.maxTotalBytes }
561
+ : {}),
562
+ };
563
+ }
564
+
565
+ export class TypedStoreEntry {
566
+ readonly key: string;
567
+ readonly info: StoreInfo;
568
+ readonly #store: ObjectStore;
569
+
570
+ constructor(store: ObjectStore, info: StoreInfo) {
571
+ this.#store = store;
572
+ this.key = info.key;
573
+ this.info = info;
574
+ }
575
+
576
+ stream(): AsyncResult<ReadableStream<Uint8Array>, StoreError> {
577
+ return AsyncResult.from((async () => {
578
+ try {
579
+ const result = await this.#store.get(this.key);
580
+ if (result === null) {
581
+ return Result.err(
582
+ new StoreError({
583
+ operation: "stream",
584
+ context: { key: this.key, reason: "not_found" },
585
+ }),
586
+ );
587
+ }
588
+
589
+ return Result.ok(streamWithErrorCheck(result));
590
+ } catch (cause) {
591
+ return Result.err(
592
+ new StoreError({
593
+ operation: "stream",
594
+ cause,
595
+ context: { key: this.key },
596
+ }),
597
+ );
598
+ }
599
+ })());
600
+ }
601
+
602
+ bytes(): AsyncResult<Uint8Array, StoreError> {
603
+ return AsyncResult.from((async () => {
604
+ try {
605
+ const bytes = await this.#store.getBlob(this.key);
606
+ if (bytes === null) {
607
+ return Result.err(
608
+ new StoreError({
609
+ operation: "bytes",
610
+ context: { key: this.key, reason: "not_found" },
611
+ }),
612
+ );
613
+ }
614
+ return Result.ok(bytes);
615
+ } catch (cause) {
616
+ return Result.err(
617
+ new StoreError({
618
+ operation: "bytes",
619
+ cause,
620
+ context: { key: this.key },
621
+ }),
622
+ );
623
+ }
624
+ })());
625
+ }
626
+ }
627
+
628
+ function streamWithErrorCheck(
629
+ result: ObjectResult,
630
+ ): ReadableStream<Uint8Array> {
631
+ const reader = result.data.getReader();
632
+
633
+ return new ReadableStream<Uint8Array>({
634
+ async pull(controller) {
635
+ const next = await reader.read();
636
+ if (next.done) {
637
+ const error = await result.error;
638
+ if (error) {
639
+ controller.error(error);
640
+ return;
641
+ }
642
+ controller.close();
643
+ return;
644
+ }
645
+
646
+ controller.enqueue(next.value);
647
+ },
648
+ async cancel(reason) {
649
+ await reader.cancel(reason);
650
+ },
651
+ });
652
+ }
653
+
654
+ export async function bytesFromStoreStream(
655
+ stream: ReadableStream<Uint8Array>,
656
+ ): Promise<Uint8Array> {
657
+ return bytesFromStream(stream);
658
+ }
package/src/tasks.ts ADDED
@@ -0,0 +1,34 @@
1
+ import { AsyncResult, type BaseError, Result } from "@qlever-llc/result";
2
+ import { logger, type LoggerLike } from "./globals.js";
3
+
4
+ export class TrellisTasks {
5
+ #tasks: Record<string, Promise<Result<void, BaseError>>> = {};
6
+
7
+ #log: LoggerLike;
8
+
9
+ constructor(opts: { log?: LoggerLike }) {
10
+ this.#log = opts.log ?? logger;
11
+ }
12
+
13
+ /*
14
+ * Add a task to the task queue
15
+ */
16
+ add<E extends BaseError>(name: string, task: AsyncResult<void, E>) {
17
+ if (name in this.#tasks) {
18
+ this.#log.error({ name }, "Task already running?");
19
+ throw new Error(`Task ${name} already running`);
20
+ }
21
+ this.#log.debug({ name }, "Added task");
22
+ this.#tasks[name] = task.then((r: Result<void, E>) => {
23
+ if (Result.isErr(r)) {
24
+ this.#log.error(r, "Task encountered a runtime error");
25
+ }
26
+
27
+ return r;
28
+ });
29
+ }
30
+
31
+ wait(): AsyncResult<void, BaseError> {
32
+ return AsyncResult.any(Object.values(this.#tasks));
33
+ }
34
+ }
@@ -0,0 +1,35 @@
1
+ import {
2
+ type Context,
3
+ context,
4
+ propagation,
5
+ type Span,
6
+ trace,
7
+ } from "@opentelemetry/api";
8
+
9
+ export interface HeaderCarrier {
10
+ get(key: string): string | undefined;
11
+ set(key: string, value: string): void;
12
+ }
13
+
14
+ export function injectTraceContext(carrier: HeaderCarrier, span?: Span): void {
15
+ const ctx = span ? trace.setSpan(context.active(), span) : context.active();
16
+
17
+ propagation.inject(ctx, carrier, {
18
+ set: (c, k, v) => c.set(k, v),
19
+ });
20
+ }
21
+
22
+ export function extractTraceContext(carrier: HeaderCarrier): Context {
23
+ return propagation.extract(context.active(), carrier, {
24
+ get: (c, k) => c.get(k),
25
+ keys: () => [],
26
+ });
27
+ }
28
+
29
+ export function createMapCarrier(): HeaderCarrier {
30
+ const map = new Map<string, string>();
31
+ return {
32
+ get: (key: string) => map.get(key),
33
+ set: (key: string, value: string) => map.set(key, value),
34
+ };
35
+ }