@jinn-network/client 0.1.8 → 0.1.9-canary.144d87d2
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 +6 -0
- package/dist/adapters/mech/adapter.d.ts +21 -1
- package/dist/adapters/mech/adapter.js +77 -10
- package/dist/adapters/mech/adapter.js.map +1 -1
- package/dist/adapters/mech/contracts.js +62 -28
- 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.js +5 -1
- package/dist/adapters/mech/safe.js.map +1 -1
- package/dist/adapters/mech/verdict-code.js +1 -1
- package/dist/adapters/mech/verdict-code.js.map +1 -1
- package/dist/api/bootstrap-endpoint.d.ts +1 -0
- package/dist/api/bootstrap-endpoint.js +1 -0
- package/dist/api/bootstrap-endpoint.js.map +1 -1
- 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 +8 -2
- package/dist/api/gather-status.js +29 -117
- package/dist/api/gather-status.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 +1 -1
- package/dist/api/operator-artifacts-endpoint.js.map +1 -1
- package/dist/api/peers.js +2 -0
- package/dist/api/peers.js.map +1 -1
- package/dist/api/setup-endpoints.d.ts +32 -0
- package/dist/api/setup-endpoints.js +94 -24
- package/dist/api/setup-endpoints.js.map +1 -1
- package/dist/api/solvernets-endpoints.js +4 -1
- package/dist/api/solvernets-endpoints.js.map +1 -1
- package/dist/api/status-build.d.ts +43 -33
- package/dist/api/status-build.js +3 -26
- package/dist/api/status-build.js.map +1 -1
- 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/stop-hook.d.ts +1 -1
- package/dist/api/stop-hook.js +1 -1
- package/dist/api/stop-hook.js.map +1 -1
- package/dist/build-info.json +4 -4
- package/dist/build-meta.json +1 -1
- package/dist/cli/commands/codedigest-revert-check.js +6 -2
- package/dist/cli/commands/codedigest-revert-check.js.map +1 -1
- package/dist/cli/commands/doctor.d.ts +3 -0
- package/dist/cli/commands/doctor.js +37 -2
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/eval.d.ts +87 -0
- package/dist/cli/commands/eval.js +481 -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 +30 -3
- package/dist/cli/commands/rewards.js.map +1 -1
- package/dist/cli/commands/solver-nets.js +68 -0
- package/dist/cli/commands/solver-nets.js.map +1 -1
- package/dist/cli/commands/status.js +0 -1
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/index.js +2 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/config.d.ts +102 -15
- package/dist/config.js +166 -19
- package/dist/config.js.map +1 -1
- package/dist/daemon/ai-units-gate.d.ts +6 -6
- package/dist/daemon/ai-units-gate.js +11 -10
- package/dist/daemon/ai-units-gate.js.map +1 -1
- package/dist/daemon/balance-topup-loop.js +3 -0
- package/dist/daemon/balance-topup-loop.js.map +1 -1
- package/dist/daemon/checkpoint-loop.js +2 -2
- package/dist/daemon/creator.d.ts +1 -0
- package/dist/daemon/creator.js +26 -14
- package/dist/daemon/creator.js.map +1 -1
- package/dist/daemon/daemon.d.ts +15 -0
- package/dist/daemon/daemon.js +78 -22
- package/dist/daemon/daemon.js.map +1 -1
- package/dist/daemon/eviction-loop.d.ts +7 -0
- package/dist/daemon/eviction-loop.js +19 -3
- package/dist/daemon/eviction-loop.js.map +1 -1
- package/dist/daemon/jinn-claim-loop.js +3 -0
- package/dist/daemon/jinn-claim-loop.js.map +1 -1
- package/dist/daemon/join-applier.d.ts +35 -0
- package/dist/daemon/join-applier.js +49 -0
- package/dist/daemon/join-applier.js.map +1 -0
- package/dist/daemon/loop-heartbeat.d.ts +34 -0
- package/dist/daemon/loop-heartbeat.js +39 -0
- package/dist/daemon/loop-heartbeat.js.map +1 -0
- package/dist/daemon/reward-claim-loop.js +4 -1
- package/dist/daemon/reward-claim-loop.js.map +1 -1
- package/dist/daemon/watchdog-loop.d.ts +84 -0
- package/dist/daemon/watchdog-loop.js +91 -0
- package/dist/daemon/watchdog-loop.js.map +1 -0
- package/dist/dashboard/assets/index-8tAiMbUV.css +1 -0
- package/dist/dashboard/assets/index-D6a-DfaM.js +171 -0
- package/dist/dashboard/index.html +2 -2
- package/dist/discovery/http.d.ts +17 -0
- package/dist/discovery/http.js +295 -25
- package/dist/discovery/http.js.map +1 -1
- package/dist/discovery/onchain.js +155 -1
- package/dist/discovery/onchain.js.map +1 -1
- package/dist/discovery/types.d.ts +106 -0
- package/dist/discovery/types.js +40 -0
- package/dist/discovery/types.js.map +1 -1
- package/dist/discovery/with-fallback.js +14 -0
- package/dist/discovery/with-fallback.js.map +1 -1
- package/dist/earning/bootstrap.d.ts +25 -0
- package/dist/earning/bootstrap.js +79 -28
- 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 +11 -0
- package/dist/earning/safe-adapter.js.map +1 -1
- package/dist/earning/stolas-claim.js +5 -5
- package/dist/earning/types.d.ts +1 -1
- package/dist/earning/types.js +1 -1
- package/dist/earning/types.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 +224 -0
- package/dist/eval/orchestrator.js +250 -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 +1 -1
- package/dist/events/types.js +1 -1
- package/dist/events/types.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 +24 -0
- package/dist/harnesses/engine/engine.js +72 -9
- package/dist/harnesses/engine/engine.js.map +1 -1
- package/dist/harnesses/engine/packaging.js +1 -1
- package/dist/harnesses/engine/packaging.js.map +1 -1
- package/dist/harnesses/engine/persistence.d.ts +17 -0
- package/dist/harnesses/engine/persistence.js +28 -0
- package/dist/harnesses/engine/persistence.js.map +1 -1
- package/dist/harnesses/impls/claude-mcp-hyperliquid/mcp-tools.d.ts +1 -1
- package/dist/harnesses/impls/claude-mcp-hyperliquid/mcp-tools.js +1 -1
- package/dist/harnesses/impls/claude-mcp-hyperliquid/mcp-tools.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 +6 -1
- package/dist/harnesses/impls/hermes-agent/bootstrap.js.map +1 -1
- package/dist/harnesses/impls/hermes-agent/harness.d.ts +17 -3
- package/dist/harnesses/impls/hermes-agent/harness.js +68 -5
- package/dist/harnesses/impls/hermes-agent/harness.js.map +1 -1
- package/dist/harnesses/impls/index.d.ts +2 -0
- package/dist/harnesses/impls/index.js +9 -0
- package/dist/harnesses/impls/index.js.map +1 -1
- package/dist/harnesses/impls/jinn-repo-evaluator/eval-runner.d.ts +34 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/eval-runner.js +111 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/eval-runner.js.map +1 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/evaluator.d.ts +24 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/evaluator.js +19 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/evaluator.js.map +1 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/harness.d.ts +64 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/harness.js +125 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/harness.js.map +1 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/repro.d.ts +32 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/repro.js +73 -0
- package/dist/harnesses/impls/jinn-repo-evaluator/repro.js.map +1 -0
- package/dist/harnesses/impls/learner/adapters/claude-code.js +5 -0
- package/dist/harnesses/impls/learner/adapters/claude-code.js.map +1 -1
- package/dist/harnesses/impls/learner/harness.d.ts +17 -1
- package/dist/harnesses/impls/learner/harness.js +51 -1
- package/dist/harnesses/impls/learner/harness.js.map +1 -1
- package/dist/harnesses/impls/learner/harvest.d.ts +2 -0
- package/dist/harnesses/impls/learner/harvest.js +51 -1
- 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/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/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 +10 -0
- package/dist/harnesses/readiness-registry.js +13 -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 +16 -1
- package/dist/learner/revert-decision.js +38 -18
- package/dist/learner/revert-decision.js.map +1 -1
- package/dist/learner/revert-stats.d.ts +14 -0
- package/dist/learner/revert-stats.js +42 -0
- package/dist/learner/revert-stats.js.map +1 -1
- 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 +94 -25
- package/dist/main.js.map +1 -1
- package/dist/mcp/operator-server.js +1 -1
- package/dist/mcp/operator-server.js.map +1 -1
- package/dist/mcp/server.js +1 -1
- package/dist/mcp/server.js.map +1 -1
- 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 +4 -0
- 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 +7 -1
- package/dist/preflight/pidfile-liveness.js +14 -0
- package/dist/preflight/pidfile-liveness.js.map +1 -1
- package/dist/rpc/transport.d.ts +43 -5
- package/dist/rpc/transport.js +131 -30
- package/dist/rpc/transport.js.map +1 -1
- package/dist/scripts/swe-rebench-v2-seed-pool.json +2 -1
- package/dist/solver-nets/registry.d.ts +19 -0
- package/dist/solver-nets/registry.js +95 -66
- package/dist/solver-nets/registry.js.map +1 -1
- package/dist/solver-types/_jinn-repo-pool.d.ts +27 -0
- package/dist/solver-types/_jinn-repo-pool.js +27 -0
- package/dist/solver-types/_jinn-repo-pool.js.map +1 -0
- 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-state.d.ts +9 -0
- package/dist/solver-types/_swe-rebench-v2-state.js +14 -0
- package/dist/solver-types/_swe-rebench-v2-state.js.map +1 -1
- package/dist/solver-types/_swe-rebench-v2-validated-pool.d.ts +30 -0
- package/dist/solver-types/_swe-rebench-v2-validated-pool.js +40 -0
- package/dist/solver-types/_swe-rebench-v2-validated-pool.js.map +1 -1
- package/dist/solver-types/index.js +2 -0
- package/dist/solver-types/index.js.map +1 -1
- package/dist/solver-types/jinn-repo-admit.d.ts +17 -0
- package/dist/solver-types/jinn-repo-admit.js +16 -0
- package/dist/solver-types/jinn-repo-admit.js.map +1 -0
- package/dist/solver-types/jinn-repo-auto.d.ts +60 -0
- package/dist/solver-types/jinn-repo-auto.js +163 -0
- package/dist/solver-types/jinn-repo-auto.js.map +1 -0
- package/dist/solver-types/jinn-repo-definition.d.ts +15 -0
- package/dist/solver-types/jinn-repo-definition.js +34 -0
- package/dist/solver-types/jinn-repo-definition.js.map +1 -0
- package/dist/solver-types/jinn-repo-extract.d.ts +16 -0
- package/dist/solver-types/jinn-repo-extract.js +32 -0
- package/dist/solver-types/jinn-repo-extract.js.map +1 -0
- package/dist/solver-types/jinn-repo.d.ts +21 -0
- package/dist/solver-types/jinn-repo.js +23 -0
- package/dist/solver-types/jinn-repo.js.map +1 -0
- package/dist/solver-types/learner-loop-test.js +1 -1
- package/dist/solver-types/learner-loop-test.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.d.ts +2 -0
- package/dist/solver-types/swe-rebench-v2.js +115 -10
- package/dist/solver-types/swe-rebench-v2.js.map +1 -1
- package/dist/solvernets/launched-record-dispatcher.d.ts +5 -0
- package/dist/solvernets/launched-record-dispatcher.js +8 -1
- package/dist/solvernets/launched-record-dispatcher.js.map +1 -1
- package/dist/solvernets/registry-client-erc8004.js +29 -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 +1 -1
- package/dist/solvernets/store.js +8 -3
- package/dist/solvernets/store.js.map +1 -1
- package/dist/spend/ai-units-config.d.ts +10 -0
- package/dist/spend/ai-units-config.js +7 -1
- package/dist/spend/ai-units-config.js.map +1 -1
- package/dist/spend/ai-units.d.ts +51 -0
- package/dist/spend/ai-units.js +73 -0
- package/dist/spend/ai-units.js.map +1 -1
- package/dist/spend/record.js +12 -5
- package/dist/spend/record.js.map +1 -1
- package/dist/store/store.d.ts +91 -5
- package/dist/store/store.js +170 -7
- package/dist/store/store.js.map +1 -1
- package/dist/trajectory/harness-bundle-schema.d.ts +1 -1
- package/dist/trajectory/harness-bundle-schema.js +1 -1
- package/dist/trajectory/harness-bundle-schema.js.map +1 -1
- package/dist/trajectory/schema.d.ts +1 -1
- package/dist/trajectory/schema.js +1 -1
- package/dist/trajectory/schema.js.map +1 -1
- package/dist/trajectory/transcript-parsers/types.d.ts +1 -1
- package/dist/trajectory/transcript-parsers/types.js +1 -1
- package/dist/trajectory/transcript-parsers/types.js.map +1 -1
- package/dist/types/envelope.d.ts +1 -1
- package/dist/types/envelope.js +1 -1
- package/dist/types/envelope.js.map +1 -1
- package/dist/types/payloads/index.d.ts +1 -1
- package/dist/types/payloads/index.js +7 -1
- package/dist/types/payloads/index.js.map +1 -1
- package/dist/types/payloads/portfolio-v0.d.ts +1 -1
- package/dist/types/payloads/portfolio-v0.js +1 -1
- package/dist/types/payloads/portfolio-v0.js.map +1 -1
- package/dist/types/payloads/prediction-apy-v0.d.ts +1 -1
- package/dist/types/payloads/prediction-apy-v0.js +1 -1
- package/dist/types/payloads/prediction-apy-v0.js.map +1 -1
- package/dist/types/payloads/prediction-v0.d.ts +1 -1
- package/dist/types/payloads/prediction-v0.js +1 -1
- package/dist/types/payloads/prediction-v0.js.map +1 -1
- package/dist/types/portfolio.d.ts +1 -1
- package/dist/types/portfolio.js +1 -1
- package/dist/types/portfolio.js.map +1 -1
- package/dist/types/prediction-apy.d.ts +1 -1
- package/dist/types/prediction-apy.js +1 -1
- package/dist/types/prediction-apy.js.map +1 -1
- package/dist/types/prediction.d.ts +1 -1
- package/dist/types/prediction.js +1 -1
- package/dist/types/prediction.js.map +1 -1
- package/dist/types/session-provenance.d.ts +1 -1
- package/dist/types/session-provenance.js +1 -1
- package/dist/types/session-provenance.js.map +1 -1
- package/dist/types/task-document.d.ts +1 -1
- package/dist/types/task-document.js +1 -1
- package/dist/types/task-document.js.map +1 -1
- package/dist/types/task.d.ts +1 -1
- package/dist/types/task.js +1 -1
- package/dist/types/task.js.map +1 -1
- package/dist/types/window.d.ts +1 -1
- package/dist/types/window.js +1 -1
- package/dist/types/window.js.map +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/checkpoint.d.ts +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/checkpoint.js +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/contracts.d.ts +3 -2
- package/dist/vendor/@jinn-network/sdk/dist/contracts.js +49 -0
- package/dist/vendor/@jinn-network/sdk/dist/jinn-repo.d.ts +44 -0
- package/dist/vendor/@jinn-network/sdk/dist/jinn-repo.js +25 -0
- package/dist/vendor/@jinn-network/sdk/dist/json-schema.d.ts +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/json-schema.js +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/payloads/jinn-repo.d.ts +38 -0
- package/dist/vendor/@jinn-network/sdk/dist/payloads/jinn-repo.js +22 -0
- package/dist/vendor/@jinn-network/sdk/dist/payloads/prediction-v1.d.ts +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/payloads/prediction-v1.js +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/payloads/session-derived.d.ts +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/payloads/session-derived.js +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/payloads/swe-rebench-v2.d.ts +109 -2
- package/dist/vendor/@jinn-network/sdk/dist/payloads/swe-rebench-v2.js +26 -2
- package/dist/vendor/@jinn-network/sdk/dist/prediction-v1.d.ts +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/prediction-v1.js +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/jinn-repo.d.ts +4 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/jinn-repo.js +2 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/manifest-schema.d.ts +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/manifest-schema.js +1 -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/dist/swe-rebench-v2.d.ts +1 -1
- package/dist/vendor/@jinn-network/sdk/dist/swe-rebench-v2.js +1 -1
- package/dist/vendor/@jinn-network/sdk/package.json +9 -1
- package/docker-compose.yml +3 -2
- package/package.json +23 -20
- package/plugins/jinn-repo-runtime/.claude-plugin/plugin.json +5 -0
- package/plugins/jinn-repo-runtime/.codex-plugin/plugin.json +39 -0
- package/plugins/jinn-repo-runtime/README.md +27 -0
- package/plugins/jinn-repo-runtime/hooks/hooks.json +16 -0
- package/plugins/jinn-repo-runtime/hooks/session-start +73 -0
- package/plugins/jinn-repo-runtime/jinn.plugin.json +11 -0
- package/plugins/jinn-repo-runtime/skills/task/SKILL.md +92 -0
- 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 +4 -0
- package/plugins/swe-rebench-v2-runtime/hooks/hooks.json +16 -0
- package/plugins/swe-rebench-v2-runtime/hooks/session-start +74 -0
- package/dist/dashboard/assets/index-CzKxvMcU.css +0 -32
- package/dist/dashboard/assets/index-yVemxHot.js +0 -351
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/solvernets/store.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAChC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC9E,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,CAAC,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/solvernets/store.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,8 +16,12 @@
|
|
|
16
16
|
import type { JinnConfig } from '../config.js';
|
|
17
17
|
import { type CredentialId } from './credential.js';
|
|
18
18
|
export interface AiUnitsDaemonConfig {
|
|
19
|
+
/** Unit caps — retained for the legacy /v1/status unit surface (#1006). */
|
|
19
20
|
capPerBlock: number;
|
|
20
21
|
capPerWeek: number;
|
|
22
|
+
/** USD-micros caps — what the gate now compares against (issue #1004). */
|
|
23
|
+
capPerBlockUsdMicros: number;
|
|
24
|
+
capPerWeekUsdMicros: number;
|
|
21
25
|
/** manifestCid -> credentialId (set only when the harness has one). */
|
|
22
26
|
manifestCredentials: Record<string, CredentialId>;
|
|
23
27
|
/**
|
|
@@ -26,6 +30,12 @@ export interface AiUnitsDaemonConfig {
|
|
|
26
30
|
* one-time warn rather than silently halting claims.
|
|
27
31
|
*/
|
|
28
32
|
manifestProjectedAiUnits: Record<string, number | null>;
|
|
33
|
+
/**
|
|
34
|
+
* manifestCid -> projected USD micros per task (issue #1004). `null` =
|
|
35
|
+
* unpriceable model (gate fails open with a warn), same semantics as
|
|
36
|
+
* {@link manifestProjectedAiUnits}.
|
|
37
|
+
*/
|
|
38
|
+
manifestProjectedUsdMicros: Record<string, number | null>;
|
|
29
39
|
/**
|
|
30
40
|
* manifestCid -> the model id from the joined SolverNet config. Threaded
|
|
31
41
|
* onto the per-request activity row at claim time so the row carries
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import { resolveCredentialId } from './credential.js';
|
|
2
|
-
import { projectAiUnits, resolveReferenceCeiling } from './ai-units.js';
|
|
2
|
+
import { projectAiUnits, projectTaskUsdMicros, resolveReferenceCeiling, resolveReferenceCeilingUsdMicros, } from './ai-units.js';
|
|
3
3
|
export function buildAiUnitsConfig(config, env,
|
|
4
4
|
/** Optional home dir override for resolveCredentialId's disk probe — tests only. */
|
|
5
5
|
homeDirOverride) {
|
|
6
6
|
const { units_per_block, units_per_week } = resolveReferenceCeiling(env);
|
|
7
|
+
const { usd_micros_per_block, usd_micros_per_week } = resolveReferenceCeilingUsdMicros(env);
|
|
7
8
|
const manifestCredentials = {};
|
|
8
9
|
const manifestProjectedAiUnits = {};
|
|
10
|
+
const manifestProjectedUsdMicros = {};
|
|
9
11
|
const manifestModels = {};
|
|
10
12
|
for (const [manifestCid, entry] of Object.entries(config.joinedSolverNets ?? {})) {
|
|
11
13
|
const credentialId = resolveCredentialId(entry.harness, env, homeDirOverride);
|
|
@@ -13,6 +15,7 @@ homeDirOverride) {
|
|
|
13
15
|
continue;
|
|
14
16
|
manifestCredentials[manifestCid] = credentialId;
|
|
15
17
|
manifestProjectedAiUnits[manifestCid] = projectAiUnits(entry.harness, entry.model, credentialId);
|
|
18
|
+
manifestProjectedUsdMicros[manifestCid] = projectTaskUsdMicros(entry.harness, entry.model, credentialId);
|
|
16
19
|
manifestModels[manifestCid] = entry.model;
|
|
17
20
|
}
|
|
18
21
|
if (Object.keys(manifestCredentials).length === 0)
|
|
@@ -20,8 +23,11 @@ homeDirOverride) {
|
|
|
20
23
|
return {
|
|
21
24
|
capPerBlock: units_per_block,
|
|
22
25
|
capPerWeek: units_per_week,
|
|
26
|
+
capPerBlockUsdMicros: usd_micros_per_block,
|
|
27
|
+
capPerWeekUsdMicros: usd_micros_per_week,
|
|
23
28
|
manifestCredentials,
|
|
24
29
|
manifestProjectedAiUnits,
|
|
30
|
+
manifestProjectedUsdMicros,
|
|
25
31
|
manifestModels,
|
|
26
32
|
};
|
|
27
33
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ai-units-config.js","sourceRoot":"","sources":["../../src/spend/ai-units-config.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,iBAAiB,CAAC;AACzE,OAAO,
|
|
1
|
+
{"version":3,"file":"ai-units-config.js","sourceRoot":"","sources":["../../src/spend/ai-units-config.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,iBAAiB,CAAC;AACzE,OAAO,EACL,cAAc,EACd,oBAAoB,EACpB,uBAAuB,EACvB,gCAAgC,GACjC,MAAM,eAAe,CAAC;AAgCvB,MAAM,UAAU,kBAAkB,CAChC,MAA4C,EAC5C,GAAsB;AACtB,oFAAoF;AACpF,eAAwB;IAExB,MAAM,EAAE,eAAe,EAAE,cAAc,EAAE,GAAG,uBAAuB,CAAC,GAAG,CAAC,CAAC;IACzE,MAAM,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,GAAG,gCAAgC,CAAC,GAAG,CAAC,CAAC;IAE5F,MAAM,mBAAmB,GAAiC,EAAE,CAAC;IAC7D,MAAM,wBAAwB,GAAkC,EAAE,CAAC;IACnE,MAAM,0BAA0B,GAAkC,EAAE,CAAC;IACrE,MAAM,cAAc,GAAuC,EAAE,CAAC;IAE9D,KAAK,MAAM,CAAC,WAAW,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,gBAAgB,IAAI,EAAE,CAAC,EAAE,CAAC;QACjF,MAAM,YAAY,GAAG,mBAAmB,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,eAAe,CAAC,CAAC;QAC9E,IAAI,CAAC,YAAY;YAAE,SAAS;QAC5B,mBAAmB,CAAC,WAAW,CAAC,GAAG,YAAY,CAAC;QAChD,wBAAwB,CAAC,WAAW,CAAC,GAAG,cAAc,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QACjG,0BAA0B,CAAC,WAAW,CAAC,GAAG,oBAAoB,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QACzG,cAAc,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC;IAC5C,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,SAAS,CAAC;IAEpE,OAAO;QACL,WAAW,EAAE,eAAe;QAC5B,UAAU,EAAE,cAAc;QAC1B,oBAAoB,EAAE,oBAAoB;QAC1C,mBAAmB,EAAE,mBAAmB;QACxC,mBAAmB;QACnB,wBAAwB;QACxB,0BAA0B;QAC1B,cAAc;KACf,CAAC;AACJ,CAAC"}
|
package/dist/spend/ai-units.d.ts
CHANGED
|
@@ -18,6 +18,13 @@
|
|
|
18
18
|
* The cap is layered with the existing per-credential USD `spendCaps`
|
|
19
19
|
* spend-cap gate from PR #345/#346 — both gates run; the more
|
|
20
20
|
* conservative one wins. This module owns the AI-units side only.
|
|
21
|
+
*
|
|
22
|
+
* Issue #1004: the gate's comparison now runs in **USD** (actual harvested
|
|
23
|
+
* spend vs a USD ceiling), not projected AI units. The peg below survives
|
|
24
|
+
* as the calibration constant deriving that USD ceiling and as the
|
|
25
|
+
* presentation-layer conversion for the legacy unit fields the SPA still
|
|
26
|
+
* reads. For subscription credentials the USD ceiling is a *proxy* budget —
|
|
27
|
+
* it bounds Jinn-attributable model cost, not the provider's plan quota.
|
|
21
28
|
*/
|
|
22
29
|
/**
|
|
23
30
|
* Calibration peg: the USD cost of one GPT-5.4-mini Codex-Plus 6h block.
|
|
@@ -26,6 +33,11 @@
|
|
|
26
33
|
*
|
|
27
34
|
* Conservative — biases toward over-warning rather than under-warning so
|
|
28
35
|
* the ceiling pauses early rather than late.
|
|
36
|
+
*
|
|
37
|
+
* Issue #1004: demoted to a calibration constant — it derives
|
|
38
|
+
* {@link REFERENCE_CEILING_USD_MICROS} and converts the legacy unit fields
|
|
39
|
+
* for presentation, but no longer appears in the gate's comparison. Kept
|
|
40
|
+
* exported because the SPA's `HarnessFootprintPanel.tsx` imports it (#1006).
|
|
29
41
|
*/
|
|
30
42
|
export declare const GPT_5_4_MINI_USD_PER_BLOCK = 0.5;
|
|
31
43
|
/**
|
|
@@ -40,6 +52,21 @@ export declare const REFERENCE_CEILING: {
|
|
|
40
52
|
readonly units_per_block: number;
|
|
41
53
|
readonly units_per_week: number;
|
|
42
54
|
};
|
|
55
|
+
/**
|
|
56
|
+
* USD-micros ceiling (issue #1004). The gate now compares **actual USD
|
|
57
|
+
* spend** against this ceiling rather than projected AI units. Derived
|
|
58
|
+
* directly from {@link REFERENCE_CEILING} through the GPT-5.4-mini peg:
|
|
59
|
+
* usd_micros = units / 100 * GPT_5_4_MINI_USD_PER_BLOCK * 1_000_000.
|
|
60
|
+
* Default 100 units/block => $0.50/block (500_000 micros); 2800 units/week
|
|
61
|
+
* => $14/week (14_000_000 micros). Calibration is preserved; only the
|
|
62
|
+
* comparison unit changed. For subscription credentials this USD budget is
|
|
63
|
+
* a *proxy* — it bounds Jinn-attributable model cost, not the provider's
|
|
64
|
+
* plan quota directly.
|
|
65
|
+
*/
|
|
66
|
+
export declare const REFERENCE_CEILING_USD_MICROS: {
|
|
67
|
+
readonly usd_micros_per_block: number;
|
|
68
|
+
readonly usd_micros_per_week: number;
|
|
69
|
+
};
|
|
43
70
|
/**
|
|
44
71
|
* Project the AI-unit cost of one task for a harness/model combination.
|
|
45
72
|
*
|
|
@@ -64,6 +91,20 @@ export declare const REFERENCE_CEILING: {
|
|
|
64
91
|
* call-site clarity and future-proofing.
|
|
65
92
|
*/
|
|
66
93
|
export declare function projectAiUnits(harness: string | undefined, model: string | undefined, _credentialId?: string | null): number | null;
|
|
94
|
+
/**
|
|
95
|
+
* Project the per-task cost of one harness/model combination in USD micros
|
|
96
|
+
* (issue #1004). This is the in-flight debit the gate books for a claim
|
|
97
|
+
* before its actual cost is harvested. Same harness classification as
|
|
98
|
+
* {@link projectAiUnits}:
|
|
99
|
+
* - `0` for harnesses that make no marginal LLM call,
|
|
100
|
+
* - `null` when a paid-LLM harness's model is unknown to the cost table
|
|
101
|
+
* (gate fails open with a warn),
|
|
102
|
+
* - otherwise `round(estimateModelCost(model).usd * 1_000_000)`.
|
|
103
|
+
*
|
|
104
|
+
* `_credentialId` does not change the projection (the model costs the same
|
|
105
|
+
* regardless of auth path); it labels the accounting bucket only.
|
|
106
|
+
*/
|
|
107
|
+
export declare function projectTaskUsdMicros(harness: string | undefined, model: string | undefined, _credentialId?: string | null): number | null;
|
|
67
108
|
/**
|
|
68
109
|
* Resolve the active ceiling from env. CI / tests override the baked-in
|
|
69
110
|
* 100 units via `JINN_AI_UNITS_CEILING_OVERRIDE`. Accepts:
|
|
@@ -78,6 +119,16 @@ export declare function resolveReferenceCeiling(env: NodeJS.ProcessEnv): {
|
|
|
78
119
|
units_per_block: number;
|
|
79
120
|
units_per_week: number;
|
|
80
121
|
};
|
|
122
|
+
/**
|
|
123
|
+
* Resolve the active USD-micros ceiling from env (issue #1004). Reuses
|
|
124
|
+
* {@link resolveReferenceCeiling} so the `JINN_AI_UNITS_CEILING_OVERRIDE`
|
|
125
|
+
* parsing (integer or `<block>:<week>`, malformed-warn, default fallback)
|
|
126
|
+
* lives in one place, then converts both bounds through the peg.
|
|
127
|
+
*/
|
|
128
|
+
export declare function resolveReferenceCeilingUsdMicros(env: NodeJS.ProcessEnv): {
|
|
129
|
+
usd_micros_per_block: number;
|
|
130
|
+
usd_micros_per_week: number;
|
|
131
|
+
};
|
|
81
132
|
/** Start of the next 6h UTC-aligned block after `now`. */
|
|
82
133
|
export declare function blockResetsAtUtc(now: Date): Date;
|
|
83
134
|
/**
|
package/dist/spend/ai-units.js
CHANGED
|
@@ -18,6 +18,13 @@
|
|
|
18
18
|
* The cap is layered with the existing per-credential USD `spendCaps`
|
|
19
19
|
* spend-cap gate from PR #345/#346 — both gates run; the more
|
|
20
20
|
* conservative one wins. This module owns the AI-units side only.
|
|
21
|
+
*
|
|
22
|
+
* Issue #1004: the gate's comparison now runs in **USD** (actual harvested
|
|
23
|
+
* spend vs a USD ceiling), not projected AI units. The peg below survives
|
|
24
|
+
* as the calibration constant deriving that USD ceiling and as the
|
|
25
|
+
* presentation-layer conversion for the legacy unit fields the SPA still
|
|
26
|
+
* reads. For subscription credentials the USD ceiling is a *proxy* budget —
|
|
27
|
+
* it bounds Jinn-attributable model cost, not the provider's plan quota.
|
|
21
28
|
*/
|
|
22
29
|
import { estimateModelCost } from '../harnesses/cost-estimates.js';
|
|
23
30
|
import { CLAUDE_CODE_HARNESS, CODEX_HARNESS, HERMES_AGENT_HARNESS, canonicalHarnessName, } from '../harnesses/names.js';
|
|
@@ -28,6 +35,11 @@ import { CLAUDE_CODE_HARNESS, CODEX_HARNESS, HERMES_AGENT_HARNESS, canonicalHarn
|
|
|
28
35
|
*
|
|
29
36
|
* Conservative — biases toward over-warning rather than under-warning so
|
|
30
37
|
* the ceiling pauses early rather than late.
|
|
38
|
+
*
|
|
39
|
+
* Issue #1004: demoted to a calibration constant — it derives
|
|
40
|
+
* {@link REFERENCE_CEILING_USD_MICROS} and converts the legacy unit fields
|
|
41
|
+
* for presentation, but no longer appears in the gate's comparison. Kept
|
|
42
|
+
* exported because the SPA's `HarnessFootprintPanel.tsx` imports it (#1006).
|
|
31
43
|
*/
|
|
32
44
|
export const GPT_5_4_MINI_USD_PER_BLOCK = 0.5;
|
|
33
45
|
/**
|
|
@@ -42,6 +54,25 @@ export const REFERENCE_CEILING = {
|
|
|
42
54
|
units_per_block: 100,
|
|
43
55
|
units_per_week: 100 * 28,
|
|
44
56
|
};
|
|
57
|
+
/**
|
|
58
|
+
* USD-micros ceiling (issue #1004). The gate now compares **actual USD
|
|
59
|
+
* spend** against this ceiling rather than projected AI units. Derived
|
|
60
|
+
* directly from {@link REFERENCE_CEILING} through the GPT-5.4-mini peg:
|
|
61
|
+
* usd_micros = units / 100 * GPT_5_4_MINI_USD_PER_BLOCK * 1_000_000.
|
|
62
|
+
* Default 100 units/block => $0.50/block (500_000 micros); 2800 units/week
|
|
63
|
+
* => $14/week (14_000_000 micros). Calibration is preserved; only the
|
|
64
|
+
* comparison unit changed. For subscription credentials this USD budget is
|
|
65
|
+
* a *proxy* — it bounds Jinn-attributable model cost, not the provider's
|
|
66
|
+
* plan quota directly.
|
|
67
|
+
*/
|
|
68
|
+
export const REFERENCE_CEILING_USD_MICROS = {
|
|
69
|
+
usd_micros_per_block: unitsToUsdMicros(REFERENCE_CEILING.units_per_block),
|
|
70
|
+
usd_micros_per_week: unitsToUsdMicros(REFERENCE_CEILING.units_per_week),
|
|
71
|
+
};
|
|
72
|
+
/** Convert an AI-unit count to USD micros through the GPT-5.4-mini peg. */
|
|
73
|
+
function unitsToUsdMicros(units) {
|
|
74
|
+
return Math.round((units / 100) * GPT_5_4_MINI_USD_PER_BLOCK * 1_000_000);
|
|
75
|
+
}
|
|
45
76
|
/** 6h block in milliseconds — UTC blocks start at 00:00 / 06:00 / 12:00 / 18:00. */
|
|
46
77
|
const SIX_HOUR_BLOCK_MS = 6 * 60 * 60 * 1_000;
|
|
47
78
|
/** 7 days in milliseconds — UTC-aligned. */
|
|
@@ -85,6 +116,35 @@ export function projectAiUnits(harness, model, _credentialId) {
|
|
|
85
116
|
return null;
|
|
86
117
|
return (cost.usd / GPT_5_4_MINI_USD_PER_BLOCK) * 100;
|
|
87
118
|
}
|
|
119
|
+
/**
|
|
120
|
+
* Project the per-task cost of one harness/model combination in USD micros
|
|
121
|
+
* (issue #1004). This is the in-flight debit the gate books for a claim
|
|
122
|
+
* before its actual cost is harvested. Same harness classification as
|
|
123
|
+
* {@link projectAiUnits}:
|
|
124
|
+
* - `0` for harnesses that make no marginal LLM call,
|
|
125
|
+
* - `null` when a paid-LLM harness's model is unknown to the cost table
|
|
126
|
+
* (gate fails open with a warn),
|
|
127
|
+
* - otherwise `round(estimateModelCost(model).usd * 1_000_000)`.
|
|
128
|
+
*
|
|
129
|
+
* `_credentialId` does not change the projection (the model costs the same
|
|
130
|
+
* regardless of auth path); it labels the accounting bucket only.
|
|
131
|
+
*/
|
|
132
|
+
export function projectTaskUsdMicros(harness, model, _credentialId) {
|
|
133
|
+
if (!harness)
|
|
134
|
+
return null;
|
|
135
|
+
const canonical = canonicalHarnessName(harness);
|
|
136
|
+
const isPaidLlmHarness = canonical === CLAUDE_CODE_HARNESS ||
|
|
137
|
+
canonical === CODEX_HARNESS ||
|
|
138
|
+
canonical === HERMES_AGENT_HARNESS;
|
|
139
|
+
if (!isPaidLlmHarness)
|
|
140
|
+
return 0;
|
|
141
|
+
if (!model)
|
|
142
|
+
return null;
|
|
143
|
+
const cost = estimateModelCost(model);
|
|
144
|
+
if (!cost)
|
|
145
|
+
return null;
|
|
146
|
+
return Math.round(cost.usd * 1_000_000);
|
|
147
|
+
}
|
|
88
148
|
/**
|
|
89
149
|
* Resolve the active ceiling from env. CI / tests override the baked-in
|
|
90
150
|
* 100 units via `JINN_AI_UNITS_CEILING_OVERRIDE`. Accepts:
|
|
@@ -118,6 +178,19 @@ export function resolveReferenceCeiling(env) {
|
|
|
118
178
|
warnMalformedOverride(raw);
|
|
119
179
|
return { units_per_block: REFERENCE_CEILING.units_per_block, units_per_week: REFERENCE_CEILING.units_per_week };
|
|
120
180
|
}
|
|
181
|
+
/**
|
|
182
|
+
* Resolve the active USD-micros ceiling from env (issue #1004). Reuses
|
|
183
|
+
* {@link resolveReferenceCeiling} so the `JINN_AI_UNITS_CEILING_OVERRIDE`
|
|
184
|
+
* parsing (integer or `<block>:<week>`, malformed-warn, default fallback)
|
|
185
|
+
* lives in one place, then converts both bounds through the peg.
|
|
186
|
+
*/
|
|
187
|
+
export function resolveReferenceCeilingUsdMicros(env) {
|
|
188
|
+
const units = resolveReferenceCeiling(env);
|
|
189
|
+
return {
|
|
190
|
+
usd_micros_per_block: unitsToUsdMicros(units.units_per_block),
|
|
191
|
+
usd_micros_per_week: unitsToUsdMicros(units.units_per_week),
|
|
192
|
+
};
|
|
193
|
+
}
|
|
121
194
|
function warnMalformedOverride(raw) {
|
|
122
195
|
// One-time warn per resolve call — the function is only invoked at
|
|
123
196
|
// startup, so a module-level memo is unnecessary. Surfaces the operator's
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ai-units.js","sourceRoot":"","sources":["../../src/spend/ai-units.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"ai-units.js","sourceRoot":"","sources":["../../src/spend/ai-units.ts"],"names":[],"mappings":"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"}
|
package/dist/spend/record.js
CHANGED
|
@@ -22,11 +22,18 @@ export function recordTaskCost(store, args, env = process.env) {
|
|
|
22
22
|
model: usage.model,
|
|
23
23
|
detail: usage.estimated ? 'estimated' : 'observed',
|
|
24
24
|
});
|
|
25
|
-
// Issue #
|
|
26
|
-
// row + set claim_status='delivered'.
|
|
27
|
-
//
|
|
28
|
-
//
|
|
29
|
-
|
|
25
|
+
// Issue #1004: fill actual_cost_usd_micros on the per-request claimed
|
|
26
|
+
// row + set claim_status='delivered'. The gate's accumulator reads this
|
|
27
|
+
// column (COALESCE actual, estimated) so the delivered actual replaces
|
|
28
|
+
// the claim-time estimate in the running total. For subscription
|
|
29
|
+
// credentials the resulting USD figure is a *proxy* budget — it bounds
|
|
30
|
+
// Jinn-attributable model cost, not the provider's plan quota directly.
|
|
31
|
+
// `usage.estimated` is carried through (AC4) so a telemetry-less harness
|
|
32
|
+
// such as Hermes, whose actual cost is itself a heuristic, is not
|
|
33
|
+
// presented as metered by the gate. ai_units stays as captured at claim
|
|
34
|
+
// time (legacy unit surface, #1006). Idempotent: no-op when no claimed
|
|
35
|
+
// row exists for this request id.
|
|
36
|
+
store.finalizeClaimDelivered(args.requestId, actualCostUsdMicros, usage.estimated);
|
|
30
37
|
}
|
|
31
38
|
catch (err) {
|
|
32
39
|
console.warn(`[spend] failed to record task cost for ${args.requestId}: ` +
|
package/dist/spend/record.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"record.js","sourceRoot":"","sources":["../../src/spend/record.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEjD;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAC5B,KAAY,EACZ,IAMC,EACD,MAAyB,OAAO,CAAC,GAAG;IAEpC,IAAI,CAAC;QACH,MAAM,YAAY,GAAG,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAC5D,IAAI,CAAC,YAAY;YAAE,OAAO;QAC1B,MAAM,KAAK,GAAG,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7E,MAAM,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,GAAG,SAAS,CAAC,CAAC;QAClE,KAAK,CAAC,mBAAmB,CAAC;YACxB,EAAE,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YAC5B,IAAI,EAAE,WAAW;YACjB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,YAAY;YACZ,aAAa,EAAE,mBAAmB;YAClC,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU;SACnD,CAAC,CAAC;QACH,
|
|
1
|
+
{"version":3,"file":"record.js","sourceRoot":"","sources":["../../src/spend/record.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEjD;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAC5B,KAAY,EACZ,IAMC,EACD,MAAyB,OAAO,CAAC,GAAG;IAEpC,IAAI,CAAC;QACH,MAAM,YAAY,GAAG,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAC5D,IAAI,CAAC,YAAY;YAAE,OAAO;QAC1B,MAAM,KAAK,GAAG,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7E,MAAM,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,GAAG,SAAS,CAAC,CAAC;QAClE,KAAK,CAAC,mBAAmB,CAAC;YACxB,EAAE,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YAC5B,IAAI,EAAE,WAAW;YACjB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,YAAY;YACZ,aAAa,EAAE,mBAAmB;YAClC,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU;SACnD,CAAC,CAAC;QACH,sEAAsE;QACtE,wEAAwE;QACxE,uEAAuE;QACvE,iEAAiE;QACjE,uEAAuE;QACvE,wEAAwE;QACxE,yEAAyE;QACzE,kEAAkE;QAClE,wEAAwE;QACxE,uEAAuE;QACvE,kCAAkC;QAClC,KAAK,CAAC,sBAAsB,CAAC,IAAI,CAAC,SAAS,EAAE,mBAAmB,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;IACrF,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CACV,0CAA0C,IAAI,CAAC,SAAS,IAAI;YAC1D,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CACxD,CAAC;IACJ,CAAC;AACH,CAAC"}
|
package/dist/store/store.d.ts
CHANGED
|
@@ -344,6 +344,39 @@ export declare class Store {
|
|
|
344
344
|
* Issue #815.
|
|
345
345
|
*/
|
|
346
346
|
aiUnitsThisWeek(credentialId: string, now?: Date): number;
|
|
347
|
+
/**
|
|
348
|
+
* Actual-spend accumulator for the current 6h UTC block (issue #1004).
|
|
349
|
+
*
|
|
350
|
+
* Sums `COALESCE(actual_cost_usd_micros, estimated_cost_usd_micros, 0)`
|
|
351
|
+
* over rows whose `claim_status` is `'claimed'` or `'delivered'`:
|
|
352
|
+
* - delivered rows contribute the real harvested cost (`actual_*`),
|
|
353
|
+
* - in-flight claimed rows contribute their estimate so a burst of
|
|
354
|
+
* concurrent claims cannot slip the cap before any of them deliver,
|
|
355
|
+
* - failed claims (status `'claim_failed'`) are excluded.
|
|
356
|
+
*
|
|
357
|
+
* `estimated` is true iff the summed figure includes any estimate-backed
|
|
358
|
+
* cost: an in-flight `claimed` row with no `actual_cost_usd_micros` yet,
|
|
359
|
+
* OR a `delivered` row whose actual cost is itself a heuristic
|
|
360
|
+
* (`actual_cost_estimated = 1` — a telemetry-less harness such as Hermes).
|
|
361
|
+
* It is false only when every contributing row is harvested actual
|
|
362
|
+
* telemetry. The gate surfaces this so an estimate-backed figure is not
|
|
363
|
+
* presented as metered. Block boundaries mirror `aiUnitsThisBlock`.
|
|
364
|
+
*/
|
|
365
|
+
usdMicrosThisBlock(credentialId: string, now?: Date): {
|
|
366
|
+
usdMicros: number;
|
|
367
|
+
estimated: boolean;
|
|
368
|
+
};
|
|
369
|
+
/**
|
|
370
|
+
* Actual-spend accumulator for the trailing 7-day rolling window from
|
|
371
|
+
* `now` (issue #1004). Same COALESCE + claim_status filter + `estimated`
|
|
372
|
+
* semantics as {@link usdMicrosThisBlock}.
|
|
373
|
+
*/
|
|
374
|
+
usdMicrosThisWeek(credentialId: string, now?: Date): {
|
|
375
|
+
usdMicros: number;
|
|
376
|
+
estimated: boolean;
|
|
377
|
+
};
|
|
378
|
+
/** Shared COALESCE-sum + estimate-flag query for the USD accumulators. */
|
|
379
|
+
private sumUsdMicros;
|
|
347
380
|
/**
|
|
348
381
|
* True iff an `ai_units_cap_reached` row exists for the given
|
|
349
382
|
* (credentialId, window, blockId). Used by the daemon to hydrate the
|
|
@@ -357,12 +390,22 @@ export declare class Store {
|
|
|
357
390
|
hasAiUnitsCapReachedFor(credentialId: string, window: 'block' | 'week', blockId: string): boolean;
|
|
358
391
|
/**
|
|
359
392
|
* Mark the per-request `claimed` row as `delivered` and record
|
|
360
|
-
* `actual_cost_usd_micros
|
|
361
|
-
*
|
|
362
|
-
*
|
|
363
|
-
*
|
|
393
|
+
* `actual_cost_usd_micros` (issue #1004 — the gate's accumulator now
|
|
394
|
+
* reads this column via COALESCE, so a delivered row's real harvested
|
|
395
|
+
* cost replaces its claim-time estimate in the running total). The
|
|
396
|
+
* `ai_units` projection captured at claim time is intentionally NOT
|
|
397
|
+
* recomputed — it remains the per-task estimate for the legacy unit
|
|
398
|
+
* surfaces. For subscription credentials the resulting USD figure is a
|
|
399
|
+
* *proxy* budget, not an exact bound on the provider's plan quota.
|
|
400
|
+
*
|
|
401
|
+
* `actualCostEstimated` (issue #1004, AC4) records whether the actual
|
|
402
|
+
* cost is itself a heuristic — true for a telemetry-less harness such as
|
|
403
|
+
* Hermes whose `harvestHarnessUsage` falls back to an a-priori estimate,
|
|
404
|
+
* false when the figure is harvested telemetry. The gate reads it so a
|
|
405
|
+
* delivered-but-heuristic row reports `estimated: true` rather than being
|
|
406
|
+
* presented as metered. Idempotent: a no-op when no `claimed` row exists.
|
|
364
407
|
*/
|
|
365
|
-
finalizeClaimDelivered(requestId: string, actualCostUsdMicros: number): void;
|
|
408
|
+
finalizeClaimDelivered(requestId: string, actualCostUsdMicros: number, actualCostEstimated: boolean): void;
|
|
366
409
|
/** Newer events first, then ascending id for `jinn logs --follow` (oldest in batch printed first in caller). */
|
|
367
410
|
getActivityEventsAfterId(afterId: number, limit: number): ActivityEventRow[];
|
|
368
411
|
/**
|
|
@@ -499,6 +542,49 @@ export declare class Store {
|
|
|
499
542
|
queryEnvelopeProjections(query?: EnvelopeProjectionQuery): EnvelopeProjection[];
|
|
500
543
|
saveErc8004Anchor(input: Erc8004AnchorInput): void;
|
|
501
544
|
listErc8004AnchorsByEnvelopeCids(envelopeCids: readonly string[]): Erc8004AnchorRow[];
|
|
545
|
+
/**
|
|
546
|
+
* Upsert one held-out eval result (issue #818). PK is
|
|
547
|
+
* `(checkpoint_cid, slate_version, instance_id)` so a re-run overwrites.
|
|
548
|
+
* `passed` is null for `unscorable` rows.
|
|
549
|
+
*/
|
|
550
|
+
recordEvalResult(args: EvalResultRecord): void;
|
|
551
|
+
/**
|
|
552
|
+
* Aggregate the eval results for a (checkpoint, slate version):
|
|
553
|
+
* `scorable` = rows with `unscorable = 0`; `passed` = scorable rows with
|
|
554
|
+
* `passed = 1`. Unscorable rows are counted separately and never enter the
|
|
555
|
+
* denominator. A checkpoint with no rows yields all-zero (the orchestrator
|
|
556
|
+
* reads this to detect a not-yet-evaluated parent).
|
|
557
|
+
*/
|
|
558
|
+
getEvalAggregate(checkpoint_cid: string, slate_version: string): EvalAggregate;
|
|
559
|
+
/**
|
|
560
|
+
* Distinct `slate_hash` values recorded for a (checkpoint, slate version).
|
|
561
|
+
* The eval orchestrator reads this to detect slate-content drift under a
|
|
562
|
+
* stable version label — the held-out exam is only an honest before/after
|
|
563
|
+
* when the parent and child were scored on the SAME slate content (defeating
|
|
564
|
+
* confounder #1, task-selection). Empty when the checkpoint has no rows.
|
|
565
|
+
*/
|
|
566
|
+
getEvalSlateHashes(checkpoint_cid: string, slate_version: string): string[];
|
|
567
|
+
/** Per-task eval results for a (checkpoint, slate version), ordered by instance_id. */
|
|
568
|
+
getEvalResults(checkpoint_cid: string, slate_version: string): EvalResultRow[];
|
|
502
569
|
close(): void;
|
|
503
570
|
}
|
|
571
|
+
export interface EvalResultRecord {
|
|
572
|
+
checkpoint_cid: string;
|
|
573
|
+
slate_hash: string;
|
|
574
|
+
slate_version: string;
|
|
575
|
+
instance_id: string;
|
|
576
|
+
/** Pass/fail; ignored (stored NULL) when `unscorable` is true. */
|
|
577
|
+
passed: boolean | null;
|
|
578
|
+
unscorable: boolean;
|
|
579
|
+
code_digest: string;
|
|
580
|
+
run_at_ms: number;
|
|
581
|
+
test_log_excerpt?: string | null;
|
|
582
|
+
}
|
|
583
|
+
/** A persisted eval result read back from the store (same shape as the record written). */
|
|
584
|
+
export type EvalResultRow = EvalResultRecord;
|
|
585
|
+
export interface EvalAggregate {
|
|
586
|
+
passed: number;
|
|
587
|
+
scorable: number;
|
|
588
|
+
unscorable: number;
|
|
589
|
+
}
|
|
504
590
|
export {};
|