@jinn-network/client 0.1.2 → 0.1.3-canary.262e5cda

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 (812) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/CONTRIBUTING.md +8 -2
  3. package/README.md +38 -14
  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/dist/adapters/adapter.d.ts +2 -2
  10. package/dist/adapters/claim-registry/client.d.ts +9 -0
  11. package/dist/adapters/claim-registry/client.js +22 -2
  12. package/dist/adapters/claim-registry/client.js.map +1 -1
  13. package/dist/adapters/local/adapter.d.ts +2 -2
  14. package/dist/adapters/local/adapter.js +8 -8
  15. package/dist/adapters/local/adapter.js.map +1 -1
  16. package/dist/adapters/mech/adapter.d.ts +3 -4
  17. package/dist/adapters/mech/adapter.js +86 -50
  18. package/dist/adapters/mech/adapter.js.map +1 -1
  19. package/dist/adapters/mech/contracts.d.ts +6 -4
  20. package/dist/adapters/mech/contracts.js +118 -14
  21. package/dist/adapters/mech/contracts.js.map +1 -1
  22. package/dist/adapters/mech/ipfs.d.ts +61 -6
  23. package/dist/adapters/mech/ipfs.js +159 -26
  24. package/dist/adapters/mech/ipfs.js.map +1 -1
  25. package/dist/adapters/mech/safe-revert.d.ts +39 -0
  26. package/dist/adapters/mech/safe-revert.js +130 -0
  27. package/dist/adapters/mech/safe-revert.js.map +1 -0
  28. package/dist/adapters/mech/safe.js +47 -21
  29. package/dist/adapters/mech/safe.js.map +1 -1
  30. package/dist/adapters/mech/types.d.ts +8 -0
  31. package/dist/adapters/mech/types.js.map +1 -1
  32. package/dist/agent/agent-ws.d.ts +55 -0
  33. package/dist/agent/agent-ws.js +288 -0
  34. package/dist/agent/agent-ws.js.map +1 -0
  35. package/dist/agent/auto-mode-detect.d.ts +6 -0
  36. package/dist/agent/auto-mode-detect.js +44 -0
  37. package/dist/agent/auto-mode-detect.js.map +1 -0
  38. package/dist/agent/operator-claude.d.ts +22 -0
  39. package/dist/agent/operator-claude.js +130 -0
  40. package/dist/agent/operator-claude.js.map +1 -0
  41. package/dist/api/admin-endpoint.d.ts +12 -0
  42. package/dist/api/admin-endpoint.js +71 -0
  43. package/dist/api/admin-endpoint.js.map +1 -0
  44. package/dist/api/bootstrap-endpoint.d.ts +16 -0
  45. package/dist/api/bootstrap-endpoint.js +78 -0
  46. package/dist/api/bootstrap-endpoint.js.map +1 -0
  47. package/dist/api/events-endpoint.d.ts +9 -0
  48. package/dist/api/events-endpoint.js +46 -0
  49. package/dist/api/events-endpoint.js.map +1 -0
  50. package/dist/api/fleet-build.d.ts +1 -1
  51. package/dist/api/fleet-build.js +17 -8
  52. package/dist/api/fleet-build.js.map +1 -1
  53. package/dist/api/gather-status.js +5 -1
  54. package/dist/api/gather-status.js.map +1 -1
  55. package/dist/api/handshake.d.ts +17 -0
  56. package/dist/api/handshake.js +28 -0
  57. package/dist/api/handshake.js.map +1 -0
  58. package/dist/api/peers.js +20 -5
  59. package/dist/api/peers.js.map +1 -1
  60. package/dist/api/portfolio-v0-build.d.ts +6 -0
  61. package/dist/api/portfolio-v0-build.js +6 -1
  62. package/dist/api/portfolio-v0-build.js.map +1 -1
  63. package/dist/api/rewards-build.js +3 -8
  64. package/dist/api/rewards-build.js.map +1 -1
  65. package/dist/api/server.d.ts +54 -0
  66. package/dist/api/server.js +239 -13
  67. package/dist/api/server.js.map +1 -1
  68. package/dist/api/setup-endpoints.d.ts +34 -0
  69. package/dist/api/setup-endpoints.js +188 -0
  70. package/dist/api/setup-endpoints.js.map +1 -0
  71. package/dist/api/status-build.d.ts +9 -1
  72. package/dist/api/status-build.js +44 -9
  73. package/dist/api/status-build.js.map +1 -1
  74. package/dist/api/status-rollup-build.d.ts +46 -1
  75. package/dist/api/status-rollup-build.js +168 -5
  76. package/dist/api/status-rollup-build.js.map +1 -1
  77. package/dist/api/ui-token.d.ts +5 -0
  78. package/dist/api/ui-token.js +36 -0
  79. package/dist/api/ui-token.js.map +1 -0
  80. package/dist/build-info.d.ts +32 -0
  81. package/dist/build-info.js +69 -0
  82. package/dist/build-info.js.map +1 -0
  83. package/dist/build-info.json +6 -0
  84. package/dist/build-meta.json +1 -1
  85. package/dist/cli/command.d.ts +9 -0
  86. package/dist/cli/commands/balance.d.ts +7 -0
  87. package/dist/cli/commands/balance.js +38 -32
  88. package/dist/cli/commands/balance.js.map +1 -1
  89. package/dist/cli/commands/bootstrap.d.ts +13 -1
  90. package/dist/cli/commands/bootstrap.js +150 -132
  91. package/dist/cli/commands/bootstrap.js.map +1 -1
  92. package/dist/cli/commands/claim-rewards.js +14 -2
  93. package/dist/cli/commands/claim-rewards.js.map +1 -1
  94. package/dist/cli/commands/conformance.d.ts +12 -0
  95. package/dist/cli/commands/conformance.js +140 -0
  96. package/dist/cli/commands/conformance.js.map +1 -0
  97. package/dist/cli/commands/create.d.ts +36 -0
  98. package/dist/cli/commands/create.js +374 -0
  99. package/dist/cli/commands/create.js.map +1 -0
  100. package/dist/cli/commands/doctor.d.ts +34 -1
  101. package/dist/cli/commands/doctor.js +136 -121
  102. package/dist/cli/commands/doctor.js.map +1 -1
  103. package/dist/cli/commands/fleet-scale.d.ts +19 -1
  104. package/dist/cli/commands/fleet-scale.js +379 -361
  105. package/dist/cli/commands/fleet-scale.js.map +1 -1
  106. package/dist/cli/commands/fleet.d.ts +7 -0
  107. package/dist/cli/commands/fleet.js +39 -33
  108. package/dist/cli/commands/fleet.js.map +1 -1
  109. package/dist/cli/commands/fund-requirements.d.ts +14 -1
  110. package/dist/cli/commands/fund-requirements.js +183 -174
  111. package/dist/cli/commands/fund-requirements.js.map +1 -1
  112. package/dist/cli/commands/history.d.ts +10 -1
  113. package/dist/cli/commands/history.js +66 -57
  114. package/dist/cli/commands/history.js.map +1 -1
  115. package/dist/cli/commands/impls.d.ts +18 -0
  116. package/dist/cli/commands/impls.js +208 -0
  117. package/dist/cli/commands/impls.js.map +1 -0
  118. package/dist/cli/commands/init.js +4 -1
  119. package/dist/cli/commands/init.js.map +1 -1
  120. package/dist/cli/commands/intents.js +13 -9
  121. package/dist/cli/commands/intents.js.map +1 -1
  122. package/dist/cli/commands/logs.d.ts +6 -1
  123. package/dist/cli/commands/logs.js +77 -70
  124. package/dist/cli/commands/logs.js.map +1 -1
  125. package/dist/cli/commands/migrate-agent-id.d.ts +26 -0
  126. package/dist/cli/commands/migrate-agent-id.js +165 -0
  127. package/dist/cli/commands/migrate-agent-id.js.map +1 -0
  128. package/dist/cli/commands/plug-ins.d.ts +34 -0
  129. package/dist/cli/commands/plug-ins.js +282 -0
  130. package/dist/cli/commands/plug-ins.js.map +1 -0
  131. package/dist/cli/commands/plugin-install.d.ts +10 -0
  132. package/dist/cli/commands/plugin-install.js +226 -14
  133. package/dist/cli/commands/plugin-install.js.map +1 -1
  134. package/dist/cli/commands/rewards.d.ts +7 -0
  135. package/dist/cli/commands/rewards.js +46 -40
  136. package/dist/cli/commands/rewards.js.map +1 -1
  137. package/dist/cli/commands/run.d.ts +14 -1
  138. package/dist/cli/commands/run.js +232 -90
  139. package/dist/cli/commands/run.js.map +1 -1
  140. package/dist/cli/commands/status.d.ts +10 -0
  141. package/dist/cli/commands/status.js +97 -34
  142. package/dist/cli/commands/status.js.map +1 -1
  143. package/dist/cli/commands/submit-intent.js +33 -6
  144. package/dist/cli/commands/submit-intent.js.map +1 -1
  145. package/dist/cli/commands/ui.js +45 -0
  146. package/dist/cli/commands/ui.js.map +1 -0
  147. package/dist/cli/commands/update.d.ts +5 -0
  148. package/dist/cli/commands/update.js +102 -97
  149. package/dist/cli/commands/update.js.map +1 -1
  150. package/dist/cli/commands/version.js +3 -1
  151. package/dist/cli/commands/version.js.map +1 -1
  152. package/dist/cli/commands/withdraw.d.ts +21 -1
  153. package/dist/cli/commands/withdraw.js +175 -159
  154. package/dist/cli/commands/withdraw.js.map +1 -1
  155. package/dist/cli/execution-context.d.ts +1 -1
  156. package/dist/cli/execution-context.js +2 -1
  157. package/dist/cli/execution-context.js.map +1 -1
  158. package/dist/cli/help.js +7 -0
  159. package/dist/cli/help.js.map +1 -1
  160. package/dist/cli/index.d.ts +7 -0
  161. package/dist/cli/index.js +18 -2
  162. package/dist/cli/index.js.map +1 -1
  163. package/dist/cli/intent-registry-access.d.ts +33 -1
  164. package/dist/cli/intent-registry-access.js +40 -2
  165. package/dist/cli/intent-registry-access.js.map +1 -1
  166. package/dist/cli/open-browser.d.ts +1 -0
  167. package/dist/cli/open-browser.js +18 -0
  168. package/dist/cli/open-browser.js.map +1 -0
  169. package/dist/cli/password.d.ts +3 -3
  170. package/dist/cli/password.js +5 -5
  171. package/dist/cli/password.js.map +1 -1
  172. package/dist/config.d.ts +883 -11
  173. package/dist/config.js +435 -4
  174. package/dist/config.js.map +1 -1
  175. package/dist/conformance/checks/artifacts.d.ts +37 -0
  176. package/dist/conformance/checks/artifacts.js +110 -0
  177. package/dist/conformance/checks/artifacts.js.map +1 -0
  178. package/dist/conformance/checks/envelope-schema.d.ts +17 -0
  179. package/dist/conformance/checks/envelope-schema.js +36 -0
  180. package/dist/conformance/checks/envelope-schema.js.map +1 -0
  181. package/dist/conformance/checks/hash-signature.d.ts +26 -0
  182. package/dist/conformance/checks/hash-signature.js +70 -0
  183. package/dist/conformance/checks/hash-signature.js.map +1 -0
  184. package/dist/conformance/checks/payload.d.ts +19 -0
  185. package/dist/conformance/checks/payload.js +52 -0
  186. package/dist/conformance/checks/payload.js.map +1 -0
  187. package/dist/conformance/checks/secret-scrub.d.ts +33 -0
  188. package/dist/conformance/checks/secret-scrub.js +118 -0
  189. package/dist/conformance/checks/secret-scrub.js.map +1 -0
  190. package/dist/conformance/checks/source-runtime.d.ts +43 -0
  191. package/dist/conformance/checks/source-runtime.js +68 -0
  192. package/dist/conformance/checks/source-runtime.js.map +1 -0
  193. package/dist/conformance/checks/source-static.d.ts +61 -0
  194. package/dist/conformance/checks/source-static.js +311 -0
  195. package/dist/conformance/checks/source-static.js.map +1 -0
  196. package/dist/conformance/checks/trajectory-chain.d.ts +18 -0
  197. package/dist/conformance/checks/trajectory-chain.js +51 -0
  198. package/dist/conformance/checks/trajectory-chain.js.map +1 -0
  199. package/dist/conformance/checks/trajectory-profile.d.ts +17 -0
  200. package/dist/conformance/checks/trajectory-profile.js +51 -0
  201. package/dist/conformance/checks/trajectory-profile.js.map +1 -0
  202. package/dist/conformance/checks/trajectory-schema.d.ts +20 -0
  203. package/dist/conformance/checks/trajectory-schema.js +40 -0
  204. package/dist/conformance/checks/trajectory-schema.js.map +1 -0
  205. package/dist/conformance/checks/verdict.d.ts +44 -0
  206. package/dist/conformance/checks/verdict.js +122 -0
  207. package/dist/conformance/checks/verdict.js.map +1 -0
  208. package/dist/conformance/harness.d.ts +32 -0
  209. package/dist/conformance/harness.js +228 -0
  210. package/dist/conformance/harness.js.map +1 -0
  211. package/dist/conformance/types.d.ts +88 -0
  212. package/dist/conformance/types.js +31 -0
  213. package/dist/conformance/types.js.map +1 -0
  214. package/dist/corpus/acquire.d.ts +37 -0
  215. package/dist/corpus/acquire.js +155 -0
  216. package/dist/corpus/acquire.js.map +1 -0
  217. package/dist/corpus/cache.d.ts +14 -0
  218. package/dist/corpus/cache.js +18 -0
  219. package/dist/corpus/cache.js.map +1 -0
  220. package/dist/corpus/fetch.d.ts +9 -0
  221. package/dist/corpus/fetch.js +24 -0
  222. package/dist/corpus/fetch.js.map +1 -0
  223. package/dist/corpus/index.d.ts +16 -0
  224. package/dist/corpus/index.js +78 -0
  225. package/dist/corpus/index.js.map +1 -0
  226. package/dist/corpus/query.d.ts +17 -0
  227. package/dist/corpus/query.js +108 -0
  228. package/dist/corpus/query.js.map +1 -0
  229. package/dist/corpus/route-resolver.d.ts +16 -0
  230. package/dist/corpus/route-resolver.js +20 -0
  231. package/dist/corpus/route-resolver.js.map +1 -0
  232. package/dist/corpus/types.d.ts +107 -0
  233. package/dist/corpus/types.js +50 -0
  234. package/dist/corpus/types.js.map +1 -0
  235. package/dist/daemon/balance-topup-loop.js +2 -1
  236. package/dist/daemon/balance-topup-loop.js.map +1 -1
  237. package/dist/daemon/creator.d.ts +2 -2
  238. package/dist/daemon/creator.js +2 -2
  239. package/dist/daemon/creator.js.map +1 -1
  240. package/dist/daemon/daemon.d.ts +70 -15
  241. package/dist/daemon/daemon.js +159 -41
  242. package/dist/daemon/daemon.js.map +1 -1
  243. package/dist/daemon/delivery-watcher.js +31 -1
  244. package/dist/daemon/delivery-watcher.js.map +1 -1
  245. package/dist/daemon/jinn-claim-loop-canonical.d.ts +207 -0
  246. package/dist/daemon/jinn-claim-loop-canonical.js +296 -0
  247. package/dist/daemon/jinn-claim-loop-canonical.js.map +1 -0
  248. package/dist/daemon/jinn-claim-loop-mock.d.ts +61 -0
  249. package/dist/daemon/jinn-claim-loop-mock.js +122 -0
  250. package/dist/daemon/jinn-claim-loop-mock.js.map +1 -0
  251. package/dist/daemon/jinn-claim-loop.d.ts +123 -0
  252. package/dist/daemon/jinn-claim-loop.js +256 -0
  253. package/dist/daemon/jinn-claim-loop.js.map +1 -0
  254. package/dist/daemon/reward-claim-loop.d.ts +2 -0
  255. package/dist/daemon/reward-claim-loop.js +32 -27
  256. package/dist/daemon/reward-claim-loop.js.map +1 -1
  257. package/dist/dashboard/assets/index-Bxlk5qpa.js +68 -0
  258. package/dist/dashboard/assets/index-DQ3u_vP5.css +32 -0
  259. package/dist/dashboard/index.html +18 -74
  260. package/dist/earning/agent-wallet-binding.d.ts +133 -0
  261. package/dist/earning/agent-wallet-binding.js +202 -0
  262. package/dist/earning/agent-wallet-binding.js.map +1 -0
  263. package/dist/earning/bootstrap.d.ts +64 -0
  264. package/dist/earning/bootstrap.js +325 -32
  265. package/dist/earning/bootstrap.js.map +1 -1
  266. package/dist/earning/contracts.d.ts +323 -0
  267. package/dist/earning/contracts.js +276 -0
  268. package/dist/earning/contracts.js.map +1 -1
  269. package/dist/earning/funding-plan.d.ts +90 -0
  270. package/dist/earning/funding-plan.js +203 -0
  271. package/dist/earning/funding-plan.js.map +1 -0
  272. package/dist/earning/migrate-agent-id.d.ts +130 -0
  273. package/dist/earning/migrate-agent-id.js +257 -0
  274. package/dist/earning/migrate-agent-id.js.map +1 -0
  275. package/dist/earning/orphan-sweep.d.ts +14 -0
  276. package/dist/earning/orphan-sweep.js +63 -2
  277. package/dist/earning/orphan-sweep.js.map +1 -1
  278. package/dist/earning/reconcile.d.ts +2 -0
  279. package/dist/earning/reconcile.js +30 -0
  280. package/dist/earning/reconcile.js.map +1 -1
  281. package/dist/earning/stolas-claim.d.ts +86 -6
  282. package/dist/earning/stolas-claim.js +123 -9
  283. package/dist/earning/stolas-claim.js.map +1 -1
  284. package/dist/earning/store.d.ts +39 -0
  285. package/dist/earning/store.js +72 -1
  286. package/dist/earning/store.js.map +1 -1
  287. package/dist/earning/testnet-setup-migration.d.ts +32 -0
  288. package/dist/earning/testnet-setup-migration.js +214 -0
  289. package/dist/earning/testnet-setup-migration.js.map +1 -0
  290. package/dist/earning/types.d.ts +53 -9
  291. package/dist/earning/types.js +51 -2
  292. package/dist/earning/types.js.map +1 -1
  293. package/dist/earning/viem-clients.d.ts +20 -0
  294. package/dist/earning/viem-clients.js +32 -1
  295. package/dist/earning/viem-clients.js.map +1 -1
  296. package/dist/erc8004/abis.d.ts +381 -0
  297. package/dist/erc8004/abis.js +238 -0
  298. package/dist/erc8004/abis.js.map +1 -0
  299. package/dist/erc8004/addresses.d.ts +40 -0
  300. package/dist/erc8004/addresses.js +64 -0
  301. package/dist/erc8004/addresses.js.map +1 -0
  302. package/dist/erc8004/identity.d.ts +202 -0
  303. package/dist/erc8004/identity.js +305 -0
  304. package/dist/erc8004/identity.js.map +1 -0
  305. package/dist/erc8004/index.d.ts +13 -0
  306. package/dist/erc8004/index.js +20 -0
  307. package/dist/erc8004/index.js.map +1 -0
  308. package/dist/erc8004/reputation.d.ts +349 -0
  309. package/dist/erc8004/reputation.js +464 -0
  310. package/dist/erc8004/reputation.js.map +1 -0
  311. package/dist/erc8004/subgraph.d.ts +46 -0
  312. package/dist/erc8004/subgraph.js +37 -0
  313. package/dist/erc8004/subgraph.js.map +1 -0
  314. package/dist/erc8004/validation.d.ts +145 -0
  315. package/dist/erc8004/validation.js +219 -0
  316. package/dist/erc8004/validation.js.map +1 -0
  317. package/dist/errors/persisted-bootstrap-error.d.ts +4 -0
  318. package/dist/errors/persisted-bootstrap-error.js +50 -0
  319. package/dist/errors/persisted-bootstrap-error.js.map +1 -0
  320. package/dist/events/emitter.d.ts +12 -0
  321. package/dist/events/emitter.js +23 -0
  322. package/dist/events/emitter.js.map +1 -0
  323. package/dist/events/ring-buffer.d.ts +25 -0
  324. package/dist/events/ring-buffer.js +46 -0
  325. package/dist/events/ring-buffer.js.map +1 -0
  326. package/dist/events/types.d.ts +42 -0
  327. package/dist/events/types.js +28 -0
  328. package/dist/events/types.js.map +1 -0
  329. package/dist/index.d.ts +1 -1
  330. package/dist/intents/kinds/index.d.ts +10 -0
  331. package/dist/intents/kinds/index.js +7 -0
  332. package/dist/intents/kinds/index.js.map +1 -1
  333. package/dist/intents/kinds/learner-loop-test.d.ts +2 -0
  334. package/dist/intents/kinds/learner-loop-test.js +39 -0
  335. package/dist/intents/kinds/learner-loop-test.js.map +1 -0
  336. package/dist/intents/kinds/prediction-apy-v0.js +5 -1
  337. package/dist/intents/kinds/prediction-apy-v0.js.map +1 -1
  338. package/dist/intents/kinds/prediction-v0.js +5 -0
  339. package/dist/intents/kinds/prediction-v0.js.map +1 -1
  340. package/dist/intents/kinds/spec-kind.d.ts +18 -1
  341. package/dist/intents/posting-service.d.ts +3 -5
  342. package/dist/intents/posting-service.js +16 -50
  343. package/dist/intents/posting-service.js.map +1 -1
  344. package/dist/intents/prediction-apy-v0-auto.d.ts +12 -2
  345. package/dist/intents/prediction-apy-v0-auto.js +27 -2
  346. package/dist/intents/prediction-apy-v0-auto.js.map +1 -1
  347. package/dist/intents/prediction-v0-auto.d.ts +14 -4
  348. package/dist/intents/prediction-v0-auto.js +29 -5
  349. package/dist/intents/prediction-v0-auto.js.map +1 -1
  350. package/dist/intents/signing.d.ts +13 -0
  351. package/dist/intents/signing.js +27 -0
  352. package/dist/intents/signing.js.map +1 -0
  353. package/dist/intents/sources.d.ts +12 -5
  354. package/dist/intents/sources.js +11 -11
  355. package/dist/intents/sources.js.map +1 -1
  356. package/dist/main.d.ts +5 -2
  357. package/dist/main.js +792 -66
  358. package/dist/main.js.map +1 -1
  359. package/dist/mcp/acquire-artifact.d.ts +39 -0
  360. package/dist/mcp/acquire-artifact.js +163 -0
  361. package/dist/mcp/acquire-artifact.js.map +1 -0
  362. package/dist/mcp/operator-server.d.ts +20 -3
  363. package/dist/mcp/operator-server.js +500 -25
  364. package/dist/mcp/operator-server.js.map +1 -1
  365. package/dist/mcp/search-artifacts.d.ts +31 -0
  366. package/dist/mcp/search-artifacts.js +40 -0
  367. package/dist/mcp/search-artifacts.js.map +1 -0
  368. package/dist/mcp/server.js +103 -58
  369. package/dist/mcp/server.js.map +1 -1
  370. package/dist/observability/emit-event.d.ts +1 -1
  371. package/dist/observability/emit-event.js.map +1 -1
  372. package/dist/operator-errors.js +4 -5
  373. package/dist/operator-errors.js.map +1 -1
  374. package/dist/preflight/claude-auth.d.ts +11 -11
  375. package/dist/preflight/claude-auth.js +18 -32
  376. package/dist/preflight/claude-auth.js.map +1 -1
  377. package/dist/restorer/capability/index.d.ts +82 -0
  378. package/dist/restorer/capability/index.js +12 -0
  379. package/dist/restorer/capability/index.js.map +1 -0
  380. package/dist/restorer/capability/scoped-rpc.d.ts +12 -0
  381. package/dist/restorer/capability/scoped-rpc.js +34 -0
  382. package/dist/restorer/capability/scoped-rpc.js.map +1 -0
  383. package/dist/restorer/capability/scoped-secrets.d.ts +8 -0
  384. package/dist/restorer/capability/scoped-secrets.js +10 -0
  385. package/dist/restorer/capability/scoped-secrets.js.map +1 -0
  386. package/dist/restorer/capability/scoped-signer.d.ts +46 -0
  387. package/dist/restorer/capability/scoped-signer.js +73 -0
  388. package/dist/restorer/capability/scoped-signer.js.map +1 -0
  389. package/dist/restorer/engine/canonical-json.d.ts +0 -17
  390. package/dist/restorer/engine/canonical-json.js +56 -49
  391. package/dist/restorer/engine/canonical-json.js.map +1 -1
  392. package/dist/restorer/engine/claim.js +8 -1
  393. package/dist/restorer/engine/claim.js.map +1 -1
  394. package/dist/restorer/engine/delivery.d.ts +2 -0
  395. package/dist/restorer/engine/delivery.js +2 -2
  396. package/dist/restorer/engine/delivery.js.map +1 -1
  397. package/dist/restorer/engine/engine.d.ts +143 -26
  398. package/dist/restorer/engine/engine.js +485 -104
  399. package/dist/restorer/engine/engine.js.map +1 -1
  400. package/dist/restorer/engine/envelope-assembly.d.ts +65 -0
  401. package/dist/restorer/engine/envelope-assembly.js +60 -0
  402. package/dist/restorer/engine/envelope-assembly.js.map +1 -0
  403. package/dist/restorer/engine/packaging.d.ts +30 -30
  404. package/dist/restorer/engine/packaging.js +73 -47
  405. package/dist/restorer/engine/packaging.js.map +1 -1
  406. package/dist/restorer/engine/persistence.d.ts +7 -7
  407. package/dist/restorer/engine/persistence.js +4 -4
  408. package/dist/restorer/engine/persistence.js.map +1 -1
  409. package/dist/restorer/engine/registry.d.ts +24 -13
  410. package/dist/restorer/engine/registry.js +16 -13
  411. package/dist/restorer/engine/registry.js.map +1 -1
  412. package/dist/restorer/engine/validate-manifest.d.ts +23 -0
  413. package/dist/restorer/engine/validate-manifest.js +49 -0
  414. package/dist/restorer/engine/validate-manifest.js.map +1 -0
  415. package/dist/restorer/engine/verification-stub.d.ts +18 -0
  416. package/dist/restorer/engine/verification-stub.js +18 -0
  417. package/dist/restorer/engine/verification-stub.js.map +1 -0
  418. package/dist/restorer/external-impls/index.d.ts +3 -0
  419. package/dist/restorer/external-impls/index.js +2 -0
  420. package/dist/restorer/external-impls/index.js.map +1 -0
  421. package/dist/restorer/external-impls/loader.d.ts +49 -0
  422. package/dist/restorer/external-impls/loader.js +138 -0
  423. package/dist/restorer/external-impls/loader.js.map +1 -0
  424. package/dist/restorer/external-impls/package-hash.d.ts +26 -0
  425. package/dist/restorer/external-impls/package-hash.js +102 -0
  426. package/dist/restorer/external-impls/package-hash.js.map +1 -0
  427. package/dist/restorer/external-impls/types.d.ts +42 -0
  428. package/dist/restorer/external-impls/types.js +10 -0
  429. package/dist/restorer/external-impls/types.js.map +1 -0
  430. package/dist/restorer/impls/claude-code-learner/adapters/claude-code.d.ts +38 -0
  431. package/dist/restorer/impls/claude-code-learner/adapters/claude-code.js +200 -0
  432. package/dist/restorer/impls/claude-code-learner/adapters/claude-code.js.map +1 -0
  433. package/dist/restorer/impls/claude-code-learner/harvest.d.ts +19 -0
  434. package/dist/restorer/impls/claude-code-learner/harvest.js +146 -0
  435. package/dist/restorer/impls/claude-code-learner/harvest.js.map +1 -0
  436. package/dist/restorer/impls/claude-code-learner/index.d.ts +15 -0
  437. package/dist/restorer/impls/claude-code-learner/index.js +14 -0
  438. package/dist/restorer/impls/claude-code-learner/index.js.map +1 -0
  439. package/dist/restorer/impls/claude-code-learner/mcp-config.d.ts +48 -0
  440. package/dist/restorer/impls/claude-code-learner/mcp-config.js +52 -0
  441. package/dist/restorer/impls/claude-code-learner/mcp-config.js.map +1 -0
  442. package/dist/restorer/impls/claude-code-learner/plugin-path.d.ts +14 -0
  443. package/dist/restorer/impls/claude-code-learner/plugin-path.js +30 -0
  444. package/dist/restorer/impls/claude-code-learner/plugin-path.js.map +1 -0
  445. package/dist/restorer/impls/claude-code-learner/restorer.d.ts +38 -0
  446. package/dist/restorer/impls/claude-code-learner/restorer.js +73 -0
  447. package/dist/restorer/impls/claude-code-learner/restorer.js.map +1 -0
  448. package/dist/restorer/impls/claude-code-learner/test-utils/fake-plugin-outputs.d.ts +19 -0
  449. package/dist/restorer/impls/claude-code-learner/test-utils/fake-plugin-outputs.js +111 -0
  450. package/dist/restorer/impls/claude-code-learner/test-utils/fake-plugin-outputs.js.map +1 -0
  451. package/dist/restorer/impls/claude-code-learner/test-utils/noop-adapter.d.ts +22 -0
  452. package/dist/restorer/impls/claude-code-learner/test-utils/noop-adapter.js +35 -0
  453. package/dist/restorer/impls/claude-code-learner/test-utils/noop-adapter.js.map +1 -0
  454. package/dist/restorer/impls/claude-code-learner/test-utils/synthetic-session.d.ts +20 -0
  455. package/dist/restorer/impls/claude-code-learner/test-utils/synthetic-session.js +34 -0
  456. package/dist/restorer/impls/claude-code-learner/test-utils/synthetic-session.js.map +1 -0
  457. package/dist/restorer/impls/claude-code-learner/types.d.ts +99 -0
  458. package/dist/restorer/impls/claude-code-learner/types.js +2 -0
  459. package/dist/restorer/impls/claude-code-learner/types.js.map +1 -0
  460. package/dist/restorer/impls/claude-code-learner/wrapper.d.ts +49 -0
  461. package/dist/restorer/impls/claude-code-learner/wrapper.js +144 -0
  462. package/dist/restorer/impls/claude-code-learner/wrapper.js.map +1 -0
  463. package/dist/restorer/impls/claude-mcp-hyperliquid/index.d.ts +2 -2
  464. package/dist/restorer/impls/claude-mcp-hyperliquid/index.js +2 -2
  465. package/dist/restorer/impls/claude-mcp-hyperliquid/index.js.map +1 -1
  466. package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.d.ts +7 -0
  467. package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.js +38 -0
  468. package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.js.map +1 -1
  469. package/dist/restorer/impls/claude-mcp-prediction/index.d.ts +2 -2
  470. package/dist/restorer/impls/claude-mcp-prediction/index.js +12 -2
  471. package/dist/restorer/impls/claude-mcp-prediction/index.js.map +1 -1
  472. package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.d.ts +9 -2
  473. package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.js +9 -125
  474. package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.js.map +1 -1
  475. package/dist/restorer/impls/claude-mcp-prediction-apy/index.d.ts +2 -2
  476. package/dist/restorer/impls/claude-mcp-prediction-apy/index.js +9 -2
  477. package/dist/restorer/impls/claude-mcp-prediction-apy/index.js.map +1 -1
  478. package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.d.ts +10 -0
  479. package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.js +10 -119
  480. package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.js.map +1 -1
  481. package/dist/restorer/impls/claude-mcp-shared/single-session-orchestrator.d.ts +84 -0
  482. package/dist/restorer/impls/claude-mcp-shared/single-session-orchestrator.js +206 -0
  483. package/dist/restorer/impls/claude-mcp-shared/single-session-orchestrator.js.map +1 -0
  484. package/dist/restorer/impls/evaluation-context.d.ts +11 -4
  485. package/dist/restorer/impls/evaluation-context.js +9 -2
  486. package/dist/restorer/impls/evaluation-context.js.map +1 -1
  487. package/dist/restorer/impls/index.d.ts +46 -1
  488. package/dist/restorer/impls/index.js +38 -0
  489. package/dist/restorer/impls/index.js.map +1 -1
  490. package/dist/restorer/impls/legacy-claude/index.d.ts +13 -1
  491. package/dist/restorer/impls/legacy-claude/index.js +2 -0
  492. package/dist/restorer/impls/legacy-claude/index.js.map +1 -1
  493. package/dist/restorer/impls/portfolio-v0-evaluator/index.d.ts +4 -4
  494. package/dist/restorer/impls/portfolio-v0-evaluator/index.js +184 -55
  495. package/dist/restorer/impls/portfolio-v0-evaluator/index.js.map +1 -1
  496. package/dist/restorer/impls/prediction-apy-v0-baseline/index.d.ts +1 -1
  497. package/dist/restorer/impls/prediction-apy-v0-baseline/index.js +8 -1
  498. package/dist/restorer/impls/prediction-apy-v0-baseline/index.js.map +1 -1
  499. package/dist/restorer/impls/prediction-apy-v0-evaluator/index.d.ts +3 -3
  500. package/dist/restorer/impls/prediction-apy-v0-evaluator/index.js +153 -15
  501. package/dist/restorer/impls/prediction-apy-v0-evaluator/index.js.map +1 -1
  502. package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.d.ts +14 -5
  503. package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.js +16 -23
  504. package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.js.map +1 -1
  505. package/dist/restorer/impls/prediction-v0-baseline/index.d.ts +1 -1
  506. package/dist/restorer/impls/prediction-v0-baseline/index.js +16 -7
  507. package/dist/restorer/impls/prediction-v0-baseline/index.js.map +1 -1
  508. package/dist/restorer/impls/prediction-v0-evaluator/checks/integrity.d.ts +5 -3
  509. package/dist/restorer/impls/prediction-v0-evaluator/checks/integrity.js.map +1 -1
  510. package/dist/restorer/impls/prediction-v0-evaluator/index.d.ts +2 -2
  511. package/dist/restorer/impls/prediction-v0-evaluator/index.js +175 -67
  512. package/dist/restorer/impls/prediction-v0-evaluator/index.js.map +1 -1
  513. package/dist/restorer/manifest/index.d.ts +3 -0
  514. package/dist/restorer/manifest/index.js +3 -0
  515. package/dist/restorer/manifest/index.js.map +1 -0
  516. package/dist/restorer/manifest/load.d.ts +7 -0
  517. package/dist/restorer/manifest/load.js +49 -0
  518. package/dist/restorer/manifest/load.js.map +1 -0
  519. package/dist/restorer/manifest/types.d.ts +75 -0
  520. package/dist/restorer/manifest/types.js +8 -0
  521. package/dist/restorer/manifest/types.js.map +1 -0
  522. package/dist/restorer/manifest/verify.d.ts +15 -0
  523. package/dist/restorer/manifest/verify.js +53 -0
  524. package/dist/restorer/manifest/verify.js.map +1 -0
  525. package/dist/restorer/plug-ins/index.d.ts +14 -0
  526. package/dist/restorer/plug-ins/index.js +11 -0
  527. package/dist/restorer/plug-ins/index.js.map +1 -0
  528. package/dist/restorer/plug-ins/loader.d.ts +27 -0
  529. package/dist/restorer/plug-ins/loader.js +101 -0
  530. package/dist/restorer/plug-ins/loader.js.map +1 -0
  531. package/dist/restorer/plug-ins/manifest.d.ts +7 -0
  532. package/dist/restorer/plug-ins/manifest.js +97 -0
  533. package/dist/restorer/plug-ins/manifest.js.map +1 -0
  534. package/dist/restorer/plug-ins/registry.d.ts +24 -0
  535. package/dist/restorer/plug-ins/registry.js +17 -0
  536. package/dist/restorer/plug-ins/registry.js.map +1 -0
  537. package/dist/restorer/plug-ins/serialise.d.ts +29 -0
  538. package/dist/restorer/plug-ins/serialise.js +29 -0
  539. package/dist/restorer/plug-ins/serialise.js.map +1 -0
  540. package/dist/restorer/plug-ins/types.d.ts +77 -0
  541. package/dist/restorer/plug-ins/types.js +10 -0
  542. package/dist/restorer/plug-ins/types.js.map +1 -0
  543. package/dist/restorer/types.d.ts +66 -11
  544. package/dist/restorer/types.js.map +1 -1
  545. package/dist/runner/claude.d.ts +3 -3
  546. package/dist/runner/claude.js +57 -21
  547. package/dist/runner/claude.js.map +1 -1
  548. package/dist/runner/runner.d.ts +29 -2
  549. package/dist/runner/simple.d.ts +2 -2
  550. package/dist/runner/simple.js +2 -2
  551. package/dist/runner/simple.js.map +1 -1
  552. package/dist/scripts/fix-node-pty.mjs +62 -0
  553. package/dist/setup-mode.d.ts +34 -0
  554. package/dist/setup-mode.js +49 -0
  555. package/dist/setup-mode.js.map +1 -0
  556. package/dist/store/store.d.ts +79 -3
  557. package/dist/store/store.js +189 -6
  558. package/dist/store/store.js.map +1 -1
  559. package/dist/templates/plug-in/hook/README.md.tmpl +24 -0
  560. package/dist/templates/plug-in/hook/gitignore.tmpl +3 -0
  561. package/dist/templates/plug-in/hook/hooks/event.sh.tmpl +15 -0
  562. package/dist/templates/plug-in/hook/jinn-plugin.json.tmpl +16 -0
  563. package/dist/templates/plug-in/hook/package.json.tmpl +14 -0
  564. package/dist/templates/plug-in/hook/test/manifest.test.ts.tmpl +21 -0
  565. package/dist/templates/plug-in/mcp-tool/README.md.tmpl +26 -0
  566. package/dist/templates/plug-in/mcp-tool/gitignore.tmpl +4 -0
  567. package/dist/templates/plug-in/mcp-tool/jinn-plugin.json.tmpl +16 -0
  568. package/dist/templates/plug-in/mcp-tool/package.json.tmpl +19 -0
  569. package/dist/templates/plug-in/mcp-tool/src/server.ts.tmpl +17 -0
  570. package/dist/templates/plug-in/mcp-tool/test/server.test.ts.tmpl +18 -0
  571. package/dist/templates/plug-in/memory-backend/README.md.tmpl +33 -0
  572. package/dist/templates/plug-in/memory-backend/gitignore.tmpl +4 -0
  573. package/dist/templates/plug-in/memory-backend/jinn-plugin.json.tmpl +16 -0
  574. package/dist/templates/plug-in/memory-backend/package.json.tmpl +19 -0
  575. package/dist/templates/plug-in/memory-backend/src/server.ts.tmpl +23 -0
  576. package/dist/templates/plug-in/memory-backend/test/server.test.ts.tmpl +17 -0
  577. package/dist/templates/plug-in/phase-agent-override/README.md.tmpl +30 -0
  578. package/dist/templates/plug-in/phase-agent-override/agents/agent.md.tmpl +26 -0
  579. package/dist/templates/plug-in/phase-agent-override/gitignore.tmpl +3 -0
  580. package/dist/templates/plug-in/phase-agent-override/jinn-plugin.json.tmpl +17 -0
  581. package/dist/templates/plug-in/phase-agent-override/package.json.tmpl +14 -0
  582. package/dist/templates/plug-in/phase-agent-override/test/manifest.test.ts.tmpl +24 -0
  583. package/dist/templates/plug-in/skill-bundle/.claude-plugin/plugin.json.tmpl +5 -0
  584. package/dist/templates/plug-in/skill-bundle/README.md.tmpl +28 -0
  585. package/dist/templates/plug-in/skill-bundle/gitignore.tmpl +3 -0
  586. package/dist/templates/plug-in/skill-bundle/jinn-plugin.json.tmpl +15 -0
  587. package/dist/templates/plug-in/skill-bundle/package.json.tmpl +14 -0
  588. package/dist/templates/plug-in/skill-bundle/skills/example/SKILL.md.tmpl +14 -0
  589. package/dist/templates/plug-in/skill-bundle/test/manifest.test.ts.tmpl +21 -0
  590. package/dist/templates/plug-in/topic-explorer/README.md.tmpl +24 -0
  591. package/dist/templates/plug-in/topic-explorer/agents/explorer.md.tmpl +26 -0
  592. package/dist/templates/plug-in/topic-explorer/gitignore.tmpl +3 -0
  593. package/dist/templates/plug-in/topic-explorer/jinn-plugin.json.tmpl +17 -0
  594. package/dist/templates/plug-in/topic-explorer/package.json.tmpl +14 -0
  595. package/dist/templates/plug-in/topic-explorer/test/manifest.test.ts.tmpl +22 -0
  596. package/dist/templates/restorer/alternative-harness/README.md.tmpl +44 -0
  597. package/dist/templates/restorer/alternative-harness/gitignore.tmpl +3 -0
  598. package/dist/templates/restorer/alternative-harness/jinn.manifest.json.tmpl +22 -0
  599. package/dist/templates/restorer/alternative-harness/package.json.tmpl +26 -0
  600. package/dist/templates/restorer/alternative-harness/src/coordinator.ts.tmpl +50 -0
  601. package/dist/templates/restorer/alternative-harness/src/harness.ts.tmpl +31 -0
  602. package/dist/templates/restorer/alternative-harness/src/index.ts.tmpl +44 -0
  603. package/dist/templates/restorer/alternative-harness/src/mock-harness.ts.tmpl +41 -0
  604. package/dist/templates/restorer/alternative-harness/src/phases/debrief.ts.tmpl +28 -0
  605. package/dist/templates/restorer/alternative-harness/src/phases/execute.ts.tmpl +33 -0
  606. package/dist/templates/restorer/alternative-harness/src/phases/improve.ts.tmpl +31 -0
  607. package/dist/templates/restorer/alternative-harness/src/phases/memory.ts.tmpl +31 -0
  608. package/dist/templates/restorer/alternative-harness/src/phases/orient.ts.tmpl +21 -0
  609. package/dist/templates/restorer/alternative-harness/src/phases/plan.ts.tmpl +25 -0
  610. package/dist/templates/restorer/alternative-harness/src/phases/strategize.ts.tmpl +29 -0
  611. package/dist/templates/restorer/alternative-harness/test/coordinator.test.ts.tmpl +52 -0
  612. package/dist/templates/restorer/alternative-harness/test/unit.test.ts.tmpl +54 -0
  613. package/dist/templates/restorer/alternative-harness/tsconfig.json.tmpl +16 -0
  614. package/dist/templates/restorer/evaluator/README.md.tmpl +36 -0
  615. package/dist/templates/restorer/evaluator/gitignore.tmpl +3 -0
  616. package/dist/templates/restorer/evaluator/jinn.manifest.json.tmpl +22 -0
  617. package/dist/templates/restorer/evaluator/package.json.tmpl +26 -0
  618. package/dist/templates/restorer/evaluator/src/index.ts.tmpl +35 -0
  619. package/dist/templates/restorer/evaluator/test/unit.test.ts.tmpl +48 -0
  620. package/dist/templates/restorer/evaluator/tsconfig.json.tmpl +16 -0
  621. package/dist/templates/restorer/forecaster/README.md.tmpl +25 -0
  622. package/dist/templates/restorer/forecaster/gitignore.tmpl +5 -0
  623. package/dist/templates/restorer/forecaster/jinn.manifest.json.tmpl +22 -0
  624. package/dist/templates/restorer/forecaster/package.json.tmpl +26 -0
  625. package/dist/templates/restorer/forecaster/src/index.ts.tmpl +33 -0
  626. package/dist/templates/restorer/forecaster/test/unit.test.ts.tmpl +41 -0
  627. package/dist/templates/restorer/forecaster/tsconfig.json.tmpl +16 -0
  628. package/dist/trajectory/collector.d.ts +49 -0
  629. package/dist/trajectory/collector.js +86 -0
  630. package/dist/trajectory/collector.js.map +1 -0
  631. package/dist/trajectory/emit.d.ts +27 -0
  632. package/dist/trajectory/emit.js +40 -0
  633. package/dist/trajectory/emit.js.map +1 -0
  634. package/dist/trajectory/hash-chain.d.ts +18 -0
  635. package/dist/trajectory/hash-chain.js +23 -0
  636. package/dist/trajectory/hash-chain.js.map +1 -0
  637. package/dist/trajectory/index.d.ts +22 -0
  638. package/dist/trajectory/index.js +23 -0
  639. package/dist/trajectory/index.js.map +1 -0
  640. package/dist/trajectory/schema.d.ts +14 -14
  641. package/dist/trajectory/secret-scrub.d.ts +32 -0
  642. package/dist/trajectory/secret-scrub.js +51 -0
  643. package/dist/trajectory/secret-scrub.js.map +1 -0
  644. package/dist/trajectory/span-profile.d.ts +27 -0
  645. package/dist/trajectory/span-profile.js +51 -0
  646. package/dist/trajectory/span-profile.js.map +1 -0
  647. package/dist/trajectory/wrappers/http.d.ts +37 -0
  648. package/dist/trajectory/wrappers/http.js +85 -0
  649. package/dist/trajectory/wrappers/http.js.map +1 -0
  650. package/dist/trajectory/wrappers/mcp.d.ts +17 -0
  651. package/dist/trajectory/wrappers/mcp.js +58 -0
  652. package/dist/trajectory/wrappers/mcp.js.map +1 -0
  653. package/dist/trajectory/wrappers/subprocess.d.ts +32 -0
  654. package/dist/trajectory/wrappers/subprocess.js +70 -0
  655. package/dist/trajectory/wrappers/subprocess.js.map +1 -0
  656. package/dist/tx-retry.js +23 -9
  657. package/dist/tx-retry.js.map +1 -1
  658. package/dist/types/desired-state.d.ts +211 -21
  659. package/dist/types/desired-state.js +26 -15
  660. package/dist/types/desired-state.js.map +1 -1
  661. package/dist/types/envelope.d.ts +1473 -0
  662. package/dist/types/envelope.js +114 -0
  663. package/dist/types/envelope.js.map +1 -0
  664. package/dist/types/index.d.ts +4 -4
  665. package/dist/types/index.js +4 -4
  666. package/dist/types/index.js.map +1 -1
  667. package/dist/types/intent.d.ts +276 -0
  668. package/dist/types/intent.js +74 -0
  669. package/dist/types/intent.js.map +1 -0
  670. package/dist/types/payloads/index.d.ts +11 -0
  671. package/dist/types/payloads/index.js +46 -0
  672. package/dist/types/payloads/index.js.map +1 -0
  673. package/dist/types/payloads/portfolio-v0.d.ts +481 -0
  674. package/dist/types/payloads/portfolio-v0.js +94 -0
  675. package/dist/types/payloads/portfolio-v0.js.map +1 -0
  676. package/dist/types/payloads/prediction-apy-v0.d.ts +231 -0
  677. package/dist/types/payloads/prediction-apy-v0.js +63 -0
  678. package/dist/types/payloads/prediction-apy-v0.js.map +1 -0
  679. package/dist/types/payloads/prediction-v0.d.ts +262 -0
  680. package/dist/types/payloads/prediction-v0.js +73 -0
  681. package/dist/types/payloads/prediction-v0.js.map +1 -0
  682. package/dist/types/portfolio.d.ts +23 -685
  683. package/dist/types/portfolio.js +16 -106
  684. package/dist/types/portfolio.js.map +1 -1
  685. package/dist/types/prediction-apy.d.ts +9 -344
  686. package/dist/types/prediction-apy.js +9 -65
  687. package/dist/types/prediction-apy.js.map +1 -1
  688. package/dist/types/prediction.d.ts +25 -396
  689. package/dist/types/prediction.js +5 -79
  690. package/dist/types/prediction.js.map +1 -1
  691. package/dist/types/window.d.ts +12 -0
  692. package/dist/types/window.js +6 -0
  693. package/dist/types/window.js.map +1 -0
  694. package/dist/util/path-safety.d.ts +22 -0
  695. package/dist/util/path-safety.js +29 -0
  696. package/dist/util/path-safety.js.map +1 -0
  697. package/dist/util/redact-rpc-urls.d.ts +5 -0
  698. package/dist/util/redact-rpc-urls.js +9 -0
  699. package/dist/util/redact-rpc-urls.js.map +1 -0
  700. package/dist/x402/acquire.d.ts +14 -3
  701. package/dist/x402/acquire.js +28 -11
  702. package/dist/x402/acquire.js.map +1 -1
  703. package/dist/x402/handler.d.ts +15 -3
  704. package/dist/x402/handler.js +67 -24
  705. package/dist/x402/handler.js.map +1 -1
  706. package/package.json +36 -11
  707. package/plugins/claude-code-learner/.claude-plugin/plugin.json +9 -0
  708. package/plugins/claude-code-learner/AGENTS.md +30 -0
  709. package/plugins/claude-code-learner/CLAUDE.md +31 -0
  710. package/plugins/claude-code-learner/README.md +58 -0
  711. package/plugins/claude-code-learner/agents/analyst.md +69 -0
  712. package/plugins/claude-code-learner/agents/consolidator.md +95 -0
  713. package/plugins/claude-code-learner/agents/explorer.md +54 -0
  714. package/plugins/claude-code-learner/agents/planner.md +88 -0
  715. package/plugins/claude-code-learner/agents/promoter.md +114 -0
  716. package/plugins/claude-code-learner/agents/step-worker.md +48 -0
  717. package/plugins/claude-code-learner/agents/strategist.md +86 -0
  718. package/plugins/claude-code-learner/hooks/hooks.json +16 -0
  719. package/plugins/claude-code-learner/hooks/session-start +49 -0
  720. package/plugins/claude-code-learner/skills/coordinator/SKILL.md +131 -0
  721. package/plugins/claude-code-learner/skills/debrief/SKILL.md +71 -0
  722. package/plugins/claude-code-learner/skills/execute/SKILL.md +91 -0
  723. package/plugins/claude-code-learner/skills/improve/SKILL.md +57 -0
  724. package/plugins/claude-code-learner/skills/memory-consolidation/SKILL.md +57 -0
  725. package/plugins/claude-code-learner/skills/orient/SKILL.md +82 -0
  726. package/plugins/claude-code-learner/skills/plan/SKILL.md +54 -0
  727. package/plugins/claude-code-learner/skills/strategize/SKILL.md +63 -0
  728. package/skills/jinn-operator/SKILL.md +84 -35
  729. package/templates/plug-in/hook/README.md.tmpl +24 -0
  730. package/templates/plug-in/hook/gitignore.tmpl +3 -0
  731. package/templates/plug-in/hook/hooks/event.sh.tmpl +15 -0
  732. package/templates/plug-in/hook/jinn-plugin.json.tmpl +16 -0
  733. package/templates/plug-in/hook/package.json.tmpl +14 -0
  734. package/templates/plug-in/hook/test/manifest.test.ts.tmpl +21 -0
  735. package/templates/plug-in/mcp-tool/README.md.tmpl +26 -0
  736. package/templates/plug-in/mcp-tool/gitignore.tmpl +4 -0
  737. package/templates/plug-in/mcp-tool/jinn-plugin.json.tmpl +16 -0
  738. package/templates/plug-in/mcp-tool/package.json.tmpl +19 -0
  739. package/templates/plug-in/mcp-tool/src/server.ts.tmpl +17 -0
  740. package/templates/plug-in/mcp-tool/test/server.test.ts.tmpl +18 -0
  741. package/templates/plug-in/memory-backend/README.md.tmpl +33 -0
  742. package/templates/plug-in/memory-backend/gitignore.tmpl +4 -0
  743. package/templates/plug-in/memory-backend/jinn-plugin.json.tmpl +16 -0
  744. package/templates/plug-in/memory-backend/package.json.tmpl +19 -0
  745. package/templates/plug-in/memory-backend/src/server.ts.tmpl +23 -0
  746. package/templates/plug-in/memory-backend/test/server.test.ts.tmpl +17 -0
  747. package/templates/plug-in/phase-agent-override/README.md.tmpl +30 -0
  748. package/templates/plug-in/phase-agent-override/agents/agent.md.tmpl +26 -0
  749. package/templates/plug-in/phase-agent-override/gitignore.tmpl +3 -0
  750. package/templates/plug-in/phase-agent-override/jinn-plugin.json.tmpl +17 -0
  751. package/templates/plug-in/phase-agent-override/package.json.tmpl +14 -0
  752. package/templates/plug-in/phase-agent-override/test/manifest.test.ts.tmpl +24 -0
  753. package/templates/plug-in/skill-bundle/.claude-plugin/plugin.json.tmpl +5 -0
  754. package/templates/plug-in/skill-bundle/README.md.tmpl +28 -0
  755. package/templates/plug-in/skill-bundle/gitignore.tmpl +3 -0
  756. package/templates/plug-in/skill-bundle/jinn-plugin.json.tmpl +15 -0
  757. package/templates/plug-in/skill-bundle/package.json.tmpl +14 -0
  758. package/templates/plug-in/skill-bundle/skills/example/SKILL.md.tmpl +14 -0
  759. package/templates/plug-in/skill-bundle/test/manifest.test.ts.tmpl +21 -0
  760. package/templates/plug-in/topic-explorer/README.md.tmpl +24 -0
  761. package/templates/plug-in/topic-explorer/agents/explorer.md.tmpl +26 -0
  762. package/templates/plug-in/topic-explorer/gitignore.tmpl +3 -0
  763. package/templates/plug-in/topic-explorer/jinn-plugin.json.tmpl +17 -0
  764. package/templates/plug-in/topic-explorer/package.json.tmpl +14 -0
  765. package/templates/plug-in/topic-explorer/test/manifest.test.ts.tmpl +22 -0
  766. package/templates/restorer/alternative-harness/README.md.tmpl +44 -0
  767. package/templates/restorer/alternative-harness/gitignore.tmpl +3 -0
  768. package/templates/restorer/alternative-harness/jinn.manifest.json.tmpl +22 -0
  769. package/templates/restorer/alternative-harness/package.json.tmpl +26 -0
  770. package/templates/restorer/alternative-harness/src/coordinator.ts.tmpl +50 -0
  771. package/templates/restorer/alternative-harness/src/harness.ts.tmpl +31 -0
  772. package/templates/restorer/alternative-harness/src/index.ts.tmpl +44 -0
  773. package/templates/restorer/alternative-harness/src/mock-harness.ts.tmpl +41 -0
  774. package/templates/restorer/alternative-harness/src/phases/debrief.ts.tmpl +28 -0
  775. package/templates/restorer/alternative-harness/src/phases/execute.ts.tmpl +33 -0
  776. package/templates/restorer/alternative-harness/src/phases/improve.ts.tmpl +31 -0
  777. package/templates/restorer/alternative-harness/src/phases/memory.ts.tmpl +31 -0
  778. package/templates/restorer/alternative-harness/src/phases/orient.ts.tmpl +21 -0
  779. package/templates/restorer/alternative-harness/src/phases/plan.ts.tmpl +25 -0
  780. package/templates/restorer/alternative-harness/src/phases/strategize.ts.tmpl +29 -0
  781. package/templates/restorer/alternative-harness/test/coordinator.test.ts.tmpl +52 -0
  782. package/templates/restorer/alternative-harness/test/unit.test.ts.tmpl +54 -0
  783. package/templates/restorer/alternative-harness/tsconfig.json.tmpl +16 -0
  784. package/templates/restorer/evaluator/README.md.tmpl +36 -0
  785. package/templates/restorer/evaluator/gitignore.tmpl +3 -0
  786. package/templates/restorer/evaluator/jinn.manifest.json.tmpl +22 -0
  787. package/templates/restorer/evaluator/package.json.tmpl +26 -0
  788. package/templates/restorer/evaluator/src/index.ts.tmpl +35 -0
  789. package/templates/restorer/evaluator/test/unit.test.ts.tmpl +48 -0
  790. package/templates/restorer/evaluator/tsconfig.json.tmpl +16 -0
  791. package/templates/restorer/forecaster/README.md.tmpl +25 -0
  792. package/templates/restorer/forecaster/gitignore.tmpl +5 -0
  793. package/templates/restorer/forecaster/jinn.manifest.json.tmpl +22 -0
  794. package/templates/restorer/forecaster/package.json.tmpl +26 -0
  795. package/templates/restorer/forecaster/src/index.ts.tmpl +33 -0
  796. package/templates/restorer/forecaster/test/unit.test.ts.tmpl +41 -0
  797. package/templates/restorer/forecaster/tsconfig.json.tmpl +16 -0
  798. package/dist/bin/jinn-mcp.d.ts +0 -2
  799. package/dist/bin/jinn-mcp.js +0 -10
  800. package/dist/bin/jinn-mcp.js.map +0 -1
  801. package/dist/cli/commands/quickstart.js +0 -330
  802. package/dist/cli/commands/quickstart.js.map +0 -1
  803. package/dist/discovery/registry.d.ts +0 -97
  804. package/dist/discovery/registry.js +0 -177
  805. package/dist/discovery/registry.js.map +0 -1
  806. package/dist/discovery/subgraph.d.ts +0 -37
  807. package/dist/discovery/subgraph.js +0 -87
  808. package/dist/discovery/subgraph.js.map +0 -1
  809. package/dist/restorer/engine/manifest-assembly.d.ts +0 -67
  810. package/dist/restorer/engine/manifest-assembly.js +0 -79
  811. package/dist/restorer/engine/manifest-assembly.js.map +0 -1
  812. /package/dist/cli/commands/{quickstart.d.ts → ui.d.ts} +0 -0
@@ -3,183 +3,262 @@ import { COMMON_FLAGS } from '../command.js';
3
3
  import { emitResult } from '../output.js';
4
4
  import { emitEnvelope } from '../../errors/envelope.js';
5
5
  import { ensureConfirmed, emitDryRun } from '../action.js';
6
- import { gatherIntrospectionRaw } from '../introspection-context.js';
7
- import { resolveCliPassword } from '../password.js';
8
- import { createCliSignerContext } from '../execution-context.js';
6
+ import { gatherIntrospectionRaw as defaultGatherIntrospectionRaw } from '../introspection-context.js';
7
+ import { resolveCliPassword as defaultResolveCliPassword } from '../password.js';
8
+ import { createCliSignerContext as defaultCreateCliSignerContext, } from '../execution-context.js';
9
9
  import { FleetBootstrapper } from '../../earning/bootstrap.js';
10
- import { retireFleetServiceOnChain } from '../../earning/fleet-retire.js';
11
- import { findServiceByDisplayIndex } from '../../earning/fleet-display-index.js';
12
- import { isRecoverableTransactionError } from '../../tx-retry.js';
13
- async function runScale(ctx, rest) {
14
- let parsed;
15
- try {
16
- parsed = parseArgs({
17
- args: rest,
18
- options: {
19
- ...COMMON_FLAGS,
20
- to: { type: 'string' },
21
- 'dry-run': { type: 'boolean', default: false },
22
- yes: { type: 'boolean', default: false },
23
- },
24
- allowPositionals: false,
25
- });
26
- }
27
- catch (err) {
28
- emitEnvelope({
29
- code: 'invalid_invocation',
30
- message: err instanceof Error ? err.message : String(err),
31
- exampleCli: 'jinn fleet scale --to 3 --dry-run',
32
- details: { field: 'flags' },
33
- }, { writer: ctx.writer, exit: ctx.exit });
34
- return;
35
- }
36
- const to = parseInt(parsed.values.to, 10);
37
- if (!Number.isFinite(to) || to < 0) {
38
- emitEnvelope({
39
- code: 'invalid_invocation',
40
- message: '--to must be a non-negative integer',
41
- exampleCli: 'jinn fleet scale --to 3 --dry-run',
42
- details: { field: '--to', expected: 'non-negative integer' },
43
- }, { writer: ctx.writer, exit: ctx.exit });
44
- return;
45
- }
46
- const raw = await gatherIntrospectionRaw({ argv: ctx.argv });
47
- const sorted = [...(raw.fleet?.services ?? [])].sort((a, b) => a.index - b.index);
48
- const current = sorted.length;
49
- const dryRun = parsed.values['dry-run'];
50
- const yes = parsed.values.yes;
51
- let plan = [];
52
- let description;
53
- if (to === current) {
54
- plan = [];
55
- description = `Fleet is already at size ${current}. No action.`;
56
- }
57
- else if (to > current) {
58
- plan = [{ action: 'grow', from: current, to }];
59
- description = `Would grow fleet from ${current} to ${to} via bootstrap with targetServices=${to}.`;
60
- }
61
- else {
62
- const indices = sorted.slice(to).map(s => s.index);
63
- plan = [{ action: 'retire', from: current, to, indices }];
64
- description = `Would retire services with HD service.index ${indices.join(', ')} (on-chain slot; shrink path) to shrink fleet from ${current} to ${to}.`;
65
- }
66
- if (dryRun) {
67
- emitDryRun(ctx, { verb: 'fleet scale', description, plan });
68
- return;
69
- }
70
- if (!ensureConfirmed(ctx, { yes, dryRun: false }))
71
- return;
72
- if (to === current) {
73
- emitResult({
74
- schemaVersion: 1,
75
- generatedAt: new Date().toISOString(),
76
- verb: 'fleet scale',
77
- from: current,
78
- to,
79
- action: 'none',
80
- }, (v) => {
81
- const value = v;
82
- return `Fleet already at target size ${value.to}.`;
83
- }, {
84
- json: Boolean(parsed.values.json),
85
- human: Boolean(parsed.values.human),
86
- writer: ctx.writer,
87
- stdoutIsTty: ctx.stdoutIsTty,
88
- noColor: Boolean(ctx.env['NO_COLOR']),
89
- });
90
- return;
91
- }
92
- const pw = resolveCliPassword(ctx.argv, ctx.env);
93
- if (!pw.ok) {
94
- emitEnvelope({
95
- code: 'invalid_invocation',
96
- message: pw.message,
97
- exampleCli: 'jinn fleet scale --to 3 --yes',
98
- details: { field: 'keystore password' },
99
- }, { writer: ctx.writer, exit: ctx.exit });
100
- return;
101
- }
102
- const built = await createCliSignerContext({ argv: ctx.argv, env: ctx.env });
103
- if (!built.ok) {
104
- emitEnvelope(built.envelope, { writer: ctx.writer, exit: ctx.exit });
105
- return;
106
- }
107
- const { config, networkChain, chainConfig, fleetStore, masterWallet, publicClient } = built.ctx;
108
- if (to > current) {
109
- const bootstrapper = new FleetBootstrapper({
110
- earningDir: config.earningDir,
111
- chain: networkChain,
112
- rpcUrl: config.rpcUrl,
113
- stakingMode: config.stakingMode,
114
- targetServices: to,
115
- testnetL2DeploymentPath: config.testnetL2DeploymentPath,
116
- testnetL2TokenDeploymentPath: config.testnetL2TokenDeploymentPath,
117
- testnetMechDeploymentPath: config.testnetMechDeploymentPath,
118
- testnetStolasDeploymentPath: config.testnetStolasDeploymentPath,
119
- testnetClaimRegistryDeploymentPath: config.testnetClaimRegistryDeploymentPath,
120
- debug: config.debug,
121
- masterEthDailyEstimateWei: config.masterEthDailyEstimateWei,
122
- pollIntervalMs: config.pollIntervalMs,
123
- });
124
- let result;
10
+ import { retireFleetServiceOnChain as defaultRetireFleetServiceOnChain } from '../../earning/fleet-retire.js';
11
+ import { findServiceByDisplayIndex as defaultFindServiceByDisplayIndex } from '../../earning/fleet-display-index.js';
12
+ import { isRecoverableTransactionError as defaultIsRecoverableTransactionError } from '../../tx-retry.js';
13
+ import { loadConfig as defaultLoadConfig, getConfigPathFromArgs as defaultGetConfigPathFromArgs, } from '../../config.js';
14
+ import { isOperationalServiceStep } from '../../earning/types.js';
15
+ const PRODUCTION_DEPS = {
16
+ loadConfig: defaultLoadConfig,
17
+ getConfigPathFromArgs: defaultGetConfigPathFromArgs,
18
+ gatherIntrospectionRaw: defaultGatherIntrospectionRaw,
19
+ resolveCliPassword: defaultResolveCliPassword,
20
+ signerContextFactory: defaultCreateCliSignerContext,
21
+ bootstrapperFactory: (config) => new FleetBootstrapper({
22
+ earningDir: config.earningDir,
23
+ chain: config.networkChain ?? (config.network === 'testnet' ? 'base-sepolia' : 'base'),
24
+ rpcUrl: config.rpcUrl,
25
+ stakingMode: config.stakingMode,
26
+ targetServices: config.targetServices,
27
+ testnetL2DeploymentPath: config.testnetL2DeploymentPath,
28
+ testnetL2TokenDeploymentPath: config.testnetL2TokenDeploymentPath,
29
+ testnetMechDeploymentPath: config.testnetMechDeploymentPath,
30
+ testnetStolasDeploymentPath: config.testnetStolasDeploymentPath,
31
+ testnetClaimRegistryDeploymentPath: config.testnetClaimRegistryDeploymentPath,
32
+ debug: config.debug,
33
+ masterEthDailyEstimateWei: config.masterEthDailyEstimateWei,
34
+ minEoaGasWei: config.minEoaGasWei,
35
+ minSafeEthWei: config.minSafeEthWei,
36
+ pollIntervalMs: config.pollIntervalMs,
37
+ }),
38
+ retireFleetServiceOnChain: defaultRetireFleetServiceOnChain,
39
+ findServiceByDisplayIndex: defaultFindServiceByDisplayIndex,
40
+ isRecoverableTransactionError: defaultIsRecoverableTransactionError,
41
+ };
42
+ export function createFleetScaleCommand(deps = PRODUCTION_DEPS) {
43
+ async function runScale(ctx, rest) {
44
+ let parsed;
125
45
  try {
126
- result = await bootstrapper.bootstrap(pw.password);
46
+ parsed = parseArgs({
47
+ args: rest,
48
+ options: {
49
+ ...COMMON_FLAGS,
50
+ to: { type: 'string' },
51
+ 'dry-run': { type: 'boolean', default: false },
52
+ yes: { type: 'boolean', default: false },
53
+ },
54
+ allowPositionals: false,
55
+ });
127
56
  }
128
- catch (e) {
129
- if (isRecoverableTransactionError(e)) {
130
- emitEnvelope({
131
- code: 'transient_error',
132
- message: e instanceof Error ? e.message : String(e),
133
- exampleCli: 'jinn fleet scale --to 3 --yes',
134
- details: { cause: e instanceof Error ? e.message : String(e) },
135
- }, { writer: ctx.writer, exit: ctx.exit });
136
- return;
137
- }
57
+ catch (err) {
138
58
  emitEnvelope({
139
- code: 'fatal',
140
- message: e instanceof Error ? e.message : String(e),
141
- details: { cause: e instanceof Error ? e.message : String(e) },
59
+ code: 'invalid_invocation',
60
+ message: err instanceof Error ? err.message : String(err),
61
+ exampleCli: 'jinn fleet scale --to 3 --dry-run',
62
+ details: { field: 'flags' },
142
63
  }, { writer: ctx.writer, exit: ctx.exit });
143
64
  return;
144
65
  }
145
- if (result.funding) {
66
+ const to = parseInt(parsed.values.to, 10);
67
+ if (!Number.isFinite(to) || to < 0) {
146
68
  emitEnvelope({
147
- code: 'funding_required',
148
- message: result.message,
149
- hint: 'Fund the listed address and re-run.',
150
- exampleCli: 'jinn fund-requirements --json',
151
- details: {
152
- role: 'master',
153
- address: result.funding.master_address,
154
- asset: 'native',
155
- needWei: result.funding.eth_required,
156
- haveWei: result.funding.eth_balance,
157
- },
69
+ code: 'invalid_invocation',
70
+ message: '--to must be a non-negative integer',
71
+ exampleCli: 'jinn fleet scale --to 3 --dry-run',
72
+ details: { field: '--to', expected: 'non-negative integer' },
158
73
  }, { writer: ctx.writer, exit: ctx.exit });
159
74
  return;
160
75
  }
161
- if (!result.ok) {
76
+ const raw = await deps.gatherIntrospectionRaw({ argv: ctx.argv });
77
+ const sorted = [...(raw.fleet?.services ?? [])].sort((a, b) => a.index - b.index);
78
+ const current = sorted.length;
79
+ const dryRun = parsed.values['dry-run'];
80
+ const yes = parsed.values.yes;
81
+ let plan = [];
82
+ let description;
83
+ if (to === current) {
84
+ plan = [];
85
+ description = `Fleet is already at size ${current}. No action.`;
86
+ }
87
+ else if (to > current) {
88
+ plan = [{ action: 'grow', from: current, to }];
89
+ description = `Would grow fleet from ${current} to ${to} via bootstrap with targetServices=${to}.`;
90
+ }
91
+ else {
92
+ const indices = sorted.slice(to).map(s => s.index);
93
+ plan = [{ action: 'retire', from: current, to, indices }];
94
+ description = `Would retire services with HD service.index ${indices.join(', ')} (on-chain slot; shrink path) to shrink fleet from ${current} to ${to}.`;
95
+ }
96
+ if (dryRun) {
97
+ emitDryRun(ctx, { verb: 'fleet scale', description, plan });
98
+ return;
99
+ }
100
+ if (!ensureConfirmed(ctx, { yes, dryRun: false }))
101
+ return;
102
+ if (to === current) {
103
+ emitResult({
104
+ schemaVersion: 1,
105
+ generatedAt: new Date().toISOString(),
106
+ verb: 'fleet scale',
107
+ from: current,
108
+ to,
109
+ action: 'none',
110
+ }, (v) => {
111
+ const value = v;
112
+ return `Fleet already at target size ${value.to}.`;
113
+ }, {
114
+ json: Boolean(parsed.values.json),
115
+ human: Boolean(parsed.values.human),
116
+ writer: ctx.writer,
117
+ stdoutIsTty: ctx.stdoutIsTty,
118
+ noColor: Boolean(ctx.env['NO_COLOR']),
119
+ });
120
+ return;
121
+ }
122
+ const pw = deps.resolveCliPassword(ctx.argv, ctx.env);
123
+ if (!pw.ok) {
162
124
  emitEnvelope({
163
- code: 'fatal',
164
- message: result.message,
165
- hint: 'Bootstrap failed before the fleet reached the target size.',
166
- details: { cause: result.message },
125
+ code: 'invalid_invocation',
126
+ message: pw.message,
127
+ exampleCli: 'jinn fleet scale --to 3 --yes',
128
+ details: { field: 'keystore password' },
167
129
  }, { writer: ctx.writer, exit: ctx.exit });
168
130
  return;
169
131
  }
170
- const state = result.fleet_state;
132
+ const built = await deps.signerContextFactory({ argv: ctx.argv, env: ctx.env });
133
+ if (!built.ok) {
134
+ emitEnvelope(built.envelope, { writer: ctx.writer, exit: ctx.exit });
135
+ return;
136
+ }
137
+ const { config, networkChain, chainConfig, fleetStore, masterWallet, publicClient } = built.ctx;
138
+ if (to > current) {
139
+ const bootstrapper = deps.bootstrapperFactory({ ...config, networkChain });
140
+ let result;
141
+ try {
142
+ result = await bootstrapper.bootstrap(pw.password);
143
+ }
144
+ catch (e) {
145
+ if (deps.isRecoverableTransactionError(e)) {
146
+ emitEnvelope({
147
+ code: 'transient_error',
148
+ message: e instanceof Error ? e.message : String(e),
149
+ exampleCli: 'jinn fleet scale --to 3 --yes',
150
+ details: { cause: e instanceof Error ? e.message : String(e) },
151
+ }, { writer: ctx.writer, exit: ctx.exit });
152
+ return;
153
+ }
154
+ emitEnvelope({
155
+ code: 'fatal',
156
+ message: e instanceof Error ? e.message : String(e),
157
+ details: { cause: e instanceof Error ? e.message : String(e) },
158
+ }, { writer: ctx.writer, exit: ctx.exit });
159
+ return;
160
+ }
161
+ if (result.funding) {
162
+ emitEnvelope({
163
+ code: 'funding_required',
164
+ message: result.message,
165
+ hint: 'Fund the listed address and re-run.',
166
+ exampleCli: 'jinn fund-requirements --json',
167
+ details: {
168
+ role: 'master',
169
+ address: result.funding.master_address,
170
+ asset: 'native',
171
+ needWei: result.funding.eth_required,
172
+ haveWei: result.funding.eth_balance,
173
+ },
174
+ }, { writer: ctx.writer, exit: ctx.exit });
175
+ return;
176
+ }
177
+ if (!result.ok) {
178
+ emitEnvelope({
179
+ code: 'fatal',
180
+ message: result.message,
181
+ hint: 'Bootstrap failed before the fleet reached the target size.',
182
+ details: { cause: result.message },
183
+ }, { writer: ctx.writer, exit: ctx.exit });
184
+ return;
185
+ }
186
+ const state = result.fleet_state;
187
+ emitResult({
188
+ schemaVersion: 1,
189
+ generatedAt: new Date().toISOString(),
190
+ verb: 'fleet scale',
191
+ action: 'grow',
192
+ from: current,
193
+ to,
194
+ servicesComplete: state.services.filter(s => isOperationalServiceStep(s.step)).length,
195
+ message: result.message,
196
+ }, (v) => {
197
+ const value = v;
198
+ return `Fleet grow complete.\nFrom: ${value.from}\nTo: ${value.to}\nComplete services: ${value.servicesComplete}`;
199
+ }, {
200
+ json: Boolean(parsed.values.json),
201
+ human: Boolean(parsed.values.human),
202
+ writer: ctx.writer,
203
+ stdoutIsTty: ctx.stdoutIsTty,
204
+ noColor: Boolean(ctx.env['NO_COLOR']),
205
+ });
206
+ return;
207
+ }
208
+ const indices = sorted
209
+ .slice(to)
210
+ .map(s => s.index)
211
+ .sort((a, b) => b - a);
212
+ const retired = [];
213
+ for (const index of indices) {
214
+ try {
215
+ const r = await deps.retireFleetServiceOnChain({
216
+ publicClient,
217
+ masterWallet,
218
+ distributorAddress: chainConfig.distributorAddress,
219
+ fleetStore,
220
+ chain: networkChain,
221
+ serviceIndex: index,
222
+ });
223
+ retired.push({ index, txHash: r.txHash, message: r.message });
224
+ if (!r.ok) {
225
+ emitEnvelope({
226
+ code: 'fatal',
227
+ message: r.message,
228
+ hint: 'Fix the on-chain or fleet state issue, then retry shrink.',
229
+ details: { index, partialRetire: retired },
230
+ }, { writer: ctx.writer, exit: ctx.exit });
231
+ return;
232
+ }
233
+ }
234
+ catch (e) {
235
+ if (deps.isRecoverableTransactionError(e)) {
236
+ emitEnvelope({
237
+ code: 'transient_error',
238
+ message: e instanceof Error ? e.message : String(e),
239
+ details: { index, partialRetire: retired },
240
+ }, { writer: ctx.writer, exit: ctx.exit });
241
+ return;
242
+ }
243
+ emitEnvelope({
244
+ code: 'fatal',
245
+ message: e instanceof Error ? e.message : String(e),
246
+ details: { index, partialRetire: retired },
247
+ }, { writer: ctx.writer, exit: ctx.exit });
248
+ return;
249
+ }
250
+ }
171
251
  emitResult({
172
252
  schemaVersion: 1,
173
253
  generatedAt: new Date().toISOString(),
174
254
  verb: 'fleet scale',
175
- action: 'grow',
255
+ action: 'shrink',
176
256
  from: current,
177
257
  to,
178
- servicesComplete: state.services.filter(s => s.step === 'complete').length,
179
- message: result.message,
258
+ retired,
180
259
  }, (v) => {
181
260
  const value = v;
182
- return `Fleet grow complete.\nFrom: ${value.from}\nTo: ${value.to}\nComplete services: ${value.servicesComplete}`;
261
+ return `Fleet shrink complete.\nFrom: ${value.from}\nTo: ${value.to}\nRetired chain indices: ${value.retired.map((r) => r.index).join(', ')}`;
183
262
  }, {
184
263
  json: Boolean(parsed.values.json),
185
264
  human: Boolean(parsed.values.human),
@@ -187,250 +266,187 @@ async function runScale(ctx, rest) {
187
266
  stdoutIsTty: ctx.stdoutIsTty,
188
267
  noColor: Boolean(ctx.env['NO_COLOR']),
189
268
  });
190
- return;
191
269
  }
192
- const indices = sorted
193
- .slice(to)
194
- .map(s => s.index)
195
- .sort((a, b) => b - a);
196
- const retired = [];
197
- for (const index of indices) {
270
+ async function runRetire(ctx, rest) {
271
+ const [indexArg, ...flagArgs] = rest;
272
+ if (!indexArg || indexArg.startsWith('--')) {
273
+ emitEnvelope({
274
+ code: 'invalid_invocation',
275
+ message: 'jinn fleet retire requires a service index',
276
+ exampleCli: 'jinn fleet retire 2 --dry-run',
277
+ details: {
278
+ field: '<index>',
279
+ expected: 'non-negative display index (same as services[].index in jinn fleet JSON)',
280
+ },
281
+ }, { writer: ctx.writer, exit: ctx.exit });
282
+ return;
283
+ }
284
+ const displayIndex = parseInt(indexArg, 10);
285
+ if (!Number.isFinite(displayIndex) || displayIndex < 0) {
286
+ emitEnvelope({
287
+ code: 'invalid_invocation',
288
+ message: `Invalid service index: ${indexArg}`,
289
+ exampleCli: 'jinn fleet retire 2 --dry-run',
290
+ details: {
291
+ field: '<index>',
292
+ expected: 'non-negative display index (same as services[].index in jinn fleet JSON)',
293
+ },
294
+ }, { writer: ctx.writer, exit: ctx.exit });
295
+ return;
296
+ }
297
+ let parsed;
198
298
  try {
199
- const r = await retireFleetServiceOnChain({
299
+ parsed = parseArgs({
300
+ args: flagArgs,
301
+ options: {
302
+ ...COMMON_FLAGS,
303
+ 'dry-run': { type: 'boolean', default: false },
304
+ yes: { type: 'boolean', default: false },
305
+ },
306
+ allowPositionals: false,
307
+ });
308
+ }
309
+ catch (err) {
310
+ emitEnvelope({
311
+ code: 'invalid_invocation',
312
+ message: err instanceof Error ? err.message : String(err),
313
+ exampleCli: 'jinn fleet retire 2 --dry-run',
314
+ details: { field: 'flags' },
315
+ }, { writer: ctx.writer, exit: ctx.exit });
316
+ return;
317
+ }
318
+ const raw = await deps.gatherIntrospectionRaw({ argv: ctx.argv });
319
+ const fleet = raw.fleet;
320
+ const svc = fleet ? deps.findServiceByDisplayIndex(fleet.services, displayIndex) : undefined;
321
+ const dryRun = parsed.values['dry-run'];
322
+ const yes = parsed.values.yes;
323
+ let plan;
324
+ let description;
325
+ if (!svc) {
326
+ plan = [];
327
+ description = `Display index ${displayIndex} is not in fleet state (already retired or never existed). No action.`;
328
+ }
329
+ else {
330
+ plan = [{ action: 'retire', index: displayIndex, chainIndex: svc.index, txCount: 1 }];
331
+ description = `Would retire display index ${displayIndex} (HD service.index=${svc.index}): distributor.unstakeAndWithdraw, then remove row from earning_state.json.`;
332
+ }
333
+ if (dryRun) {
334
+ emitDryRun(ctx, { verb: 'fleet retire', description, plan });
335
+ return;
336
+ }
337
+ if (!ensureConfirmed(ctx, { yes, dryRun: false }))
338
+ return;
339
+ if (!svc) {
340
+ emitResult({
341
+ schemaVersion: 1,
342
+ generatedAt: new Date().toISOString(),
343
+ verb: 'fleet retire',
344
+ index: displayIndex,
345
+ action: 'none',
346
+ }, (v) => `Service ${String(v.index)} is already absent from fleet state.`, {
347
+ json: Boolean(parsed.values.json),
348
+ human: Boolean(parsed.values.human),
349
+ writer: ctx.writer,
350
+ stdoutIsTty: ctx.stdoutIsTty,
351
+ noColor: Boolean(ctx.env['NO_COLOR']),
352
+ });
353
+ return;
354
+ }
355
+ const pw = deps.resolveCliPassword(ctx.argv, ctx.env);
356
+ if (!pw.ok) {
357
+ emitEnvelope({
358
+ code: 'invalid_invocation',
359
+ message: pw.message,
360
+ exampleCli: 'jinn fleet retire 2 --yes',
361
+ details: { field: 'keystore password' },
362
+ }, { writer: ctx.writer, exit: ctx.exit });
363
+ return;
364
+ }
365
+ const built = await deps.signerContextFactory({ argv: ctx.argv, env: ctx.env });
366
+ if (!built.ok) {
367
+ emitEnvelope(built.envelope, { writer: ctx.writer, exit: ctx.exit });
368
+ return;
369
+ }
370
+ const { networkChain, chainConfig, fleetStore, masterWallet, publicClient } = built.ctx;
371
+ try {
372
+ const r = await deps.retireFleetServiceOnChain({
200
373
  publicClient,
201
374
  masterWallet,
202
375
  distributorAddress: chainConfig.distributorAddress,
203
376
  fleetStore,
204
377
  chain: networkChain,
205
- serviceIndex: index,
378
+ serviceIndex: svc.index,
206
379
  });
207
- retired.push({ index, txHash: r.txHash, message: r.message });
208
380
  if (!r.ok) {
209
381
  emitEnvelope({
210
382
  code: 'fatal',
211
383
  message: r.message,
212
- hint: 'Fix the on-chain or fleet state issue, then retry shrink.',
213
- details: { index, partialRetire: retired },
384
+ details: { displayIndex, chainIndex: svc.index },
214
385
  }, { writer: ctx.writer, exit: ctx.exit });
215
386
  return;
216
387
  }
388
+ emitResult({
389
+ schemaVersion: 1,
390
+ generatedAt: new Date().toISOString(),
391
+ verb: 'fleet retire',
392
+ index: displayIndex,
393
+ chainIndex: svc.index,
394
+ ok: r.ok,
395
+ txHash: r.txHash ?? null,
396
+ message: r.message,
397
+ }, (v) => {
398
+ const value = v;
399
+ return `Service retired.\nDisplay index: ${value.index}\nChain index: ${value.chainIndex}\nTx: ${value.txHash ?? 'n/a'}`;
400
+ }, {
401
+ json: Boolean(parsed.values.json),
402
+ human: Boolean(parsed.values.human),
403
+ writer: ctx.writer,
404
+ stdoutIsTty: ctx.stdoutIsTty,
405
+ noColor: Boolean(ctx.env['NO_COLOR']),
406
+ });
217
407
  }
218
408
  catch (e) {
219
- if (isRecoverableTransactionError(e)) {
409
+ if (deps.isRecoverableTransactionError(e)) {
220
410
  emitEnvelope({
221
411
  code: 'transient_error',
222
412
  message: e instanceof Error ? e.message : String(e),
223
- details: { index, partialRetire: retired },
413
+ details: { displayIndex, chainIndex: svc.index },
224
414
  }, { writer: ctx.writer, exit: ctx.exit });
225
415
  return;
226
416
  }
227
417
  emitEnvelope({
228
418
  code: 'fatal',
229
419
  message: e instanceof Error ? e.message : String(e),
230
- details: { index, partialRetire: retired },
231
- }, { writer: ctx.writer, exit: ctx.exit });
232
- return;
233
- }
234
- }
235
- emitResult({
236
- schemaVersion: 1,
237
- generatedAt: new Date().toISOString(),
238
- verb: 'fleet scale',
239
- action: 'shrink',
240
- from: current,
241
- to,
242
- retired,
243
- }, (v) => {
244
- const value = v;
245
- return `Fleet shrink complete.\nFrom: ${value.from}\nTo: ${value.to}\nRetired chain indices: ${value.retired.map((r) => r.index).join(', ')}`;
246
- }, {
247
- json: Boolean(parsed.values.json),
248
- human: Boolean(parsed.values.human),
249
- writer: ctx.writer,
250
- stdoutIsTty: ctx.stdoutIsTty,
251
- noColor: Boolean(ctx.env['NO_COLOR']),
252
- });
253
- }
254
- async function runRetire(ctx, rest) {
255
- const [indexArg, ...flagArgs] = rest;
256
- if (!indexArg || indexArg.startsWith('--')) {
257
- emitEnvelope({
258
- code: 'invalid_invocation',
259
- message: 'jinn fleet retire requires a service index',
260
- exampleCli: 'jinn fleet retire 2 --dry-run',
261
- details: {
262
- field: '<index>',
263
- expected: 'non-negative display index (same as services[].index in jinn fleet JSON)',
264
- },
265
- }, { writer: ctx.writer, exit: ctx.exit });
266
- return;
267
- }
268
- const displayIndex = parseInt(indexArg, 10);
269
- if (!Number.isFinite(displayIndex) || displayIndex < 0) {
270
- emitEnvelope({
271
- code: 'invalid_invocation',
272
- message: `Invalid service index: ${indexArg}`,
273
- exampleCli: 'jinn fleet retire 2 --dry-run',
274
- details: {
275
- field: '<index>',
276
- expected: 'non-negative display index (same as services[].index in jinn fleet JSON)',
277
- },
278
- }, { writer: ctx.writer, exit: ctx.exit });
279
- return;
280
- }
281
- let parsed;
282
- try {
283
- parsed = parseArgs({
284
- args: flagArgs,
285
- options: {
286
- ...COMMON_FLAGS,
287
- 'dry-run': { type: 'boolean', default: false },
288
- yes: { type: 'boolean', default: false },
289
- },
290
- allowPositionals: false,
291
- });
292
- }
293
- catch (err) {
294
- emitEnvelope({
295
- code: 'invalid_invocation',
296
- message: err instanceof Error ? err.message : String(err),
297
- exampleCli: 'jinn fleet retire 2 --dry-run',
298
- details: { field: 'flags' },
299
- }, { writer: ctx.writer, exit: ctx.exit });
300
- return;
301
- }
302
- const raw = await gatherIntrospectionRaw({ argv: ctx.argv });
303
- const fleet = raw.fleet;
304
- const svc = fleet ? findServiceByDisplayIndex(fleet.services, displayIndex) : undefined;
305
- const dryRun = parsed.values['dry-run'];
306
- const yes = parsed.values.yes;
307
- let plan;
308
- let description;
309
- if (!svc) {
310
- plan = [];
311
- description = `Display index ${displayIndex} is not in fleet state (already retired or never existed). No action.`;
312
- }
313
- else {
314
- plan = [{ action: 'retire', index: displayIndex, chainIndex: svc.index, txCount: 1 }];
315
- description = `Would retire display index ${displayIndex} (HD service.index=${svc.index}): distributor.unstakeAndWithdraw, then remove row from earning_state.json.`;
316
- }
317
- if (dryRun) {
318
- emitDryRun(ctx, { verb: 'fleet retire', description, plan });
319
- return;
320
- }
321
- if (!ensureConfirmed(ctx, { yes, dryRun: false }))
322
- return;
323
- if (!svc) {
324
- emitResult({
325
- schemaVersion: 1,
326
- generatedAt: new Date().toISOString(),
327
- verb: 'fleet retire',
328
- index: displayIndex,
329
- action: 'none',
330
- }, (v) => `Service ${String(v.index)} is already absent from fleet state.`, {
331
- json: Boolean(parsed.values.json),
332
- human: Boolean(parsed.values.human),
333
- writer: ctx.writer,
334
- stdoutIsTty: ctx.stdoutIsTty,
335
- noColor: Boolean(ctx.env['NO_COLOR']),
336
- });
337
- return;
338
- }
339
- const pw = resolveCliPassword(ctx.argv, ctx.env);
340
- if (!pw.ok) {
341
- emitEnvelope({
342
- code: 'invalid_invocation',
343
- message: pw.message,
344
- exampleCli: 'jinn fleet retire 2 --yes',
345
- details: { field: 'keystore password' },
346
- }, { writer: ctx.writer, exit: ctx.exit });
347
- return;
348
- }
349
- const built = await createCliSignerContext({ argv: ctx.argv, env: ctx.env });
350
- if (!built.ok) {
351
- emitEnvelope(built.envelope, { writer: ctx.writer, exit: ctx.exit });
352
- return;
353
- }
354
- const { networkChain, chainConfig, fleetStore, masterWallet, publicClient } = built.ctx;
355
- try {
356
- const r = await retireFleetServiceOnChain({
357
- publicClient,
358
- masterWallet,
359
- distributorAddress: chainConfig.distributorAddress,
360
- fleetStore,
361
- chain: networkChain,
362
- serviceIndex: svc.index,
363
- });
364
- if (!r.ok) {
365
- emitEnvelope({
366
- code: 'fatal',
367
- message: r.message,
368
420
  details: { displayIndex, chainIndex: svc.index },
369
421
  }, { writer: ctx.writer, exit: ctx.exit });
370
- return;
371
422
  }
372
- emitResult({
373
- schemaVersion: 1,
374
- generatedAt: new Date().toISOString(),
375
- verb: 'fleet retire',
376
- index: displayIndex,
377
- chainIndex: svc.index,
378
- ok: r.ok,
379
- txHash: r.txHash ?? null,
380
- message: r.message,
381
- }, (v) => {
382
- const value = v;
383
- return `Service retired.\nDisplay index: ${value.index}\nChain index: ${value.chainIndex}\nTx: ${value.txHash ?? 'n/a'}`;
384
- }, {
385
- json: Boolean(parsed.values.json),
386
- human: Boolean(parsed.values.human),
387
- writer: ctx.writer,
388
- stdoutIsTty: ctx.stdoutIsTty,
389
- noColor: Boolean(ctx.env['NO_COLOR']),
390
- });
391
423
  }
392
- catch (e) {
393
- if (isRecoverableTransactionError(e)) {
424
+ async function run(ctx) {
425
+ const [subverb, ...rest] = ctx.argv;
426
+ if (!subverb) {
394
427
  emitEnvelope({
395
- code: 'transient_error',
396
- message: e instanceof Error ? e.message : String(e),
397
- details: { displayIndex, chainIndex: svc.index },
428
+ code: 'invalid_invocation',
429
+ message: 'jinn fleet requires a subverb: scale | retire',
430
+ exampleCli: 'jinn fleet scale --to 3 --dry-run',
431
+ details: { field: 'subverb', expected: 'scale | retire' },
398
432
  }, { writer: ctx.writer, exit: ctx.exit });
399
433
  return;
400
434
  }
401
- emitEnvelope({
402
- code: 'fatal',
403
- message: e instanceof Error ? e.message : String(e),
404
- details: { displayIndex, chainIndex: svc.index },
405
- }, { writer: ctx.writer, exit: ctx.exit });
406
- }
407
- }
408
- async function run(ctx) {
409
- const [subverb, ...rest] = ctx.argv;
410
- if (!subverb) {
435
+ if (subverb === 'scale')
436
+ return runScale(ctx, rest);
437
+ if (subverb === 'retire')
438
+ return runRetire(ctx, rest);
411
439
  emitEnvelope({
412
440
  code: 'invalid_invocation',
413
- message: 'jinn fleet requires a subverb: scale | retire',
414
- exampleCli: 'jinn fleet scale --to 3 --dry-run',
441
+ message: `Unknown fleet subverb: ${subverb}`,
442
+ exampleCli: 'jinn fleet --help',
415
443
  details: { field: 'subverb', expected: 'scale | retire' },
416
444
  }, { writer: ctx.writer, exit: ctx.exit });
417
- return;
418
445
  }
419
- if (subverb === 'scale')
420
- return runScale(ctx, rest);
421
- if (subverb === 'retire')
422
- return runRetire(ctx, rest);
423
- emitEnvelope({
424
- code: 'invalid_invocation',
425
- message: `Unknown fleet subverb: ${subverb}`,
426
- exampleCli: 'jinn fleet --help',
427
- details: { field: 'subverb', expected: 'scale | retire' },
428
- }, { writer: ctx.writer, exit: ctx.exit });
429
- }
430
- const command = {
431
- name: 'fleet-manage',
432
- summary: 'Fleet management: scale | retire <index>',
433
- helpText: `Usage: jinn fleet <subverb> [flags...]
446
+ return {
447
+ name: 'fleet-manage',
448
+ summary: 'Fleet management: scale | retire <index>',
449
+ helpText: `Usage: jinn fleet <subverb> [flags...]
434
450
 
435
451
  Subverbs:
436
452
  scale --to N [--dry-run] [--yes] Grow or shrink the fleet to N services (idempotent)
@@ -444,7 +460,9 @@ Examples:
444
460
  jinn fleet scale --to 3 --yes
445
461
  jinn fleet retire 1 --dry-run
446
462
  `,
447
- run,
448
- };
463
+ run,
464
+ };
465
+ }
466
+ const command = createFleetScaleCommand();
449
467
  export default command;
450
468
  //# sourceMappingURL=fleet-scale.js.map