@jinn-network/client 0.1.7 → 0.1.8-canary.09a3b2f6
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/README.md +67 -1
- package/dist/adapters/mech/adapter.d.ts +39 -2
- package/dist/adapters/mech/adapter.js +178 -20
- package/dist/adapters/mech/adapter.js.map +1 -1
- package/dist/adapters/mech/contracts.d.ts +22 -1
- package/dist/adapters/mech/contracts.js +96 -52
- package/dist/adapters/mech/contracts.js.map +1 -1
- package/dist/adapters/mech/safe-revert.d.ts +4 -0
- package/dist/adapters/mech/safe-revert.js +5 -1
- package/dist/adapters/mech/safe-revert.js.map +1 -1
- package/dist/adapters/mech/safe.d.ts +1 -1
- package/dist/adapters/mech/safe.js +10 -4
- package/dist/adapters/mech/safe.js.map +1 -1
- package/dist/adapters/mech/types.d.ts +6 -1
- package/dist/adapters/mech/types.js.map +1 -1
- package/dist/agent/operator-claude.js +8 -0
- package/dist/agent/operator-claude.js.map +1 -1
- package/dist/api/activity-events-endpoint.d.ts +14 -0
- package/dist/api/activity-events-endpoint.js +59 -0
- package/dist/api/activity-events-endpoint.js.map +1 -0
- package/dist/api/bootstrap-endpoint.d.ts +1 -2
- package/dist/api/bootstrap-endpoint.js +42 -24
- package/dist/api/bootstrap-endpoint.js.map +1 -1
- package/dist/api/codex-doctor-endpoint.d.ts +22 -5
- package/dist/api/codex-doctor-endpoint.js +136 -17
- package/dist/api/codex-doctor-endpoint.js.map +1 -1
- package/dist/api/debug-report-endpoint.d.ts +27 -0
- package/dist/api/debug-report-endpoint.js +157 -0
- package/dist/api/debug-report-endpoint.js.map +1 -0
- package/dist/api/discovery-endpoint.d.ts +1 -0
- package/dist/api/discovery-endpoint.js +24 -0
- package/dist/api/discovery-endpoint.js.map +1 -1
- package/dist/api/fleet-build.d.ts +1 -7
- package/dist/api/fleet-build.js +0 -7
- package/dist/api/fleet-build.js.map +1 -1
- package/dist/api/gather-status.d.ts +39 -0
- package/dist/api/gather-status.js +181 -84
- package/dist/api/gather-status.js.map +1 -1
- package/dist/api/hermes-doctor-endpoint.d.ts +15 -7
- package/dist/api/hermes-doctor-endpoint.js +56 -19
- package/dist/api/hermes-doctor-endpoint.js.map +1 -1
- package/dist/api/launcher-status.d.ts +4 -2
- package/dist/api/launcher-status.js +11 -10
- package/dist/api/launcher-status.js.map +1 -1
- package/dist/api/launcher-tasks.d.ts +1 -1
- package/dist/api/launcher-tasks.js +12 -8
- package/dist/api/launcher-tasks.js.map +1 -1
- package/dist/api/loop-completion-build.d.ts +79 -0
- package/dist/api/loop-completion-build.js +155 -0
- package/dist/api/loop-completion-build.js.map +1 -0
- package/dist/api/operator-artifacts-endpoint.js +73 -6
- package/dist/api/operator-artifacts-endpoint.js.map +1 -1
- package/dist/api/portfolio-v0-build.d.ts +7 -1
- package/dist/api/portfolio-v0-build.js +6 -2
- package/dist/api/portfolio-v0-build.js.map +1 -1
- package/dist/api/prediction-v1-build.d.ts +6 -0
- package/dist/api/prediction-v1-build.js +3 -1
- package/dist/api/prediction-v1-build.js.map +1 -1
- package/dist/api/server.d.ts +17 -0
- package/dist/api/server.js +40 -1
- package/dist/api/server.js.map +1 -1
- package/dist/api/setup-endpoints.d.ts +13 -9
- package/dist/api/setup-endpoints.js +50 -173
- package/dist/api/setup-endpoints.js.map +1 -1
- package/dist/api/solvernets-endpoints.js +33 -63
- package/dist/api/solvernets-endpoints.js.map +1 -1
- package/dist/api/status-build.d.ts +140 -17
- package/dist/api/status-build.js +47 -34
- package/dist/api/status-build.js.map +1 -1
- package/dist/api/status-harness-rollup.d.ts +35 -0
- package/dist/api/status-harness-rollup.js +45 -0
- package/dist/api/status-harness-rollup.js.map +1 -0
- package/dist/api/status-rollup-build.d.ts +0 -4
- package/dist/api/status-rollup-build.js +0 -4
- package/dist/api/status-rollup-build.js.map +1 -1
- package/dist/api/task-runs-build.d.ts +8 -0
- package/dist/api/task-runs-build.js +5 -1
- package/dist/api/task-runs-build.js.map +1 -1
- package/dist/build-info.json +4 -4
- package/dist/build-meta.json +1 -1
- package/dist/captures/live-publisher.js +24 -4
- package/dist/captures/live-publisher.js.map +1 -1
- package/dist/captures/publish.d.ts +1 -1
- package/dist/chain-read-errors.d.ts +12 -0
- package/dist/chain-read-errors.js +26 -1
- package/dist/chain-read-errors.js.map +1 -1
- package/dist/cli/commands/codedigest-revert-check.d.ts +33 -0
- package/dist/cli/commands/codedigest-revert-check.js +253 -0
- package/dist/cli/commands/codedigest-revert-check.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +3 -0
- package/dist/cli/commands/doctor.js +35 -0
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/eval.d.ts +76 -0
- package/dist/cli/commands/eval.js +401 -0
- package/dist/cli/commands/eval.js.map +1 -0
- package/dist/cli/commands/rewards.d.ts +2 -0
- package/dist/cli/commands/rewards.js +27 -0
- package/dist/cli/commands/rewards.js.map +1 -1
- package/dist/cli/commands/solver-nets.d.ts +1 -0
- package/dist/cli/commands/solver-nets.js +245 -22
- package/dist/cli/commands/solver-nets.js.map +1 -1
- package/dist/cli/commands/solver-plugins-block.d.ts +33 -0
- package/dist/cli/commands/solver-plugins-block.js +118 -0
- package/dist/cli/commands/solver-plugins-block.js.map +1 -0
- package/dist/cli/commands/solver-plugins-feedback.d.ts +72 -0
- package/dist/cli/commands/solver-plugins-feedback.js +262 -0
- package/dist/cli/commands/solver-plugins-feedback.js.map +1 -0
- package/dist/cli/commands/solver-plugins-read.d.ts +54 -0
- package/dist/cli/commands/solver-plugins-read.js +259 -0
- package/dist/cli/commands/solver-plugins-read.js.map +1 -0
- package/dist/cli/commands/solver-plugins.d.ts +35 -0
- package/dist/cli/commands/solver-plugins.js +399 -2
- package/dist/cli/commands/solver-plugins.js.map +1 -1
- package/dist/cli/commands/status.js +0 -1
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/tasks.js +15 -2
- package/dist/cli/commands/tasks.js.map +1 -1
- package/dist/cli/index.js +4 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/task-native-readiness.d.ts +7 -0
- package/dist/cli/task-native-readiness.js +7 -5
- package/dist/cli/task-native-readiness.js.map +1 -1
- package/dist/config.d.ts +206 -232
- package/dist/config.js +289 -107
- package/dist/config.js.map +1 -1
- package/dist/daemon/ai-units-gate.d.ts +54 -0
- package/dist/daemon/ai-units-gate.js +83 -0
- package/dist/daemon/ai-units-gate.js.map +1 -0
- package/dist/daemon/creator.js +13 -0
- package/dist/daemon/creator.js.map +1 -1
- package/dist/daemon/daemon.d.ts +10 -0
- package/dist/daemon/daemon.js +205 -30
- package/dist/daemon/daemon.js.map +1 -1
- package/dist/daemon/eviction-loop.d.ts +7 -0
- package/dist/daemon/eviction-loop.js +16 -0
- package/dist/daemon/eviction-loop.js.map +1 -1
- package/dist/daemon/gate-logger.d.ts +9 -0
- package/dist/daemon/gate-logger.js +2 -0
- package/dist/daemon/gate-logger.js.map +1 -0
- package/dist/daemon/jinn-claim-loop.js +22 -4
- package/dist/daemon/jinn-claim-loop.js.map +1 -1
- package/dist/daemon/readiness-gate.d.ts +1 -4
- package/dist/daemon/readiness-gate.js.map +1 -1
- package/dist/daemon/spend-cap-gate.d.ts +40 -0
- package/dist/daemon/spend-cap-gate.js +46 -0
- package/dist/daemon/spend-cap-gate.js.map +1 -0
- package/dist/dashboard/assets/index-3quVQqik.js +167 -0
- package/dist/dashboard/assets/index-BVAWkLwY.css +1 -0
- package/dist/dashboard/index.html +2 -2
- package/dist/discovery/http.d.ts +7 -0
- package/dist/discovery/http.js +567 -24
- package/dist/discovery/http.js.map +1 -1
- package/dist/discovery/onchain.js +197 -5
- package/dist/discovery/onchain.js.map +1 -1
- package/dist/discovery/types.d.ts +235 -0
- package/dist/discovery/types.js +40 -0
- package/dist/discovery/types.js.map +1 -1
- package/dist/discovery/with-fallback.js +41 -0
- package/dist/discovery/with-fallback.js.map +1 -1
- package/dist/earning/bootstrap.d.ts +31 -3
- package/dist/earning/bootstrap.js +94 -22
- package/dist/earning/bootstrap.js.map +1 -1
- package/dist/earning/faucet.d.ts +1 -1
- package/dist/earning/faucet.js +2 -2
- package/dist/earning/faucet.js.map +1 -1
- package/dist/earning/safe-adapter.js +34 -11
- package/dist/earning/safe-adapter.js.map +1 -1
- package/dist/earning/types.d.ts +6 -6
- package/dist/earning/viem-clients.d.ts +11 -4
- package/dist/earning/viem-clients.js +14 -5
- package/dist/earning/viem-clients.js.map +1 -1
- package/dist/erc8004/identity.d.ts +19 -3
- package/dist/erc8004/identity.js +38 -11
- package/dist/erc8004/identity.js.map +1 -1
- package/dist/erc8004/index.d.ts +1 -1
- package/dist/erc8004/index.js.map +1 -1
- package/dist/eval/eval-harness-run.d.ts +63 -0
- package/dist/eval/eval-harness-run.js +123 -0
- package/dist/eval/eval-harness-run.js.map +1 -0
- package/dist/eval/orchestrator.d.ts +163 -0
- package/dist/eval/orchestrator.js +232 -0
- package/dist/eval/orchestrator.js.map +1 -0
- package/dist/eval/paired.d.ts +68 -0
- package/dist/eval/paired.js +93 -0
- package/dist/eval/paired.js.map +1 -0
- package/dist/eval/resolve-slate-tasks.d.ts +35 -0
- package/dist/eval/resolve-slate-tasks.js +56 -0
- package/dist/eval/resolve-slate-tasks.js.map +1 -0
- package/dist/eval/screen-discovery.d.ts +22 -0
- package/dist/eval/screen-discovery.js +71 -0
- package/dist/eval/screen-discovery.js.map +1 -0
- package/dist/eval/screen-progress.d.ts +41 -0
- package/dist/eval/screen-progress.js +60 -0
- package/dist/eval/screen-progress.js.map +1 -0
- package/dist/eval/screen-runner.d.ts +30 -0
- package/dist/eval/screen-runner.js +289 -0
- package/dist/eval/screen-runner.js.map +1 -0
- package/dist/eval/screen.d.ts +107 -0
- package/dist/eval/screen.js +159 -0
- package/dist/eval/screen.js.map +1 -0
- package/dist/eval/slope.d.ts +29 -0
- package/dist/eval/slope.js +46 -0
- package/dist/eval/slope.js.map +1 -0
- package/dist/eval/train-sequence.d.ts +35 -0
- package/dist/eval/train-sequence.js +59 -0
- package/dist/eval/train-sequence.js.map +1 -0
- package/dist/eval/wilson.d.ts +45 -0
- package/dist/eval/wilson.js +48 -0
- package/dist/eval/wilson.js.map +1 -0
- package/dist/events/types.d.ts +2 -2
- package/dist/harnesses/cost-estimates.d.ts +10 -31
- package/dist/harnesses/cost-estimates.js +11 -43
- package/dist/harnesses/cost-estimates.js.map +1 -1
- package/dist/harnesses/engine/canonical-json.js +5 -3
- package/dist/harnesses/engine/canonical-json.js.map +1 -1
- package/dist/harnesses/engine/engine.d.ts +37 -4
- package/dist/harnesses/engine/engine.js +151 -20
- package/dist/harnesses/engine/engine.js.map +1 -1
- package/dist/harnesses/engine/persistence.d.ts +38 -4
- package/dist/harnesses/engine/persistence.js +71 -6
- package/dist/harnesses/engine/persistence.js.map +1 -1
- package/dist/harnesses/engine/state.d.ts +9 -0
- package/dist/harnesses/engine/state.js +23 -10
- package/dist/harnesses/engine/state.js.map +1 -1
- package/dist/harnesses/impls/hermes-agent/adapter.d.ts +2 -0
- package/dist/harnesses/impls/hermes-agent/adapter.js +8 -5
- package/dist/harnesses/impls/hermes-agent/adapter.js.map +1 -1
- package/dist/harnesses/impls/hermes-agent/bootstrap.d.ts +1 -0
- package/dist/harnesses/impls/hermes-agent/bootstrap.js +10 -3
- package/dist/harnesses/impls/hermes-agent/bootstrap.js.map +1 -1
- package/dist/harnesses/impls/hermes-agent/config-builder.d.ts +1 -1
- package/dist/harnesses/impls/hermes-agent/config-builder.js +4 -2
- package/dist/harnesses/impls/hermes-agent/config-builder.js.map +1 -1
- package/dist/harnesses/impls/hermes-agent/harness.d.ts +31 -3
- package/dist/harnesses/impls/hermes-agent/harness.js +84 -7
- package/dist/harnesses/impls/hermes-agent/harness.js.map +1 -1
- package/dist/harnesses/impls/hermes-agent/prompt.d.ts +6 -6
- package/dist/harnesses/impls/hermes-agent/prompt.js +6 -6
- package/dist/harnesses/impls/index.d.ts +2 -0
- package/dist/harnesses/impls/index.js +2 -0
- package/dist/harnesses/impls/index.js.map +1 -1
- package/dist/harnesses/impls/learner/adapters/claude-code.d.ts +17 -0
- package/dist/harnesses/impls/learner/adapters/claude-code.js +118 -14
- package/dist/harnesses/impls/learner/adapters/claude-code.js.map +1 -1
- package/dist/harnesses/impls/learner/adapters/codex-code.d.ts +9 -0
- package/dist/harnesses/impls/learner/adapters/codex-code.js +30 -8
- package/dist/harnesses/impls/learner/adapters/codex-code.js.map +1 -1
- package/dist/harnesses/impls/learner/harness.d.ts +41 -1
- package/dist/harnesses/impls/learner/harness.js +78 -4
- package/dist/harnesses/impls/learner/harness.js.map +1 -1
- package/dist/harnesses/impls/learner/harvest.d.ts +3 -1
- package/dist/harnesses/impls/learner/harvest.js +30 -6
- package/dist/harnesses/impls/learner/harvest.js.map +1 -1
- package/dist/harnesses/impls/learner/plugin-path.js +1 -0
- package/dist/harnesses/impls/learner/plugin-path.js.map +1 -1
- package/dist/harnesses/impls/learner/restoration-patch.d.ts +2 -2
- package/dist/harnesses/impls/learner/restoration-patch.js +25 -6
- package/dist/harnesses/impls/learner/restoration-patch.js.map +1 -1
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/eval-runner.js +21 -1
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/eval-runner.js.map +1 -1
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/harness.js +3 -1
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/harness.js.map +1 -1
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/hf-fetcher.d.ts +74 -5
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/hf-fetcher.js +103 -32
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/hf-fetcher.js.map +1 -1
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/index.d.ts +2 -2
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/index.js +3 -1
- package/dist/harnesses/impls/swe-rebench-v2-evaluator/index.js.map +1 -1
- package/dist/harnesses/readiness-registry.d.ts +7 -0
- package/dist/harnesses/readiness-registry.js +9 -0
- package/dist/harnesses/readiness-registry.js.map +1 -1
- package/dist/harnesses/types.d.ts +14 -0
- package/dist/learner/revert-decision.d.ts +74 -0
- package/dist/learner/revert-decision.js +73 -0
- package/dist/learner/revert-decision.js.map +1 -0
- package/dist/learner/revert-stats.d.ts +38 -0
- package/dist/learner/revert-stats.js +86 -0
- package/dist/learner/revert-stats.js.map +1 -0
- package/dist/local-provider-url.d.ts +3 -0
- package/dist/local-provider-url.js +28 -0
- package/dist/local-provider-url.js.map +1 -0
- package/dist/main.js +199 -104
- package/dist/main.js.map +1 -1
- package/dist/mcp/get-codedigest-reward.d.ts +13 -0
- package/dist/mcp/get-codedigest-reward.js +23 -0
- package/dist/mcp/get-codedigest-reward.js.map +1 -0
- package/dist/mcp/server.js +23 -0
- package/dist/mcp/server.js.map +1 -1
- package/dist/observability/debug-report-assemble.d.ts +43 -0
- package/dist/observability/debug-report-assemble.js +80 -0
- package/dist/observability/debug-report-assemble.js.map +1 -0
- package/dist/observability/emit-event.d.ts +9 -2
- package/dist/observability/emit-event.js +36 -2
- package/dist/observability/emit-event.js.map +1 -1
- package/dist/observability/file-logger.d.ts +69 -0
- package/dist/observability/file-logger.js +177 -0
- package/dist/observability/file-logger.js.map +1 -0
- package/dist/observability/redact-secrets.d.ts +65 -0
- package/dist/observability/redact-secrets.js +300 -0
- package/dist/observability/redact-secrets.js.map +1 -0
- package/dist/observability/tar.d.ts +30 -0
- package/dist/observability/tar.js +102 -0
- package/dist/observability/tar.js.map +1 -0
- package/dist/plugins/learner/.claude-plugin/plugin.json +1 -1
- package/dist/plugins/learner/.codex-plugin/plugin.json +1 -1
- package/dist/plugins/learner/hooks/session-start +30 -1
- package/dist/plugins/learner/skills/learn/consolidator-prompt.md +22 -1
- package/dist/plugins/learner/skills/learn/promoter-prompt.md +72 -1
- package/dist/preflight/deployment-readiness.d.ts +147 -0
- package/dist/preflight/deployment-readiness.js +366 -0
- package/dist/preflight/deployment-readiness.js.map +1 -0
- package/dist/preflight/pidfile-liveness.d.ts +50 -0
- package/dist/preflight/pidfile-liveness.js +117 -0
- package/dist/preflight/pidfile-liveness.js.map +1 -0
- package/dist/preflight/rpc-network.d.ts +40 -0
- package/dist/preflight/rpc-network.js +67 -1
- package/dist/preflight/rpc-network.js.map +1 -1
- package/dist/rpc/transport.d.ts +145 -0
- package/dist/rpc/transport.js +319 -0
- package/dist/rpc/transport.js.map +1 -0
- package/dist/scripts/donation-consumption-acceptance.js +7 -28
- package/dist/scripts/donation-consumption-acceptance.js.map +1 -1
- package/dist/scripts/swe-rebench-v2-pytest-missing.json +16 -0
- package/dist/solver-nets/prediction-operator-ux.d.ts +1 -2
- package/dist/solver-nets/prediction-operator-ux.js +56 -53
- package/dist/solver-nets/prediction-operator-ux.js.map +1 -1
- package/dist/solver-nets/registry.d.ts +19 -1
- package/dist/solver-nets/registry.js +37 -24
- package/dist/solver-nets/registry.js.map +1 -1
- package/dist/solver-types/_swe-rebench-v2-held-out-slate.d.ts +76 -0
- package/dist/solver-types/_swe-rebench-v2-held-out-slate.js +156 -0
- package/dist/solver-types/_swe-rebench-v2-held-out-slate.js.map +1 -0
- package/dist/solver-types/_swe-rebench-v2-pool-recovery.d.ts +81 -0
- package/dist/solver-types/_swe-rebench-v2-pool-recovery.js +116 -0
- package/dist/solver-types/_swe-rebench-v2-pool-recovery.js.map +1 -0
- package/dist/solver-types/_swe-rebench-v2-pool.d.ts +9 -2
- package/dist/solver-types/_swe-rebench-v2-pool.js +15 -20
- package/dist/solver-types/_swe-rebench-v2-pool.js.map +1 -1
- package/dist/solver-types/_swe-rebench-v2-state.d.ts +24 -0
- package/dist/solver-types/_swe-rebench-v2-state.js +33 -0
- package/dist/solver-types/_swe-rebench-v2-state.js.map +1 -1
- package/dist/solver-types/_swe-rebench-v2-validated-pool.d.ts +116 -2
- package/dist/solver-types/_swe-rebench-v2-validated-pool.js +296 -21
- package/dist/solver-types/_swe-rebench-v2-validated-pool.js.map +1 -1
- package/dist/solver-types/slates/held-out-slate.swe-rebench-v2.v1.json +20 -0
- package/dist/solver-types/slates/held-out-slate.swe-rebench-v2.v2.json +19 -0
- package/dist/solver-types/slates/held-out-slate.swe-rebench-v2.v2.screening-report.json +628 -0
- package/dist/solver-types/solver-type.d.ts +8 -0
- package/dist/solver-types/swe-rebench-v2-auto.d.ts +20 -11
- package/dist/solver-types/swe-rebench-v2-auto.js +64 -19
- package/dist/solver-types/swe-rebench-v2-auto.js.map +1 -1
- package/dist/solver-types/swe-rebench-v2.d.ts +10 -2
- package/dist/solver-types/swe-rebench-v2.js +233 -13
- package/dist/solver-types/swe-rebench-v2.js.map +1 -1
- package/dist/solvernets/daemon-init.d.ts +1 -1
- package/dist/solvernets/daemon-init.js +19 -4
- package/dist/solvernets/daemon-init.js.map +1 -1
- package/dist/solvernets/launched-record-dispatcher.d.ts +7 -0
- package/dist/solvernets/launched-record-dispatcher.js +10 -4
- package/dist/solvernets/launched-record-dispatcher.js.map +1 -1
- package/dist/solvernets/registry-client-erc8004.js +40 -37
- package/dist/solvernets/registry-client-erc8004.js.map +1 -1
- package/dist/solvernets/registry-client.d.ts +6 -0
- package/dist/solvernets/store.d.ts +2 -2
- package/dist/solvernets/store.js +7 -2
- package/dist/solvernets/store.js.map +1 -1
- package/dist/spend/ai-units-config.d.ts +49 -0
- package/dist/spend/ai-units-config.js +34 -0
- package/dist/spend/ai-units-config.js.map +1 -0
- package/dist/spend/ai-units.d.ts +140 -0
- package/dist/spend/ai-units.js +229 -0
- package/dist/spend/ai-units.js.map +1 -0
- package/dist/spend/cost-surface-status.d.ts +12 -0
- package/dist/spend/cost-surface-status.js +24 -0
- package/dist/spend/cost-surface-status.js.map +1 -0
- package/dist/spend/credential.d.ts +39 -0
- package/dist/spend/credential.js +71 -0
- package/dist/spend/credential.js.map +1 -0
- package/dist/spend/daemon-config.d.ts +13 -0
- package/dist/spend/daemon-config.js +24 -0
- package/dist/spend/daemon-config.js.map +1 -0
- package/dist/spend/pricing.d.ts +16 -0
- package/dist/spend/pricing.js +26 -0
- package/dist/spend/pricing.js.map +1 -0
- package/dist/spend/record.d.ts +13 -0
- package/dist/spend/record.js +43 -0
- package/dist/spend/record.js.map +1 -0
- package/dist/spend/usage.d.ts +27 -0
- package/dist/spend/usage.js +113 -0
- package/dist/spend/usage.js.map +1 -0
- package/dist/store/store.d.ts +187 -0
- package/dist/store/store.js +467 -4
- package/dist/store/store.js.map +1 -1
- package/dist/trajectory/transcript-parsers/codex-session.d.ts +12 -6
- package/dist/trajectory/transcript-parsers/codex-session.js +114 -13
- package/dist/trajectory/transcript-parsers/codex-session.js.map +1 -1
- package/dist/trajectory/transcript-parsers/types.d.ts +8 -8
- package/dist/trajectory/transcript-session-dirs.d.ts +18 -0
- package/dist/trajectory/transcript-session-dirs.js +85 -0
- package/dist/trajectory/transcript-session-dirs.js.map +1 -0
- package/dist/trajectory/transcript-watcher.d.ts +20 -1
- package/dist/trajectory/transcript-watcher.js +108 -32
- package/dist/trajectory/transcript-watcher.js.map +1 -1
- package/dist/tx-retry.d.ts +25 -0
- package/dist/tx-retry.js +95 -7
- package/dist/tx-retry.js.map +1 -1
- package/dist/types/payloads/portfolio-v0.d.ts +3 -3
- package/dist/types/payloads/prediction-apy-v0.d.ts +3 -3
- package/dist/types/payloads/prediction-v0.d.ts +12 -12
- package/dist/vendor/@jinn-network/sdk/dist/payloads/swe-rebench-v2.d.ts +108 -1
- package/dist/vendor/@jinn-network/sdk/dist/payloads/swe-rebench-v2.js +25 -1
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/swe-rebench-v2-held-out-slate.d.ts +65 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/swe-rebench-v2-held-out-slate.js +123 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/swe-rebench-v2.d.ts +2 -2
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/swe-rebench-v2.js +1 -1
- package/dist/vendor/@jinn-network/sdk/package.json +4 -0
- package/docker-compose.yml +3 -2
- package/package.json +30 -18
- package/plugins/learner/.claude-plugin/plugin.json +1 -1
- package/plugins/learner/.codex-plugin/plugin.json +1 -1
- package/plugins/learner/hooks/session-start +30 -1
- package/plugins/learner/skills/learn/consolidator-prompt.md +22 -1
- package/plugins/learner/skills/learn/promoter-prompt.md +72 -1
- package/plugins/swe-rebench-v2-diffmin/README.md +10 -9
- package/plugins/swe-rebench-v2-diffmin/jinn.plugin.json +1 -1
- package/plugins/swe-rebench-v2-diffmin/skills/diffmin/SKILL.md +15 -10
- package/plugins/swe-rebench-v2-diffmin/skills/test-map/SKILL.md +10 -12
- package/plugins/swe-rebench-v2-runtime/.claude-plugin/plugin.json +1 -1
- package/plugins/swe-rebench-v2-runtime/.codex-plugin/plugin.json +3 -3
- package/plugins/swe-rebench-v2-runtime/README.md +6 -6
- package/plugins/swe-rebench-v2-runtime/hooks/hooks.json +16 -0
- package/plugins/swe-rebench-v2-runtime/hooks/session-start +74 -0
- package/plugins/swe-rebench-v2-runtime/jinn.plugin.json +2 -3
- package/plugins/swe-rebench-v2-runtime/skills/task/SKILL.md +81 -0
- package/dist/dashboard/assets/index-BUlE8F3Y.js +0 -330
- package/dist/dashboard/assets/index-blqc7eqq.css +0 -32
- package/plugins/swe-rebench-v2-runtime/skills/orient/SKILL.md +0 -29
- package/plugins/swe-rebench-v2-runtime/skills/plan/SKILL.md +0 -53
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Pidfile liveness preflight (issue #649). Classifies the recorded PID and
|
|
3
|
+
* returns a discriminated decision; side-effect-free so the caller owns the
|
|
4
|
+
* unlink (mirrors the idiom at `client/src/mcp/operator-server.ts:209-213`).
|
|
5
|
+
*
|
|
6
|
+
* Branches (load-bearing — see #649 acceptance criteria):
|
|
7
|
+
* - File missing → { decision: 'proceed' }
|
|
8
|
+
* - File malformed (NaN/empty) → { decision: 'unlink-stale', reason: 'malformed' }
|
|
9
|
+
* - PID 1 or our own pid → { decision: 'unlink-stale', reason: 'self-or-pid1-container' }
|
|
10
|
+
* - process.kill(pid, 0) ESRCH → { decision: 'unlink-stale', reason: 'esrch' }
|
|
11
|
+
* - process.kill(pid, 0) ok → { decision: 'refuse', reason: 'alive' }
|
|
12
|
+
* - process.kill(pid, 0) EPERM → { decision: 'refuse', reason: 'eperm' }
|
|
13
|
+
* - any other errno → { decision: 'refuse', reason: 'unknown' }
|
|
14
|
+
*
|
|
15
|
+
* The PID-1/self branch classifies *before* the `process.kill` probe (#805): in
|
|
16
|
+
* a container the daemon is PID 1, whose pidfile outlives the container on the
|
|
17
|
+
* persistent volume; `process.kill(1, 0)` always succeeds, so a probe-first
|
|
18
|
+
* order would mis-classify the stale record as a live sibling and crash-loop.
|
|
19
|
+
*
|
|
20
|
+
* `.trim()` before `parseInt` is required: `main.ts` writes the PID with a
|
|
21
|
+
* trailing `\n` (see `client/src/main.ts` writeFileSync near the pidfile site).
|
|
22
|
+
*/
|
|
23
|
+
import { existsSync, readFileSync, unlinkSync } from 'node:fs';
|
|
24
|
+
import { emitEnvelope } from '../errors/envelope.js';
|
|
25
|
+
import { emitStructured } from '../events/emitter.js';
|
|
26
|
+
export function checkPidfileLiveness(input) {
|
|
27
|
+
const { pidPath } = input;
|
|
28
|
+
if (!existsSync(pidPath)) {
|
|
29
|
+
return { decision: 'proceed' };
|
|
30
|
+
}
|
|
31
|
+
let raw;
|
|
32
|
+
try {
|
|
33
|
+
raw = readFileSync(pidPath, 'utf-8');
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
// Unreadable pidfile: treat as stale. If the caller's subsequent write also
|
|
37
|
+
// fails, that surfaces via main.ts's `writeFileSync`.
|
|
38
|
+
return { decision: 'unlink-stale', pid: null, pidfilePath: pidPath, reason: 'malformed' };
|
|
39
|
+
}
|
|
40
|
+
const parsed = parseInt(raw.trim(), 10);
|
|
41
|
+
if (!Number.isFinite(parsed) || parsed <= 0) {
|
|
42
|
+
return { decision: 'unlink-stale', pid: null, pidfilePath: pidPath, reason: 'malformed' };
|
|
43
|
+
}
|
|
44
|
+
// #805: in a container the daemon is PID 1; the pidfile on the persistent
|
|
45
|
+
// volume outlives the container, and `process.kill(1, 0)` always succeeds, so
|
|
46
|
+
// we must classify the self/PID-1 record as stale *before* the liveness probe
|
|
47
|
+
// below — otherwise the probe reports it alive and the daemon crash-loops. A
|
|
48
|
+
// record of our own pid is likewise self, never a live sibling.
|
|
49
|
+
if (parsed === 1 || parsed === process.pid) {
|
|
50
|
+
return { decision: 'unlink-stale', pid: parsed, pidfilePath: pidPath, reason: 'self-or-pid1-container' };
|
|
51
|
+
}
|
|
52
|
+
try {
|
|
53
|
+
process.kill(parsed, 0);
|
|
54
|
+
return { decision: 'refuse', pid: parsed, pidfilePath: pidPath, reason: 'alive' };
|
|
55
|
+
}
|
|
56
|
+
catch (err) {
|
|
57
|
+
const errno = err.code;
|
|
58
|
+
if (errno === 'ESRCH') {
|
|
59
|
+
return { decision: 'unlink-stale', pid: parsed, pidfilePath: pidPath, reason: 'esrch' };
|
|
60
|
+
}
|
|
61
|
+
if (errno === 'EPERM') {
|
|
62
|
+
return { decision: 'refuse', pid: parsed, pidfilePath: pidPath, reason: 'eperm' };
|
|
63
|
+
}
|
|
64
|
+
// Any other errno: conservative refuse rather than risk trampling a daemon
|
|
65
|
+
// we can't classify.
|
|
66
|
+
return { decision: 'refuse', pid: parsed, pidfilePath: pidPath, reason: 'unknown' };
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Apply the pidfile-liveness gate at `jinn run` startup (#649). On `refuse`
|
|
71
|
+
* emits the `invalid_invocation` envelope and exits (does not return); on
|
|
72
|
+
* `unlink-stale` logs the cleanup, removes the stale pidfile, and returns;
|
|
73
|
+
* on `proceed` returns immediately. Callers MUST write the pidfile themselves
|
|
74
|
+
* after this returns — the helper deliberately stops short of the write so the
|
|
75
|
+
* "// DO NOT add store mutations above this line — see #649" invariant in
|
|
76
|
+
* main.ts stays visible at the call site.
|
|
77
|
+
*/
|
|
78
|
+
export function applyPidfileLivenessGate(pidPath, sinks = {}) {
|
|
79
|
+
const liveness = checkPidfileLiveness({ pidPath });
|
|
80
|
+
if (liveness.decision === 'refuse') {
|
|
81
|
+
emitEnvelope({
|
|
82
|
+
code: 'invalid_invocation',
|
|
83
|
+
message: `Another jinn daemon is already running (PID ${liveness.pid}).`,
|
|
84
|
+
hint: 'Run `jinn stop` to terminate it, or set JINN_EARNING_DIR to a different earning directory.',
|
|
85
|
+
exampleCli: 'jinn stop',
|
|
86
|
+
details: {
|
|
87
|
+
field: 'daemon_pidfile',
|
|
88
|
+
pid: liveness.pid,
|
|
89
|
+
pidfilePath: pidPath,
|
|
90
|
+
reason: liveness.reason,
|
|
91
|
+
},
|
|
92
|
+
}, sinks);
|
|
93
|
+
// emitEnvelope calls process.exit in production; the test sink may throw
|
|
94
|
+
// or no-op. Either way control does not fall through to the writeFileSync
|
|
95
|
+
// in the caller.
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
if (liveness.decision === 'unlink-stale') {
|
|
99
|
+
emitStructured({
|
|
100
|
+
kind: 'system',
|
|
101
|
+
message: `cleaning up stale pidfile (${liveness.reason})`,
|
|
102
|
+
details: {
|
|
103
|
+
phase: 'preflight',
|
|
104
|
+
pidfilePath: pidPath,
|
|
105
|
+
reason: liveness.reason,
|
|
106
|
+
pid: liveness.pid,
|
|
107
|
+
},
|
|
108
|
+
});
|
|
109
|
+
try {
|
|
110
|
+
unlinkSync(pidPath);
|
|
111
|
+
}
|
|
112
|
+
catch {
|
|
113
|
+
/* best-effort — the writeFileSync that follows surfaces any real problem */
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=pidfile-liveness.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pidfile-liveness.js","sourceRoot":"","sources":["../../src/preflight/pidfile-liveness.ts"],"names":[],"mappings":"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"}
|
|
@@ -42,3 +42,43 @@ export declare function logRpcLocalDevToStderr(r: RpcNetworkPreflightOk, write?:
|
|
|
42
42
|
export declare function rpcHostForDisplay(rpcUrl: string): string;
|
|
43
43
|
export declare function checkRpcNetwork(config: Pick<JinnConfig, 'network' | 'rpcUrl'>): Promise<RpcNetworkPreflightResult>;
|
|
44
44
|
export declare function rpcNetworkFailureHint(result: RpcNetworkPreflightFail): string;
|
|
45
|
+
/** Layer label for log lines and AC7 summary formatting. */
|
|
46
|
+
export type ProbeLayer = 'L1' | 'L2';
|
|
47
|
+
export type ProbeOk = {
|
|
48
|
+
ok: true;
|
|
49
|
+
host: string;
|
|
50
|
+
latencyMs: number;
|
|
51
|
+
};
|
|
52
|
+
export type ProbeFail = {
|
|
53
|
+
ok: false;
|
|
54
|
+
host: string;
|
|
55
|
+
/** HTTP status when applicable (4xx / 5xx). */
|
|
56
|
+
code?: number;
|
|
57
|
+
/** Failure shape when no HTTP status is available. */
|
|
58
|
+
reason?: 'unreachable' | 'unknown';
|
|
59
|
+
message: string;
|
|
60
|
+
};
|
|
61
|
+
export type ProbeResult = ProbeOk | ProbeFail;
|
|
62
|
+
export interface ProbeFallbackChainOptions {
|
|
63
|
+
/** Logger for per-slot lines. Defaults to `console.error`. */
|
|
64
|
+
log?: (message: string) => void;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Probe each URL in a fallback chain with a per-slot `eth_blockNumber` call.
|
|
68
|
+
* Records ok/latency or a structured failure (HTTP status / unreachable).
|
|
69
|
+
*
|
|
70
|
+
* The probe is **log-only** — it never throws on per-slot failures. Startup
|
|
71
|
+
* gating remains the job of {@link checkRpcNetwork}, which fails loud on
|
|
72
|
+
* chain-id mismatch.
|
|
73
|
+
*
|
|
74
|
+
* Per AC9 (issue #592): emits one log line per slot
|
|
75
|
+
* `[rpc] <layer> <host> ok latency=Nms`
|
|
76
|
+
* `[rpc] <layer> <host> warn <http-status>` (e.g. 429, 503)
|
|
77
|
+
* `[rpc] <layer> <host> warn unreachable: <message>`
|
|
78
|
+
*/
|
|
79
|
+
export declare function probeFallbackChain(urls: readonly string[], network: ExpectedRpcNetwork, layer: ProbeLayer, options?: ProbeFallbackChainOptions): Promise<ProbeResult[]>;
|
|
80
|
+
/**
|
|
81
|
+
* Boot-log summary line for a fallback chain, formatted per AC7:
|
|
82
|
+
* `[rpc] L2 transport: fallback chain (N providers) — primary=<host>`
|
|
83
|
+
*/
|
|
84
|
+
export declare function summarizeFallbackChain(layer: ProbeLayer, urls: readonly string[]): string;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { createPublicClient, http } from 'viem';
|
|
1
|
+
import { createPublicClient, http, HttpRequestError } from 'viem';
|
|
2
2
|
import { base, baseSepolia } from 'viem/chains';
|
|
3
|
+
import { describeFallbackChain, maskRpcHost } from '../rpc/transport.js';
|
|
3
4
|
export function expectedChainIdForNetwork(network) {
|
|
4
5
|
return network === 'testnet' ? 84532 : 8453;
|
|
5
6
|
}
|
|
@@ -118,4 +119,69 @@ export function rpcNetworkFailureHint(result) {
|
|
|
118
119
|
}
|
|
119
120
|
return 'Set rpcUrl to a Base mainnet endpoint such as https://mainnet.base.org, or set BASE_RPC_URL.';
|
|
120
121
|
}
|
|
122
|
+
function classifyProbeError(host, err) {
|
|
123
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
124
|
+
if (err instanceof HttpRequestError && typeof err.status === 'number') {
|
|
125
|
+
return { ok: false, host, code: err.status, message };
|
|
126
|
+
}
|
|
127
|
+
// viem wraps HTTP errors inside other shapes; walk the cause chain.
|
|
128
|
+
let cur = err?.cause;
|
|
129
|
+
while (cur) {
|
|
130
|
+
if (cur instanceof HttpRequestError && typeof cur.status === 'number') {
|
|
131
|
+
return { ok: false, host, code: cur.status, message };
|
|
132
|
+
}
|
|
133
|
+
cur = cur.cause;
|
|
134
|
+
}
|
|
135
|
+
return { ok: false, host, reason: 'unreachable', message };
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Probe each URL in a fallback chain with a per-slot `eth_blockNumber` call.
|
|
139
|
+
* Records ok/latency or a structured failure (HTTP status / unreachable).
|
|
140
|
+
*
|
|
141
|
+
* The probe is **log-only** — it never throws on per-slot failures. Startup
|
|
142
|
+
* gating remains the job of {@link checkRpcNetwork}, which fails loud on
|
|
143
|
+
* chain-id mismatch.
|
|
144
|
+
*
|
|
145
|
+
* Per AC9 (issue #592): emits one log line per slot
|
|
146
|
+
* `[rpc] <layer> <host> ok latency=Nms`
|
|
147
|
+
* `[rpc] <layer> <host> warn <http-status>` (e.g. 429, 503)
|
|
148
|
+
* `[rpc] <layer> <host> warn unreachable: <message>`
|
|
149
|
+
*/
|
|
150
|
+
export async function probeFallbackChain(urls, network, layer, options = {}) {
|
|
151
|
+
const log = options.log ?? ((m) => process.stderr.write(`${m}\n`));
|
|
152
|
+
// Chain is informational only — eth_blockNumber doesn't depend on chain
|
|
153
|
+
// identity. Both L1 and L2 layers reuse the same Base/Base-Sepolia pair
|
|
154
|
+
// since this is just used to satisfy viem's typing.
|
|
155
|
+
const chain = network === 'testnet' ? baseSepolia : base;
|
|
156
|
+
const results = [];
|
|
157
|
+
for (const url of urls) {
|
|
158
|
+
const host = maskRpcHost(url);
|
|
159
|
+
const client = createPublicClient({ chain, transport: http(url, { retryCount: 0 }) });
|
|
160
|
+
const t0 = performance.now();
|
|
161
|
+
try {
|
|
162
|
+
await client.getBlockNumber();
|
|
163
|
+
const latencyMs = Math.max(0, Math.round(performance.now() - t0));
|
|
164
|
+
log(`[rpc] ${layer} ${host} ok latency=${latencyMs}ms`);
|
|
165
|
+
results.push({ ok: true, host, latencyMs });
|
|
166
|
+
}
|
|
167
|
+
catch (err) {
|
|
168
|
+
const failure = classifyProbeError(host, err);
|
|
169
|
+
if (failure.code !== undefined) {
|
|
170
|
+
log(`[rpc] ${layer} ${host} warn ${failure.code}`);
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
log(`[rpc] ${layer} ${host} warn unreachable: ${failure.message.split('\n')[0]}`);
|
|
174
|
+
}
|
|
175
|
+
results.push(failure);
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return results;
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Boot-log summary line for a fallback chain, formatted per AC7:
|
|
182
|
+
* `[rpc] L2 transport: fallback chain (N providers) — primary=<host>`
|
|
183
|
+
*/
|
|
184
|
+
export function summarizeFallbackChain(layer, urls) {
|
|
185
|
+
return `[rpc] ${layer} transport: ${describeFallbackChain(urls)}`;
|
|
186
|
+
}
|
|
121
187
|
//# sourceMappingURL=rpc-network.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rpc-network.js","sourceRoot":"","sources":["../../src/preflight/rpc-network.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"rpc-network.js","sourceRoot":"","sources":["../../src/preflight/rpc-network.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* RPC transport helper — builds a viem `fallback()` transport from a single
|
|
3
|
+
* URL, an array of URLs, or a comma-separated string. The substrate for issue
|
|
4
|
+
* #592 (multi-RPC fallback chain across daemon / relayer / indexer / CI).
|
|
5
|
+
*
|
|
6
|
+
* Design:
|
|
7
|
+
* - `parseRpcUrls` normalises `string | readonly string[]` to a deduplicated
|
|
8
|
+
* non-empty array, splits comma-strings, trims, drops empties, and caps the
|
|
9
|
+
* chain at {@link MAX_RPC_CHAIN_LENGTH} providers (extras are dropped with a
|
|
10
|
+
* warning). Throws when no URLs remain.
|
|
11
|
+
* - `buildFallbackTransport` wraps `http(url)` per slot inside viem's
|
|
12
|
+
* `fallback([...], { rank: false, retryCount: 0 })`. `rank: false` is
|
|
13
|
+
* explicit — the issue's "Tenderly stays in slot 3" constraint requires
|
|
14
|
+
* order preservation (no latency-based reshuffling). `retryCount: 0` keeps
|
|
15
|
+
* the helper from doubling retries on top of the existing
|
|
16
|
+
* `withRecoverableRetry` wrapper used by callers like the mech adapter.
|
|
17
|
+
* - On exhausted fall-through the helper rejects with `AllRpcsFailedError`,
|
|
18
|
+
* which carries a structured `providers: readonly string[]` list of masked
|
|
19
|
+
* hosts so callers and tests can assert on it.
|
|
20
|
+
* - `describeFallbackChain` formats the canonical AC7 boot-log summary line:
|
|
21
|
+
* `fallback chain (N providers) — primary=<host>`.
|
|
22
|
+
*
|
|
23
|
+
* Do not conflate with `discovery.fallbackToOnchain` — that's a separate layer
|
|
24
|
+
* at the read-API level (Ponder → eth_getLogs floor). This helper sits beneath
|
|
25
|
+
* both layers at the JSON-RPC transport level.
|
|
26
|
+
*/
|
|
27
|
+
import { type FallbackTransport, type Transport } from 'viem';
|
|
28
|
+
/**
|
|
29
|
+
* Hard cap on the number of providers in a single fallback chain. Four covers
|
|
30
|
+
* the "operator paid primary + public publicnode + public sepolia.base.org +
|
|
31
|
+
* Tenderly slot-3" shape from the issue; beyond that the boot probe takes too
|
|
32
|
+
* long and slot 5+ is almost always copy-paste noise.
|
|
33
|
+
*/
|
|
34
|
+
export declare const MAX_RPC_CHAIN_LENGTH = 4;
|
|
35
|
+
export interface ParseRpcUrlsOptions {
|
|
36
|
+
/** Logger used to emit the "capped" warning. Defaults to `console.error`. */
|
|
37
|
+
log?: (message: string) => void;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Normalise `string | readonly string[]` into a non-empty, deduplicated,
|
|
41
|
+
* capped list of RPC URLs. Comma-separated strings are split (operator
|
|
42
|
+
* convention, see `peers` in `config.ts`). Duplicates are removed before the
|
|
43
|
+
* cap is applied so the effective chain length matches operator intent (an
|
|
44
|
+
* operator who prepends their paid primary to the existing fallback list
|
|
45
|
+
* shouldn't burn a slot on the duplicate).
|
|
46
|
+
*
|
|
47
|
+
* @throws if the input yields zero non-empty URLs.
|
|
48
|
+
*/
|
|
49
|
+
export declare function parseRpcUrls(input: string | readonly string[], options?: ParseRpcUrlsOptions): string[];
|
|
50
|
+
/**
|
|
51
|
+
* Error thrown when every provider in a fallback chain has failed. Carries
|
|
52
|
+
* the masked host list so callers can surface a useful operator-facing message
|
|
53
|
+
* without leaking secret query strings (api-key paths).
|
|
54
|
+
*/
|
|
55
|
+
export declare class AllRpcsFailedError extends Error {
|
|
56
|
+
readonly providers: readonly string[];
|
|
57
|
+
readonly cause?: unknown;
|
|
58
|
+
constructor(providers: readonly string[], cause?: unknown);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Detect errors that viem's `fallback()` short-circuits on (via its
|
|
62
|
+
* `shouldThrow(err)` fast-exit) — `ExecutionRevertedError`,
|
|
63
|
+
* `TransactionRejectedRpcError`, `UserRejectedRequestError`,
|
|
64
|
+
* `WalletConnectSessionSettlementError`, and CAIP user-rejected (code
|
|
65
|
+
* `5000`). These are EVM- or wallet-level signals, NOT transport-level
|
|
66
|
+
* failures, so they must propagate unchanged. Wrapping them as
|
|
67
|
+
* `AllRpcsFailedError` would give the operator-app a false-positive
|
|
68
|
+
* "all RPCs failed" message when the actual problem is e.g. a contract
|
|
69
|
+
* revert on a view function.
|
|
70
|
+
*
|
|
71
|
+
* Mirrors viem's own predicate at
|
|
72
|
+
* `node_modules/viem/clients/transports/fallback.ts` (`shouldThrow`),
|
|
73
|
+
* dispatching by **numeric JSON-RPC code** (the path that catches real
|
|
74
|
+
* `RpcRequestError` instances coming out of the HTTP transport) plus the
|
|
75
|
+
* `ExecutionRevertedError.nodeMessage` regex (the path that catches reverts
|
|
76
|
+
* surfaced as plain `Error` with no numeric code). The cause-chain walk by
|
|
77
|
+
* class `name` remains as a third path for wallet-provider stacks that
|
|
78
|
+
* deliver proper class instances (and for already-normalised errors after
|
|
79
|
+
* viem's `buildRequest` re-wrap pass).
|
|
80
|
+
*/
|
|
81
|
+
export declare function isViemShouldThrowError(err: unknown): boolean;
|
|
82
|
+
/**
|
|
83
|
+
* Default cooldown applied to a slot that returns a quota / rate-limit error
|
|
84
|
+
* (#835). After this window the demoted slot becomes eligible again rather than
|
|
85
|
+
* being permanently disabled (AC2), so a transient 429 / monthly-quota blip
|
|
86
|
+
* never strands an operator on a degraded provider for the rest of the process.
|
|
87
|
+
*/
|
|
88
|
+
export declare const DEFAULT_RPC_COOLDOWN_MS = 60000;
|
|
89
|
+
/**
|
|
90
|
+
* Detect quota / rate-limit errors from an RPC provider (#835). Unlike
|
|
91
|
+
* {@link isViemShouldThrowError} (which marks EVM/wallet-level signals that must
|
|
92
|
+
* NOT trigger fallback), a quota error means the *slot* is temporarily unusable
|
|
93
|
+
* and should be demoted behind healthy slots for a cooldown window. Walks the
|
|
94
|
+
* cause chain (cycle-safe, mirroring `isViemShouldThrowError`) and matches on:
|
|
95
|
+
* - HTTP `status === 429` (the `http()` transport's `HttpRequestError`);
|
|
96
|
+
* - JSON-RPC `code === LimitExceededRpcError.code` (-32005);
|
|
97
|
+
* - a narrow message regex backstop covering unambiguous provider phrasings
|
|
98
|
+
* ("rate limit", "too many requests", "429", "quota", "compute unit",
|
|
99
|
+
* "request rate", "throughput") — deliberately excluding the ambiguous
|
|
100
|
+
* "limit"/"exceeded" words that collide with gas-limit errors.
|
|
101
|
+
*
|
|
102
|
+
* Deliberately narrow: a 5xx / network error is NOT a quota error (it falls
|
|
103
|
+
* through via viem but does not cool the slot — AC3 keeps static order when no
|
|
104
|
+
* quota errors occur), and a contract revert (code 3) is never a quota error.
|
|
105
|
+
*/
|
|
106
|
+
export declare function isRpcQuotaError(err: unknown): boolean;
|
|
107
|
+
/**
|
|
108
|
+
* Mask an RPC URL down to its hostname for display / error reporting. Drops
|
|
109
|
+
* the path so api-key segments in the URL don't leak into logs.
|
|
110
|
+
*/
|
|
111
|
+
export declare function maskRpcHost(url: string): string;
|
|
112
|
+
export interface BuildFallbackTransportOptions {
|
|
113
|
+
/**
|
|
114
|
+
* Set to `true` to let viem rank providers by latency. Default `false` —
|
|
115
|
+
* order matters for operator-configured paid primaries and the
|
|
116
|
+
* "Tenderly stays in slot 3" constraint from the issue.
|
|
117
|
+
*/
|
|
118
|
+
rank?: boolean;
|
|
119
|
+
/**
|
|
120
|
+
* Injectable clock for the quota-cooldown bookkeeping (#835). Defaults to
|
|
121
|
+
* {@link Date.now}. Tests pass a controllable stub so cooldown expiry (AC2)
|
|
122
|
+
* is deterministic without real timers.
|
|
123
|
+
*/
|
|
124
|
+
now?: () => number;
|
|
125
|
+
/**
|
|
126
|
+
* How long a slot stays demoted after a quota / rate-limit error, in ms
|
|
127
|
+
* (#835). Defaults to {@link DEFAULT_RPC_COOLDOWN_MS}.
|
|
128
|
+
*/
|
|
129
|
+
cooldownMs?: number;
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Build a viem fallback transport over the given URLs. Returns a callable
|
|
133
|
+
* transport suitable for `createPublicClient({ transport })`.
|
|
134
|
+
*
|
|
135
|
+
* Errors that exhaust the chain are wrapped in `AllRpcsFailedError`.
|
|
136
|
+
*/
|
|
137
|
+
export declare function buildFallbackTransport(urls: readonly string[], options?: BuildFallbackTransportOptions): FallbackTransport;
|
|
138
|
+
export declare namespace buildFallbackTransport {
|
|
139
|
+
var buildFromTransports: (transports: readonly Transport[], urls: readonly string[], options?: BuildFallbackTransportOptions) => FallbackTransport;
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Boot-log summary line for a fallback chain. Matches the canonical AC7
|
|
143
|
+
* format: `fallback chain (N providers) — primary=<host>`.
|
|
144
|
+
*/
|
|
145
|
+
export declare function describeFallbackChain(urls: readonly string[]): string;
|