@jinn-network/client 0.1.2 → 0.1.3-canary.24b69ea4

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 (1458) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/CONTRIBUTING.md +9 -2
  3. package/README.md +67 -47
  4. package/deployments/deployment-jinn-mvi-l1-sepolia-fast.json +36 -0
  5. package/deployments/deployment-jinn-mvi-l1-sepolia.json +36 -0
  6. package/deployments/deployment-jinn-mvi-l2-baseSepolia.json +12 -0
  7. package/deployments/deployment-phase1b-mech-baseSepolia-fast.json +3 -3
  8. package/deployments/deployment-stolas-l2-baseSepolia-fast.json +1 -1
  9. package/deployments/deployment-task-coordinator-router-v3-baseSepolia-fast.json +38 -0
  10. package/dist/adapters/adapter.d.ts +19 -8
  11. package/dist/adapters/local/adapter.d.ts +10 -9
  12. package/dist/adapters/local/adapter.js +52 -79
  13. package/dist/adapters/local/adapter.js.map +1 -1
  14. package/dist/adapters/mech/adapter.d.ts +37 -15
  15. package/dist/adapters/mech/adapter.js +557 -364
  16. package/dist/adapters/mech/adapter.js.map +1 -1
  17. package/dist/adapters/mech/contracts.d.ts +80 -20
  18. package/dist/adapters/mech/contracts.js +372 -100
  19. package/dist/adapters/mech/contracts.js.map +1 -1
  20. package/dist/adapters/mech/ipfs.d.ts +66 -12
  21. package/dist/adapters/mech/ipfs.js +165 -30
  22. package/dist/adapters/mech/ipfs.js.map +1 -1
  23. package/dist/adapters/mech/safe-revert.d.ts +40 -0
  24. package/dist/adapters/mech/safe-revert.js +261 -0
  25. package/dist/adapters/mech/safe-revert.js.map +1 -0
  26. package/dist/adapters/mech/safe.js +48 -22
  27. package/dist/adapters/mech/safe.js.map +1 -1
  28. package/dist/adapters/mech/task-subgraph.d.ts +23 -0
  29. package/dist/adapters/mech/task-subgraph.js +157 -0
  30. package/dist/adapters/mech/task-subgraph.js.map +1 -0
  31. package/dist/adapters/mech/types.d.ts +256 -84
  32. package/dist/adapters/mech/types.js +125 -50
  33. package/dist/adapters/mech/types.js.map +1 -1
  34. package/dist/agent/agent-ws.d.ts +57 -0
  35. package/dist/agent/agent-ws.js +301 -0
  36. package/dist/agent/agent-ws.js.map +1 -0
  37. package/dist/agent/auto-mode-detect.d.ts +6 -0
  38. package/dist/agent/auto-mode-detect.js +44 -0
  39. package/dist/agent/auto-mode-detect.js.map +1 -0
  40. package/dist/agent/operator-claude.d.ts +22 -0
  41. package/dist/agent/operator-claude.js +176 -0
  42. package/dist/agent/operator-claude.js.map +1 -0
  43. package/dist/api/admin-endpoint.d.ts +12 -0
  44. package/dist/api/admin-endpoint.js +71 -0
  45. package/dist/api/admin-endpoint.js.map +1 -0
  46. package/dist/api/agent-binding-endpoint.d.ts +26 -0
  47. package/dist/api/agent-binding-endpoint.js +28 -0
  48. package/dist/api/agent-binding-endpoint.js.map +1 -0
  49. package/dist/api/bootstrap-endpoint.d.ts +25 -0
  50. package/dist/api/bootstrap-endpoint.js +104 -0
  51. package/dist/api/bootstrap-endpoint.js.map +1 -0
  52. package/dist/api/captures.d.ts +22 -0
  53. package/dist/api/captures.js +88 -0
  54. package/dist/api/captures.js.map +1 -0
  55. package/dist/api/events-endpoint.d.ts +9 -0
  56. package/dist/api/events-endpoint.js +46 -0
  57. package/dist/api/events-endpoint.js.map +1 -0
  58. package/dist/api/fleet-build.d.ts +1 -1
  59. package/dist/api/fleet-build.js +17 -8
  60. package/dist/api/fleet-build.js.map +1 -1
  61. package/dist/api/gather-status.d.ts +16 -1
  62. package/dist/api/gather-status.js +194 -3
  63. package/dist/api/gather-status.js.map +1 -1
  64. package/dist/api/handshake.d.ts +17 -0
  65. package/dist/api/handshake.js +28 -0
  66. package/dist/api/handshake.js.map +1 -0
  67. package/dist/api/harness-status-endpoint.d.ts +20 -0
  68. package/dist/api/harness-status-endpoint.js +13 -0
  69. package/dist/api/harness-status-endpoint.js.map +1 -0
  70. package/dist/api/history-build.d.ts +2 -2
  71. package/dist/api/history-build.js +3 -3
  72. package/dist/api/history-build.js.map +1 -1
  73. package/dist/api/launcher-endpoints.d.ts +43 -0
  74. package/dist/api/launcher-endpoints.js +50 -0
  75. package/dist/api/launcher-endpoints.js.map +1 -0
  76. package/dist/api/launcher-status.d.ts +93 -0
  77. package/dist/api/launcher-status.js +84 -0
  78. package/dist/api/launcher-status.js.map +1 -0
  79. package/dist/api/launcher-tasks.d.ts +76 -0
  80. package/dist/api/launcher-tasks.js +127 -0
  81. package/dist/api/launcher-tasks.js.map +1 -0
  82. package/dist/api/leaderboard-api.d.ts +20 -0
  83. package/dist/api/leaderboard-api.js +18 -0
  84. package/dist/api/leaderboard-api.js.map +1 -0
  85. package/dist/api/operator-artifacts-endpoint.d.ts +19 -0
  86. package/dist/api/operator-artifacts-endpoint.js +271 -0
  87. package/dist/api/operator-artifacts-endpoint.js.map +1 -0
  88. package/dist/api/peers.js +21 -6
  89. package/dist/api/peers.js.map +1 -1
  90. package/dist/api/portfolio-v0-build.d.ts +16 -10
  91. package/dist/api/portfolio-v0-build.js +36 -31
  92. package/dist/api/portfolio-v0-build.js.map +1 -1
  93. package/dist/api/portfolio-v0-doctor.js +1 -1
  94. package/dist/api/portfolio-v0-doctor.js.map +1 -1
  95. package/dist/api/prediction-v1-build.d.ts +65 -0
  96. package/dist/api/prediction-v1-build.js +73 -0
  97. package/dist/api/prediction-v1-build.js.map +1 -0
  98. package/dist/api/rewards-build.js +3 -8
  99. package/dist/api/rewards-build.js.map +1 -1
  100. package/dist/api/server.d.ts +106 -1
  101. package/dist/api/server.js +396 -17
  102. package/dist/api/server.js.map +1 -1
  103. package/dist/api/setup-endpoints.d.ts +62 -0
  104. package/dist/api/setup-endpoints.js +752 -0
  105. package/dist/api/setup-endpoints.js.map +1 -0
  106. package/dist/api/solvernets-catalog-build.d.ts +47 -0
  107. package/dist/api/solvernets-catalog-build.js +19 -0
  108. package/dist/api/solvernets-catalog-build.js.map +1 -0
  109. package/dist/api/solvernets-endpoint.d.ts +15 -0
  110. package/dist/api/solvernets-endpoint.js +5 -0
  111. package/dist/api/solvernets-endpoint.js.map +1 -0
  112. package/dist/api/solvernets-endpoints.d.ts +104 -0
  113. package/dist/api/solvernets-endpoints.js +1121 -0
  114. package/dist/api/solvernets-endpoints.js.map +1 -0
  115. package/dist/api/status-build.d.ts +26 -2
  116. package/dist/api/status-build.js +46 -9
  117. package/dist/api/status-build.js.map +1 -1
  118. package/dist/api/status-rollup-build.d.ts +46 -1
  119. package/dist/api/status-rollup-build.js +174 -8
  120. package/dist/api/status-rollup-build.js.map +1 -1
  121. package/dist/api/stop-hook.d.ts +36 -0
  122. package/dist/api/stop-hook.js +77 -0
  123. package/dist/api/stop-hook.js.map +1 -0
  124. package/dist/api/task-runs-build.d.ts +27 -0
  125. package/dist/api/task-runs-build.js +46 -0
  126. package/dist/api/task-runs-build.js.map +1 -0
  127. package/dist/api/ui-token.d.ts +5 -0
  128. package/dist/api/ui-token.js +36 -0
  129. package/dist/api/ui-token.js.map +1 -0
  130. package/dist/bin/jinn-stop-hook.d.ts +9 -0
  131. package/dist/bin/jinn-stop-hook.js +52 -0
  132. package/dist/bin/jinn-stop-hook.js.map +1 -0
  133. package/dist/build-info.d.ts +32 -0
  134. package/dist/build-info.js +69 -0
  135. package/dist/build-info.js.map +1 -0
  136. package/dist/build-info.json +6 -0
  137. package/dist/build-meta.json +1 -1
  138. package/dist/captures/dedup.d.ts +27 -0
  139. package/dist/captures/dedup.js +48 -0
  140. package/dist/captures/dedup.js.map +1 -0
  141. package/dist/captures/index.d.ts +4 -0
  142. package/dist/captures/index.js +5 -0
  143. package/dist/captures/index.js.map +1 -0
  144. package/dist/captures/live-publisher.d.ts +33 -0
  145. package/dist/captures/live-publisher.js +101 -0
  146. package/dist/captures/live-publisher.js.map +1 -0
  147. package/dist/captures/publish.d.ts +83 -0
  148. package/dist/captures/publish.js +212 -0
  149. package/dist/captures/publish.js.map +1 -0
  150. package/dist/captures/rate-limit.d.ts +39 -0
  151. package/dist/captures/rate-limit.js +79 -0
  152. package/dist/captures/rate-limit.js.map +1 -0
  153. package/dist/cli/command.d.ts +9 -0
  154. package/dist/cli/commands/auth.js +6 -3
  155. package/dist/cli/commands/auth.js.map +1 -1
  156. package/dist/cli/commands/balance.d.ts +7 -0
  157. package/dist/cli/commands/balance.js +38 -32
  158. package/dist/cli/commands/balance.js.map +1 -1
  159. package/dist/cli/commands/bootstrap.d.ts +13 -1
  160. package/dist/cli/commands/bootstrap.js +150 -133
  161. package/dist/cli/commands/bootstrap.js.map +1 -1
  162. package/dist/cli/commands/capture.d.ts +33 -0
  163. package/dist/cli/commands/capture.js +345 -0
  164. package/dist/cli/commands/capture.js.map +1 -0
  165. package/dist/cli/commands/checkpoint.d.ts +85 -0
  166. package/dist/cli/commands/checkpoint.js +75 -0
  167. package/dist/cli/commands/checkpoint.js.map +1 -0
  168. package/dist/cli/commands/claim-rewards.js +14 -2
  169. package/dist/cli/commands/claim-rewards.js.map +1 -1
  170. package/dist/cli/commands/conformance.d.ts +12 -0
  171. package/dist/cli/commands/conformance.js +140 -0
  172. package/dist/cli/commands/conformance.js.map +1 -0
  173. package/dist/cli/commands/create.d.ts +22 -0
  174. package/dist/cli/commands/create.js +226 -0
  175. package/dist/cli/commands/create.js.map +1 -0
  176. package/dist/cli/commands/doctor.d.ts +49 -1
  177. package/dist/cli/commands/doctor.js +162 -134
  178. package/dist/cli/commands/doctor.js.map +1 -1
  179. package/dist/cli/commands/fleet-scale.d.ts +19 -1
  180. package/dist/cli/commands/fleet-scale.js +378 -361
  181. package/dist/cli/commands/fleet-scale.js.map +1 -1
  182. package/dist/cli/commands/fleet.d.ts +7 -0
  183. package/dist/cli/commands/fleet.js +39 -33
  184. package/dist/cli/commands/fleet.js.map +1 -1
  185. package/dist/cli/commands/fund-requirements.d.ts +14 -1
  186. package/dist/cli/commands/fund-requirements.js +182 -174
  187. package/dist/cli/commands/fund-requirements.js.map +1 -1
  188. package/dist/cli/commands/harnesses.d.ts +38 -0
  189. package/dist/cli/commands/harnesses.js +376 -0
  190. package/dist/cli/commands/harnesses.js.map +1 -0
  191. package/dist/cli/commands/history.d.ts +10 -1
  192. package/dist/cli/commands/history.js +68 -59
  193. package/dist/cli/commands/history.js.map +1 -1
  194. package/dist/cli/commands/init.js +4 -1
  195. package/dist/cli/commands/init.js.map +1 -1
  196. package/dist/cli/commands/integrations.d.ts +13 -0
  197. package/dist/cli/commands/integrations.js +1010 -0
  198. package/dist/cli/commands/integrations.js.map +1 -0
  199. package/dist/cli/commands/logs.d.ts +6 -1
  200. package/dist/cli/commands/logs.js +77 -70
  201. package/dist/cli/commands/logs.js.map +1 -1
  202. package/dist/cli/commands/migrate-agent-id.d.ts +26 -0
  203. package/dist/cli/commands/migrate-agent-id.js +164 -0
  204. package/dist/cli/commands/migrate-agent-id.js.map +1 -0
  205. package/dist/cli/commands/prediction-scoreboard.d.ts +10 -0
  206. package/dist/cli/commands/prediction-scoreboard.js +136 -0
  207. package/dist/cli/commands/prediction-scoreboard.js.map +1 -0
  208. package/dist/cli/commands/quickstart.d.ts +51 -1
  209. package/dist/cli/commands/quickstart.js +514 -296
  210. package/dist/cli/commands/quickstart.js.map +1 -1
  211. package/dist/cli/commands/rewards.d.ts +7 -0
  212. package/dist/cli/commands/rewards.js +46 -40
  213. package/dist/cli/commands/rewards.js.map +1 -1
  214. package/dist/cli/commands/run.d.ts +14 -1
  215. package/dist/cli/commands/run.js +243 -91
  216. package/dist/cli/commands/run.js.map +1 -1
  217. package/dist/cli/commands/solver-nets.js +231 -0
  218. package/dist/cli/commands/solver-nets.js.map +1 -0
  219. package/dist/cli/commands/solver-plugins.d.ts +9 -0
  220. package/dist/cli/commands/solver-plugins.js +186 -0
  221. package/dist/cli/commands/solver-plugins.js.map +1 -0
  222. package/dist/cli/commands/status.d.ts +13 -0
  223. package/dist/cli/commands/status.js +105 -34
  224. package/dist/cli/commands/status.js.map +1 -1
  225. package/dist/cli/commands/stop.js +87 -14
  226. package/dist/cli/commands/stop.js.map +1 -1
  227. package/dist/cli/commands/tasks.js +405 -0
  228. package/dist/cli/commands/tasks.js.map +1 -0
  229. package/dist/cli/commands/ui.d.ts +3 -0
  230. package/dist/cli/commands/ui.js +45 -0
  231. package/dist/cli/commands/ui.js.map +1 -0
  232. package/dist/cli/commands/update.d.ts +12 -0
  233. package/dist/cli/commands/update.js +321 -91
  234. package/dist/cli/commands/update.js.map +1 -1
  235. package/dist/cli/commands/version.js +3 -2
  236. package/dist/cli/commands/version.js.map +1 -1
  237. package/dist/cli/commands/withdraw.d.ts +21 -1
  238. package/dist/cli/commands/withdraw.js +175 -159
  239. package/dist/cli/commands/withdraw.js.map +1 -1
  240. package/dist/cli/deployment-digest.js +0 -5
  241. package/dist/cli/deployment-digest.js.map +1 -1
  242. package/dist/cli/execution-context.d.ts +1 -1
  243. package/dist/cli/execution-context.js +4 -4
  244. package/dist/cli/execution-context.js.map +1 -1
  245. package/dist/cli/help.js +8 -1
  246. package/dist/cli/help.js.map +1 -1
  247. package/dist/cli/index.d.ts +7 -0
  248. package/dist/cli/index.js +28 -6
  249. package/dist/cli/index.js.map +1 -1
  250. package/dist/cli/introspection-context.js +0 -1
  251. package/dist/cli/introspection-context.js.map +1 -1
  252. package/dist/cli/open-browser.d.ts +1 -0
  253. package/dist/cli/open-browser.js +18 -0
  254. package/dist/cli/open-browser.js.map +1 -0
  255. package/dist/cli/password.d.ts +3 -3
  256. package/dist/cli/password.js +6 -6
  257. package/dist/cli/password.js.map +1 -1
  258. package/dist/cli/task-native-readiness.d.ts +27 -0
  259. package/dist/cli/task-native-readiness.js +170 -0
  260. package/dist/cli/task-native-readiness.js.map +1 -0
  261. package/dist/config.d.ts +1897 -60
  262. package/dist/config.js +602 -33
  263. package/dist/config.js.map +1 -1
  264. package/dist/conformance/checks/artifacts.d.ts +37 -0
  265. package/dist/conformance/checks/artifacts.js +110 -0
  266. package/dist/conformance/checks/artifacts.js.map +1 -0
  267. package/dist/conformance/checks/envelope-schema.d.ts +17 -0
  268. package/dist/conformance/checks/envelope-schema.js +36 -0
  269. package/dist/conformance/checks/envelope-schema.js.map +1 -0
  270. package/dist/conformance/checks/hash-signature.d.ts +26 -0
  271. package/dist/conformance/checks/hash-signature.js +70 -0
  272. package/dist/conformance/checks/hash-signature.js.map +1 -0
  273. package/dist/conformance/checks/payload.d.ts +19 -0
  274. package/dist/conformance/checks/payload.js +52 -0
  275. package/dist/conformance/checks/payload.js.map +1 -0
  276. package/dist/conformance/checks/secret-scrub.d.ts +33 -0
  277. package/dist/conformance/checks/secret-scrub.js +118 -0
  278. package/dist/conformance/checks/secret-scrub.js.map +1 -0
  279. package/dist/conformance/checks/source-runtime.d.ts +43 -0
  280. package/dist/conformance/checks/source-runtime.js +68 -0
  281. package/dist/conformance/checks/source-runtime.js.map +1 -0
  282. package/dist/conformance/checks/source-static.d.ts +61 -0
  283. package/dist/conformance/checks/source-static.js +311 -0
  284. package/dist/conformance/checks/source-static.js.map +1 -0
  285. package/dist/conformance/checks/trajectory-chain.d.ts +18 -0
  286. package/dist/conformance/checks/trajectory-chain.js +51 -0
  287. package/dist/conformance/checks/trajectory-chain.js.map +1 -0
  288. package/dist/conformance/checks/trajectory-profile.d.ts +17 -0
  289. package/dist/conformance/checks/trajectory-profile.js +51 -0
  290. package/dist/conformance/checks/trajectory-profile.js.map +1 -0
  291. package/dist/conformance/checks/trajectory-schema.d.ts +20 -0
  292. package/dist/conformance/checks/trajectory-schema.js +40 -0
  293. package/dist/conformance/checks/trajectory-schema.js.map +1 -0
  294. package/dist/conformance/checks/verdict.d.ts +44 -0
  295. package/dist/conformance/checks/verdict.js +122 -0
  296. package/dist/conformance/checks/verdict.js.map +1 -0
  297. package/dist/conformance/harness.d.ts +32 -0
  298. package/dist/conformance/harness.js +227 -0
  299. package/dist/conformance/harness.js.map +1 -0
  300. package/dist/conformance/types.d.ts +88 -0
  301. package/dist/conformance/types.js +31 -0
  302. package/dist/conformance/types.js.map +1 -0
  303. package/dist/corpus/acquire.d.ts +42 -0
  304. package/dist/corpus/acquire.js +213 -0
  305. package/dist/corpus/acquire.js.map +1 -0
  306. package/dist/corpus/cache.d.ts +14 -0
  307. package/dist/corpus/cache.js +18 -0
  308. package/dist/corpus/cache.js.map +1 -0
  309. package/dist/corpus/envelope-projection.d.ts +12 -0
  310. package/dist/corpus/envelope-projection.js +110 -0
  311. package/dist/corpus/envelope-projection.js.map +1 -0
  312. package/dist/corpus/fetch.d.ts +9 -0
  313. package/dist/corpus/fetch.js +24 -0
  314. package/dist/corpus/fetch.js.map +1 -0
  315. package/dist/corpus/index.d.ts +19 -0
  316. package/dist/corpus/index.js +87 -0
  317. package/dist/corpus/index.js.map +1 -0
  318. package/dist/corpus/prediction-brier-scoreboard-report.d.ts +17 -0
  319. package/dist/corpus/prediction-brier-scoreboard-report.js +148 -0
  320. package/dist/corpus/prediction-brier-scoreboard-report.js.map +1 -0
  321. package/dist/corpus/prediction-brier-scoreboard.d.ts +56 -0
  322. package/dist/corpus/prediction-brier-scoreboard.js +269 -0
  323. package/dist/corpus/prediction-brier-scoreboard.js.map +1 -0
  324. package/dist/corpus/prediction-scoreable-verdicts.d.ts +4 -0
  325. package/dist/corpus/prediction-scoreable-verdicts.js +23 -0
  326. package/dist/corpus/prediction-scoreable-verdicts.js.map +1 -0
  327. package/dist/corpus/query.d.ts +17 -0
  328. package/dist/corpus/query.js +113 -0
  329. package/dist/corpus/query.js.map +1 -0
  330. package/dist/corpus/route-resolver.d.ts +16 -0
  331. package/dist/corpus/route-resolver.js +20 -0
  332. package/dist/corpus/route-resolver.js.map +1 -0
  333. package/dist/corpus/types.d.ts +151 -0
  334. package/dist/corpus/types.js +50 -0
  335. package/dist/corpus/types.js.map +1 -0
  336. package/dist/daemon/balance-topup-loop.js +2 -1
  337. package/dist/daemon/balance-topup-loop.js.map +1 -1
  338. package/dist/daemon/creator.d.ts +7 -7
  339. package/dist/daemon/creator.js +11 -14
  340. package/dist/daemon/creator.js.map +1 -1
  341. package/dist/daemon/daemon.d.ts +83 -31
  342. package/dist/daemon/daemon.js +206 -67
  343. package/dist/daemon/daemon.js.map +1 -1
  344. package/dist/daemon/delivery-watcher.js +50 -4
  345. package/dist/daemon/delivery-watcher.js.map +1 -1
  346. package/dist/daemon/freeze-fence.d.ts +42 -0
  347. package/dist/daemon/freeze-fence.js +71 -0
  348. package/dist/daemon/freeze-fence.js.map +1 -0
  349. package/dist/daemon/jinn-claim-loop-canonical.d.ts +207 -0
  350. package/dist/daemon/jinn-claim-loop-canonical.js +296 -0
  351. package/dist/daemon/jinn-claim-loop-canonical.js.map +1 -0
  352. package/dist/daemon/jinn-claim-loop-mock.d.ts +61 -0
  353. package/dist/daemon/jinn-claim-loop-mock.js +122 -0
  354. package/dist/daemon/jinn-claim-loop-mock.js.map +1 -0
  355. package/dist/daemon/jinn-claim-loop.d.ts +123 -0
  356. package/dist/daemon/jinn-claim-loop.js +256 -0
  357. package/dist/daemon/jinn-claim-loop.js.map +1 -0
  358. package/dist/daemon/reward-claim-loop.d.ts +2 -0
  359. package/dist/daemon/reward-claim-loop.js +32 -27
  360. package/dist/daemon/reward-claim-loop.js.map +1 -1
  361. package/dist/dashboard/assets/index-DBPsa50k.js +76 -0
  362. package/dist/dashboard/assets/index-D_NMfDfV.css +32 -0
  363. package/dist/dashboard/index.html +18 -74
  364. package/dist/earning/agent-wallet-binding.d.ts +133 -0
  365. package/dist/earning/agent-wallet-binding.js +202 -0
  366. package/dist/earning/agent-wallet-binding.js.map +1 -0
  367. package/dist/earning/bootstrap.d.ts +88 -1
  368. package/dist/earning/bootstrap.js +409 -56
  369. package/dist/earning/bootstrap.js.map +1 -1
  370. package/dist/earning/contracts.d.ts +328 -6
  371. package/dist/earning/contracts.js +295 -14
  372. package/dist/earning/contracts.js.map +1 -1
  373. package/dist/earning/evidence-simhash.d.ts +1 -1
  374. package/dist/earning/faucet.d.ts +31 -0
  375. package/dist/earning/faucet.js +37 -0
  376. package/dist/earning/faucet.js.map +1 -1
  377. package/dist/earning/funding-plan.d.ts +89 -0
  378. package/dist/earning/funding-plan.js +202 -0
  379. package/dist/earning/funding-plan.js.map +1 -0
  380. package/dist/earning/migrate-agent-id.d.ts +129 -0
  381. package/dist/earning/migrate-agent-id.js +256 -0
  382. package/dist/earning/migrate-agent-id.js.map +1 -0
  383. package/dist/earning/orphan-sweep.d.ts +14 -0
  384. package/dist/earning/orphan-sweep.js +63 -2
  385. package/dist/earning/orphan-sweep.js.map +1 -1
  386. package/dist/earning/reconcile.d.ts +2 -0
  387. package/dist/earning/reconcile.js +30 -0
  388. package/dist/earning/reconcile.js.map +1 -1
  389. package/dist/earning/safe-adapter.js +45 -3
  390. package/dist/earning/safe-adapter.js.map +1 -1
  391. package/dist/earning/stolas-claim.d.ts +86 -6
  392. package/dist/earning/stolas-claim.js +123 -9
  393. package/dist/earning/stolas-claim.js.map +1 -1
  394. package/dist/earning/store.d.ts +47 -0
  395. package/dist/earning/store.js +113 -1
  396. package/dist/earning/store.js.map +1 -1
  397. package/dist/earning/testnet-setup-migration.d.ts +32 -0
  398. package/dist/earning/testnet-setup-migration.js +214 -0
  399. package/dist/earning/testnet-setup-migration.js.map +1 -0
  400. package/dist/earning/types.d.ts +57 -9
  401. package/dist/earning/types.js +51 -2
  402. package/dist/earning/types.js.map +1 -1
  403. package/dist/earning/viem-clients.d.ts +20 -0
  404. package/dist/earning/viem-clients.js +32 -1
  405. package/dist/earning/viem-clients.js.map +1 -1
  406. package/dist/erc8004/abis.d.ts +423 -0
  407. package/dist/erc8004/abis.js +265 -0
  408. package/dist/erc8004/abis.js.map +1 -0
  409. package/dist/erc8004/addresses.d.ts +40 -0
  410. package/dist/erc8004/addresses.js +64 -0
  411. package/dist/erc8004/addresses.js.map +1 -0
  412. package/dist/erc8004/identity.d.ts +273 -0
  413. package/dist/erc8004/identity.js +405 -0
  414. package/dist/erc8004/identity.js.map +1 -0
  415. package/dist/erc8004/index.d.ts +13 -0
  416. package/dist/erc8004/index.js +20 -0
  417. package/dist/erc8004/index.js.map +1 -0
  418. package/dist/erc8004/reputation.d.ts +349 -0
  419. package/dist/erc8004/reputation.js +464 -0
  420. package/dist/erc8004/reputation.js.map +1 -0
  421. package/dist/erc8004/subgraph.d.ts +46 -0
  422. package/dist/erc8004/subgraph.js +37 -0
  423. package/dist/erc8004/subgraph.js.map +1 -0
  424. package/dist/erc8004/validation.d.ts +145 -0
  425. package/dist/erc8004/validation.js +219 -0
  426. package/dist/erc8004/validation.js.map +1 -0
  427. package/dist/errors/persisted-bootstrap-error.d.ts +4 -0
  428. package/dist/errors/persisted-bootstrap-error.js +50 -0
  429. package/dist/errors/persisted-bootstrap-error.js.map +1 -0
  430. package/dist/events/emitter.d.ts +12 -0
  431. package/dist/events/emitter.js +23 -0
  432. package/dist/events/emitter.js.map +1 -0
  433. package/dist/events/ring-buffer.d.ts +25 -0
  434. package/dist/events/ring-buffer.js +46 -0
  435. package/dist/events/ring-buffer.js.map +1 -0
  436. package/dist/events/types.d.ts +42 -0
  437. package/dist/events/types.js +28 -0
  438. package/dist/events/types.js.map +1 -0
  439. package/dist/harnesses/capability/index.d.ts +82 -0
  440. package/dist/harnesses/capability/index.js +12 -0
  441. package/dist/harnesses/capability/index.js.map +1 -0
  442. package/dist/harnesses/capability/scoped-rpc.d.ts +12 -0
  443. package/dist/harnesses/capability/scoped-rpc.js +34 -0
  444. package/dist/harnesses/capability/scoped-rpc.js.map +1 -0
  445. package/dist/harnesses/capability/scoped-secrets.d.ts +8 -0
  446. package/dist/harnesses/capability/scoped-secrets.js +10 -0
  447. package/dist/harnesses/capability/scoped-secrets.js.map +1 -0
  448. package/dist/harnesses/capability/scoped-signer.d.ts +46 -0
  449. package/dist/harnesses/capability/scoped-signer.js +73 -0
  450. package/dist/harnesses/capability/scoped-signer.js.map +1 -0
  451. package/dist/harnesses/engine/artifact-scrub.d.ts +12 -0
  452. package/dist/harnesses/engine/artifact-scrub.js +104 -0
  453. package/dist/harnesses/engine/artifact-scrub.js.map +1 -0
  454. package/dist/harnesses/engine/canonical-json.d.ts +1 -0
  455. package/dist/harnesses/engine/canonical-json.js +66 -0
  456. package/dist/harnesses/engine/canonical-json.js.map +1 -0
  457. package/dist/harnesses/engine/delivery.d.ts +58 -0
  458. package/dist/harnesses/engine/delivery.js +67 -0
  459. package/dist/harnesses/engine/delivery.js.map +1 -0
  460. package/dist/harnesses/engine/engine.d.ts +519 -0
  461. package/dist/harnesses/engine/engine.js +1588 -0
  462. package/dist/harnesses/engine/engine.js.map +1 -0
  463. package/dist/harnesses/engine/envelope-assembly.d.ts +73 -0
  464. package/dist/harnesses/engine/envelope-assembly.js +60 -0
  465. package/dist/harnesses/engine/envelope-assembly.js.map +1 -0
  466. package/dist/harnesses/engine/packaging.d.ts +99 -0
  467. package/dist/harnesses/engine/packaging.js +424 -0
  468. package/dist/harnesses/engine/packaging.js.map +1 -0
  469. package/dist/harnesses/engine/persistence.d.ts +198 -0
  470. package/dist/harnesses/engine/persistence.js +443 -0
  471. package/dist/harnesses/engine/persistence.js.map +1 -0
  472. package/dist/harnesses/engine/recovery.d.ts +22 -0
  473. package/dist/harnesses/engine/recovery.js +24 -0
  474. package/dist/harnesses/engine/recovery.js.map +1 -0
  475. package/dist/harnesses/engine/registry.d.ts +55 -0
  476. package/dist/harnesses/engine/registry.js +66 -0
  477. package/dist/harnesses/engine/registry.js.map +1 -0
  478. package/dist/harnesses/engine/signing.d.ts +30 -0
  479. package/dist/harnesses/engine/signing.js +39 -0
  480. package/dist/harnesses/engine/signing.js.map +1 -0
  481. package/dist/harnesses/engine/state.d.ts +42 -0
  482. package/dist/harnesses/engine/state.js +87 -0
  483. package/dist/harnesses/engine/state.js.map +1 -0
  484. package/dist/harnesses/engine/validate-manifest.d.ts +23 -0
  485. package/dist/harnesses/engine/validate-manifest.js +63 -0
  486. package/dist/harnesses/engine/validate-manifest.js.map +1 -0
  487. package/dist/harnesses/engine/verification-stub.d.ts +18 -0
  488. package/dist/harnesses/engine/verification-stub.js +18 -0
  489. package/dist/harnesses/engine/verification-stub.js.map +1 -0
  490. package/dist/harnesses/external-impls/index.d.ts +3 -0
  491. package/dist/harnesses/external-impls/index.js +2 -0
  492. package/dist/harnesses/external-impls/index.js.map +1 -0
  493. package/dist/harnesses/external-impls/loader.d.ts +50 -0
  494. package/dist/harnesses/external-impls/loader.js +139 -0
  495. package/dist/harnesses/external-impls/loader.js.map +1 -0
  496. package/dist/harnesses/external-impls/package-hash.d.ts +26 -0
  497. package/dist/harnesses/external-impls/package-hash.js +102 -0
  498. package/dist/harnesses/external-impls/package-hash.js.map +1 -0
  499. package/dist/harnesses/external-impls/types.d.ts +42 -0
  500. package/dist/harnesses/external-impls/types.js +10 -0
  501. package/dist/harnesses/external-impls/types.js.map +1 -0
  502. package/dist/harnesses/freeze.d.ts +34 -0
  503. package/dist/harnesses/freeze.js +60 -0
  504. package/dist/harnesses/freeze.js.map +1 -0
  505. package/dist/harnesses/impls/claude-code-learner/adapters/claude-code.d.ts +57 -0
  506. package/dist/harnesses/impls/claude-code-learner/adapters/claude-code.js +239 -0
  507. package/dist/harnesses/impls/claude-code-learner/adapters/claude-code.js.map +1 -0
  508. package/dist/harnesses/impls/claude-code-learner/adapters/codex-code.d.ts +31 -0
  509. package/dist/harnesses/impls/claude-code-learner/adapters/codex-code.js +257 -0
  510. package/dist/harnesses/impls/claude-code-learner/adapters/codex-code.js.map +1 -0
  511. package/dist/harnesses/impls/claude-code-learner/adapters/codex-workspace.d.ts +21 -0
  512. package/dist/harnesses/impls/claude-code-learner/adapters/codex-workspace.js +193 -0
  513. package/dist/harnesses/impls/claude-code-learner/adapters/codex-workspace.js.map +1 -0
  514. package/dist/harnesses/impls/claude-code-learner/harness.d.ts +22 -0
  515. package/dist/harnesses/impls/claude-code-learner/harness.js +62 -0
  516. package/dist/harnesses/impls/claude-code-learner/harness.js.map +1 -0
  517. package/dist/harnesses/impls/claude-code-learner/harvest.d.ts +20 -0
  518. package/dist/harnesses/impls/claude-code-learner/harvest.js +510 -0
  519. package/dist/harnesses/impls/claude-code-learner/harvest.js.map +1 -0
  520. package/dist/harnesses/impls/claude-code-learner/index.d.ts +18 -0
  521. package/dist/harnesses/impls/claude-code-learner/index.js +15 -0
  522. package/dist/harnesses/impls/claude-code-learner/index.js.map +1 -0
  523. package/dist/harnesses/impls/claude-code-learner/plugin-path.d.ts +14 -0
  524. package/dist/harnesses/impls/claude-code-learner/plugin-path.js +30 -0
  525. package/dist/harnesses/impls/claude-code-learner/plugin-path.js.map +1 -0
  526. package/dist/harnesses/impls/claude-code-learner/test-utils/fake-plugin-outputs.d.ts +50 -0
  527. package/dist/harnesses/impls/claude-code-learner/test-utils/fake-plugin-outputs.js +192 -0
  528. package/dist/harnesses/impls/claude-code-learner/test-utils/fake-plugin-outputs.js.map +1 -0
  529. package/dist/harnesses/impls/claude-code-learner/test-utils/noop-adapter.d.ts +22 -0
  530. package/dist/harnesses/impls/claude-code-learner/test-utils/noop-adapter.js +35 -0
  531. package/dist/harnesses/impls/claude-code-learner/test-utils/noop-adapter.js.map +1 -0
  532. package/dist/harnesses/impls/claude-code-learner/types.d.ts +114 -0
  533. package/dist/harnesses/impls/claude-code-learner/types.js.map +1 -0
  534. package/dist/harnesses/impls/claude-mcp-hyperliquid/api-wallet.d.ts +64 -0
  535. package/dist/harnesses/impls/claude-mcp-hyperliquid/api-wallet.js.map +1 -0
  536. package/dist/harnesses/impls/claude-mcp-hyperliquid/index.d.ts +106 -0
  537. package/dist/harnesses/impls/claude-mcp-hyperliquid/index.js +723 -0
  538. package/dist/harnesses/impls/claude-mcp-hyperliquid/index.js.map +1 -0
  539. package/dist/harnesses/impls/claude-mcp-hyperliquid/mcp-tools.js.map +1 -0
  540. package/dist/harnesses/impls/claude-mcp-hyperliquid/safety-rails.js.map +1 -0
  541. package/dist/harnesses/impls/claude-mcp-hyperliquid/session-orchestrator.d.ts +104 -0
  542. package/dist/harnesses/impls/claude-mcp-hyperliquid/session-orchestrator.js +264 -0
  543. package/dist/harnesses/impls/claude-mcp-hyperliquid/session-orchestrator.js.map +1 -0
  544. package/dist/harnesses/impls/claude-mcp-prediction/index.d.ts +44 -0
  545. package/dist/harnesses/impls/claude-mcp-prediction/index.js +250 -0
  546. package/dist/harnesses/impls/claude-mcp-prediction/index.js.map +1 -0
  547. package/dist/harnesses/impls/claude-mcp-prediction/mcp-tools.js +135 -0
  548. package/dist/harnesses/impls/claude-mcp-prediction/mcp-tools.js.map +1 -0
  549. package/dist/harnesses/impls/claude-mcp-prediction/prompt.d.ts +8 -0
  550. package/dist/harnesses/impls/claude-mcp-prediction/prompt.js +54 -0
  551. package/dist/harnesses/impls/claude-mcp-prediction/prompt.js.map +1 -0
  552. package/dist/harnesses/impls/claude-mcp-prediction/session-orchestrator.d.ts +43 -0
  553. package/dist/harnesses/impls/claude-mcp-prediction/session-orchestrator.js +21 -0
  554. package/dist/harnesses/impls/claude-mcp-prediction/session-orchestrator.js.map +1 -0
  555. package/dist/harnesses/impls/claude-mcp-prediction/types.d.ts +84 -0
  556. package/dist/harnesses/impls/claude-mcp-prediction/types.js +6 -0
  557. package/dist/harnesses/impls/claude-mcp-prediction/types.js.map +1 -0
  558. package/dist/harnesses/impls/claude-mcp-prediction-apy/index.d.ts +36 -0
  559. package/dist/harnesses/impls/claude-mcp-prediction-apy/index.js +241 -0
  560. package/dist/harnesses/impls/claude-mcp-prediction-apy/index.js.map +1 -0
  561. package/dist/harnesses/impls/claude-mcp-prediction-apy/mcp-tools.js +136 -0
  562. package/dist/harnesses/impls/claude-mcp-prediction-apy/mcp-tools.js.map +1 -0
  563. package/dist/harnesses/impls/claude-mcp-prediction-apy/prompt.d.ts +7 -0
  564. package/dist/harnesses/impls/claude-mcp-prediction-apy/prompt.js +46 -0
  565. package/dist/harnesses/impls/claude-mcp-prediction-apy/prompt.js.map +1 -0
  566. package/dist/harnesses/impls/claude-mcp-prediction-apy/session-orchestrator.d.ts +37 -0
  567. package/dist/harnesses/impls/claude-mcp-prediction-apy/session-orchestrator.js +19 -0
  568. package/dist/harnesses/impls/claude-mcp-prediction-apy/session-orchestrator.js.map +1 -0
  569. package/dist/harnesses/impls/claude-mcp-prediction-apy/types.d.ts +64 -0
  570. package/dist/harnesses/impls/claude-mcp-prediction-apy/types.js +6 -0
  571. package/dist/harnesses/impls/claude-mcp-prediction-apy/types.js.map +1 -0
  572. package/dist/harnesses/impls/claude-mcp-shared/single-session-orchestrator.d.ts +84 -0
  573. package/dist/harnesses/impls/claude-mcp-shared/single-session-orchestrator.js +206 -0
  574. package/dist/harnesses/impls/claude-mcp-shared/single-session-orchestrator.js.map +1 -0
  575. package/dist/harnesses/impls/evaluation-context.d.ts +23 -0
  576. package/dist/harnesses/impls/evaluation-context.js +25 -0
  577. package/dist/harnesses/impls/evaluation-context.js.map +1 -0
  578. package/dist/harnesses/impls/index.d.ts +84 -0
  579. package/dist/harnesses/impls/index.js +136 -0
  580. package/dist/harnesses/impls/index.js.map +1 -0
  581. package/dist/harnesses/impls/legacy-claude/index.d.ts +66 -0
  582. package/dist/harnesses/impls/legacy-claude/index.js +168 -0
  583. package/dist/harnesses/impls/legacy-claude/index.js.map +1 -0
  584. package/dist/harnesses/impls/portfolio-v0-evaluator/canonical-metrics.d.ts +68 -0
  585. package/dist/harnesses/impls/portfolio-v0-evaluator/canonical-metrics.js +117 -0
  586. package/dist/harnesses/impls/portfolio-v0-evaluator/canonical-metrics.js.map +1 -0
  587. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/availability.js.map +1 -0
  588. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/consistency.d.ts +78 -0
  589. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/consistency.js +274 -0
  590. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/consistency.js.map +1 -0
  591. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/eligibility.d.ts +23 -0
  592. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/eligibility.js +49 -0
  593. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/eligibility.js.map +1 -0
  594. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/integrity.d.ts +25 -0
  595. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/integrity.js +44 -0
  596. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/integrity.js.map +1 -0
  597. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/spec.d.ts +17 -0
  598. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/spec.js +43 -0
  599. package/dist/harnesses/impls/portfolio-v0-evaluator/checks/spec.js.map +1 -0
  600. package/dist/harnesses/impls/portfolio-v0-evaluator/index.d.ts +44 -0
  601. package/dist/harnesses/impls/portfolio-v0-evaluator/index.js +569 -0
  602. package/dist/harnesses/impls/portfolio-v0-evaluator/index.js.map +1 -0
  603. package/dist/harnesses/impls/portfolio-v0-evaluator/score.js.map +1 -0
  604. package/dist/harnesses/impls/portfolio-v0-evaluator/types.d.ts +34 -0
  605. package/dist/harnesses/impls/portfolio-v0-evaluator/types.js.map +1 -0
  606. package/dist/harnesses/impls/prediction-apy-v0-baseline/index.d.ts +42 -0
  607. package/dist/harnesses/impls/prediction-apy-v0-baseline/index.js +114 -0
  608. package/dist/harnesses/impls/prediction-apy-v0-baseline/index.js.map +1 -0
  609. package/dist/harnesses/impls/prediction-apy-v0-baseline/strategy.js.map +1 -0
  610. package/dist/harnesses/impls/prediction-apy-v0-baseline/types.js.map +1 -0
  611. package/dist/harnesses/impls/prediction-apy-v0-evaluator/canonical-metrics.d.ts +6 -0
  612. package/dist/harnesses/impls/prediction-apy-v0-evaluator/canonical-metrics.js +11 -0
  613. package/dist/harnesses/impls/prediction-apy-v0-evaluator/canonical-metrics.js.map +1 -0
  614. package/dist/harnesses/impls/prediction-apy-v0-evaluator/index.d.ts +42 -0
  615. package/dist/harnesses/impls/prediction-apy-v0-evaluator/index.js +346 -0
  616. package/dist/harnesses/impls/prediction-apy-v0-evaluator/index.js.map +1 -0
  617. package/dist/harnesses/impls/prediction-apy-v0-evaluator/parse-submission.d.ts +16 -0
  618. package/dist/harnesses/impls/prediction-apy-v0-evaluator/parse-submission.js +22 -0
  619. package/dist/harnesses/impls/prediction-apy-v0-evaluator/parse-submission.js.map +1 -0
  620. package/dist/harnesses/impls/prediction-apy-v0-evaluator/score.js.map +1 -0
  621. package/dist/harnesses/impls/prediction-apy-v0-evaluator/types.js.map +1 -0
  622. package/dist/harnesses/impls/prediction-v0-baseline/index.d.ts +33 -0
  623. package/dist/harnesses/impls/prediction-v0-baseline/index.js +109 -0
  624. package/dist/harnesses/impls/prediction-v0-baseline/index.js.map +1 -0
  625. package/dist/harnesses/impls/prediction-v0-baseline/strategy.d.ts +8 -0
  626. package/dist/harnesses/impls/prediction-v0-baseline/strategy.js +41 -0
  627. package/dist/harnesses/impls/prediction-v0-baseline/strategy.js.map +1 -0
  628. package/dist/harnesses/impls/prediction-v0-baseline/types.d.ts +7 -0
  629. package/dist/harnesses/impls/prediction-v0-baseline/types.js.map +1 -0
  630. package/dist/harnesses/impls/prediction-v0-evaluator/canonical-metrics.d.ts +20 -0
  631. package/dist/harnesses/impls/prediction-v0-evaluator/canonical-metrics.js.map +1 -0
  632. package/dist/harnesses/impls/prediction-v0-evaluator/checks/availability.d.ts +9 -0
  633. package/dist/harnesses/impls/prediction-v0-evaluator/checks/availability.js.map +1 -0
  634. package/dist/harnesses/impls/prediction-v0-evaluator/checks/eligibility.d.ts +3 -0
  635. package/dist/harnesses/impls/prediction-v0-evaluator/checks/eligibility.js.map +1 -0
  636. package/dist/harnesses/impls/prediction-v0-evaluator/checks/integrity.d.ts +15 -0
  637. package/dist/harnesses/impls/prediction-v0-evaluator/checks/integrity.js +111 -0
  638. package/dist/harnesses/impls/prediction-v0-evaluator/checks/integrity.js.map +1 -0
  639. package/dist/harnesses/impls/prediction-v0-evaluator/checks/spec.d.ts +5 -0
  640. package/dist/harnesses/impls/prediction-v0-evaluator/checks/spec.js.map +1 -0
  641. package/dist/harnesses/impls/prediction-v0-evaluator/index.d.ts +36 -0
  642. package/dist/harnesses/impls/prediction-v0-evaluator/index.js +342 -0
  643. package/dist/harnesses/impls/prediction-v0-evaluator/index.js.map +1 -0
  644. package/dist/harnesses/impls/prediction-v0-evaluator/score.js.map +1 -0
  645. package/dist/harnesses/impls/prediction-v0-evaluator/types.js +2 -0
  646. package/dist/harnesses/impls/prediction-v0-evaluator/types.js.map +1 -0
  647. package/dist/harnesses/impls/prediction-v1-baseline/index.d.ts +31 -0
  648. package/dist/harnesses/impls/prediction-v1-baseline/index.js +79 -0
  649. package/dist/harnesses/impls/prediction-v1-baseline/index.js.map +1 -0
  650. package/dist/harnesses/impls/prediction-v1-evaluator/index.d.ts +32 -0
  651. package/dist/harnesses/impls/prediction-v1-evaluator/index.js +219 -0
  652. package/dist/harnesses/impls/prediction-v1-evaluator/index.js.map +1 -0
  653. package/dist/harnesses/impls/session-derived-evaluator/index.d.ts +4 -0
  654. package/dist/harnesses/impls/session-derived-evaluator/index.js +5 -0
  655. package/dist/harnesses/impls/session-derived-evaluator/index.js.map +1 -0
  656. package/dist/harnesses/impls/session-derived-evaluator/llm-judge.d.ts +16 -0
  657. package/dist/harnesses/impls/session-derived-evaluator/llm-judge.js +16 -0
  658. package/dist/harnesses/impls/session-derived-evaluator/llm-judge.js.map +1 -0
  659. package/dist/harnesses/impls/session-derived-evaluator/signals.d.ts +13 -0
  660. package/dist/harnesses/impls/session-derived-evaluator/signals.js +15 -0
  661. package/dist/harnesses/impls/session-derived-evaluator/signals.js.map +1 -0
  662. package/dist/harnesses/impls/session-derived-evaluator/structural-similarity.d.ts +7 -0
  663. package/dist/harnesses/impls/session-derived-evaluator/structural-similarity.js +28 -0
  664. package/dist/harnesses/impls/session-derived-evaluator/structural-similarity.js.map +1 -0
  665. package/dist/harnesses/impls/session-derived-evaluator/test-suite-rerun.d.ts +15 -0
  666. package/dist/harnesses/impls/session-derived-evaluator/test-suite-rerun.js +17 -0
  667. package/dist/harnesses/impls/session-derived-evaluator/test-suite-rerun.js.map +1 -0
  668. package/dist/harnesses/impls/swe-rebench-v2-evaluator/eval-runner.d.ts +20 -0
  669. package/dist/harnesses/impls/swe-rebench-v2-evaluator/eval-runner.js +107 -0
  670. package/dist/harnesses/impls/swe-rebench-v2-evaluator/eval-runner.js.map +1 -0
  671. package/dist/harnesses/impls/swe-rebench-v2-evaluator/harness.d.ts +74 -0
  672. package/dist/harnesses/impls/swe-rebench-v2-evaluator/harness.js +288 -0
  673. package/dist/harnesses/impls/swe-rebench-v2-evaluator/harness.js.map +1 -0
  674. package/dist/harnesses/impls/swe-rebench-v2-evaluator/hf-fetcher.d.ts +33 -0
  675. package/dist/harnesses/impls/swe-rebench-v2-evaluator/hf-fetcher.js +96 -0
  676. package/dist/harnesses/impls/swe-rebench-v2-evaluator/hf-fetcher.js.map +1 -0
  677. package/dist/harnesses/impls/swe-rebench-v2-evaluator/index.d.ts +61 -0
  678. package/dist/harnesses/impls/swe-rebench-v2-evaluator/index.js +42 -0
  679. package/dist/harnesses/impls/swe-rebench-v2-evaluator/index.js.map +1 -0
  680. package/dist/harnesses/manifest/index.d.ts +3 -0
  681. package/dist/harnesses/manifest/index.js +3 -0
  682. package/dist/harnesses/manifest/index.js.map +1 -0
  683. package/dist/harnesses/manifest/load.d.ts +7 -0
  684. package/dist/harnesses/manifest/load.js +49 -0
  685. package/dist/harnesses/manifest/load.js.map +1 -0
  686. package/dist/harnesses/manifest/types.d.ts +75 -0
  687. package/dist/harnesses/manifest/types.js +8 -0
  688. package/dist/harnesses/manifest/types.js.map +1 -0
  689. package/dist/harnesses/manifest/verify.d.ts +15 -0
  690. package/dist/harnesses/manifest/verify.js +53 -0
  691. package/dist/harnesses/manifest/verify.js.map +1 -0
  692. package/dist/harnesses/mode-state.d.ts +7 -0
  693. package/dist/harnesses/mode-state.js +43 -0
  694. package/dist/harnesses/mode-state.js.map +1 -0
  695. package/dist/harnesses/names.d.ts +6 -0
  696. package/dist/harnesses/names.js +24 -0
  697. package/dist/harnesses/names.js.map +1 -0
  698. package/dist/harnesses/types.d.ts +276 -0
  699. package/dist/harnesses/types.js +28 -0
  700. package/dist/harnesses/types.js.map +1 -0
  701. package/dist/index.d.ts +1 -1
  702. package/dist/main.d.ts +17 -2
  703. package/dist/main.js +1593 -147
  704. package/dist/main.js.map +1 -1
  705. package/dist/mcp/acquire-artifact.d.ts +41 -0
  706. package/dist/mcp/acquire-artifact.js +168 -0
  707. package/dist/mcp/acquire-artifact.js.map +1 -0
  708. package/dist/mcp/operator-server.d.ts +21 -4
  709. package/dist/mcp/operator-server.js +505 -30
  710. package/dist/mcp/operator-server.js.map +1 -1
  711. package/dist/mcp/search-records.d.ts +94 -0
  712. package/dist/mcp/search-records.js +396 -0
  713. package/dist/mcp/search-records.js.map +1 -0
  714. package/dist/mcp/server.d.ts +4 -4
  715. package/dist/mcp/server.js +240 -61
  716. package/dist/mcp/server.js.map +1 -1
  717. package/dist/observability/emit-event.d.ts +2 -2
  718. package/dist/observability/emit-event.js +2 -2
  719. package/dist/observability/emit-event.js.map +1 -1
  720. package/dist/operator-errors.d.ts +14 -0
  721. package/dist/operator-errors.js +39 -10
  722. package/dist/operator-errors.js.map +1 -1
  723. package/dist/plugins/digest.d.ts +1 -0
  724. package/dist/plugins/digest.js +28 -0
  725. package/dist/plugins/digest.js.map +1 -0
  726. package/dist/plugins/index.d.ts +6 -0
  727. package/dist/plugins/index.js +6 -0
  728. package/dist/plugins/index.js.map +1 -0
  729. package/dist/plugins/manifest.d.ts +7 -0
  730. package/dist/plugins/manifest.js +22 -0
  731. package/dist/plugins/manifest.js.map +1 -0
  732. package/dist/plugins/registry.d.ts +9 -0
  733. package/dist/plugins/registry.js +24 -0
  734. package/dist/plugins/registry.js.map +1 -0
  735. package/dist/plugins/resolvers.d.ts +2 -0
  736. package/dist/plugins/resolvers.js +126 -0
  737. package/dist/plugins/resolvers.js.map +1 -0
  738. package/dist/plugins/types.d.ts +35 -0
  739. package/dist/plugins/types.js +2 -0
  740. package/dist/plugins/types.js.map +1 -0
  741. package/dist/plugins/validator.d.ts +3 -0
  742. package/dist/plugins/validator.js +50 -0
  743. package/dist/plugins/validator.js.map +1 -0
  744. package/dist/preflight/claude-auth.d.ts +14 -12
  745. package/dist/preflight/claude-auth.js +23 -37
  746. package/dist/preflight/claude-auth.js.map +1 -1
  747. package/dist/preflight/claude-required.d.ts +8 -0
  748. package/dist/preflight/claude-required.js +17 -0
  749. package/dist/preflight/claude-required.js.map +1 -0
  750. package/dist/runner/claude.d.ts +3 -3
  751. package/dist/runner/claude.js +62 -26
  752. package/dist/runner/claude.js.map +1 -1
  753. package/dist/runner/runner.d.ts +29 -2
  754. package/dist/runner/simple.d.ts +2 -2
  755. package/dist/runner/simple.js +2 -2
  756. package/dist/runner/simple.js.map +1 -1
  757. package/dist/scripts/donation-consumption-acceptance.d.ts +71 -0
  758. package/dist/scripts/donation-consumption-acceptance.js +1117 -0
  759. package/dist/scripts/donation-consumption-acceptance.js.map +1 -0
  760. package/dist/scripts/fix-node-pty.mjs +113 -0
  761. package/dist/setup/claude-code-install.d.ts +19 -0
  762. package/dist/setup/claude-code-install.js +51 -0
  763. package/dist/setup/claude-code-install.js.map +1 -0
  764. package/dist/setup-mode.d.ts +34 -0
  765. package/dist/setup-mode.js +49 -0
  766. package/dist/setup-mode.js.map +1 -0
  767. package/dist/solver-nets/contracts.d.ts +2 -0
  768. package/dist/solver-nets/contracts.js +2 -0
  769. package/dist/solver-nets/contracts.js.map +1 -0
  770. package/dist/solver-nets/prediction-operator-ux.d.ts +112 -0
  771. package/dist/solver-nets/prediction-operator-ux.js +463 -0
  772. package/dist/solver-nets/prediction-operator-ux.js.map +1 -0
  773. package/dist/solver-nets/registry.d.ts +64 -0
  774. package/dist/solver-nets/registry.js +218 -0
  775. package/dist/solver-nets/registry.js.map +1 -0
  776. package/dist/solver-types/_session-derived-distill.d.ts +28 -0
  777. package/dist/solver-types/_session-derived-distill.js +52 -0
  778. package/dist/solver-types/_session-derived-distill.js.map +1 -0
  779. package/dist/solver-types/_session-derived-pool.d.ts +10 -0
  780. package/dist/solver-types/_session-derived-pool.js +27 -0
  781. package/dist/solver-types/_session-derived-pool.js.map +1 -0
  782. package/dist/solver-types/_session-derived-state.d.ts +17 -0
  783. package/dist/solver-types/_session-derived-state.js +25 -0
  784. package/dist/solver-types/_session-derived-state.js.map +1 -0
  785. package/dist/solver-types/_swe-rebench-v2-aggregate.d.ts +31 -0
  786. package/dist/solver-types/_swe-rebench-v2-aggregate.js +49 -0
  787. package/dist/solver-types/_swe-rebench-v2-aggregate.js.map +1 -0
  788. package/dist/solver-types/_swe-rebench-v2-escrow.d.ts +27 -0
  789. package/dist/solver-types/_swe-rebench-v2-escrow.js +26 -0
  790. package/dist/solver-types/_swe-rebench-v2-escrow.js.map +1 -0
  791. package/dist/solver-types/_swe-rebench-v2-pool.d.ts +51 -0
  792. package/dist/solver-types/_swe-rebench-v2-pool.js +72 -0
  793. package/dist/solver-types/_swe-rebench-v2-pool.js.map +1 -0
  794. package/dist/solver-types/_swe-rebench-v2-state.d.ts +24 -0
  795. package/dist/solver-types/_swe-rebench-v2-state.js +54 -0
  796. package/dist/solver-types/_swe-rebench-v2-state.js.map +1 -0
  797. package/dist/solver-types/constants.d.ts +5 -0
  798. package/dist/solver-types/constants.js +6 -0
  799. package/dist/solver-types/constants.js.map +1 -0
  800. package/dist/solver-types/index.d.ts +10 -0
  801. package/dist/solver-types/index.js +32 -0
  802. package/dist/solver-types/index.js.map +1 -0
  803. package/dist/solver-types/learner-loop-test.d.ts +2 -0
  804. package/dist/solver-types/learner-loop-test.js +39 -0
  805. package/dist/solver-types/learner-loop-test.js.map +1 -0
  806. package/dist/solver-types/portfolio-v0.d.ts +2 -0
  807. package/dist/solver-types/portfolio-v0.js +13 -0
  808. package/dist/solver-types/portfolio-v0.js.map +1 -0
  809. package/dist/solver-types/prediction-apy-v0-auto.d.ts +27 -0
  810. package/dist/solver-types/prediction-apy-v0-auto.js +109 -0
  811. package/dist/solver-types/prediction-apy-v0-auto.js.map +1 -0
  812. package/dist/solver-types/prediction-apy-v0-template.d.ts +8 -0
  813. package/dist/solver-types/prediction-apy-v0-template.js +22 -0
  814. package/dist/solver-types/prediction-apy-v0-template.js.map +1 -0
  815. package/dist/solver-types/prediction-apy-v0.d.ts +3 -0
  816. package/dist/solver-types/prediction-apy-v0.js +25 -0
  817. package/dist/solver-types/prediction-apy-v0.js.map +1 -0
  818. package/dist/solver-types/prediction-v0-auto.d.ts +69 -0
  819. package/dist/solver-types/prediction-v0-auto.js +146 -0
  820. package/dist/solver-types/prediction-v0-auto.js.map +1 -0
  821. package/dist/solver-types/prediction-v0-template.d.ts +70 -0
  822. package/dist/solver-types/prediction-v0-template.js +145 -0
  823. package/dist/solver-types/prediction-v0-template.js.map +1 -0
  824. package/dist/solver-types/prediction-v0.d.ts +13 -0
  825. package/dist/solver-types/prediction-v0.js +31 -0
  826. package/dist/solver-types/prediction-v0.js.map +1 -0
  827. package/dist/solver-types/prediction-v1-auto.d.ts +122 -0
  828. package/dist/solver-types/prediction-v1-auto.js +366 -0
  829. package/dist/solver-types/prediction-v1-auto.js.map +1 -0
  830. package/dist/solver-types/prediction-v1.d.ts +11 -0
  831. package/dist/solver-types/prediction-v1.js +27 -0
  832. package/dist/solver-types/prediction-v1.js.map +1 -0
  833. package/dist/solver-types/session-derived.d.ts +2 -0
  834. package/dist/solver-types/session-derived.js +24 -0
  835. package/dist/solver-types/session-derived.js.map +1 -0
  836. package/dist/solver-types/solver-type.d.ts +53 -0
  837. package/dist/solver-types/solver-type.js +6 -0
  838. package/dist/solver-types/solver-type.js.map +1 -0
  839. package/dist/solver-types/swe-rebench-v2-auto.d.ts +38 -0
  840. package/dist/solver-types/swe-rebench-v2-auto.js +56 -0
  841. package/dist/solver-types/swe-rebench-v2-auto.js.map +1 -0
  842. package/dist/solver-types/swe-rebench-v2.d.ts +69 -0
  843. package/dist/solver-types/swe-rebench-v2.js +356 -0
  844. package/dist/solver-types/swe-rebench-v2.js.map +1 -0
  845. package/dist/solvernets/daemon-init.d.ts +291 -0
  846. package/dist/solvernets/daemon-init.js +431 -0
  847. package/dist/solvernets/daemon-init.js.map +1 -0
  848. package/dist/solvernets/launch-state-machine.d.ts +165 -0
  849. package/dist/solvernets/launch-state-machine.js +406 -0
  850. package/dist/solvernets/launch-state-machine.js.map +1 -0
  851. package/dist/solvernets/launched-record-dispatcher.d.ts +55 -0
  852. package/dist/solvernets/launched-record-dispatcher.js +169 -0
  853. package/dist/solvernets/launched-record-dispatcher.js.map +1 -0
  854. package/dist/solvernets/lifecycle-transitions.d.ts +183 -0
  855. package/dist/solvernets/lifecycle-transitions.js +386 -0
  856. package/dist/solvernets/lifecycle-transitions.js.map +1 -0
  857. package/dist/solvernets/manifest.d.ts +120 -0
  858. package/dist/solvernets/manifest.js +166 -0
  859. package/dist/solvernets/manifest.js.map +1 -0
  860. package/dist/solvernets/most-recent-wins.d.ts +77 -0
  861. package/dist/solvernets/most-recent-wins.js +82 -0
  862. package/dist/solvernets/most-recent-wins.js.map +1 -0
  863. package/dist/solvernets/registry-client-erc8004.d.ts +239 -0
  864. package/dist/solvernets/registry-client-erc8004.js +382 -0
  865. package/dist/solvernets/registry-client-erc8004.js.map +1 -0
  866. package/dist/solvernets/registry-client.d.ts +121 -0
  867. package/dist/solvernets/registry-client.js +19 -0
  868. package/dist/solvernets/registry-client.js.map +1 -0
  869. package/dist/solvernets/store.d.ts +298 -0
  870. package/dist/solvernets/store.js +271 -0
  871. package/dist/solvernets/store.js.map +1 -0
  872. package/dist/store/captures.d.ts +85 -0
  873. package/dist/store/captures.js +167 -0
  874. package/dist/store/captures.js.map +1 -0
  875. package/dist/store/store.d.ts +235 -21
  876. package/dist/store/store.js +1000 -46
  877. package/dist/store/store.js.map +1 -1
  878. package/dist/tasks/posting-service.d.ts +25 -0
  879. package/dist/tasks/posting-service.js +149 -0
  880. package/dist/tasks/posting-service.js.map +1 -0
  881. package/dist/tasks/signing.d.ts +4 -0
  882. package/dist/tasks/signing.js +18 -0
  883. package/dist/tasks/signing.js.map +1 -0
  884. package/dist/tasks/sources.d.ts +46 -0
  885. package/dist/tasks/sources.js +45 -0
  886. package/dist/tasks/sources.js.map +1 -0
  887. package/dist/templates/harnesses/alternative-harness/README.md.tmpl +44 -0
  888. package/dist/templates/harnesses/alternative-harness/gitignore.tmpl +3 -0
  889. package/dist/templates/harnesses/alternative-harness/jinn.manifest.json.tmpl +22 -0
  890. package/dist/templates/harnesses/alternative-harness/package.json.tmpl +26 -0
  891. package/dist/templates/harnesses/alternative-harness/src/coordinator.ts.tmpl +50 -0
  892. package/dist/templates/harnesses/alternative-harness/src/harness.ts.tmpl +31 -0
  893. package/dist/templates/harnesses/alternative-harness/src/index.ts.tmpl +44 -0
  894. package/dist/templates/harnesses/alternative-harness/src/mock-harness.ts.tmpl +41 -0
  895. package/dist/templates/harnesses/alternative-harness/src/phases/debrief.ts.tmpl +28 -0
  896. package/dist/templates/harnesses/alternative-harness/src/phases/execute.ts.tmpl +33 -0
  897. package/dist/templates/harnesses/alternative-harness/src/phases/improve.ts.tmpl +31 -0
  898. package/dist/templates/harnesses/alternative-harness/src/phases/memory.ts.tmpl +31 -0
  899. package/dist/templates/harnesses/alternative-harness/src/phases/orient.ts.tmpl +21 -0
  900. package/dist/templates/harnesses/alternative-harness/src/phases/plan.ts.tmpl +25 -0
  901. package/dist/templates/harnesses/alternative-harness/src/phases/strategize.ts.tmpl +29 -0
  902. package/dist/templates/harnesses/alternative-harness/test/coordinator.test.ts.tmpl +53 -0
  903. package/dist/templates/harnesses/alternative-harness/test/unit.test.ts.tmpl +55 -0
  904. package/dist/templates/harnesses/alternative-harness/tsconfig.json.tmpl +16 -0
  905. package/dist/templates/harnesses/evaluator/README.md.tmpl +36 -0
  906. package/dist/templates/harnesses/evaluator/gitignore.tmpl +3 -0
  907. package/dist/templates/harnesses/evaluator/jinn.manifest.json.tmpl +22 -0
  908. package/dist/templates/harnesses/evaluator/package.json.tmpl +26 -0
  909. package/dist/templates/harnesses/evaluator/src/index.ts.tmpl +35 -0
  910. package/dist/templates/harnesses/evaluator/test/unit.test.ts.tmpl +49 -0
  911. package/dist/templates/harnesses/evaluator/tsconfig.json.tmpl +16 -0
  912. package/dist/templates/harnesses/forecaster/README.md.tmpl +25 -0
  913. package/dist/templates/harnesses/forecaster/gitignore.tmpl +5 -0
  914. package/dist/templates/harnesses/forecaster/jinn.manifest.json.tmpl +22 -0
  915. package/dist/templates/harnesses/forecaster/package.json.tmpl +26 -0
  916. package/dist/templates/harnesses/forecaster/src/index.ts.tmpl +33 -0
  917. package/dist/templates/harnesses/forecaster/test/unit.test.ts.tmpl +42 -0
  918. package/dist/templates/harnesses/forecaster/tsconfig.json.tmpl +16 -0
  919. package/dist/trajectory/collector.d.ts +59 -0
  920. package/dist/trajectory/collector.js +164 -0
  921. package/dist/trajectory/collector.js.map +1 -0
  922. package/dist/trajectory/emit.d.ts +29 -0
  923. package/dist/trajectory/emit.js +81 -0
  924. package/dist/trajectory/emit.js.map +1 -0
  925. package/dist/trajectory/harness-bundle-rules/aider.d.ts +13 -0
  926. package/dist/trajectory/harness-bundle-rules/aider.js +26 -0
  927. package/dist/trajectory/harness-bundle-rules/aider.js.map +1 -0
  928. package/dist/trajectory/harness-bundle-rules/claude-code.d.ts +16 -0
  929. package/dist/trajectory/harness-bundle-rules/claude-code.js +71 -0
  930. package/dist/trajectory/harness-bundle-rules/claude-code.js.map +1 -0
  931. package/dist/trajectory/harness-bundle-rules/codex.d.ts +13 -0
  932. package/dist/trajectory/harness-bundle-rules/codex.js +96 -0
  933. package/dist/trajectory/harness-bundle-rules/codex.js.map +1 -0
  934. package/dist/trajectory/harness-bundle-rules/continue.d.ts +10 -0
  935. package/dist/trajectory/harness-bundle-rules/continue.js +43 -0
  936. package/dist/trajectory/harness-bundle-rules/continue.js.map +1 -0
  937. package/dist/trajectory/harness-bundle-rules/cursor.d.ts +20 -0
  938. package/dist/trajectory/harness-bundle-rules/cursor.js +55 -0
  939. package/dist/trajectory/harness-bundle-rules/cursor.js.map +1 -0
  940. package/dist/trajectory/harness-bundle-rules/gemini-cli.d.ts +15 -0
  941. package/dist/trajectory/harness-bundle-rules/gemini-cli.js +112 -0
  942. package/dist/trajectory/harness-bundle-rules/gemini-cli.js.map +1 -0
  943. package/dist/trajectory/harness-bundle-rules/types.d.ts +25 -0
  944. package/dist/trajectory/harness-bundle-rules/types.js +15 -0
  945. package/dist/trajectory/harness-bundle-rules/types.js.map +1 -0
  946. package/dist/trajectory/harness-bundle-schema.d.ts +74 -0
  947. package/dist/trajectory/harness-bundle-schema.js +34 -0
  948. package/dist/trajectory/harness-bundle-schema.js.map +1 -0
  949. package/dist/trajectory/harness-bundle.d.ts +73 -0
  950. package/dist/trajectory/harness-bundle.js +128 -0
  951. package/dist/trajectory/harness-bundle.js.map +1 -0
  952. package/dist/trajectory/hash-chain.d.ts +18 -0
  953. package/dist/trajectory/hash-chain.js +23 -0
  954. package/dist/trajectory/hash-chain.js.map +1 -0
  955. package/dist/trajectory/index.d.ts +28 -0
  956. package/dist/trajectory/index.js +28 -0
  957. package/dist/trajectory/index.js.map +1 -0
  958. package/dist/trajectory/llm-proxy-spans.d.ts +14 -0
  959. package/dist/trajectory/llm-proxy-spans.js +51 -0
  960. package/dist/trajectory/llm-proxy-spans.js.map +1 -0
  961. package/dist/trajectory/llm-proxy.d.ts +32 -0
  962. package/dist/trajectory/llm-proxy.js +97 -0
  963. package/dist/trajectory/llm-proxy.js.map +1 -0
  964. package/dist/trajectory/processors/credential-scrub.d.ts +11 -0
  965. package/dist/trajectory/processors/credential-scrub.js +40 -0
  966. package/dist/trajectory/processors/credential-scrub.js.map +1 -0
  967. package/dist/trajectory/processors/identity-scrub.d.ts +18 -0
  968. package/dist/trajectory/processors/identity-scrub.js +43 -0
  969. package/dist/trajectory/processors/identity-scrub.js.map +1 -0
  970. package/dist/trajectory/processors/manifest-builder.d.ts +18 -0
  971. package/dist/trajectory/processors/manifest-builder.js +26 -0
  972. package/dist/trajectory/processors/manifest-builder.js.map +1 -0
  973. package/dist/trajectory/processors/path-scrub.d.ts +15 -0
  974. package/dist/trajectory/processors/path-scrub.js +52 -0
  975. package/dist/trajectory/processors/path-scrub.js.map +1 -0
  976. package/dist/trajectory/processors/sentinel.d.ts +16 -0
  977. package/dist/trajectory/processors/sentinel.js +17 -0
  978. package/dist/trajectory/processors/sentinel.js.map +1 -0
  979. package/dist/trajectory/processors/sqlite-exporter.d.ts +32 -0
  980. package/dist/trajectory/processors/sqlite-exporter.js +48 -0
  981. package/dist/trajectory/processors/sqlite-exporter.js.map +1 -0
  982. package/dist/trajectory/processors/transcript-content-scrub.d.ts +9 -0
  983. package/dist/trajectory/processors/transcript-content-scrub.js +58 -0
  984. package/dist/trajectory/processors/transcript-content-scrub.js.map +1 -0
  985. package/dist/trajectory/receiver.d.ts +37 -0
  986. package/dist/trajectory/receiver.js +584 -0
  987. package/dist/trajectory/receiver.js.map +1 -0
  988. package/dist/trajectory/schema.d.ts +102 -14
  989. package/dist/trajectory/schema.js +29 -0
  990. package/dist/trajectory/schema.js.map +1 -1
  991. package/dist/trajectory/secret-scrub.d.ts +32 -0
  992. package/dist/trajectory/secret-scrub.js +51 -0
  993. package/dist/trajectory/secret-scrub.js.map +1 -0
  994. package/dist/trajectory/span-profile.d.ts +27 -0
  995. package/dist/trajectory/span-profile.js +51 -0
  996. package/dist/trajectory/span-profile.js.map +1 -0
  997. package/dist/trajectory/synthetic-span-builder.d.ts +50 -0
  998. package/dist/trajectory/synthetic-span-builder.js +115 -0
  999. package/dist/trajectory/synthetic-span-builder.js.map +1 -0
  1000. package/dist/trajectory/transcript-parsers/aider-history.d.ts +42 -0
  1001. package/dist/trajectory/transcript-parsers/aider-history.js +182 -0
  1002. package/dist/trajectory/transcript-parsers/aider-history.js.map +1 -0
  1003. package/dist/trajectory/transcript-parsers/claude-code-jsonl.d.ts +37 -0
  1004. package/dist/trajectory/transcript-parsers/claude-code-jsonl.js +143 -0
  1005. package/dist/trajectory/transcript-parsers/claude-code-jsonl.js.map +1 -0
  1006. package/dist/trajectory/transcript-parsers/codex-session.d.ts +36 -0
  1007. package/dist/trajectory/transcript-parsers/codex-session.js +135 -0
  1008. package/dist/trajectory/transcript-parsers/codex-session.js.map +1 -0
  1009. package/dist/trajectory/transcript-parsers/continue-devdata.d.ts +41 -0
  1010. package/dist/trajectory/transcript-parsers/continue-devdata.js +191 -0
  1011. package/dist/trajectory/transcript-parsers/continue-devdata.js.map +1 -0
  1012. package/dist/trajectory/transcript-parsers/cursor-sqlite.d.ts +38 -0
  1013. package/dist/trajectory/transcript-parsers/cursor-sqlite.js +119 -0
  1014. package/dist/trajectory/transcript-parsers/cursor-sqlite.js.map +1 -0
  1015. package/dist/trajectory/transcript-parsers/gemini-session.d.ts +35 -0
  1016. package/dist/trajectory/transcript-parsers/gemini-session.js +138 -0
  1017. package/dist/trajectory/transcript-parsers/gemini-session.js.map +1 -0
  1018. package/dist/trajectory/transcript-parsers/types.d.ts +101 -0
  1019. package/dist/trajectory/transcript-parsers/types.js +33 -0
  1020. package/dist/trajectory/transcript-parsers/types.js.map +1 -0
  1021. package/dist/trajectory/transcript-watcher.d.ts +62 -0
  1022. package/dist/trajectory/transcript-watcher.js +157 -0
  1023. package/dist/trajectory/transcript-watcher.js.map +1 -0
  1024. package/dist/trajectory/wrappers/http.d.ts +37 -0
  1025. package/dist/trajectory/wrappers/http.js +85 -0
  1026. package/dist/trajectory/wrappers/http.js.map +1 -0
  1027. package/dist/trajectory/wrappers/mcp.d.ts +17 -0
  1028. package/dist/trajectory/wrappers/mcp.js +58 -0
  1029. package/dist/trajectory/wrappers/mcp.js.map +1 -0
  1030. package/dist/trajectory/wrappers/subprocess.d.ts +32 -0
  1031. package/dist/trajectory/wrappers/subprocess.js +70 -0
  1032. package/dist/trajectory/wrappers/subprocess.js.map +1 -0
  1033. package/dist/tx-retry.js +90 -9
  1034. package/dist/tx-retry.js.map +1 -1
  1035. package/dist/types/envelope.d.ts +2742 -0
  1036. package/dist/types/envelope.js +149 -0
  1037. package/dist/types/envelope.js.map +1 -0
  1038. package/dist/types/index.d.ts +4 -4
  1039. package/dist/types/index.js +4 -4
  1040. package/dist/types/index.js.map +1 -1
  1041. package/dist/types/payloads/index.d.ts +12 -0
  1042. package/dist/types/payloads/index.js +62 -0
  1043. package/dist/types/payloads/index.js.map +1 -0
  1044. package/dist/types/payloads/portfolio-v0.d.ts +481 -0
  1045. package/dist/types/payloads/portfolio-v0.js +94 -0
  1046. package/dist/types/payloads/portfolio-v0.js.map +1 -0
  1047. package/dist/types/payloads/prediction-apy-v0.d.ts +231 -0
  1048. package/dist/types/payloads/prediction-apy-v0.js +63 -0
  1049. package/dist/types/payloads/prediction-apy-v0.js.map +1 -0
  1050. package/dist/types/payloads/prediction-v0.d.ts +262 -0
  1051. package/dist/types/payloads/prediction-v0.js +73 -0
  1052. package/dist/types/payloads/prediction-v0.js.map +1 -0
  1053. package/dist/types/payloads/prediction-v1.d.ts +2 -0
  1054. package/dist/types/payloads/prediction-v1.js +2 -0
  1055. package/dist/types/payloads/prediction-v1.js.map +1 -0
  1056. package/dist/types/portfolio.d.ts +31 -698
  1057. package/dist/types/portfolio.js +20 -110
  1058. package/dist/types/portfolio.js.map +1 -1
  1059. package/dist/types/prediction-apy.d.ts +26 -366
  1060. package/dist/types/prediction-apy.js +12 -68
  1061. package/dist/types/prediction-apy.js.map +1 -1
  1062. package/dist/types/prediction-v1.d.ts +2 -0
  1063. package/dist/types/prediction-v1.js +2 -0
  1064. package/dist/types/prediction-v1.js.map +1 -0
  1065. package/dist/types/prediction.d.ts +546 -382
  1066. package/dist/types/prediction.js +16 -87
  1067. package/dist/types/prediction.js.map +1 -1
  1068. package/dist/types/session-provenance.d.ts +71 -0
  1069. package/dist/types/session-provenance.js +19 -0
  1070. package/dist/types/session-provenance.js.map +1 -0
  1071. package/dist/types/task-document.d.ts +1121 -0
  1072. package/dist/types/task-document.js +99 -0
  1073. package/dist/types/task-document.js.map +1 -0
  1074. package/dist/types/task.d.ts +805 -0
  1075. package/dist/types/task.js +88 -0
  1076. package/dist/types/task.js.map +1 -0
  1077. package/dist/types/window.d.ts +12 -0
  1078. package/dist/types/window.js +6 -0
  1079. package/dist/types/window.js.map +1 -0
  1080. package/dist/util/path-safety.d.ts +21 -0
  1081. package/dist/util/path-safety.js +28 -0
  1082. package/dist/util/path-safety.js.map +1 -0
  1083. package/dist/util/redact-rpc-urls.d.ts +5 -0
  1084. package/dist/util/redact-rpc-urls.js +9 -0
  1085. package/dist/util/redact-rpc-urls.js.map +1 -0
  1086. package/dist/vendor/@jinn-network/sdk/README.md +89 -0
  1087. package/dist/vendor/@jinn-network/sdk/dist/capabilities.d.ts +52 -0
  1088. package/dist/vendor/@jinn-network/sdk/dist/capabilities.js +1 -0
  1089. package/dist/vendor/@jinn-network/sdk/dist/checkpoint.d.ts +120 -0
  1090. package/dist/vendor/@jinn-network/sdk/dist/checkpoint.js +39 -0
  1091. package/dist/vendor/@jinn-network/sdk/dist/contracts.d.ts +145 -0
  1092. package/dist/vendor/@jinn-network/sdk/dist/contracts.js +317 -0
  1093. package/dist/vendor/@jinn-network/sdk/dist/harness.d.ts +120 -0
  1094. package/dist/vendor/@jinn-network/sdk/dist/harness.js +31 -0
  1095. package/dist/vendor/@jinn-network/sdk/dist/index.d.ts +4 -0
  1096. package/dist/vendor/@jinn-network/sdk/dist/index.js +7 -0
  1097. package/dist/vendor/@jinn-network/sdk/dist/json-schema.d.ts +32 -0
  1098. package/dist/vendor/@jinn-network/sdk/dist/json-schema.js +131 -0
  1099. package/dist/vendor/@jinn-network/sdk/dist/manifest.d.ts +69 -0
  1100. package/dist/vendor/@jinn-network/sdk/dist/manifest.js +3 -0
  1101. package/dist/vendor/@jinn-network/sdk/dist/payloads/prediction-v1.d.ts +223 -0
  1102. package/dist/vendor/@jinn-network/sdk/dist/payloads/prediction-v1.js +64 -0
  1103. package/dist/vendor/@jinn-network/sdk/dist/payloads/session-derived.d.ts +359 -0
  1104. package/dist/vendor/@jinn-network/sdk/dist/payloads/session-derived.js +60 -0
  1105. package/dist/vendor/@jinn-network/sdk/dist/payloads/swe-rebench-v2.d.ts +110 -0
  1106. package/dist/vendor/@jinn-network/sdk/dist/payloads/swe-rebench-v2.js +58 -0
  1107. package/dist/vendor/@jinn-network/sdk/dist/plugins.d.ts +36 -0
  1108. package/dist/vendor/@jinn-network/sdk/dist/plugins.js +54 -0
  1109. package/dist/vendor/@jinn-network/sdk/dist/prediction-v1.d.ts +870 -0
  1110. package/dist/vendor/@jinn-network/sdk/dist/prediction-v1.js +80 -0
  1111. package/dist/vendor/@jinn-network/sdk/dist/session-derived/distill-prompt-v1.d.ts +2 -0
  1112. package/dist/vendor/@jinn-network/sdk/dist/session-derived/distill-prompt-v1.js +10 -0
  1113. package/dist/vendor/@jinn-network/sdk/dist/solvernets/index.d.ts +6 -0
  1114. package/dist/vendor/@jinn-network/sdk/dist/solvernets/index.js +8 -0
  1115. package/dist/vendor/@jinn-network/sdk/dist/solvernets/manifest-schema.d.ts +559 -0
  1116. package/dist/vendor/@jinn-network/sdk/dist/solvernets/manifest-schema.js +126 -0
  1117. package/dist/vendor/@jinn-network/sdk/dist/solvernets/prediction-v1.d.ts +6 -0
  1118. package/dist/vendor/@jinn-network/sdk/dist/solvernets/prediction-v1.js +3 -0
  1119. package/dist/vendor/@jinn-network/sdk/dist/solvernets/swe-rebench-v2.d.ts +4 -0
  1120. package/dist/vendor/@jinn-network/sdk/dist/solvernets/swe-rebench-v2.js +2 -0
  1121. package/dist/vendor/@jinn-network/sdk/dist/swe-rebench-v2.d.ts +66 -0
  1122. package/dist/vendor/@jinn-network/sdk/dist/swe-rebench-v2.js +44 -0
  1123. package/dist/vendor/@jinn-network/sdk/dist/types.d.ts +116 -0
  1124. package/dist/vendor/@jinn-network/sdk/dist/types.js +21 -0
  1125. package/dist/vendor/@jinn-network/sdk/package.json +43 -0
  1126. package/dist/venues/hyperliquid/account-value.d.ts +1 -1
  1127. package/dist/venues/hyperliquid/account-value.js +1 -1
  1128. package/dist/venues/polymarket/client.d.ts +77 -0
  1129. package/dist/venues/polymarket/client.js +309 -0
  1130. package/dist/venues/polymarket/client.js.map +1 -0
  1131. package/dist/withdraw/run-withdraw-plan.js +0 -2
  1132. package/dist/withdraw/run-withdraw-plan.js.map +1 -1
  1133. package/dist/x402/acquire.d.ts +14 -3
  1134. package/dist/x402/acquire.js +28 -11
  1135. package/dist/x402/acquire.js.map +1 -1
  1136. package/dist/x402/handler.d.ts +15 -3
  1137. package/dist/x402/handler.js +189 -24
  1138. package/dist/x402/handler.js.map +1 -1
  1139. package/package.json +60 -15
  1140. package/plugins/claude-code-learner/.claude-plugin/plugin.json +9 -0
  1141. package/plugins/claude-code-learner/.codex-plugin/plugin.json +39 -0
  1142. package/plugins/claude-code-learner/AGENTS.md +40 -0
  1143. package/plugins/claude-code-learner/CLAUDE.md +33 -0
  1144. package/plugins/claude-code-learner/README.md +59 -0
  1145. package/plugins/claude-code-learner/hooks/hooks.json +16 -0
  1146. package/plugins/claude-code-learner/hooks/session-start +38 -0
  1147. package/plugins/claude-code-learner/skills/learn/SKILL.md +412 -0
  1148. package/plugins/claude-code-learner/skills/learn/analyst-prompt.md +68 -0
  1149. package/plugins/claude-code-learner/skills/learn/consolidator-prompt.md +94 -0
  1150. package/plugins/claude-code-learner/skills/learn/explorer-prompt.md +53 -0
  1151. package/plugins/claude-code-learner/skills/learn/planner-prompt.md +87 -0
  1152. package/plugins/claude-code-learner/skills/learn/promoter-prompt.md +113 -0
  1153. package/plugins/claude-code-learner/skills/learn/step-worker-prompt.md +47 -0
  1154. package/plugins/claude-code-learner/skills/learn/strategist-prompt.md +85 -0
  1155. package/plugins/jinn-prediction-plugin/.claude-plugin/plugin.json +19 -0
  1156. package/plugins/jinn-prediction-plugin/.mcp.json +8 -0
  1157. package/plugins/jinn-prediction-plugin/GEMINI.md +7 -0
  1158. package/plugins/jinn-prediction-plugin/gemini-extension.json +13 -0
  1159. package/plugins/jinn-prediction-plugin/jinn.plugin.json +26 -0
  1160. package/plugins/jinn-prediction-plugin/mcp/polymarket-server.mjs +322 -0
  1161. package/plugins/jinn-prediction-plugin/schemas/prediction-v0-solution.schema.json +12 -0
  1162. package/plugins/jinn-prediction-plugin/schemas/prediction-v0-task.schema.json +25 -0
  1163. package/plugins/jinn-prediction-plugin/schemas/prediction-v0-verdict.schema.json +11 -0
  1164. package/plugins/jinn-prediction-plugin/schemas/prediction-v1-solution.schema.json +34 -0
  1165. package/plugins/jinn-prediction-plugin/schemas/prediction-v1-task.schema.json +118 -0
  1166. package/plugins/jinn-prediction-plugin/schemas/prediction-v1-verdict.schema.json +84 -0
  1167. package/plugins/jinn-prediction-plugin/skills/base-rate-forecasting/SKILL.md +3 -0
  1168. package/plugins/jinn-prediction-plugin/skills/calibration/SKILL.md +3 -0
  1169. package/plugins/jinn-prediction-plugin/skills/common-biases/SKILL.md +3 -0
  1170. package/plugins/jinn-prediction-plugin/skills/polymarket-task-handling/SKILL.md +5 -0
  1171. package/plugins/jinn-prediction-plugin/skills/prediction-corpus-retrieval/SKILL.md +35 -0
  1172. package/plugins/network-tools/.claude-plugin/plugin.json +12 -0
  1173. package/plugins/network-tools/.codex-plugin/plugin.json +39 -0
  1174. package/plugins/network-tools/.mcp.json +11 -0
  1175. package/plugins/network-tools/jinn.plugin.json +29 -0
  1176. package/plugins/network-tools/mcp/jinn-client-server.mjs +110 -0
  1177. package/plugins/swe-rebench-v2-runtime/.claude-plugin/plugin.json +5 -0
  1178. package/plugins/swe-rebench-v2-runtime/.codex-plugin/plugin.json +39 -0
  1179. package/plugins/swe-rebench-v2-runtime/README.md +11 -0
  1180. package/plugins/swe-rebench-v2-runtime/jinn.plugin.json +12 -0
  1181. package/plugins/swe-rebench-v2-runtime/skills/orient/SKILL.md +25 -0
  1182. package/plugins/swe-rebench-v2-runtime/skills/plan/SKILL.md +64 -0
  1183. package/skills/jinn-operator/SKILL.md +120 -101
  1184. package/templates/harnesses/alternative-harness/README.md.tmpl +44 -0
  1185. package/templates/harnesses/alternative-harness/gitignore.tmpl +3 -0
  1186. package/templates/harnesses/alternative-harness/jinn.manifest.json.tmpl +22 -0
  1187. package/templates/harnesses/alternative-harness/package.json.tmpl +26 -0
  1188. package/templates/harnesses/alternative-harness/src/coordinator.ts.tmpl +50 -0
  1189. package/templates/harnesses/alternative-harness/src/harness.ts.tmpl +31 -0
  1190. package/templates/harnesses/alternative-harness/src/index.ts.tmpl +44 -0
  1191. package/templates/harnesses/alternative-harness/src/mock-harness.ts.tmpl +41 -0
  1192. package/templates/harnesses/alternative-harness/src/phases/debrief.ts.tmpl +28 -0
  1193. package/templates/harnesses/alternative-harness/src/phases/execute.ts.tmpl +33 -0
  1194. package/templates/harnesses/alternative-harness/src/phases/improve.ts.tmpl +31 -0
  1195. package/templates/harnesses/alternative-harness/src/phases/memory.ts.tmpl +31 -0
  1196. package/templates/harnesses/alternative-harness/src/phases/orient.ts.tmpl +21 -0
  1197. package/templates/harnesses/alternative-harness/src/phases/plan.ts.tmpl +25 -0
  1198. package/templates/harnesses/alternative-harness/src/phases/strategize.ts.tmpl +29 -0
  1199. package/templates/harnesses/alternative-harness/test/coordinator.test.ts.tmpl +53 -0
  1200. package/templates/harnesses/alternative-harness/test/unit.test.ts.tmpl +55 -0
  1201. package/templates/harnesses/alternative-harness/tsconfig.json.tmpl +16 -0
  1202. package/templates/harnesses/evaluator/README.md.tmpl +36 -0
  1203. package/templates/harnesses/evaluator/gitignore.tmpl +3 -0
  1204. package/templates/harnesses/evaluator/jinn.manifest.json.tmpl +22 -0
  1205. package/templates/harnesses/evaluator/package.json.tmpl +26 -0
  1206. package/templates/harnesses/evaluator/src/index.ts.tmpl +35 -0
  1207. package/templates/harnesses/evaluator/test/unit.test.ts.tmpl +49 -0
  1208. package/templates/harnesses/evaluator/tsconfig.json.tmpl +16 -0
  1209. package/templates/harnesses/forecaster/README.md.tmpl +25 -0
  1210. package/templates/harnesses/forecaster/gitignore.tmpl +5 -0
  1211. package/templates/harnesses/forecaster/jinn.manifest.json.tmpl +22 -0
  1212. package/templates/harnesses/forecaster/package.json.tmpl +26 -0
  1213. package/templates/harnesses/forecaster/src/index.ts.tmpl +33 -0
  1214. package/templates/harnesses/forecaster/test/unit.test.ts.tmpl +42 -0
  1215. package/templates/harnesses/forecaster/tsconfig.json.tmpl +16 -0
  1216. package/dist/adapters/claim-registry/abi.d.ts +0 -127
  1217. package/dist/adapters/claim-registry/abi.js +0 -93
  1218. package/dist/adapters/claim-registry/abi.js.map +0 -1
  1219. package/dist/adapters/claim-registry/client.d.ts +0 -89
  1220. package/dist/adapters/claim-registry/client.js +0 -205
  1221. package/dist/adapters/claim-registry/client.js.map +0 -1
  1222. package/dist/adapters/mech/claim-policy.d.ts +0 -40
  1223. package/dist/adapters/mech/claim-policy.js +0 -104
  1224. package/dist/adapters/mech/claim-policy.js.map +0 -1
  1225. package/dist/bin/jinn-mcp.d.ts +0 -2
  1226. package/dist/bin/jinn-mcp.js +0 -10
  1227. package/dist/bin/jinn-mcp.js.map +0 -1
  1228. package/dist/cli/commands/intents.d.ts +0 -17
  1229. package/dist/cli/commands/intents.js +0 -489
  1230. package/dist/cli/commands/intents.js.map +0 -1
  1231. package/dist/cli/commands/plugin-install.js +0 -803
  1232. package/dist/cli/commands/plugin-install.js.map +0 -1
  1233. package/dist/cli/commands/submit-intent.js +0 -245
  1234. package/dist/cli/commands/submit-intent.js.map +0 -1
  1235. package/dist/cli/intent-registry-access.d.ts +0 -62
  1236. package/dist/cli/intent-registry-access.js +0 -165
  1237. package/dist/cli/intent-registry-access.js.map +0 -1
  1238. package/dist/discovery/registry.d.ts +0 -97
  1239. package/dist/discovery/registry.js +0 -177
  1240. package/dist/discovery/registry.js.map +0 -1
  1241. package/dist/discovery/subgraph.d.ts +0 -37
  1242. package/dist/discovery/subgraph.js +0 -87
  1243. package/dist/discovery/subgraph.js.map +0 -1
  1244. package/dist/intents/kinds/constants.d.ts +0 -5
  1245. package/dist/intents/kinds/constants.js +0 -6
  1246. package/dist/intents/kinds/constants.js.map +0 -1
  1247. package/dist/intents/kinds/index.d.ts +0 -28
  1248. package/dist/intents/kinds/index.js +0 -50
  1249. package/dist/intents/kinds/index.js.map +0 -1
  1250. package/dist/intents/kinds/portfolio-v0.d.ts +0 -2
  1251. package/dist/intents/kinds/portfolio-v0.js +0 -13
  1252. package/dist/intents/kinds/portfolio-v0.js.map +0 -1
  1253. package/dist/intents/kinds/prediction-apy-v0.d.ts +0 -3
  1254. package/dist/intents/kinds/prediction-apy-v0.js +0 -21
  1255. package/dist/intents/kinds/prediction-apy-v0.js.map +0 -1
  1256. package/dist/intents/kinds/prediction-v0.d.ts +0 -3
  1257. package/dist/intents/kinds/prediction-v0.js +0 -32
  1258. package/dist/intents/kinds/prediction-v0.js.map +0 -1
  1259. package/dist/intents/kinds/spec-kind.d.ts +0 -38
  1260. package/dist/intents/kinds/spec-kind.js +0 -6
  1261. package/dist/intents/kinds/spec-kind.js.map +0 -1
  1262. package/dist/intents/posting-service.d.ts +0 -26
  1263. package/dist/intents/posting-service.js +0 -218
  1264. package/dist/intents/posting-service.js.map +0 -1
  1265. package/dist/intents/prediction-apy-v0-auto.d.ts +0 -11
  1266. package/dist/intents/prediction-apy-v0-auto.js +0 -46
  1267. package/dist/intents/prediction-apy-v0-auto.js.map +0 -1
  1268. package/dist/intents/prediction-apy-v0-template.d.ts +0 -8
  1269. package/dist/intents/prediction-apy-v0-template.js +0 -22
  1270. package/dist/intents/prediction-apy-v0-template.js.map +0 -1
  1271. package/dist/intents/prediction-v0-auto.d.ts +0 -53
  1272. package/dist/intents/prediction-v0-auto.js +0 -84
  1273. package/dist/intents/prediction-v0-auto.js.map +0 -1
  1274. package/dist/intents/prediction-v0-template.d.ts +0 -70
  1275. package/dist/intents/prediction-v0-template.js +0 -145
  1276. package/dist/intents/prediction-v0-template.js.map +0 -1
  1277. package/dist/intents/sources.d.ts +0 -39
  1278. package/dist/intents/sources.js +0 -42
  1279. package/dist/intents/sources.js.map +0 -1
  1280. package/dist/restorer/engine/canonical-json.d.ts +0 -18
  1281. package/dist/restorer/engine/canonical-json.js +0 -59
  1282. package/dist/restorer/engine/canonical-json.js.map +0 -1
  1283. package/dist/restorer/engine/claim.d.ts +0 -69
  1284. package/dist/restorer/engine/claim.js +0 -104
  1285. package/dist/restorer/engine/claim.js.map +0 -1
  1286. package/dist/restorer/engine/delivery.d.ts +0 -52
  1287. package/dist/restorer/engine/delivery.js +0 -63
  1288. package/dist/restorer/engine/delivery.js.map +0 -1
  1289. package/dist/restorer/engine/engine.d.ts +0 -213
  1290. package/dist/restorer/engine/engine.js +0 -769
  1291. package/dist/restorer/engine/engine.js.map +0 -1
  1292. package/dist/restorer/engine/manifest-assembly.d.ts +0 -67
  1293. package/dist/restorer/engine/manifest-assembly.js +0 -79
  1294. package/dist/restorer/engine/manifest-assembly.js.map +0 -1
  1295. package/dist/restorer/engine/packaging.d.ts +0 -87
  1296. package/dist/restorer/engine/packaging.js +0 -350
  1297. package/dist/restorer/engine/packaging.js.map +0 -1
  1298. package/dist/restorer/engine/persistence.d.ts +0 -170
  1299. package/dist/restorer/engine/persistence.js +0 -381
  1300. package/dist/restorer/engine/persistence.js.map +0 -1
  1301. package/dist/restorer/engine/recovery.d.ts +0 -22
  1302. package/dist/restorer/engine/recovery.js +0 -24
  1303. package/dist/restorer/engine/recovery.js.map +0 -1
  1304. package/dist/restorer/engine/registry.d.ts +0 -62
  1305. package/dist/restorer/engine/registry.js +0 -73
  1306. package/dist/restorer/engine/registry.js.map +0 -1
  1307. package/dist/restorer/engine/signing.d.ts +0 -30
  1308. package/dist/restorer/engine/signing.js +0 -39
  1309. package/dist/restorer/engine/signing.js.map +0 -1
  1310. package/dist/restorer/engine/state.d.ts +0 -42
  1311. package/dist/restorer/engine/state.js +0 -87
  1312. package/dist/restorer/engine/state.js.map +0 -1
  1313. package/dist/restorer/impls/claude-mcp-hyperliquid/api-wallet.d.ts +0 -64
  1314. package/dist/restorer/impls/claude-mcp-hyperliquid/api-wallet.js.map +0 -1
  1315. package/dist/restorer/impls/claude-mcp-hyperliquid/index.d.ts +0 -104
  1316. package/dist/restorer/impls/claude-mcp-hyperliquid/index.js +0 -721
  1317. package/dist/restorer/impls/claude-mcp-hyperliquid/index.js.map +0 -1
  1318. package/dist/restorer/impls/claude-mcp-hyperliquid/mcp-tools.js.map +0 -1
  1319. package/dist/restorer/impls/claude-mcp-hyperliquid/safety-rails.js.map +0 -1
  1320. package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.d.ts +0 -97
  1321. package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.js +0 -226
  1322. package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.js.map +0 -1
  1323. package/dist/restorer/impls/claude-mcp-prediction/index.d.ts +0 -44
  1324. package/dist/restorer/impls/claude-mcp-prediction/index.js +0 -239
  1325. package/dist/restorer/impls/claude-mcp-prediction/index.js.map +0 -1
  1326. package/dist/restorer/impls/claude-mcp-prediction/mcp-tools.js +0 -135
  1327. package/dist/restorer/impls/claude-mcp-prediction/mcp-tools.js.map +0 -1
  1328. package/dist/restorer/impls/claude-mcp-prediction/prompt.d.ts +0 -8
  1329. package/dist/restorer/impls/claude-mcp-prediction/prompt.js +0 -54
  1330. package/dist/restorer/impls/claude-mcp-prediction/prompt.js.map +0 -1
  1331. package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.d.ts +0 -36
  1332. package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.js +0 -137
  1333. package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.js.map +0 -1
  1334. package/dist/restorer/impls/claude-mcp-prediction/types.d.ts +0 -84
  1335. package/dist/restorer/impls/claude-mcp-prediction/types.js +0 -6
  1336. package/dist/restorer/impls/claude-mcp-prediction/types.js.map +0 -1
  1337. package/dist/restorer/impls/claude-mcp-prediction-apy/index.d.ts +0 -34
  1338. package/dist/restorer/impls/claude-mcp-prediction-apy/index.js +0 -233
  1339. package/dist/restorer/impls/claude-mcp-prediction-apy/index.js.map +0 -1
  1340. package/dist/restorer/impls/claude-mcp-prediction-apy/mcp-tools.js +0 -136
  1341. package/dist/restorer/impls/claude-mcp-prediction-apy/mcp-tools.js.map +0 -1
  1342. package/dist/restorer/impls/claude-mcp-prediction-apy/prompt.d.ts +0 -7
  1343. package/dist/restorer/impls/claude-mcp-prediction-apy/prompt.js +0 -46
  1344. package/dist/restorer/impls/claude-mcp-prediction-apy/prompt.js.map +0 -1
  1345. package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.d.ts +0 -27
  1346. package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.js +0 -128
  1347. package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.js.map +0 -1
  1348. package/dist/restorer/impls/claude-mcp-prediction-apy/types.d.ts +0 -64
  1349. package/dist/restorer/impls/claude-mcp-prediction-apy/types.js +0 -6
  1350. package/dist/restorer/impls/claude-mcp-prediction-apy/types.js.map +0 -1
  1351. package/dist/restorer/impls/evaluation-context.d.ts +0 -16
  1352. package/dist/restorer/impls/evaluation-context.js +0 -18
  1353. package/dist/restorer/impls/evaluation-context.js.map +0 -1
  1354. package/dist/restorer/impls/index.d.ts +0 -46
  1355. package/dist/restorer/impls/index.js +0 -88
  1356. package/dist/restorer/impls/index.js.map +0 -1
  1357. package/dist/restorer/impls/legacy-claude/index.d.ts +0 -52
  1358. package/dist/restorer/impls/legacy-claude/index.js +0 -140
  1359. package/dist/restorer/impls/legacy-claude/index.js.map +0 -1
  1360. package/dist/restorer/impls/portfolio-v0-evaluator/canonical-metrics.d.ts +0 -68
  1361. package/dist/restorer/impls/portfolio-v0-evaluator/canonical-metrics.js +0 -117
  1362. package/dist/restorer/impls/portfolio-v0-evaluator/canonical-metrics.js.map +0 -1
  1363. package/dist/restorer/impls/portfolio-v0-evaluator/checks/availability.js.map +0 -1
  1364. package/dist/restorer/impls/portfolio-v0-evaluator/checks/consistency.d.ts +0 -78
  1365. package/dist/restorer/impls/portfolio-v0-evaluator/checks/consistency.js +0 -274
  1366. package/dist/restorer/impls/portfolio-v0-evaluator/checks/consistency.js.map +0 -1
  1367. package/dist/restorer/impls/portfolio-v0-evaluator/checks/eligibility.d.ts +0 -23
  1368. package/dist/restorer/impls/portfolio-v0-evaluator/checks/eligibility.js +0 -49
  1369. package/dist/restorer/impls/portfolio-v0-evaluator/checks/eligibility.js.map +0 -1
  1370. package/dist/restorer/impls/portfolio-v0-evaluator/checks/integrity.d.ts +0 -25
  1371. package/dist/restorer/impls/portfolio-v0-evaluator/checks/integrity.js +0 -44
  1372. package/dist/restorer/impls/portfolio-v0-evaluator/checks/integrity.js.map +0 -1
  1373. package/dist/restorer/impls/portfolio-v0-evaluator/checks/spec.d.ts +0 -17
  1374. package/dist/restorer/impls/portfolio-v0-evaluator/checks/spec.js +0 -43
  1375. package/dist/restorer/impls/portfolio-v0-evaluator/checks/spec.js.map +0 -1
  1376. package/dist/restorer/impls/portfolio-v0-evaluator/index.d.ts +0 -44
  1377. package/dist/restorer/impls/portfolio-v0-evaluator/index.js +0 -440
  1378. package/dist/restorer/impls/portfolio-v0-evaluator/index.js.map +0 -1
  1379. package/dist/restorer/impls/portfolio-v0-evaluator/score.js.map +0 -1
  1380. package/dist/restorer/impls/portfolio-v0-evaluator/types.d.ts +0 -34
  1381. package/dist/restorer/impls/portfolio-v0-evaluator/types.js.map +0 -1
  1382. package/dist/restorer/impls/prediction-apy-v0-baseline/index.d.ts +0 -40
  1383. package/dist/restorer/impls/prediction-apy-v0-baseline/index.js +0 -107
  1384. package/dist/restorer/impls/prediction-apy-v0-baseline/index.js.map +0 -1
  1385. package/dist/restorer/impls/prediction-apy-v0-baseline/strategy.js.map +0 -1
  1386. package/dist/restorer/impls/prediction-apy-v0-baseline/types.js.map +0 -1
  1387. package/dist/restorer/impls/prediction-apy-v0-evaluator/canonical-metrics.d.ts +0 -6
  1388. package/dist/restorer/impls/prediction-apy-v0-evaluator/canonical-metrics.js +0 -11
  1389. package/dist/restorer/impls/prediction-apy-v0-evaluator/canonical-metrics.js.map +0 -1
  1390. package/dist/restorer/impls/prediction-apy-v0-evaluator/index.d.ts +0 -42
  1391. package/dist/restorer/impls/prediction-apy-v0-evaluator/index.js +0 -208
  1392. package/dist/restorer/impls/prediction-apy-v0-evaluator/index.js.map +0 -1
  1393. package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.d.ts +0 -7
  1394. package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.js +0 -29
  1395. package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.js.map +0 -1
  1396. package/dist/restorer/impls/prediction-apy-v0-evaluator/score.js.map +0 -1
  1397. package/dist/restorer/impls/prediction-apy-v0-evaluator/types.js.map +0 -1
  1398. package/dist/restorer/impls/prediction-v0-baseline/index.d.ts +0 -31
  1399. package/dist/restorer/impls/prediction-v0-baseline/index.js +0 -100
  1400. package/dist/restorer/impls/prediction-v0-baseline/index.js.map +0 -1
  1401. package/dist/restorer/impls/prediction-v0-baseline/strategy.d.ts +0 -8
  1402. package/dist/restorer/impls/prediction-v0-baseline/strategy.js +0 -41
  1403. package/dist/restorer/impls/prediction-v0-baseline/strategy.js.map +0 -1
  1404. package/dist/restorer/impls/prediction-v0-baseline/types.d.ts +0 -7
  1405. package/dist/restorer/impls/prediction-v0-baseline/types.js.map +0 -1
  1406. package/dist/restorer/impls/prediction-v0-evaluator/canonical-metrics.d.ts +0 -20
  1407. package/dist/restorer/impls/prediction-v0-evaluator/canonical-metrics.js.map +0 -1
  1408. package/dist/restorer/impls/prediction-v0-evaluator/checks/availability.d.ts +0 -9
  1409. package/dist/restorer/impls/prediction-v0-evaluator/checks/availability.js.map +0 -1
  1410. package/dist/restorer/impls/prediction-v0-evaluator/checks/eligibility.d.ts +0 -3
  1411. package/dist/restorer/impls/prediction-v0-evaluator/checks/eligibility.js.map +0 -1
  1412. package/dist/restorer/impls/prediction-v0-evaluator/checks/integrity.d.ts +0 -13
  1413. package/dist/restorer/impls/prediction-v0-evaluator/checks/integrity.js +0 -111
  1414. package/dist/restorer/impls/prediction-v0-evaluator/checks/integrity.js.map +0 -1
  1415. package/dist/restorer/impls/prediction-v0-evaluator/checks/spec.d.ts +0 -5
  1416. package/dist/restorer/impls/prediction-v0-evaluator/checks/spec.js.map +0 -1
  1417. package/dist/restorer/impls/prediction-v0-evaluator/index.d.ts +0 -36
  1418. package/dist/restorer/impls/prediction-v0-evaluator/index.js +0 -234
  1419. package/dist/restorer/impls/prediction-v0-evaluator/index.js.map +0 -1
  1420. package/dist/restorer/impls/prediction-v0-evaluator/score.js.map +0 -1
  1421. package/dist/restorer/impls/prediction-v0-evaluator/types.js.map +0 -1
  1422. package/dist/restorer/types.d.ts +0 -194
  1423. package/dist/restorer/types.js +0 -28
  1424. package/dist/restorer/types.js.map +0 -1
  1425. package/dist/types/desired-state.d.ts +0 -94
  1426. package/dist/types/desired-state.js +0 -36
  1427. package/dist/types/desired-state.js.map +0 -1
  1428. /package/dist/cli/commands/{plugin-install.d.ts → solver-nets.d.ts} +0 -0
  1429. /package/dist/cli/commands/{submit-intent.d.ts → tasks.d.ts} +0 -0
  1430. /package/dist/{restorer/impls/prediction-apy-v0-baseline → harnesses/impls/claude-code-learner}/types.js +0 -0
  1431. /package/dist/{restorer → harnesses}/impls/claude-mcp-hyperliquid/api-wallet.js +0 -0
  1432. /package/dist/{restorer → harnesses}/impls/claude-mcp-hyperliquid/mcp-tools.d.ts +0 -0
  1433. /package/dist/{restorer → harnesses}/impls/claude-mcp-hyperliquid/mcp-tools.js +0 -0
  1434. /package/dist/{restorer → harnesses}/impls/claude-mcp-hyperliquid/safety-rails.d.ts +0 -0
  1435. /package/dist/{restorer → harnesses}/impls/claude-mcp-hyperliquid/safety-rails.js +0 -0
  1436. /package/dist/{restorer → harnesses}/impls/claude-mcp-prediction/mcp-tools.d.ts +0 -0
  1437. /package/dist/{restorer → harnesses}/impls/claude-mcp-prediction-apy/mcp-tools.d.ts +0 -0
  1438. /package/dist/{restorer → harnesses}/impls/portfolio-v0-evaluator/checks/availability.d.ts +0 -0
  1439. /package/dist/{restorer → harnesses}/impls/portfolio-v0-evaluator/checks/availability.js +0 -0
  1440. /package/dist/{restorer → harnesses}/impls/portfolio-v0-evaluator/score.d.ts +0 -0
  1441. /package/dist/{restorer → harnesses}/impls/portfolio-v0-evaluator/score.js +0 -0
  1442. /package/dist/{restorer → harnesses}/impls/portfolio-v0-evaluator/types.js +0 -0
  1443. /package/dist/{restorer → harnesses}/impls/prediction-apy-v0-baseline/strategy.d.ts +0 -0
  1444. /package/dist/{restorer → harnesses}/impls/prediction-apy-v0-baseline/strategy.js +0 -0
  1445. /package/dist/{restorer → harnesses}/impls/prediction-apy-v0-baseline/types.d.ts +0 -0
  1446. /package/dist/{restorer/impls/prediction-apy-v0-evaluator → harnesses/impls/prediction-apy-v0-baseline}/types.js +0 -0
  1447. /package/dist/{restorer → harnesses}/impls/prediction-apy-v0-evaluator/score.d.ts +0 -0
  1448. /package/dist/{restorer → harnesses}/impls/prediction-apy-v0-evaluator/score.js +0 -0
  1449. /package/dist/{restorer → harnesses}/impls/prediction-apy-v0-evaluator/types.d.ts +0 -0
  1450. /package/dist/{restorer/impls/prediction-v0-baseline → harnesses/impls/prediction-apy-v0-evaluator}/types.js +0 -0
  1451. /package/dist/{restorer/impls/prediction-v0-evaluator → harnesses/impls/prediction-v0-baseline}/types.js +0 -0
  1452. /package/dist/{restorer → harnesses}/impls/prediction-v0-evaluator/canonical-metrics.js +0 -0
  1453. /package/dist/{restorer → harnesses}/impls/prediction-v0-evaluator/checks/availability.js +0 -0
  1454. /package/dist/{restorer → harnesses}/impls/prediction-v0-evaluator/checks/eligibility.js +0 -0
  1455. /package/dist/{restorer → harnesses}/impls/prediction-v0-evaluator/checks/spec.js +0 -0
  1456. /package/dist/{restorer → harnesses}/impls/prediction-v0-evaluator/score.d.ts +0 -0
  1457. /package/dist/{restorer → harnesses}/impls/prediction-v0-evaluator/score.js +0 -0
  1458. /package/dist/{restorer → harnesses}/impls/prediction-v0-evaluator/types.d.ts +0 -0
@@ -0,0 +1,1121 @@
1
+ import { randomUUID } from 'node:crypto';
2
+ import { z } from 'zod';
3
+ import { getSolverNetContract, } from '../vendor/@jinn-network/sdk/dist/solvernets/index.js';
4
+ import { DraftSolverNetRecordSchema, LaunchedSolverNetRecordSchema, } from '../solvernets/store.js';
5
+ import { signManifest, } from '../solvernets/manifest.js';
6
+ import { resolveContractFromSolverNetId } from '../solvernets/launched-record-dispatcher.js';
7
+ // ── Draft CRUD validation schemas ──────────────────────────────────────────
8
+ // Zod schema for the editable subset of a draft. Mirrors
9
+ // `DraftSolverNetRecordSchema` from the store but drops the
10
+ // store-managed fields (`schemaVersion`, `draftId`, `createdAt`,
11
+ // `updatedAt`, `completedSteps` is editable by the UI).
12
+ //
13
+ // All fields are optional — POST with `{}` produces an empty draft, PATCH
14
+ // of a single field updates only that field. Wrong types → Zod fails fast,
15
+ // the route returns 400 with a structured error.
16
+ const DraftEditableSchema = z
17
+ .object({
18
+ templateContractId: z.string().optional(),
19
+ templateContractVersion: z.string().optional(),
20
+ name: z.string().optional(),
21
+ description: z.string().optional(),
22
+ generatorConfig: z.record(z.string(), z.unknown()).optional(),
23
+ solutionPriceWei: z.string().optional(),
24
+ verdictPriceWei: z.string().optional(),
25
+ openRoles: z.array(z.enum(['solver', 'evaluator'])).optional(),
26
+ completedSteps: z
27
+ .array(z.enum(['define', 'reviewContract', 'configureGenerator', 'configurePricing']))
28
+ .optional(),
29
+ })
30
+ .strict();
31
+ // Fields the API explicitly forbids in a request body. Surfaced here so the
32
+ // 400 message can name them rather than relying on `.strict()`'s generic
33
+ // "Unrecognized key" wording (which doesn't tell the SPA *why* a field is
34
+ // rejected — these are immutable, not just unknown).
35
+ const IMMUTABLE_FIELDS = ['draftId', 'createdAt', 'updatedAt', 'schemaVersion'];
36
+ function rejectImmutableFields(body) {
37
+ if (typeof body !== 'object' || body === null)
38
+ return null;
39
+ for (const f of IMMUTABLE_FIELDS) {
40
+ if (f in body) {
41
+ return { error: `\`${f}\` is immutable and cannot be set via the API`, field: f };
42
+ }
43
+ }
44
+ return null;
45
+ }
46
+ function applyEditable(current, patch, now) {
47
+ const next = { ...current, updatedAt: now };
48
+ // Only assign keys that are explicitly present in the patch object so that
49
+ // PATCH `{ name: 'x' }` doesn't clear `description` etc. The Zod schema's
50
+ // `.optional()` would let `undefined` slip through, hence the explicit
51
+ // `key in patch` check below.
52
+ if ('templateContractId' in patch)
53
+ next.templateContractId = patch.templateContractId;
54
+ if ('templateContractVersion' in patch)
55
+ next.templateContractVersion = patch.templateContractVersion;
56
+ if ('name' in patch)
57
+ next.name = patch.name;
58
+ if ('description' in patch)
59
+ next.description = patch.description;
60
+ if ('generatorConfig' in patch)
61
+ next.generatorConfig = patch.generatorConfig;
62
+ if ('solutionPriceWei' in patch)
63
+ next.solutionPriceWei = patch.solutionPriceWei;
64
+ if ('verdictPriceWei' in patch)
65
+ next.verdictPriceWei = patch.verdictPriceWei;
66
+ if ('openRoles' in patch)
67
+ next.openRoles = patch.openRoles;
68
+ if ('completedSteps' in patch && patch.completedSteps !== undefined) {
69
+ next.completedSteps = patch.completedSteps;
70
+ }
71
+ return next;
72
+ }
73
+ // ── Catalog query-string schemas (Task 15) ──────────────────────────────────
74
+ /**
75
+ * Status filter shared by `/launched` (owned-list) and `/registry`
76
+ * (global-list). The owned-list also accepts `launching`/`failed` because
77
+ * those are local-only states that never make it to the registry; the
78
+ * registry list is restricted to lifecycle-broadcast states.
79
+ */
80
+ const OwnedStatusFilterSchema = z.enum([
81
+ 'launching',
82
+ 'launched',
83
+ 'paused',
84
+ 'retired',
85
+ 'failed',
86
+ ]);
87
+ const RegistryStatusFilterSchema = z.enum(['launched', 'paused', 'retired']);
88
+ /**
89
+ * Loose CIDv0 / CIDv1 sniff. We are not validating the full multihash —
90
+ * that is the registry client's job — but rejecting trivial garbage here
91
+ * (slashes from path traversal, hyphens, empty strings) keeps the IPFS
92
+ * round-trip away from obvious attacks. CIDv0 = `Qm` + base58btc; CIDv1 in
93
+ * the dag-pb codec we use here is base32-lower and starts with `bafy`.
94
+ *
95
+ * We accept any sufficiently-long alphanumeric tail without enforcing the
96
+ * exact alphabet — the registry client's hash check against the on-chain
97
+ * advertised hash is the canonical gate; this regex only filters obviously
98
+ * non-CID inputs.
99
+ */
100
+ // CIDv0 (Qm-base58) or CIDv1 (any multicodec — multibase prefix `b` is
101
+ // base32 lowercase alphanumeric). Earlier this regex anchored to `bafy`,
102
+ // the dag-pb codec prefix; the IPFS adapter actually pins manifests as
103
+ // raw bytes (codec `raw`), producing `bafkrei...`. See jinn-mono-wkzp.
104
+ // Loose by design — the registry client does the canonical decode. This only
105
+ // blocks obviously invalid/path-like input before an IPFS round-trip.
106
+ const CID_SHAPE_REGEX = /^(Qm[A-Za-z0-9]{10,}|b[A-Za-z0-9]{10,})$/u;
107
+ // ── Lifecycle / generator-config validation schemas ─────────────────────────
108
+ const LifecycleBodySchema = z
109
+ .object({
110
+ target: z.enum(['paused', 'launched', 'retired']),
111
+ })
112
+ .strict();
113
+ /**
114
+ * Zod schema mirroring `PredictionV1GeneratorRuntimeConfig` from
115
+ * `solver-types/prediction-v1-auto.ts`. Kept narrow on purpose: only fields
116
+ * the operator can hot-apply are accepted. Static-config fields (agent
117
+ * identity, transport URLs) live in the daemon's static-config block and
118
+ * are never mutated through this endpoint.
119
+ *
120
+ * `.strict()` rejects unknown keys so a typo in the SPA surfaces as 400
121
+ * rather than silently dropping the field.
122
+ */
123
+ const PredictionV1GeneratorConfigPatchSchema = z
124
+ .object({
125
+ cadenceMs: z.number().int().nonnegative().optional(),
126
+ maxNewRoundsPerPoll: z.number().int().nonnegative().optional(),
127
+ maxNewRoundsPerDay: z.number().int().nonnegative().optional(),
128
+ maxOpenRounds: z.number().int().nonnegative().optional(),
129
+ submissionWindowMs: z.number().int().nonnegative().optional(),
130
+ allowlistConditionIds: z.array(z.string()).optional(),
131
+ blocklistConditionIds: z.array(z.string()).optional(),
132
+ minTimeToResolutionHours: z.number().nonnegative().optional(),
133
+ maxTimeToResolutionHours: z.number().nonnegative().optional(),
134
+ minLiquidityUsd: z.string().optional(),
135
+ minVolume24hUsd: z.string().optional(),
136
+ maxYesSpread: z.string().optional(),
137
+ maxOrderbookAgeSeconds: z.number().int().nonnegative().optional(),
138
+ })
139
+ .strict();
140
+ const SweRebenchV2GeneratorConfigPatchSchema = z
141
+ .object({
142
+ N_target_successes: z.number().int().positive().optional(),
143
+ N_max_postings_per_task: z.number().int().positive().optional(),
144
+ cooldown_ms: z.number().int().nonnegative().optional(),
145
+ claimPolicy: z
146
+ .object({
147
+ maxClaims: z.number().int().positive().max(65_535).optional(),
148
+ maxClaimsPerOperator: z.number().int().positive().max(65_535).optional(),
149
+ claimLeaseTtlSeconds: z.number().int().positive().optional(),
150
+ })
151
+ .strict()
152
+ .optional(),
153
+ })
154
+ .strict()
155
+ .superRefine((value, ctx) => {
156
+ if (value.N_target_successes !== undefined &&
157
+ value.N_max_postings_per_task !== undefined &&
158
+ value.N_max_postings_per_task < value.N_target_successes) {
159
+ ctx.addIssue({
160
+ code: z.ZodIssueCode.custom,
161
+ path: ['N_max_postings_per_task'],
162
+ message: 'must be >= N_target_successes',
163
+ });
164
+ }
165
+ if (value.claimPolicy?.maxClaims !== undefined &&
166
+ value.claimPolicy.maxClaimsPerOperator !== undefined &&
167
+ value.claimPolicy.maxClaimsPerOperator > value.claimPolicy.maxClaims) {
168
+ ctx.addIssue({
169
+ code: z.ZodIssueCode.custom,
170
+ path: ['claimPolicy', 'maxClaimsPerOperator'],
171
+ message: 'must be <= claimPolicy.maxClaims',
172
+ });
173
+ }
174
+ });
175
+ function isRecordForContract(record, id, version) {
176
+ const contract = resolveContractFromSolverNetId(record.solverNetId);
177
+ return contract?.id === id && contract.version === version;
178
+ }
179
+ function defaultSweRebenchV2ClaimPolicy() {
180
+ const defaults = getSolverNetContract({
181
+ id: 'swe-rebench-v2',
182
+ version: 'v1',
183
+ })?.claimPolicyDefaults;
184
+ return {
185
+ maxClaims: defaults?.maxClaims ?? 50,
186
+ maxClaimsPerOperator: defaults?.maxClaimsPerOperator ?? 5,
187
+ claimLeaseTtlSeconds: defaults?.claimLeaseTtlSeconds ?? 60 * 60,
188
+ };
189
+ }
190
+ function mergeGeneratorConfigPatchForRecord(record, patch) {
191
+ const nextConfig = {
192
+ ...(record.generatorConfig ?? {}),
193
+ ...patch,
194
+ };
195
+ if (isRecordForContract(record, 'swe-rebench-v2', 'v1') &&
196
+ typeof patch.claimPolicy === 'object' &&
197
+ patch.claimPolicy !== null) {
198
+ const existingPolicy = typeof record.generatorConfig?.claimPolicy === 'object' &&
199
+ record.generatorConfig.claimPolicy !== null
200
+ ? record.generatorConfig.claimPolicy
201
+ : {};
202
+ nextConfig.claimPolicy = {
203
+ ...existingPolicy,
204
+ ...patch.claimPolicy,
205
+ };
206
+ }
207
+ return nextConfig;
208
+ }
209
+ function validateSweRebenchV2EffectiveConfig(record, config) {
210
+ if (!isRecordForContract(record, 'swe-rebench-v2', 'v1'))
211
+ return undefined;
212
+ const defaults = defaultSweRebenchV2ClaimPolicy();
213
+ const rawPolicy = typeof config.claimPolicy === 'object' && config.claimPolicy !== null
214
+ ? config.claimPolicy
215
+ : {};
216
+ const maxClaims = typeof rawPolicy.maxClaims === 'number'
217
+ ? rawPolicy.maxClaims
218
+ : defaults.maxClaims;
219
+ const maxClaimsPerOperator = typeof rawPolicy.maxClaimsPerOperator === 'number'
220
+ ? rawPolicy.maxClaimsPerOperator
221
+ : defaults.maxClaimsPerOperator;
222
+ if (maxClaimsPerOperator > maxClaims) {
223
+ return 'claimPolicy.maxClaimsPerOperator must be <= claimPolicy.maxClaims';
224
+ }
225
+ return undefined;
226
+ }
227
+ function parseGeneratorConfigPatchForRecord(record, raw) {
228
+ if (isRecordForContract(record, 'swe-rebench-v2', 'v1')) {
229
+ return SweRebenchV2GeneratorConfigPatchSchema.safeParse(raw);
230
+ }
231
+ return PredictionV1GeneratorConfigPatchSchema.safeParse(raw);
232
+ }
233
+ /**
234
+ * Inspect a draft to determine whether it is launchable. The launch endpoint
235
+ * uses this gate (and the gate alone) to decide whether to proceed; field-
236
+ * shape validation has already happened on every PATCH.
237
+ */
238
+ function checkDraftCompleteness(draft) {
239
+ const missing = [];
240
+ if (!draft.name || draft.name.trim().length === 0)
241
+ missing.push('name');
242
+ if (draft.description === undefined || draft.description === null)
243
+ missing.push('description');
244
+ if (!draft.templateContractId)
245
+ missing.push('templateContractId');
246
+ if (!draft.templateContractVersion)
247
+ missing.push('templateContractVersion');
248
+ if (!draft.solutionPriceWei)
249
+ missing.push('solutionPriceWei');
250
+ if (!draft.verdictPriceWei)
251
+ missing.push('verdictPriceWei');
252
+ if (!draft.openRoles || draft.openRoles.length === 0)
253
+ missing.push('openRoles');
254
+ return { ok: missing.length === 0, missingFields: missing };
255
+ }
256
+ /**
257
+ * Build an `UnsignedSolverNetManifestV1` from a launchable draft + the
258
+ * configured launcher identity + the SDK contract template. Caller signs
259
+ * the result and hands it to `LaunchAction.launch`.
260
+ *
261
+ * `solverNetId` is derived from the launcher agentId + a stable suffix
262
+ * derived from the draftId so re-launching the same draft would collide
263
+ * (idempotency) — but because we delete drafts post-launch, in practice each
264
+ * draft launches once and the id is unique.
265
+ */
266
+ function buildUnsignedManifest(args) {
267
+ const { draft, launcher, network, now } = args;
268
+ const contract = getSolverNetContract({
269
+ id: draft.templateContractId,
270
+ version: draft.templateContractVersion,
271
+ });
272
+ if (!contract) {
273
+ return {
274
+ ok: false,
275
+ error: `unknown contract template ${draft.templateContractId}.${draft.templateContractVersion}`,
276
+ };
277
+ }
278
+ // Stable solverNetId: launcher agentId + draftId tail. Draft ids are uuid-
279
+ // based so this gives uniqueness across launchers and within a launcher.
280
+ const draftTail = draft.draftId.replace(/^draft_/, '').slice(0, 8);
281
+ const solverNetId = `${launcher.agentId}_${contract.id}-${contract.version}_${draftTail}`;
282
+ const nowIso = now().toISOString();
283
+ const manifest = {
284
+ schemaVersion: 'solvernet.manifest.v1',
285
+ solverNetId,
286
+ network,
287
+ name: draft.name,
288
+ description: draft.description ?? '',
289
+ launcher: {
290
+ safeAddress: launcher.safeAddress,
291
+ agentEoa: launcher.agentEoa,
292
+ agentId: launcher.agentId,
293
+ },
294
+ contract: {
295
+ id: contract.id,
296
+ version: contract.version,
297
+ schemas: {
298
+ task: contract.schemas.task.json,
299
+ solution: contract.schemas.solution.json,
300
+ verdict: contract.schemas.verdict.json,
301
+ },
302
+ claimPolicyDefaults: contract.claimPolicyDefaults,
303
+ credentialRequirements: contract.credentialRequirements,
304
+ // Copy the readonly `inputs` arrays so the manifest's mutable-array
305
+ // schema accepts them. Functional content is identical.
306
+ evaluationFunction: {
307
+ ...contract.evaluationFunction,
308
+ inputs: [...contract.evaluationFunction.inputs],
309
+ },
310
+ aggregationFunction: {
311
+ ...contract.aggregationFunction,
312
+ inputs: [...contract.aggregationFunction.inputs],
313
+ },
314
+ },
315
+ solutionPriceWei: draft.solutionPriceWei,
316
+ verdictPriceWei: draft.verdictPriceWei,
317
+ openRoles: draft.openRoles,
318
+ createdAt: draft.createdAt,
319
+ launchedAt: nowIso,
320
+ };
321
+ return { ok: true, manifest };
322
+ }
323
+ /**
324
+ * Project a (record, manifest) pair into the catalog-row summary shape
325
+ * shared with `SolverNetRegistryClient.listLaunched`.
326
+ *
327
+ * The lifecycle fields (`status`, `statusUpdatedAt`, `anchorBlock`) come
328
+ * from the local `LaunchedSolverNetRecord` because the daemon owns the
329
+ * authoritative view of what it has launched — we do *not* want to pay
330
+ * an extra subgraph round-trip to re-derive lifecycle state when the
331
+ * record already has it. The remaining fields (name, contract, prices,
332
+ * openRoles, launcher) come from the manifest body.
333
+ *
334
+ * `status` widens to the registry's three-value enum: launching/failed
335
+ * are local-only and never present on a record that has a manifest cached,
336
+ * but we coerce them defensively to `launched`/`retired` respectively to
337
+ * keep the projection total. Callers should gate on `record.status`
338
+ * being one of {launched, paused, retired} before deciding to display.
339
+ */
340
+ function summarizeLaunchedRecord(record, manifest) {
341
+ const status = record.status === 'paused'
342
+ ? 'paused'
343
+ : record.status === 'retired'
344
+ ? 'retired'
345
+ : 'launched';
346
+ return {
347
+ manifestCid: record.manifestCid,
348
+ solverNetId: manifest.solverNetId,
349
+ name: manifest.name,
350
+ network: manifest.network,
351
+ launcherAgentId: manifest.launcher.agentId,
352
+ launcherSafeAddress: manifest.launcher.safeAddress,
353
+ status,
354
+ statusUpdatedAt: record.statusUpdatedAt,
355
+ contractId: manifest.contract.id,
356
+ contractVersion: manifest.contract.version,
357
+ solutionPriceWei: manifest.solutionPriceWei,
358
+ verdictPriceWei: manifest.verdictPriceWei,
359
+ openRoles: manifest.openRoles,
360
+ anchorBlock: record.registry.metadataBlockNumber ?? 0,
361
+ };
362
+ }
363
+ /**
364
+ * Look up a manifest summary for a record, using only the registry
365
+ * client's in-process cache. Returns `undefined` on cache miss or when
366
+ * the registry client is not wired — callers (the launched-list /
367
+ * launched-get endpoints) treat `undefined` as "no summary available"
368
+ * and fall back to displaying record-only fields.
369
+ *
370
+ * Cache-only by design: the launched-list endpoint runs on every SPA
371
+ * poll, and an IPFS round-trip per row would dominate latency. For
372
+ * SolverNets the daemon launched itself, the cache is warm by
373
+ * construction (the launch path populates it).
374
+ */
375
+ async function tryGetSummary(record, registry) {
376
+ if (!registry)
377
+ return undefined;
378
+ try {
379
+ const manifest = await registry.getManifestFromCache({
380
+ manifestCid: record.manifestCid,
381
+ });
382
+ if (manifest === null)
383
+ return undefined;
384
+ return summarizeLaunchedRecord(record, manifest);
385
+ }
386
+ catch {
387
+ // Defensive — the cache lookup is supposed to be infallible, but a
388
+ // future async-backed cache could throw (storage error). We surface
389
+ // an undefined summary rather than failing the entire list response.
390
+ return undefined;
391
+ }
392
+ }
393
+ // ── Implementation ──────────────────────────────────────────────────────────
394
+ export function registerSolverNetsEndpoints(app, deps) {
395
+ // jinn-mono-hqz0: deps may be a Proxy whose `store` property only resolves
396
+ // after the SolverNet subsystem finishes post-bootstrap init. We bind a
397
+ // Proxy-backed `store` so each method call dereferences the live value
398
+ // at invocation time — destructuring would capture the initial undefined.
399
+ const store = new Proxy({}, {
400
+ get(_t, prop) {
401
+ const live = deps.store;
402
+ if (!live) {
403
+ throw new Error('SolverNet store not initialised; subsystem still booting');
404
+ }
405
+ const value = live[prop];
406
+ return typeof value === 'function' ? value.bind(live) : value;
407
+ },
408
+ });
409
+ // POST /v1/solvernets/drafts — create a new draft.
410
+ app.post('/v1/solvernets/drafts', async (c) => {
411
+ // Body is optional. An empty body (or a request with no body at all)
412
+ // produces a fully-empty draft — the SPA fills it in via subsequent
413
+ // PATCH calls as the operator walks the wizard.
414
+ let raw = {};
415
+ const text = await c.req.text();
416
+ if (text.length > 0) {
417
+ try {
418
+ raw = JSON.parse(text);
419
+ }
420
+ catch {
421
+ return c.json({ error: 'invalid_body', message: 'expected JSON body' }, 400);
422
+ }
423
+ }
424
+ const immutable = rejectImmutableFields(raw);
425
+ if (immutable) {
426
+ return c.json({ error: 'invalid_body', message: immutable.error }, 400);
427
+ }
428
+ const parsed = DraftEditableSchema.safeParse(raw);
429
+ if (!parsed.success) {
430
+ return c.json({
431
+ error: 'invalid_body',
432
+ message: parsed.error.issues
433
+ .map((i) => `${i.path.join('.') || '<body>'}: ${i.message}`)
434
+ .join('; '),
435
+ }, 400);
436
+ }
437
+ const now = new Date().toISOString();
438
+ const draft = {
439
+ schemaVersion: 'solvernet.draft.v1',
440
+ draftId: `draft_${randomUUID()}`,
441
+ completedSteps: parsed.data.completedSteps ?? [],
442
+ createdAt: now,
443
+ updatedAt: now,
444
+ ...(parsed.data.templateContractId !== undefined && {
445
+ templateContractId: parsed.data.templateContractId,
446
+ }),
447
+ ...(parsed.data.templateContractVersion !== undefined && {
448
+ templateContractVersion: parsed.data.templateContractVersion,
449
+ }),
450
+ ...(parsed.data.name !== undefined && { name: parsed.data.name }),
451
+ ...(parsed.data.description !== undefined && {
452
+ description: parsed.data.description,
453
+ }),
454
+ ...(parsed.data.generatorConfig !== undefined && {
455
+ generatorConfig: parsed.data.generatorConfig,
456
+ }),
457
+ ...(parsed.data.solutionPriceWei !== undefined && {
458
+ solutionPriceWei: parsed.data.solutionPriceWei,
459
+ }),
460
+ ...(parsed.data.verdictPriceWei !== undefined && {
461
+ verdictPriceWei: parsed.data.verdictPriceWei,
462
+ }),
463
+ ...(parsed.data.openRoles !== undefined && {
464
+ openRoles: parsed.data.openRoles,
465
+ }),
466
+ };
467
+ // Defensive parse: ensures the constructed shape still satisfies the
468
+ // store's schema. If a future schema field becomes required and we
469
+ // forget to populate it, we want a 500 here rather than a corrupt
470
+ // file on disk.
471
+ const validated = DraftSolverNetRecordSchema.safeParse(draft);
472
+ if (!validated.success) {
473
+ return c.json({
474
+ error: 'internal_error',
475
+ message: `failed to construct draft: ${validated.error.issues.map((i) => i.message).join('; ')}`,
476
+ }, 500);
477
+ }
478
+ try {
479
+ await store.writeDraft(validated.data);
480
+ }
481
+ catch (err) {
482
+ return c.json({
483
+ error: 'store_write_failed',
484
+ message: err instanceof Error ? err.message : String(err),
485
+ }, 500);
486
+ }
487
+ return c.json(validated.data);
488
+ });
489
+ // GET /v1/solvernets/drafts — list all owned drafts.
490
+ app.get('/v1/solvernets/drafts', async (c) => {
491
+ let drafts;
492
+ try {
493
+ drafts = await store.listDrafts();
494
+ }
495
+ catch (err) {
496
+ return c.json({
497
+ error: 'store_read_failed',
498
+ message: err instanceof Error ? err.message : String(err),
499
+ }, 500);
500
+ }
501
+ return c.json({ drafts });
502
+ });
503
+ // GET /v1/solvernets/drafts/:id — load a single draft.
504
+ app.get('/v1/solvernets/drafts/:id', async (c) => {
505
+ const id = c.req.param('id');
506
+ if (!id) {
507
+ return c.json({ error: 'invalid_invocation', message: 'missing draft id' }, 400);
508
+ }
509
+ let draft;
510
+ try {
511
+ draft = await store.loadDraft(id);
512
+ }
513
+ catch (err) {
514
+ return c.json({
515
+ error: 'store_read_failed',
516
+ message: err instanceof Error ? err.message : String(err),
517
+ }, 500);
518
+ }
519
+ if (!draft) {
520
+ return c.json({ error: 'draft_not_found', message: `Unknown draft: ${id}` }, 404);
521
+ }
522
+ return c.json(draft);
523
+ });
524
+ // PATCH /v1/solvernets/drafts/:id — update a draft.
525
+ app.patch('/v1/solvernets/drafts/:id', async (c) => {
526
+ const id = c.req.param('id');
527
+ if (!id) {
528
+ return c.json({ error: 'invalid_invocation', message: 'missing draft id' }, 400);
529
+ }
530
+ let raw;
531
+ try {
532
+ raw = await c.req.json();
533
+ }
534
+ catch {
535
+ return c.json({ error: 'invalid_body', message: 'expected JSON body' }, 400);
536
+ }
537
+ const immutable = rejectImmutableFields(raw);
538
+ if (immutable) {
539
+ return c.json({ error: 'invalid_body', message: immutable.error }, 400);
540
+ }
541
+ const parsed = DraftEditableSchema.safeParse(raw);
542
+ if (!parsed.success) {
543
+ return c.json({
544
+ error: 'invalid_body',
545
+ message: parsed.error.issues
546
+ .map((i) => `${i.path.join('.') || '<body>'}: ${i.message}`)
547
+ .join('; '),
548
+ }, 400);
549
+ }
550
+ let existing;
551
+ try {
552
+ existing = await store.loadDraft(id);
553
+ }
554
+ catch (err) {
555
+ return c.json({
556
+ error: 'store_read_failed',
557
+ message: err instanceof Error ? err.message : String(err),
558
+ }, 500);
559
+ }
560
+ if (!existing) {
561
+ return c.json({ error: 'draft_not_found', message: `Unknown draft: ${id}` }, 404);
562
+ }
563
+ const next = applyEditable(existing, parsed.data, new Date().toISOString());
564
+ const validated = DraftSolverNetRecordSchema.safeParse(next);
565
+ if (!validated.success) {
566
+ return c.json({
567
+ error: 'invalid_body',
568
+ message: validated.error.issues
569
+ .map((i) => `${i.path.join('.') || '<body>'}: ${i.message}`)
570
+ .join('; '),
571
+ }, 400);
572
+ }
573
+ try {
574
+ await store.writeDraft(validated.data);
575
+ }
576
+ catch (err) {
577
+ return c.json({
578
+ error: 'store_write_failed',
579
+ message: err instanceof Error ? err.message : String(err),
580
+ }, 500);
581
+ }
582
+ return c.json(validated.data);
583
+ });
584
+ // DELETE /v1/solvernets/drafts/:id — delete a draft.
585
+ app.delete('/v1/solvernets/drafts/:id', async (c) => {
586
+ const id = c.req.param('id');
587
+ if (!id) {
588
+ return c.json({ error: 'invalid_invocation', message: 'missing draft id' }, 400);
589
+ }
590
+ // Surface 404 for unknown ids rather than silent-success. The SPA can
591
+ // distinguish "I deleted the only copy" from "this id was never there"
592
+ // — useful for stale-tab detection.
593
+ let existing;
594
+ try {
595
+ existing = await store.loadDraft(id);
596
+ }
597
+ catch (err) {
598
+ return c.json({
599
+ error: 'store_read_failed',
600
+ message: err instanceof Error ? err.message : String(err),
601
+ }, 500);
602
+ }
603
+ if (!existing) {
604
+ return c.json({ error: 'draft_not_found', message: `Unknown draft: ${id}` }, 404);
605
+ }
606
+ try {
607
+ await store.deleteDraft(id);
608
+ }
609
+ catch (err) {
610
+ return c.json({
611
+ error: 'store_write_failed',
612
+ message: err instanceof Error ? err.message : String(err),
613
+ }, 500);
614
+ }
615
+ return c.json({ ok: true });
616
+ });
617
+ // ── Task 14 routes ────────────────────────────────────────────────────────
618
+ // POST /v1/solvernets/drafts/:id/launch — kick off the launch state machine.
619
+ //
620
+ // Behaviour: validate completeness, build + sign the manifest, fire
621
+ // `launchAction.launch(...)` in the background, and return 202 with a
622
+ // poll URL. The state machine pins to IPFS, writes the initial record,
623
+ // broadcasts setMetadata, awaits confirmation, and spawns the generator
624
+ // — all asynchronously. The SPA polls `GET /v1/solvernets/launched/:id`
625
+ // to track progress (`launchProgress.phase` reflects which phase the
626
+ // machine is currently in).
627
+ app.post('/v1/solvernets/drafts/:id/launch', async (c) => {
628
+ const id = c.req.param('id');
629
+ if (!id) {
630
+ return c.json({ error: 'invalid_invocation', message: 'missing draft id' }, 400);
631
+ }
632
+ if (!deps.launch) {
633
+ return c.json({
634
+ error: 'launch_unavailable',
635
+ message: 'launch routes are not configured; the daemon is missing launch dependencies',
636
+ }, 503);
637
+ }
638
+ const launchDeps = deps.launch;
639
+ let draft;
640
+ try {
641
+ draft = await store.loadDraft(id);
642
+ }
643
+ catch (err) {
644
+ return c.json({
645
+ error: 'store_read_failed',
646
+ message: err instanceof Error ? err.message : String(err),
647
+ }, 500);
648
+ }
649
+ if (!draft) {
650
+ return c.json({ error: 'draft_not_found', message: `Unknown draft: ${id}` }, 404);
651
+ }
652
+ const completeness = checkDraftCompleteness(draft);
653
+ if (!completeness.ok) {
654
+ return c.json({
655
+ error: 'draft_incomplete',
656
+ message: `draft is missing required fields: ${completeness.missingFields.join(', ')}`,
657
+ missingFields: completeness.missingFields,
658
+ }, 400);
659
+ }
660
+ const built = buildUnsignedManifest({
661
+ draft,
662
+ launcher: launchDeps.launcher,
663
+ network: launchDeps.network,
664
+ now: launchDeps.now ?? (() => new Date()),
665
+ });
666
+ if (!built.ok) {
667
+ return c.json({ error: 'invalid_template', message: built.error }, 400);
668
+ }
669
+ let manifest;
670
+ try {
671
+ manifest = await signManifest(built.manifest, launchDeps.signer.agentEoaPrivateKey);
672
+ }
673
+ catch (err) {
674
+ return c.json({
675
+ error: 'manifest_sign_failed',
676
+ message: err instanceof Error ? err.message : String(err),
677
+ }, 500);
678
+ }
679
+ // Idempotency: if a record with this solverNetId already exists, return
680
+ // it instead of starting a second launch. The state machine itself is
681
+ // also idempotent (launch() routes to resume() for existing records),
682
+ // but short-circuiting here avoids a redundant signManifest round.
683
+ const existing = await store.loadRecord(manifest.solverNetId);
684
+ if (existing) {
685
+ return c.json({
686
+ solverNetId: manifest.solverNetId,
687
+ status: existing.status,
688
+ pollUrl: `/v1/solvernets/launched/${manifest.solverNetId}`,
689
+ }, 202);
690
+ }
691
+ // Fire-and-forget: the launch state machine pins, writes the record,
692
+ // broadcasts, awaits confirmation, and spawns the generator. We do not
693
+ // await it here — production launches can take 30+ seconds (IPFS pin +
694
+ // tx confirmation) and the SPA tracks progress via `launchProgress`.
695
+ void launchDeps.launchAction
696
+ .launch({
697
+ manifest,
698
+ signer: launchDeps.signer,
699
+ // jinn-mono-jnr1: forward the wizard's per-record runtime config so
700
+ // the launched record persists it; otherwise the generator falls
701
+ // back to DEFAULTS (cadence 6h etc.) regardless of what the
702
+ // operator picked in the Create flow.
703
+ generatorConfig: draft.generatorConfig,
704
+ })
705
+ .catch((err) => {
706
+ // The state machine has already persisted the failure to disk
707
+ // (`launchProgress.txError`); we just log so the daemon operator
708
+ // sees the failure in stderr without crashing the process.
709
+ // eslint-disable-next-line no-console
710
+ console.error(`[solvernets] background launch ${manifest.solverNetId} failed:`, err);
711
+ });
712
+ // Briefly wait for the initial record to land on disk so the SPA's
713
+ // first poll always finds a record. The launch action's first persisted
714
+ // checkpoint is after the IPFS upload — typically <100ms with mocked
715
+ // ipfs (tests) or a few seconds in production. If it does not show up
716
+ // within the timeout we return 202 anyway; the SPA's poll will reveal
717
+ // the failure.
718
+ const POLL_BUDGET_MS = 5_000;
719
+ const POLL_INTERVAL_MS = 25;
720
+ const start = Date.now();
721
+ let initialRecord = null;
722
+ while (Date.now() - start < POLL_BUDGET_MS) {
723
+ initialRecord = await store.loadRecord(manifest.solverNetId);
724
+ if (initialRecord)
725
+ break;
726
+ await new Promise((r) => setTimeout(r, POLL_INTERVAL_MS));
727
+ }
728
+ return c.json({
729
+ solverNetId: manifest.solverNetId,
730
+ status: initialRecord?.status ?? 'launching',
731
+ pollUrl: `/v1/solvernets/launched/${manifest.solverNetId}`,
732
+ }, 202);
733
+ });
734
+ // GET /v1/solvernets/launched/:id — read the current launched record.
735
+ //
736
+ // Prefers the in-memory recordRef (lifecycle / launch state machines
737
+ // mutate it synchronously after each disk write) and falls back to disk.
738
+ // Either source is up-to-date because both are written before the
739
+ // operation returns.
740
+ //
741
+ // Response shape: the persisted record fields + an optional
742
+ // `summary?: SolverNetManifestSummary` derived from the registry
743
+ // client's in-process manifest cache. Cache miss → `summary` is
744
+ // omitted. The summary is the only place catalog-y identity (name,
745
+ // contract id/version, prices, openRoles) appears on this surface;
746
+ // the SPA falls back to bare record fields when it is missing.
747
+ app.get('/v1/solvernets/launched/:id', async (c) => {
748
+ const id = c.req.param('id');
749
+ if (!id) {
750
+ return c.json({ error: 'invalid_invocation', message: 'missing record id' }, 400);
751
+ }
752
+ // Prefer in-memory ref when available (lifecycle / launch updates land
753
+ // there first via mutation).
754
+ if (deps.launch) {
755
+ const entry = deps.launch.pendingGenerators.current.find((g) => g.recordRef.current.solverNetId === id);
756
+ if (entry) {
757
+ const summary = await tryGetSummary(entry.recordRef.current, deps.registry);
758
+ return c.json({
759
+ ...entry.recordRef.current,
760
+ ...(summary !== undefined ? { summary } : {}),
761
+ });
762
+ }
763
+ }
764
+ let record;
765
+ try {
766
+ record = await store.loadRecord(id);
767
+ }
768
+ catch (err) {
769
+ return c.json({
770
+ error: 'store_read_failed',
771
+ message: err instanceof Error ? err.message : String(err),
772
+ }, 500);
773
+ }
774
+ if (!record) {
775
+ return c.json({ error: 'record_not_found', message: `Unknown record: ${id}` }, 404);
776
+ }
777
+ const summary = await tryGetSummary(record, deps.registry);
778
+ return c.json({
779
+ ...record,
780
+ ...(summary !== undefined ? { summary } : {}),
781
+ });
782
+ });
783
+ // PATCH /v1/solvernets/launched/:id/lifecycle — pause / resume / retire.
784
+ //
785
+ // Blocking: the lifecycle transition is one tx + one receipt, typically
786
+ // 5-30 seconds. We await completion and return the updated record so the
787
+ // SPA can re-render in a single round-trip.
788
+ app.patch('/v1/solvernets/launched/:id/lifecycle', async (c) => {
789
+ const id = c.req.param('id');
790
+ if (!id) {
791
+ return c.json({ error: 'invalid_invocation', message: 'missing record id' }, 400);
792
+ }
793
+ if (!deps.launch) {
794
+ return c.json({
795
+ error: 'launch_unavailable',
796
+ message: 'lifecycle routes are not configured',
797
+ }, 503);
798
+ }
799
+ const launchDeps = deps.launch;
800
+ let raw;
801
+ try {
802
+ raw = await c.req.json();
803
+ }
804
+ catch {
805
+ return c.json({ error: 'invalid_body', message: 'expected JSON body' }, 400);
806
+ }
807
+ const parsed = LifecycleBodySchema.safeParse(raw);
808
+ if (!parsed.success) {
809
+ return c.json({
810
+ error: 'invalid_body',
811
+ message: parsed.error.issues
812
+ .map((i) => `${i.path.join('.') || '<body>'}: ${i.message}`)
813
+ .join('; '),
814
+ }, 400);
815
+ }
816
+ const target = parsed.data.target;
817
+ let record;
818
+ try {
819
+ record = await store.loadRecord(id);
820
+ }
821
+ catch (err) {
822
+ return c.json({
823
+ error: 'store_read_failed',
824
+ message: err instanceof Error ? err.message : String(err),
825
+ }, 500);
826
+ }
827
+ if (!record) {
828
+ return c.json({ error: 'record_not_found', message: `Unknown record: ${id}` }, 404);
829
+ }
830
+ // Terminal-state guard at the API edge so the caller gets a typed error
831
+ // before we even touch the state machine. The state machine also
832
+ // rejects (it is the source of truth) but surfacing it here gives a
833
+ // stable error code.
834
+ if (record.status === 'retired' && target !== 'retired') {
835
+ return c.json({
836
+ error: 'lifecycle_terminal',
837
+ message: `SolverNet ${id} is retired; transitions are no-ops`,
838
+ }, 400);
839
+ }
840
+ // Idempotent no-op: caller's view matches current state, no work to do.
841
+ if (record.status === target && record.lifecycleProgress === undefined) {
842
+ return c.json(record);
843
+ }
844
+ let updated;
845
+ try {
846
+ updated = await launchDeps.lifecycleTransition.transition(record, target);
847
+ }
848
+ catch (err) {
849
+ return c.json({
850
+ error: 'lifecycle_failed',
851
+ message: err instanceof Error ? err.message : String(err),
852
+ }, 500);
853
+ }
854
+ // Mutate the in-memory recordRef so subsequent reads (and the next
855
+ // generator tick) see the new status without waiting for a disk reload.
856
+ const entry = launchDeps.pendingGenerators.current.find((g) => g.recordRef.current.solverNetId === id);
857
+ if (entry) {
858
+ entry.recordRef.current = updated;
859
+ }
860
+ return c.json(updated);
861
+ });
862
+ // PATCH /v1/solvernets/launched/:id/generator-config — hot-apply config.
863
+ //
864
+ // Updates the persisted record's `generatorConfig` AND mutates the live
865
+ // `configRef.current` for any pendingGenerators entry. The next generator
866
+ // tick reads the new cadence/allowlist/caps via the ref.
867
+ app.patch('/v1/solvernets/launched/:id/generator-config', async (c) => {
868
+ const id = c.req.param('id');
869
+ if (!id) {
870
+ return c.json({ error: 'invalid_invocation', message: 'missing record id' }, 400);
871
+ }
872
+ if (!deps.launch) {
873
+ return c.json({
874
+ error: 'launch_unavailable',
875
+ message: 'generator-config routes are not configured',
876
+ }, 503);
877
+ }
878
+ const launchDeps = deps.launch;
879
+ let raw;
880
+ try {
881
+ raw = await c.req.json();
882
+ }
883
+ catch {
884
+ return c.json({ error: 'invalid_body', message: 'expected JSON body' }, 400);
885
+ }
886
+ let record;
887
+ try {
888
+ record = await store.loadRecord(id);
889
+ }
890
+ catch (err) {
891
+ return c.json({
892
+ error: 'store_read_failed',
893
+ message: err instanceof Error ? err.message : String(err),
894
+ }, 500);
895
+ }
896
+ if (!record) {
897
+ return c.json({ error: 'record_not_found', message: `Unknown record: ${id}` }, 404);
898
+ }
899
+ const parsed = parseGeneratorConfigPatchForRecord(record, raw);
900
+ if (!parsed.success) {
901
+ return c.json({
902
+ error: 'invalid_body',
903
+ message: parsed.error.issues
904
+ .map((i) => `${i.path.join('.') || '<body>'}: ${i.message}`)
905
+ .join('; '),
906
+ }, 400);
907
+ }
908
+ // Patch semantics: merge the provided fields over the existing config.
909
+ // Operators editing one field shouldn't have to re-send the rest.
910
+ const nextConfig = mergeGeneratorConfigPatchForRecord(record, parsed.data);
911
+ const effectiveConfigError = validateSweRebenchV2EffectiveConfig(record, nextConfig);
912
+ if (effectiveConfigError) {
913
+ return c.json({
914
+ error: 'invalid_body',
915
+ message: effectiveConfigError,
916
+ }, 400);
917
+ }
918
+ // Persist on disk. The store schema treats generatorConfig as an opaque
919
+ // record; we widen the strongly-typed runtime config back to that shape
920
+ // for storage.
921
+ const updatedRecord = {
922
+ ...record,
923
+ generatorConfig: nextConfig,
924
+ };
925
+ const validated = LaunchedSolverNetRecordSchema.safeParse(updatedRecord);
926
+ if (!validated.success) {
927
+ return c.json({
928
+ error: 'invalid_record',
929
+ message: `failed to construct updated record: ${validated.error.issues.map((i) => i.message).join('; ')}`,
930
+ }, 500);
931
+ }
932
+ try {
933
+ await store.writeRecord(validated.data);
934
+ }
935
+ catch (err) {
936
+ return c.json({
937
+ error: 'store_write_failed',
938
+ message: err instanceof Error ? err.message : String(err),
939
+ }, 500);
940
+ }
941
+ // Hot-apply: mutate the live configRef + recordRef in place so the next
942
+ // generator tick sees the new config without waiting for a disk reload.
943
+ // It is valid for there to be no pendingGenerators entry (e.g. the
944
+ // record is paused / retired and the generator is not running) — the
945
+ // disk write above is enough; the next time the daemon spawns the
946
+ // generator (next launched-status flip) it will seed configRef from
947
+ // the persisted record.
948
+ const entry = launchDeps.pendingGenerators.current.find((g) => g.recordRef.current.solverNetId === id);
949
+ if (entry) {
950
+ entry.configRef.current = nextConfig;
951
+ entry.recordRef.current = validated.data;
952
+ }
953
+ return c.json(nextConfig);
954
+ });
955
+ // ── Task 15 routes ────────────────────────────────────────────────────────
956
+ // GET /v1/solvernets/launched — list owned launched records (= what this
957
+ // daemon launched). The registry catalog (below) is the global view; this
958
+ // is the local mirror — exactly the rows the daemon is responsible for
959
+ // running generators for.
960
+ //
961
+ // Optional `?status=<launching|launched|paused|retired|failed>` filter
962
+ // narrows the list. Without the filter, all records (including retired)
963
+ // are returned — the SPA decides what to show. This shape lets the SPA
964
+ // render a unified "your SolverNets" tab without N round-trips.
965
+ //
966
+ // Each row also carries an optional `summary?: SolverNetManifestSummary`
967
+ // populated from the registry client's in-process manifest cache —
968
+ // populated for every SolverNet this daemon launched (the launch path
969
+ // primes the cache), `undefined` for the pre-cache window during a
970
+ // launch in flight. Cache-only on purpose: list responses run on every
971
+ // SPA poll, and an IPFS round-trip per row would dominate latency.
972
+ app.get('/v1/solvernets/launched', async (c) => {
973
+ const statusQuery = c.req.query('status');
974
+ let statusFilter;
975
+ if (statusQuery !== undefined) {
976
+ const parsed = OwnedStatusFilterSchema.safeParse(statusQuery);
977
+ if (!parsed.success) {
978
+ return c.json({
979
+ error: 'invalid_query',
980
+ message: `unknown status filter: ${statusQuery}`,
981
+ }, 400);
982
+ }
983
+ statusFilter = parsed.data;
984
+ }
985
+ let records;
986
+ try {
987
+ records = await store.loadOwnedRecords();
988
+ }
989
+ catch (err) {
990
+ return c.json({
991
+ error: 'store_read_failed',
992
+ message: err instanceof Error ? err.message : String(err),
993
+ }, 500);
994
+ }
995
+ if (statusFilter !== undefined) {
996
+ records = records.filter((r) => r.status === statusFilter);
997
+ }
998
+ // Enrich each record with its manifest summary from the cache, when
999
+ // available. We `Promise.all` the lookups so a future async-backed
1000
+ // cache (e.g. SQLite) would not serialize per row, even though the
1001
+ // day-1 implementation is a synchronous Map read.
1002
+ const enriched = await Promise.all(records.map(async (record) => {
1003
+ const summary = await tryGetSummary(record, deps.registry);
1004
+ return summary !== undefined ? { ...record, summary } : record;
1005
+ }));
1006
+ return c.json({ records: enriched });
1007
+ });
1008
+ // GET /v1/solvernets/registry — list global launched SolverNets from the
1009
+ // catalog cache (populated by the daemon's registry-catalog refresh loop
1010
+ // wired in `daemon-init.ts`).
1011
+ //
1012
+ // Behaviour:
1013
+ // - Default filter is `launched + paused`; retired entries are excluded
1014
+ // unless the caller explicitly asks for `?status=retired`. This matches
1015
+ // the join-flow's "useful surface" — operators picking a SolverNet to
1016
+ // join shouldn't have to scroll past tombstoned ones.
1017
+ // - `?refresh=1` forces a refresh before reading the snapshot. The SPA
1018
+ // uses this on user-initiated reload; the auto-tick keeps the cache
1019
+ // warm in the background.
1020
+ // - Cache metadata (`lastRefreshedAt`, `lastError`) is always returned
1021
+ // so the SPA can render a "stale" indicator and surface errors.
1022
+ app.get('/v1/solvernets/registry', async (c) => {
1023
+ if (!deps.catalog) {
1024
+ return c.json({
1025
+ error: 'registry_unavailable',
1026
+ message: 'registry catalog cache is not configured',
1027
+ }, 503);
1028
+ }
1029
+ const catalog = deps.catalog;
1030
+ const statusQuery = c.req.query('status');
1031
+ let statusFilter;
1032
+ if (statusQuery !== undefined) {
1033
+ const parsed = RegistryStatusFilterSchema.safeParse(statusQuery);
1034
+ if (!parsed.success) {
1035
+ return c.json({
1036
+ error: 'invalid_query',
1037
+ message: `unknown status filter: ${statusQuery}`,
1038
+ }, 400);
1039
+ }
1040
+ statusFilter = [parsed.data];
1041
+ }
1042
+ else {
1043
+ // Default: launched + paused. Retired is excluded from the default
1044
+ // surface — operators see those only via explicit ?status=retired.
1045
+ statusFilter = ['launched', 'paused'];
1046
+ }
1047
+ if (c.req.query('refresh') === '1') {
1048
+ // Force a refresh before reading the snapshot. The cache itself
1049
+ // suppresses errors — they land in `lastError` which we surface in
1050
+ // the response, so the SPA can show "couldn't refresh, here's the
1051
+ // last cached snapshot" rather than a blank page.
1052
+ await catalog.refresh();
1053
+ }
1054
+ const snapshot = catalog.getCatalog();
1055
+ const summaries = snapshot.filter((s) => statusFilter.includes(s.status));
1056
+ const lastRefreshedAt = catalog.lastRefreshedAt();
1057
+ const lastError = catalog.lastError();
1058
+ return c.json({
1059
+ summaries,
1060
+ lastRefreshedAt: lastRefreshedAt === null ? null : lastRefreshedAt.toISOString(),
1061
+ lastError: lastError === null
1062
+ ? null
1063
+ : { message: lastError.message, at: lastError.at.toISOString() },
1064
+ });
1065
+ });
1066
+ // GET /v1/solvernets/registry/:cid — fetch a specific manifest from the
1067
+ // registry, with its current lifecycle status.
1068
+ //
1069
+ // The registry client validates the manifest's canonical hash against the
1070
+ // on-chain advertised hash; if it throws (missing IPFS body, schema
1071
+ // mismatch, hash mismatch), we surface 404 — the manifest is "not found"
1072
+ // from a useful-surface perspective regardless of which leg failed. The
1073
+ // exact failure reason is in the response message for debugging.
1074
+ //
1075
+ // CID validation here is intentionally loose: we reject obvious garbage
1076
+ // (path-traversal, decimals, empty) so we never round-trip them to IPFS,
1077
+ // but the registry client does the canonical check.
1078
+ app.get('/v1/solvernets/registry/:cid', async (c) => {
1079
+ if (!deps.registry) {
1080
+ return c.json({
1081
+ error: 'registry_unavailable',
1082
+ message: 'registry client is not configured',
1083
+ }, 503);
1084
+ }
1085
+ const registry = deps.registry;
1086
+ const cid = c.req.param('cid');
1087
+ if (!cid || !CID_SHAPE_REGEX.test(cid)) {
1088
+ return c.json({
1089
+ error: 'invalid_cid',
1090
+ message: `cid does not look like a CID: ${cid ?? '<empty>'}`,
1091
+ }, 400);
1092
+ }
1093
+ let manifest;
1094
+ try {
1095
+ manifest = await registry.getManifest({ manifestCid: cid });
1096
+ }
1097
+ catch (err) {
1098
+ return c.json({
1099
+ error: 'manifest_not_found',
1100
+ message: err instanceof Error ? err.message : String(err),
1101
+ }, 404);
1102
+ }
1103
+ let lifecycle;
1104
+ try {
1105
+ lifecycle = await registry.getLifecycleStatus({ manifestCid: cid });
1106
+ }
1107
+ catch (err) {
1108
+ // The manifest body exists on IPFS but no lifecycle events were found
1109
+ // on chain — surface as 404 with the real reason in the message.
1110
+ // This is genuinely unusual (the launcher must have setMetadata'd the
1111
+ // initial cid for the manifest to be discoverable at all), but it can
1112
+ // happen during the brief window between IPFS pin and on-chain confirm.
1113
+ return c.json({
1114
+ error: 'manifest_not_found',
1115
+ message: err instanceof Error ? err.message : String(err),
1116
+ }, 404);
1117
+ }
1118
+ return c.json({ manifest, lifecycle });
1119
+ });
1120
+ }
1121
+ //# sourceMappingURL=solvernets-endpoints.js.map