@jinn-network/client 0.1.3-canary.85489c27 → 0.1.3-canary.8e61ba74
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/dist/adapters/adapter.d.ts +15 -4
- package/dist/adapters/local/adapter.d.ts +9 -8
- package/dist/adapters/local/adapter.js +47 -74
- package/dist/adapters/local/adapter.js.map +1 -1
- package/dist/adapters/mech/adapter.d.ts +29 -13
- package/dist/adapters/mech/adapter.js +316 -311
- package/dist/adapters/mech/adapter.js.map +1 -1
- package/dist/adapters/mech/contracts.d.ts +62 -16
- package/dist/adapters/mech/contracts.js +226 -92
- package/dist/adapters/mech/contracts.js.map +1 -1
- package/dist/adapters/mech/safe-revert.js +0 -6
- package/dist/adapters/mech/safe-revert.js.map +1 -1
- package/dist/adapters/mech/types.d.ts +237 -84
- package/dist/adapters/mech/types.js +125 -50
- package/dist/adapters/mech/types.js.map +1 -1
- package/dist/api/gather-status.d.ts +0 -1
- package/dist/api/gather-status.js +0 -1
- package/dist/api/gather-status.js.map +1 -1
- package/dist/build-info.json +4 -4
- package/dist/build-meta.json +1 -1
- package/dist/cli/commands/bootstrap.js +0 -1
- package/dist/cli/commands/bootstrap.js.map +1 -1
- package/dist/cli/commands/create.js +3 -3
- package/dist/cli/commands/doctor.js +3 -11
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/fleet-scale.js +0 -1
- package/dist/cli/commands/fleet-scale.js.map +1 -1
- package/dist/cli/commands/fund-requirements.js +0 -1
- package/dist/cli/commands/fund-requirements.js.map +1 -1
- package/dist/cli/commands/migrate-agent-id.js +0 -1
- package/dist/cli/commands/migrate-agent-id.js.map +1 -1
- package/dist/cli/commands/solver-nets.js +1 -1
- package/dist/cli/commands/solver-plugins.js +3 -1
- package/dist/cli/commands/solver-plugins.js.map +1 -1
- package/dist/cli/commands/tasks.js +20 -11
- package/dist/cli/commands/tasks.js.map +1 -1
- package/dist/cli/commands/version.js +0 -1
- package/dist/cli/commands/version.js.map +1 -1
- package/dist/cli/deployment-digest.js +0 -5
- package/dist/cli/deployment-digest.js.map +1 -1
- package/dist/cli/execution-context.js +0 -1
- package/dist/cli/execution-context.js.map +1 -1
- package/dist/cli/introspection-context.js +0 -1
- package/dist/cli/introspection-context.js.map +1 -1
- package/dist/config.d.ts +404 -22
- package/dist/config.js +25 -32
- package/dist/config.js.map +1 -1
- package/dist/daemon/creator.d.ts +3 -3
- package/dist/daemon/creator.js +3 -3
- package/dist/daemon/creator.js.map +1 -1
- package/dist/daemon/daemon.d.ts +3 -6
- package/dist/daemon/daemon.js +30 -9
- package/dist/daemon/daemon.js.map +1 -1
- package/dist/daemon/jinn-claim-loop-canonical.d.ts +11 -11
- package/dist/daemon/jinn-claim-loop-canonical.js +17 -17
- package/dist/daemon/jinn-claim-loop-canonical.js.map +1 -1
- package/dist/daemon/jinn-claim-loop-mock.d.ts +4 -4
- package/dist/daemon/jinn-claim-loop-mock.js +7 -7
- package/dist/daemon/jinn-claim-loop-mock.js.map +1 -1
- package/dist/daemon/jinn-claim-loop.d.ts +4 -4
- package/dist/daemon/jinn-claim-loop.js +3 -3
- package/dist/earning/bootstrap.d.ts +0 -1
- package/dist/earning/bootstrap.js +0 -1
- package/dist/earning/bootstrap.js.map +1 -1
- package/dist/earning/contracts.d.ts +18 -20
- package/dist/earning/contracts.js +18 -29
- package/dist/earning/contracts.js.map +1 -1
- package/dist/earning/funding-plan.d.ts +0 -1
- package/dist/earning/funding-plan.js +0 -1
- package/dist/earning/funding-plan.js.map +1 -1
- package/dist/earning/migrate-agent-id.d.ts +0 -1
- package/dist/earning/migrate-agent-id.js +0 -1
- package/dist/earning/migrate-agent-id.js.map +1 -1
- package/dist/erc8004/reputation.d.ts +2 -2
- package/dist/erc8004/reputation.js +2 -2
- package/dist/events/types.d.ts +2 -2
- package/dist/harnesses/engine/delivery.d.ts +10 -6
- package/dist/harnesses/engine/delivery.js +10 -6
- package/dist/harnesses/engine/delivery.js.map +1 -1
- package/dist/harnesses/engine/engine.d.ts +16 -29
- package/dist/harnesses/engine/engine.js +67 -106
- package/dist/harnesses/engine/engine.js.map +1 -1
- package/dist/harnesses/engine/persistence.d.ts +5 -1
- package/dist/harnesses/engine/persistence.js +10 -2
- package/dist/harnesses/engine/persistence.js.map +1 -1
- package/dist/harnesses/external-impls/loader.d.ts +1 -1
- package/dist/harnesses/impls/claude-code-learner/types.d.ts +1 -1
- package/dist/harnesses/impls/claude-mcp-prediction/index.d.ts +1 -1
- package/dist/harnesses/impls/claude-mcp-prediction/index.js +6 -6
- package/dist/harnesses/impls/claude-mcp-prediction/types.d.ts +1 -1
- package/dist/harnesses/impls/claude-mcp-prediction/types.js +1 -1
- package/dist/harnesses/impls/index.js +5 -5
- package/dist/harnesses/impls/portfolio-v0-evaluator/index.js +1 -1
- package/dist/harnesses/impls/portfolio-v0-evaluator/index.js.map +1 -1
- package/dist/harnesses/impls/prediction-v0-baseline/index.d.ts +4 -4
- package/dist/harnesses/impls/prediction-v0-baseline/index.js +10 -10
- package/dist/harnesses/impls/prediction-v0-evaluator/canonical-metrics.d.ts +3 -3
- package/dist/harnesses/impls/prediction-v0-evaluator/checks/availability.d.ts +1 -1
- package/dist/harnesses/impls/prediction-v0-evaluator/index.d.ts +4 -4
- package/dist/harnesses/impls/prediction-v0-evaluator/index.js +11 -11
- package/dist/harnesses/impls/prediction-v1-baseline/index.d.ts +31 -0
- package/dist/harnesses/impls/prediction-v1-baseline/index.js +79 -0
- package/dist/harnesses/impls/prediction-v1-baseline/index.js.map +1 -0
- package/dist/harnesses/impls/prediction-v1-evaluator/index.d.ts +32 -0
- package/dist/harnesses/impls/prediction-v1-evaluator/index.js +198 -0
- package/dist/harnesses/impls/prediction-v1-evaluator/index.js.map +1 -0
- package/dist/harnesses/manifest/types.d.ts +1 -1
- package/dist/harnesses/manifest/types.js +1 -1
- package/dist/harnesses/types.d.ts +2 -1
- package/dist/harnesses/types.js.map +1 -1
- package/dist/main.js +4 -35
- 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 +2 -2
- package/dist/plugins/manifest.d.ts +1 -1
- package/dist/plugins/manifest.js +1 -1
- package/dist/plugins/manifest.js.map +1 -1
- package/dist/plugins/registry.js +1 -1
- package/dist/plugins/registry.js.map +1 -1
- package/dist/plugins/resolvers.js +2 -1
- package/dist/plugins/resolvers.js.map +1 -1
- package/dist/plugins/types.d.ts +4 -8
- package/dist/plugins/validator.js +5 -7
- package/dist/plugins/validator.js.map +1 -1
- package/dist/solver-nets/contracts.d.ts +2 -0
- package/dist/solver-nets/contracts.js +2 -0
- package/dist/solver-nets/contracts.js.map +1 -0
- package/dist/solver-nets/registry.d.ts +2 -0
- package/dist/solver-nets/registry.js +13 -5
- package/dist/solver-nets/registry.js.map +1 -1
- package/dist/solver-types/constants.d.ts +1 -1
- package/dist/solver-types/constants.js +1 -1
- package/dist/solver-types/index.d.ts +5 -5
- package/dist/solver-types/index.js +5 -5
- package/dist/solver-types/prediction-apy-v0-auto.js +12 -0
- package/dist/solver-types/prediction-apy-v0-auto.js.map +1 -1
- package/dist/solver-types/prediction-v0-auto.d.ts +4 -4
- package/dist/solver-types/prediction-v0-auto.js +22 -10
- package/dist/solver-types/prediction-v0-auto.js.map +1 -1
- package/dist/solver-types/prediction-v0-template.d.ts +10 -10
- package/dist/solver-types/prediction-v0-template.js +16 -16
- package/dist/solver-types/prediction-v0-template.js.map +1 -1
- package/dist/solver-types/prediction-v0.d.ts +2 -2
- package/dist/solver-types/prediction-v0.js +11 -11
- package/dist/solver-types/prediction-v1-auto.d.ts +22 -0
- package/dist/solver-types/prediction-v1-auto.js +211 -0
- package/dist/solver-types/prediction-v1-auto.js.map +1 -0
- package/dist/solver-types/prediction-v1.d.ts +3 -0
- package/dist/solver-types/prediction-v1.js +29 -0
- package/dist/solver-types/prediction-v1.js.map +1 -0
- package/dist/solver-types/solver-type.d.ts +5 -4
- package/dist/store/store.d.ts +4 -0
- package/dist/store/store.js +28 -4
- package/dist/store/store.js.map +1 -1
- package/dist/tasks/posting-service.d.ts +5 -2
- package/dist/tasks/posting-service.js +12 -6
- package/dist/tasks/posting-service.js.map +1 -1
- package/dist/tasks/sources.d.ts +2 -2
- package/dist/tasks/sources.js +10 -7
- package/dist/tasks/sources.js.map +1 -1
- package/dist/templates/harnesses/alternative-harness/package.json.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/coordinator.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/index.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/mock-harness.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/phases/debrief.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/phases/execute.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/phases/improve.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/phases/memory.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/phases/orient.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/phases/plan.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/src/phases/strategize.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/test/coordinator.test.ts.tmpl +1 -1
- package/dist/templates/harnesses/alternative-harness/test/unit.test.ts.tmpl +1 -1
- package/dist/templates/harnesses/evaluator/package.json.tmpl +1 -1
- package/dist/templates/harnesses/evaluator/src/index.ts.tmpl +1 -1
- package/dist/templates/harnesses/evaluator/test/unit.test.ts.tmpl +1 -1
- package/dist/templates/harnesses/forecaster/package.json.tmpl +1 -1
- package/dist/templates/harnesses/forecaster/src/index.ts.tmpl +1 -1
- package/dist/templates/harnesses/forecaster/test/unit.test.ts.tmpl +1 -1
- package/dist/trajectory/schema.d.ts +10 -10
- package/dist/types/index.d.ts +2 -2
- package/dist/types/index.js +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/types/payloads/index.d.ts +1 -0
- package/dist/types/payloads/index.js +6 -0
- package/dist/types/payloads/index.js.map +1 -1
- package/dist/types/payloads/prediction-v1.d.ts +2 -0
- package/dist/types/payloads/prediction-v1.js +2 -0
- package/dist/types/payloads/prediction-v1.js.map +1 -0
- package/dist/types/prediction-v1.d.ts +2 -0
- package/dist/types/prediction-v1.js +2 -0
- package/dist/types/prediction-v1.js.map +1 -0
- package/dist/types/prediction.d.ts +559 -19
- package/dist/types/prediction.js +12 -9
- package/dist/types/prediction.js.map +1 -1
- package/dist/types/task-document.d.ts +389 -0
- package/dist/types/task-document.js +11 -0
- package/dist/types/task-document.js.map +1 -1
- package/dist/types/task.d.ts +285 -1
- package/dist/types/task.js +6 -1
- package/dist/types/task.js.map +1 -1
- package/dist/vendor/@jinn-network/sdk/README.md +61 -0
- package/dist/vendor/@jinn-network/sdk/dist/capabilities.d.ts +52 -0
- package/dist/vendor/@jinn-network/sdk/dist/capabilities.js +1 -0
- package/dist/vendor/@jinn-network/sdk/dist/contracts.d.ts +105 -0
- package/dist/vendor/@jinn-network/sdk/dist/contracts.js +147 -0
- package/dist/vendor/@jinn-network/sdk/dist/harness.d.ts +69 -0
- package/dist/vendor/@jinn-network/sdk/dist/harness.js +1 -0
- package/dist/vendor/@jinn-network/sdk/dist/index.d.ts +2 -0
- package/dist/vendor/@jinn-network/sdk/dist/index.js +5 -0
- package/dist/vendor/@jinn-network/sdk/dist/manifest.d.ts +69 -0
- package/dist/vendor/@jinn-network/sdk/dist/manifest.js +3 -0
- package/dist/vendor/@jinn-network/sdk/dist/payloads/prediction-v1.d.ts +223 -0
- package/dist/vendor/@jinn-network/sdk/dist/payloads/prediction-v1.js +64 -0
- package/dist/vendor/@jinn-network/sdk/dist/plugins.d.ts +36 -0
- package/dist/vendor/@jinn-network/sdk/dist/plugins.js +54 -0
- package/dist/vendor/@jinn-network/sdk/dist/prediction-v1.d.ts +870 -0
- package/dist/vendor/@jinn-network/sdk/dist/prediction-v1.js +80 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/index.d.ts +2 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/index.js +1 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/prediction-v1.d.ts +6 -0
- package/dist/vendor/@jinn-network/sdk/dist/solvernets/prediction-v1.js +3 -0
- package/dist/vendor/@jinn-network/sdk/dist/types.d.ts +116 -0
- package/dist/vendor/@jinn-network/sdk/dist/types.js +21 -0
- package/dist/vendor/@jinn-network/sdk/package.json +34 -0
- package/dist/venues/polymarket/client.d.ts +77 -0
- package/dist/venues/polymarket/client.js +309 -0
- package/dist/venues/polymarket/client.js.map +1 -0
- package/dist/withdraw/run-withdraw-plan.js +0 -2
- package/dist/withdraw/run-withdraw-plan.js.map +1 -1
- package/package.json +8 -6
- package/plugins/jinn-prediction-plugin/.claude-plugin/plugin.json +13 -86
- package/plugins/jinn-prediction-plugin/.mcp.json +8 -0
- package/plugins/jinn-prediction-plugin/GEMINI.md +3 -0
- package/plugins/jinn-prediction-plugin/gemini-extension.json +13 -0
- package/plugins/jinn-prediction-plugin/jinn.plugin.json +23 -0
- package/plugins/jinn-prediction-plugin/schemas/prediction-v1-solution.schema.json +34 -0
- package/plugins/jinn-prediction-plugin/schemas/prediction-v1-task.schema.json +118 -0
- package/plugins/jinn-prediction-plugin/schemas/prediction-v1-verdict.schema.json +84 -0
- package/templates/harnesses/alternative-harness/package.json.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/coordinator.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/index.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/mock-harness.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/phases/debrief.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/phases/execute.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/phases/improve.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/phases/memory.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/phases/orient.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/phases/plan.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/src/phases/strategize.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/test/coordinator.test.ts.tmpl +1 -1
- package/templates/harnesses/alternative-harness/test/unit.test.ts.tmpl +1 -1
- package/templates/harnesses/evaluator/package.json.tmpl +1 -1
- package/templates/harnesses/evaluator/src/index.ts.tmpl +1 -1
- package/templates/harnesses/evaluator/test/unit.test.ts.tmpl +1 -1
- package/templates/harnesses/forecaster/package.json.tmpl +1 -1
- package/templates/harnesses/forecaster/src/index.ts.tmpl +1 -1
- package/templates/harnesses/forecaster/test/unit.test.ts.tmpl +1 -1
- package/dist/adapters/claim-registry/abi.d.ts +0 -127
- package/dist/adapters/claim-registry/abi.js +0 -93
- package/dist/adapters/claim-registry/abi.js.map +0 -1
- package/dist/adapters/claim-registry/client.d.ts +0 -98
- package/dist/adapters/claim-registry/client.js +0 -225
- package/dist/adapters/claim-registry/client.js.map +0 -1
- package/dist/adapters/mech/claim-policy.d.ts +0 -40
- package/dist/adapters/mech/claim-policy.js +0 -104
- package/dist/adapters/mech/claim-policy.js.map +0 -1
- package/dist/harnesses/engine/claim.d.ts +0 -69
- package/dist/harnesses/engine/claim.js +0 -111
- package/dist/harnesses/engine/claim.js.map +0 -1
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import type { Task, RequestId, TaskRequest, TaskResult, DeliveredResult } from '../types/index.js';
|
|
1
|
+
import type { Task, RequestId, PostedTask, TaskAnnouncement, TaskRequest, TaskResult, DeliveredResult } from '../types/index.js';
|
|
2
|
+
import type { Hex } from 'viem';
|
|
2
3
|
export interface ExecutionAdapter {
|
|
3
4
|
readonly name: string;
|
|
4
5
|
initialize(): Promise<void>;
|
|
5
|
-
postTask(state: Task): Promise<
|
|
6
|
+
postTask(state: Task): Promise<PostedTask>;
|
|
6
7
|
/**
|
|
7
8
|
* Optional: returns the IPFS CID of the most recently posted Task payload.
|
|
8
9
|
* Populated by adapters that upload to IPFS as part of `postTask`
|
|
@@ -10,9 +11,19 @@ export interface ExecutionAdapter {
|
|
|
10
11
|
* Returns undefined for adapters that do not upload (e.g. LocalAdapter).
|
|
11
12
|
*/
|
|
12
13
|
getLastPostedTaskCid?(): string | undefined;
|
|
13
|
-
|
|
14
|
-
|
|
14
|
+
watchForTasks(): AsyncIterable<TaskAnnouncement>;
|
|
15
|
+
claimTask(taskId: string): Promise<TaskRequest>;
|
|
15
16
|
submitResult(requestId: RequestId, result: TaskResult): Promise<void>;
|
|
17
|
+
claimEvaluation?(taskId: string, attemptIndex: number, evaluationTaskCidDigest: Hex): Promise<{
|
|
18
|
+
taskId: string;
|
|
19
|
+
attemptIndex: number;
|
|
20
|
+
verdictIndex: number;
|
|
21
|
+
requestId: string;
|
|
22
|
+
txHash: Hex;
|
|
23
|
+
blockNumber?: number;
|
|
24
|
+
}>;
|
|
25
|
+
submitSolutionDelivery?(requestId: RequestId, solutionDigest: Hex): Promise<void>;
|
|
26
|
+
submitVerdictDelivery?(requestId: RequestId, verdictDigest: Hex, verdictCode?: number): Promise<void>;
|
|
16
27
|
watchForDeliveries(): AsyncIterable<DeliveredResult>;
|
|
17
28
|
stop(): Promise<void>;
|
|
18
29
|
}
|
|
@@ -1,19 +1,20 @@
|
|
|
1
1
|
import type { ExecutionAdapter } from '../adapter.js';
|
|
2
|
-
import type { Task, RequestId, TaskRequest, TaskResult, DeliveredResult } from '../../types/index.js';
|
|
2
|
+
import type { Task, RequestId, PostedTask, TaskAnnouncement, TaskRequest, TaskResult, DeliveredResult } from '../../types/index.js';
|
|
3
3
|
export declare class LocalAdapter implements ExecutionAdapter {
|
|
4
4
|
readonly name = "local";
|
|
5
|
+
private nextTaskId;
|
|
6
|
+
private tasks;
|
|
5
7
|
private requests;
|
|
6
|
-
private
|
|
7
|
-
private
|
|
8
|
+
private claimCounts;
|
|
9
|
+
private pendingTasks;
|
|
8
10
|
private pendingDeliveries;
|
|
9
|
-
private
|
|
11
|
+
private taskWaiters;
|
|
10
12
|
private deliveryWaiters;
|
|
11
|
-
private deliveredRequestIds;
|
|
12
13
|
private stopped;
|
|
13
14
|
initialize(): Promise<void>;
|
|
14
|
-
postTask(state: Task): Promise<
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
postTask(state: Task): Promise<PostedTask>;
|
|
16
|
+
watchForTasks(): AsyncIterable<TaskAnnouncement>;
|
|
17
|
+
claimTask(taskId: string): Promise<TaskRequest>;
|
|
17
18
|
submitResult(requestId: RequestId, result: TaskResult): Promise<void>;
|
|
18
19
|
watchForDeliveries(): AsyncIterable<DeliveredResult>;
|
|
19
20
|
stop(): Promise<void>;
|
|
@@ -1,91 +1,82 @@
|
|
|
1
1
|
import { randomUUID } from 'node:crypto';
|
|
2
2
|
export class LocalAdapter {
|
|
3
3
|
name = 'local';
|
|
4
|
+
nextTaskId = 1;
|
|
5
|
+
tasks = new Map();
|
|
4
6
|
requests = new Map();
|
|
5
|
-
|
|
6
|
-
|
|
7
|
+
claimCounts = new Map();
|
|
8
|
+
pendingTasks = [];
|
|
7
9
|
pendingDeliveries = [];
|
|
8
|
-
|
|
10
|
+
taskWaiters = [];
|
|
9
11
|
deliveryWaiters = [];
|
|
10
|
-
deliveredRequestIds = new Set();
|
|
11
12
|
stopped = false;
|
|
12
13
|
async initialize() {
|
|
13
14
|
// No-op for local
|
|
14
15
|
}
|
|
15
16
|
async postTask(state) {
|
|
16
|
-
const
|
|
17
|
-
// Create restoration request
|
|
17
|
+
const taskId = String(this.nextTaskId++);
|
|
18
18
|
const restorationState = {
|
|
19
19
|
...state,
|
|
20
20
|
role: state.role ?? 'restoration',
|
|
21
21
|
};
|
|
22
|
-
const
|
|
23
|
-
|
|
22
|
+
const announcement = {
|
|
23
|
+
taskId,
|
|
24
24
|
task: restorationState,
|
|
25
|
+
taskCid: `local-${taskId}`,
|
|
26
|
+
onchainCreationTx: `0x${taskId.padStart(64, '0')}`,
|
|
27
|
+
onchainCreationBlock: this.nextTaskId,
|
|
25
28
|
};
|
|
26
|
-
this.
|
|
27
|
-
if (this.
|
|
28
|
-
this.
|
|
29
|
+
this.tasks.set(taskId, announcement);
|
|
30
|
+
if (this.taskWaiters.length > 0) {
|
|
31
|
+
this.taskWaiters.shift()(announcement);
|
|
29
32
|
}
|
|
30
33
|
else {
|
|
31
|
-
this.
|
|
34
|
+
this.pendingTasks.push(announcement);
|
|
32
35
|
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
restorationRequestId: requestId,
|
|
39
|
-
};
|
|
40
|
-
const evalRequest = {
|
|
41
|
-
requestId: evalRequestId,
|
|
42
|
-
task: evaluationState,
|
|
36
|
+
return {
|
|
37
|
+
taskId,
|
|
38
|
+
taskCid: announcement.taskCid ?? `local-${taskId}`,
|
|
39
|
+
txHash: announcement.onchainCreationTx,
|
|
40
|
+
blockNumber: announcement.onchainCreationBlock,
|
|
43
41
|
};
|
|
44
|
-
this.requests.set(evalRequestId, evalRequest);
|
|
45
|
-
// Evaluation requests are deferred — only yielded after restoration is delivered
|
|
46
|
-
this.deferredEvalRequests.push(evalRequest);
|
|
47
|
-
return requestId;
|
|
48
42
|
}
|
|
49
|
-
async *
|
|
43
|
+
async *watchForTasks() {
|
|
50
44
|
while (!this.stopped) {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
for (const evalReq of this.deferredEvalRequests) {
|
|
54
|
-
const restorationId = evalReq.task.restorationRequestId;
|
|
55
|
-
if (restorationId && this.deliveredRequestIds.has(restorationId)) {
|
|
56
|
-
// Restoration delivered — yield evaluation request
|
|
57
|
-
if (this.requestWaiters.length > 0) {
|
|
58
|
-
this.requestWaiters.shift()(evalReq);
|
|
59
|
-
}
|
|
60
|
-
else {
|
|
61
|
-
this.pendingRequests.push(evalReq);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
else {
|
|
65
|
-
stillDeferred.push(evalReq);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
this.deferredEvalRequests = stillDeferred;
|
|
69
|
-
if (this.pendingRequests.length > 0) {
|
|
70
|
-
yield this.pendingRequests.shift();
|
|
45
|
+
if (this.pendingTasks.length > 0) {
|
|
46
|
+
yield this.pendingTasks.shift();
|
|
71
47
|
}
|
|
72
48
|
else {
|
|
73
|
-
const
|
|
74
|
-
this.
|
|
49
|
+
const task = await new Promise((resolve) => {
|
|
50
|
+
this.taskWaiters.push(resolve);
|
|
75
51
|
});
|
|
76
52
|
if (!this.stopped)
|
|
77
|
-
yield
|
|
53
|
+
yield task;
|
|
78
54
|
}
|
|
79
55
|
}
|
|
80
56
|
}
|
|
81
|
-
async
|
|
82
|
-
|
|
57
|
+
async claimTask(taskId) {
|
|
58
|
+
const announcement = this.tasks.get(taskId);
|
|
59
|
+
if (!announcement)
|
|
60
|
+
throw new Error(`Unknown task: ${taskId}`);
|
|
61
|
+
const requestId = randomUUID();
|
|
62
|
+
const attemptIndex = this.claimCounts.get(taskId) ?? 0;
|
|
63
|
+
this.claimCounts.set(taskId, attemptIndex + 1);
|
|
64
|
+
const request = {
|
|
65
|
+
requestId,
|
|
66
|
+
taskId,
|
|
67
|
+
attemptIndex,
|
|
68
|
+
task: announcement.task,
|
|
69
|
+
taskCid: announcement.taskCid,
|
|
70
|
+
onchainCreationTx: announcement.onchainCreationTx,
|
|
71
|
+
onchainCreationBlock: announcement.onchainCreationBlock,
|
|
72
|
+
};
|
|
73
|
+
this.requests.set(requestId, request);
|
|
74
|
+
return request;
|
|
83
75
|
}
|
|
84
76
|
async submitResult(requestId, result) {
|
|
85
77
|
const request = this.requests.get(requestId);
|
|
86
78
|
if (!request)
|
|
87
79
|
throw new Error(`Unknown request: ${requestId}`);
|
|
88
|
-
this.deliveredRequestIds.add(requestId);
|
|
89
80
|
const delivery = {
|
|
90
81
|
requestId,
|
|
91
82
|
task: request.task,
|
|
@@ -98,23 +89,6 @@ export class LocalAdapter {
|
|
|
98
89
|
else {
|
|
99
90
|
this.pendingDeliveries.push(delivery);
|
|
100
91
|
}
|
|
101
|
-
// Check if any deferred evaluation requests are now ready
|
|
102
|
-
const stillDeferred = [];
|
|
103
|
-
for (const evalReq of this.deferredEvalRequests) {
|
|
104
|
-
const restorationId = evalReq.task.restorationRequestId;
|
|
105
|
-
if (restorationId && this.deliveredRequestIds.has(restorationId)) {
|
|
106
|
-
if (this.requestWaiters.length > 0) {
|
|
107
|
-
this.requestWaiters.shift()(evalReq);
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
this.pendingRequests.push(evalReq);
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
stillDeferred.push(evalReq);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
this.deferredEvalRequests = stillDeferred;
|
|
118
92
|
}
|
|
119
93
|
async *watchForDeliveries() {
|
|
120
94
|
while (!this.stopped) {
|
|
@@ -132,14 +106,13 @@ export class LocalAdapter {
|
|
|
132
106
|
}
|
|
133
107
|
async stop() {
|
|
134
108
|
this.stopped = true;
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
waiter({ requestId: '', task: { id: '', description: '' } });
|
|
109
|
+
for (const waiter of this.taskWaiters) {
|
|
110
|
+
waiter({ taskId: '', task: { id: '', description: '' } });
|
|
138
111
|
}
|
|
139
112
|
for (const waiter of this.deliveryWaiters) {
|
|
140
113
|
waiter({ requestId: '', task: { id: '', description: '' }, result: { data: '' }, deliveryMechAddress: '' });
|
|
141
114
|
}
|
|
142
|
-
this.
|
|
115
|
+
this.taskWaiters = [];
|
|
143
116
|
this.deliveryWaiters = [];
|
|
144
117
|
}
|
|
145
118
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/adapters/local/adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/adapters/local/adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { type Hex } from 'viem';
|
|
1
2
|
import type { ExecutionAdapter } from '../adapter.js';
|
|
2
|
-
import type { Task, RequestId, TaskRequest, TaskResult, DeliveredResult } from '../../types/index.js';
|
|
3
|
+
import type { Task, RequestId, PostedTask, TaskAnnouncement, TaskRequest, TaskResult, DeliveredResult } from '../../types/index.js';
|
|
3
4
|
import { type MechAdapterConfig } from './types.js';
|
|
4
5
|
import type { Store } from '../../store/store.js';
|
|
5
6
|
export declare class MechAdapter implements ExecutionAdapter {
|
|
@@ -11,27 +12,42 @@ export declare class MechAdapter implements ExecutionAdapter {
|
|
|
11
12
|
private requestBlockCursor;
|
|
12
13
|
private deliveryBlockCursor;
|
|
13
14
|
private pendingEvaluations;
|
|
14
|
-
private
|
|
15
|
-
private
|
|
16
|
-
private
|
|
17
|
-
private
|
|
18
|
-
private backfillMissRids;
|
|
15
|
+
private observedTasks;
|
|
16
|
+
private requestKinds;
|
|
17
|
+
private evaluationOpportunities;
|
|
18
|
+
private pendingEvaluationSolutions;
|
|
19
19
|
private originalStates;
|
|
20
20
|
private store?;
|
|
21
|
-
private claimPolicy;
|
|
22
21
|
constructor(config: MechAdapterConfig, store?: Store);
|
|
23
22
|
initialize(): Promise<void>;
|
|
24
23
|
private recoverPendingState;
|
|
25
|
-
|
|
24
|
+
private loadPendingEvaluationSolutions;
|
|
25
|
+
private persistPendingEvaluationSolutions;
|
|
26
|
+
private rememberPendingEvaluationSolution;
|
|
27
|
+
private forgetPendingEvaluationSolution;
|
|
28
|
+
postTask(state: Task): Promise<PostedTask>;
|
|
26
29
|
private signTaskDocument;
|
|
27
|
-
|
|
28
|
-
|
|
30
|
+
private contractPolicyForTask;
|
|
31
|
+
private buildEvaluationTask;
|
|
32
|
+
private restorationAnnouncementForTaskId;
|
|
33
|
+
private deliveryEnvelopeCidForSolution;
|
|
34
|
+
private evaluationAnnouncementForSolution;
|
|
35
|
+
private retryPendingEvaluationSolutions;
|
|
36
|
+
watchForTasks(): AsyncIterable<TaskAnnouncement>;
|
|
37
|
+
claimTask(taskId: string): Promise<TaskRequest>;
|
|
29
38
|
submitResult(requestId: RequestId, result: TaskResult): Promise<void>;
|
|
39
|
+
claimEvaluation(taskId: string, attemptIndex: number, evaluationTaskCidDigest: Hex): Promise<{
|
|
40
|
+
taskId: string;
|
|
41
|
+
attemptIndex: number;
|
|
42
|
+
verdictIndex: number;
|
|
43
|
+
requestId: string;
|
|
44
|
+
txHash: Hex;
|
|
45
|
+
blockNumber?: number;
|
|
46
|
+
}>;
|
|
47
|
+
submitSolutionDelivery(requestId: RequestId, solutionDigest: Hex): Promise<void>;
|
|
48
|
+
submitVerdictDelivery(requestId: RequestId, verdictDigest: Hex, verdictCode?: number): Promise<void>;
|
|
30
49
|
private evidenceHashForDelivery;
|
|
31
50
|
private ensureDeliveryClaimed;
|
|
32
51
|
watchForDeliveries(): AsyncIterable<DeliveredResult>;
|
|
33
|
-
private backfillRestorationResultFromChain;
|
|
34
|
-
private tryCreateEvaluationJob;
|
|
35
|
-
private verifyRestorationClaimed;
|
|
36
52
|
stop(): Promise<void>;
|
|
37
53
|
}
|