@magicnewton/newton-protocol-sdk 0.2.6 → 0.2.7--canary.85.19174693282.0
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.
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var l=require("../../abis/newtonAbi.js"),C=require("../../const.js"),T=require("../../types/task.js"),H=require("../../utils/https.js"),b=require("../../utils/intent.js"),f=require("../../utils/task.js"),u=require("viem"),I=require("viem/chains");const q={[I.sepolia.id]:BigInt(9223883),[I.mainnet.id]:BigInt(23385048)},R=async(t,e,a,g)=>{if(!e.taskId)throw new Error("Newton SDK: waitForTaskResponded requires taskId");const s=u.padHex(e.taskId,{size:32}),o=q[t.chain?.id??1],m=g??o,r=(await t.getContractEvents({address:a,abi:l.NewtonProverTaskManagerAbi,eventName:"TaskResponded",fromBlock:m,toBlock:"latest"})).find(n=>u.padHex(n.args.taskResponse.taskId,{size:32})===s);return r?f.convertLogToTaskResponse(r):new Promise((n,p)=>{let w,d;const c=i=>{w?.(),d&&clearTimeout(d),i&&p(i)};if(e.timeoutMs&&e.timeoutMs>0&&(d=setTimeout(()=>c(new Error("waitForTaskResponded: timeout")),e.timeoutMs)),e.abortSignal){if(e.abortSignal.aborted){c(new Error("waitForTaskResponded: aborted"));return}e.abortSignal.addEventListener("abort",()=>c(new Error("waitForTaskResponded: aborted")),{once:!0})}w=t.watchContractEvent({address:a,abi:l.NewtonProverTaskManagerAbi,eventName:"TaskResponded",onLogs:i=>{for(const h of i)if(u.padHex(h.args.taskResponse.taskId,{size:32})===s){const v=f.convertLogToTaskResponse(h);c(),n(v);return}},onError:i=>{c(i)}})})},M=(t,e,a)=>t.readContract({address:a,abi:l.NewtonProverTaskManagerAbi,functionName:"allTaskHashes",args:[e.taskId]}),P=async(t,e,a,g)=>{const s=await t.readContract({address:a,abi:l.NewtonProverTaskManagerAbi,functionName:"allTaskHashes",args:[e.taskId]});if(!u.hexToBigInt(s))throw new Error(`Failed to retrieve task status for taskId ${e.taskId}`);const o=await t.readContract({address:a,abi:l.NewtonProverTaskManagerAbi,functionName:"allTaskResponses",args:[e.taskId]}),m=!!u.hexToBigInt(o);if(!m)return T.TaskStatus.Created;const r=(await t.getContractEvents({address:a,abi:l.NewtonProverTaskManagerAbi,eventName:"TaskResponded",fromBlock:q[t.chain?.id??1],toBlock:"latest"})).find(d=>u.padHex(d.args.taskResponse.taskId,{size:32})===e.taskId);if(!r)throw new Error(`Failed to retrieve task status for taskId ${e.taskId}`);const n=f.convertLogToTaskResponse(r),p=await t.getBlockNumber();if(n?.responseCertificate?.responseExpireBlock&&p>n.responseCertificate.responseExpireBlock)return T.TaskStatus.AttestationExpired;const w=await t.readContract({address:g,abi:l.AttestationValidatorAbi,functionName:"attestations",args:[e.taskId]});return u.hexToBigInt(w)?m?T.TaskStatus.Responded:T.TaskStatus.Created:T.TaskStatus.AttestationSpent};async function _(t,e,a,g){const s=t.extend(u.publicActions),o={taskRequestedAtBlock:await s.getBlockNumber()},m=new H.AvsHttpService(!!s?.chain?.testnet,g),r=t.account;if(!r||!r.sign)throw new Error("Newton SDK: walletClient must have a local account to sign the request");const{policyClient:n,quorumNumber:p,quorumThresholdPercentage:w,wasmArgs:d,timeout:c}=e,i=b.normalizeIntent(e.intent),h=f.getEvaluationRequestHash({policyClient:n,intent:i,quorumNumber:p,quorumThresholdPercentage:w,wasmArgs:d,timeout:c}),v=await r.sign({hash:h}),N=b.sanitizeIntentForRequest(e.intent),A={policy_client:e.policyClient,intent:N,quorum_number:e.quorumNumber?b.removeHexPrefix(e.quorumNumber):null,quorum_threshold_percentage:e.quorumThresholdPercentage??null,wasm_args:e.wasmArgs?b.removeHexPrefix(e.wasmArgs):null,timeout:e.timeout,signature:v},k=await m.Post(C.AVS_METHODS.createTaskAndWait,[A],v);if(k.error)throw k.error;if(k.result.error)throw new Error(k.result.error);const E=k.result;o.taskId=E.
|
|
1
|
+
"use strict";var l=require("../../abis/newtonAbi.js"),C=require("../../const.js"),T=require("../../types/task.js"),H=require("../../utils/https.js"),b=require("../../utils/intent.js"),f=require("../../utils/task.js"),u=require("viem"),I=require("viem/chains");const q={[I.sepolia.id]:BigInt(9223883),[I.mainnet.id]:BigInt(23385048)},R=async(t,e,a,g)=>{if(!e.taskId)throw new Error("Newton SDK: waitForTaskResponded requires taskId");const s=u.padHex(e.taskId,{size:32}),o=q[t.chain?.id??1],m=g??o,r=(await t.getContractEvents({address:a,abi:l.NewtonProverTaskManagerAbi,eventName:"TaskResponded",fromBlock:m,toBlock:"latest"})).find(n=>u.padHex(n.args.taskResponse.taskId,{size:32})===s);return r?f.convertLogToTaskResponse(r):new Promise((n,p)=>{let w,d;const c=i=>{w?.(),d&&clearTimeout(d),i&&p(i)};if(e.timeoutMs&&e.timeoutMs>0&&(d=setTimeout(()=>c(new Error("waitForTaskResponded: timeout")),e.timeoutMs)),e.abortSignal){if(e.abortSignal.aborted){c(new Error("waitForTaskResponded: aborted"));return}e.abortSignal.addEventListener("abort",()=>c(new Error("waitForTaskResponded: aborted")),{once:!0})}w=t.watchContractEvent({address:a,abi:l.NewtonProverTaskManagerAbi,eventName:"TaskResponded",onLogs:i=>{for(const h of i)if(u.padHex(h.args.taskResponse.taskId,{size:32})===s){const v=f.convertLogToTaskResponse(h);c(),n(v);return}},onError:i=>{c(i)}})})},M=(t,e,a)=>t.readContract({address:a,abi:l.NewtonProverTaskManagerAbi,functionName:"allTaskHashes",args:[e.taskId]}),P=async(t,e,a,g)=>{const s=await t.readContract({address:a,abi:l.NewtonProverTaskManagerAbi,functionName:"allTaskHashes",args:[e.taskId]});if(!u.hexToBigInt(s))throw new Error(`Failed to retrieve task status for taskId ${e.taskId}`);const o=await t.readContract({address:a,abi:l.NewtonProverTaskManagerAbi,functionName:"allTaskResponses",args:[e.taskId]}),m=!!u.hexToBigInt(o);if(!m)return T.TaskStatus.Created;const r=(await t.getContractEvents({address:a,abi:l.NewtonProverTaskManagerAbi,eventName:"TaskResponded",fromBlock:q[t.chain?.id??1],toBlock:"latest"})).find(d=>u.padHex(d.args.taskResponse.taskId,{size:32})===e.taskId);if(!r)throw new Error(`Failed to retrieve task status for taskId ${e.taskId}`);const n=f.convertLogToTaskResponse(r),p=await t.getBlockNumber();if(n?.responseCertificate?.responseExpireBlock&&p>n.responseCertificate.responseExpireBlock)return T.TaskStatus.AttestationExpired;const w=await t.readContract({address:g,abi:l.AttestationValidatorAbi,functionName:"attestations",args:[e.taskId]});return u.hexToBigInt(w)?m?T.TaskStatus.Responded:T.TaskStatus.Created:T.TaskStatus.AttestationSpent};async function _(t,e,a,g){const s=t.extend(u.publicActions),o={taskRequestedAtBlock:await s.getBlockNumber()},m=new H.AvsHttpService(!!s?.chain?.testnet,g),r=t.account;if(!r||!r.sign)throw new Error("Newton SDK: walletClient must have a local account to sign the request");const{policyClient:n,quorumNumber:p,quorumThresholdPercentage:w,wasmArgs:d,timeout:c}=e,i=b.normalizeIntent(e.intent),h=f.getEvaluationRequestHash({policyClient:n,intent:i,quorumNumber:p,quorumThresholdPercentage:w,wasmArgs:d,timeout:c}),v=await r.sign({hash:h}),N=b.sanitizeIntentForRequest(e.intent),A={policy_client:e.policyClient,intent:N,quorum_number:e.quorumNumber?b.removeHexPrefix(e.quorumNumber):null,quorum_threshold_percentage:e.quorumThresholdPercentage??null,wasm_args:e.wasmArgs?b.removeHexPrefix(e.wasmArgs):null,timeout:e.timeout,signature:v},k=await m.Post(C.AVS_METHODS.createTaskAndWait,[A],v);if(k.error)throw k.error;if(k.result.error)throw new Error(k.result.error);const E=k.result;o.taskId=E.task_id;const x={get taskId(){return o.taskId},waitForTaskResponded:async({timeoutMs:B})=>{const S=o.taskId;return R(s,{taskId:S,timeoutMs:B},a,o.taskRequestedAtBlock)}};return{result:{taskId:k.result.task_id,txHash:k.result.tx_hash},...x}}exports.getTaskResponseHash=M,exports.getTaskStatus=P,exports.submitEvaluationRequest=_,exports.waitForTaskResponded=R;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{NewtonProverTaskManagerAbi as
|
|
1
|
+
import{NewtonProverTaskManagerAbi as l,AttestationValidatorAbi as x}from"../../abis/newtonAbi.js";import{AVS_METHODS as H}from"../../const.js";import{TaskStatus as g}from"../../types/task.js";import{AvsHttpService as F}from"../../utils/https.js";import{normalizeIntent as _,sanitizeIntentForRequest as y,removeHexPrefix as R}from"../../utils/intent.js";import{convertLogToTaskResponse as T,getEvaluationRequestHash as M}from"../../utils/task.js";import{hexToBigInt as b,padHex as I,publicActions as P}from"viem";import{mainnet as z,sepolia as D}from"viem/chains";const E={[D.id]:BigInt(9223883),[z.id]:BigInt(23385048)},q=async(e,t,a,p)=>{if(!t.taskId)throw new Error("Newton SDK: waitForTaskResponded requires taskId");const r=I(t.taskId,{size:32}),o=E[e.chain?.id??1],m=p??o,s=(await e.getContractEvents({address:a,abi:l,eventName:"TaskResponded",fromBlock:m,toBlock:"latest"})).find(n=>I(n.args.taskResponse.taskId,{size:32})===r);return s?T(s):new Promise((n,w)=>{let k,d;const u=i=>{k?.(),d&&clearTimeout(d),i&&w(i)};if(t.timeoutMs&&t.timeoutMs>0&&(d=setTimeout(()=>u(new Error("waitForTaskResponded: timeout")),t.timeoutMs)),t.abortSignal){if(t.abortSignal.aborted){u(new Error("waitForTaskResponded: aborted"));return}t.abortSignal.addEventListener("abort",()=>u(new Error("waitForTaskResponded: aborted")),{once:!0})}k=e.watchContractEvent({address:a,abi:l,eventName:"TaskResponded",onLogs:i=>{for(const f of i)if(I(f.args.taskResponse.taskId,{size:32})===r){const h=T(f);u(),n(h);return}},onError:i=>{u(i)}})})},K=(e,t,a)=>e.readContract({address:a,abi:l,functionName:"allTaskHashes",args:[t.taskId]}),L=async(e,t,a,p)=>{const r=await e.readContract({address:a,abi:l,functionName:"allTaskHashes",args:[t.taskId]});if(!b(r))throw new Error(`Failed to retrieve task status for taskId ${t.taskId}`);const o=await e.readContract({address:a,abi:l,functionName:"allTaskResponses",args:[t.taskId]}),m=!!b(o);if(!m)return g.Created;const s=(await e.getContractEvents({address:a,abi:l,eventName:"TaskResponded",fromBlock:E[e.chain?.id??1],toBlock:"latest"})).find(d=>I(d.args.taskResponse.taskId,{size:32})===t.taskId);if(!s)throw new Error(`Failed to retrieve task status for taskId ${t.taskId}`);const n=T(s),w=await e.getBlockNumber();if(n?.responseCertificate?.responseExpireBlock&&w>n.responseCertificate.responseExpireBlock)return g.AttestationExpired;const k=await e.readContract({address:p,abi:x,functionName:"attestations",args:[t.taskId]});return b(k)?m?g.Responded:g.Created:g.AttestationSpent};async function V(e,t,a,p){const r=e.extend(P),o={taskRequestedAtBlock:await r.getBlockNumber()},m=new F(!!r?.chain?.testnet,p),s=e.account;if(!s||!s.sign)throw new Error("Newton SDK: walletClient must have a local account to sign the request");const{policyClient:n,quorumNumber:w,quorumThresholdPercentage:k,wasmArgs:d,timeout:u}=t,i=_(t.intent),f=M({policyClient:n,intent:i,quorumNumber:w,quorumThresholdPercentage:k,wasmArgs:d,timeout:u}),h=await s.sign({hash:f}),v=y(t.intent),N={policy_client:t.policyClient,intent:v,quorum_number:t.quorumNumber?R(t.quorumNumber):null,quorum_threshold_percentage:t.quorumThresholdPercentage??null,wasm_args:t.wasmArgs?R(t.wasmArgs):null,timeout:t.timeout,signature:h},c=await m.Post(H.createTaskAndWait,[N],h);if(c.error)throw c.error;if(c.result.error)throw new Error(c.result.error);const A=c.result;o.taskId=A.task_id;const C={get taskId(){return o.taskId},waitForTaskResponded:async({timeoutMs:B})=>{const S=o.taskId;return q(r,{taskId:S,timeoutMs:B},a,o.taskRequestedAtBlock)}};return{result:{taskId:c.result.task_id,txHash:c.result.tx_hash},...C}}export{K as getTaskResponseHash,L as getTaskStatus,V as submitEvaluationRequest,q as waitForTaskResponded};
|
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
import { SubmitEvaluationRequestParams, TaskId, TaskResponseResult, TaskStatus } from '../../types/task';
|
|
2
2
|
import { PublicClient as Client, WalletClient, Hex, Address } from 'viem';
|
|
3
3
|
export interface WaitForTaskIdResult {
|
|
4
|
-
|
|
4
|
+
task_id: Hex;
|
|
5
5
|
task_request: any;
|
|
6
6
|
status: 'Completed' | 'Failed';
|
|
7
7
|
result: {
|
|
8
|
-
task_id: Hex;
|
|
9
8
|
tx_hash: Hex;
|
|
10
9
|
};
|
|
11
10
|
error?: unknown;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@magicnewton/newton-protocol-sdk",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.7--canary.85.19174693282.0",
|
|
4
4
|
"description": "Official SDK for the Newton Protocol.",
|
|
5
5
|
"author": "Newton Foundation <https://x.com/newtfoundation> (https://newton.foundation)",
|
|
6
6
|
"private": false,
|