@zama-fhe/sdk 2.0.0-alpha.3 → 2.0.0-alpha.4

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.
Files changed (38) hide show
  1. package/dist/cjs/activity.cjs +1 -1
  2. package/dist/cjs/index.cjs +1 -1
  3. package/dist/cjs/index.cjs.map +1 -1
  4. package/dist/esm/activity-DQQl0pbY.js +2 -0
  5. package/dist/esm/activity-DQQl0pbY.js.map +1 -0
  6. package/dist/esm/{activity-B1fFV04Z.d.ts → activity-DaNXJQI6.d.ts} +3 -4
  7. package/dist/esm/cleartext/index.d.ts +2 -2
  8. package/dist/esm/{eip1193-subscribe-3FLcs1me.js → eip1193-subscribe-DuNXBjej.js} +1 -1
  9. package/dist/esm/{eip1193-subscribe-3FLcs1me.js.map → eip1193-subscribe-DuNXBjej.js.map} +1 -1
  10. package/dist/esm/ethers/index.d.ts +2 -3
  11. package/dist/esm/ethers/index.js +1 -1
  12. package/dist/esm/fhe-artifact-cache-Ws5Sb7ha.js +2 -0
  13. package/dist/esm/fhe-artifact-cache-Ws5Sb7ha.js.map +1 -0
  14. package/dist/esm/{index-BFPpJ8wt.d.ts → index-Ym1h4U9i.d.ts} +2 -2
  15. package/dist/esm/index.d.ts +7 -6
  16. package/dist/esm/index.js +2 -2
  17. package/dist/esm/index.js.map +1 -1
  18. package/dist/esm/memory-storage-CaIfvzoX.js +2 -0
  19. package/dist/esm/memory-storage-CaIfvzoX.js.map +1 -0
  20. package/dist/esm/node/index.d.ts +10 -3
  21. package/dist/esm/node/index.js +1 -1
  22. package/dist/esm/node/index.js.map +1 -1
  23. package/dist/esm/query/index.d.ts +3 -4
  24. package/dist/esm/query/index.js +1 -1
  25. package/dist/esm/query/index.js.map +1 -1
  26. package/dist/esm/{relayer-sdk-CVVR30IW.d.ts → relayer-sdk-CUlPJ50H.d.ts} +2 -2
  27. package/dist/esm/relayer-sdk.node-worker.js +1 -1
  28. package/dist/esm/{token.types-DDdIZEax.d.ts → relayer-sdk.types-DK7QkCGv.d.ts} +328 -3
  29. package/dist/esm/{utils-eIBZNA_w.js → utils-DlyKooNc.js} +2 -2
  30. package/dist/esm/{utils-eIBZNA_w.js.map → utils-DlyKooNc.js.map} +1 -1
  31. package/dist/esm/viem/index.d.ts +2 -3
  32. package/dist/esm/viem/index.js +1 -1
  33. package/package.json +1 -1
  34. package/dist/esm/activity-DEoxFQLE.js +0 -2
  35. package/dist/esm/activity-DEoxFQLE.js.map +0 -1
  36. package/dist/esm/relayer-sdk.types-DI4WWkTB.d.ts +0 -317
  37. package/dist/esm/worker.base-client-DGGSkczN.js +0 -2
  38. package/dist/esm/worker.base-client-DGGSkczN.js.map +0 -1
@@ -1,2 +1,2 @@
1
- const e=require(`./errors.cjs`),t=require(`./erc165.cjs`);let n=require(`viem`);function r(e){return e instanceof Error?e:Error(String(e))}function i(e){return e.startsWith(`0x`)?e:`0x${e}`}function a(e,t){if(typeof e!=`object`||!e||Array.isArray(e))throw TypeError(`${t} must be an object, got ${typeof e}`)}function o(e,t){if(typeof e!=`string`)throw TypeError(`${t} must be a string, got ${typeof e}`)}function s(e,t){if(!Array.isArray(e))throw TypeError(`${t} must be an array, got ${typeof e}`)}function c(e,t){if(typeof e!=`function`)throw TypeError(`${t} must be a function, got ${typeof e}`)}function l(e,t,n){o(e[t],n)}function u(e,t,n){c(e[t],n)}function d(e,t){if(!e)throw TypeError(t)}function f(){let e=globalThis;for(let t of[e.chrome,e.browser])try{a(t,`ns`);let{runtime:e}=t;return a(e,`runtime`),l(e,`id`,`runtime.id`),u(e,`getURL`,`runtime.getURL`),e}catch{continue}}async function ee(e,t=1/0){if(!Number.isFinite(t)||t>=e.length)return Promise.all(e.map(e=>e()));let n=Array.from({length:e.length}),r=0;async function i(){for(;r<e.length;){let t=r++;n[t]=await e[t]()}}return await Promise.all(Array.from({length:t},i)),n}function p(e){return{address:e,abi:n.erc20Abi,functionName:`name`,args:[]}}function m(e){return{address:e,abi:n.erc20Abi,functionName:`symbol`,args:[]}}function h(e){return{address:e,abi:n.erc20Abi,functionName:`decimals`,args:[]}}function g(e,t){return{address:e,abi:n.erc20Abi,functionName:`balanceOf`,args:[t]}}function _(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`allowance`,args:[t,r]}}function v(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`approve`,args:[t,r]}}const y=[{inputs:[{internalType:`uint256`,name:`amount`,type:`uint256`},{internalType:`address`,name:`wrapFrom`,type:`address`},{internalType:`address`,name:`wrapTo`,type:`address`}],name:`getWrapFee`,outputs:[{internalType:`uint256`,name:``,type:`uint256`}],stateMutability:`view`,type:`function`},{inputs:[{internalType:`uint64`,name:`amount`,type:`uint64`},{internalType:`address`,name:`unwrapFrom`,type:`address`},{internalType:`address`,name:`unwrapTo`,type:`address`}],name:`getUnwrapFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`getBatchTransferFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`getFeeRecipient`,outputs:[{internalType:`address`,name:``,type:`address`}],stateMutability:`view`,type:`function`}];function te(e,t,n,r){return{address:e,abi:y,functionName:`getWrapFee`,args:[t,n,r]}}function ne(e,t,n,r){return{address:e,abi:y,functionName:`getUnwrapFee`,args:[t,n,r]}}function re(e){return{address:e,abi:y,functionName:`getBatchTransferFee`,args:[]}}function ie(e){return{address:e,abi:y,functionName:`getFeeRecipient`,args:[]}}const b=[{inputs:[{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`},{internalType:`uint64`,name:`expirationDate`,type:`uint64`}],name:`delegateForUserDecryption`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`}],name:`revokeDelegationForUserDecryption`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`address`,name:`delegator`,type:`address`},{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`}],name:`getUserDecryptionDelegationExpirationDate`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`}];function ae(e,t,n,r){return{address:e,abi:b,functionName:`delegateForUserDecryption`,args:[t,n,r]}}function oe(e,t,n){return{address:e,abi:b,functionName:`revokeDelegationForUserDecryption`,args:[t,n]}}function x(e,t,n,r){return{address:e,abi:b,functionName:`getUserDecryptionDelegationExpirationDate`,args:[t,n,r]}}const S=2n**64n-1n,C={CredentialsLoading:`credentials:loading`,CredentialsCached:`credentials:cached`,CredentialsExpired:`credentials:expired`,CredentialsCreating:`credentials:creating`,CredentialsCreated:`credentials:created`,CredentialsRevoked:`credentials:revoked`,CredentialsAllowed:`credentials:allowed`,SessionExpired:`session:expired`,EncryptStart:`encrypt:start`,EncryptEnd:`encrypt:end`,EncryptError:`encrypt:error`,DecryptStart:`decrypt:start`,DecryptEnd:`decrypt:end`,DecryptError:`decrypt:error`,TransactionError:`transaction:error`,ShieldSubmitted:`shield:submitted`,TransferSubmitted:`transfer:submitted`,TransferFromSubmitted:`transferFrom:submitted`,ApproveSubmitted:`approve:submitted`,ApproveUnderlyingSubmitted:`approveUnderlying:submitted`,UnwrapSubmitted:`unwrap:submitted`,FinalizeUnwrapSubmitted:`finalizeUnwrap:submitted`,DelegationSubmitted:`delegation:submitted`,RevokeDelegationSubmitted:`revokeDelegation:submitted`,UnshieldPhase1Submitted:`unshield:phase1_submitted`,UnshieldPhase2Started:`unshield:phase2_started`,UnshieldPhase2Submitted:`unshield:phase2_submitted`};var w=class{#e=new Map;async get(e){return this.#e.get(e)??null}async set(e,t){this.#e.set(e,t)}async delete(e){this.#e.delete(e)}};const se=new w;var ce=class{#e=null;#t=null;clearCache(){this.#e=null,this.#t=null}async encrypt(e,t,n){let r=await this.#n(t,n),i=crypto.getRandomValues(new Uint8Array(12)),a=new TextEncoder,o=await crypto.subtle.encrypt({name:`AES-GCM`,iv:i},r,a.encode(e));return{iv:btoa(String.fromCharCode(...i)),ciphertext:btoa(String.fromCharCode(...new Uint8Array(o)))}}async decrypt(e,t,n){let r=await this.#n(t,n),a=Uint8Array.from(atob(e.iv),e=>e.charCodeAt(0)),o=Uint8Array.from(atob(e.ciphertext),e=>e.charCodeAt(0)),s=await crypto.subtle.decrypt({name:`AES-GCM`,iv:a},r,o);return i(new TextDecoder().decode(s))}async#n(e,t){let n=`${e}:${t}`;if(this.#e&&this.#t===n)return this.#e;let r=new TextEncoder,i=await crypto.subtle.importKey(`raw`,r.encode(e),`PBKDF2`,!1,[`deriveKey`]),a=await crypto.subtle.deriveKey({name:`PBKDF2`,salt:r.encode(t),iterations:6e5,hash:`SHA-256`},i,{name:`AES-GCM`,length:256},!1,[`encrypt`,`decrypt`]);return this.#t=n,this.#e=a,a}};function T(e){a(e,`Stored credentials`),o(e.publicKey,`credentials.publicKey`),s(e.contractAddresses,`credentials.contractAddresses`);for(let t of e.contractAddresses)d(typeof t==`string`&&(0,n.isAddress)(t,{strict:!1}),`Expected each contractAddress to be a valid hex address`);a(e.encryptedPrivateKey,`credentials.encryptedPrivateKey`),o(e.encryptedPrivateKey.iv,`encryptedPrivateKey.iv`),o(e.encryptedPrivateKey.ciphertext,`encryptedPrivateKey.ciphertext`)}function le(e){T(e);let t=e;d(typeof t.delegatorAddress==`string`&&(0,n.isAddress)(t.delegatorAddress,{strict:!1}),`Expected credentials.delegatorAddress to be a valid address`),d(typeof t.delegateAddress==`string`&&(0,n.isAddress)(t.delegateAddress,{strict:!1}),`Expected credentials.delegateAddress to be a valid address`),d(typeof t.startTimestamp==`number`,`Expected startTimestamp to be a number`),d(typeof t.durationDays==`number`,`Expected durationDays to be a number`)}function E(e){return Math.floor(Date.now()/1e3)<e.startTimestamp+e.durationDays*86400}function D(e,t){let r=new Set(t.map(e=>(0,n.getAddress)(e))),i=new Set(e.map(e=>(0,n.getAddress)(e)));return r.isSubsetOf(i)}function O(e,t){return E(e)?D(e.contractAddresses,t):!1}function k(e){return[...new Set(e.map(e=>(0,n.getAddress)(e)))].toSorted()}async function ue(...e){let t=await crypto.subtle.digest(`SHA-256`,new TextEncoder().encode(e.map(String).join(`:`)));return Array.from(new Uint8Array(t)).map(e=>e.toString(16).padStart(2,`0`)).join(``).slice(0,32)}var de=class{#e;constructor(e){this.#e=e}#t(e){a(e,`Session entry`),o(e.signature,`session.signature`),d(typeof e.createdAt==`number`,`Expected session.createdAt to be a number`),d(typeof e.ttl==`number`||e.ttl===`infinite`,`Expected session.ttl to be a number or "infinite"`)}async get(e){let t=await this.#e.get(e);return t===null?null:(this.#t(t),t)}async set(e){let t={signature:e.signature,createdAt:Math.floor(Date.now()/1e3),ttl:e.ttl};await this.#e.set(e.key,t)}async delete(e){await this.#e.delete(e)}isExpired(e){return e.ttl===`infinite`?!1:e.ttl===0?!0:Math.floor(Date.now()/1e3)-e.createdAt>=e.ttl}},A=class{signer;storage;sessionSignatures;crypto;keypairTTL;sessionTTL;#e;#t=null;#n=null;#r=null;constructor(e){if(this.signer=e.signer,this.storage=e.storage,this.sessionSignatures=new de(e.sessionStorage),this.crypto=new ce,this.keypairTTL=e.keypairTTL??86400,this.sessionTTL=e.sessionTTL??2592e3,this.#e=e.onEvent??(()=>{}),typeof this.keypairTTL==`number`&&this.keypairTTL<0)throw Error(`keypairTTL must be >= 0`);if(typeof this.sessionTTL==`number`&&this.sessionTTL<0)throw Error(`sessionTTL must be >= 0`)}emit(e){this.#e({...e,timestamp:Date.now()})}async resolveCredentials({key:t,contracts:n,createKey:r,createFn:i}){this.emit({type:C.CredentialsLoading,contractAddresses:n});try{let e=await this.storage.get(t);if(e){this.assertEncrypted(e);let r=await this.sessionSignatures.get(t);if(r)if(this.sessionSignatures.isExpired(r))await this.sessionSignatures.delete(t),this.emit({type:C.SessionExpired,reason:`ttl`});else{let i=await this.decryptCredentials(e,r.signature);if(O(i,n))return this.emit({type:C.CredentialsCached,contractAddresses:n}),this.emit({type:C.CredentialsAllowed,contractAddresses:n}),i;if(E(i))return this.#i({key:t,credentials:i,requiredContracts:n});this.emit({type:C.CredentialsExpired,contractAddresses:n})}if(E(e)){if(D(e.contractAddresses,n)){let r=await this.signForContracts(e,e.contractAddresses);await this.sessionSignatures.set({key:t,signature:r,ttl:this.sessionTTL});let i=await this.decryptCredentials(e,r);return this.emit({type:C.CredentialsCached,contractAddresses:n}),this.emit({type:C.CredentialsAllowed,contractAddresses:n}),i}let r=await this.signForContracts(e,e.contractAddresses),i=await this.decryptCredentials(e,r);return this.#i({key:t,credentials:i,requiredContracts:n})}this.emit({type:C.CredentialsExpired,contractAddresses:n})}}catch(n){if(n instanceof e.m||n instanceof e.p)throw n;console.warn(`[zama-sdk] Credential resolution failed, recreating:`,n),await this.#o(t)}return(!this.#t||this.#n!==r)&&(this.#n=r,this.#t=i().then(e=>(this.emit({type:C.CredentialsAllowed,contractAddresses:n}),e)).finally(()=>{this.#t=null,this.#n=null})),this.#t}async checkExpired(e,t){try{let n=await this.storage.get(e);return n?(this.assertEncrypted(n),!O(n,t?[t]:[])):!1}catch(e){return console.warn(`[zama-sdk] isExpired check failed, treating as expired:`,e),!0}}async revokeSession(e,t){await this.sessionSignatures.delete(e),this.clearCaches(),this.emit({type:C.CredentialsRevoked,...t?{contractAddresses:t}:{}})}async checkAllowed(e){let t=await this.sessionSignatures.get(e);return t===null?!1:!this.sessionSignatures.isExpired(t)}async clearAll(e){await this.sessionSignatures.delete(e),this.clearCaches(),await this.#o(e)}clearCaches(){this.crypto.clearCache()}async createCredentials({key:t,contractAddresses:n,createFn:r,errorContext:i}){this.emit({type:C.CredentialsCreating,contractAddresses:n});try{let e=await r();return await this.persistCredentials(t,e),await this.sessionSignatures.set({key:t,signature:e.signature,ttl:this.sessionTTL}),this.emit({type:C.CredentialsCreated,contractAddresses:n}),e}catch(t){e.y(t,i)}}async#i({key:e,credentials:t,requiredContracts:n}){if(this.#r){let e=await this.#r;if(D(e.contractAddresses,n))return this.emit({type:C.CredentialsAllowed,contractAddresses:n}),e;t=e}let r=this.#a({key:e,credentials:t,requiredContracts:n});this.#r=r;try{return await r}finally{this.#r===r&&(this.#r=null)}}async#a({key:e,credentials:t,requiredContracts:n}){let r=k([...t.contractAddresses,...n]),i=await this.signForContracts(t,r),a={...t,contractAddresses:r,signature:i};return await this.persistCredentials(e,a),await this.sessionSignatures.set({key:e,signature:i,ttl:this.sessionTTL}),this.emit({type:C.CredentialsAllowed,contractAddresses:n}),a}async persistCredentials(e,t){try{let n=await this.encryptCredentials(t);await this.storage.set(e,n)}catch(e){console.warn(`[zama-sdk] Failed to encrypt credentials for persistence:`,e);return}}async#o(e){try{await this.storage.delete(e)}catch(e){console.warn(`[zama-sdk] Failed to delete credentials:`,e)}}};function fe(e){if(typeof e!=`object`||!e)return!1;let t=Reflect.get(e,`runtime`);return typeof t!=`object`||!t?!1:typeof Reflect.get(t,`id`)==`string`}var j=class e extends A{#e;#t=null;#n=null;static async computeStoreKey(e,t){return ue((0,n.getAddress)(e),t)}constructor(e){super(e),this.#e=e.relayer,fe(typeof globalThis<`u`?Reflect.get(globalThis,`chrome`):void 0)&&e.sessionStorage instanceof w&&console.warn(`[zama-sdk] Detected Chrome extension context with in-memory session storage. Session signatures will be lost on service worker restart and won't be shared across contexts. Consider using chromeSessionStorage instead. `)}async allow(...e){let t=k(e),n=await this.#r();return this.resolveCredentials({key:n,contracts:t,createKey:t.join(`,`),createFn:()=>this.create(t)})}async isExpired(e){return this.checkExpired(await this.#r(),e)}async revoke(...e){await this.revokeSession(await this.#r(),e.length>0?e:void 0)}async isAllowed(){return this.checkAllowed(await this.#r())}async clear(){await this.clearAll(await this.#r())}async create(e){let t=k(e),n=await this.#r();return this.createCredentials({key:n,contractAddresses:t,createFn:async()=>{let e=await this.#e.generateKeypair(),n=Math.floor(Date.now()/1e3),r=Math.ceil(this.keypairTTL/86400),i=await this.#e.createEIP712(e.publicKey,t,n,r),a=await this.signer.signTypedData(i);return{publicKey:e.publicKey,privateKey:e.privateKey,signature:a,contractAddresses:t,startTimestamp:n,durationDays:r}},errorContext:`Failed to create decrypt credentials`})}assertEncrypted(e){T(e)}async signForContracts(e,t){let n=await this.#e.createEIP712(e.publicKey,t,e.startTimestamp,e.durationDays);return this.signer.signTypedData(n)}async encryptCredentials(e){let t=await this.signer.getAddress(),n=await this.crypto.encrypt(e.privateKey,e.signature,t),{privateKey:r,signature:i,...a}=e;return{...a,encryptedPrivateKey:n}}async decryptCredentials(e,t){let n=await this.signer.getAddress(),r=await this.crypto.decrypt(e.encryptedPrivateKey,t,n),{encryptedPrivateKey:i,...a}=e;return{...a,privateKey:r,signature:t}}clearCaches(){this.#t=null,this.#n=null,super.clearCaches()}async#r(){let t=await this.signer.getAddress(),r=await this.signer.getChainId(),i=`${(0,n.getAddress)(t)}:${r}`;if(this.#t&&this.#n===i)return this.#t;let a=await e.computeStoreKey(t,r);return this.#n=i,this.#t=a,a}},M=class e extends A{#e;#t=null;#n=null;static async computeStoreKey(e,t,r){return ue((0,n.getAddress)(e),(0,n.getAddress)(t),r)}constructor(e){super(e),this.#e=e.relayer}async allow(e,...t){let r=(0,n.getAddress)(e),i=k(t),a=await this.#i(r);return this.resolveCredentials({key:a,contracts:i,createKey:`${r}:${i.join(`,`)}`,createFn:()=>this.#r(r,i)})}async isExpired(e,t){return this.checkExpired(await this.#i((0,n.getAddress)(e)),t)}async revoke(e){await this.revokeSession(await this.#i((0,n.getAddress)(e)))}async isAllowed(e){return this.checkAllowed(await this.#i((0,n.getAddress)(e)))}async clear(e){await this.clearAll(await this.#i((0,n.getAddress)(e)))}async#r(e,t){let n=await this.#i(e);return this.createCredentials({key:n,contractAddresses:t,createFn:async()=>{let n=await this.#e.generateKeypair(),r=await this.signer.getAddress(),i=Math.floor(Date.now()/1e3),a=Math.ceil(this.keypairTTL/86400),o={publicKey:n.publicKey,startTimestamp:i,durationDays:a,delegatorAddress:e},s=await this.#a(o,t);return{publicKey:n.publicKey,privateKey:n.privateKey,signature:s,contractAddresses:t,startTimestamp:i,durationDays:a,delegatorAddress:e,delegateAddress:r}},errorContext:`Failed to create delegated decrypt credentials`})}assertEncrypted(e){le(e)}async signForContracts(e,t){return this.#a(e,t)}async encryptCredentials(e){let t=await this.signer.getAddress(),n=await this.crypto.encrypt(e.privateKey,e.signature,t),{privateKey:r,signature:i,...a}=e;return{...a,encryptedPrivateKey:n}}async decryptCredentials(e,t){let n=await this.signer.getAddress(),r=await this.crypto.decrypt(e.encryptedPrivateKey,t,n),{encryptedPrivateKey:i,...a}=e;return{...a,privateKey:r,signature:t}}clearCaches(){this.#t=null,this.#n=null,super.clearCaches()}async#i(t){let r=await this.signer.getAddress(),i=await this.signer.getChainId(),a=`${(0,n.getAddress)(r)}:${(0,n.getAddress)(t)}:${i}`;if(this.#t&&this.#n===a)return this.#t;let o=await e.computeStoreKey(r,t,i);return this.#n=a,this.#t=o,o}async#a(e,t){let n=await this.#e.createDelegatedUserDecryptEIP712(e.publicKey,t,e.delegatorAddress,e.startTimestamp,e.durationDays);return this.signer.signTypedData({domain:{...n.domain,chainId:Number(n.domain.chainId)},types:n.types,message:{...n.message,startTimestamp:BigInt(n.message.startTimestamp),durationDays:BigInt(n.message.durationDays)}})}};const N=`zama:balances`;function P(e,t,r){return`zama:balance:${(0,n.getAddress)(e)}:${(0,n.getAddress)(t)}:${r.toLowerCase()}`}async function F({storage:e,tokenAddress:t,owner:n,handle:r}){try{let i=await e.get(P(t,n,r));return i===null?null:BigInt(i)}catch(e){return console.warn(`[zama-sdk] Balance cache read failed:`,e),null}}async function I(e){let{storage:t,tokenAddress:n,owner:r,handle:i,value:a}=e,o=P(n,r,i);try{await t.set(o,a.toString()),await pe(t,o)}catch{}}const L=new WeakMap;async function pe(e,t){let n=(L.get(e)??Promise.resolve()).then(async()=>{let n=await e.get(N),r=n?JSON.parse(n):[];r.includes(t)||(r.push(t),await e.set(N,JSON.stringify(r)))});return L.set(e,n.catch(()=>{})),n}var me=class i{credentials;delegatedCredentials;relayer;signer;address;storage;#e;constructor(e){let t={relayer:e.relayer,signer:e.signer,storage:e.storage,sessionStorage:e.sessionStorage,keypairTTL:e.keypairTTL??86400,sessionTTL:e.sessionTTL??2592e3,onEvent:e.onEvent};this.credentials=e.credentials??new j(t),this.delegatedCredentials=e.delegatedCredentials??new M(t),this.relayer=e.relayer,this.signer=e.signer,this.address=(0,n.getAddress)(e.address),this.storage=e.storage,this.#e=e.onEvent}emit(e){this.#e?.({...e,tokenAddress:this.address,timestamp:Date.now()})}async balanceOf(e){let t=e?(0,n.getAddress)(e):await this.signer.getAddress(),r=await this.readConfidentialBalanceOf(t);return this.decryptBalance(r,t)}async confidentialBalanceOf(e){let t=e?(0,n.getAddress)(e):await this.signer.getAddress();return this.readConfidentialBalanceOf(t)}async isConfidential(){return await this.signer.readContract(t.a(this.address,t.t))}async isWrapper(){return await this.signer.readContract(t.a(this.address,t.n))}static async batchDecryptBalances(e,t){if(e.length===0)return new Map;let{handles:n,owner:r,onError:a,maxConcurrency:o}=t??{},s=e[0],c=i.assertSameRelayer(e),l=r??await s.signer.getAddress();return i.#t({tokens:e,handles:n,ownerAddress:l,onError:a,maxConcurrency:o,obtainCreds:e=>s.credentials.allow(...e),decrypt:(e,t,n)=>c.userDecrypt({handles:[t],contractAddress:n,signedContractAddresses:e.contractAddresses,privateKey:e.privateKey,publicKey:e.publicKey,signature:e.signature,signerAddress:l,startTimestamp:e.startTimestamp,durationDays:e.durationDays}),errorPrefix:`Batch decryption`})}static async batchDecryptBalancesAs(e,t){if(e.length===0)return new Map;let{delegatorAddress:n,handles:r,owner:a,onError:o,maxConcurrency:s}=t,c=a??n,l=e[0];return i.assertSameRelayer(e),i.#t({tokens:e,handles:r,ownerAddress:c,onError:o,maxConcurrency:s,preFlightCheck:()=>l.#n(n),obtainCreds:e=>l.delegatedCredentials.allow(n,...e),decrypt:(e,t,n)=>l.relayer.delegatedUserDecrypt({handles:[t],contractAddress:n,signedContractAddresses:e.contractAddresses,privateKey:e.privateKey,publicKey:e.publicKey,signature:e.signature,delegatorAddress:e.delegatorAddress,delegateAddress:e.delegateAddress,startTimestamp:e.startTimestamp,durationDays:e.durationDays}),errorPrefix:`Batch delegated decryption`})}static async#t(t){let{tokens:n,handles:i,ownerAddress:a,onError:o,maxConcurrency:s,obtainCreds:c,decrypt:l,errorPrefix:u}=t,d=n[0],f=i??await Promise.all(n.map(e=>e.readConfidentialBalanceOf(a)));if(n.length!==f.length)throw new e.r(`tokens.length (${n.length}) must equal handles.length (${f.length})`);let p=d.storage,m=new Map,h=[],g=await Promise.all(n.map((e,t)=>{let n=f[t];return e.isZeroHandle(n)?0n:F({storage:p,tokenAddress:e.address,owner:a,handle:n})}));for(let e=0;e<n.length;e++){let t=n[e],r=f[e],i=g[e];if(i!=null){m.set(t.address,i);continue}h.push({token:t,handle:r})}if(h.length===0)return m;t.preFlightCheck&&await t.preFlightCheck();let _=await c(h.map(e=>e.token.address)),v=[],y=[];for(let{token:t,handle:n}of h)y.push(()=>l(_,n,t.address).then(async r=>{let i=r[n];if(i===void 0)throw new e.r(`${u} returned no value for handle ${n} on token ${t.address}`);m.set(t.address,i);try{await I({storage:p,tokenAddress:t.address,owner:a,handle:n,value:i})}catch{}}).catch(e=>{let n=r(e);if(o)try{m.set(t.address,o(n,t.address))}catch(e){v.push({address:t.address,error:r(e)})}else v.push({address:t.address,error:n})}));if(await ee(y,s),v.length>0){let t=v.map(e=>`${e.address}: ${e.error.message}`).join(`; `);throw new e.r(`${u} failed for ${v.length} token(s): ${t}`)}return m}async discoverWrapper(e){let r=(0,n.getAddress)(e);return await this.signer.readContract(t.s(r,this.address))?this.signer.readContract(t.o(r,this.address)):null}async underlyingToken(){return this.signer.readContract(t.l(this.address))}async allowance(e,r){let i=(0,n.getAddress)(e),a=await this.signer.readContract(t.l(i)),o=r?(0,n.getAddress)(r):await this.signer.getAddress();return this.signer.readContract(_(a,o,i))}async name(){return this.signer.readContract(p(this.address))}async symbol(){return this.signer.readContract(m(this.address))}async decimals(){return this.signer.readContract(h(this.address))}async allow(){await this.credentials.allow(this.address)}async isAllowed(){return this.credentials.isAllowed()}async revoke(...e){await this.credentials.revoke(...e)}static async allow(...e){if(e.length===0)return;let t=e.map(e=>e.address);await e[0].credentials.allow(...t)}async getAclAddress(){return this.relayer.getAclAddress()}async isDelegated(e){let t=await this.getDelegationExpiry(e);return t===0n?!1:t===S?!0:t>await this.signer.getBlockTimestamp()}async getDelegationExpiry({delegatorAddress:e,delegateAddress:t}){let r=await this.getAclAddress();return this.signer.readContract(x(r,(0,n.getAddress)(e),(0,n.getAddress)(t),this.address))}async#n(t){let n=await this.signer.getAddress(),r=await this.getDelegationExpiry({delegatorAddress:t,delegateAddress:n});if(r===0n)throw new e.o(`No active delegation from ${t} to ${n} for ${this.address}`);if(r!==S&&r<=await this.signer.getBlockTimestamp())throw new e.a(`Delegation from ${t} to ${n} for ${this.address} has expired`)}async readConfidentialBalanceOf(e){return await this.signer.readContract(t.f(this.address,e))}isZeroHandle(e){return e===`0x0000000000000000000000000000000000000000000000000000000000000000`||e===`0x`}async decryptBalanceAs({delegatorAddress:t,owner:i}){let a=(0,n.getAddress)(t),o=i?(0,n.getAddress)(i):a,s=await this.readConfidentialBalanceOf(o);if(this.isZeroHandle(s))return 0n;let c=await F({storage:this.storage,tokenAddress:this.address,owner:o,handle:s});if(c!==null)return c;await this.#n(a);let l=Date.now();try{this.emit({type:C.DecryptStart});let t=await this.delegatedCredentials.allow(a,this.address),n=await this.relayer.delegatedUserDecrypt({handles:[s],contractAddress:this.address,signedContractAddresses:t.contractAddresses,privateKey:t.privateKey,publicKey:t.publicKey,signature:t.signature,delegatorAddress:t.delegatorAddress,delegateAddress:t.delegateAddress,startTimestamp:t.startTimestamp,durationDays:t.durationDays});this.emit({type:C.DecryptEnd,durationMs:Date.now()-l});let r=n[s];if(r===void 0)throw new e.r(`Delegated decryption returned no value for handle ${s}`);try{await I({storage:this.storage,tokenAddress:this.address,owner:o,handle:s,value:r})}catch{}return r}catch(e){throw this.emit({type:C.DecryptError,error:r(e),durationMs:Date.now()-l}),R(e,`Failed to decrypt delegated balance`)}}async decryptBalance(t,n){if(this.isZeroHandle(t))return 0n;let i=n??await this.signer.getAddress(),a=await F({storage:this.storage,tokenAddress:this.address,owner:i,handle:t});if(a!==null)return a;let o=await this.credentials.allow(this.address),s=Date.now();try{this.emit({type:C.DecryptStart});let n=await this.relayer.userDecrypt({handles:[t],contractAddress:this.address,signedContractAddresses:o.contractAddresses,privateKey:o.privateKey,publicKey:o.publicKey,signature:o.signature,signerAddress:i,startTimestamp:o.startTimestamp,durationDays:o.durationDays});this.emit({type:C.DecryptEnd,durationMs:Date.now()-s});let r=n[t];if(r===void 0)throw new e.r(`Decryption returned no value for handle ${t}`);try{await I({storage:this.storage,tokenAddress:this.address,owner:i,handle:t,value:r})}catch{}return r}catch(e){throw this.emit({type:C.DecryptError,error:r(e),durationMs:Date.now()-s}),R(e,`Failed to decrypt balance`)}}async decryptHandles(t,n){let i=new Map,a=[];for(let e of t)this.isZeroHandle(e)?i.set(e,0n):a.push(e);if(a.length===0)return i;let o=await this.credentials.allow(this.address),s=Date.now();try{this.emit({type:C.DecryptStart});let t=await this.relayer.userDecrypt({handles:a,contractAddress:this.address,signedContractAddresses:o.contractAddresses,privateKey:o.privateKey,publicKey:o.publicKey,signature:o.signature,signerAddress:n??await this.signer.getAddress(),startTimestamp:o.startTimestamp,durationDays:o.durationDays});this.emit({type:C.DecryptEnd,durationMs:Date.now()-s});for(let n of a){let r=t[n];if(r===void 0)throw new e.r(`Decryption returned no value for handle ${n}`);i.set(n,r)}}catch(e){throw this.emit({type:C.DecryptError,error:r(e),durationMs:Date.now()-s}),R(e,`Failed to decrypt handles`)}return i}static assertSameRelayer(t){let n=t[0].relayer;for(let r=1;r<t.length;r++)if(t[r].relayer!==n)throw new e.n(`All tokens in a batch operation must share the same relayer instance`);return n}};function R(t,n){if(t instanceof e.r||t instanceof e.d||t instanceof e.f||t instanceof e.m||t instanceof e.p)return t;let r=typeof t==`object`&&t&&`statusCode`in t&&typeof t.statusCode==`number`?t.statusCode:void 0;return r===400?new e.d(t instanceof Error?t.message:`No ciphertext for this account`,{cause:t}):r===void 0?new e.r(n,{cause:t}):new e.f(t instanceof Error?t.message:n,r,{cause:t})}const z={ConfidentialTransfer:`0x67500e8d0ed826d2194f514dd0d8124f35648ab6e3fb5e6ed867134cffe661e9`,Wrapped:`0x1f7907f4d84043abe0fb7c74e8865ee5fe93fe4f691c54a7b8fa9d6fb17c7cba`,UnwrapRequested:`0x77d02d353c5629272875d11f1b34ec4c65d7430b075575b78cd2502034c469ee`,UnwrappedFinalized:`0xc64e7c81b18b674fc5b037d8a0041bfe3332d86c780a4688f404ee01fbabb152`,UnwrappedStarted:`0x3838891d4843c6d7f9f494570b6fd8843f4e3c3ddb817c1411760bd31b819806`};function B(e){return(0,n.getAddress)(i(e.slice(-40)))}function V(e){return BigInt(e)}function H(e){return e}function U(e,t){let n=2+t*64,r=e.slice(n,n+64);return r.length===64?r:r.padEnd(64,`0`)}function he(e,t){return(0,n.getAddress)(i(U(e,t).slice(-40)))}function W(e,t){return BigInt(`0x`+U(e,t))}function G(e,t){return BigInt(`0x`+U(e,t))!==0n}function K(e,t){return i(U(e,t))}function q(e){return e.topics[0]!==z.ConfidentialTransfer||e.topics.length<4?null:{eventName:`ConfidentialTransfer`,from:B(e.topics[1]),to:B(e.topics[2]),encryptedAmountHandle:H(e.topics[3])}}function J(e){return e.topics[0]!==z.Wrapped||e.topics.length<3?null:{eventName:`Wrapped`,to:B(e.topics[1]),mintTxId:V(e.topics[2]),mintAmount:W(e.data,0),amountIn:W(e.data,1),feeAmount:W(e.data,2)}}function Y(e){return e.topics[0]!==z.UnwrapRequested||e.topics.length<2?null:{eventName:`UnwrapRequested`,receiver:B(e.topics[1]),encryptedAmount:K(e.data,0)}}function X(e){return e.topics[0]!==z.UnwrappedFinalized||e.topics.length<3?null:{eventName:`UnwrappedFinalized`,burntAmountHandle:H(e.topics[1]),nextTxId:V(e.topics[2]),finalizeSuccess:G(e.data,0),feeTransferSuccess:G(e.data,1),burnAmount:W(e.data,2),unwrapAmount:W(e.data,3),feeAmount:W(e.data,4)}}function Z(e){return e.topics[0]!==z.UnwrappedStarted||e.topics.length<4?null:{eventName:`UnwrappedStarted`,requestId:V(e.topics[1]),txId:V(e.topics[2]),to:B(e.topics[3]),returnVal:G(e.data,0),refund:he(e.data,1),requestedAmount:K(e.data,2),burnAmount:K(e.data,3)}}function Q(e){return q(e)??J(e)??Y(e)??X(e)??Z(e)}function ge(e){let t=[];for(let n of e){let e=Q(n);e&&t.push(e)}return t}function _e(e){for(let t of e){let e=Y(t);if(e)return e}return null}function ve(e){for(let t of e){let e=J(t);if(e)return e}return null}const ye=[z.ConfidentialTransfer,z.Wrapped,z.UnwrapRequested,z.UnwrappedFinalized,z.UnwrappedStarted];function be(e,t){return e.toLowerCase()===t.toLowerCase()}function $(e,t,n){let r=t!==void 0&&be(e,t),i=n!==void 0&&be(e,n);return r&&i?`self`:r?`outgoing`:`incoming`}function xe(e,t,n){switch(e.eventName){case`ConfidentialTransfer`:return Se(e,t,n);case`Wrapped`:return Ce(e,t,n);case`UnwrapRequested`:return we(e,t,n);case`UnwrappedStarted`:return Te(e,t,n);case`UnwrappedFinalized`:return Ee(e,n)}}function Se(e,t,n){return{type:`transfer`,direction:$(t,e.from,e.to),amount:{type:`encrypted`,handle:e.encryptedAmountHandle},from:e.from,to:e.to,metadata:n,rawEvent:e}}function Ce(e,t,n){return{type:`shield`,direction:$(t,void 0,e.to),amount:{type:`clear`,value:e.amountIn},to:e.to,fee:e.feeAmount,metadata:n,rawEvent:e}}function we(e,t,n){return{type:`unshield_requested`,direction:$(t,void 0,e.receiver),amount:{type:`encrypted`,handle:e.encryptedAmount},to:e.receiver,metadata:n,rawEvent:e}}function Te(e,t,n){return{type:`unshield_started`,direction:$(t,void 0,e.to),amount:{type:`encrypted`,handle:e.requestedAmount},to:e.to,success:e.returnVal,metadata:n,rawEvent:e}}function Ee(e,t){return{type:`unshield_finalized`,direction:`incoming`,amount:{type:`clear`,value:e.unwrapAmount},fee:e.feeAmount,success:e.finalizeSuccess,metadata:t,rawEvent:e}}function De(e,t){let n=[];for(let r of e){let e=Q(r);if(!e)continue;let i={transactionHash:r.transactionHash,blockNumber:r.blockNumber,logIndex:r.logIndex};n.push(xe(e,t,i))}return n}function Oe(e){let t=new Set;for(let n of e)if(n.amount.type===`encrypted`&&n.amount.decryptedValue===void 0){let e=n.amount.handle;e!==`0x`&&e!==`0x0000000000000000000000000000000000000000000000000000000000000000`&&t.add(e)}return[...t]}function ke(e,t){return e.map(e=>{if(e.amount.type!==`encrypted`)return e;let n=t.get(e.amount.handle);return n===void 0?e:{...e,amount:{type:`encrypted`,handle:e.amount.handle,decryptedValue:n}}})}function Ae(e){return[...e].toSorted((e,t)=>{let n=e.metadata.blockNumber,r=t.metadata.blockNumber;if(n===void 0&&r===void 0)return 0;if(n===void 0)return-1;if(r===void 0)return 1;let i=typeof n==`bigint`?n:BigInt(n),a=typeof r==`bigint`?r:BigInt(r);if(a>i)return 1;if(a<i)return-1;let o=e.metadata.logIndex??0;return(t.metadata.logIndex??0)-o})}Object.defineProperty(exports,`A`,{enumerable:!0,get:function(){return te}}),Object.defineProperty(exports,`C`,{enumerable:!0,get:function(){return S}}),Object.defineProperty(exports,`D`,{enumerable:!0,get:function(){return re}}),Object.defineProperty(exports,`E`,{enumerable:!0,get:function(){return oe}}),Object.defineProperty(exports,`F`,{enumerable:!0,get:function(){return p}}),Object.defineProperty(exports,`I`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`L`,{enumerable:!0,get:function(){return f}}),Object.defineProperty(exports,`M`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`N`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`O`,{enumerable:!0,get:function(){return ie}}),Object.defineProperty(exports,`P`,{enumerable:!0,get:function(){return h}}),Object.defineProperty(exports,`R`,{enumerable:!0,get:function(){return r}}),Object.defineProperty(exports,`S`,{enumerable:!0,get:function(){return C}}),Object.defineProperty(exports,`T`,{enumerable:!0,get:function(){return x}}),Object.defineProperty(exports,`_`,{enumerable:!0,get:function(){return`0x0000000000000000000000000000000000000000000000000000000000000000`}}),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return ye}}),Object.defineProperty(exports,`b`,{enumerable:!0,get:function(){return w}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return Q}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return X}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return Z}}),Object.defineProperty(exports,`g`,{enumerable:!0,get:function(){return me}}),Object.defineProperty(exports,`h`,{enumerable:!0,get:function(){return ve}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return Ae}}),Object.defineProperty(exports,`j`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`k`,{enumerable:!0,get:function(){return ne}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return ge}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return _e}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return Oe}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return z}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return J}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return De}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return q}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return ke}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return Y}}),Object.defineProperty(exports,`v`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`w`,{enumerable:!0,get:function(){return ae}}),Object.defineProperty(exports,`x`,{enumerable:!0,get:function(){return se}}),Object.defineProperty(exports,`y`,{enumerable:!0,get:function(){return j}});
1
+ const e=require(`./errors.cjs`),t=require(`./erc165.cjs`);let n=require(`viem`);function r(e){return e instanceof Error?e:Error(String(e))}function i(e){return e.startsWith(`0x`)?e:`0x${e}`}function a(e,t){if(typeof e!=`object`||!e||Array.isArray(e))throw TypeError(`${t} must be an object, got ${typeof e}`)}function o(e,t){if(typeof e!=`string`)throw TypeError(`${t} must be a string, got ${typeof e}`)}function s(e,t){if(!Array.isArray(e))throw TypeError(`${t} must be an array, got ${typeof e}`)}function c(e,t){if(typeof e!=`function`)throw TypeError(`${t} must be a function, got ${typeof e}`)}function l(e,t,n){o(e[t],n)}function u(e,t,n){c(e[t],n)}function d(e,t){if(!e)throw TypeError(t)}function f(){let e=globalThis;for(let t of[e.chrome,e.browser])try{a(t,`ns`);let{runtime:e}=t;return a(e,`runtime`),l(e,`id`,`runtime.id`),u(e,`getURL`,`runtime.getURL`),e}catch{continue}}async function ee(e,t=1/0){if(!Number.isFinite(t)||t>=e.length)return Promise.all(e.map(e=>e()));let n=Array.from({length:e.length}),r=0;async function i(){for(;r<e.length;){let t=r++;n[t]=await e[t]()}}return await Promise.all(Array.from({length:t},i)),n}function p(e){return{address:e,abi:n.erc20Abi,functionName:`name`,args:[]}}function m(e){return{address:e,abi:n.erc20Abi,functionName:`symbol`,args:[]}}function h(e){return{address:e,abi:n.erc20Abi,functionName:`decimals`,args:[]}}function g(e,t){return{address:e,abi:n.erc20Abi,functionName:`balanceOf`,args:[t]}}function _(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`allowance`,args:[t,r]}}function v(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`approve`,args:[t,r]}}const y=[{inputs:[{internalType:`uint256`,name:`amount`,type:`uint256`},{internalType:`address`,name:`wrapFrom`,type:`address`},{internalType:`address`,name:`wrapTo`,type:`address`}],name:`getWrapFee`,outputs:[{internalType:`uint256`,name:``,type:`uint256`}],stateMutability:`view`,type:`function`},{inputs:[{internalType:`uint64`,name:`amount`,type:`uint64`},{internalType:`address`,name:`unwrapFrom`,type:`address`},{internalType:`address`,name:`unwrapTo`,type:`address`}],name:`getUnwrapFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`getBatchTransferFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`getFeeRecipient`,outputs:[{internalType:`address`,name:``,type:`address`}],stateMutability:`view`,type:`function`}];function te(e,t,n,r){return{address:e,abi:y,functionName:`getWrapFee`,args:[t,n,r]}}function ne(e,t,n,r){return{address:e,abi:y,functionName:`getUnwrapFee`,args:[t,n,r]}}function re(e){return{address:e,abi:y,functionName:`getBatchTransferFee`,args:[]}}function ie(e){return{address:e,abi:y,functionName:`getFeeRecipient`,args:[]}}const b=[{inputs:[{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`},{internalType:`uint64`,name:`expirationDate`,type:`uint64`}],name:`delegateForUserDecryption`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`}],name:`revokeDelegationForUserDecryption`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`address`,name:`delegator`,type:`address`},{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`}],name:`getUserDecryptionDelegationExpirationDate`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`}];function ae(e,t,n,r){return{address:e,abi:b,functionName:`delegateForUserDecryption`,args:[t,n,r]}}function oe(e,t,n){return{address:e,abi:b,functionName:`revokeDelegationForUserDecryption`,args:[t,n]}}function x(e,t,n,r){return{address:e,abi:b,functionName:`getUserDecryptionDelegationExpirationDate`,args:[t,n,r]}}const S=2n**64n-1n,C={CredentialsLoading:`credentials:loading`,CredentialsCached:`credentials:cached`,CredentialsExpired:`credentials:expired`,CredentialsCreating:`credentials:creating`,CredentialsCreated:`credentials:created`,CredentialsRevoked:`credentials:revoked`,CredentialsAllowed:`credentials:allowed`,SessionExpired:`session:expired`,EncryptStart:`encrypt:start`,EncryptEnd:`encrypt:end`,EncryptError:`encrypt:error`,DecryptStart:`decrypt:start`,DecryptEnd:`decrypt:end`,DecryptError:`decrypt:error`,TransactionError:`transaction:error`,ShieldSubmitted:`shield:submitted`,TransferSubmitted:`transfer:submitted`,TransferFromSubmitted:`transferFrom:submitted`,ApproveSubmitted:`approve:submitted`,ApproveUnderlyingSubmitted:`approveUnderlying:submitted`,UnwrapSubmitted:`unwrap:submitted`,FinalizeUnwrapSubmitted:`finalizeUnwrap:submitted`,DelegationSubmitted:`delegation:submitted`,RevokeDelegationSubmitted:`revokeDelegation:submitted`,UnshieldPhase1Submitted:`unshield:phase1_submitted`,UnshieldPhase2Started:`unshield:phase2_started`,UnshieldPhase2Submitted:`unshield:phase2_submitted`};var w=class{#e=new Map;async get(e){return this.#e.get(e)??null}async set(e,t){this.#e.set(e,t)}async delete(e){this.#e.delete(e)}};const se=new w;var ce=class{#e=null;#t=null;clearCache(){this.#e=null,this.#t=null}async encrypt(e,t,n){let r=await this.#n(t,n),i=crypto.getRandomValues(new Uint8Array(12)),a=new TextEncoder,o=await crypto.subtle.encrypt({name:`AES-GCM`,iv:i},r,a.encode(e));return{iv:btoa(String.fromCharCode(...i)),ciphertext:btoa(String.fromCharCode(...new Uint8Array(o)))}}async decrypt(e,t,n){let r=await this.#n(t,n),a=Uint8Array.from(atob(e.iv),e=>e.charCodeAt(0)),o=Uint8Array.from(atob(e.ciphertext),e=>e.charCodeAt(0)),s=await crypto.subtle.decrypt({name:`AES-GCM`,iv:a},r,o);return i(new TextDecoder().decode(s))}async#n(e,t){let n=`${e}:${t}`;if(this.#e&&this.#t===n)return this.#e;let r=new TextEncoder,i=await crypto.subtle.importKey(`raw`,r.encode(e),`PBKDF2`,!1,[`deriveKey`]),a=await crypto.subtle.deriveKey({name:`PBKDF2`,salt:r.encode(t),iterations:6e5,hash:`SHA-256`},i,{name:`AES-GCM`,length:256},!1,[`encrypt`,`decrypt`]);return this.#t=n,this.#e=a,a}};function T(e){a(e,`Stored credentials`),o(e.publicKey,`credentials.publicKey`),s(e.contractAddresses,`credentials.contractAddresses`);for(let t of e.contractAddresses)d(typeof t==`string`&&(0,n.isAddress)(t,{strict:!1}),`Expected each contractAddress to be a valid hex address`);a(e.encryptedPrivateKey,`credentials.encryptedPrivateKey`),o(e.encryptedPrivateKey.iv,`encryptedPrivateKey.iv`),o(e.encryptedPrivateKey.ciphertext,`encryptedPrivateKey.ciphertext`)}function le(e){T(e);let t=e;d(typeof t.delegatorAddress==`string`&&(0,n.isAddress)(t.delegatorAddress,{strict:!1}),`Expected credentials.delegatorAddress to be a valid address`),d(typeof t.delegateAddress==`string`&&(0,n.isAddress)(t.delegateAddress,{strict:!1}),`Expected credentials.delegateAddress to be a valid address`),d(typeof t.startTimestamp==`number`,`Expected startTimestamp to be a number`),d(typeof t.durationDays==`number`,`Expected durationDays to be a number`)}function E(e){return Math.floor(Date.now()/1e3)<e.startTimestamp+e.durationDays*86400}function D(e,t){let r=new Set(t.map(e=>(0,n.getAddress)(e))),i=new Set(e.map(e=>(0,n.getAddress)(e)));return r.isSubsetOf(i)}function O(e,t){return E(e)?D(e.contractAddresses,t):!1}function k(e){return[...new Set(e.map(e=>(0,n.getAddress)(e)))].toSorted()}async function ue(...e){let t=await crypto.subtle.digest(`SHA-256`,new TextEncoder().encode(e.map(String).join(`:`)));return Array.from(new Uint8Array(t)).map(e=>e.toString(16).padStart(2,`0`)).join(``).slice(0,32)}var de=class{#e;constructor(e){this.#e=e}#t(e){a(e,`Session entry`),o(e.signature,`session.signature`),d(typeof e.createdAt==`number`,`Expected session.createdAt to be a number`),d(typeof e.ttl==`number`||e.ttl===`infinite`,`Expected session.ttl to be a number or "infinite"`)}async get(e){let t=await this.#e.get(e);return t===null?null:(this.#t(t),t)}async set(e){let t={signature:e.signature,createdAt:Math.floor(Date.now()/1e3),ttl:e.ttl};await this.#e.set(e.key,t)}async delete(e){await this.#e.delete(e)}isExpired(e){return e.ttl===`infinite`?!1:e.ttl===0?!0:Math.floor(Date.now()/1e3)-e.createdAt>=e.ttl}},A=class{signer;storage;sessionSignatures;crypto;keypairTTL;sessionTTL;#e;#t=null;#n=null;#r=null;constructor(e){if(this.signer=e.signer,this.storage=e.storage,this.sessionSignatures=new de(e.sessionStorage),this.crypto=new ce,this.keypairTTL=e.keypairTTL??86400,this.sessionTTL=e.sessionTTL??2592e3,this.#e=e.onEvent??(()=>{}),typeof this.keypairTTL==`number`&&this.keypairTTL<0)throw Error(`keypairTTL must be >= 0`);if(typeof this.sessionTTL==`number`&&this.sessionTTL<0)throw Error(`sessionTTL must be >= 0`)}emit(e){this.#e({...e,timestamp:Date.now()})}async resolveCredentials({key:t,contracts:n,createKey:r,createFn:i}){this.emit({type:C.CredentialsLoading,contractAddresses:n});try{let e=await this.storage.get(t);if(e){this.assertEncrypted(e);let r=await this.sessionSignatures.get(t);if(r)if(this.sessionSignatures.isExpired(r))await this.sessionSignatures.delete(t),this.emit({type:C.SessionExpired,reason:`ttl`});else{let i=await this.decryptCredentials(e,r.signature);if(O(i,n))return this.emit({type:C.CredentialsCached,contractAddresses:n}),this.emit({type:C.CredentialsAllowed,contractAddresses:n}),i;if(E(i))return this.#i({key:t,credentials:i,requiredContracts:n});this.emit({type:C.CredentialsExpired,contractAddresses:n})}if(E(e)){if(D(e.contractAddresses,n)){let r=await this.signForContracts(e,e.contractAddresses);await this.sessionSignatures.set({key:t,signature:r,ttl:this.sessionTTL});let i=await this.decryptCredentials(e,r);return this.emit({type:C.CredentialsCached,contractAddresses:n}),this.emit({type:C.CredentialsAllowed,contractAddresses:n}),i}let r=await this.signForContracts(e,e.contractAddresses),i=await this.decryptCredentials(e,r);return this.#i({key:t,credentials:i,requiredContracts:n})}this.emit({type:C.CredentialsExpired,contractAddresses:n})}}catch(n){if(n instanceof e.m||n instanceof e.p)throw n;console.warn(`[zama-sdk] Credential resolution failed, recreating:`,n),await this.#o(t)}return(!this.#t||this.#n!==r)&&(this.#n=r,this.#t=i().then(e=>(this.emit({type:C.CredentialsAllowed,contractAddresses:n}),e)).finally(()=>{this.#t=null,this.#n=null})),this.#t}async checkExpired(e,t){try{let n=await this.storage.get(e);return n?(this.assertEncrypted(n),!O(n,t?[t]:[])):!1}catch(e){return console.warn(`[zama-sdk] isExpired check failed, treating as expired:`,e),!0}}async revokeSession(e,t){await this.sessionSignatures.delete(e),this.clearCaches(),this.emit({type:C.CredentialsRevoked,...t?{contractAddresses:t}:{}})}async checkAllowed(e){let t=await this.sessionSignatures.get(e);return t===null?!1:!this.sessionSignatures.isExpired(t)}async clearAll(e){await this.sessionSignatures.delete(e),this.clearCaches(),await this.#o(e)}clearCaches(){this.crypto.clearCache()}async createCredentials({key:t,contractAddresses:n,createFn:r,errorContext:i}){this.emit({type:C.CredentialsCreating,contractAddresses:n});try{let e=await r();return await this.persistCredentials(t,e),await this.sessionSignatures.set({key:t,signature:e.signature,ttl:this.sessionTTL}),this.emit({type:C.CredentialsCreated,contractAddresses:n}),e}catch(t){e.y(t,i)}}async#i({key:e,credentials:t,requiredContracts:n}){if(this.#r){let e=await this.#r;if(D(e.contractAddresses,n))return this.emit({type:C.CredentialsAllowed,contractAddresses:n}),e;t=e}let r=this.#a({key:e,credentials:t,requiredContracts:n});this.#r=r;try{return await r}finally{this.#r===r&&(this.#r=null)}}async#a({key:e,credentials:t,requiredContracts:n}){let r=k([...t.contractAddresses,...n]),i=await this.signForContracts(t,r),a={...t,contractAddresses:r,signature:i};return await this.persistCredentials(e,a),await this.sessionSignatures.set({key:e,signature:i,ttl:this.sessionTTL}),this.emit({type:C.CredentialsAllowed,contractAddresses:n}),a}async persistCredentials(e,t){try{let n=await this.encryptCredentials(t);await this.storage.set(e,n)}catch(e){console.warn(`[zama-sdk] Failed to encrypt credentials for persistence:`,e);return}}async#o(e){try{await this.storage.delete(e)}catch(e){console.warn(`[zama-sdk] Failed to delete credentials:`,e)}}};function fe(e){if(typeof e!=`object`||!e)return!1;let t=Reflect.get(e,`runtime`);return typeof t!=`object`||!t?!1:typeof Reflect.get(t,`id`)==`string`}var j=class e extends A{#e;#t=null;#n=null;static async computeStoreKey(e,t){return ue((0,n.getAddress)(e),t)}constructor(e){super(e),this.#e=e.relayer,fe(typeof globalThis<`u`?Reflect.get(globalThis,`chrome`):void 0)&&e.sessionStorage instanceof w&&console.warn(`[zama-sdk] Detected Chrome extension context with in-memory session storage. Session signatures will be lost on service worker restart and won't be shared across contexts. Consider using chromeSessionStorage instead. `)}async allow(...e){let t=k(e),n=await this.#r();return this.resolveCredentials({key:n,contracts:t,createKey:t.join(`,`),createFn:()=>this.create(t)})}async isExpired(e){return this.checkExpired(await this.#r(),e)}async revoke(...e){await this.revokeSession(await this.#r(),e.length>0?e:void 0)}async isAllowed(){return this.checkAllowed(await this.#r())}async clear(){await this.clearAll(await this.#r())}async create(e){let t=k(e),n=await this.#r();return this.createCredentials({key:n,contractAddresses:t,createFn:async()=>{let e=await this.#e.generateKeypair(),n=Math.floor(Date.now()/1e3),r=Math.ceil(this.keypairTTL/86400),i=await this.#e.createEIP712(e.publicKey,t,n,r),a=await this.signer.signTypedData(i);return{publicKey:e.publicKey,privateKey:e.privateKey,signature:a,contractAddresses:t,startTimestamp:n,durationDays:r}},errorContext:`Failed to create decrypt credentials`})}assertEncrypted(e){T(e)}async signForContracts(e,t){let n=await this.#e.createEIP712(e.publicKey,t,e.startTimestamp,e.durationDays);return this.signer.signTypedData(n)}async encryptCredentials(e){let t=await this.signer.getAddress(),n=await this.crypto.encrypt(e.privateKey,e.signature,t),{privateKey:r,signature:i,...a}=e;return{...a,encryptedPrivateKey:n}}async decryptCredentials(e,t){let n=await this.signer.getAddress(),r=await this.crypto.decrypt(e.encryptedPrivateKey,t,n),{encryptedPrivateKey:i,...a}=e;return{...a,privateKey:r,signature:t}}clearCaches(){this.#t=null,this.#n=null,super.clearCaches()}async#r(){let t=await this.signer.getAddress(),r=await this.signer.getChainId(),i=`${(0,n.getAddress)(t)}:${r}`;if(this.#t&&this.#n===i)return this.#t;let a=await e.computeStoreKey(t,r);return this.#n=i,this.#t=a,a}},M=class e extends A{#e;#t=null;#n=null;static async computeStoreKey(e,t,r){return ue((0,n.getAddress)(e),(0,n.getAddress)(t),r)}constructor(e){super(e),this.#e=e.relayer}async allow(e,...t){let r=(0,n.getAddress)(e),i=k(t),a=await this.#i(r);return this.resolveCredentials({key:a,contracts:i,createKey:`${r}:${i.join(`,`)}`,createFn:()=>this.#r(r,i)})}async isExpired(e,t){return this.checkExpired(await this.#i((0,n.getAddress)(e)),t)}async revoke(e){await this.revokeSession(await this.#i((0,n.getAddress)(e)))}async isAllowed(e){return this.checkAllowed(await this.#i((0,n.getAddress)(e)))}async clear(e){await this.clearAll(await this.#i((0,n.getAddress)(e)))}async#r(e,t){let n=await this.#i(e);return this.createCredentials({key:n,contractAddresses:t,createFn:async()=>{let n=await this.#e.generateKeypair(),r=await this.signer.getAddress(),i=Math.floor(Date.now()/1e3),a=Math.ceil(this.keypairTTL/86400),o={publicKey:n.publicKey,startTimestamp:i,durationDays:a,delegatorAddress:e},s=await this.#a(o,t);return{publicKey:n.publicKey,privateKey:n.privateKey,signature:s,contractAddresses:t,startTimestamp:i,durationDays:a,delegatorAddress:e,delegateAddress:r}},errorContext:`Failed to create delegated decrypt credentials`})}assertEncrypted(e){le(e)}async signForContracts(e,t){return this.#a(e,t)}async encryptCredentials(e){let t=await this.signer.getAddress(),n=await this.crypto.encrypt(e.privateKey,e.signature,t),{privateKey:r,signature:i,...a}=e;return{...a,encryptedPrivateKey:n}}async decryptCredentials(e,t){let n=await this.signer.getAddress(),r=await this.crypto.decrypt(e.encryptedPrivateKey,t,n),{encryptedPrivateKey:i,...a}=e;return{...a,privateKey:r,signature:t}}clearCaches(){this.#t=null,this.#n=null,super.clearCaches()}async#i(t){let r=await this.signer.getAddress(),i=await this.signer.getChainId(),a=`${(0,n.getAddress)(r)}:${(0,n.getAddress)(t)}:${i}`;if(this.#t&&this.#n===a)return this.#t;let o=await e.computeStoreKey(r,t,i);return this.#n=a,this.#t=o,o}async#a(e,t){let n=await this.#e.createDelegatedUserDecryptEIP712(e.publicKey,t,e.delegatorAddress,e.startTimestamp,e.durationDays);return this.signer.signTypedData({domain:{...n.domain,chainId:Number(n.domain.chainId)},types:n.types,message:{...n.message,startTimestamp:BigInt(n.message.startTimestamp),durationDays:BigInt(n.message.durationDays)}})}};const N=`zama:balances`;function P(e,t,r){return`zama:balance:${(0,n.getAddress)(e)}:${(0,n.getAddress)(t)}:${r.toLowerCase()}`}async function F({storage:e,tokenAddress:t,owner:n,handle:r}){try{let i=await e.get(P(t,n,r));return i===null?null:BigInt(i)}catch(e){return console.warn(`[zama-sdk] Balance cache read failed:`,e),null}}async function I(e){let{storage:t,tokenAddress:n,owner:r,handle:i,value:a}=e,o=P(n,r,i);try{await t.set(o,a.toString()),await pe(t,o)}catch{}}const L=new WeakMap;async function pe(e,t){let n=(L.get(e)??Promise.resolve()).then(async()=>{let n=await e.get(N),r=n?JSON.parse(n):[];r.includes(t)||(r.push(t),await e.set(N,JSON.stringify(r)))});return L.set(e,n.catch(()=>{})),n}var me=class i{credentials;delegatedCredentials;relayer;signer;address;storage;#e;constructor(e){let t={relayer:e.relayer,signer:e.signer,storage:e.storage,sessionStorage:e.sessionStorage,keypairTTL:e.keypairTTL??86400,sessionTTL:e.sessionTTL??2592e3,onEvent:e.onEvent};this.credentials=e.credentials??new j(t),this.delegatedCredentials=e.delegatedCredentials??new M(t),this.relayer=e.relayer,this.signer=e.signer,this.address=(0,n.getAddress)(e.address),this.storage=e.storage,this.#e=e.onEvent}emit(e){this.#e?.({...e,tokenAddress:this.address,timestamp:Date.now()})}async balanceOf(e){let t=e?(0,n.getAddress)(e):await this.signer.getAddress(),r=await this.readConfidentialBalanceOf(t);return this.decryptBalance(r,t)}async confidentialBalanceOf(e){let t=e?(0,n.getAddress)(e):await this.signer.getAddress();return this.readConfidentialBalanceOf(t)}async isConfidential(){return await this.signer.readContract(t.a(this.address,t.t))}async isWrapper(){return await this.signer.readContract(t.a(this.address,t.n))}static async batchDecryptBalances(e,t){if(e.length===0)return new Map;let{handles:n,owner:r,onError:a,maxConcurrency:o}=t??{},s=e[0],c=i.assertSameRelayer(e),l=r??await s.signer.getAddress();return i.#t({tokens:e,handles:n,ownerAddress:l,onError:a,maxConcurrency:o,obtainCreds:e=>s.credentials.allow(...e),decrypt:(e,t,n)=>c.userDecrypt({handles:[t],contractAddress:n,signedContractAddresses:e.contractAddresses,privateKey:e.privateKey,publicKey:e.publicKey,signature:e.signature,signerAddress:l,startTimestamp:e.startTimestamp,durationDays:e.durationDays}),errorPrefix:`Batch decryption`})}static async batchDecryptBalancesAs(e,t){if(e.length===0)return new Map;let{delegatorAddress:n,handles:r,owner:a,onError:o,maxConcurrency:s}=t,c=a??n,l=e[0];return i.assertSameRelayer(e),i.#t({tokens:e,handles:r,ownerAddress:c,onError:o,maxConcurrency:s,preFlightCheck:()=>l.#n(n),obtainCreds:e=>l.delegatedCredentials.allow(n,...e),decrypt:(e,t,n)=>l.relayer.delegatedUserDecrypt({handles:[t],contractAddress:n,signedContractAddresses:e.contractAddresses,privateKey:e.privateKey,publicKey:e.publicKey,signature:e.signature,delegatorAddress:e.delegatorAddress,delegateAddress:e.delegateAddress,startTimestamp:e.startTimestamp,durationDays:e.durationDays}),errorPrefix:`Batch delegated decryption`})}static async#t(t){let{tokens:n,handles:i,ownerAddress:a,onError:o,maxConcurrency:s,obtainCreds:c,decrypt:l,errorPrefix:u}=t,d=n[0],f=i??await Promise.all(n.map(e=>e.readConfidentialBalanceOf(a)));if(n.length!==f.length)throw new e.r(`tokens.length (${n.length}) must equal handles.length (${f.length})`);let p=d.storage,m=new Map,h=[],g=await Promise.all(n.map((e,t)=>{let n=f[t];return e.isZeroHandle(n)?0n:F({storage:p,tokenAddress:e.address,owner:a,handle:n})}));for(let e=0;e<n.length;e++){let t=n[e],r=f[e],i=g[e];if(i!=null){m.set(t.address,i);continue}h.push({token:t,handle:r})}if(h.length===0)return m;t.preFlightCheck&&await t.preFlightCheck();let _=await c(h.map(e=>e.token.address)),v=[],y=[];for(let{token:t,handle:n}of h)y.push(()=>l(_,n,t.address).then(async r=>{let i=r[n];if(i===void 0)throw new e.r(`${u} returned no value for handle ${n} on token ${t.address}`);m.set(t.address,i);try{await I({storage:p,tokenAddress:t.address,owner:a,handle:n,value:i})}catch{}}).catch(e=>{let n=r(e);if(o)try{m.set(t.address,o(n,t.address))}catch(e){v.push({address:t.address,error:r(e)})}else v.push({address:t.address,error:n})}));if(await ee(y,s),v.length>0){let t=v.map(e=>`${e.address}: ${e.error.message}`).join(`; `);throw new e.r(`${u} failed for ${v.length} token(s): ${t}`)}return m}async discoverWrapper(e){let r=(0,n.getAddress)(e);return await this.signer.readContract(t.s(r,this.address))?this.signer.readContract(t.o(r,this.address)):null}async underlyingToken(){return this.signer.readContract(t.l(this.address))}async allowance(e,r){let i=(0,n.getAddress)(e),a=await this.signer.readContract(t.l(i)),o=r?(0,n.getAddress)(r):await this.signer.getAddress();return this.signer.readContract(_(a,o,i))}async name(){return this.signer.readContract(p(this.address))}async symbol(){return this.signer.readContract(m(this.address))}async decimals(){return this.signer.readContract(h(this.address))}async allow(){await this.credentials.allow(this.address)}async isAllowed(){return this.credentials.isAllowed()}async revoke(...e){await this.credentials.revoke(...e)}static async allow(...e){if(e.length===0)return;let t=e.map(e=>e.address);await e[0].credentials.allow(...t)}async getAclAddress(){return this.relayer.getAclAddress()}async isDelegated(e){let t=await this.getDelegationExpiry(e);return t===0n?!1:t===S?!0:t>await this.signer.getBlockTimestamp()}async getDelegationExpiry({delegatorAddress:e,delegateAddress:t}){let r=await this.getAclAddress();return this.signer.readContract(x(r,(0,n.getAddress)(e),(0,n.getAddress)(t),this.address))}async#n(t){let n=await this.signer.getAddress(),r=await this.getDelegationExpiry({delegatorAddress:t,delegateAddress:n});if(r===0n)throw new e.o(`No active delegation from ${t} to ${n} for ${this.address}`);if(r!==S&&r<=await this.signer.getBlockTimestamp())throw new e.a(`Delegation from ${t} to ${n} for ${this.address} has expired`)}async readConfidentialBalanceOf(e){return await this.signer.readContract(t.f(this.address,e))}isZeroHandle(e){return e===`0x0000000000000000000000000000000000000000000000000000000000000000`||e===`0x`}async decryptBalanceAs({delegatorAddress:t,owner:i}){let a=(0,n.getAddress)(t),o=i?(0,n.getAddress)(i):a,s=await this.readConfidentialBalanceOf(o);if(this.isZeroHandle(s))return 0n;let c=await F({storage:this.storage,tokenAddress:this.address,owner:o,handle:s});if(c!==null)return c;await this.#n(a);let l=Date.now();try{this.emit({type:C.DecryptStart});let t=await this.delegatedCredentials.allow(a,this.address),n=await this.relayer.delegatedUserDecrypt({handles:[s],contractAddress:this.address,signedContractAddresses:t.contractAddresses,privateKey:t.privateKey,publicKey:t.publicKey,signature:t.signature,delegatorAddress:t.delegatorAddress,delegateAddress:t.delegateAddress,startTimestamp:t.startTimestamp,durationDays:t.durationDays});this.emit({type:C.DecryptEnd,durationMs:Date.now()-l});let r=n[s];if(r===void 0)throw new e.r(`Delegated decryption returned no value for handle ${s}`);try{await I({storage:this.storage,tokenAddress:this.address,owner:o,handle:s,value:r})}catch{}return r}catch(e){throw this.emit({type:C.DecryptError,error:r(e),durationMs:Date.now()-l}),R(e,`Failed to decrypt delegated balance`)}}async decryptBalance(t,n){if(this.isZeroHandle(t))return 0n;let i=n??await this.signer.getAddress(),a=await F({storage:this.storage,tokenAddress:this.address,owner:i,handle:t});if(a!==null)return a;let o=await this.credentials.allow(this.address),s=Date.now();try{this.emit({type:C.DecryptStart});let n=await this.relayer.userDecrypt({handles:[t],contractAddress:this.address,signedContractAddresses:o.contractAddresses,privateKey:o.privateKey,publicKey:o.publicKey,signature:o.signature,signerAddress:i,startTimestamp:o.startTimestamp,durationDays:o.durationDays});this.emit({type:C.DecryptEnd,durationMs:Date.now()-s});let r=n[t];if(r===void 0)throw new e.r(`Decryption returned no value for handle ${t}`);try{await I({storage:this.storage,tokenAddress:this.address,owner:i,handle:t,value:r})}catch{}return r}catch(e){throw this.emit({type:C.DecryptError,error:r(e),durationMs:Date.now()-s}),R(e,`Failed to decrypt balance`)}}async decryptHandles(t,n){let i=new Map,a=[];for(let e of t)this.isZeroHandle(e)?i.set(e,0n):a.push(e);if(a.length===0)return i;let o=await this.credentials.allow(this.address),s=Date.now();try{this.emit({type:C.DecryptStart});let t=await this.relayer.userDecrypt({handles:a,contractAddress:this.address,signedContractAddresses:o.contractAddresses,privateKey:o.privateKey,publicKey:o.publicKey,signature:o.signature,signerAddress:n??await this.signer.getAddress(),startTimestamp:o.startTimestamp,durationDays:o.durationDays});this.emit({type:C.DecryptEnd,durationMs:Date.now()-s});for(let n of a){let r=t[n];if(r===void 0)throw new e.r(`Decryption returned no value for handle ${n}`);i.set(n,r)}}catch(e){throw this.emit({type:C.DecryptError,error:r(e),durationMs:Date.now()-s}),R(e,`Failed to decrypt handles`)}return i}static assertSameRelayer(t){let n=t[0].relayer;for(let r=1;r<t.length;r++)if(t[r].relayer!==n)throw new e.n(`All tokens in a batch operation must share the same relayer instance`);return n}};function R(t,n){if(t instanceof e.r||t instanceof e.d||t instanceof e.f||t instanceof e.m||t instanceof e.p)return t;let r=typeof t==`object`&&t&&`statusCode`in t&&typeof t.statusCode==`number`?t.statusCode:void 0;return r===400?new e.d(t instanceof Error?t.message:`No ciphertext for this account`,{cause:t}):r===void 0?new e.r(n,{cause:t}):new e.f(t instanceof Error?t.message:n,r,{cause:t})}const z={ConfidentialTransfer:`0x67500e8d0ed826d2194f514dd0d8124f35648ab6e3fb5e6ed867134cffe661e9`,Wrapped:`0x1f7907f4d84043abe0fb7c74e8865ee5fe93fe4f691c54a7b8fa9d6fb17c7cba`,UnwrapRequested:`0x77d02d353c5629272875d11f1b34ec4c65d7430b075575b78cd2502034c469ee`,UnwrappedFinalized:`0xc64e7c81b18b674fc5b037d8a0041bfe3332d86c780a4688f404ee01fbabb152`,UnwrappedStarted:`0x3838891d4843c6d7f9f494570b6fd8843f4e3c3ddb817c1411760bd31b819806`};function B(e){return(0,n.getAddress)(i(e.slice(-40)))}function V(e){return BigInt(e)}function H(e){return e}function U(e,t){let n=2+t*64,r=e.slice(n,n+64);return r.length===64?r:r.padEnd(64,`0`)}function he(e,t){return(0,n.getAddress)(i(U(e,t).slice(-40)))}function W(e,t){return BigInt(`0x`+U(e,t))}function G(e,t){return BigInt(`0x`+U(e,t))!==0n}function K(e,t){return i(U(e,t))}function q(e){return e.topics[0]!==z.ConfidentialTransfer||e.topics.length<4?null:{eventName:`ConfidentialTransfer`,from:B(e.topics[1]),to:B(e.topics[2]),encryptedAmountHandle:H(e.topics[3])}}function J(e){return e.topics[0]!==z.Wrapped||e.topics.length<3?null:{eventName:`Wrapped`,to:B(e.topics[1]),mintTxId:V(e.topics[2]),mintAmount:W(e.data,0),amountIn:W(e.data,1),feeAmount:W(e.data,2)}}function Y(e){return e.topics[0]!==z.UnwrapRequested||e.topics.length<2?null:{eventName:`UnwrapRequested`,receiver:B(e.topics[1]),encryptedAmount:K(e.data,0)}}function X(e){return e.topics[0]!==z.UnwrappedFinalized||e.topics.length<3?null:{eventName:`UnwrappedFinalized`,burntAmountHandle:H(e.topics[1]),nextTxId:V(e.topics[2]),finalizeSuccess:G(e.data,0),feeTransferSuccess:G(e.data,1),burnAmount:W(e.data,2),unwrapAmount:W(e.data,3),feeAmount:W(e.data,4)}}function Z(e){return e.topics[0]!==z.UnwrappedStarted||e.topics.length<4?null:{eventName:`UnwrappedStarted`,requestId:V(e.topics[1]),txId:V(e.topics[2]),to:B(e.topics[3]),returnVal:G(e.data,0),refund:he(e.data,1),requestedAmount:K(e.data,2),burnAmount:K(e.data,3)}}function Q(e){return q(e)??J(e)??Y(e)??X(e)??Z(e)}function ge(e){let t=[];for(let n of e){let e=Q(n);e&&t.push(e)}return t}function _e(e){for(let t of e){let e=Y(t);if(e)return e}return null}function ve(e){for(let t of e){let e=J(t);if(e)return e}return null}const ye=[z.ConfidentialTransfer,z.Wrapped,z.UnwrapRequested,z.UnwrappedFinalized,z.UnwrappedStarted];function be(e,t){return e.toLowerCase()===t.toLowerCase()}function $(e,t,n){let r=t!==void 0&&be(e,t),i=n!==void 0&&be(e,n);return r&&i?`self`:r?`outgoing`:`incoming`}function xe(e,t,n){switch(e.eventName){case`ConfidentialTransfer`:return Se(e,t,n);case`Wrapped`:return Ce(e,t,n);case`UnwrapRequested`:return we(e,t,n);case`UnwrappedStarted`:return Te(e,t,n);case`UnwrappedFinalized`:return Ee(e,n)}}function Se(e,t,n){return{type:`transfer`,direction:$(t,e.from,e.to),amount:{type:`encrypted`,handle:e.encryptedAmountHandle},from:e.from,to:e.to,metadata:n,rawEvent:e}}function Ce(e,t,n){return{type:`shield`,direction:$(t,void 0,e.to),amount:{type:`clear`,value:e.amountIn},to:e.to,fee:e.feeAmount,metadata:n,rawEvent:e}}function we(e,t,n){return{type:`unshield_requested`,direction:$(t,void 0,e.receiver),amount:{type:`encrypted`,handle:e.encryptedAmount},to:e.receiver,metadata:n,rawEvent:e}}function Te(e,t,n){return{type:`unshield_started`,direction:$(t,void 0,e.to),amount:{type:`encrypted`,handle:e.requestedAmount},to:e.to,success:e.returnVal,metadata:n,rawEvent:e}}function Ee(e,t){return{type:`unshield_finalized`,direction:`incoming`,amount:{type:`clear`,value:e.unwrapAmount},fee:e.feeAmount,success:e.finalizeSuccess,metadata:t,rawEvent:e}}function De(e,t){let n=[];for(let r of e){let e=Q(r);if(!e)continue;let i={transactionHash:r.transactionHash,blockNumber:r.blockNumber,logIndex:r.logIndex};n.push(xe(e,t,i))}return n}function Oe(e){let t=new Set;for(let n of e)if(n.amount.type===`encrypted`&&n.amount.decryptedValue===void 0){let e=n.amount.handle;e!==`0x`&&e!==`0x0000000000000000000000000000000000000000000000000000000000000000`&&t.add(e)}return[...t]}function ke(e,t){return e.map(e=>{if(e.amount.type!==`encrypted`)return e;let n=t.get(e.amount.handle);return n===void 0?e:{...e,amount:{type:`encrypted`,handle:e.amount.handle,decryptedValue:n}}})}function Ae(e){return[...e].toSorted((e,t)=>{let n=e.metadata.blockNumber,r=t.metadata.blockNumber;if(n===void 0&&r===void 0)return 0;if(n===void 0)return-1;if(r===void 0)return 1;let i=typeof n==`bigint`?n:BigInt(n),a=typeof r==`bigint`?r:BigInt(r);if(a>i)return 1;if(a<i)return-1;let o=e.metadata.logIndex??0;return(t.metadata.logIndex??0)-o})}Object.defineProperty(exports,`A`,{enumerable:!0,get:function(){return te}}),Object.defineProperty(exports,`B`,{enumerable:!0,get:function(){return r}}),Object.defineProperty(exports,`C`,{enumerable:!0,get:function(){return S}}),Object.defineProperty(exports,`D`,{enumerable:!0,get:function(){return re}}),Object.defineProperty(exports,`E`,{enumerable:!0,get:function(){return oe}}),Object.defineProperty(exports,`F`,{enumerable:!0,get:function(){return p}}),Object.defineProperty(exports,`I`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`L`,{enumerable:!0,get:function(){return a}}),Object.defineProperty(exports,`M`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`N`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`O`,{enumerable:!0,get:function(){return ie}}),Object.defineProperty(exports,`P`,{enumerable:!0,get:function(){return h}}),Object.defineProperty(exports,`R`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`S`,{enumerable:!0,get:function(){return C}}),Object.defineProperty(exports,`T`,{enumerable:!0,get:function(){return x}}),Object.defineProperty(exports,`_`,{enumerable:!0,get:function(){return`0x0000000000000000000000000000000000000000000000000000000000000000`}}),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return ye}}),Object.defineProperty(exports,`b`,{enumerable:!0,get:function(){return w}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return Q}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return X}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return Z}}),Object.defineProperty(exports,`g`,{enumerable:!0,get:function(){return me}}),Object.defineProperty(exports,`h`,{enumerable:!0,get:function(){return ve}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return Ae}}),Object.defineProperty(exports,`j`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`k`,{enumerable:!0,get:function(){return ne}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return ge}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return _e}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return Oe}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return z}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return J}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return De}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return q}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return ke}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return Y}}),Object.defineProperty(exports,`v`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`w`,{enumerable:!0,get:function(){return ae}}),Object.defineProperty(exports,`x`,{enumerable:!0,get:function(){return se}}),Object.defineProperty(exports,`y`,{enumerable:!0,get:function(){return j}}),Object.defineProperty(exports,`z`,{enumerable:!0,get:function(){return f}});
2
2
  //# sourceMappingURL=activity.cjs.map
@@ -491,5 +491,5 @@ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=requi
491
491
  };
492
492
  //#endregion
493
493
  })();
494
- `,l=class extends s{constructor(e){super(e,e.logger)}createWorker(){let e=t.L();if(e)return new Worker(e.getURL(`relayer-sdk.worker.js`));let n=URL.createObjectURL(new Blob([c],{type:`application/javascript`}));try{return new Worker(n)}finally{URL.revokeObjectURL(n)}}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(){return{type:`INIT`,payload:this.config}}async updateCsrf(e){await this.sendRequest(`UPDATE_CSRF`,{csrfToken:e})}},u=class{#e=null;#t=null;#n=null;#r=!1;#i=null;#a=`idle`;#o;#s;constructor(e){this.#s=e}get status(){return this.#a}get initError(){return this.#o}#c(e,t){this.#a=e,this.#o=t,this.#s.onStatusChange?.(e,t)}async#l(){let e=await this.#s.getChainId(),{transports:t,security:r,threads:i}=this.#s;if(i!==void 0&&(!Number.isInteger(i)||i<1))throw Error(`Invalid thread count: ${i}. Must be a positive integer.`);return i!==void 0&&globalThis.SharedArrayBuffer===void 0&&this.#s.logger?.warn(`threads option requires SharedArrayBuffer (COOP/COEP headers). Falling back to single-threaded.`),{cdnUrl:`https://cdn.zama.org/relayer-sdk-js/0.4.1/relayer-sdk-js.umd.cjs`,fhevmConfig:Object.assign({},n.t[e],t[e]),csrfToken:r?.getCsrfToken?.()??``,integrity:r?.integrityCheck===!1?void 0:`2bd5401738b74509549bed2029bbbabedd481b10ac260f66e64a4ff3723d6d704180c51e882757c56ca1840491e90e33`,logger:this.#s.logger,thread:i}}async#u(){if(this.#n)return this.#n;this.#n=this.#d();try{return await this.#n}finally{this.#n=null}}async#d(){this.#r&&(this.#r=!1,this.#e=null,this.#t=null,this.#i=null);let t=await this.#s.getChainId();return this.#i!==null&&t!==this.#i&&(this.#e?.terminate(),this.#e=null,this.#t=null),this.#i=t,this.#t||=(this.#c(`initializing`),this.#f().then(e=>(this.#c(`ready`),e)).catch(t=>{this.#t=null;let n=t instanceof e.g?t:new e.c(`Failed to initialize FHE worker`,{cause:t instanceof Error?t:void 0});throw this.#c(`error`,n),n})),this.#t}async#f(){let e=new l(await this.#l());if(await e.initWorker(),this.#r)throw e.terminate(),Error(`RelayerWeb was terminated during initialization`);return this.#e=e,e}terminate(){this.#r=!0,this.#e&&=(this.#e.terminate(),null),this.#t=null,this.#n=null}async#p(){if(this.#e){let e=this.#s.security?.getCsrfToken?.()??``;e&&await this.#e.updateCsrf(e)}}async generateKeypair(){let e=await(await this.#u()).generateKeypair();return{publicKey:e.publicKey,privateKey:e.privateKey}}async createEIP712(e,t,r,i=7){let a=await(await this.#u()).createEIP712({publicKey:e,contractAddresses:t,startTimestamp:r,durationDays:i}),o={name:a.domain.name,version:a.domain.version,chainId:a.domain.chainId,verifyingContract:a.domain.verifyingContract};return{domain:o,types:{EIP712Domain:n.a(o),UserDecryptRequestVerification:a.types.UserDecryptRequestVerification},message:{publicKey:a.message.publicKey,contractAddresses:a.message.contractAddresses,startTimestamp:a.message.startTimestamp,durationDays:a.message.durationDays,extraData:a.message.extraData}}}async encrypt(e){let{values:t,contractAddress:r,userAddress:i}=e;return n.o(async()=>{let e=await this.#u();await this.#p();let n=await e.encrypt({values:t,contractAddress:r,userAddress:i});return{handles:n.handles,inputProof:n.inputProof}})}async userDecrypt(e){return n.o(async()=>{let t=await this.#u();return await this.#p(),(await t.userDecrypt(e)).clearValues})}async publicDecrypt(e){return n.o(async()=>{let t=await this.#u();await this.#p();let n=await t.publicDecrypt(e);return{clearValues:n.clearValues,abiEncodedClearValues:n.abiEncodedClearValues,decryptionProof:n.decryptionProof}})}async createDelegatedUserDecryptEIP712(e,t,n,r,i=7){return(await this.#u()).createDelegatedUserDecryptEIP712({publicKey:e,contractAddresses:t,delegatorAddress:n,startTimestamp:r,durationDays:i})}async delegatedUserDecrypt(e){return n.o(async()=>{let t=await this.#u();return await this.#p(),(await t.delegatedUserDecrypt(e)).clearValues})}async requestZKProofVerification(e){return n.o(async()=>{let t=await this.#u();return await this.#p(),t.requestZKProofVerification(e)})}async getPublicKey(){return(await(await this.#u()).getPublicKey()).result}async getPublicParams(e){return(await(await this.#u()).getPublicParams(e)).result}async getAclAddress(){let t=await this.#s.getChainId(),r=Object.assign({},n.t[t],this.#s.transports[t]);if(!r.aclContractAddress)throw new e.n(`No ACL address configured for chain ${t}`);return r.aclContractAddress}},d=class n extends t.g{static ZERO_ADDRESS=`0x0000000000000000000000000000000000000000`;wrapper;#e;#t=null;constructor(e){super(e),this.wrapper=e.wrapper?(0,a.getAddress)(e.wrapper):this.address}async#n(){return this.#e===void 0?(this.#t||=this.signer.readContract(r.l(this.wrapper)).then(e=>(this.#e=e,this.#t=null,e)).catch(e=>{throw this.#t=null,e}),this.#t):this.#e}async confidentialTransfer(n,i,o){let s=(0,a.getAddress)(n),c,l,u=Date.now();try{this.emit({type:t.S.EncryptStart}),{handles:c,inputProof:l}=await this.relayer.encrypt({values:[{value:i,type:`euint64`}],contractAddress:this.address,userAddress:await this.signer.getAddress()}),this.emit({type:t.S.EncryptEnd,durationMs:Date.now()-u}),f(()=>o?.onEncryptComplete?.())}catch(n){throw this.emit({type:t.S.EncryptError,error:t.R(n),durationMs:Date.now()-u}),n instanceof e.g?n:new e.c(`Failed to encrypt transfer amount`,{cause:n instanceof Error?n:void 0})}if(c.length===0)throw new e.c(`Encryption returned no handles`);try{let e=await this.signer.writeContract(r.m(this.address,s,c[0],l));return this.emit({type:t.S.TransferSubmitted,txHash:e}),f(()=>o?.onTransferSubmitted?.(e)),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`transfer`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Transfer transaction failed`,{cause:n instanceof Error?n:void 0})}}async confidentialTransferFrom(n,i,o,s){let c=(0,a.getAddress)(n),l=(0,a.getAddress)(i),u,d,p=Date.now();try{this.emit({type:t.S.EncryptStart}),{handles:u,inputProof:d}=await this.relayer.encrypt({values:[{value:o,type:`euint64`}],contractAddress:this.address,userAddress:c}),this.emit({type:t.S.EncryptEnd,durationMs:Date.now()-p}),f(()=>s?.onEncryptComplete?.())}catch(n){throw this.emit({type:t.S.EncryptError,error:t.R(n),durationMs:Date.now()-p}),n instanceof e.g?n:new e.c(`Failed to encrypt transferFrom amount`,{cause:n instanceof Error?n:void 0})}if(u.length===0)throw new e.c(`Encryption returned no handles`);try{let e=await this.signer.writeContract(r.h(this.address,c,l,u[0],d));return this.emit({type:t.S.TransferFromSubmitted,txHash:e}),f(()=>s?.onTransferSubmitted?.(e)),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`transferFrom`,error:t.R(n)}),n instanceof e.g?n:new e.h(`TransferFrom transaction failed`,{cause:n instanceof Error?n:void 0})}}async approve(n,i){let o=(0,a.getAddress)(n);try{let e=await this.signer.writeContract(r.x(this.address,o,i));return this.emit({type:t.S.ApproveSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`approve`,error:t.R(n)}),n instanceof e.g?n:new e.t(`Operator approval failed`,{cause:n instanceof Error?n:void 0})}}async isApproved(e,t){let n=(0,a.getAddress)(e),i=t?(0,a.getAddress)(t):await this.signer.getAddress();return this.signer.readContract(r.v(this.address,i,n))}async shield(i,o){if(await this.#n()===n.ZERO_ADDRESS)return this.shieldETH(i,i+(o?.fees??0n));let s=o?.approvalStrategy??`exact`;s!==`skip`&&await this.#a(i,s===`max`,o?.callbacks);try{let e=o?.to?(0,a.getAddress)(o.to):await this.signer.getAddress(),n=await this.signer.writeContract(r.u(this.wrapper,e,i));return this.emit({type:t.S.ShieldSubmitted,txHash:n}),f(()=>o?.callbacks?.onShieldSubmitted?.(n)),{txHash:n,receipt:await this.signer.waitForTransactionReceipt(n)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`shield`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Shield transaction failed`,{cause:n instanceof Error?n:void 0})}}async shieldETH(n,i){try{let e=await this.signer.getAddress(),a=await this.signer.writeContract(r.d(this.wrapper,e,n,i??n));return this.emit({type:t.S.ShieldSubmitted,txHash:a}),{txHash:a,receipt:await this.signer.waitForTransactionReceipt(a)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`shieldETH`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Shield ETH transaction failed`,{cause:n instanceof Error?n:void 0})}}async unwrap(n){let i=await this.signer.getAddress(),a,o,s=Date.now();try{this.emit({type:t.S.EncryptStart}),{handles:a,inputProof:o}=await this.relayer.encrypt({values:[{value:n,type:`euint64`}],contractAddress:this.wrapper,userAddress:i}),this.emit({type:t.S.EncryptEnd,durationMs:Date.now()-s})}catch(n){throw this.emit({type:t.S.EncryptError,error:t.R(n),durationMs:Date.now()-s}),n instanceof e.g?n:new e.c(`Failed to encrypt unshield amount`,{cause:n instanceof Error?n:void 0})}if(a.length===0)throw new e.c(`Encryption returned no handles`);try{let e=await this.signer.writeContract(r.C(this.address,i,i,a[0],o));return this.emit({type:t.S.UnwrapSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`unwrap`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Unshield transaction failed`,{cause:n instanceof Error?n:void 0})}}async unwrapAll(){let n=await this.signer.getAddress(),i=await this.readConfidentialBalanceOf(n);if(this.isZeroHandle(i))throw new e.r(`Cannot unshield: balance is zero`);try{let e=await this.signer.writeContract(r.w(this.address,n,n,i));return this.emit({type:t.S.UnwrapSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`unwrap`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Unshield-all transaction failed`,{cause:n instanceof Error?n:void 0})}}async unshield(e,t){let n=crypto.randomUUID(),r=await this.unwrap(e);return f(()=>t?.onUnwrapSubmitted?.(r.txHash)),this.#i(r.txHash,t,n)}async unshieldAll(e){let t=crypto.randomUUID(),n=await this.unwrapAll();return f(()=>e?.onUnwrapSubmitted?.(n.txHash)),this.#i(n.txHash,e,t)}async resumeUnshield(e,t){return this.#i(e,t,crypto.randomUUID())}async finalizeUnwrap(n){let i,o,s=Date.now();try{this.emit({type:t.S.DecryptStart});let r=await this.relayer.publicDecrypt([n]);this.emit({type:t.S.DecryptEnd,durationMs:Date.now()-s}),o=r.decryptionProof;try{i=(0,a.hexToBigInt)(r.abiEncodedClearValues)}catch{throw new e.r(`Cannot parse decrypted value: ${r.abiEncodedClearValues}`)}}catch(n){throw this.emit({type:t.S.DecryptError,error:t.R(n),durationMs:Date.now()-s}),n instanceof e.g?n:new e.r(`Failed to finalize unshield`,{cause:n instanceof Error?n:void 0})}try{let e=await this.signer.writeContract(r.c(this.wrapper,n,i,o));return this.emit({type:t.S.FinalizeUnwrapSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`finalizeUnwrap`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Failed to finalize unshield`,{cause:n instanceof Error?n:void 0})}}async approveUnderlying(n){let r=await this.#n(),i=n??2n**256n-1n;try{if(i>0n){let e=await this.signer.getAddress();await this.signer.readContract(t.j(r,e,this.wrapper))>0n&&await this.signer.writeContract(t.M(r,this.wrapper,0n))}let e=await this.signer.writeContract(t.M(r,this.wrapper,i));return this.emit({type:t.S.ApproveUnderlyingSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`approveUnderlying`,error:t.R(n)}),n instanceof e.g?n:new e.t(`ERC-20 approval failed`,{cause:n instanceof Error?n:void 0})}}async delegateDecryption({delegateAddress:n,expirationDate:r}){if(r&&r.getTime()<=Date.now())throw new e.n(`Expiration date must be in the future`);let i=await this.getAclAddress(),o=r?BigInt(Math.floor(r.getTime()/1e3)):t.C;try{let e=await this.signer.writeContract(t.w(i,(0,a.getAddress)(n),this.address,o));return this.emit({type:t.S.DelegationSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`delegateDecryption`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Delegation transaction failed`,{cause:n instanceof Error?n:void 0})}}async revokeDelegation({delegateAddress:n}){let r=await this.getAclAddress();try{let e=await this.signer.writeContract(t.E(r,(0,a.getAddress)(n),this.address));return this.emit({type:t.S.RevokeDelegationSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`revokeDelegation`,error:t.R(n)}),n instanceof e.g?n:new e.h(`Revoke delegation transaction failed`,{cause:n instanceof Error?n:void 0})}}static async batchDelegateDecryption({tokens:e,delegateAddress:t,expirationDate:r}){return n.#r(e,e=>e.delegateDecryption({delegateAddress:t,expirationDate:r}),`Delegation failed`)}static async batchRevokeDelegation({tokens:e,delegateAddress:t}){return n.#r(e,e=>e.revokeDelegation({delegateAddress:t}),`Revoke delegation failed`)}static async#r(t,n,r){let i=new Map,a=await Promise.allSettled(t.map(n));for(let n=0;n<t.length;n++){let o=a[n];if(o.status===`fulfilled`)i.set(t[n].address,o.value);else{let a=o.reason instanceof e.g?o.reason:new e.h(r,{cause:o.reason});i.set(t[n].address,a)}}return i}async#i(n,r,i){this.emit({type:t.S.UnshieldPhase1Submitted,txHash:n,operationId:i});let a;try{a=await this.signer.waitForTransactionReceipt(n)}catch(t){throw t instanceof e.g?t:new e.h(`Failed to get unshield receipt`,{cause:t})}let o=t.m(a.logs);if(!o)throw new e.h(`No UnwrapRequested event found in unshield receipt`);this.emit({type:t.S.UnshieldPhase2Started,operationId:i}),f(()=>r?.onFinalizing?.());let s=await this.finalizeUnwrap(o.encryptedAmount);return this.emit({type:t.S.UnshieldPhase2Submitted,txHash:s.txHash,operationId:i}),f(()=>r?.onFinalizeSubmitted?.(s.txHash)),s}async#a(n,r,i){let a=await this.#n(),o=await this.signer.getAddress(),s=await this.signer.readContract(t.j(a,o,this.wrapper));if(!(s>=n))try{s>0n&&await this.signer.writeContract(t.M(a,this.wrapper,0n));let e=r?2n**256n-1n:n,o=await this.signer.writeContract(t.M(a,this.wrapper,e));this.emit({type:t.S.ApproveUnderlyingSubmitted,txHash:o}),f(()=>i?.onApprovalSubmitted?.(o))}catch(t){throw t instanceof e.g?t:new e.t(`ERC-20 approval failed`,{cause:t instanceof Error?t:void 0})}}};function f(e){try{e()}catch(e){console.warn(`[zama-sdk] Callback threw:`,e)}}var p=class{relayer;signer;storage;sessionStorage;credentials;delegatedCredentials;#e;#t;#n;#r=null;#i=null;constructor(e){this.relayer=e.relayer,this.signer=e.signer,this.storage=e.storage,this.sessionStorage=e.sessionStorage??new t.b,this.#e=e.onEvent??function(){};let n={relayer:this.relayer,signer:this.signer,storage:this.storage,sessionStorage:this.sessionStorage,keypairTTL:(()=>{let t=e.keypairTTL??86400;if(t<=0)throw Error(`keypairTTL must be a positive number (seconds)`);return t})(),sessionTTL:e.sessionTTL??2592e3,onEvent:this.#e};if(this.credentials=new t.y(n),this.delegatedCredentials=new t.v(n),this.#n=this.#a(),this.signer.subscribe){let n=e.signerLifecycleCallbacks,r=(e,n)=>{n().catch(n=>{this.#e?.({type:t.S.TransactionError,operation:e,error:t.R(n),timestamp:Date.now()})})};this.#t=this.signer.subscribe({onDisconnect:()=>{r(`signerDisconnect`,async()=>{await this.#o(),this.#r=null,this.#i=null,n?.onDisconnect?.()})},onAccountChange:e=>{r(`signerAccountChange`,async()=>{await this.#o(),this.#r=(0,a.getAddress)(e);try{this.#i=await this.signer.getChainId()}catch{}n?.onAccountChange?.(e)})},onChainChange:e=>{r(`signerChainChange`,async()=>{await this.#o(),this.#i=e;try{this.#r=await this.signer.getAddress()}catch{}n?.onChainChange?.(e)})}})}}async#a(){try{let e=await this.signer.getAddress(),t=await this.signer.getChainId();this.#r=e,this.#i=t}catch{}}async#o(){if(await this.#n,this.#r===null||this.#r===void 0||this.#i===null||this.#i===void 0)return;let e=await t.y.computeStoreKey(this.#r,this.#i);await this.sessionStorage.delete(e),this.#e?.({type:t.S.CredentialsRevoked,timestamp:Date.now()})}createReadonlyToken(e){return new t.g({relayer:this.relayer,signer:this.signer,storage:this.storage,sessionStorage:this.sessionStorage,credentials:this.credentials,delegatedCredentials:this.delegatedCredentials,address:(0,a.getAddress)(e),onEvent:this.#e})}createToken(e,t){return new d({relayer:this.relayer,signer:this.signer,storage:this.storage,sessionStorage:this.sessionStorage,credentials:this.credentials,delegatedCredentials:this.delegatedCredentials,address:(0,a.getAddress)(e),wrapper:t?(0,a.getAddress)(t):void 0,onEvent:this.#e})}async allow(...e){await this.credentials.allow(...e)}async revoke(...e){await this.credentials.revoke(...e)}async revokeSession(){await this.#n;let e=this.#r??await this.signer.getAddress(),n=this.#i??await this.signer.getChainId(),r=await t.y.computeStoreKey(e,n);await this.sessionStorage.delete(r),this.#e?.({type:t.S.CredentialsRevoked,timestamp:Date.now()})}async isAllowed(){return this.credentials.isAllowed()}dispose(){this.#t?.(),this.#t=void 0}terminate(){this.dispose(),this.relayer.terminate()}},m=class{#e=null;#t=null;#n;#r;#i=`credentials`;constructor(e=`CredentialStore`,t=1){this.#n=e,this.#r=t}#a(){return this.#e?Promise.resolve(this.#e):(this.#t||=new Promise((e,t)=>{let n=indexedDB.open(this.#n,this.#r);n.onupgradeneeded=()=>{let e=n.result;e.objectStoreNames.contains(this.#i)||e.createObjectStore(this.#i,{keyPath:`key`})},n.onsuccess=()=>{this.#e=n.result,this.#t=null,this.#e.onversionchange=()=>{this.#e?.close(),this.#e=null,this.#t=null},this.#e.onclose=()=>{this.#e=null,this.#t=null},e(this.#e)},n.onerror=()=>{this.#e=null,this.#t=null,t(n.error)}}),this.#t)}async#o(e,t){let n=await this.#a();return new Promise((r,i)=>{let a=n.transaction(this.#i,e);a.onabort=()=>i(a.error??Error(`Transaction aborted`));let o=t(a.objectStore(this.#i));e===`readonly`?o.onsuccess=()=>r(o.result):a.oncomplete=()=>r(o.result),o.onerror=()=>i(o.error)})}async get(e){return(await this.#o(`readonly`,t=>t.get(e)))?.value??null}async set(e,t){await this.#o(`readwrite`,n=>n.put({key:e,value:t}))}async delete(e){await this.#o(`readwrite`,t=>t.delete(e))}async clear(){await this.#o(`readwrite`,e=>e.clear())}};const h=new m;var g=class{async get(e){return(await chrome.storage.session.get(e))[e]??null}async set(e,t){await chrome.storage.session.set({[e]:t})}async delete(e){await chrome.storage.session.remove(e)}};const _=new g;function v(e){return`zama:pending-unshield:${e}`}async function y(e,t,n){await e.set(v(t),n)}async function b(e,t){return e.get(v(t))}async function x(e,t){await e.delete(v(t))}exports.ApprovalFailedError=e.t,exports.ChromeSessionStorage=g,exports.ConfigurationError=e.n,exports.CredentialsManager=t.y,exports.DecryptionFailedError=e.r,exports.DelegatedCredentialsManager=t.v,exports.DelegationCooldownError=e.i,exports.DelegationExpiredError=e.a,exports.DelegationNotFoundError=e.o,exports.DelegationSelfNotAllowedError=e.s,exports.ERC7984_INTERFACE_ID=r.t,exports.ERC7984_WRAPPER_INTERFACE_ID=r.n,exports.EncryptionFailedError=e.c,exports.HardhatConfig=n.n,exports.IndexedDBStorage=m,exports.InvalidKeypairError=e.l,exports.KeypairExpiredError=e.u,exports.MainnetConfig=n.r,exports.MemoryStorage=t.b,exports.NoCiphertextError=e.d,exports.ReadonlyToken=t.g,exports.RelayerRequestFailedError=e.f,exports.RelayerWeb=u,exports.SepoliaConfig=n.i,exports.SigningFailedError=e.p,exports.SigningRejectedError=e.m,exports.TOKEN_TOPICS=t.a,exports.Token=d,exports.Topics=t.o,exports.TransactionRevertedError=e.h,exports.ZERO_HANDLE=t._,exports.ZamaError=e.g,exports.ZamaErrorCode=e._,exports.ZamaSDK=p,exports.ZamaSDKEvents=t.S,exports.allowanceContract=t.j,exports.applyDecryptedValues=t.t,exports.approveContract=t.M,exports.balanceOfContract=t.N,exports.chromeSessionStorage=_,exports.clearPendingUnshield=x,exports.confidentialBalanceOfContract=r.f,exports.confidentialBatchTransferContract=i.t,exports.confidentialTotalSupplyContract=r.p,exports.confidentialTransferContract=r.m,exports.confidentialTransferFromContract=r.h,exports.decimalsContract=t.P,exports.decodeConfidentialTransfer=t.s,exports.decodeOnChainEvent=t.c,exports.decodeOnChainEvents=t.l,exports.decodeUnwrapRequested=t.u,exports.decodeUnwrappedFinalized=t.d,exports.decodeUnwrappedStarted=t.f,exports.decodeWrapped=t.p,exports.delegateForUserDecryptionContract=t.w,exports.deploymentCoordinatorContract=r.g,exports.extractEncryptedHandles=t.n,exports.finalizeUnwrapContract=r.c,exports.findUnwrapRequested=t.m,exports.findWrapped=t.h,exports.getBatchTransferFeeContract=t.D,exports.getDelegationExpiryContract=t.T,exports.getFeeRecipientContract=t.O,exports.getUnwrapFeeContract=t.k,exports.getWrapFeeContract=t.A,exports.getWrapperContract=r.o,exports.indexedDBStorage=h,exports.isConfidentialTokenContract=r.r,exports.isConfidentialWrapperContract=r.i,exports.isFinalizeUnwrapOperatorContract=r._,exports.isOperatorContract=r.v,exports.loadPendingUnshield=b,exports.matchZamaError=e.v,exports.memoryStorage=t.x,exports.nameContract=t.F,exports.parseActivityFeed=t.r,exports.rateContract=r.y,exports.revokeDelegationContract=t.E,exports.savePendingUnshield=y,exports.setFinalizeUnwrapOperatorContract=r.b,exports.setOperatorContract=r.x,exports.sortByBlockNumber=t.i,exports.supportsInterfaceContract=r.a,exports.symbolContract=t.I,exports.totalSupplyContract=r.S,exports.underlyingContract=r.l,exports.unwrapContract=r.C,exports.unwrapFromBalanceContract=r.w,exports.wrapContract=r.u,exports.wrapETHContract=r.d,exports.wrapperExistsContract=r.s;
494
+ `,l=class extends s{constructor(e){super(e,e.logger)}createWorker(){let e=t.z();if(e)return new Worker(e.getURL(`relayer-sdk.worker.js`));let n=URL.createObjectURL(new Blob([c],{type:`application/javascript`}));try{return new Worker(n)}finally{URL.revokeObjectURL(n)}}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(){return{type:`INIT`,payload:this.config}}async updateCsrf(e){await this.sendRequest(`UPDATE_CSRF`,{csrfToken:e})}};const u=8192,d=300*1e3;function f(e){let t=[];for(let n=0;n<e.length;n+=u)t.push(String.fromCharCode(...e.subarray(n,n+u)));return btoa(t.join(``))}function p(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 m(e){return`fhe:pubkey:${e}`}function h(e,t){return`fhe:params:${e}:${t}`}function g(e){return`fhe:params-index:${e}`}function _(e){t.L(e,`CachedPublicKey`),t.R(e,`publicKeyId`,`CachedPublicKey.publicKeyId`),t.R(e,`publicKey`,`CachedPublicKey.publicKey`)}function v(e){t.L(e,`CachedPublicParams`),t.R(e,`publicParamsId`,`CachedPublicParams.publicParamsId`),t.R(e,`publicParams`,`CachedPublicParams.publicParams`)}var y=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=m(this.#t);try{let e=await this.#e.get(n);if(e){_(e);let t={publicKeyId:e.publicKeyId,publicKey:p(e.publicKey)};return this.#a=t,t}}catch(e){await this.#g(n),this.#i.warn(`Failed to read public key from persistent storage, falling back to network fetch`,{chainId:this.#t,error:t.B(e).message})}let r=await e();if(r===null)return null;this.#a=r;try{let e={publicKeyId:r.publicKeyId,publicKey:f(r.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.B(e).message})}return r}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=h(this.#t,e);try{let t=await this.#e.get(r);if(t){v(t);let n={publicParamsId:t.publicParamsId,publicParams:p(t.publicParams)};return this.#o.set(e,n),n}}catch(n){await this.#g(r),this.#i.warn(`Failed to read public params from persistent storage, falling back to network fetch`,{chainId:this.#t,bits:e,error:t.B(n).message})}let i=await n();if(i===null)return null;this.#o.set(e,i);try{let n={publicParamsId:i.publicParamsId,publicParams:f(i.publicParams),lastValidatedAt:Date.now()};await this.#e.set(r,n);let a=g(this.#t),o=await this.#e.get(a).catch(e=>(this.#i.warn(`Failed to read params index from storage`,{chainId:this.#t,error:t.B(e).message}),null))??[];o.includes(e)||await this.#e.set(a,[...o,e])}catch(n){this.#i.warn(`Failed to persist public params to storage`,{chainId:this.#t,bits:e,error:t.B(n).message})}return i}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 n=m(this.#t),r=null,i=[];try{let[a,o]=await Promise.all([this.#e.get(n),this.#h()]);if(a)try{_(a),r={...a,lastValidatedAt:a.lastValidatedAt??0}}catch(e){this.#i.warn(`Corrupt public key cache entry detected, deleting`,{chainId:this.#t,error:t.B(e).message}),await this.#g(n)}if(i=o,!r)return!1;if([r,...i.map(e=>e.data)].every(t=>e-t.lastValidatedAt<this.#r))return this.#u=e,!1;let s=await globalThis.fetch(`${this.#n}/keyurl`);if(!s.ok){let t=e-this.#r+d;return this.#i.warn(`Manifest fetch failed during revalidation, retrying in 5 min`,{status:s.status,relayerUrl:this.#n}),await this.#v(n,{...r,lastValidatedAt:t},i.map(e=>({...e,data:{...e.data,lastValidatedAt:t}}))),this.#u=t,!1}let c=await s.json();if(!c||typeof c!=`object`||!(`fhePublicKey`in c)||!c.fhePublicKey?.urls?.length||!(`crs`in c)||typeof c.crs!=`object`){this.#i.error(`Relayer manifest has unexpected shape — check relayer URL and API version`,{relayerUrl:this.#n,manifestKeys:c&&typeof c==`object`?Object.keys(c):[]});let t=e-this.#r+d;return await this.#v(n,{...r,lastValidatedAt:t},i.map(e=>({...e,data:{...e.data,lastValidatedAt:t}}))),this.#u=t,!1}let l=c,u=l.fhePublicKey.urls[0];if(r.artifactUrl&&u&&u!==r.artifactUrl)return await this.#_(n,i),this.#u=null,!0;let f={...r,lastValidatedAt:e};if(u){let e=await this.#m(u,r);if(!e.fresh)return await this.#_(n,i),this.#u=null,!0;f={...f,artifactUrl:u,etag:e.etag,lastModified:e.lastModified}}let p=[];for(let t of i){let r=l.crs[String(t.bits)]?.urls[0];if(t.data.artifactUrl&&r&&r!==t.data.artifactUrl)return await this.#_(n,i),this.#u=null,!0;let a={...t.data,lastValidatedAt:e};if(r){let e=await this.#m(r,t.data);if(!e.fresh)return await this.#_(n,i),this.#u=null,!0;a={...a,artifactUrl:r,etag:e.etag,lastModified:e.lastModified}}p.push({...t,data:a})}return await this.#v(n,f,p),this.#u=e,!1}catch(a){let o=t.B(a),s=a instanceof TypeError||a instanceof ReferenceError||a instanceof RangeError||a 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:o.message});let l=e-this.#r+d;try{r&&await this.#v(n,{...r,lastValidatedAt:l},i.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.B(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=g(this.#t),n=await this.#e.get(e).catch(e=>(this.#i.warn(`Failed to read params index, CRS revalidation may be incomplete`,{chainId:this.#t,error:t.B(e).message}),null))??[],r=new Set([...this.#o.keys(),...n]),i=Array.from(r);return(await Promise.all(i.map(async e=>{let n=h(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.B(n).message}),null}if(!r)return null;try{return v(r),{bits:e,key:n,data:{...r,lastValidatedAt:r.lastValidatedAt??0}}}catch(r){return this.#i.warn(`Corrupt params cache entry detected, deleting`,{chainId:this.#t,bits:e,error:t.B(r).message}),await this.#g(n),null}}))).filter(e=>e!==null)}async#g(e){await this.#e.delete(e).catch(n=>{this.#i.warn(`Failed to delete cache entry`,{chainId:this.#t,key:e,error:t.B(n).message})})}async#_(e,n){let r=g(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.B(e).message})}this.#a=void 0,this.#o.clear()}async#v(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.B(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.B(e).message})}))];await Promise.all(i)}},b=class{#e=null;#t=null;#n;#r;#i;constructor(e=`CredentialStore`,t=1,n=`credentials`){this.#n=e,this.#r=t,this.#i=n}#a(){return this.#e?Promise.resolve(this.#e):(this.#t||=new Promise((e,t)=>{let n=indexedDB.open(this.#n,this.#r);n.onupgradeneeded=()=>{let e=n.result;e.objectStoreNames.contains(this.#i)||e.createObjectStore(this.#i,{keyPath:`key`})},n.onsuccess=()=>{this.#e=n.result,this.#t=null,this.#e.onversionchange=()=>{console.warn(`IndexedDB "${this.#n}" closing due to version change from another tab`),this.#e?.close(),this.#e=null,this.#t=null},this.#e.onclose=()=>{this.#e=null,this.#t=null},e(this.#e)},n.onerror=()=>{this.#e=null,this.#t=null,t(n.error)}}),this.#t)}async#o(e,t){let n=await this.#a();return new Promise((r,i)=>{let a=n.transaction(this.#i,e);a.onabort=()=>i(a.error??Error(`Transaction aborted`));let o=t(a.objectStore(this.#i));e===`readonly`?o.onsuccess=()=>r(o.result):a.oncomplete=()=>r(o.result),o.onerror=()=>i(o.error)})}async get(e){return(await this.#o(`readonly`,t=>t.get(e)))?.value??null}async set(e,t){await this.#o(`readwrite`,n=>n.put({key:e,value:t}))}async delete(e){await this.#o(`readwrite`,t=>t.delete(e))}async clear(){await this.#o(`readwrite`,e=>e.clear())}};const x=new b;var S=class{#e=null;#t=null;#n=null;#r=!1;#i=null;#a=null;#o=null;#s=`idle`;#c;#l;constructor(e){this.#l=e}get status(){return this.#s}get initError(){return this.#c}#u(e,t){this.#s=e,this.#c=t,this.#l.onStatusChange?.(e,t)}async#d(){let e=await this.#l.getChainId(),{transports:t,security:r,threads:i}=this.#l;if(i!==void 0&&(!Number.isInteger(i)||i<1))throw Error(`Invalid thread count: ${i}. Must be a positive integer.`);return i!==void 0&&globalThis.SharedArrayBuffer===void 0&&this.#l.logger?.warn(`threads option requires SharedArrayBuffer (COOP/COEP headers). Falling back to single-threaded.`),{cdnUrl:`https://cdn.zama.org/relayer-sdk-js/0.4.1/relayer-sdk-js.umd.cjs`,fhevmConfig:Object.assign({},n.t[e],t[e]),csrfToken:r?.getCsrfToken?.()??``,integrity:r?.integrityCheck===!1?void 0:`2bd5401738b74509549bed2029bbbabedd481b10ac260f66e64a4ff3723d6d704180c51e882757c56ca1840491e90e33`,logger:this.#l.logger,thread:i}}async#f(){if(this.#n)return this.#n;this.#n=this.#m();try{return await this.#n}finally{this.#n=null}}#p(){this.#e?.terminate(),this.#e=null,this.#t=null,this.#a=null}async#m(){this.#r&&(this.#r=!1,this.#e=null,this.#t=null,this.#i=null);let t=await this.#l.getChainId();if(this.#i!==null&&t!==this.#i&&this.#p(),this.#i=t,this.#o||=this.#l.fheArtifactStorage??new b(`FheArtifactCache`,1,`artifacts`),!this.#a){let e=Object.assign({},n.t[t],this.#l.transports[t]);this.#a=new y({storage:this.#o,chainId:t,relayerUrl:e.relayerUrl,ttl:this.#l.fheArtifactCacheTTL,logger:this.#l.logger})}if(this.#a){let e=!1;try{e=await this.#a.revalidateIfDue()}catch(e){this.#l.logger?.warn(`Artifact revalidation failed, proceeding with potentially stale cache`,{error:e instanceof Error?e.message:String(e)})}e&&(this.#l.logger?.info(`Cached FHE artifacts are stale — reinitializing`),this.#p())}return this.#t||=(this.#u(`initializing`),this.#h().then(e=>(this.#u(`ready`),e)).catch(t=>{this.#t=null;let n=t instanceof e.g?t:new e.c(`Failed to initialize FHE worker`,{cause:t instanceof Error?t:void 0});throw this.#u(`error`,n),n})),this.#t}async#h(){let e=new l(await this.#d());if(await e.initWorker(),this.#r)throw e.terminate(),Error(`RelayerWeb was terminated during initialization`);return this.#e=e,e}terminate(){this.#r=!0,this.#e&&=(this.#e.terminate(),null),this.#t=null,this.#n=null}async#g(){if(this.#e){let e=this.#l.security?.getCsrfToken?.()??``;e&&await this.#e.updateCsrf(e)}}async generateKeypair(){let e=await(await this.#f()).generateKeypair();return{publicKey:e.publicKey,privateKey:e.privateKey}}async createEIP712(e,t,r,i=7){let a=await(await this.#f()).createEIP712({publicKey:e,contractAddresses:t,startTimestamp:r,durationDays:i}),o={name:a.domain.name,version:a.domain.version,chainId:a.domain.chainId,verifyingContract:a.domain.verifyingContract};return{domain:o,types:{EIP712Domain:n.a(o),UserDecryptRequestVerification:a.types.UserDecryptRequestVerification},message:{publicKey:a.message.publicKey,contractAddresses:a.message.contractAddresses,startTimestamp:a.message.startTimestamp,durationDays:a.message.durationDays,extraData:a.message.extraData}}}async encrypt(e){let{values:t,contractAddress:r,userAddress:i}=e;return n.o(async()=>{let e=await this.#f();await this.#g();let n=await e.encrypt({values:t,contractAddress:r,userAddress:i});return{handles:n.handles,inputProof:n.inputProof}})}async userDecrypt(e){return n.o(async()=>{let t=await this.#f();return await this.#g(),(await t.userDecrypt(e)).clearValues})}async publicDecrypt(e){return n.o(async()=>{let t=await this.#f();await this.#g();let n=await t.publicDecrypt(e);return{clearValues:n.clearValues,abiEncodedClearValues:n.abiEncodedClearValues,decryptionProof:n.decryptionProof}})}async createDelegatedUserDecryptEIP712(e,t,n,r,i=7){return(await this.#f()).createDelegatedUserDecryptEIP712({publicKey:e,contractAddresses:t,delegatorAddress:n,startTimestamp:r,durationDays:i})}async delegatedUserDecrypt(e){return n.o(async()=>{let t=await this.#f();return await this.#g(),(await t.delegatedUserDecrypt(e)).clearValues})}async requestZKProofVerification(e){return n.o(async()=>{let t=await this.#f();return await this.#g(),t.requestZKProofVerification(e)})}async getPublicKey(){let e=await this.#f();return this.#a?this.#a.getPublicKey(async()=>(await e.getPublicKey()).result):(await e.getPublicKey()).result}async getPublicParams(e){let t=await this.#f();return this.#a?this.#a.getPublicParams(e,async()=>(await t.getPublicParams(e)).result):(await t.getPublicParams(e)).result}async getAclAddress(){let t=await this.#l.getChainId(),r=Object.assign({},n.t[t],this.#l.transports[t]);if(!r.aclContractAddress)throw new e.n(`No ACL address configured for chain ${t}`);return r.aclContractAddress}},C=class n extends t.g{static ZERO_ADDRESS=`0x0000000000000000000000000000000000000000`;wrapper;#e;#t=null;constructor(e){super(e),this.wrapper=e.wrapper?(0,a.getAddress)(e.wrapper):this.address}async#n(){return this.#e===void 0?(this.#t||=this.signer.readContract(r.l(this.wrapper)).then(e=>(this.#e=e,this.#t=null,e)).catch(e=>{throw this.#t=null,e}),this.#t):this.#e}async confidentialTransfer(n,i,o){let s=(0,a.getAddress)(n),c,l,u=Date.now();try{this.emit({type:t.S.EncryptStart}),{handles:c,inputProof:l}=await this.relayer.encrypt({values:[{value:i,type:`euint64`}],contractAddress:this.address,userAddress:await this.signer.getAddress()}),this.emit({type:t.S.EncryptEnd,durationMs:Date.now()-u}),w(()=>o?.onEncryptComplete?.())}catch(n){throw this.emit({type:t.S.EncryptError,error:t.B(n),durationMs:Date.now()-u}),n instanceof e.g?n:new e.c(`Failed to encrypt transfer amount`,{cause:n instanceof Error?n:void 0})}if(c.length===0)throw new e.c(`Encryption returned no handles`);try{let e=await this.signer.writeContract(r.m(this.address,s,c[0],l));return this.emit({type:t.S.TransferSubmitted,txHash:e}),w(()=>o?.onTransferSubmitted?.(e)),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`transfer`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Transfer transaction failed`,{cause:n instanceof Error?n:void 0})}}async confidentialTransferFrom(n,i,o,s){let c=(0,a.getAddress)(n),l=(0,a.getAddress)(i),u,d,f=Date.now();try{this.emit({type:t.S.EncryptStart}),{handles:u,inputProof:d}=await this.relayer.encrypt({values:[{value:o,type:`euint64`}],contractAddress:this.address,userAddress:c}),this.emit({type:t.S.EncryptEnd,durationMs:Date.now()-f}),w(()=>s?.onEncryptComplete?.())}catch(n){throw this.emit({type:t.S.EncryptError,error:t.B(n),durationMs:Date.now()-f}),n instanceof e.g?n:new e.c(`Failed to encrypt transferFrom amount`,{cause:n instanceof Error?n:void 0})}if(u.length===0)throw new e.c(`Encryption returned no handles`);try{let e=await this.signer.writeContract(r.h(this.address,c,l,u[0],d));return this.emit({type:t.S.TransferFromSubmitted,txHash:e}),w(()=>s?.onTransferSubmitted?.(e)),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`transferFrom`,error:t.B(n)}),n instanceof e.g?n:new e.h(`TransferFrom transaction failed`,{cause:n instanceof Error?n:void 0})}}async approve(n,i){let o=(0,a.getAddress)(n);try{let e=await this.signer.writeContract(r.x(this.address,o,i));return this.emit({type:t.S.ApproveSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`approve`,error:t.B(n)}),n instanceof e.g?n:new e.t(`Operator approval failed`,{cause:n instanceof Error?n:void 0})}}async isApproved(e,t){let n=(0,a.getAddress)(e),i=t?(0,a.getAddress)(t):await this.signer.getAddress();return this.signer.readContract(r.v(this.address,i,n))}async shield(i,o){if(await this.#n()===n.ZERO_ADDRESS)return this.shieldETH(i,i+(o?.fees??0n));let s=o?.approvalStrategy??`exact`;s!==`skip`&&await this.#a(i,s===`max`,o?.callbacks);try{let e=o?.to?(0,a.getAddress)(o.to):await this.signer.getAddress(),n=await this.signer.writeContract(r.u(this.wrapper,e,i));return this.emit({type:t.S.ShieldSubmitted,txHash:n}),w(()=>o?.callbacks?.onShieldSubmitted?.(n)),{txHash:n,receipt:await this.signer.waitForTransactionReceipt(n)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`shield`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Shield transaction failed`,{cause:n instanceof Error?n:void 0})}}async shieldETH(n,i){try{let e=await this.signer.getAddress(),a=await this.signer.writeContract(r.d(this.wrapper,e,n,i??n));return this.emit({type:t.S.ShieldSubmitted,txHash:a}),{txHash:a,receipt:await this.signer.waitForTransactionReceipt(a)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`shieldETH`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Shield ETH transaction failed`,{cause:n instanceof Error?n:void 0})}}async unwrap(n){let i=await this.signer.getAddress(),a,o,s=Date.now();try{this.emit({type:t.S.EncryptStart}),{handles:a,inputProof:o}=await this.relayer.encrypt({values:[{value:n,type:`euint64`}],contractAddress:this.wrapper,userAddress:i}),this.emit({type:t.S.EncryptEnd,durationMs:Date.now()-s})}catch(n){throw this.emit({type:t.S.EncryptError,error:t.B(n),durationMs:Date.now()-s}),n instanceof e.g?n:new e.c(`Failed to encrypt unshield amount`,{cause:n instanceof Error?n:void 0})}if(a.length===0)throw new e.c(`Encryption returned no handles`);try{let e=await this.signer.writeContract(r.C(this.address,i,i,a[0],o));return this.emit({type:t.S.UnwrapSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`unwrap`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Unshield transaction failed`,{cause:n instanceof Error?n:void 0})}}async unwrapAll(){let n=await this.signer.getAddress(),i=await this.readConfidentialBalanceOf(n);if(this.isZeroHandle(i))throw new e.r(`Cannot unshield: balance is zero`);try{let e=await this.signer.writeContract(r.w(this.address,n,n,i));return this.emit({type:t.S.UnwrapSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`unwrap`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Unshield-all transaction failed`,{cause:n instanceof Error?n:void 0})}}async unshield(e,t){let n=crypto.randomUUID(),r=await this.unwrap(e);return w(()=>t?.onUnwrapSubmitted?.(r.txHash)),this.#i(r.txHash,t,n)}async unshieldAll(e){let t=crypto.randomUUID(),n=await this.unwrapAll();return w(()=>e?.onUnwrapSubmitted?.(n.txHash)),this.#i(n.txHash,e,t)}async resumeUnshield(e,t){return this.#i(e,t,crypto.randomUUID())}async finalizeUnwrap(n){let i,o,s=Date.now();try{this.emit({type:t.S.DecryptStart});let r=await this.relayer.publicDecrypt([n]);this.emit({type:t.S.DecryptEnd,durationMs:Date.now()-s}),o=r.decryptionProof;try{i=(0,a.hexToBigInt)(r.abiEncodedClearValues)}catch{throw new e.r(`Cannot parse decrypted value: ${r.abiEncodedClearValues}`)}}catch(n){throw this.emit({type:t.S.DecryptError,error:t.B(n),durationMs:Date.now()-s}),n instanceof e.g?n:new e.r(`Failed to finalize unshield`,{cause:n instanceof Error?n:void 0})}try{let e=await this.signer.writeContract(r.c(this.wrapper,n,i,o));return this.emit({type:t.S.FinalizeUnwrapSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`finalizeUnwrap`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Failed to finalize unshield`,{cause:n instanceof Error?n:void 0})}}async approveUnderlying(n){let r=await this.#n(),i=n??2n**256n-1n;try{if(i>0n){let e=await this.signer.getAddress();await this.signer.readContract(t.j(r,e,this.wrapper))>0n&&await this.signer.writeContract(t.M(r,this.wrapper,0n))}let e=await this.signer.writeContract(t.M(r,this.wrapper,i));return this.emit({type:t.S.ApproveUnderlyingSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`approveUnderlying`,error:t.B(n)}),n instanceof e.g?n:new e.t(`ERC-20 approval failed`,{cause:n instanceof Error?n:void 0})}}async delegateDecryption({delegateAddress:n,expirationDate:r}){if(r&&r.getTime()<=Date.now())throw new e.n(`Expiration date must be in the future`);let i=await this.getAclAddress(),o=r?BigInt(Math.floor(r.getTime()/1e3)):t.C;try{let e=await this.signer.writeContract(t.w(i,(0,a.getAddress)(n),this.address,o));return this.emit({type:t.S.DelegationSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`delegateDecryption`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Delegation transaction failed`,{cause:n instanceof Error?n:void 0})}}async revokeDelegation({delegateAddress:n}){let r=await this.getAclAddress();try{let e=await this.signer.writeContract(t.E(r,(0,a.getAddress)(n),this.address));return this.emit({type:t.S.RevokeDelegationSubmitted,txHash:e}),{txHash:e,receipt:await this.signer.waitForTransactionReceipt(e)}}catch(n){throw this.emit({type:t.S.TransactionError,operation:`revokeDelegation`,error:t.B(n)}),n instanceof e.g?n:new e.h(`Revoke delegation transaction failed`,{cause:n instanceof Error?n:void 0})}}static async batchDelegateDecryption({tokens:e,delegateAddress:t,expirationDate:r}){return n.#r(e,e=>e.delegateDecryption({delegateAddress:t,expirationDate:r}),`Delegation failed`)}static async batchRevokeDelegation({tokens:e,delegateAddress:t}){return n.#r(e,e=>e.revokeDelegation({delegateAddress:t}),`Revoke delegation failed`)}static async#r(t,n,r){let i=new Map,a=await Promise.allSettled(t.map(n));for(let n=0;n<t.length;n++){let o=a[n];if(o.status===`fulfilled`)i.set(t[n].address,o.value);else{let a=o.reason instanceof e.g?o.reason:new e.h(r,{cause:o.reason});i.set(t[n].address,a)}}return i}async#i(n,r,i){this.emit({type:t.S.UnshieldPhase1Submitted,txHash:n,operationId:i});let a;try{a=await this.signer.waitForTransactionReceipt(n)}catch(t){throw t instanceof e.g?t:new e.h(`Failed to get unshield receipt`,{cause:t})}let o=t.m(a.logs);if(!o)throw new e.h(`No UnwrapRequested event found in unshield receipt`);this.emit({type:t.S.UnshieldPhase2Started,operationId:i}),w(()=>r?.onFinalizing?.());let s=await this.finalizeUnwrap(o.encryptedAmount);return this.emit({type:t.S.UnshieldPhase2Submitted,txHash:s.txHash,operationId:i}),w(()=>r?.onFinalizeSubmitted?.(s.txHash)),s}async#a(n,r,i){let a=await this.#n(),o=await this.signer.getAddress(),s=await this.signer.readContract(t.j(a,o,this.wrapper));if(!(s>=n))try{s>0n&&await this.signer.writeContract(t.M(a,this.wrapper,0n));let e=r?2n**256n-1n:n,o=await this.signer.writeContract(t.M(a,this.wrapper,e));this.emit({type:t.S.ApproveUnderlyingSubmitted,txHash:o}),w(()=>i?.onApprovalSubmitted?.(o))}catch(t){throw t instanceof e.g?t:new e.t(`ERC-20 approval failed`,{cause:t instanceof Error?t:void 0})}}};function w(e){try{e()}catch(e){console.warn(`[zama-sdk] Callback threw:`,e)}}var T=class{relayer;signer;storage;sessionStorage;credentials;delegatedCredentials;#e;#t;#n;#r=null;#i=null;constructor(e){this.relayer=e.relayer,this.signer=e.signer,this.storage=e.storage,this.sessionStorage=e.sessionStorage??new t.b,this.#e=e.onEvent??function(){};let n={relayer:this.relayer,signer:this.signer,storage:this.storage,sessionStorage:this.sessionStorage,keypairTTL:(()=>{let t=e.keypairTTL??86400;if(t<=0)throw Error(`keypairTTL must be a positive number (seconds)`);return t})(),sessionTTL:e.sessionTTL??2592e3,onEvent:this.#e};if(this.credentials=new t.y(n),this.delegatedCredentials=new t.v(n),this.#n=this.#a(),this.signer.subscribe){let n=e.signerLifecycleCallbacks,r=(e,n)=>{n().catch(n=>{this.#e?.({type:t.S.TransactionError,operation:e,error:t.B(n),timestamp:Date.now()})})};this.#t=this.signer.subscribe({onDisconnect:()=>{r(`signerDisconnect`,async()=>{await this.#o(),this.#r=null,this.#i=null,n?.onDisconnect?.()})},onAccountChange:e=>{r(`signerAccountChange`,async()=>{await this.#o(),this.#r=(0,a.getAddress)(e);try{this.#i=await this.signer.getChainId()}catch{}n?.onAccountChange?.(e)})},onChainChange:e=>{r(`signerChainChange`,async()=>{await this.#o(),this.#i=e;try{this.#r=await this.signer.getAddress()}catch{}n?.onChainChange?.(e)})}})}}async#a(){try{let e=await this.signer.getAddress(),t=await this.signer.getChainId();this.#r=e,this.#i=t}catch{}}async#o(){if(await this.#n,this.#r===null||this.#r===void 0||this.#i===null||this.#i===void 0)return;let e=await t.y.computeStoreKey(this.#r,this.#i);await this.sessionStorage.delete(e),this.#e?.({type:t.S.CredentialsRevoked,timestamp:Date.now()})}createReadonlyToken(e){return new t.g({relayer:this.relayer,signer:this.signer,storage:this.storage,sessionStorage:this.sessionStorage,credentials:this.credentials,delegatedCredentials:this.delegatedCredentials,address:(0,a.getAddress)(e),onEvent:this.#e})}createToken(e,t){return new C({relayer:this.relayer,signer:this.signer,storage:this.storage,sessionStorage:this.sessionStorage,credentials:this.credentials,delegatedCredentials:this.delegatedCredentials,address:(0,a.getAddress)(e),wrapper:t?(0,a.getAddress)(t):void 0,onEvent:this.#e})}async allow(...e){await this.credentials.allow(...e)}async revoke(...e){await this.credentials.revoke(...e)}async revokeSession(){await this.#n;let e=this.#r??await this.signer.getAddress(),n=this.#i??await this.signer.getChainId(),r=await t.y.computeStoreKey(e,n);await this.sessionStorage.delete(r),this.#e?.({type:t.S.CredentialsRevoked,timestamp:Date.now()})}async isAllowed(){return this.credentials.isAllowed()}dispose(){this.#t?.(),this.#t=void 0}terminate(){this.dispose(),this.relayer.terminate()}},E=class{async get(e){return(await chrome.storage.session.get(e))[e]??null}async set(e,t){await chrome.storage.session.set({[e]:t})}async delete(e){await chrome.storage.session.remove(e)}};const D=new E;function O(e){return`zama:pending-unshield:${e}`}async function k(e,t,n){await e.set(O(t),n)}async function A(e,t){return e.get(O(t))}async function j(e,t){await e.delete(O(t))}exports.ApprovalFailedError=e.t,exports.ChromeSessionStorage=E,exports.ConfigurationError=e.n,exports.CredentialsManager=t.y,exports.DecryptionFailedError=e.r,exports.DelegatedCredentialsManager=t.v,exports.DelegationCooldownError=e.i,exports.DelegationExpiredError=e.a,exports.DelegationNotFoundError=e.o,exports.DelegationSelfNotAllowedError=e.s,exports.ERC7984_INTERFACE_ID=r.t,exports.ERC7984_WRAPPER_INTERFACE_ID=r.n,exports.EncryptionFailedError=e.c,exports.HardhatConfig=n.n,exports.IndexedDBStorage=b,exports.InvalidKeypairError=e.l,exports.KeypairExpiredError=e.u,exports.MainnetConfig=n.r,exports.MemoryStorage=t.b,exports.NoCiphertextError=e.d,exports.ReadonlyToken=t.g,exports.RelayerRequestFailedError=e.f,exports.RelayerWeb=S,exports.SepoliaConfig=n.i,exports.SigningFailedError=e.p,exports.SigningRejectedError=e.m,exports.TOKEN_TOPICS=t.a,exports.Token=C,exports.Topics=t.o,exports.TransactionRevertedError=e.h,exports.ZERO_HANDLE=t._,exports.ZamaError=e.g,exports.ZamaErrorCode=e._,exports.ZamaSDK=T,exports.ZamaSDKEvents=t.S,exports.allowanceContract=t.j,exports.applyDecryptedValues=t.t,exports.approveContract=t.M,exports.balanceOfContract=t.N,exports.chromeSessionStorage=D,exports.clearPendingUnshield=j,exports.confidentialBalanceOfContract=r.f,exports.confidentialBatchTransferContract=i.t,exports.confidentialTotalSupplyContract=r.p,exports.confidentialTransferContract=r.m,exports.confidentialTransferFromContract=r.h,exports.decimalsContract=t.P,exports.decodeConfidentialTransfer=t.s,exports.decodeOnChainEvent=t.c,exports.decodeOnChainEvents=t.l,exports.decodeUnwrapRequested=t.u,exports.decodeUnwrappedFinalized=t.d,exports.decodeUnwrappedStarted=t.f,exports.decodeWrapped=t.p,exports.delegateForUserDecryptionContract=t.w,exports.deploymentCoordinatorContract=r.g,exports.extractEncryptedHandles=t.n,exports.finalizeUnwrapContract=r.c,exports.findUnwrapRequested=t.m,exports.findWrapped=t.h,exports.getBatchTransferFeeContract=t.D,exports.getDelegationExpiryContract=t.T,exports.getFeeRecipientContract=t.O,exports.getUnwrapFeeContract=t.k,exports.getWrapFeeContract=t.A,exports.getWrapperContract=r.o,exports.indexedDBStorage=x,exports.isConfidentialTokenContract=r.r,exports.isConfidentialWrapperContract=r.i,exports.isFinalizeUnwrapOperatorContract=r._,exports.isOperatorContract=r.v,exports.loadPendingUnshield=A,exports.matchZamaError=e.v,exports.memoryStorage=t.x,exports.nameContract=t.F,exports.parseActivityFeed=t.r,exports.rateContract=r.y,exports.revokeDelegationContract=t.E,exports.savePendingUnshield=k,exports.setFinalizeUnwrapOperatorContract=r.b,exports.setOperatorContract=r.x,exports.sortByBlockNumber=t.i,exports.supportsInterfaceContract=r.a,exports.symbolContract=t.I,exports.totalSupplyContract=r.S,exports.underlyingContract=r.l,exports.unwrapContract=r.C,exports.unwrapFromBalanceContract=r.w,exports.wrapContract=r.u,exports.wrapETHContract=r.d,exports.wrapperExistsContract=r.s;
495
495
  //# sourceMappingURL=index.cjs.map