@zama-fhe/sdk 3.0.1 → 3.1.0-alpha.2
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 +47 -797
- package/dist/cjs/assertions.cjs +2 -0
- package/dist/cjs/assertions.cjs.map +1 -0
- package/dist/cjs/base-signer.cjs +2 -0
- package/dist/cjs/base-signer.cjs.map +1 -0
- package/dist/cjs/chains/index.cjs +1 -0
- package/dist/cjs/chains.cjs +2 -0
- package/dist/cjs/chains.cjs.map +1 -0
- package/dist/cjs/cleartext/index.cjs +1 -1
- package/dist/cjs/eip1193-subscribe.cjs +1 -1
- package/dist/cjs/eip1193-subscribe.cjs.map +1 -1
- package/dist/cjs/encryption.cjs +2 -0
- package/dist/cjs/encryption.cjs.map +1 -0
- package/dist/cjs/ethers/index.cjs +1 -1
- package/dist/cjs/ethers/index.cjs.map +1 -1
- package/dist/cjs/index.cjs +1 -514
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/query/index.cjs +1 -1
- package/dist/cjs/query/index.cjs.map +1 -1
- package/dist/cjs/relayer-cleartext.cjs +2 -0
- package/dist/cjs/relayer-cleartext.cjs.map +1 -0
- package/dist/cjs/relayer-sdk.worker.js +75 -75
- package/dist/cjs/relayer.cjs +1 -1
- package/dist/cjs/relayer.cjs.map +1 -1
- package/dist/cjs/token.cjs +2 -0
- package/dist/cjs/token.cjs.map +1 -0
- package/dist/cjs/validation.cjs +2 -0
- package/dist/cjs/validation.cjs.map +1 -0
- package/dist/cjs/viem/index.cjs +1 -1
- package/dist/cjs/viem/index.cjs.map +1 -1
- package/dist/cjs/web/index.cjs +515 -0
- package/dist/cjs/web/index.cjs.map +1 -0
- package/dist/cjs/wrappers-registry.cjs +1 -1
- package/dist/cjs/wrappers-registry.cjs.map +1 -1
- package/dist/esm/assertions-qxjXTeNw.js +2 -0
- package/dist/esm/{assertions-BARApuMj.js.map → assertions-qxjXTeNw.js.map} +1 -1
- package/dist/esm/base-signer-BKI5njAs.js +2 -0
- package/dist/esm/base-signer-BKI5njAs.js.map +1 -0
- package/dist/esm/base-signer-pKDrNMlE.d.ts +63 -0
- package/dist/esm/chains/index.d.ts +3 -0
- package/dist/esm/chains/index.js +1 -0
- package/dist/esm/chains-DKasII-S.js +2 -0
- package/dist/esm/chains-DKasII-S.js.map +1 -0
- package/dist/esm/cleartext/index.d.ts +2 -86
- package/dist/esm/cleartext/index.js +1 -1
- package/dist/esm/cleartext-Hw0ScIRR.d.ts +19 -0
- package/dist/esm/cleartext-xzeh3Frj.js +2 -0
- package/dist/esm/cleartext-xzeh3Frj.js.map +1 -0
- package/dist/esm/eip1193-subscribe-B7nvT1Mp.js +2 -0
- package/dist/esm/eip1193-subscribe-B7nvT1Mp.js.map +1 -0
- package/dist/esm/{encryption-CmIPBcfP.js → encryption-xcQIQ9NP.js} +2 -2
- package/dist/esm/{encryption-CmIPBcfP.js.map → encryption-xcQIQ9NP.js.map} +1 -1
- package/dist/esm/{error-B6H-mBAh.js → error-BRHDbi2m.js} +1 -1
- package/dist/esm/{error-B6H-mBAh.js.map → error-BRHDbi2m.js.map} +1 -1
- package/dist/esm/ethers/index.d.ts +62 -16
- package/dist/esm/ethers/index.js +1 -1
- package/dist/esm/ethers/index.js.map +1 -1
- package/dist/esm/{hex-D_B-zoId.js → hex-BgMi2Yfs.js} +2 -2
- package/dist/esm/{hex-D_B-zoId.js.map → hex-BgMi2Yfs.js.map} +1 -1
- package/dist/esm/{activity-CUYnGNME.d.ts → index-BFGqQkab.d.ts} +1613 -2472
- package/dist/esm/{relayer-utils-iSPis4x-.d.ts → index-BYVFG3L9.d.ts} +50 -23
- package/dist/esm/index.d.ts +19 -101
- package/dist/esm/index.js +1 -514
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/indexeddb-storage-D2L6iKfO.js +2 -0
- package/dist/esm/indexeddb-storage-D2L6iKfO.js.map +1 -0
- package/dist/esm/memory-storage-CV60XJrC.js +2 -0
- package/dist/esm/memory-storage-CV60XJrC.js.map +1 -0
- package/dist/esm/node/index.d.ts +92 -131
- package/dist/esm/node/index.js +1 -1
- package/dist/esm/node/index.js.map +1 -1
- package/dist/esm/node/relayer-sdk.node-worker.js +1 -1
- package/dist/esm/node/relayer-sdk.node-worker.js.map +1 -1
- package/dist/esm/query/index.d.ts +83 -157
- package/dist/esm/query/index.js +1 -1
- package/dist/esm/query/index.js.map +1 -1
- package/dist/esm/relayer-BP6EyPUy.js +2 -0
- package/dist/esm/relayer-BP6EyPUy.js.map +1 -0
- package/dist/esm/relayer-cleartext-CCaAhwgH.js +2 -0
- package/dist/esm/relayer-cleartext-CCaAhwgH.js.map +1 -0
- package/dist/esm/relayer-cleartext-C_5NGHjw.d.ts +702 -0
- package/dist/esm/relayer-sdk.worker.js +75 -75
- package/dist/esm/token-DTgVBH31.js +2 -0
- package/dist/esm/token-DTgVBH31.js.map +1 -0
- package/dist/esm/types-CC0Mp18i.d.ts +652 -0
- package/dist/esm/types-CKtFhknu.d.ts +14 -0
- package/dist/esm/types-DSq1YR39.d.ts +30 -0
- package/dist/esm/types-qTxGTfOc.d.ts +48 -0
- package/dist/esm/validation-D2VCFYWj.js +2 -0
- package/dist/esm/validation-D2VCFYWj.js.map +1 -0
- package/dist/esm/viem/index.d.ts +41 -16
- package/dist/esm/viem/index.js +1 -1
- package/dist/esm/viem/index.js.map +1 -1
- package/dist/esm/web/index.d.ts +21 -0
- package/dist/esm/web/index.js +515 -0
- package/dist/esm/web/index.js.map +1 -0
- package/dist/esm/worker.base-client-pErLQy-p.js +2 -0
- package/dist/esm/worker.base-client-pErLQy-p.js.map +1 -0
- package/dist/esm/wrappers-registry-BNxAZZWS.js +2 -0
- package/dist/esm/wrappers-registry-BNxAZZWS.js.map +1 -0
- package/package.json +33 -6
- package/dist/cjs/activity.cjs +0 -2
- package/dist/cjs/activity.cjs.map +0 -1
- package/dist/cjs/cleartext.cjs +0 -2
- package/dist/cjs/cleartext.cjs.map +0 -1
- package/dist/esm/activity-BAFx7EMt.js +0 -2
- package/dist/esm/activity-BAFx7EMt.js.map +0 -1
- package/dist/esm/assertions-BARApuMj.js +0 -2
- package/dist/esm/cleartext-Cs28cTsa.js +0 -2
- package/dist/esm/cleartext-Cs28cTsa.js.map +0 -1
- package/dist/esm/eip1193-subscribe-Cl_wlVuQ.js +0 -2
- package/dist/esm/eip1193-subscribe-Cl_wlVuQ.js.map +0 -1
- package/dist/esm/memory-storage-F8xjMzVy.js +0 -2
- package/dist/esm/memory-storage-F8xjMzVy.js.map +0 -1
- package/dist/esm/relayer-C6u3eOlN.js +0 -2
- package/dist/esm/relayer-C6u3eOlN.js.map +0 -1
- package/dist/esm/relayer-sdk-DPqytEbO.d.ts +0 -44
- package/dist/esm/relayer-sdk.types-CGfXwKcB.d.ts +0 -528
- package/dist/esm/relayer-utils-BeoTNDM4.js +0 -2
- package/dist/esm/relayer-utils-BeoTNDM4.js.map +0 -1
- package/dist/esm/wrappers-registry-Ckwd2j6g.js +0 -2
- package/dist/esm/wrappers-registry-Ckwd2j6g.js.map +0 -1
|
@@ -0,0 +1,515 @@
|
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`../validation.cjs`),t=require(`../assertions.cjs`);let n=require(`zod/mini`);var r=class{#e=null;async ensureInit(){return this.#e||=this.init().catch(e=>{throw this.#e=null,e}),this.#e}resetInit(){this.#e=null}async getAclAddress(){return this.chain.aclContractAddress}};const i=n.z.object({artifactUrl:n.z.optional(n.z.string()),etag:n.z.optional(n.z.string()),lastModified:n.z.optional(n.z.string()),lastValidatedAt:n.z._default(n.z.optional(n.z.number().check(n.z.nonnegative())),0)}),a=n.z.extend(i,{publicKeyId:n.z.string(),publicKey:n.z.string()}),o=n.z.extend(i,{publicParamsId:n.z.string(),publicParams:n.z.string()}),s=n.z.array(n.z.int().check(n.z.nonnegative())),c=n.z.object({status:n.z.literal(`succeeded`),response:n.z.object({fheKeyInfo:n.z.array(n.z.object({fhePublicKey:n.z.object({urls:n.z.array(n.z.string()).check(n.z.minLength(1))})})).check(n.z.minLength(1)),crs:n.z.record(n.z.string(),n.z.object({urls:n.z.array(n.z.string()).check(n.z.minLength(1))}))})}),l=8192,u=300*1e3;function d(e){let t=[];for(let n=0;n<e.length;n+=l)t.push(String.fromCharCode(...e.subarray(n,n+l)));return btoa(t.join(``))}function f(e){let t;try{t=atob(e)}catch{throw Error(`Invalid base64 data (length: ${e.length})`)}if(t.length===0)throw Error(`Decoded artifact is empty`);let n=new Uint8Array(t.length);for(let e=0;e<t.length;e++)n[e]=t.charCodeAt(e);return n}function p(e){return`fhe:pubkey:${e}`}function m(e,t){return`fhe:params:${e}:${t}`}function h(e){return`fhe:params-index:${e}`}var g=class{#e;#t;#n;#r;#i;#a;#o=new Map;#s=null;#c=new Map;#l=null;#u=null;constructor(e){this.#e=e.storage,this.#t=e.chainId,this.#n=e.relayerUrl,this.#r=(e.ttl??86400)*1e3,this.#i=e.logger??console}async getPublicKey(e){if(this.#a!==void 0)return this.#a;if(this.#s)return this.#s;this.#s=this.#d(e);try{return await this.#s}finally{this.#s=null}}async#d(e){let n=p(this.#t),r=await this.#g(n,a,`public key`,`Failed to read public key from persistent storage, falling back to network fetch`);if(r)try{let e={publicKeyId:r.publicKeyId,publicKey:f(r.publicKey)};return this.#a=e,e}catch(e){await this.#y(n,`public key`,{error:t.s(e).message})}let i=await e();if(i===null)return null;this.#a=i;try{let e={publicKeyId:i.publicKeyId,publicKey:d(i.publicKey),lastValidatedAt:Date.now()};await this.#e.set(n,e)}catch(e){this.#i.warn(`Failed to persist public key to storage`,{chainId:this.#t,error:t.s(e).message})}return i}async getPublicParams(e,t){let n=this.#o.get(e);if(n!==void 0)return n;let r=this.#c.get(e);if(r)return r;let i=this.#f(e,t);this.#c.set(e,i);try{return await i}finally{this.#c.delete(e)}}async#f(e,n){let r=m(this.#t,e),i=await this.#g(r,o,`params`,`Failed to read public params from persistent storage, falling back to network fetch`,{bits:e});if(i)try{let t={publicParamsId:i.publicParamsId,publicParams:f(i.publicParams)};return this.#o.set(e,t),t}catch(n){await this.#y(r,`params`,{bits:e,error:t.s(n).message})}let a=await n();if(a===null)return null;this.#o.set(e,a);try{let t={publicParamsId:a.publicParamsId,publicParams:d(a.publicParams),lastValidatedAt:Date.now()};await this.#e.set(r,t);let n=h(this.#t),i=await this.#v(`Failed to read params index from storage`);i.includes(e)||await this.#e.set(n,[...i,e])}catch(n){this.#i.warn(`Failed to persist public params to storage`,{chainId:this.#t,bits:e,error:t.s(n).message})}return a}async revalidateIfDue(){if(this.#l)return this.#l;this.#l=this.#p();try{return await this.#l}finally{this.#l=null}}async#p(){let e=Date.now();if(this.#u!==null&&e-this.#u<this.#r||!this.#n)return!1;let r=p(this.#t),i=null,o=[];try{let[s,l]=await Promise.all([this.#e.get(r),this.#h()]);if(s!=null&&(i=await this.#_(r,s,a,`public key`)),o=l,!i)return!1;if([i,...o.map(e=>e.data)].every(t=>e-t.lastValidatedAt<this.#r))return this.#u=e,!1;let d=await globalThis.fetch(`${this.#n}/keyurl`);if(!d.ok){let t=e-this.#r+u;return this.#i.warn(`Manifest fetch failed during revalidation, retrying in 5 min`,{status:d.status,relayerUrl:this.#n}),await this.#S(r,{...i,lastValidatedAt:t},o.map(e=>({...e,data:{...e.data,lastValidatedAt:t}}))),this.#u=t,!1}let f=c.safeParse(await d.json());if(!f.success){this.#i.error(`Relayer manifest has unexpected shape — check relayer URL and API version`,{relayerUrl:this.#n,error:n.z.prettifyError(f.error)});let t=e-this.#r+u;return await this.#S(r,{...i,lastValidatedAt:t},o.map(e=>({...e,data:{...e.data,lastValidatedAt:t}}))),this.#u=t,!1}let p=f.data.response,m=p.fheKeyInfo[0];t.r(m,`manifest.response.fheKeyInfo[0]`);let h=m.fhePublicKey.urls[0];if(i.artifactUrl&&h&&h!==i.artifactUrl)return await this.#x(r,o),this.#u=null,!0;let g={...i,lastValidatedAt:e};if(h){let e=await this.#m(h,i);if(!e.fresh)return await this.#x(r,o),this.#u=null,!0;g={...g,artifactUrl:h,etag:e.etag,lastModified:e.lastModified}}let _=[];for(let t of o){let n=p.crs[String(t.bits)]?.urls[0];if(t.data.artifactUrl&&n&&n!==t.data.artifactUrl)return await this.#x(r,o),this.#u=null,!0;let i={...t.data,lastValidatedAt:e};if(n){let e=await this.#m(n,t.data);if(!e.fresh)return await this.#x(r,o),this.#u=null,!0;i={...i,artifactUrl:n,etag:e.etag,lastModified:e.lastModified}}_.push({...t,data:i})}return await this.#S(r,g,_),this.#u=e,!1}catch(n){let a=t.s(n),s=n instanceof TypeError||n instanceof ReferenceError||n instanceof RangeError||n instanceof SyntaxError,c=s?`error`:`warn`;this.#i[c](s?`Unexpected error during revalidation (possible bug)`:`Revalidation failed, using cached artifacts (fail-open)`,{chainId:this.#t,relayerUrl:this.#n,error:a.message});let l=e-this.#r+u;try{i&&await this.#S(r,{...i,lastValidatedAt:l},o.map(e=>({...e,data:{...e.data,lastValidatedAt:l}})))}catch(e){this.#i.warn(`Failed to update validation timestamps after revalidation error`,{chainId:this.#t,error:t.s(e).message})}return this.#u=l,!1}}async#m(e,t){let n=!!(t.etag||t.lastModified),r={};t.etag&&(r[`If-None-Match`]=t.etag),t.lastModified&&(r[`If-Modified-Since`]=t.lastModified);let i=await globalThis.fetch(e,{method:`HEAD`,headers:r});if(i.status===405&&(i=await globalThis.fetch(e,{headers:r})),!i.ok&&i.status!==304)throw Error(`Artifact freshness check failed: HEAD ${e} returned ${i.status}`);let a=i.headers.get(`etag`)??void 0,o=i.headers.get(`last-modified`)??void 0;return i.status===304?{fresh:!0,etag:a??t.etag,lastModified:o??t.lastModified}:n?{fresh:!1,etag:a,lastModified:o}:{fresh:!0,etag:a,lastModified:o}}async#h(){let e=await this.#v(`Failed to read params index, CRS revalidation may be incomplete`),n=new Set([...this.#o.keys(),...e]),r=Array.from(n);return(await Promise.all(r.map(async e=>{let n=m(this.#t,e),r;try{r=await this.#e.get(n)}catch(n){return this.#i.warn(`Failed to read cached params entry during revalidation`,{chainId:this.#t,bits:e,error:t.s(n).message}),null}if(r==null)return null;let i=await this.#_(n,r,o,`params`,{bits:e});return i?{bits:e,key:n,data:i}:null}))).filter(e=>e!==null)}async#g(e,n,r,i,a={}){let o;try{o=await this.#e.get(e)}catch(e){return this.#i.warn(i,{chainId:this.#t,...a,error:t.s(e).message}),null}return o==null?null:this.#_(e,o,n,r,a)}async#_(e,t,r,i,a={}){let o=n.z.safeParse(r,t);return o.success?o.data:(await this.#y(e,i,{...a,error:n.z.prettifyError(o.error)}),null)}async#v(e){let t=h(this.#t);return await this.#g(t,s,`params index`,e)??[]}async#y(e,t,n={}){await this.#b(e),this.#i.warn(`Corrupt ${t} cache entry detected, deleting`,{chainId:this.#t,...n})}async#b(e){await this.#e.delete(e).catch(n=>{this.#i.warn(`Failed to delete cache entry`,{chainId:this.#t,key:e,error:t.s(n).message})})}async#x(e,n){let r=h(this.#t);try{await Promise.all([this.#e.delete(e),this.#e.delete(r),...n.map(e=>this.#e.delete(e.key))])}catch(e){this.#i.warn(`Failed to clear stale artifacts from persistent storage`,{chainId:this.#t,error:t.s(e).message})}this.#a=void 0,this.#o.clear()}async#S(e,n,r){let i=[this.#e.set(e,n).catch(e=>{this.#i.warn(`Failed to update public key validation timestamp`,{chainId:this.#t,error:t.s(e).message})}),...r.map(e=>this.#e.set(e.key,e.data).catch(e=>{this.#i.warn(`Failed to update params validation timestamp`,{chainId:this.#t,error:t.s(e).message})}))];await Promise.all(i)}};async function _(e,t=2){let n;for(let r=0;r<=t;r++)try{return await e()}catch(e){if(n=e,r<t&&v(e)){await y(500*2**r);continue}throw e}throw n}function v(e){if(!(e instanceof Error))return!1;let t=e.message.toLowerCase();return t.includes(`timed out`)||t.includes(`timeout`)||t.includes(`econnreset`)||t.includes(`econnrefused`)||t.includes(`network`)||t.includes(`fetch failed`)||t.includes(`socket hang up`)||t.includes(`502`)||t.includes(`503`)||t.includes(`504`)}function y(e){return new Promise(t=>setTimeout(t,e))}var b=class extends r{#e=null;#t=null;#n;constructor(e){super(),this.#n=e}get chain(){return this.#n.chain}async init(){await this.#r.initWorker()}get#r(){return this.#n.worker}#i(){return this.#e||=(this.#t||=this.#n.fheArtifactStorage??new e.n(`FheArtifactCache`,1,`artifacts`),new g({storage:this.#t,chainId:this.chain.id,relayerUrl:this.chain.relayerUrl,ttl:this.#n.fheArtifactCacheTTL,logger:this.#n.logger})),this.#e}terminate(){this.#e=null,this.resetInit()}[Symbol.dispose](){this.terminate()}async#a(){let e=this.#n.security?.getCsrfToken?.()??``;e&&await this.#r.updateCsrf(e)}async generateKeypair(){await this.ensureInit();let e=this.chain.id,t=await this.#r.generateKeypair({chainId:e});return{publicKey:t.publicKey,privateKey:t.privateKey}}async createEIP712(e,t,n,r=7){await this.ensureInit();let i=this.chain.id;return this.#r.createEIP712({chainId:i,publicKey:e,contractAddresses:t,startTimestamp:n,durationDays:r})}async encrypt(e){let{values:t,contractAddress:n,userAddress:r}=e;await this.ensureInit();let i=this.chain.id;return _(async()=>{await this.#a();let e=await this.#r.encrypt({chainId:i,values:t,contractAddress:n,userAddress:r});return{handles:e.handles,inputProof:e.inputProof}})}async userDecrypt(e){await this.ensureInit();let t=this.chain.id;return _(async()=>(await this.#a(),(await this.#r.userDecrypt({chainId:t,...e})).clearValues))}async publicDecrypt(e){await this.ensureInit();let t=this.chain.id;return _(async()=>{await this.#a();let n=await this.#r.publicDecrypt({chainId:t,encryptedValues:e});return{clearValues:n.clearValues,abiEncodedClearValues:n.abiEncodedClearValues,decryptionProof:n.decryptionProof}})}async createDelegatedUserDecryptEIP712(e,t,n,r,i=7){await this.ensureInit();let a=this.chain.id;return this.#r.createDelegatedUserDecryptEIP712({chainId:a,publicKey:e,contractAddresses:t,delegatorAddress:n,startTimestamp:r,durationDays:i})}async delegatedUserDecrypt(e){await this.ensureInit();let t=this.chain.id;return _(async()=>(await this.#a(),(await this.#r.delegatedUserDecrypt({chainId:t,...e})).clearValues))}async requestZKProofVerification(e){await this.ensureInit();let t=this.chain.id;return _(async()=>(await this.#a(),this.#r.requestZKProofVerification({chainId:t,zkProof:e})))}async getPublicKey(){await this.ensureInit();let e=this.chain.id;return this.#i().getPublicKey(async()=>(await this.#r.getPublicKey({chainId:e})).result)}async getPublicParams(e){await this.ensureInit();let t=this.chain.id;return this.#i().getPublicParams(e,async()=>(await this.#r.getPublicParams({chainId:t,bits:e})).result)}};const x=3e4;var S=class{#e=null;#t=new Map;#n=null;config;logger;constructor(e,t){this.config=e,this.logger=t}async initWorker(){return this.#e?this.#e:(this.#n||=this.#r().catch(e=>{throw this.#n=null,e}),this.#n)}async#r(){let e=this.createWorker();this.wireEvents(e);try{let{type:t,payload:n}=this.getInitPayload();await this.sendRequestTo(e,t,n,6e4),this.onWorkerReady?.(e),this.#e=e}catch(t){throw this.terminateWorker(e),t}return this.#e}terminate(){if(this.#e){for(let[e,t]of this.#t)clearTimeout(t.timeoutId),t.reject(Error(`Worker terminated`)),this.#t.delete(e);this.terminateWorker(this.#e),this.#e=null}this.#n=null}handleResponse(e){let t=this.#t.get(e.id);if(!t){this.logger?.warn(`[WorkerClient] Received response for unknown request`,{id:e.id});return}let n=Math.round(performance.now()-t.startTime);if(clearTimeout(t.timeoutId),this.#t.delete(e.id),e.success)this.logger?.debug(`[WorkerClient] ← ${t.type} OK`,{id:e.id,elapsed:n}),t.resolve(e.data);else{this.logger?.error(`[WorkerClient] ← ${t.type} FAILED`,{id:e.id,elapsed:n,error:e.error});let r=Error(e.error);`statusCode`in e&&typeof e.statusCode==`number`&&(r.statusCode=e.statusCode),t.reject(r)}}handleWorkerError(e){this.logger?.error(`[WorkerClient] Worker error`,{error:e});let t=this.#e;this.#e=null,this.#i(`Worker error: ${e}`),t&&this.terminateWorker(t)}handleWorkerMessageError(){this.logger?.error(`[WorkerClient] Message deserialization failed`);let e=this.#e;this.#e=null,this.#i(`Worker message deserialization failed`),e&&this.terminateWorker(e)}sendRequestTo(e,t,n,r=x){return new Promise((i,a)=>{let o=this.generateRequestId(),s=performance.now();this.logger?.debug(`[WorkerClient] → ${t}`,{id:o});let c=setTimeout(()=>{this.#t.delete(o);let e=Math.round(performance.now()-s);this.logger?.error(`[WorkerClient] ${t} timed out after ${r}ms`,{id:o,elapsed:e}),a(Error(`Request ${t} timed out after ${r}ms`))},r);this.#t.set(o,{resolve:i,reject:a,timeoutId:c,startTime:s,type:t});let l={id:o,type:t,payload:n};this.postMessage(e,l)})}async sendRequest(e,t,n=x){let r=await this.initWorker();return this.sendRequestTo(r,e,t,n)}async generateKeypair(e){return this.sendRequest(`GENERATE_KEYPAIR`,e)}async createEIP712(e){return this.sendRequest(`CREATE_EIP712`,e)}async encrypt(e){return this.sendRequest(`ENCRYPT`,e)}async userDecrypt(e){return this.sendRequest(`USER_DECRYPT`,e)}async publicDecrypt(e){return this.sendRequest(`PUBLIC_DECRYPT`,e)}async createDelegatedUserDecryptEIP712(e){return this.sendRequest(`CREATE_DELEGATED_EIP712`,e)}async delegatedUserDecrypt(e){return this.sendRequest(`DELEGATED_USER_DECRYPT`,e)}async requestZKProofVerification(e){return this.sendRequest(`REQUEST_ZK_PROOF_VERIFICATION`,e)}async getPublicKey(e){return this.sendRequest(`GET_PUBLIC_KEY`,e)}async getPublicParams(e){return this.sendRequest(`GET_PUBLIC_PARAMS`,e)}#i(e){for(let[t,n]of this.#t)clearTimeout(n.timeoutId),n.reject(Error(e)),this.#t.delete(t)}};function C(e){try{return t.i(e,`runtime`),t.a(e,`id`,`runtime.id`),t.n(e,`getURL`,`runtime.getURL`),!0}catch{return!1}}function w(){let e=globalThis;for(let n of[e.chrome,e.browser])try{if(t.i(n,`ns`),C(n.runtime))return n.runtime}catch{continue}}var T=class extends S{env=`web`;constructor(e){super(e,e.logger)}createWorker(){let e=w();if(e)return new Worker(e.getURL(`relayer-sdk.worker.js`));let t=URL.createObjectURL(new Blob([`(function() {
|
|
2
|
+
//#region src/utils/assertions.ts
|
|
3
|
+
function assertObject(value, context) {
|
|
4
|
+
if (typeof value !== "object" || value === null || Array.isArray(value)) throw new TypeError(\`\${context} must be an object, got \${typeof value}\`);
|
|
5
|
+
}
|
|
6
|
+
function assertString(value, context) {
|
|
7
|
+
if (typeof value !== "string") throw new TypeError(\`\${context} must be a string, got \${typeof value}\`);
|
|
8
|
+
}
|
|
9
|
+
function assertFunction(value, context) {
|
|
10
|
+
if (typeof value !== "function") throw new TypeError(\`\${context} must be a function, got \${typeof value}\`);
|
|
11
|
+
}
|
|
12
|
+
/** Assert that \`obj[key]\` is a string. Narrows \`obj\` to include \`{ [key]: string }\`. */
|
|
13
|
+
function assertStringProp(obj, key, context) {
|
|
14
|
+
assertString(obj[key], context);
|
|
15
|
+
}
|
|
16
|
+
/** Assert that \`obj[key]\` is a function. Narrows \`obj\` to include \`{ [key]: F }\`. */
|
|
17
|
+
function assertFunctionProp(obj, key, context) {
|
|
18
|
+
assertFunction(obj[key], context);
|
|
19
|
+
}
|
|
20
|
+
function assertCondition(condition, message) {
|
|
21
|
+
if (!condition) throw new TypeError(message);
|
|
22
|
+
}
|
|
23
|
+
//#endregion
|
|
24
|
+
//#region src/utils/hex.ts
|
|
25
|
+
/** Normalize a un-prefixed hex payload to a 0x-prefixed \`Hex\` value. */
|
|
26
|
+
function prefixHex(value) {
|
|
27
|
+
return value.startsWith("0x") ? value : \`0x\${value}\`;
|
|
28
|
+
}
|
|
29
|
+
/** Convert a public \`Hex\` value back an unprefixed format. */
|
|
30
|
+
function unprefixHex(value) {
|
|
31
|
+
assertCondition(value.startsWith("0x"), \`Expected 0x-prefixed hex, got: \${value}\`);
|
|
32
|
+
return value.slice(2);
|
|
33
|
+
}
|
|
34
|
+
//#endregion
|
|
35
|
+
//#region src/worker/browser-extension.ts
|
|
36
|
+
function isValidRuntime(runtime) {
|
|
37
|
+
try {
|
|
38
|
+
assertObject(runtime, "runtime");
|
|
39
|
+
assertStringProp(runtime, "id", "runtime.id");
|
|
40
|
+
assertFunctionProp(runtime, "getURL", "runtime.getURL");
|
|
41
|
+
return true;
|
|
42
|
+
} catch {
|
|
43
|
+
return false;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Return the browser extension runtime object, or \`undefined\` outside extensions.
|
|
48
|
+
* Works across Chrome/Edge (\`chrome.runtime\`) and Firefox/Safari (\`browser.runtime\`).
|
|
49
|
+
* Extensions have restricted CSP that blocks \`blob:\` URLs, so callers use
|
|
50
|
+
* this to detect the environment and resolve file URLs via \`runtime.getURL\`.
|
|
51
|
+
*/
|
|
52
|
+
function getBrowserExtensionRuntime() {
|
|
53
|
+
const g = globalThis;
|
|
54
|
+
for (const ns of [g.chrome, g.browser]) try {
|
|
55
|
+
assertObject(ns, "ns");
|
|
56
|
+
if (isValidRuntime(ns.runtime)) return ns.runtime;
|
|
57
|
+
} catch {
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//#endregion
|
|
62
|
+
//#region src/worker/relayer-sdk.worker.ts
|
|
63
|
+
const instances = /* @__PURE__ */ new Map();
|
|
64
|
+
const pending = /* @__PURE__ */ new Map();
|
|
65
|
+
const configs = /* @__PURE__ */ new Map();
|
|
66
|
+
/** Convert an FheChain to the FhevmInstanceConfig shape expected by createInstance. */
|
|
67
|
+
function toInstanceConfig(chain) {
|
|
68
|
+
return {
|
|
69
|
+
...chain,
|
|
70
|
+
chainId: chain.id
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
let sdkGlobal = null;
|
|
74
|
+
/**
|
|
75
|
+
* Get or lazily create an FhevmInstance for the given chain.
|
|
76
|
+
*/
|
|
77
|
+
async function getInstance(chainId) {
|
|
78
|
+
const existing = instances.get(chainId);
|
|
79
|
+
if (existing) return existing;
|
|
80
|
+
const inflight = pending.get(chainId);
|
|
81
|
+
if (inflight) return inflight;
|
|
82
|
+
const config = configs.get(chainId);
|
|
83
|
+
if (!config) throw new Error(\`No config for chain \${chainId}. Available: [\${[...configs.keys()].join(", ")}]\`);
|
|
84
|
+
if (!sdkGlobal) throw new Error("Relayer SDK is not initialized. Call INIT first.");
|
|
85
|
+
const promise = sdkGlobal.createInstance({
|
|
86
|
+
...toInstanceConfig(config),
|
|
87
|
+
batchRpcCalls: false
|
|
88
|
+
}).then((instance) => {
|
|
89
|
+
instances.set(chainId, instance);
|
|
90
|
+
pending.delete(chainId);
|
|
91
|
+
return instance;
|
|
92
|
+
}).catch((err) => {
|
|
93
|
+
pending.delete(chainId);
|
|
94
|
+
throw err;
|
|
95
|
+
});
|
|
96
|
+
pending.set(chainId, promise);
|
|
97
|
+
return promise;
|
|
98
|
+
}
|
|
99
|
+
function unreachableFheType(_) {
|
|
100
|
+
throw new Error("Unsupported FHE type");
|
|
101
|
+
}
|
|
102
|
+
const relayerUrls = /* @__PURE__ */ new Set();
|
|
103
|
+
let csrfTokenBase = "";
|
|
104
|
+
const CSRF_HEADER_NAME = "x-csrf-token";
|
|
105
|
+
const MUTATING_METHODS = new Set([
|
|
106
|
+
"POST",
|
|
107
|
+
"PUT",
|
|
108
|
+
"DELETE",
|
|
109
|
+
"PATCH"
|
|
110
|
+
]);
|
|
111
|
+
/**
|
|
112
|
+
* Register relayer URLs from chain configs for fetch interception.
|
|
113
|
+
*/
|
|
114
|
+
function registerRelayerUrls(chainConfigs) {
|
|
115
|
+
for (const c of chainConfigs) if (c.relayerUrl) relayerUrls.add(c.relayerUrl);
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Send a success response back to the main thread.
|
|
119
|
+
* Optionally transfers ArrayBuffers for zero-copy performance.
|
|
120
|
+
*/
|
|
121
|
+
function sendSuccess(id, type, data, transfer) {
|
|
122
|
+
const response = {
|
|
123
|
+
id,
|
|
124
|
+
type,
|
|
125
|
+
success: true,
|
|
126
|
+
data
|
|
127
|
+
};
|
|
128
|
+
return transfer ? self.postMessage(response, transfer) : self.postMessage(response);
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Send an error response back to the main thread.
|
|
132
|
+
*/
|
|
133
|
+
function sendError(id, type, error, statusCode) {
|
|
134
|
+
const response = {
|
|
135
|
+
id,
|
|
136
|
+
type,
|
|
137
|
+
success: false,
|
|
138
|
+
error
|
|
139
|
+
};
|
|
140
|
+
if (statusCode !== void 0) response.statusCode = statusCode;
|
|
141
|
+
self.postMessage(response);
|
|
142
|
+
}
|
|
143
|
+
const originalFetch = fetch;
|
|
144
|
+
/** Allowed CDN hostnames for loading the relayer SDK script. */
|
|
145
|
+
const ALLOWED_CDN_HOSTS = new Set(["cdn.zama.org"]);
|
|
146
|
+
/**
|
|
147
|
+
* Validate the CDN URL supplied by the caller.
|
|
148
|
+
* Ensures only HTTPS URLs from approved hosts are used when loading
|
|
149
|
+
* SDK code into the worker.
|
|
150
|
+
*/
|
|
151
|
+
function validateCdnUrl(rawUrl) {
|
|
152
|
+
let url;
|
|
153
|
+
try {
|
|
154
|
+
url = new URL(rawUrl);
|
|
155
|
+
} catch {
|
|
156
|
+
throw new Error("Invalid CDN URL");
|
|
157
|
+
}
|
|
158
|
+
if (url.protocol !== "https:") throw new Error("CDN URL must use https");
|
|
159
|
+
if (!ALLOWED_CDN_HOSTS.has(url.hostname)) throw new Error(\`CDN URL host is not allowed: \${url.hostname}\`);
|
|
160
|
+
return url.toString();
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Set up fetch interceptor to add credentials and CSRF token for relayer requests.
|
|
164
|
+
* Workers don't automatically include cookies, so we intercept fetch calls
|
|
165
|
+
* targeting our relayer proxy to inject credentials and CSRF headers.
|
|
166
|
+
*/
|
|
167
|
+
function setupFetchInterceptor() {
|
|
168
|
+
globalThis.fetch = async (input, init) => {
|
|
169
|
+
const url = typeof input === "string" ? input : input instanceof URL ? input.href : input.url;
|
|
170
|
+
const method = init?.method?.toUpperCase() ?? "GET";
|
|
171
|
+
if (relayerUrls.size > 0 && [...relayerUrls].some((base) => url.startsWith(base))) {
|
|
172
|
+
const headers = new Headers(init?.headers);
|
|
173
|
+
if (MUTATING_METHODS.has(method) && csrfTokenBase) headers.set(CSRF_HEADER_NAME, csrfTokenBase);
|
|
174
|
+
return originalFetch(input, {
|
|
175
|
+
...init,
|
|
176
|
+
headers,
|
|
177
|
+
credentials: "include"
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
return originalFetch(input, init);
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* Verify a fetched script's SHA-384 hash matches the expected integrity value.
|
|
185
|
+
*/
|
|
186
|
+
async function verifyIntegrity(content, expectedHash) {
|
|
187
|
+
const encoder = new TextEncoder();
|
|
188
|
+
const hashBuffer = await crypto.subtle.digest("SHA-384", encoder.encode(content));
|
|
189
|
+
const hashHex = [...new Uint8Array(hashBuffer)].map((b) => b.toString(16).padStart(2, "0")).join("");
|
|
190
|
+
if (hashHex !== expectedHash) throw new Error(\`CDN integrity check failed: expected SHA-384 \${expectedHash}, got \${hashHex}\`);
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Load SDK script from CDN.
|
|
194
|
+
* Uses two strategies depending on the environment:
|
|
195
|
+
* - **Web apps (default):** fetch + blob URL + importScripts. Avoids MIME-type
|
|
196
|
+
* rejections (some CDNs serve .cjs as \`application/node\`) and CSP
|
|
197
|
+
* \`unsafe-eval\` violations.
|
|
198
|
+
* - **Browser extensions (Chrome/Firefox/Safari):** importScripts directly.
|
|
199
|
+
* Blob URLs are blocked by extension CSP, but the CDN must be allowed
|
|
200
|
+
* in the extension's manifest CSP.
|
|
201
|
+
*
|
|
202
|
+
* Integrity is always verified when a hash is provided, regardless of strategy.
|
|
203
|
+
*/
|
|
204
|
+
async function fetchScript(cdnUrl) {
|
|
205
|
+
const response = await originalFetch(cdnUrl);
|
|
206
|
+
if (!response.ok) throw new Error(\`Failed to fetch SDK: \${response.status} \${response.statusText}\`);
|
|
207
|
+
return response.text();
|
|
208
|
+
}
|
|
209
|
+
async function loadSdkScript(cdnUrl, integrity) {
|
|
210
|
+
const validatedUrl = validateCdnUrl(cdnUrl);
|
|
211
|
+
if (getBrowserExtensionRuntime()) {
|
|
212
|
+
if (integrity) await verifyIntegrity(await fetchScript(validatedUrl), integrity);
|
|
213
|
+
return self.importScripts(validatedUrl);
|
|
214
|
+
}
|
|
215
|
+
const scriptContent = await fetchScript(validatedUrl);
|
|
216
|
+
if (integrity) await verifyIntegrity(scriptContent, integrity);
|
|
217
|
+
const blob = new Blob([scriptContent], { type: "application/javascript" });
|
|
218
|
+
const blobUrl = URL.createObjectURL(blob);
|
|
219
|
+
try {
|
|
220
|
+
self.importScripts(blobUrl);
|
|
221
|
+
} finally {
|
|
222
|
+
URL.revokeObjectURL(blobUrl);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
/**
|
|
226
|
+
* Handle INIT request - load SDK WASM and register chain configs (instances are lazy).
|
|
227
|
+
*/
|
|
228
|
+
async function handleInit(request) {
|
|
229
|
+
const { id, type, payload } = request;
|
|
230
|
+
try {
|
|
231
|
+
if (payload.env !== "web") throw new Error(\`Web worker received unexpected env: \${payload.env}\`);
|
|
232
|
+
const { cdnUrl, csrfToken, integrity, thread } = payload;
|
|
233
|
+
csrfTokenBase = csrfToken;
|
|
234
|
+
setupFetchInterceptor();
|
|
235
|
+
await loadSdkScript(cdnUrl, integrity);
|
|
236
|
+
if (!self.relayerSDK) throw new Error("Failed to load relayerSDK from CDN");
|
|
237
|
+
sdkGlobal = self.relayerSDK;
|
|
238
|
+
await sdkGlobal.initSDK(thread !== null && thread !== void 0 ? { thread } : void 0);
|
|
239
|
+
registerRelayerUrls(payload.chains);
|
|
240
|
+
for (const chain of payload.chains) configs.set(chain.id, chain);
|
|
241
|
+
sendSuccess(id, type, { initialized: true });
|
|
242
|
+
} catch (error) {
|
|
243
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
244
|
+
console.error("[Worker] Init error:", message);
|
|
245
|
+
sendError(id, type, message);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
/** Coerce a boolean to bigint for numeric FHE types. */
|
|
249
|
+
function toBigInt(value) {
|
|
250
|
+
return typeof value === "boolean" ? value ? 1n : 0n : value;
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* Add a single typed value to the encrypted input builder.
|
|
254
|
+
*/
|
|
255
|
+
function addTypedValue(input, entry) {
|
|
256
|
+
const { value, type: fheType } = entry;
|
|
257
|
+
switch (fheType) {
|
|
258
|
+
case "ebool":
|
|
259
|
+
input.addBool(typeof value === "boolean" ? value : value !== 0n);
|
|
260
|
+
break;
|
|
261
|
+
case "euint8":
|
|
262
|
+
input.add8(toBigInt(value));
|
|
263
|
+
break;
|
|
264
|
+
case "euint16":
|
|
265
|
+
input.add16(toBigInt(value));
|
|
266
|
+
break;
|
|
267
|
+
case "euint32":
|
|
268
|
+
input.add32(toBigInt(value));
|
|
269
|
+
break;
|
|
270
|
+
case "euint64":
|
|
271
|
+
input.add64(toBigInt(value));
|
|
272
|
+
break;
|
|
273
|
+
case "euint128":
|
|
274
|
+
input.add128(toBigInt(value));
|
|
275
|
+
break;
|
|
276
|
+
case "euint256":
|
|
277
|
+
input.add256(toBigInt(value));
|
|
278
|
+
break;
|
|
279
|
+
case "eaddress":
|
|
280
|
+
input.addAddress(value);
|
|
281
|
+
break;
|
|
282
|
+
default: unreachableFheType(fheType);
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
/**
|
|
286
|
+
* Handle ENCRYPT request.
|
|
287
|
+
*/
|
|
288
|
+
async function handleEncrypt(request) {
|
|
289
|
+
const { id, type, payload } = request;
|
|
290
|
+
const { values, contractAddress, userAddress } = payload;
|
|
291
|
+
try {
|
|
292
|
+
const input = (await getInstance(payload.chainId)).createEncryptedInput(contractAddress, userAddress);
|
|
293
|
+
for (const entry of values) addTypedValue(input, entry);
|
|
294
|
+
const encrypted = await input.encrypt();
|
|
295
|
+
sendSuccess(id, type, {
|
|
296
|
+
handles: encrypted.handles,
|
|
297
|
+
inputProof: encrypted.inputProof
|
|
298
|
+
}, [encrypted.inputProof.buffer, ...encrypted.handles.map((h) => h.buffer)]);
|
|
299
|
+
} catch (error) {
|
|
300
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
301
|
+
console.error("[Worker] Encrypt error:", message);
|
|
302
|
+
sendError(id, type, message);
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* Handle USER_DECRYPT request.
|
|
307
|
+
*/
|
|
308
|
+
async function handleUserDecrypt(request) {
|
|
309
|
+
const { id, type, payload } = request;
|
|
310
|
+
try {
|
|
311
|
+
const instance = await getInstance(payload.chainId);
|
|
312
|
+
const handleContractPairs = payload.encryptedValues.map((encryptedValue) => ({
|
|
313
|
+
handle: encryptedValue,
|
|
314
|
+
contractAddress: payload.contractAddress
|
|
315
|
+
}));
|
|
316
|
+
sendSuccess(id, type, { clearValues: await instance.userDecrypt(handleContractPairs, unprefixHex(payload.privateKey), unprefixHex(payload.publicKey), payload.signature, payload.signedContractAddresses, payload.signerAddress, payload.startTimestamp, payload.durationDays) });
|
|
317
|
+
} catch (error) {
|
|
318
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
319
|
+
const statusCode = extractHttpStatus(error);
|
|
320
|
+
console.error("[Worker] UserDecrypt error:", message);
|
|
321
|
+
sendError(id, type, message, statusCode);
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Extract an HTTP status code from an error, if present.
|
|
326
|
+
* Relayer SDK errors may carry a \`status\` or \`statusCode\` property.
|
|
327
|
+
*/
|
|
328
|
+
function extractHttpStatus(error) {
|
|
329
|
+
if (error === null || error === void 0 || typeof error !== "object") return;
|
|
330
|
+
const e = error;
|
|
331
|
+
if (typeof e.statusCode === "number") return e.statusCode;
|
|
332
|
+
if (typeof e.status === "number") return e.status;
|
|
333
|
+
if (e.cause !== null && e.cause !== void 0 && typeof e.cause === "object") {
|
|
334
|
+
const cause = e.cause;
|
|
335
|
+
if (typeof cause.statusCode === "number") return cause.statusCode;
|
|
336
|
+
if (typeof cause.status === "number") return cause.status;
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
/**
|
|
340
|
+
* Handle PUBLIC_DECRYPT request.
|
|
341
|
+
*/
|
|
342
|
+
async function handlePublicDecrypt(request) {
|
|
343
|
+
const { id, type, payload } = request;
|
|
344
|
+
try {
|
|
345
|
+
sendSuccess(id, type, { ...await (await getInstance(payload.chainId)).publicDecrypt(payload.encryptedValues) });
|
|
346
|
+
} catch (error) {
|
|
347
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
348
|
+
console.error("[Worker] PublicDecrypt error:", message);
|
|
349
|
+
sendError(id, type, message);
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
/**
|
|
353
|
+
* Handle GENERATE_KEYPAIR request.
|
|
354
|
+
*/
|
|
355
|
+
async function handleGenerateKeypair(request) {
|
|
356
|
+
const { id, type, payload } = request;
|
|
357
|
+
try {
|
|
358
|
+
const keypair = (await getInstance(payload.chainId)).generateKeypair();
|
|
359
|
+
sendSuccess(id, type, {
|
|
360
|
+
publicKey: prefixHex(keypair.publicKey),
|
|
361
|
+
privateKey: prefixHex(keypair.privateKey)
|
|
362
|
+
});
|
|
363
|
+
} catch (error) {
|
|
364
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
365
|
+
console.error("[Worker] GenerateKeypair error:", message);
|
|
366
|
+
sendError(id, type, message);
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
/**
|
|
370
|
+
* Handle CREATE_EIP712 request.
|
|
371
|
+
*/
|
|
372
|
+
async function handleCreateEIP712(request) {
|
|
373
|
+
const { id, type, payload } = request;
|
|
374
|
+
try {
|
|
375
|
+
sendSuccess(id, type, (await getInstance(payload.chainId)).createEIP712(unprefixHex(payload.publicKey), payload.contractAddresses, payload.startTimestamp, payload.durationDays));
|
|
376
|
+
} catch (error) {
|
|
377
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
378
|
+
console.error("[Worker] CreateEIP712 error:", message);
|
|
379
|
+
sendError(id, type, message);
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
/**
|
|
383
|
+
* Handle CREATE_DELEGATED_EIP712 request.
|
|
384
|
+
*/
|
|
385
|
+
async function handleCreateDelegatedEIP712(request) {
|
|
386
|
+
const { id, type, payload } = request;
|
|
387
|
+
try {
|
|
388
|
+
sendSuccess(id, type, (await getInstance(payload.chainId)).createDelegatedUserDecryptEIP712(unprefixHex(payload.publicKey), payload.contractAddresses, payload.delegatorAddress, payload.startTimestamp, payload.durationDays));
|
|
389
|
+
} catch (error) {
|
|
390
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
391
|
+
console.error("[Worker] CreateDelegatedEIP712 error:", message);
|
|
392
|
+
sendError(id, type, message);
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
/**
|
|
396
|
+
* Handle DELEGATED_USER_DECRYPT request.
|
|
397
|
+
*/
|
|
398
|
+
async function handleDelegatedUserDecrypt(request) {
|
|
399
|
+
const { id, type, payload } = request;
|
|
400
|
+
try {
|
|
401
|
+
const instance = await getInstance(payload.chainId);
|
|
402
|
+
const handleContractPairs = payload.encryptedValues.map((encryptedValue) => ({
|
|
403
|
+
handle: encryptedValue,
|
|
404
|
+
contractAddress: payload.contractAddress
|
|
405
|
+
}));
|
|
406
|
+
sendSuccess(id, type, { clearValues: await instance.delegatedUserDecrypt(handleContractPairs, unprefixHex(payload.privateKey), unprefixHex(payload.publicKey), payload.signature, payload.signedContractAddresses, payload.delegatorAddress, payload.delegateAddress, payload.startTimestamp, payload.durationDays) });
|
|
407
|
+
} catch (error) {
|
|
408
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
409
|
+
const statusCode = extractHttpStatus(error);
|
|
410
|
+
console.error("[Worker] DelegatedUserDecrypt error:", message);
|
|
411
|
+
sendError(id, type, message, statusCode);
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
/**
|
|
415
|
+
* Handle REQUEST_ZK_PROOF_VERIFICATION request.
|
|
416
|
+
*/
|
|
417
|
+
async function handleRequestZKProofVerification(request) {
|
|
418
|
+
const { id, type, payload } = request;
|
|
419
|
+
try {
|
|
420
|
+
const result = await (await getInstance(payload.chainId)).requestZKProofVerification(payload.zkProof);
|
|
421
|
+
sendSuccess(id, type, result, [result.inputProof.buffer, ...result.handles.map((h) => h.buffer)]);
|
|
422
|
+
} catch (error) {
|
|
423
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
424
|
+
console.error("[Worker] RequestZKProofVerification error:", message);
|
|
425
|
+
sendError(id, type, message);
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
/**
|
|
429
|
+
* Handle GET_PUBLIC_KEY request.
|
|
430
|
+
*/
|
|
431
|
+
async function handleGetPublicKey(request) {
|
|
432
|
+
const { id, type, payload } = request;
|
|
433
|
+
try {
|
|
434
|
+
sendSuccess(id, type, { result: (await getInstance(payload.chainId)).getPublicKey() });
|
|
435
|
+
} catch (error) {
|
|
436
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
437
|
+
console.error("[Worker] GetPublicKey error:", message);
|
|
438
|
+
sendError(id, type, message);
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
/**
|
|
442
|
+
* Handle GET_PUBLIC_PARAMS request.
|
|
443
|
+
*/
|
|
444
|
+
async function handleGetPublicParams(request) {
|
|
445
|
+
const { id, type, payload } = request;
|
|
446
|
+
try {
|
|
447
|
+
sendSuccess(id, type, { result: (await getInstance(payload.chainId)).getPublicParams(payload.bits) });
|
|
448
|
+
} catch (error) {
|
|
449
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
450
|
+
console.error("[Worker] GetPublicParams error:", message);
|
|
451
|
+
sendError(id, type, message);
|
|
452
|
+
}
|
|
453
|
+
}
|
|
454
|
+
/**
|
|
455
|
+
* Handle UPDATE_CSRF request - update the stored CSRF token.
|
|
456
|
+
*/
|
|
457
|
+
function handleUpdateCsrf(request) {
|
|
458
|
+
const { id, type, payload } = request;
|
|
459
|
+
csrfTokenBase = payload.csrfToken;
|
|
460
|
+
sendSuccess(id, type, { updated: true });
|
|
461
|
+
}
|
|
462
|
+
/**
|
|
463
|
+
* Main message handler.
|
|
464
|
+
*/
|
|
465
|
+
self.onmessage = async (event) => {
|
|
466
|
+
const request = event.data;
|
|
467
|
+
try {
|
|
468
|
+
switch (request.type) {
|
|
469
|
+
case "INIT":
|
|
470
|
+
await handleInit(request);
|
|
471
|
+
break;
|
|
472
|
+
case "UPDATE_CSRF":
|
|
473
|
+
handleUpdateCsrf(request);
|
|
474
|
+
break;
|
|
475
|
+
case "ENCRYPT":
|
|
476
|
+
await handleEncrypt(request);
|
|
477
|
+
break;
|
|
478
|
+
case "USER_DECRYPT":
|
|
479
|
+
await handleUserDecrypt(request);
|
|
480
|
+
break;
|
|
481
|
+
case "PUBLIC_DECRYPT":
|
|
482
|
+
await handlePublicDecrypt(request);
|
|
483
|
+
break;
|
|
484
|
+
case "GENERATE_KEYPAIR":
|
|
485
|
+
await handleGenerateKeypair(request);
|
|
486
|
+
break;
|
|
487
|
+
case "CREATE_EIP712":
|
|
488
|
+
await handleCreateEIP712(request);
|
|
489
|
+
break;
|
|
490
|
+
case "CREATE_DELEGATED_EIP712":
|
|
491
|
+
await handleCreateDelegatedEIP712(request);
|
|
492
|
+
break;
|
|
493
|
+
case "DELEGATED_USER_DECRYPT":
|
|
494
|
+
await handleDelegatedUserDecrypt(request);
|
|
495
|
+
break;
|
|
496
|
+
case "REQUEST_ZK_PROOF_VERIFICATION":
|
|
497
|
+
await handleRequestZKProofVerification(request);
|
|
498
|
+
break;
|
|
499
|
+
case "GET_PUBLIC_KEY":
|
|
500
|
+
await handleGetPublicKey(request);
|
|
501
|
+
break;
|
|
502
|
+
case "GET_PUBLIC_PARAMS":
|
|
503
|
+
await handleGetPublicParams(request);
|
|
504
|
+
break;
|
|
505
|
+
default: console.error("[Worker] Unknown request type:", request.type);
|
|
506
|
+
}
|
|
507
|
+
} catch (error) {
|
|
508
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
509
|
+
sendError(request?.id ?? "unknown", request?.type ?? "UNKNOWN", message);
|
|
510
|
+
}
|
|
511
|
+
};
|
|
512
|
+
//#endregion
|
|
513
|
+
})();
|
|
514
|
+
`],{type:`application/javascript`}));try{return new Worker(t)}finally{URL.revokeObjectURL(t)}}wireEvents(e){e.onmessage=e=>this.handleResponse(e.data),e.onerror=e=>this.handleWorkerError(e.message),e.onmessageerror=()=>this.handleWorkerMessageError()}postMessage(e,t){e.postMessage(t)}terminateWorker(e){e.terminate()}generateRequestId(){return crypto.randomUUID()}getInitPayload(){let{cdnUrl:e,chains:t,csrfToken:n,integrity:r,thread:i}=this.config;return{type:`INIT`,payload:{env:`web`,cdnUrl:e,chains:t,csrfToken:n,integrity:r,thread:i}}}async updateCsrf(e){await this.sendRequest(`UPDATE_CSRF`,{csrfToken:e})}};const E=n.z.object({threads:n.z.optional(n.z.int().check(n.z.positive())),fheArtifactCacheTTL:n.z.optional(n.z.int().check(n.z.nonnegative()))});function D(t){return t!==void 0&&e.t(E,t),{type:`web`,createWorker:e=>new T({cdnUrl:`https://cdn.zama.org/relayer-sdk-js/0.4.2/relayer-sdk-js.umd.cjs`,chains:e,csrfToken:t?.security?.getCsrfToken?.()??``,integrity:t?.security?.integrityCheck===!1?void 0:`114438b01d518b53a447fa3e8bfbe6e71031cb42ac43219bb9f53488456fdfa4bbc8989628366d436e68f6526c7647eb`,logger:t?.logger,thread:t?.threads}),createRelayer:(e,n)=>new b({chain:e,worker:n,...t})}}exports.RelayerWeb=b,exports.web=D;
|
|
515
|
+
//# sourceMappingURL=index.cjs.map
|