@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.
- package/CHANGELOG.md +20 -0
- package/CONTRIBUTING.md +8 -2
- package/README.md +38 -14
- package/deployments/deployment-jinn-mvi-l1-sepolia-fast.json +36 -0
- package/deployments/deployment-jinn-mvi-l1-sepolia.json +36 -0
- package/deployments/deployment-jinn-mvi-l2-baseSepolia.json +12 -0
- package/deployments/deployment-phase1b-mech-baseSepolia-fast.json +3 -3
- package/deployments/deployment-stolas-l2-baseSepolia-fast.json +1 -1
- package/dist/adapters/adapter.d.ts +2 -2
- package/dist/adapters/claim-registry/client.d.ts +9 -0
- package/dist/adapters/claim-registry/client.js +22 -2
- package/dist/adapters/claim-registry/client.js.map +1 -1
- package/dist/adapters/local/adapter.d.ts +2 -2
- package/dist/adapters/local/adapter.js +8 -8
- package/dist/adapters/local/adapter.js.map +1 -1
- package/dist/adapters/mech/adapter.d.ts +3 -4
- package/dist/adapters/mech/adapter.js +86 -50
- package/dist/adapters/mech/adapter.js.map +1 -1
- package/dist/adapters/mech/contracts.d.ts +6 -4
- package/dist/adapters/mech/contracts.js +118 -14
- package/dist/adapters/mech/contracts.js.map +1 -1
- package/dist/adapters/mech/ipfs.d.ts +61 -6
- package/dist/adapters/mech/ipfs.js +159 -26
- package/dist/adapters/mech/ipfs.js.map +1 -1
- package/dist/adapters/mech/safe-revert.d.ts +39 -0
- package/dist/adapters/mech/safe-revert.js +130 -0
- package/dist/adapters/mech/safe-revert.js.map +1 -0
- package/dist/adapters/mech/safe.js +47 -21
- package/dist/adapters/mech/safe.js.map +1 -1
- package/dist/adapters/mech/types.d.ts +8 -0
- package/dist/adapters/mech/types.js.map +1 -1
- package/dist/agent/agent-ws.d.ts +55 -0
- package/dist/agent/agent-ws.js +288 -0
- package/dist/agent/agent-ws.js.map +1 -0
- package/dist/agent/auto-mode-detect.d.ts +6 -0
- package/dist/agent/auto-mode-detect.js +44 -0
- package/dist/agent/auto-mode-detect.js.map +1 -0
- package/dist/agent/operator-claude.d.ts +22 -0
- package/dist/agent/operator-claude.js +130 -0
- package/dist/agent/operator-claude.js.map +1 -0
- package/dist/api/admin-endpoint.d.ts +12 -0
- package/dist/api/admin-endpoint.js +71 -0
- package/dist/api/admin-endpoint.js.map +1 -0
- package/dist/api/bootstrap-endpoint.d.ts +16 -0
- package/dist/api/bootstrap-endpoint.js +78 -0
- package/dist/api/bootstrap-endpoint.js.map +1 -0
- package/dist/api/events-endpoint.d.ts +9 -0
- package/dist/api/events-endpoint.js +46 -0
- package/dist/api/events-endpoint.js.map +1 -0
- package/dist/api/fleet-build.d.ts +1 -1
- package/dist/api/fleet-build.js +17 -8
- package/dist/api/fleet-build.js.map +1 -1
- package/dist/api/gather-status.js +5 -1
- package/dist/api/gather-status.js.map +1 -1
- package/dist/api/handshake.d.ts +17 -0
- package/dist/api/handshake.js +28 -0
- package/dist/api/handshake.js.map +1 -0
- package/dist/api/peers.js +20 -5
- package/dist/api/peers.js.map +1 -1
- package/dist/api/portfolio-v0-build.d.ts +6 -0
- package/dist/api/portfolio-v0-build.js +6 -1
- package/dist/api/portfolio-v0-build.js.map +1 -1
- package/dist/api/rewards-build.js +3 -8
- package/dist/api/rewards-build.js.map +1 -1
- package/dist/api/server.d.ts +54 -0
- package/dist/api/server.js +239 -13
- package/dist/api/server.js.map +1 -1
- package/dist/api/setup-endpoints.d.ts +34 -0
- package/dist/api/setup-endpoints.js +188 -0
- package/dist/api/setup-endpoints.js.map +1 -0
- package/dist/api/status-build.d.ts +9 -1
- package/dist/api/status-build.js +44 -9
- package/dist/api/status-build.js.map +1 -1
- package/dist/api/status-rollup-build.d.ts +46 -1
- package/dist/api/status-rollup-build.js +168 -5
- package/dist/api/status-rollup-build.js.map +1 -1
- package/dist/api/ui-token.d.ts +5 -0
- package/dist/api/ui-token.js +36 -0
- package/dist/api/ui-token.js.map +1 -0
- package/dist/build-info.d.ts +32 -0
- package/dist/build-info.js +69 -0
- package/dist/build-info.js.map +1 -0
- package/dist/build-info.json +6 -0
- package/dist/build-meta.json +1 -1
- package/dist/cli/command.d.ts +9 -0
- package/dist/cli/commands/balance.d.ts +7 -0
- package/dist/cli/commands/balance.js +38 -32
- package/dist/cli/commands/balance.js.map +1 -1
- package/dist/cli/commands/bootstrap.d.ts +13 -1
- package/dist/cli/commands/bootstrap.js +150 -132
- package/dist/cli/commands/bootstrap.js.map +1 -1
- package/dist/cli/commands/claim-rewards.js +14 -2
- package/dist/cli/commands/claim-rewards.js.map +1 -1
- package/dist/cli/commands/conformance.d.ts +12 -0
- package/dist/cli/commands/conformance.js +140 -0
- package/dist/cli/commands/conformance.js.map +1 -0
- package/dist/cli/commands/create.d.ts +36 -0
- package/dist/cli/commands/create.js +374 -0
- package/dist/cli/commands/create.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +34 -1
- package/dist/cli/commands/doctor.js +136 -121
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/fleet-scale.d.ts +19 -1
- package/dist/cli/commands/fleet-scale.js +379 -361
- package/dist/cli/commands/fleet-scale.js.map +1 -1
- package/dist/cli/commands/fleet.d.ts +7 -0
- package/dist/cli/commands/fleet.js +39 -33
- package/dist/cli/commands/fleet.js.map +1 -1
- package/dist/cli/commands/fund-requirements.d.ts +14 -1
- package/dist/cli/commands/fund-requirements.js +183 -174
- package/dist/cli/commands/fund-requirements.js.map +1 -1
- package/dist/cli/commands/history.d.ts +10 -1
- package/dist/cli/commands/history.js +66 -57
- package/dist/cli/commands/history.js.map +1 -1
- package/dist/cli/commands/impls.d.ts +18 -0
- package/dist/cli/commands/impls.js +208 -0
- package/dist/cli/commands/impls.js.map +1 -0
- package/dist/cli/commands/init.js +4 -1
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/intents.js +13 -9
- package/dist/cli/commands/intents.js.map +1 -1
- package/dist/cli/commands/logs.d.ts +6 -1
- package/dist/cli/commands/logs.js +77 -70
- package/dist/cli/commands/logs.js.map +1 -1
- package/dist/cli/commands/migrate-agent-id.d.ts +26 -0
- package/dist/cli/commands/migrate-agent-id.js +165 -0
- package/dist/cli/commands/migrate-agent-id.js.map +1 -0
- package/dist/cli/commands/plug-ins.d.ts +34 -0
- package/dist/cli/commands/plug-ins.js +282 -0
- package/dist/cli/commands/plug-ins.js.map +1 -0
- package/dist/cli/commands/plugin-install.d.ts +10 -0
- package/dist/cli/commands/plugin-install.js +226 -14
- package/dist/cli/commands/plugin-install.js.map +1 -1
- package/dist/cli/commands/rewards.d.ts +7 -0
- package/dist/cli/commands/rewards.js +46 -40
- package/dist/cli/commands/rewards.js.map +1 -1
- package/dist/cli/commands/run.d.ts +14 -1
- package/dist/cli/commands/run.js +232 -90
- package/dist/cli/commands/run.js.map +1 -1
- package/dist/cli/commands/status.d.ts +10 -0
- package/dist/cli/commands/status.js +97 -34
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/submit-intent.js +33 -6
- package/dist/cli/commands/submit-intent.js.map +1 -1
- package/dist/cli/commands/ui.js +45 -0
- package/dist/cli/commands/ui.js.map +1 -0
- package/dist/cli/commands/update.d.ts +5 -0
- package/dist/cli/commands/update.js +102 -97
- package/dist/cli/commands/update.js.map +1 -1
- package/dist/cli/commands/version.js +3 -1
- package/dist/cli/commands/version.js.map +1 -1
- package/dist/cli/commands/withdraw.d.ts +21 -1
- package/dist/cli/commands/withdraw.js +175 -159
- package/dist/cli/commands/withdraw.js.map +1 -1
- package/dist/cli/execution-context.d.ts +1 -1
- package/dist/cli/execution-context.js +2 -1
- package/dist/cli/execution-context.js.map +1 -1
- package/dist/cli/help.js +7 -0
- package/dist/cli/help.js.map +1 -1
- package/dist/cli/index.d.ts +7 -0
- package/dist/cli/index.js +18 -2
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/intent-registry-access.d.ts +33 -1
- package/dist/cli/intent-registry-access.js +40 -2
- package/dist/cli/intent-registry-access.js.map +1 -1
- package/dist/cli/open-browser.d.ts +1 -0
- package/dist/cli/open-browser.js +18 -0
- package/dist/cli/open-browser.js.map +1 -0
- package/dist/cli/password.d.ts +3 -3
- package/dist/cli/password.js +5 -5
- package/dist/cli/password.js.map +1 -1
- package/dist/config.d.ts +883 -11
- package/dist/config.js +435 -4
- package/dist/config.js.map +1 -1
- package/dist/conformance/checks/artifacts.d.ts +37 -0
- package/dist/conformance/checks/artifacts.js +110 -0
- package/dist/conformance/checks/artifacts.js.map +1 -0
- package/dist/conformance/checks/envelope-schema.d.ts +17 -0
- package/dist/conformance/checks/envelope-schema.js +36 -0
- package/dist/conformance/checks/envelope-schema.js.map +1 -0
- package/dist/conformance/checks/hash-signature.d.ts +26 -0
- package/dist/conformance/checks/hash-signature.js +70 -0
- package/dist/conformance/checks/hash-signature.js.map +1 -0
- package/dist/conformance/checks/payload.d.ts +19 -0
- package/dist/conformance/checks/payload.js +52 -0
- package/dist/conformance/checks/payload.js.map +1 -0
- package/dist/conformance/checks/secret-scrub.d.ts +33 -0
- package/dist/conformance/checks/secret-scrub.js +118 -0
- package/dist/conformance/checks/secret-scrub.js.map +1 -0
- package/dist/conformance/checks/source-runtime.d.ts +43 -0
- package/dist/conformance/checks/source-runtime.js +68 -0
- package/dist/conformance/checks/source-runtime.js.map +1 -0
- package/dist/conformance/checks/source-static.d.ts +61 -0
- package/dist/conformance/checks/source-static.js +311 -0
- package/dist/conformance/checks/source-static.js.map +1 -0
- package/dist/conformance/checks/trajectory-chain.d.ts +18 -0
- package/dist/conformance/checks/trajectory-chain.js +51 -0
- package/dist/conformance/checks/trajectory-chain.js.map +1 -0
- package/dist/conformance/checks/trajectory-profile.d.ts +17 -0
- package/dist/conformance/checks/trajectory-profile.js +51 -0
- package/dist/conformance/checks/trajectory-profile.js.map +1 -0
- package/dist/conformance/checks/trajectory-schema.d.ts +20 -0
- package/dist/conformance/checks/trajectory-schema.js +40 -0
- package/dist/conformance/checks/trajectory-schema.js.map +1 -0
- package/dist/conformance/checks/verdict.d.ts +44 -0
- package/dist/conformance/checks/verdict.js +122 -0
- package/dist/conformance/checks/verdict.js.map +1 -0
- package/dist/conformance/harness.d.ts +32 -0
- package/dist/conformance/harness.js +228 -0
- package/dist/conformance/harness.js.map +1 -0
- package/dist/conformance/types.d.ts +88 -0
- package/dist/conformance/types.js +31 -0
- package/dist/conformance/types.js.map +1 -0
- package/dist/corpus/acquire.d.ts +37 -0
- package/dist/corpus/acquire.js +155 -0
- package/dist/corpus/acquire.js.map +1 -0
- package/dist/corpus/cache.d.ts +14 -0
- package/dist/corpus/cache.js +18 -0
- package/dist/corpus/cache.js.map +1 -0
- package/dist/corpus/fetch.d.ts +9 -0
- package/dist/corpus/fetch.js +24 -0
- package/dist/corpus/fetch.js.map +1 -0
- package/dist/corpus/index.d.ts +16 -0
- package/dist/corpus/index.js +78 -0
- package/dist/corpus/index.js.map +1 -0
- package/dist/corpus/query.d.ts +17 -0
- package/dist/corpus/query.js +108 -0
- package/dist/corpus/query.js.map +1 -0
- package/dist/corpus/route-resolver.d.ts +16 -0
- package/dist/corpus/route-resolver.js +20 -0
- package/dist/corpus/route-resolver.js.map +1 -0
- package/dist/corpus/types.d.ts +107 -0
- package/dist/corpus/types.js +50 -0
- package/dist/corpus/types.js.map +1 -0
- package/dist/daemon/balance-topup-loop.js +2 -1
- package/dist/daemon/balance-topup-loop.js.map +1 -1
- package/dist/daemon/creator.d.ts +2 -2
- package/dist/daemon/creator.js +2 -2
- package/dist/daemon/creator.js.map +1 -1
- package/dist/daemon/daemon.d.ts +70 -15
- package/dist/daemon/daemon.js +159 -41
- package/dist/daemon/daemon.js.map +1 -1
- package/dist/daemon/delivery-watcher.js +31 -1
- package/dist/daemon/delivery-watcher.js.map +1 -1
- package/dist/daemon/jinn-claim-loop-canonical.d.ts +207 -0
- package/dist/daemon/jinn-claim-loop-canonical.js +296 -0
- package/dist/daemon/jinn-claim-loop-canonical.js.map +1 -0
- package/dist/daemon/jinn-claim-loop-mock.d.ts +61 -0
- package/dist/daemon/jinn-claim-loop-mock.js +122 -0
- package/dist/daemon/jinn-claim-loop-mock.js.map +1 -0
- package/dist/daemon/jinn-claim-loop.d.ts +123 -0
- package/dist/daemon/jinn-claim-loop.js +256 -0
- package/dist/daemon/jinn-claim-loop.js.map +1 -0
- package/dist/daemon/reward-claim-loop.d.ts +2 -0
- package/dist/daemon/reward-claim-loop.js +32 -27
- package/dist/daemon/reward-claim-loop.js.map +1 -1
- package/dist/dashboard/assets/index-Bxlk5qpa.js +68 -0
- package/dist/dashboard/assets/index-DQ3u_vP5.css +32 -0
- package/dist/dashboard/index.html +18 -74
- package/dist/earning/agent-wallet-binding.d.ts +133 -0
- package/dist/earning/agent-wallet-binding.js +202 -0
- package/dist/earning/agent-wallet-binding.js.map +1 -0
- package/dist/earning/bootstrap.d.ts +64 -0
- package/dist/earning/bootstrap.js +325 -32
- package/dist/earning/bootstrap.js.map +1 -1
- package/dist/earning/contracts.d.ts +323 -0
- package/dist/earning/contracts.js +276 -0
- package/dist/earning/contracts.js.map +1 -1
- package/dist/earning/funding-plan.d.ts +90 -0
- package/dist/earning/funding-plan.js +203 -0
- package/dist/earning/funding-plan.js.map +1 -0
- package/dist/earning/migrate-agent-id.d.ts +130 -0
- package/dist/earning/migrate-agent-id.js +257 -0
- package/dist/earning/migrate-agent-id.js.map +1 -0
- package/dist/earning/orphan-sweep.d.ts +14 -0
- package/dist/earning/orphan-sweep.js +63 -2
- package/dist/earning/orphan-sweep.js.map +1 -1
- package/dist/earning/reconcile.d.ts +2 -0
- package/dist/earning/reconcile.js +30 -0
- package/dist/earning/reconcile.js.map +1 -1
- package/dist/earning/stolas-claim.d.ts +86 -6
- package/dist/earning/stolas-claim.js +123 -9
- package/dist/earning/stolas-claim.js.map +1 -1
- package/dist/earning/store.d.ts +39 -0
- package/dist/earning/store.js +72 -1
- package/dist/earning/store.js.map +1 -1
- package/dist/earning/testnet-setup-migration.d.ts +32 -0
- package/dist/earning/testnet-setup-migration.js +214 -0
- package/dist/earning/testnet-setup-migration.js.map +1 -0
- package/dist/earning/types.d.ts +53 -9
- package/dist/earning/types.js +51 -2
- package/dist/earning/types.js.map +1 -1
- package/dist/earning/viem-clients.d.ts +20 -0
- package/dist/earning/viem-clients.js +32 -1
- package/dist/earning/viem-clients.js.map +1 -1
- package/dist/erc8004/abis.d.ts +381 -0
- package/dist/erc8004/abis.js +238 -0
- package/dist/erc8004/abis.js.map +1 -0
- package/dist/erc8004/addresses.d.ts +40 -0
- package/dist/erc8004/addresses.js +64 -0
- package/dist/erc8004/addresses.js.map +1 -0
- package/dist/erc8004/identity.d.ts +202 -0
- package/dist/erc8004/identity.js +305 -0
- package/dist/erc8004/identity.js.map +1 -0
- package/dist/erc8004/index.d.ts +13 -0
- package/dist/erc8004/index.js +20 -0
- package/dist/erc8004/index.js.map +1 -0
- package/dist/erc8004/reputation.d.ts +349 -0
- package/dist/erc8004/reputation.js +464 -0
- package/dist/erc8004/reputation.js.map +1 -0
- package/dist/erc8004/subgraph.d.ts +46 -0
- package/dist/erc8004/subgraph.js +37 -0
- package/dist/erc8004/subgraph.js.map +1 -0
- package/dist/erc8004/validation.d.ts +145 -0
- package/dist/erc8004/validation.js +219 -0
- package/dist/erc8004/validation.js.map +1 -0
- package/dist/errors/persisted-bootstrap-error.d.ts +4 -0
- package/dist/errors/persisted-bootstrap-error.js +50 -0
- package/dist/errors/persisted-bootstrap-error.js.map +1 -0
- package/dist/events/emitter.d.ts +12 -0
- package/dist/events/emitter.js +23 -0
- package/dist/events/emitter.js.map +1 -0
- package/dist/events/ring-buffer.d.ts +25 -0
- package/dist/events/ring-buffer.js +46 -0
- package/dist/events/ring-buffer.js.map +1 -0
- package/dist/events/types.d.ts +42 -0
- package/dist/events/types.js +28 -0
- package/dist/events/types.js.map +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/intents/kinds/index.d.ts +10 -0
- package/dist/intents/kinds/index.js +7 -0
- package/dist/intents/kinds/index.js.map +1 -1
- package/dist/intents/kinds/learner-loop-test.d.ts +2 -0
- package/dist/intents/kinds/learner-loop-test.js +39 -0
- package/dist/intents/kinds/learner-loop-test.js.map +1 -0
- package/dist/intents/kinds/prediction-apy-v0.js +5 -1
- package/dist/intents/kinds/prediction-apy-v0.js.map +1 -1
- package/dist/intents/kinds/prediction-v0.js +5 -0
- package/dist/intents/kinds/prediction-v0.js.map +1 -1
- package/dist/intents/kinds/spec-kind.d.ts +18 -1
- package/dist/intents/posting-service.d.ts +3 -5
- package/dist/intents/posting-service.js +16 -50
- package/dist/intents/posting-service.js.map +1 -1
- package/dist/intents/prediction-apy-v0-auto.d.ts +12 -2
- package/dist/intents/prediction-apy-v0-auto.js +27 -2
- package/dist/intents/prediction-apy-v0-auto.js.map +1 -1
- package/dist/intents/prediction-v0-auto.d.ts +14 -4
- package/dist/intents/prediction-v0-auto.js +29 -5
- package/dist/intents/prediction-v0-auto.js.map +1 -1
- package/dist/intents/signing.d.ts +13 -0
- package/dist/intents/signing.js +27 -0
- package/dist/intents/signing.js.map +1 -0
- package/dist/intents/sources.d.ts +12 -5
- package/dist/intents/sources.js +11 -11
- package/dist/intents/sources.js.map +1 -1
- package/dist/main.d.ts +5 -2
- package/dist/main.js +792 -66
- package/dist/main.js.map +1 -1
- package/dist/mcp/acquire-artifact.d.ts +39 -0
- package/dist/mcp/acquire-artifact.js +163 -0
- package/dist/mcp/acquire-artifact.js.map +1 -0
- package/dist/mcp/operator-server.d.ts +20 -3
- package/dist/mcp/operator-server.js +500 -25
- package/dist/mcp/operator-server.js.map +1 -1
- package/dist/mcp/search-artifacts.d.ts +31 -0
- package/dist/mcp/search-artifacts.js +40 -0
- package/dist/mcp/search-artifacts.js.map +1 -0
- package/dist/mcp/server.js +103 -58
- package/dist/mcp/server.js.map +1 -1
- package/dist/observability/emit-event.d.ts +1 -1
- package/dist/observability/emit-event.js.map +1 -1
- package/dist/operator-errors.js +4 -5
- package/dist/operator-errors.js.map +1 -1
- package/dist/preflight/claude-auth.d.ts +11 -11
- package/dist/preflight/claude-auth.js +18 -32
- package/dist/preflight/claude-auth.js.map +1 -1
- package/dist/restorer/capability/index.d.ts +82 -0
- package/dist/restorer/capability/index.js +12 -0
- package/dist/restorer/capability/index.js.map +1 -0
- package/dist/restorer/capability/scoped-rpc.d.ts +12 -0
- package/dist/restorer/capability/scoped-rpc.js +34 -0
- package/dist/restorer/capability/scoped-rpc.js.map +1 -0
- package/dist/restorer/capability/scoped-secrets.d.ts +8 -0
- package/dist/restorer/capability/scoped-secrets.js +10 -0
- package/dist/restorer/capability/scoped-secrets.js.map +1 -0
- package/dist/restorer/capability/scoped-signer.d.ts +46 -0
- package/dist/restorer/capability/scoped-signer.js +73 -0
- package/dist/restorer/capability/scoped-signer.js.map +1 -0
- package/dist/restorer/engine/canonical-json.d.ts +0 -17
- package/dist/restorer/engine/canonical-json.js +56 -49
- package/dist/restorer/engine/canonical-json.js.map +1 -1
- package/dist/restorer/engine/claim.js +8 -1
- package/dist/restorer/engine/claim.js.map +1 -1
- package/dist/restorer/engine/delivery.d.ts +2 -0
- package/dist/restorer/engine/delivery.js +2 -2
- package/dist/restorer/engine/delivery.js.map +1 -1
- package/dist/restorer/engine/engine.d.ts +143 -26
- package/dist/restorer/engine/engine.js +485 -104
- package/dist/restorer/engine/engine.js.map +1 -1
- package/dist/restorer/engine/envelope-assembly.d.ts +65 -0
- package/dist/restorer/engine/envelope-assembly.js +60 -0
- package/dist/restorer/engine/envelope-assembly.js.map +1 -0
- package/dist/restorer/engine/packaging.d.ts +30 -30
- package/dist/restorer/engine/packaging.js +73 -47
- package/dist/restorer/engine/packaging.js.map +1 -1
- package/dist/restorer/engine/persistence.d.ts +7 -7
- package/dist/restorer/engine/persistence.js +4 -4
- package/dist/restorer/engine/persistence.js.map +1 -1
- package/dist/restorer/engine/registry.d.ts +24 -13
- package/dist/restorer/engine/registry.js +16 -13
- package/dist/restorer/engine/registry.js.map +1 -1
- package/dist/restorer/engine/validate-manifest.d.ts +23 -0
- package/dist/restorer/engine/validate-manifest.js +49 -0
- package/dist/restorer/engine/validate-manifest.js.map +1 -0
- package/dist/restorer/engine/verification-stub.d.ts +18 -0
- package/dist/restorer/engine/verification-stub.js +18 -0
- package/dist/restorer/engine/verification-stub.js.map +1 -0
- package/dist/restorer/external-impls/index.d.ts +3 -0
- package/dist/restorer/external-impls/index.js +2 -0
- package/dist/restorer/external-impls/index.js.map +1 -0
- package/dist/restorer/external-impls/loader.d.ts +49 -0
- package/dist/restorer/external-impls/loader.js +138 -0
- package/dist/restorer/external-impls/loader.js.map +1 -0
- package/dist/restorer/external-impls/package-hash.d.ts +26 -0
- package/dist/restorer/external-impls/package-hash.js +102 -0
- package/dist/restorer/external-impls/package-hash.js.map +1 -0
- package/dist/restorer/external-impls/types.d.ts +42 -0
- package/dist/restorer/external-impls/types.js +10 -0
- package/dist/restorer/external-impls/types.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/adapters/claude-code.d.ts +38 -0
- package/dist/restorer/impls/claude-code-learner/adapters/claude-code.js +200 -0
- package/dist/restorer/impls/claude-code-learner/adapters/claude-code.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/harvest.d.ts +19 -0
- package/dist/restorer/impls/claude-code-learner/harvest.js +146 -0
- package/dist/restorer/impls/claude-code-learner/harvest.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/index.d.ts +15 -0
- package/dist/restorer/impls/claude-code-learner/index.js +14 -0
- package/dist/restorer/impls/claude-code-learner/index.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/mcp-config.d.ts +48 -0
- package/dist/restorer/impls/claude-code-learner/mcp-config.js +52 -0
- package/dist/restorer/impls/claude-code-learner/mcp-config.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/plugin-path.d.ts +14 -0
- package/dist/restorer/impls/claude-code-learner/plugin-path.js +30 -0
- package/dist/restorer/impls/claude-code-learner/plugin-path.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/restorer.d.ts +38 -0
- package/dist/restorer/impls/claude-code-learner/restorer.js +73 -0
- package/dist/restorer/impls/claude-code-learner/restorer.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/fake-plugin-outputs.d.ts +19 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/fake-plugin-outputs.js +111 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/fake-plugin-outputs.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/noop-adapter.d.ts +22 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/noop-adapter.js +35 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/noop-adapter.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/synthetic-session.d.ts +20 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/synthetic-session.js +34 -0
- package/dist/restorer/impls/claude-code-learner/test-utils/synthetic-session.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/types.d.ts +99 -0
- package/dist/restorer/impls/claude-code-learner/types.js +2 -0
- package/dist/restorer/impls/claude-code-learner/types.js.map +1 -0
- package/dist/restorer/impls/claude-code-learner/wrapper.d.ts +49 -0
- package/dist/restorer/impls/claude-code-learner/wrapper.js +144 -0
- package/dist/restorer/impls/claude-code-learner/wrapper.js.map +1 -0
- package/dist/restorer/impls/claude-mcp-hyperliquid/index.d.ts +2 -2
- package/dist/restorer/impls/claude-mcp-hyperliquid/index.js +2 -2
- package/dist/restorer/impls/claude-mcp-hyperliquid/index.js.map +1 -1
- package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.d.ts +7 -0
- package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.js +38 -0
- package/dist/restorer/impls/claude-mcp-hyperliquid/session-orchestrator.js.map +1 -1
- package/dist/restorer/impls/claude-mcp-prediction/index.d.ts +2 -2
- package/dist/restorer/impls/claude-mcp-prediction/index.js +12 -2
- package/dist/restorer/impls/claude-mcp-prediction/index.js.map +1 -1
- package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.d.ts +9 -2
- package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.js +9 -125
- package/dist/restorer/impls/claude-mcp-prediction/session-orchestrator.js.map +1 -1
- package/dist/restorer/impls/claude-mcp-prediction-apy/index.d.ts +2 -2
- package/dist/restorer/impls/claude-mcp-prediction-apy/index.js +9 -2
- package/dist/restorer/impls/claude-mcp-prediction-apy/index.js.map +1 -1
- package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.d.ts +10 -0
- package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.js +10 -119
- package/dist/restorer/impls/claude-mcp-prediction-apy/session-orchestrator.js.map +1 -1
- package/dist/restorer/impls/claude-mcp-shared/single-session-orchestrator.d.ts +84 -0
- package/dist/restorer/impls/claude-mcp-shared/single-session-orchestrator.js +206 -0
- package/dist/restorer/impls/claude-mcp-shared/single-session-orchestrator.js.map +1 -0
- package/dist/restorer/impls/evaluation-context.d.ts +11 -4
- package/dist/restorer/impls/evaluation-context.js +9 -2
- package/dist/restorer/impls/evaluation-context.js.map +1 -1
- package/dist/restorer/impls/index.d.ts +46 -1
- package/dist/restorer/impls/index.js +38 -0
- package/dist/restorer/impls/index.js.map +1 -1
- package/dist/restorer/impls/legacy-claude/index.d.ts +13 -1
- package/dist/restorer/impls/legacy-claude/index.js +2 -0
- package/dist/restorer/impls/legacy-claude/index.js.map +1 -1
- package/dist/restorer/impls/portfolio-v0-evaluator/index.d.ts +4 -4
- package/dist/restorer/impls/portfolio-v0-evaluator/index.js +184 -55
- package/dist/restorer/impls/portfolio-v0-evaluator/index.js.map +1 -1
- package/dist/restorer/impls/prediction-apy-v0-baseline/index.d.ts +1 -1
- package/dist/restorer/impls/prediction-apy-v0-baseline/index.js +8 -1
- package/dist/restorer/impls/prediction-apy-v0-baseline/index.js.map +1 -1
- package/dist/restorer/impls/prediction-apy-v0-evaluator/index.d.ts +3 -3
- package/dist/restorer/impls/prediction-apy-v0-evaluator/index.js +153 -15
- package/dist/restorer/impls/prediction-apy-v0-evaluator/index.js.map +1 -1
- package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.d.ts +14 -5
- package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.js +16 -23
- package/dist/restorer/impls/prediction-apy-v0-evaluator/parse-submission.js.map +1 -1
- package/dist/restorer/impls/prediction-v0-baseline/index.d.ts +1 -1
- package/dist/restorer/impls/prediction-v0-baseline/index.js +16 -7
- package/dist/restorer/impls/prediction-v0-baseline/index.js.map +1 -1
- package/dist/restorer/impls/prediction-v0-evaluator/checks/integrity.d.ts +5 -3
- package/dist/restorer/impls/prediction-v0-evaluator/checks/integrity.js.map +1 -1
- package/dist/restorer/impls/prediction-v0-evaluator/index.d.ts +2 -2
- package/dist/restorer/impls/prediction-v0-evaluator/index.js +175 -67
- package/dist/restorer/impls/prediction-v0-evaluator/index.js.map +1 -1
- package/dist/restorer/manifest/index.d.ts +3 -0
- package/dist/restorer/manifest/index.js +3 -0
- package/dist/restorer/manifest/index.js.map +1 -0
- package/dist/restorer/manifest/load.d.ts +7 -0
- package/dist/restorer/manifest/load.js +49 -0
- package/dist/restorer/manifest/load.js.map +1 -0
- package/dist/restorer/manifest/types.d.ts +75 -0
- package/dist/restorer/manifest/types.js +8 -0
- package/dist/restorer/manifest/types.js.map +1 -0
- package/dist/restorer/manifest/verify.d.ts +15 -0
- package/dist/restorer/manifest/verify.js +53 -0
- package/dist/restorer/manifest/verify.js.map +1 -0
- package/dist/restorer/plug-ins/index.d.ts +14 -0
- package/dist/restorer/plug-ins/index.js +11 -0
- package/dist/restorer/plug-ins/index.js.map +1 -0
- package/dist/restorer/plug-ins/loader.d.ts +27 -0
- package/dist/restorer/plug-ins/loader.js +101 -0
- package/dist/restorer/plug-ins/loader.js.map +1 -0
- package/dist/restorer/plug-ins/manifest.d.ts +7 -0
- package/dist/restorer/plug-ins/manifest.js +97 -0
- package/dist/restorer/plug-ins/manifest.js.map +1 -0
- package/dist/restorer/plug-ins/registry.d.ts +24 -0
- package/dist/restorer/plug-ins/registry.js +17 -0
- package/dist/restorer/plug-ins/registry.js.map +1 -0
- package/dist/restorer/plug-ins/serialise.d.ts +29 -0
- package/dist/restorer/plug-ins/serialise.js +29 -0
- package/dist/restorer/plug-ins/serialise.js.map +1 -0
- package/dist/restorer/plug-ins/types.d.ts +77 -0
- package/dist/restorer/plug-ins/types.js +10 -0
- package/dist/restorer/plug-ins/types.js.map +1 -0
- package/dist/restorer/types.d.ts +66 -11
- package/dist/restorer/types.js.map +1 -1
- package/dist/runner/claude.d.ts +3 -3
- package/dist/runner/claude.js +57 -21
- package/dist/runner/claude.js.map +1 -1
- package/dist/runner/runner.d.ts +29 -2
- package/dist/runner/simple.d.ts +2 -2
- package/dist/runner/simple.js +2 -2
- package/dist/runner/simple.js.map +1 -1
- package/dist/scripts/fix-node-pty.mjs +62 -0
- package/dist/setup-mode.d.ts +34 -0
- package/dist/setup-mode.js +49 -0
- package/dist/setup-mode.js.map +1 -0
- package/dist/store/store.d.ts +79 -3
- package/dist/store/store.js +189 -6
- package/dist/store/store.js.map +1 -1
- package/dist/templates/plug-in/hook/README.md.tmpl +24 -0
- package/dist/templates/plug-in/hook/gitignore.tmpl +3 -0
- package/dist/templates/plug-in/hook/hooks/event.sh.tmpl +15 -0
- package/dist/templates/plug-in/hook/jinn-plugin.json.tmpl +16 -0
- package/dist/templates/plug-in/hook/package.json.tmpl +14 -0
- package/dist/templates/plug-in/hook/test/manifest.test.ts.tmpl +21 -0
- package/dist/templates/plug-in/mcp-tool/README.md.tmpl +26 -0
- package/dist/templates/plug-in/mcp-tool/gitignore.tmpl +4 -0
- package/dist/templates/plug-in/mcp-tool/jinn-plugin.json.tmpl +16 -0
- package/dist/templates/plug-in/mcp-tool/package.json.tmpl +19 -0
- package/dist/templates/plug-in/mcp-tool/src/server.ts.tmpl +17 -0
- package/dist/templates/plug-in/mcp-tool/test/server.test.ts.tmpl +18 -0
- package/dist/templates/plug-in/memory-backend/README.md.tmpl +33 -0
- package/dist/templates/plug-in/memory-backend/gitignore.tmpl +4 -0
- package/dist/templates/plug-in/memory-backend/jinn-plugin.json.tmpl +16 -0
- package/dist/templates/plug-in/memory-backend/package.json.tmpl +19 -0
- package/dist/templates/plug-in/memory-backend/src/server.ts.tmpl +23 -0
- package/dist/templates/plug-in/memory-backend/test/server.test.ts.tmpl +17 -0
- package/dist/templates/plug-in/phase-agent-override/README.md.tmpl +30 -0
- package/dist/templates/plug-in/phase-agent-override/agents/agent.md.tmpl +26 -0
- package/dist/templates/plug-in/phase-agent-override/gitignore.tmpl +3 -0
- package/dist/templates/plug-in/phase-agent-override/jinn-plugin.json.tmpl +17 -0
- package/dist/templates/plug-in/phase-agent-override/package.json.tmpl +14 -0
- package/dist/templates/plug-in/phase-agent-override/test/manifest.test.ts.tmpl +24 -0
- package/dist/templates/plug-in/skill-bundle/.claude-plugin/plugin.json.tmpl +5 -0
- package/dist/templates/plug-in/skill-bundle/README.md.tmpl +28 -0
- package/dist/templates/plug-in/skill-bundle/gitignore.tmpl +3 -0
- package/dist/templates/plug-in/skill-bundle/jinn-plugin.json.tmpl +15 -0
- package/dist/templates/plug-in/skill-bundle/package.json.tmpl +14 -0
- package/dist/templates/plug-in/skill-bundle/skills/example/SKILL.md.tmpl +14 -0
- package/dist/templates/plug-in/skill-bundle/test/manifest.test.ts.tmpl +21 -0
- package/dist/templates/plug-in/topic-explorer/README.md.tmpl +24 -0
- package/dist/templates/plug-in/topic-explorer/agents/explorer.md.tmpl +26 -0
- package/dist/templates/plug-in/topic-explorer/gitignore.tmpl +3 -0
- package/dist/templates/plug-in/topic-explorer/jinn-plugin.json.tmpl +17 -0
- package/dist/templates/plug-in/topic-explorer/package.json.tmpl +14 -0
- package/dist/templates/plug-in/topic-explorer/test/manifest.test.ts.tmpl +22 -0
- package/dist/templates/restorer/alternative-harness/README.md.tmpl +44 -0
- package/dist/templates/restorer/alternative-harness/gitignore.tmpl +3 -0
- package/dist/templates/restorer/alternative-harness/jinn.manifest.json.tmpl +22 -0
- package/dist/templates/restorer/alternative-harness/package.json.tmpl +26 -0
- package/dist/templates/restorer/alternative-harness/src/coordinator.ts.tmpl +50 -0
- package/dist/templates/restorer/alternative-harness/src/harness.ts.tmpl +31 -0
- package/dist/templates/restorer/alternative-harness/src/index.ts.tmpl +44 -0
- package/dist/templates/restorer/alternative-harness/src/mock-harness.ts.tmpl +41 -0
- package/dist/templates/restorer/alternative-harness/src/phases/debrief.ts.tmpl +28 -0
- package/dist/templates/restorer/alternative-harness/src/phases/execute.ts.tmpl +33 -0
- package/dist/templates/restorer/alternative-harness/src/phases/improve.ts.tmpl +31 -0
- package/dist/templates/restorer/alternative-harness/src/phases/memory.ts.tmpl +31 -0
- package/dist/templates/restorer/alternative-harness/src/phases/orient.ts.tmpl +21 -0
- package/dist/templates/restorer/alternative-harness/src/phases/plan.ts.tmpl +25 -0
- package/dist/templates/restorer/alternative-harness/src/phases/strategize.ts.tmpl +29 -0
- package/dist/templates/restorer/alternative-harness/test/coordinator.test.ts.tmpl +52 -0
- package/dist/templates/restorer/alternative-harness/test/unit.test.ts.tmpl +54 -0
- package/dist/templates/restorer/alternative-harness/tsconfig.json.tmpl +16 -0
- package/dist/templates/restorer/evaluator/README.md.tmpl +36 -0
- package/dist/templates/restorer/evaluator/gitignore.tmpl +3 -0
- package/dist/templates/restorer/evaluator/jinn.manifest.json.tmpl +22 -0
- package/dist/templates/restorer/evaluator/package.json.tmpl +26 -0
- package/dist/templates/restorer/evaluator/src/index.ts.tmpl +35 -0
- package/dist/templates/restorer/evaluator/test/unit.test.ts.tmpl +48 -0
- package/dist/templates/restorer/evaluator/tsconfig.json.tmpl +16 -0
- package/dist/templates/restorer/forecaster/README.md.tmpl +25 -0
- package/dist/templates/restorer/forecaster/gitignore.tmpl +5 -0
- package/dist/templates/restorer/forecaster/jinn.manifest.json.tmpl +22 -0
- package/dist/templates/restorer/forecaster/package.json.tmpl +26 -0
- package/dist/templates/restorer/forecaster/src/index.ts.tmpl +33 -0
- package/dist/templates/restorer/forecaster/test/unit.test.ts.tmpl +41 -0
- package/dist/templates/restorer/forecaster/tsconfig.json.tmpl +16 -0
- package/dist/trajectory/collector.d.ts +49 -0
- package/dist/trajectory/collector.js +86 -0
- package/dist/trajectory/collector.js.map +1 -0
- package/dist/trajectory/emit.d.ts +27 -0
- package/dist/trajectory/emit.js +40 -0
- package/dist/trajectory/emit.js.map +1 -0
- package/dist/trajectory/hash-chain.d.ts +18 -0
- package/dist/trajectory/hash-chain.js +23 -0
- package/dist/trajectory/hash-chain.js.map +1 -0
- package/dist/trajectory/index.d.ts +22 -0
- package/dist/trajectory/index.js +23 -0
- package/dist/trajectory/index.js.map +1 -0
- package/dist/trajectory/schema.d.ts +14 -14
- package/dist/trajectory/secret-scrub.d.ts +32 -0
- package/dist/trajectory/secret-scrub.js +51 -0
- package/dist/trajectory/secret-scrub.js.map +1 -0
- package/dist/trajectory/span-profile.d.ts +27 -0
- package/dist/trajectory/span-profile.js +51 -0
- package/dist/trajectory/span-profile.js.map +1 -0
- package/dist/trajectory/wrappers/http.d.ts +37 -0
- package/dist/trajectory/wrappers/http.js +85 -0
- package/dist/trajectory/wrappers/http.js.map +1 -0
- package/dist/trajectory/wrappers/mcp.d.ts +17 -0
- package/dist/trajectory/wrappers/mcp.js +58 -0
- package/dist/trajectory/wrappers/mcp.js.map +1 -0
- package/dist/trajectory/wrappers/subprocess.d.ts +32 -0
- package/dist/trajectory/wrappers/subprocess.js +70 -0
- package/dist/trajectory/wrappers/subprocess.js.map +1 -0
- package/dist/tx-retry.js +23 -9
- package/dist/tx-retry.js.map +1 -1
- package/dist/types/desired-state.d.ts +211 -21
- package/dist/types/desired-state.js +26 -15
- package/dist/types/desired-state.js.map +1 -1
- package/dist/types/envelope.d.ts +1473 -0
- package/dist/types/envelope.js +114 -0
- package/dist/types/envelope.js.map +1 -0
- package/dist/types/index.d.ts +4 -4
- package/dist/types/index.js +4 -4
- package/dist/types/index.js.map +1 -1
- package/dist/types/intent.d.ts +276 -0
- package/dist/types/intent.js +74 -0
- package/dist/types/intent.js.map +1 -0
- package/dist/types/payloads/index.d.ts +11 -0
- package/dist/types/payloads/index.js +46 -0
- package/dist/types/payloads/index.js.map +1 -0
- package/dist/types/payloads/portfolio-v0.d.ts +481 -0
- package/dist/types/payloads/portfolio-v0.js +94 -0
- package/dist/types/payloads/portfolio-v0.js.map +1 -0
- package/dist/types/payloads/prediction-apy-v0.d.ts +231 -0
- package/dist/types/payloads/prediction-apy-v0.js +63 -0
- package/dist/types/payloads/prediction-apy-v0.js.map +1 -0
- package/dist/types/payloads/prediction-v0.d.ts +262 -0
- package/dist/types/payloads/prediction-v0.js +73 -0
- package/dist/types/payloads/prediction-v0.js.map +1 -0
- package/dist/types/portfolio.d.ts +23 -685
- package/dist/types/portfolio.js +16 -106
- package/dist/types/portfolio.js.map +1 -1
- package/dist/types/prediction-apy.d.ts +9 -344
- package/dist/types/prediction-apy.js +9 -65
- package/dist/types/prediction-apy.js.map +1 -1
- package/dist/types/prediction.d.ts +25 -396
- package/dist/types/prediction.js +5 -79
- package/dist/types/prediction.js.map +1 -1
- package/dist/types/window.d.ts +12 -0
- package/dist/types/window.js +6 -0
- package/dist/types/window.js.map +1 -0
- package/dist/util/path-safety.d.ts +22 -0
- package/dist/util/path-safety.js +29 -0
- package/dist/util/path-safety.js.map +1 -0
- package/dist/util/redact-rpc-urls.d.ts +5 -0
- package/dist/util/redact-rpc-urls.js +9 -0
- package/dist/util/redact-rpc-urls.js.map +1 -0
- package/dist/x402/acquire.d.ts +14 -3
- package/dist/x402/acquire.js +28 -11
- package/dist/x402/acquire.js.map +1 -1
- package/dist/x402/handler.d.ts +15 -3
- package/dist/x402/handler.js +67 -24
- package/dist/x402/handler.js.map +1 -1
- package/package.json +36 -11
- package/plugins/claude-code-learner/.claude-plugin/plugin.json +9 -0
- package/plugins/claude-code-learner/AGENTS.md +30 -0
- package/plugins/claude-code-learner/CLAUDE.md +31 -0
- package/plugins/claude-code-learner/README.md +58 -0
- package/plugins/claude-code-learner/agents/analyst.md +69 -0
- package/plugins/claude-code-learner/agents/consolidator.md +95 -0
- package/plugins/claude-code-learner/agents/explorer.md +54 -0
- package/plugins/claude-code-learner/agents/planner.md +88 -0
- package/plugins/claude-code-learner/agents/promoter.md +114 -0
- package/plugins/claude-code-learner/agents/step-worker.md +48 -0
- package/plugins/claude-code-learner/agents/strategist.md +86 -0
- package/plugins/claude-code-learner/hooks/hooks.json +16 -0
- package/plugins/claude-code-learner/hooks/session-start +49 -0
- package/plugins/claude-code-learner/skills/coordinator/SKILL.md +131 -0
- package/plugins/claude-code-learner/skills/debrief/SKILL.md +71 -0
- package/plugins/claude-code-learner/skills/execute/SKILL.md +91 -0
- package/plugins/claude-code-learner/skills/improve/SKILL.md +57 -0
- package/plugins/claude-code-learner/skills/memory-consolidation/SKILL.md +57 -0
- package/plugins/claude-code-learner/skills/orient/SKILL.md +82 -0
- package/plugins/claude-code-learner/skills/plan/SKILL.md +54 -0
- package/plugins/claude-code-learner/skills/strategize/SKILL.md +63 -0
- package/skills/jinn-operator/SKILL.md +84 -35
- package/templates/plug-in/hook/README.md.tmpl +24 -0
- package/templates/plug-in/hook/gitignore.tmpl +3 -0
- package/templates/plug-in/hook/hooks/event.sh.tmpl +15 -0
- package/templates/plug-in/hook/jinn-plugin.json.tmpl +16 -0
- package/templates/plug-in/hook/package.json.tmpl +14 -0
- package/templates/plug-in/hook/test/manifest.test.ts.tmpl +21 -0
- package/templates/plug-in/mcp-tool/README.md.tmpl +26 -0
- package/templates/plug-in/mcp-tool/gitignore.tmpl +4 -0
- package/templates/plug-in/mcp-tool/jinn-plugin.json.tmpl +16 -0
- package/templates/plug-in/mcp-tool/package.json.tmpl +19 -0
- package/templates/plug-in/mcp-tool/src/server.ts.tmpl +17 -0
- package/templates/plug-in/mcp-tool/test/server.test.ts.tmpl +18 -0
- package/templates/plug-in/memory-backend/README.md.tmpl +33 -0
- package/templates/plug-in/memory-backend/gitignore.tmpl +4 -0
- package/templates/plug-in/memory-backend/jinn-plugin.json.tmpl +16 -0
- package/templates/plug-in/memory-backend/package.json.tmpl +19 -0
- package/templates/plug-in/memory-backend/src/server.ts.tmpl +23 -0
- package/templates/plug-in/memory-backend/test/server.test.ts.tmpl +17 -0
- package/templates/plug-in/phase-agent-override/README.md.tmpl +30 -0
- package/templates/plug-in/phase-agent-override/agents/agent.md.tmpl +26 -0
- package/templates/plug-in/phase-agent-override/gitignore.tmpl +3 -0
- package/templates/plug-in/phase-agent-override/jinn-plugin.json.tmpl +17 -0
- package/templates/plug-in/phase-agent-override/package.json.tmpl +14 -0
- package/templates/plug-in/phase-agent-override/test/manifest.test.ts.tmpl +24 -0
- package/templates/plug-in/skill-bundle/.claude-plugin/plugin.json.tmpl +5 -0
- package/templates/plug-in/skill-bundle/README.md.tmpl +28 -0
- package/templates/plug-in/skill-bundle/gitignore.tmpl +3 -0
- package/templates/plug-in/skill-bundle/jinn-plugin.json.tmpl +15 -0
- package/templates/plug-in/skill-bundle/package.json.tmpl +14 -0
- package/templates/plug-in/skill-bundle/skills/example/SKILL.md.tmpl +14 -0
- package/templates/plug-in/skill-bundle/test/manifest.test.ts.tmpl +21 -0
- package/templates/plug-in/topic-explorer/README.md.tmpl +24 -0
- package/templates/plug-in/topic-explorer/agents/explorer.md.tmpl +26 -0
- package/templates/plug-in/topic-explorer/gitignore.tmpl +3 -0
- package/templates/plug-in/topic-explorer/jinn-plugin.json.tmpl +17 -0
- package/templates/plug-in/topic-explorer/package.json.tmpl +14 -0
- package/templates/plug-in/topic-explorer/test/manifest.test.ts.tmpl +22 -0
- package/templates/restorer/alternative-harness/README.md.tmpl +44 -0
- package/templates/restorer/alternative-harness/gitignore.tmpl +3 -0
- package/templates/restorer/alternative-harness/jinn.manifest.json.tmpl +22 -0
- package/templates/restorer/alternative-harness/package.json.tmpl +26 -0
- package/templates/restorer/alternative-harness/src/coordinator.ts.tmpl +50 -0
- package/templates/restorer/alternative-harness/src/harness.ts.tmpl +31 -0
- package/templates/restorer/alternative-harness/src/index.ts.tmpl +44 -0
- package/templates/restorer/alternative-harness/src/mock-harness.ts.tmpl +41 -0
- package/templates/restorer/alternative-harness/src/phases/debrief.ts.tmpl +28 -0
- package/templates/restorer/alternative-harness/src/phases/execute.ts.tmpl +33 -0
- package/templates/restorer/alternative-harness/src/phases/improve.ts.tmpl +31 -0
- package/templates/restorer/alternative-harness/src/phases/memory.ts.tmpl +31 -0
- package/templates/restorer/alternative-harness/src/phases/orient.ts.tmpl +21 -0
- package/templates/restorer/alternative-harness/src/phases/plan.ts.tmpl +25 -0
- package/templates/restorer/alternative-harness/src/phases/strategize.ts.tmpl +29 -0
- package/templates/restorer/alternative-harness/test/coordinator.test.ts.tmpl +52 -0
- package/templates/restorer/alternative-harness/test/unit.test.ts.tmpl +54 -0
- package/templates/restorer/alternative-harness/tsconfig.json.tmpl +16 -0
- package/templates/restorer/evaluator/README.md.tmpl +36 -0
- package/templates/restorer/evaluator/gitignore.tmpl +3 -0
- package/templates/restorer/evaluator/jinn.manifest.json.tmpl +22 -0
- package/templates/restorer/evaluator/package.json.tmpl +26 -0
- package/templates/restorer/evaluator/src/index.ts.tmpl +35 -0
- package/templates/restorer/evaluator/test/unit.test.ts.tmpl +48 -0
- package/templates/restorer/evaluator/tsconfig.json.tmpl +16 -0
- package/templates/restorer/forecaster/README.md.tmpl +25 -0
- package/templates/restorer/forecaster/gitignore.tmpl +5 -0
- package/templates/restorer/forecaster/jinn.manifest.json.tmpl +22 -0
- package/templates/restorer/forecaster/package.json.tmpl +26 -0
- package/templates/restorer/forecaster/src/index.ts.tmpl +33 -0
- package/templates/restorer/forecaster/test/unit.test.ts.tmpl +41 -0
- package/templates/restorer/forecaster/tsconfig.json.tmpl +16 -0
- package/dist/bin/jinn-mcp.d.ts +0 -2
- package/dist/bin/jinn-mcp.js +0 -10
- package/dist/bin/jinn-mcp.js.map +0 -1
- package/dist/cli/commands/quickstart.js +0 -330
- package/dist/cli/commands/quickstart.js.map +0 -1
- package/dist/discovery/registry.d.ts +0 -97
- package/dist/discovery/registry.js +0 -177
- package/dist/discovery/registry.js.map +0 -1
- package/dist/discovery/subgraph.d.ts +0 -37
- package/dist/discovery/subgraph.js +0 -87
- package/dist/discovery/subgraph.js.map +0 -1
- package/dist/restorer/engine/manifest-assembly.d.ts +0 -67
- package/dist/restorer/engine/manifest-assembly.js +0 -79
- package/dist/restorer/engine/manifest-assembly.js.map +0 -1
- /package/dist/cli/commands/{quickstart.d.ts → ui.d.ts} +0 -0
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Per-artifact resolution chain: cache → self-store → routeResolver → origin.
|
|
3
|
+
*
|
|
4
|
+
* Always hash-verifies before persisting to cache.
|
|
5
|
+
*
|
|
6
|
+
* Spec §2.3 step 4-6.
|
|
7
|
+
*/
|
|
8
|
+
import { createHash } from 'node:crypto';
|
|
9
|
+
import { acquireArtifactWithPayment } from '../x402/acquire.js';
|
|
10
|
+
import { AcquireError, HashMismatchError } from './types.js';
|
|
11
|
+
function sha256Hex(buf) {
|
|
12
|
+
return createHash('sha256').update(buf).digest('hex');
|
|
13
|
+
}
|
|
14
|
+
export async function acquireArtifactContent(args) {
|
|
15
|
+
const { sha256, artifactType, access, store, selfSafeAddress, privateKey, routeResolver, envelopeCid, ownerSafe, acquireFn = acquireArtifactWithPayment, } = args;
|
|
16
|
+
const now = () => new Date().toISOString();
|
|
17
|
+
// 1. Cache hit
|
|
18
|
+
const cached = store.getNetworkArtifact(sha256);
|
|
19
|
+
if (cached) {
|
|
20
|
+
store.touchNetworkArtifactUsage(sha256, now());
|
|
21
|
+
return {
|
|
22
|
+
sha256,
|
|
23
|
+
bytes: cached.content,
|
|
24
|
+
artifactType: cached.artifactType,
|
|
25
|
+
source: 'cache',
|
|
26
|
+
paidAmountUsdc: '0',
|
|
27
|
+
fetchedAt: cached.fetchedAt,
|
|
28
|
+
sourceOperator: cached.sourceOperator ?? undefined,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
// 2. Self-store fast path
|
|
32
|
+
if (ownerSafe && ownerSafe.toLowerCase() === selfSafeAddress.toLowerCase()) {
|
|
33
|
+
const own = store.getServedArtifact(sha256);
|
|
34
|
+
if (own) {
|
|
35
|
+
// Re-verify before mirroring. If served_artifacts has been corrupted
|
|
36
|
+
// (disk error, manual edit, future migration bug, etc.) we must NOT
|
|
37
|
+
// propagate the bad bytes into network_artifacts where peers can
|
|
38
|
+
// fetch them via x402. Throwing closes the cache-poisoning gap; the
|
|
39
|
+
// self-store path is now hash-equivalent to origin / route-resolver.
|
|
40
|
+
const actualSha = sha256Hex(own.content);
|
|
41
|
+
if (actualSha !== sha256) {
|
|
42
|
+
throw new HashMismatchError(sha256, actualSha, 'self-store', selfSafeAddress);
|
|
43
|
+
}
|
|
44
|
+
// Mirror into cache so peer asks for the same content can hit cache (provenance: self-store-mirror).
|
|
45
|
+
const ts = now();
|
|
46
|
+
store.saveNetworkArtifact({
|
|
47
|
+
sha256,
|
|
48
|
+
artifactType: own.artifactType,
|
|
49
|
+
envelopeCid: own.envelopeCid,
|
|
50
|
+
content: own.content,
|
|
51
|
+
source: 'self-store-mirror',
|
|
52
|
+
paidAmountUsdc: '0',
|
|
53
|
+
fetchedAt: ts,
|
|
54
|
+
});
|
|
55
|
+
return {
|
|
56
|
+
sha256,
|
|
57
|
+
bytes: own.content,
|
|
58
|
+
artifactType: own.artifactType,
|
|
59
|
+
source: 'self-store',
|
|
60
|
+
paidAmountUsdc: '0',
|
|
61
|
+
fetchedAt: ts,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
// 3. Route resolver
|
|
66
|
+
if (routeResolver) {
|
|
67
|
+
try {
|
|
68
|
+
const out = await routeResolver.resolve({ sha256, access, requesterSafe: selfSafeAddress });
|
|
69
|
+
if (out) {
|
|
70
|
+
const actualSha = sha256Hex(out.bytes);
|
|
71
|
+
if (actualSha !== sha256) {
|
|
72
|
+
throw new HashMismatchError(sha256, actualSha, 'route-resolver', out.sourceOperator);
|
|
73
|
+
}
|
|
74
|
+
const ts = now();
|
|
75
|
+
store.saveNetworkArtifact({
|
|
76
|
+
sha256,
|
|
77
|
+
artifactType,
|
|
78
|
+
envelopeCid: envelopeCid ?? null,
|
|
79
|
+
content: out.bytes,
|
|
80
|
+
source: 'route-resolver',
|
|
81
|
+
sourceOperator: out.sourceOperator ?? null,
|
|
82
|
+
paidAmountUsdc: out.pricePaidUsdc,
|
|
83
|
+
fetchedAt: ts,
|
|
84
|
+
});
|
|
85
|
+
return {
|
|
86
|
+
sha256,
|
|
87
|
+
bytes: out.bytes,
|
|
88
|
+
artifactType,
|
|
89
|
+
source: 'route-resolver',
|
|
90
|
+
paidAmountUsdc: out.pricePaidUsdc,
|
|
91
|
+
fetchedAt: ts,
|
|
92
|
+
sourceOperator: out.sourceOperator,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
catch (err) {
|
|
97
|
+
if (err instanceof HashMismatchError)
|
|
98
|
+
throw err;
|
|
99
|
+
throw new AcquireError(sha256, 'routeResolver failed', err);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
// 4. Origin fetch
|
|
103
|
+
let bytes;
|
|
104
|
+
try {
|
|
105
|
+
const raw = await acquireFn(access.endpoint, sha256, privateKey);
|
|
106
|
+
// Accept both the legacy `Buffer | null` shape and the new discriminated
|
|
107
|
+
// union from acquireArtifactWithPayment. Buffer.isBuffer guards before
|
|
108
|
+
// we duck-type into the union.
|
|
109
|
+
if (raw === null || Buffer.isBuffer(raw)) {
|
|
110
|
+
bytes = raw;
|
|
111
|
+
}
|
|
112
|
+
else if (raw.ok === true) {
|
|
113
|
+
bytes = raw.content;
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
// ok: false — preserve the reason so the caller / daemon route can
|
|
117
|
+
// surface it via AcquireError.cause.
|
|
118
|
+
throw new AcquireError(sha256, `origin fetch failed: ${raw.reason}${raw.message ? ` (${raw.message})` : ''}`, raw);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
catch (err) {
|
|
122
|
+
if (err instanceof AcquireError)
|
|
123
|
+
throw err;
|
|
124
|
+
throw new AcquireError(sha256, 'origin fetch failed', err);
|
|
125
|
+
}
|
|
126
|
+
if (!bytes) {
|
|
127
|
+
throw new AcquireError(sha256, 'origin returned null (404 / payment failed)');
|
|
128
|
+
}
|
|
129
|
+
const actualSha = sha256Hex(bytes);
|
|
130
|
+
if (actualSha !== sha256) {
|
|
131
|
+
throw new HashMismatchError(sha256, actualSha, 'origin', ownerSafe);
|
|
132
|
+
}
|
|
133
|
+
const ts = now();
|
|
134
|
+
store.saveNetworkArtifact({
|
|
135
|
+
sha256,
|
|
136
|
+
artifactType,
|
|
137
|
+
envelopeCid: envelopeCid ?? null,
|
|
138
|
+
content: bytes,
|
|
139
|
+
source: 'origin',
|
|
140
|
+
sourceOperator: ownerSafe ?? null,
|
|
141
|
+
sourceEndpoint: access.endpoint,
|
|
142
|
+
paidAmountUsdc: access.priceUsdc,
|
|
143
|
+
fetchedAt: ts,
|
|
144
|
+
});
|
|
145
|
+
return {
|
|
146
|
+
sha256,
|
|
147
|
+
bytes,
|
|
148
|
+
artifactType,
|
|
149
|
+
source: 'origin',
|
|
150
|
+
paidAmountUsdc: access.priceUsdc,
|
|
151
|
+
fetchedAt: ts,
|
|
152
|
+
sourceOperator: ownerSafe,
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
//# sourceMappingURL=acquire.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acquire.js","sourceRoot":"","sources":["../../src/corpus/acquire.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Corpus cache helpers.
|
|
3
|
+
*
|
|
4
|
+
* The corpus library reuses the existing `network_artifacts` and `served_artifacts`
|
|
5
|
+
* tables on the daemon's `Store`. There is no separate corpus cache layer — the
|
|
6
|
+
* acquire chain in `acquire.ts` is the only writer/reader. This module exposes
|
|
7
|
+
* thin convenience helpers for higher-level code that wants to inspect or
|
|
8
|
+
* pre-populate the cache without going through `acquireArtifactContent`.
|
|
9
|
+
*
|
|
10
|
+
* Spec: spec/2026-04-30-phase-a-umbrella.md §2.4 (caching semantics).
|
|
11
|
+
*/
|
|
12
|
+
import type { Store, NetworkArtifactRow } from '../store/store.js';
|
|
13
|
+
export declare function getCachedArtifact(store: Store, sha256: string): NetworkArtifactRow | null;
|
|
14
|
+
export declare function hasCachedArtifact(store: Store, sha256: string): boolean;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Corpus cache helpers.
|
|
3
|
+
*
|
|
4
|
+
* The corpus library reuses the existing `network_artifacts` and `served_artifacts`
|
|
5
|
+
* tables on the daemon's `Store`. There is no separate corpus cache layer — the
|
|
6
|
+
* acquire chain in `acquire.ts` is the only writer/reader. This module exposes
|
|
7
|
+
* thin convenience helpers for higher-level code that wants to inspect or
|
|
8
|
+
* pre-populate the cache without going through `acquireArtifactContent`.
|
|
9
|
+
*
|
|
10
|
+
* Spec: spec/2026-04-30-phase-a-umbrella.md §2.4 (caching semantics).
|
|
11
|
+
*/
|
|
12
|
+
export function getCachedArtifact(store, sha256) {
|
|
13
|
+
return store.getNetworkArtifact(sha256);
|
|
14
|
+
}
|
|
15
|
+
export function hasCachedArtifact(store, sha256) {
|
|
16
|
+
return store.getNetworkArtifact(sha256) !== null;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=cache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/corpus/cache.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAIH,MAAM,UAAU,iBAAiB,CAAC,KAAY,EAAE,MAAc;IAC5D,OAAO,KAAK,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,KAAY,EAAE,MAAc;IAC5D,OAAO,KAAK,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC;AACnD,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Fetch a manifest envelope from IPFS by CID and parse it under the v1 schema.
|
|
3
|
+
*
|
|
4
|
+
* Spec §2.3 step 2.
|
|
5
|
+
*/
|
|
6
|
+
import type { EnvelopeRef, ManifestPreview } from './types.js';
|
|
7
|
+
type FetchFromIpfs = (gatewayUrl: string, cid: string) => Promise<unknown>;
|
|
8
|
+
export declare function fetchManifest(ref: EnvelopeRef, ipfsGatewayUrl: string, fetchImpl?: FetchFromIpfs): Promise<ManifestPreview>;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Fetch a manifest envelope from IPFS by CID and parse it under the v1 schema.
|
|
3
|
+
*
|
|
4
|
+
* Spec §2.3 step 2.
|
|
5
|
+
*/
|
|
6
|
+
import { SignedEnvelopeSchema } from '../types/envelope.js';
|
|
7
|
+
import { fetchFromIpfs } from '../adapters/mech/ipfs.js';
|
|
8
|
+
import { ManifestFetchError } from './types.js';
|
|
9
|
+
export async function fetchManifest(ref, ipfsGatewayUrl, fetchImpl = fetchFromIpfs) {
|
|
10
|
+
let raw;
|
|
11
|
+
try {
|
|
12
|
+
raw = await fetchImpl(ipfsGatewayUrl, ref.manifestCid);
|
|
13
|
+
}
|
|
14
|
+
catch (err) {
|
|
15
|
+
throw new ManifestFetchError(ref.manifestCid, 'IPFS fetch failed', err);
|
|
16
|
+
}
|
|
17
|
+
const parsed = SignedEnvelopeSchema.safeParse(raw);
|
|
18
|
+
if (!parsed.success) {
|
|
19
|
+
throw new ManifestFetchError(ref.manifestCid, `schema parse failed: ${parsed.error.issues.map((i) => `${i.path.join('.')}: ${i.message}`).join('; ')}`);
|
|
20
|
+
}
|
|
21
|
+
const envelope = parsed.data;
|
|
22
|
+
return { ref, envelope };
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=fetch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch.js","sourceRoot":"","sources":["../../src/corpus/fetch.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,oBAAoB,EAAuB,MAAM,sBAAsB,CAAC;AACjF,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAIhD,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,GAAgB,EAChB,cAAsB,EACtB,YAA2B,aAAa;IAExC,IAAI,GAAY,CAAC;IACjB,IAAI,CAAC;QACH,GAAG,GAAG,MAAM,SAAS,CAAC,cAAc,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC;IACzD,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,IAAI,kBAAkB,CAAC,GAAG,CAAC,WAAW,EAAE,mBAAmB,EAAE,GAAG,CAAC,CAAC;IAC1E,CAAC;IACD,MAAM,MAAM,GAAG,oBAAoB,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IACnD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QACpB,MAAM,IAAI,kBAAkB,CAC1B,GAAG,CAAC,WAAW,EACf,wBAAwB,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACzG,CAAC;IACJ,CAAC;IACD,MAAM,QAAQ,GAAmB,MAAM,CAAC,IAAI,CAAC;IAC7C,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC;AAC3B,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Corpus library entry point.
|
|
3
|
+
*
|
|
4
|
+
* Spec: spec/2026-04-30-phase-a-umbrella.md §2.
|
|
5
|
+
*/
|
|
6
|
+
import type { Corpus, CorpusOptions } from './types.js';
|
|
7
|
+
export type { Corpus, CorpusOptions, CorpusQuery, EnvelopeRef, ManifestPreview, Envelope, ArtifactContent, ReadArgs, RouteResolver, } from './types.js';
|
|
8
|
+
export { CorpusQueryError, ManifestFetchError, AcquireError, HashMismatchError } from './types.js';
|
|
9
|
+
export { noopRouteResolver } from './route-resolver.js';
|
|
10
|
+
export { getCachedArtifact, hasCachedArtifact } from './cache.js';
|
|
11
|
+
interface InternalDeps {
|
|
12
|
+
fetch?: typeof globalThis.fetch;
|
|
13
|
+
fetchFromIpfs?: (gatewayUrl: string, cid: string) => Promise<unknown>;
|
|
14
|
+
acquireFn?: (endpoint: string, sha256: string, privateKey: string) => Promise<Buffer | null>;
|
|
15
|
+
}
|
|
16
|
+
export declare function createCorpus(opts: CorpusOptions, deps?: InternalDeps): Corpus;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Corpus library entry point.
|
|
3
|
+
*
|
|
4
|
+
* Spec: spec/2026-04-30-phase-a-umbrella.md §2.
|
|
5
|
+
*/
|
|
6
|
+
import { runCorpusQuery } from './query.js';
|
|
7
|
+
import { fetchManifest } from './fetch.js';
|
|
8
|
+
import { acquireArtifactContent } from './acquire.js';
|
|
9
|
+
export { CorpusQueryError, ManifestFetchError, AcquireError, HashMismatchError } from './types.js';
|
|
10
|
+
export { noopRouteResolver } from './route-resolver.js';
|
|
11
|
+
export { getCachedArtifact, hasCachedArtifact } from './cache.js';
|
|
12
|
+
export function createCorpus(opts, deps = {}) {
|
|
13
|
+
const fetchImpl = deps.fetch ?? globalThis.fetch;
|
|
14
|
+
const fetchFromIpfsImpl = deps.fetchFromIpfs;
|
|
15
|
+
const acquireFn = deps.acquireFn;
|
|
16
|
+
async function query(q) {
|
|
17
|
+
return runCorpusQuery(opts.subgraphUrl, q, fetchImpl);
|
|
18
|
+
}
|
|
19
|
+
async function fetchOne(ref) {
|
|
20
|
+
return fetchManifest(ref, opts.ipfsGatewayUrl, fetchFromIpfsImpl);
|
|
21
|
+
}
|
|
22
|
+
async function acquire(manifest) {
|
|
23
|
+
const contents = new Map();
|
|
24
|
+
for (const a of manifest.envelope.artifacts) {
|
|
25
|
+
const ac = await acquireArtifactContent({
|
|
26
|
+
sha256: a.sha256,
|
|
27
|
+
artifactType: a.artifactType,
|
|
28
|
+
access: a.access,
|
|
29
|
+
store: opts.store,
|
|
30
|
+
selfSafeAddress: opts.selfSafeAddress,
|
|
31
|
+
privateKey: opts.signer.privateKey,
|
|
32
|
+
routeResolver: opts.routeResolver,
|
|
33
|
+
envelopeCid: manifest.ref.manifestCid,
|
|
34
|
+
ownerSafe: manifest.envelope.participant.safeAddress,
|
|
35
|
+
acquireFn,
|
|
36
|
+
});
|
|
37
|
+
contents.set(a.sha256, ac);
|
|
38
|
+
}
|
|
39
|
+
return { ref: manifest.ref, envelope: manifest.envelope, artifactContents: contents };
|
|
40
|
+
}
|
|
41
|
+
async function acquireBySha256(sha256, access, hint) {
|
|
42
|
+
return acquireArtifactContent({
|
|
43
|
+
sha256,
|
|
44
|
+
artifactType: hint?.artifactType ?? 'unknown',
|
|
45
|
+
access,
|
|
46
|
+
store: opts.store,
|
|
47
|
+
selfSafeAddress: opts.selfSafeAddress,
|
|
48
|
+
privateKey: opts.signer.privateKey,
|
|
49
|
+
routeResolver: opts.routeResolver,
|
|
50
|
+
envelopeCid: hint?.envelopeCid,
|
|
51
|
+
acquireFn,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
async function read(args) {
|
|
55
|
+
const refs = await query(args.query);
|
|
56
|
+
const previews = [];
|
|
57
|
+
for (const ref of refs) {
|
|
58
|
+
previews.push(await fetchOne(ref));
|
|
59
|
+
}
|
|
60
|
+
// Post-fetch kind filter (subgraph index doesn't expose intent kind; spec §10 Q6).
|
|
61
|
+
const kindFilter = args.query.kind;
|
|
62
|
+
const kindFiltered = kindFilter ? previews.filter((p) => p.envelope.kind === kindFilter) : previews;
|
|
63
|
+
const selected = args.select ? args.select(kindFiltered) : kindFiltered;
|
|
64
|
+
const envelopes = [];
|
|
65
|
+
for (const sel of selected) {
|
|
66
|
+
envelopes.push(await acquire(sel));
|
|
67
|
+
}
|
|
68
|
+
return envelopes;
|
|
69
|
+
}
|
|
70
|
+
return {
|
|
71
|
+
read,
|
|
72
|
+
query,
|
|
73
|
+
fetchManifest: fetchOne,
|
|
74
|
+
acquire,
|
|
75
|
+
acquireBySha256,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/corpus/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Subgraph GraphQL query for the corpus.
|
|
3
|
+
*
|
|
4
|
+
* v0: query Execution rows; filter by evidenceTier, participant, time window
|
|
5
|
+
* directly on the subgraph; filter by `kind` (intent kind) post-fetch since the
|
|
6
|
+
* subgraph's Execution.kind is the router-level ENVELOPE/EVALUATION discriminator,
|
|
7
|
+
* not the per-intent-kind string.
|
|
8
|
+
*
|
|
9
|
+
* Spec §2.3 step 1, §10 Q6.
|
|
10
|
+
*/
|
|
11
|
+
import type { CorpusQuery, EnvelopeRef } from './types.js';
|
|
12
|
+
export interface BuiltQuery {
|
|
13
|
+
query: string;
|
|
14
|
+
variables: Record<string, unknown>;
|
|
15
|
+
}
|
|
16
|
+
export declare function buildSubgraphQuery(q: CorpusQuery): BuiltQuery;
|
|
17
|
+
export declare function runCorpusQuery(subgraphUrl: string, q: CorpusQuery, fetchImpl?: typeof globalThis.fetch): Promise<EnvelopeRef[]>;
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Subgraph GraphQL query for the corpus.
|
|
3
|
+
*
|
|
4
|
+
* v0: query Execution rows; filter by evidenceTier, participant, time window
|
|
5
|
+
* directly on the subgraph; filter by `kind` (intent kind) post-fetch since the
|
|
6
|
+
* subgraph's Execution.kind is the router-level ENVELOPE/EVALUATION discriminator,
|
|
7
|
+
* not the per-intent-kind string.
|
|
8
|
+
*
|
|
9
|
+
* Spec §2.3 step 1, §10 Q6.
|
|
10
|
+
*/
|
|
11
|
+
import { CorpusQueryError } from './types.js';
|
|
12
|
+
const HARD_LIMIT = 500;
|
|
13
|
+
const DEFAULT_LIMIT = 50;
|
|
14
|
+
const QUERY_GQL = `
|
|
15
|
+
query CorpusExecutions(
|
|
16
|
+
$first: Int!,
|
|
17
|
+
$tier: ExecutionTier,
|
|
18
|
+
$publishedAfter: BigInt,
|
|
19
|
+
$publishedBefore: BigInt,
|
|
20
|
+
$operatorWallet: Bytes,
|
|
21
|
+
) {
|
|
22
|
+
executions(
|
|
23
|
+
first: $first,
|
|
24
|
+
where: {
|
|
25
|
+
tier: $tier,
|
|
26
|
+
publishedAt_gte: $publishedAfter,
|
|
27
|
+
publishedAt_lte: $publishedBefore,
|
|
28
|
+
operator_: { agentWallet: $operatorWallet },
|
|
29
|
+
},
|
|
30
|
+
orderBy: publishedAt,
|
|
31
|
+
orderDirection: desc,
|
|
32
|
+
) {
|
|
33
|
+
id
|
|
34
|
+
manifestCid
|
|
35
|
+
manifestHash
|
|
36
|
+
tier
|
|
37
|
+
publishedAt
|
|
38
|
+
operator {
|
|
39
|
+
id
|
|
40
|
+
agentId
|
|
41
|
+
owner
|
|
42
|
+
agentWallet
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
`;
|
|
47
|
+
const TIER_TO_GQL = {
|
|
48
|
+
'self-signed': 'SELF_SIGNED',
|
|
49
|
+
'committed': 'COMMITTED',
|
|
50
|
+
'attested': 'ATTESTED',
|
|
51
|
+
};
|
|
52
|
+
const TIER_FROM_GQL = {
|
|
53
|
+
SELF_SIGNED: 'self-signed',
|
|
54
|
+
COMMITTED: 'committed',
|
|
55
|
+
ATTESTED: 'attested',
|
|
56
|
+
UNKNOWN: 'unknown',
|
|
57
|
+
};
|
|
58
|
+
export function buildSubgraphQuery(q) {
|
|
59
|
+
const first = Math.min(Math.max(1, q.limit ?? DEFAULT_LIMIT), HARD_LIMIT);
|
|
60
|
+
const variables = {
|
|
61
|
+
first,
|
|
62
|
+
tier: q.evidenceTier ? TIER_TO_GQL[q.evidenceTier] : null,
|
|
63
|
+
publishedAfter: q.generatedAfter !== undefined ? String(q.generatedAfter) : null,
|
|
64
|
+
publishedBefore: q.generatedBefore !== undefined ? String(q.generatedBefore) : null,
|
|
65
|
+
operatorWallet: q.participant?.safeAddress ?? null,
|
|
66
|
+
kind: null, // post-fetch filter; spec §10 Q6.
|
|
67
|
+
};
|
|
68
|
+
return { query: QUERY_GQL, variables };
|
|
69
|
+
}
|
|
70
|
+
export async function runCorpusQuery(subgraphUrl, q, fetchImpl = globalThis.fetch) {
|
|
71
|
+
const built = buildSubgraphQuery(q);
|
|
72
|
+
let response;
|
|
73
|
+
try {
|
|
74
|
+
response = await fetchImpl(subgraphUrl, {
|
|
75
|
+
method: 'POST',
|
|
76
|
+
headers: { 'content-type': 'application/json' },
|
|
77
|
+
body: JSON.stringify(built),
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
throw new CorpusQueryError(`subgraph fetch failed`, err);
|
|
82
|
+
}
|
|
83
|
+
if (!response.ok) {
|
|
84
|
+
throw new CorpusQueryError(`subgraph HTTP ${response.status}`);
|
|
85
|
+
}
|
|
86
|
+
let body;
|
|
87
|
+
try {
|
|
88
|
+
body = (await response.json());
|
|
89
|
+
}
|
|
90
|
+
catch (err) {
|
|
91
|
+
throw new CorpusQueryError(`subgraph returned non-JSON body`, err);
|
|
92
|
+
}
|
|
93
|
+
if (body.errors && body.errors.length > 0) {
|
|
94
|
+
throw new CorpusQueryError(`subgraph errors: ${body.errors.map((e) => e.message).join('; ')}`);
|
|
95
|
+
}
|
|
96
|
+
const rows = body.data?.executions ?? [];
|
|
97
|
+
return rows.map((r) => ({
|
|
98
|
+
manifestCid: r.manifestCid,
|
|
99
|
+
manifestHash: r.manifestHash,
|
|
100
|
+
operator: {
|
|
101
|
+
agentId: r.operator.agentId,
|
|
102
|
+
safeAddress: r.operator.agentWallet ?? r.operator.owner,
|
|
103
|
+
},
|
|
104
|
+
evidenceTier: TIER_FROM_GQL[r.tier] ?? 'unknown',
|
|
105
|
+
publishedAt: Number(r.publishedAt),
|
|
106
|
+
}));
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../src/corpus/query.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Default RouteResolver — uses the artifact's own access.endpoint directly.
|
|
3
|
+
*
|
|
4
|
+
* Phase A.1 doesn't ship a centralized resolver: every artifact descriptor in
|
|
5
|
+
* the manifest envelope already carries its own `access.endpoint` and
|
|
6
|
+
* `access.priceUsdc`. The default resolver simply returns null so the acquire
|
|
7
|
+
* chain falls through to the origin x402 fetch using those fields.
|
|
8
|
+
*
|
|
9
|
+
* Future phases may introduce a real resolver (e.g. multi-mirror selection,
|
|
10
|
+
* DHT lookup, peer routing) by implementing the `RouteResolver` interface from
|
|
11
|
+
* `./types.js`.
|
|
12
|
+
*
|
|
13
|
+
* Spec: spec/2026-04-30-phase-a-umbrella.md §2.5.
|
|
14
|
+
*/
|
|
15
|
+
import type { RouteResolver } from './types.js';
|
|
16
|
+
export declare const noopRouteResolver: RouteResolver;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Default RouteResolver — uses the artifact's own access.endpoint directly.
|
|
3
|
+
*
|
|
4
|
+
* Phase A.1 doesn't ship a centralized resolver: every artifact descriptor in
|
|
5
|
+
* the manifest envelope already carries its own `access.endpoint` and
|
|
6
|
+
* `access.priceUsdc`. The default resolver simply returns null so the acquire
|
|
7
|
+
* chain falls through to the origin x402 fetch using those fields.
|
|
8
|
+
*
|
|
9
|
+
* Future phases may introduce a real resolver (e.g. multi-mirror selection,
|
|
10
|
+
* DHT lookup, peer routing) by implementing the `RouteResolver` interface from
|
|
11
|
+
* `./types.js`.
|
|
12
|
+
*
|
|
13
|
+
* Spec: spec/2026-04-30-phase-a-umbrella.md §2.5.
|
|
14
|
+
*/
|
|
15
|
+
export const noopRouteResolver = {
|
|
16
|
+
async resolve() {
|
|
17
|
+
return null;
|
|
18
|
+
},
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=route-resolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route-resolver.js","sourceRoot":"","sources":["../../src/corpus/route-resolver.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAIH,MAAM,CAAC,MAAM,iBAAiB,GAAkB;IAC9C,KAAK,CAAC,OAAO;QACX,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Public types for the corpus library.
|
|
3
|
+
*
|
|
4
|
+
* See spec/2026-04-30-phase-a-umbrella.md §2.2 for the rationale and the
|
|
5
|
+
* narrative description of the read pipeline.
|
|
6
|
+
*/
|
|
7
|
+
import type { Store } from '../store/store.js';
|
|
8
|
+
import type { SignedEnvelope } from '../types/envelope.js';
|
|
9
|
+
export interface CorpusOptions {
|
|
10
|
+
subgraphUrl: string;
|
|
11
|
+
ipfsGatewayUrl: string;
|
|
12
|
+
store: Store;
|
|
13
|
+
signer: {
|
|
14
|
+
privateKey: string;
|
|
15
|
+
};
|
|
16
|
+
selfSafeAddress: string;
|
|
17
|
+
routeResolver?: RouteResolver;
|
|
18
|
+
}
|
|
19
|
+
export interface CorpusQuery {
|
|
20
|
+
kind?: string;
|
|
21
|
+
intentCid?: string;
|
|
22
|
+
participant?: {
|
|
23
|
+
safeAddress?: string;
|
|
24
|
+
};
|
|
25
|
+
evidenceTier?: 'self-signed' | 'committed' | 'attested';
|
|
26
|
+
generatedAfter?: number;
|
|
27
|
+
generatedBefore?: number;
|
|
28
|
+
limit?: number;
|
|
29
|
+
}
|
|
30
|
+
export interface ReadArgs {
|
|
31
|
+
query: CorpusQuery;
|
|
32
|
+
select?: (manifests: ManifestPreview[]) => ManifestPreview[];
|
|
33
|
+
}
|
|
34
|
+
export interface EnvelopeRef {
|
|
35
|
+
manifestCid: string;
|
|
36
|
+
manifestHash: string;
|
|
37
|
+
operator: {
|
|
38
|
+
agentId: string;
|
|
39
|
+
safeAddress: string;
|
|
40
|
+
};
|
|
41
|
+
evidenceTier: 'self-signed' | 'committed' | 'attested' | 'unknown';
|
|
42
|
+
publishedAt: number;
|
|
43
|
+
}
|
|
44
|
+
export interface ManifestPreview {
|
|
45
|
+
ref: EnvelopeRef;
|
|
46
|
+
envelope: SignedEnvelope;
|
|
47
|
+
}
|
|
48
|
+
export interface ArtifactContent {
|
|
49
|
+
sha256: string;
|
|
50
|
+
bytes: Buffer;
|
|
51
|
+
artifactType: string;
|
|
52
|
+
source: 'cache' | 'self-store' | 'origin' | 'route-resolver';
|
|
53
|
+
paidAmountUsdc: string;
|
|
54
|
+
fetchedAt: string;
|
|
55
|
+
sourceOperator?: string;
|
|
56
|
+
}
|
|
57
|
+
export interface Envelope extends ManifestPreview {
|
|
58
|
+
artifactContents: Map<string, ArtifactContent>;
|
|
59
|
+
}
|
|
60
|
+
export interface RouteResolver {
|
|
61
|
+
resolve(req: {
|
|
62
|
+
sha256: string;
|
|
63
|
+
access: {
|
|
64
|
+
endpoint: string;
|
|
65
|
+
priceUsdc: string;
|
|
66
|
+
};
|
|
67
|
+
requesterSafe: string;
|
|
68
|
+
}): Promise<{
|
|
69
|
+
bytes: Buffer;
|
|
70
|
+
sourceOperator?: string;
|
|
71
|
+
pricePaidUsdc: string;
|
|
72
|
+
} | null>;
|
|
73
|
+
}
|
|
74
|
+
export interface Corpus {
|
|
75
|
+
read(args: ReadArgs): Promise<Envelope[]>;
|
|
76
|
+
query(q: CorpusQuery): Promise<EnvelopeRef[]>;
|
|
77
|
+
fetchManifest(ref: EnvelopeRef): Promise<ManifestPreview>;
|
|
78
|
+
acquire(manifest: ManifestPreview): Promise<Envelope>;
|
|
79
|
+
acquireBySha256(sha256: string, access: {
|
|
80
|
+
endpoint: string;
|
|
81
|
+
priceUsdc: string;
|
|
82
|
+
}, hint?: {
|
|
83
|
+
artifactType?: string;
|
|
84
|
+
envelopeCid?: string;
|
|
85
|
+
}): Promise<ArtifactContent>;
|
|
86
|
+
}
|
|
87
|
+
export declare class CorpusQueryError extends Error {
|
|
88
|
+
readonly cause?: unknown | undefined;
|
|
89
|
+
constructor(message: string, cause?: unknown | undefined);
|
|
90
|
+
}
|
|
91
|
+
export declare class ManifestFetchError extends Error {
|
|
92
|
+
readonly manifestCid: string;
|
|
93
|
+
readonly cause?: unknown | undefined;
|
|
94
|
+
constructor(manifestCid: string, message: string, cause?: unknown | undefined);
|
|
95
|
+
}
|
|
96
|
+
export declare class AcquireError extends Error {
|
|
97
|
+
readonly sha256: string;
|
|
98
|
+
readonly cause?: unknown | undefined;
|
|
99
|
+
constructor(sha256: string, message: string, cause?: unknown | undefined);
|
|
100
|
+
}
|
|
101
|
+
export declare class HashMismatchError extends Error {
|
|
102
|
+
readonly sha256Expected: string;
|
|
103
|
+
readonly sha256Actual: string;
|
|
104
|
+
readonly source: string;
|
|
105
|
+
readonly sourceOperator?: string | undefined;
|
|
106
|
+
constructor(sha256Expected: string, sha256Actual: string, source: string, sourceOperator?: string | undefined);
|
|
107
|
+
}
|