@zama-fhe/sdk 2.4.0 → 2.5.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/activity.cjs +1 -1
- package/dist/cjs/activity.cjs.map +1 -1
- package/dist/cjs/index.cjs +2 -2
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/query/index.cjs +1 -1
- package/dist/cjs/query/index.cjs.map +1 -1
- package/dist/esm/{activity-CAZLy9Lp.d.ts → activity-C38S7VvH.d.ts} +32 -11
- package/dist/esm/activity-DQtra5rT.js +2 -0
- package/dist/esm/activity-DQtra5rT.js.map +1 -0
- package/dist/esm/index.d.ts +2 -2
- package/dist/esm/index.js +2 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/query/index.d.ts +2 -2
- package/dist/esm/query/index.js +1 -1
- package/dist/esm/query/index.js.map +1 -1
- package/package.json +1 -1
- package/dist/esm/activity-CCD_CGXh.js +0 -2
- package/dist/esm/activity-CCD_CGXh.js.map +0 -1
package/dist/cjs/activity.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`./relayer.cjs`),t=require(`./wrappers-registry.cjs`);let n=require(`viem`);var r=class extends e.a{constructor(t,n){super(e.o.SigningRejected,t,n),this.name=`SigningRejectedError`}},i=class extends e.a{constructor(t,n){super(e.o.SigningFailed,t,n),this.name=`SigningFailedError`}};function a(e,t){let n=typeof e==`object`&&!!e&&`code`in e&&e.code===4001,a=e instanceof Error?e.message:String(e),o=a.toLowerCase(),s=o.includes(`user rejected`)||o.includes(`user denied`),c=`${t}: ${a}`;throw n||s?new r(c,{cause:e}):new i(c,{cause:e})}var o=class extends e.a{constructor(t,n){super(e.o.KeypairExpired,t,n),this.name=`KeypairExpiredError`}},s=class extends e.a{constructor(t,n){super(e.o.InvalidKeypair,t,n),this.name=`InvalidKeypairError`}},c=class extends e.a{constructor(t,n){super(e.o.NoCiphertext,t,n),this.name=`NoCiphertextError`}},l=class extends e.a{constructor(t,n){super(e.o.DelegationSelfNotAllowed,t,n),this.name=`DelegationSelfNotAllowedError`}},u=class extends e.a{constructor(t,n){super(e.o.DelegationCooldown,t,n),this.name=`DelegationCooldownError`}},d=class extends e.a{constructor(t,n){super(e.o.DelegationNotFound,t,n),this.name=`DelegationNotFoundError`}},f=class extends e.a{constructor(t,n){super(e.o.DelegationExpired,t,n),this.name=`DelegationExpiredError`}},p=class extends e.a{constructor(t,n){super(e.o.DelegationExpiryUnchanged,t,n),this.name=`DelegationExpiryUnchangedError`}},m=class extends e.a{constructor(t,n){super(e.o.DelegationDelegateEqualsContract,t,n),this.name=`DelegationDelegateEqualsContractError`}},h=class extends e.a{constructor(t,n){super(e.o.DelegationContractIsSelf,t,n),this.name=`DelegationContractIsSelfError`}},g=class extends e.a{constructor(t,n){super(e.o.AclPaused,t,n),this.name=`AclPausedError`}},_=class extends e.a{constructor(t,n){super(e.o.DelegationExpirationTooSoon,t,n),this.name=`DelegationExpirationTooSoonError`}},v=class extends e.a{constructor(t,n){super(e.o.DelegationNotPropagated,t,n),this.name=`DelegationNotPropagatedError`}};function ee(e,t){if(e==null)throw TypeError(`${t} must not be null or undefined`)}function y(e,t){if(typeof e!=`object`||!e||Array.isArray(e))throw TypeError(`${t} must be an object, got ${typeof e}`)}function b(e,t){if(typeof e!=`string`)throw TypeError(`${t} must be a string, got ${typeof e}`)}function te(e,t){if(!Array.isArray(e))throw TypeError(`${t} must be an array, got ${typeof e}`)}function ne(e,t){if(typeof e!=`function`)throw TypeError(`${t} must be a function, got ${typeof e}`)}function x(e,t){if(typeof e!=`bigint`)throw TypeError(`${t} must be a bigint, got ${typeof e}`)}function re(e,t,n){b(e[t],n)}function ie(e,t,n){ne(e[t],n)}function S(e,t){if(!e)throw TypeError(t)}function C(e){return e instanceof Error?e:typeof e==`object`&&e&&`message`in e?Error(String(e.message)):Error(String(e))}function ae(e){if(!(e instanceof Error))return!1;if(e.name===`ContractFunctionExecutionError`||e.name===`ContractFunctionRevertedError`||`code`in e&&e.code===`CALL_EXCEPTION`)return!0;let t=e.message.toLowerCase();return t.includes(`execution reverted`)||t.includes(`call revert exception`)}function w(e){return e.startsWith(`0x`)?e:`0x${e}`}function oe(e){return{address:e,abi:n.erc20Abi,functionName:`name`,args:[]}}function se(e){return{address:e,abi:n.erc20Abi,functionName:`symbol`,args:[]}}function ce(e){return{address:e,abi:n.erc20Abi,functionName:`decimals`,args:[]}}function le(e){return{address:e,abi:n.erc20Abi,functionName:`totalSupply`,args:[]}}function ue(e,t){return{address:e,abi:n.erc20Abi,functionName:`balanceOf`,args:[t]}}function de(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`allowance`,args:[t,r]}}function fe(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`approve`,args:[t,r]}}const T=[{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`},{inputs:[{internalType:`address`,name:`delegator`,type:`address`},{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`},{internalType:`bytes32`,name:`handle`,type:`bytes32`}],name:`isHandleDelegatedForUserDecryption`,outputs:[{internalType:`bool`,name:``,type:`bool`}],stateMutability:`view`,type:`function`}];function pe(e,t,n,r){return{address:e,abi:T,functionName:`delegateForUserDecryption`,args:[t,n,r]}}function me(e,t,n){return{address:e,abi:T,functionName:`revokeDelegationForUserDecryption`,args:[t,n]}}function he(e,t,n,r){return{address:e,abi:T,functionName:`getUserDecryptionDelegationExpirationDate`,args:[t,n,r]}}function ge(e,t,n,r,i){return{address:e,abi:T,functionName:`isHandleDelegatedForUserDecryption`,args:[t,n,r,i]}}const E=2n**64n-1n;var D=class{#e;#t=`zama:decrypt`;#n=`${this.#t}:keys`;#r=Promise.resolve();constructor(e){this.#e=e}async get(e,t,n){try{let r=this.#o(e,t,n);return await this.#e.get(r)}catch(e){return console.warn(`[zama-sdk] DecryptCache.get failed:`,e),null}}async set(e,t,n,r){try{let i=this.#o(e,t,n);await this.#e.set(i,r),this.#r=this.#r.then(()=>this.#c(i).catch(e=>{console.warn(`[zama-sdk] DecryptCache index write failed:`,e)})),await this.#r}catch(e){console.warn(`[zama-sdk] DecryptCache.set failed:`,e)}}async clearForRequester(e){this.#r=this.#r.then(()=>this.#i(e).catch(e=>{console.warn(`[zama-sdk] DecryptCache.clearForRequester failed:`,e)})),await this.#r}async#i(e){let t=(0,n.getAddress)(e),r=`${this.#t}:${t}:`,i=await this.#s(),a=[],o=[];for(let e of i)e.startsWith(r)?a.push(e):o.push(e);await Promise.all(a.map(e=>this.#e.delete(e).catch(()=>{}))),await this.#e.set(this.#n,o)}async clearAll(){this.#r=this.#r.then(()=>this.#a().catch(e=>{console.warn(`[zama-sdk] DecryptCache.clearAll failed:`,e)})),await this.#r}async#a(){let e=await this.#s();await Promise.all(e.map(e=>this.#e.delete(e).catch(()=>{}))),await this.#e.delete(this.#n)}#o(e,t,r){return`${this.#t}:${(0,n.getAddress)(e)}:${(0,n.getAddress)(t)}:${r.toLowerCase()}`}async#s(){return await this.#e.get(this.#n)??[]}async#c(e){let t=await this.#s();t.includes(e)||(t.push(e),await this.#e.set(this.#n,t))}},O=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 _e=new O,k={CredentialsLoading:`credentials:loading`,CredentialsCached:`credentials:cached`,CredentialsExpired:`credentials:expired`,CredentialsCreating:`credentials:creating`,CredentialsCreated:`credentials:created`,CredentialsRevoked:`credentials:revoked`,CredentialsPersistFailed:`credentials:persist_failed`,CredentialsAllowed:`credentials:allowed`,CredentialsCorrupted:`credentials:corrupted`,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 ve=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),i=Uint8Array.from(atob(e.iv),e=>e.charCodeAt(0)),a=Uint8Array.from(atob(e.ciphertext),e=>e.charCodeAt(0)),o=await crypto.subtle.decrypt({name:`AES-GCM`,iv:i},r,a);return w(new TextDecoder().decode(o))}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 A(e){y(e,`Stored credentials`),b(e.publicKey,`credentials.publicKey`),te(e.contractAddresses,`credentials.contractAddresses`);for(let t of e.contractAddresses)S(typeof t==`string`&&(0,n.isAddress)(t,{strict:!1}),`Expected each contractAddress to be a valid hex address`);y(e.encryptedPrivateKey,`credentials.encryptedPrivateKey`),b(e.encryptedPrivateKey.iv,`encryptedPrivateKey.iv`),b(e.encryptedPrivateKey.ciphertext,`encryptedPrivateKey.ciphertext`),S(typeof e.startTimestamp==`number`,`Expected credentials.startTimestamp to be a number`),S(typeof e.durationDays==`number`,`Expected credentials.durationDays to be a number`)}function ye(e){A(e);let t=e;S(typeof t.delegatorAddress==`string`&&(0,n.isAddress)(t.delegatorAddress,{strict:!1}),`Expected credentials.delegatorAddress to be a valid address`),S(typeof t.delegateAddress==`string`&&(0,n.isAddress)(t.delegateAddress,{strict:!1}),`Expected credentials.delegateAddress to be a valid address`),S(typeof t.startTimestamp==`number`,`Expected startTimestamp to be a number`),S(typeof t.durationDays==`number`,`Expected durationDays to be a number`)}function j(e){return Math.floor(Date.now()/1e3)<e.startTimestamp+e.durationDays*86400}function M(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 N(e,t){return j(e)?M(e.contractAddresses,t):!1}function P(e){return[...new Set(e.map(e=>(0,n.getAddress)(e)))].toSorted()}async function F(...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 be=class{#e;constructor(e){this.#e=e}#t(e){y(e,`Session entry`),b(e.signature,`session.signature`),S(typeof e.createdAt==`number`,`Expected session.createdAt to be a number`),S(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}},I=class{signer;storage;sessionSignatures;crypto;keypairTTL;sessionTTL;#e;#t=null;#n=null;#r=null;#i=null;constructor(e){if(this.signer=e.signer,this.storage=e.storage,this.sessionSignatures=new be(e.sessionStorage),this.crypto=new ve,this.keypairTTL=e.keypairTTL??2592e3,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`);typeof this.sessionTTL==`number`&&this.sessionTTL>this.keypairTTL&&(this.sessionTTL=this.keypairTTL,console.warn(`[zama-sdk] sessionTTL was clamped to keypairTTL (${this.keypairTTL}s). A session that outlives the keypair causes isAllowed() to return true after the keypair expires, leading to unexpected wallet prompts.`))}emit(e){this.#e({...e,timestamp:Date.now()})}async resolveCredentials({key:t,contracts:n,createKey:r,createFn:i}){this.emit({type:k.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:k.SessionExpired,reason:`ttl`});else{let i=await this.decryptCredentials(e,r.signature);if(N(i,n))return this.emit({type:k.CredentialsCached,contractAddresses:n}),this.emit({type:k.CredentialsAllowed,contractAddresses:n}),i;if(j(i))return this.#a({key:t,credentials:i,requiredContracts:n});this.emit({type:k.CredentialsExpired,contractAddresses:n})}if(j(e)){if(M(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:k.CredentialsCached,contractAddresses:n}),this.emit({type:k.CredentialsAllowed,contractAddresses:n}),i}let r=await this.signForContracts(e,e.contractAddresses),i=await this.decryptCredentials(e,r);return this.#a({key:t,credentials:i,requiredContracts:n})}this.emit({type:k.CredentialsExpired,contractAddresses:n})}}catch(n){if(n instanceof e.a)throw n;console.warn(`[zama-sdk] Credential resolution failed, recreating:`,n),this.emit({type:k.CredentialsCorrupted,error:C(n)}),await this.#s(t)}return(!this.#t||this.#n!==r)&&(this.#n=r,this.#t=i().then(e=>(this.emit({type:k.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),!N(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:k.CredentialsRevoked,...t?{contractAddresses:t}:{}})}async checkAllowed(e,t){if(t.length===0)return!1;let n=await this.sessionSignatures.get(e);if(n===null||this.sessionSignatures.isExpired(n))return!1;try{let n=await this.storage.get(e);return n?(this.assertEncrypted(n),N(n,t)):!1}catch{return!1}}async clearAll(e){await this.sessionSignatures.delete(e),this.clearCaches(),await this.#s(e)}clearCaches(){this.crypto.clearCache(),this.#i=null}async createCredentials({key:t,contractAddresses:n,createFn:r,errorContext:i}){this.emit({type:k.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:k.CredentialsCreated,contractAddresses:n}),e}catch(t){if(t instanceof e.a)throw t;return a(t,i)}}async#a({key:e,credentials:t,requiredContracts:n}){if(this.#r){let e=await this.#r;if(M(e.contractAddresses,n))return this.emit({type:k.CredentialsAllowed,contractAddresses:n}),e;t=e}else if(this.#i){let e=this.#i;if(M(e.contractAddresses,n))return this.emit({type:k.CredentialsAllowed,contractAddresses:n}),e;t=e}let r=this.#o({key:e,credentials:t,requiredContracts:n});this.#r=r;try{let e=await r;return this.#i=e,e}finally{this.#r===r&&(this.#r=null)}}async#o({key:e,credentials:t,requiredContracts:n}){let r=P([...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:k.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),this.emit({type:k.CredentialsPersistFailed,error:C(e)})}}async#s(e){try{await this.storage.delete(e)}catch(e){console.warn(`[zama-sdk] Failed to delete credentials:`,e),this.emit({type:k.CredentialsPersistFailed,error:C(e)})}}};function xe(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 L=class e extends I{#e;#t=null;#n=null;static async computeStoreKey(e,t){return F((0,n.getAddress)(e),t)}constructor(e){super(e),this.#e=e.relayer,xe(typeof globalThis<`u`?Reflect.get(globalThis,`chrome`):void 0)&&e.sessionStorage instanceof O&&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=P(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 revokeByKey(e){await this.revokeSession(e)}async isAllowed(e){return this.checkAllowed(await this.#r(),e)}async clear(){await this.clearAll(await this.#r())}async create(e){let t=P(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){A(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}},R=class e extends I{#e;#t=null;#n=null;static async computeStoreKey(e,t,r){return F((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=P(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,t){return this.checkAllowed(await this.#i((0,n.getAddress)(e)),t)}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){ye(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)}})}};async function Se(e,t=1/0){if(Number.isFinite(t)&&t<=0)throw Error(`maxConcurrency must be a positive number`);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++;e[t]&&(n[t]=await e[t]())}}return await Promise.all(Array.from({length:t},i)),n}var Ce=class r{credentials;delegatedCredentials;relayer;signer;address;storage;cache;#e;constructor(e){let t={relayer:e.relayer,signer:e.signer,storage:e.storage,sessionStorage:e.sessionStorage,keypairTTL:e.keypairTTL??2592e3,sessionTTL:e.sessionTTL??2592e3,onEvent:e.onEvent};this.credentials=e.credentials??new L(t),this.delegatedCredentials=e.delegatedCredentials??new R(t),this.relayer=e.relayer,this.signer=e.signer,this.address=(0,n.getAddress)(e.address),this.storage=e.storage,this.cache=e.cache??new D(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.f(this.address,t.c))}async isWrapper(){return await this.signer.readContract(t.f(this.address,t.l))}static async batchDecryptBalances(e,t){if(e.length===0)return new Map;let{handles:n,owner:i,onError:a,maxConcurrency:o}=t??{},s=e[0],c=r.assertSameRelayer(e),l=i??await s.signer.getAddress();return r.#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:i,owner:a,onError:o,maxConcurrency:s}=t,c=a??n,l=e[0];return r.assertSameRelayer(e),r.#t({tokens:e,handles:i,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:r,ownerAddress:i,onError:a,maxConcurrency:o,obtainCreds:s,decrypt:c,errorPrefix:l}=t,u=n[0],d=r??await Promise.all(n.map(e=>e.readConfidentialBalanceOf(i)));if(n.length!==d.length)throw new e.r(`tokens.length (${n.length}) must equal handles.length (${d.length})`);let f=new Map,p=[],m=await Promise.all(n.map((e,t)=>{let n=d[t];return e.isZeroHandle(n)?0n:u.cache.get(i,e.address,n)}));for(let e=0;e<n.length;e++){let t=n[e],r=d[e],i=m[e];if(i!=null){x(i,`batchDecryptCore: cached`),f.set(t.address,i);continue}p.push({token:t,handle:r})}if(p.length===0)return f;t.preFlightCheck&&await t.preFlightCheck();let h=await s(p.map(e=>e.token.address)),g=[],_=[];for(let{token:t,handle:n}of p)_.push(()=>c(h,n,t.address).then(async r=>{let a=r[n];if(a===void 0)throw new e.r(`${l} returned no value for handle ${n} on token ${t.address}`);x(a,`batchDecryptCore: result[handle]`),f.set(t.address,a),u.cache.set(i,t.address,n,a)}).catch(e=>{let n=C(e);if(a)try{f.set(t.address,a(n,t.address))}catch(e){g.push({address:t.address,error:C(e)})}else g.push({address:t.address,error:n})}));if(await Se(_,o),g.length>0){let t=g.map(e=>`${e.address}: ${e.error.message}`).join(`; `);throw new e.r(`${l} failed for ${g.length} token(s): ${t}`)}return f}async underlyingToken(){return this.signer.readContract(t.m(this.address))}async allowance(e,r){let i=(0,n.getAddress)(e),a=await this.signer.readContract(t.m(i)),o=r?(0,n.getAddress)(r):await this.signer.getAddress();return this.signer.readContract(de(a,o,i))}async name(){return this.signer.readContract(oe(this.address))}async symbol(){return this.signer.readContract(se(this.address))}async decimals(){return this.signer.readContract(ce(this.address))}async allow(){await this.credentials.allow(this.address)}async isAllowed(){return this.credentials.isAllowed([this.address])}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===E?!0:t>await this.signer.getBlockTimestamp()}async getDelegationExpiry({delegatorAddress:e,delegateAddress:t}){let r=await this.getAclAddress();return this.signer.readContract(he(r,(0,n.getAddress)(e),(0,n.getAddress)(t),this.address))}async#n(e){let t=await this.signer.getAddress(),n=await this.getDelegationExpiry({delegatorAddress:e,delegateAddress:t});if(n===0n)throw new d(`No active delegation from ${e} to ${t} for ${this.address}`);if(n!==E&&n<=await this.signer.getBlockTimestamp())throw new f(`Delegation from ${e} to ${t} for ${this.address} has expired`)}async readConfidentialBalanceOf(e){return await this.signer.readContract(t.g(this.address,e))}isZeroHandle(e){return e===`0x0000000000000000000000000000000000000000000000000000000000000000`||e===`0x`}async decryptBalanceAs({delegatorAddress:t,owner:r}){let i=(0,n.getAddress)(t),a=r?(0,n.getAddress)(r):i,o=await this.readConfidentialBalanceOf(a);if(this.isZeroHandle(o))return 0n;let s=await this.cache.get(a,this.address,o);if(s!==null)return x(s,`decryptBalanceAs: cached`),s;await this.#n(i);let c=Date.now();try{this.emit({type:k.DecryptStart});let t=await this.delegatedCredentials.allow(i,this.address),n=await this.relayer.delegatedUserDecrypt({handles:[o],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:k.DecryptEnd,durationMs:Date.now()-c});let r=n[o];if(r===void 0)throw new e.r(`Delegated decryption returned no value for handle ${o}`);return x(r,`decryptBalanceAs: result[handle]`),await this.cache.set(a,this.address,o,r),r}catch(e){throw this.emit({type:k.DecryptError,error:C(e),durationMs:Date.now()-c}),z(e,`Failed to decrypt delegated balance`,!0)}}async decryptBalance(t,n){if(this.isZeroHandle(t))return 0n;let r=n??await this.signer.getAddress(),i=await this.cache.get(r,this.address,t);if(i!==null)return x(i,`decryptBalance: cached`),i;let a=await this.credentials.allow(this.address),o=Date.now();try{this.emit({type:k.DecryptStart});let n=await this.relayer.userDecrypt({handles:[t],contractAddress:this.address,signedContractAddresses:a.contractAddresses,privateKey:a.privateKey,publicKey:a.publicKey,signature:a.signature,signerAddress:r,startTimestamp:a.startTimestamp,durationDays:a.durationDays});this.emit({type:k.DecryptEnd,durationMs:Date.now()-o});let i=n[t];if(i===void 0)throw new e.r(`Decryption returned no value for handle ${t}`);return x(i,`decryptBalance: result[handle]`),await this.cache.set(r,this.address,t,i),i}catch(e){throw this.emit({type:k.DecryptError,error:C(e),durationMs:Date.now()-o}),z(e,`Failed to decrypt balance`)}}async decryptHandles(t,n){let r=new Map,i=[];for(let e of t)this.isZeroHandle(e)?r.set(e,0n):i.push(e);if(i.length===0)return r;let a=await this.credentials.allow(this.address),o=Date.now();try{this.emit({type:k.DecryptStart});let t=await this.relayer.userDecrypt({handles:i,contractAddress:this.address,signedContractAddresses:a.contractAddresses,privateKey:a.privateKey,publicKey:a.publicKey,signature:a.signature,signerAddress:n??await this.signer.getAddress(),startTimestamp:a.startTimestamp,durationDays:a.durationDays});this.emit({type:k.DecryptEnd,durationMs:Date.now()-o});for(let n of i){let i=t[n];if(i===void 0)throw new e.r(`Decryption returned no value for handle ${n}`);r.set(n,i)}}catch(e){throw this.emit({type:k.DecryptError,error:C(e),durationMs:Date.now()-o}),z(e,`Failed to decrypt handles`)}return r}static assertSameRelayer(t){let n=t[0].relayer;for(let r=1;r<t.length;r++)if(t[r].relayer!==n)throw new e.t(`All tokens in a batch operation must share the same relayer instance`);return n}};function z(t,n,a=!1){if(t instanceof e.r||t instanceof c||t instanceof e.n||t instanceof v||t instanceof r||t instanceof i)return t;let o=typeof t==`object`&&t&&`statusCode`in t&&typeof t.statusCode==`number`?t.statusCode:void 0;return o===400?new c(t instanceof Error?t.message:`No ciphertext for this account`,{cause:t}):a&&o===500?new v(`Delegated decryption failed with a server error. This is most commonly caused by the delegation not having propagated to the gateway yet — after granting delegation, allow 1–2 minutes for cross-chain synchronization before retrying. If the error persists, the gateway or relayer may be experiencing an unrelated issue.`,{cause:t}):o===void 0?new e.r(n,{cause:t}):new e.n(t instanceof Error?t.message:n,o,{cause:t})}const B={ConfidentialTransfer:`0x67500e8d0ed826d2194f514dd0d8124f35648ab6e3fb5e6ed867134cffe661e9`,Wrapped:`0x4700c1726b4198077cd40320a32c45265a1910521eb0ef713dd1d8412413d7fc`,UnwrapRequested:`0x77d02d353c5629272875d11f1b34ec4c65d7430b075575b78cd2502034c469ee`,UnwrappedFinalized:`0x2d4edf3c2943002120f53dab3f8940043f34799f4a92ab90f2f81f7dd004a49e`,UnwrappedStarted:`0x3838891d4843c6d7f9f494570b6fd8843f4e3c3ddb817c1411760bd31b819806`};function V(e){return(0,n.getAddress)(w(e.slice(-40)))}function we(e){return BigInt(e)}function Te(e){return e}function H(e,t){let n=2+t*64,r=e.slice(n,n+64);return r.length===64?r:r.padEnd(64,`0`)}function U(e,t){return(0,n.getAddress)(w(H(e,t).slice(-40)))}function W(e,t){return BigInt(`0x`+H(e,t))}function Ee(e,t){return BigInt(`0x`+H(e,t))!==0n}function G(e,t){return w(H(e,t))}function De(e){return e.topics[0]!==B.ConfidentialTransfer||e.topics.length<4?null:{eventName:`ConfidentialTransfer`,from:V(e.topics[1]),to:V(e.topics[2]),encryptedAmountHandle:Te(e.topics[3])}}function K(e){return e.topics[0]!==B.Wrapped||e.topics.length<2?null:{eventName:`Wrapped`,to:V(e.topics[1]),amountIn:W(e.data,0)}}function q(e){return e.topics[0]!==B.UnwrapRequested||e.topics.length<2?null:{eventName:`UnwrapRequested`,receiver:V(e.topics[1]),encryptedAmount:G(e.data,0)}}function Oe(e){return e.topics[0]!==B.UnwrappedFinalized||e.topics.length<2?null:{eventName:`UnwrappedFinalized`,receiver:V(e.topics[1]),encryptedAmount:G(e.data,0),cleartextAmount:W(e.data,1)}}function ke(e){return e.topics[0]!==B.UnwrappedStarted||e.topics.length<4?null:{eventName:`UnwrappedStarted`,requestId:we(e.topics[1]),txId:we(e.topics[2]),to:V(e.topics[3]),returnVal:Ee(e.data,0),refund:U(e.data,1),requestedAmount:G(e.data,2),burnAmount:G(e.data,3)}}function J(e){return De(e)??K(e)??q(e)??Oe(e)??ke(e)}function Ae(e){let t=[];for(let n of e){let e=J(n);e&&t.push(e)}return t}function je(e){for(let t of e){let e=q(t);if(e)return e}return null}function Me(e){for(let t of e){let e=K(t);if(e)return e}return null}const Ne=[B.ConfidentialTransfer,B.Wrapped,B.UnwrapRequested,B.UnwrappedFinalized,B.UnwrappedStarted],Y={DelegatedForUserDecryption:`0x527b025d7ff06689c1ab9d32dfd7881c964cce72ce8ac5b2fe1d3be8cfda5bfc`,RevokedDelegationForUserDecryption:`0x7aca80b6b7928b9038f186e3d9922a0fc5d52c398fbf144725c142c52a5277e4`};function X(e){return e.topics[0]!==Y.DelegatedForUserDecryption||e.topics.length<3?null:{eventName:`DelegatedForUserDecryption`,delegator:V(e.topics[1]),delegate:V(e.topics[2]),contractAddress:U(e.data,0),delegationCounter:W(e.data,1),oldExpirationDate:W(e.data,2),newExpirationDate:W(e.data,3)}}function Z(e){return e.topics[0]!==Y.RevokedDelegationForUserDecryption||e.topics.length<3?null:{eventName:`RevokedDelegationForUserDecryption`,delegator:V(e.topics[1]),delegate:V(e.topics[2]),contractAddress:U(e.data,0),delegationCounter:W(e.data,1),oldExpirationDate:W(e.data,2)}}function Pe(e){return X(e)??Z(e)}function Fe(e){let t=[];for(let n of e){let e=Pe(n);e&&t.push(e)}return t}function Ie(e){for(let t of e){let e=X(t);if(e)return e}return null}function Le(e){for(let t of e){let e=Z(t);if(e)return e}return null}const Re=[Y.DelegatedForUserDecryption,Y.RevokedDelegationForUserDecryption];function Q(e,t){return e.toLowerCase()===t.toLowerCase()}function $(e,t,n){let r=t!==void 0&&Q(e,t),i=n!==void 0&&Q(e,n);return r&&i?`self`:r?`outgoing`:`incoming`}function ze(e,t,n){switch(e.eventName){case`ConfidentialTransfer`:return Be(e,t,n);case`Wrapped`:return Ve(e,t,n);case`UnwrapRequested`:return He(e,t,n);case`UnwrappedStarted`:return Ue(e,t,n);case`UnwrappedFinalized`:return We(e,t,n);default:throw Error(`Unknown event: ${e.eventName}`)}}function Be(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 Ve(e,t,n){return{type:`shield`,direction:$(t,void 0,e.to),amount:{type:`clear`,value:e.amountIn},to:e.to,metadata:n,rawEvent:e}}function He(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 Ue(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 We(e,t,n){return{type:`unshield_finalized`,direction:$(t,void 0,e.receiver),amount:{type:`clear`,value:e.cleartextAmount},to:e.receiver,metadata:n,rawEvent:e}}function Ge(e,t){let n=[];for(let r of e){let e=J(r);if(!e)continue;let i={transactionHash:r.transactionHash,blockNumber:r.blockNumber,logIndex:r.logIndex};n.push(ze(e,t,i))}return n}function Ke(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 qe(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:(x(n,`applyDecryptedValues: value`),{...e,amount:{type:`encrypted`,handle:e.amount.handle,decryptedValue:n}})})}function Je(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,`$`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`A`,{enumerable:!0,get:function(){return _e}}),Object.defineProperty(exports,`B`,{enumerable:!0,get:function(){return ce}}),Object.defineProperty(exports,`C`,{enumerable:!0,get:function(){return Me}}),Object.defineProperty(exports,`D`,{enumerable:!0,get:function(){return L}}),Object.defineProperty(exports,`E`,{enumerable:!0,get:function(){return R}}),Object.defineProperty(exports,`F`,{enumerable:!0,get:function(){return ge}}),Object.defineProperty(exports,`G`,{enumerable:!0,get:function(){return C}}),Object.defineProperty(exports,`H`,{enumerable:!0,get:function(){return oe}}),Object.defineProperty(exports,`I`,{enumerable:!0,get:function(){return me}}),Object.defineProperty(exports,`J`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`K`,{enumerable:!0,get:function(){return ie}}),Object.defineProperty(exports,`L`,{enumerable:!0,get:function(){return de}}),Object.defineProperty(exports,`M`,{enumerable:!0,get:function(){return E}}),Object.defineProperty(exports,`N`,{enumerable:!0,get:function(){return pe}}),Object.defineProperty(exports,`O`,{enumerable:!0,get:function(){return k}}),Object.defineProperty(exports,`P`,{enumerable:!0,get:function(){return he}}),Object.defineProperty(exports,`Q`,{enumerable:!0,get:function(){return u}}),Object.defineProperty(exports,`R`,{enumerable:!0,get:function(){return fe}}),Object.defineProperty(exports,`S`,{enumerable:!0,get:function(){return je}}),Object.defineProperty(exports,`T`,{enumerable:!0,get:function(){return`0x0000000000000000000000000000000000000000000000000000000000000000`}}),Object.defineProperty(exports,`U`,{enumerable:!0,get:function(){return se}}),Object.defineProperty(exports,`V`,{enumerable:!0,get:function(){return le}}),Object.defineProperty(exports,`W`,{enumerable:!0,get:function(){return ae}}),Object.defineProperty(exports,`X`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`Y`,{enumerable:!0,get:function(){return re}}),Object.defineProperty(exports,`Z`,{enumerable:!0,get:function(){return h}}),Object.defineProperty(exports,`_`,{enumerable:!0,get:function(){return Oe}}),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return Re}}),Object.defineProperty(exports,`at`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`b`,{enumerable:!0,get:function(){return Ie}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return B}}),Object.defineProperty(exports,`ct`,{enumerable:!0,get:function(){return c}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return De}}),Object.defineProperty(exports,`et`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return X}}),Object.defineProperty(exports,`g`,{enumerable:!0,get:function(){return q}}),Object.defineProperty(exports,`h`,{enumerable:!0,get:function(){return Z}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return Je}}),Object.defineProperty(exports,`it`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`j`,{enumerable:!0,get:function(){return D}}),Object.defineProperty(exports,`k`,{enumerable:!0,get:function(){return O}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return Pe}}),Object.defineProperty(exports,`lt`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return Ae}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return Ke}}),Object.defineProperty(exports,`nt`,{enumerable:!0,get:function(){return p}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return Y}}),Object.defineProperty(exports,`ot`,{enumerable:!0,get:function(){return s}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return J}}),Object.defineProperty(exports,`q`,{enumerable:!0,get:function(){return ee}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return Ge}}),Object.defineProperty(exports,`rt`,{enumerable:!0,get:function(){return d}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return Ne}}),Object.defineProperty(exports,`st`,{enumerable:!0,get:function(){return o}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return qe}}),Object.defineProperty(exports,`tt`,{enumerable:!0,get:function(){return f}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return Fe}}),Object.defineProperty(exports,`ut`,{enumerable:!0,get:function(){return r}}),Object.defineProperty(exports,`v`,{enumerable:!0,get:function(){return ke}}),Object.defineProperty(exports,`w`,{enumerable:!0,get:function(){return Ce}}),Object.defineProperty(exports,`x`,{enumerable:!0,get:function(){return Le}}),Object.defineProperty(exports,`y`,{enumerable:!0,get:function(){return K}}),Object.defineProperty(exports,`z`,{enumerable:!0,get:function(){return ue}});
|
|
1
|
+
const e=require(`./relayer.cjs`),t=require(`./wrappers-registry.cjs`);let n=require(`viem`);var r=class extends e.a{constructor(t,n){super(e.o.SigningRejected,t,n),this.name=`SigningRejectedError`}},i=class extends e.a{constructor(t,n){super(e.o.SigningFailed,t,n),this.name=`SigningFailedError`}};function a(e,t){let n=typeof e==`object`&&!!e&&`code`in e&&e.code===4001,a=e instanceof Error?e.message:String(e),o=a.toLowerCase(),s=o.includes(`user rejected`)||o.includes(`user denied`),c=`${t}: ${a}`;throw n||s?new r(c,{cause:e}):new i(c,{cause:e})}var o=class extends e.a{constructor(t,n){super(e.o.KeypairExpired,t,n),this.name=`KeypairExpiredError`}},s=class extends e.a{constructor(t,n){super(e.o.InvalidKeypair,t,n),this.name=`InvalidKeypairError`}},c=class extends e.a{constructor(t,n){super(e.o.NoCiphertext,t,n),this.name=`NoCiphertextError`}},l=class extends e.a{constructor(t,n){super(e.o.DelegationSelfNotAllowed,t,n),this.name=`DelegationSelfNotAllowedError`}},u=class extends e.a{constructor(t,n){super(e.o.DelegationCooldown,t,n),this.name=`DelegationCooldownError`}},d=class extends e.a{constructor(t,n){super(e.o.DelegationNotFound,t,n),this.name=`DelegationNotFoundError`}},f=class extends e.a{constructor(t,n){super(e.o.DelegationExpired,t,n),this.name=`DelegationExpiredError`}},p=class extends e.a{constructor(t,n){super(e.o.DelegationExpiryUnchanged,t,n),this.name=`DelegationExpiryUnchangedError`}},m=class extends e.a{constructor(t,n){super(e.o.DelegationDelegateEqualsContract,t,n),this.name=`DelegationDelegateEqualsContractError`}},h=class extends e.a{constructor(t,n){super(e.o.DelegationContractIsSelf,t,n),this.name=`DelegationContractIsSelfError`}},g=class extends e.a{constructor(t,n){super(e.o.AclPaused,t,n),this.name=`AclPausedError`}},_=class extends e.a{constructor(t,n){super(e.o.DelegationExpirationTooSoon,t,n),this.name=`DelegationExpirationTooSoonError`}},v=class extends e.a{constructor(t,n){super(e.o.DelegationNotPropagated,t,n),this.name=`DelegationNotPropagatedError`}};function y(t,n,a=!1){if(t instanceof e.r||t instanceof c||t instanceof e.n||t instanceof v||t instanceof r||t instanceof i)return t;let o=typeof t==`object`&&t&&`statusCode`in t&&typeof t.statusCode==`number`?t.statusCode:void 0;return o===400?new c(t instanceof Error?t.message:`No ciphertext for this account`,{cause:t}):a&&o===500?new v(`Delegated decryption failed with a server error. This is most commonly caused by the delegation not having propagated to the gateway yet — after granting delegation, allow 1–2 minutes for cross-chain synchronization before retrying. If the error persists, the gateway or relayer may be experiencing an unrelated issue.`,{cause:t}):o===void 0?new e.r(n,{cause:t}):new e.n(t instanceof Error?t.message:n,o,{cause:t})}function ee(e,t){if(e==null)throw TypeError(`${t} must not be null or undefined`)}function b(e,t){if(typeof e!=`object`||!e||Array.isArray(e))throw TypeError(`${t} must be an object, got ${typeof e}`)}function x(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 te(e,t){if(typeof e!=`function`)throw TypeError(`${t} must be a function, got ${typeof e}`)}function C(e,t){if(typeof e!=`bigint`)throw TypeError(`${t} must be a bigint, got ${typeof e}`)}function ne(e,t,n){x(e[t],n)}function re(e,t,n){te(e[t],n)}function w(e,t){if(!e)throw TypeError(t)}function T(e){return e instanceof Error?e:typeof e==`object`&&e&&`message`in e?Error(String(e.message)):Error(String(e))}function ie(e){if(!(e instanceof Error))return!1;if(e.name===`ContractFunctionExecutionError`||e.name===`ContractFunctionRevertedError`||`code`in e&&e.code===`CALL_EXCEPTION`)return!0;let t=e.message.toLowerCase();return t.includes(`execution reverted`)||t.includes(`call revert exception`)}function E(e){return e.startsWith(`0x`)?e:`0x${e}`}function D(e){return{address:e,abi:n.erc20Abi,functionName:`name`,args:[]}}function ae(e){return{address:e,abi:n.erc20Abi,functionName:`symbol`,args:[]}}function oe(e){return{address:e,abi:n.erc20Abi,functionName:`decimals`,args:[]}}function se(e){return{address:e,abi:n.erc20Abi,functionName:`totalSupply`,args:[]}}function ce(e,t){return{address:e,abi:n.erc20Abi,functionName:`balanceOf`,args:[t]}}function le(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`allowance`,args:[t,r]}}function ue(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`approve`,args:[t,r]}}const O=[{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`},{inputs:[{internalType:`address`,name:`delegator`,type:`address`},{internalType:`address`,name:`delegate`,type:`address`},{internalType:`address`,name:`contractAddress`,type:`address`},{internalType:`bytes32`,name:`handle`,type:`bytes32`}],name:`isHandleDelegatedForUserDecryption`,outputs:[{internalType:`bool`,name:``,type:`bool`}],stateMutability:`view`,type:`function`}];function de(e,t,n,r){return{address:e,abi:O,functionName:`delegateForUserDecryption`,args:[t,n,r]}}function fe(e,t,n){return{address:e,abi:O,functionName:`revokeDelegationForUserDecryption`,args:[t,n]}}function pe(e,t,n,r){return{address:e,abi:O,functionName:`getUserDecryptionDelegationExpirationDate`,args:[t,n,r]}}function me(e,t,n,r,i){return{address:e,abi:O,functionName:`isHandleDelegatedForUserDecryption`,args:[t,n,r,i]}}const k=2n**64n-1n;var A=class{#e;#t=`zama:decrypt`;#n=`${this.#t}:keys`;#r=Promise.resolve();constructor(e){this.#e=e}async get(e,t,n){try{let r=this.#o(e,t,n);return await this.#e.get(r)}catch(e){return console.warn(`[zama-sdk] DecryptCache.get failed:`,e),null}}async set(e,t,n,r){try{let i=this.#o(e,t,n);await this.#e.set(i,r),this.#r=this.#r.then(()=>this.#c(i).catch(e=>{console.warn(`[zama-sdk] DecryptCache index write failed:`,e)})),await this.#r}catch(e){console.warn(`[zama-sdk] DecryptCache.set failed:`,e)}}async clearForRequester(e){this.#r=this.#r.then(()=>this.#i(e).catch(e=>{console.warn(`[zama-sdk] DecryptCache.clearForRequester failed:`,e)})),await this.#r}async#i(e){let t=(0,n.getAddress)(e),r=`${this.#t}:${t}:`,i=await this.#s(),a=[],o=[];for(let e of i)e.startsWith(r)?a.push(e):o.push(e);await Promise.all(a.map(e=>this.#e.delete(e).catch(()=>{}))),await this.#e.set(this.#n,o)}async clearAll(){this.#r=this.#r.then(()=>this.#a().catch(e=>{console.warn(`[zama-sdk] DecryptCache.clearAll failed:`,e)})),await this.#r}async#a(){let e=await this.#s();await Promise.all(e.map(e=>this.#e.delete(e).catch(()=>{}))),await this.#e.delete(this.#n)}#o(e,t,r){return`${this.#t}:${(0,n.getAddress)(e)}:${(0,n.getAddress)(t)}:${r.toLowerCase()}`}async#s(){return await this.#e.get(this.#n)??[]}async#c(e){let t=await this.#s();t.includes(e)||(t.push(e),await this.#e.set(this.#n,t))}},j=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 he=new j,M={CredentialsLoading:`credentials:loading`,CredentialsCached:`credentials:cached`,CredentialsExpired:`credentials:expired`,CredentialsCreating:`credentials:creating`,CredentialsCreated:`credentials:created`,CredentialsRevoked:`credentials:revoked`,CredentialsPersistFailed:`credentials:persist_failed`,CredentialsAllowed:`credentials:allowed`,CredentialsCorrupted:`credentials:corrupted`,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 ge=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),i=Uint8Array.from(atob(e.iv),e=>e.charCodeAt(0)),a=Uint8Array.from(atob(e.ciphertext),e=>e.charCodeAt(0)),o=await crypto.subtle.decrypt({name:`AES-GCM`,iv:i},r,a);return E(new TextDecoder().decode(o))}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 N(e){b(e,`Stored credentials`),x(e.publicKey,`credentials.publicKey`),S(e.contractAddresses,`credentials.contractAddresses`);for(let t of e.contractAddresses)w(typeof t==`string`&&(0,n.isAddress)(t,{strict:!1}),`Expected each contractAddress to be a valid hex address`);b(e.encryptedPrivateKey,`credentials.encryptedPrivateKey`),x(e.encryptedPrivateKey.iv,`encryptedPrivateKey.iv`),x(e.encryptedPrivateKey.ciphertext,`encryptedPrivateKey.ciphertext`),w(typeof e.startTimestamp==`number`,`Expected credentials.startTimestamp to be a number`),w(typeof e.durationDays==`number`,`Expected credentials.durationDays to be a number`)}function _e(e){N(e);let t=e;w(typeof t.delegatorAddress==`string`&&(0,n.isAddress)(t.delegatorAddress,{strict:!1}),`Expected credentials.delegatorAddress to be a valid address`),w(typeof t.delegateAddress==`string`&&(0,n.isAddress)(t.delegateAddress,{strict:!1}),`Expected credentials.delegateAddress to be a valid address`),w(typeof t.startTimestamp==`number`,`Expected startTimestamp to be a number`),w(typeof t.durationDays==`number`,`Expected durationDays to be a number`)}function P(e){return Math.floor(Date.now()/1e3)<e.startTimestamp+e.durationDays*86400}function F(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 I(e,t){return P(e)?F(e.contractAddresses,t):!1}function L(e){return[...new Set(e.map(e=>(0,n.getAddress)(e)))].toSorted()}async function R(...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 ve=class{#e;constructor(e){this.#e=e}#t(e){b(e,`Session entry`),x(e.signature,`session.signature`),w(typeof e.createdAt==`number`,`Expected session.createdAt to be a number`),w(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}},z=class{signer;storage;sessionSignatures;crypto;keypairTTL;sessionTTL;#e;#t=null;#n=null;#r=null;#i=null;constructor(e){if(this.signer=e.signer,this.storage=e.storage,this.sessionSignatures=new ve(e.sessionStorage),this.crypto=new ge,this.keypairTTL=e.keypairTTL??2592e3,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`);typeof this.sessionTTL==`number`&&this.sessionTTL>this.keypairTTL&&(this.sessionTTL=this.keypairTTL,console.warn(`[zama-sdk] sessionTTL was clamped to keypairTTL (${this.keypairTTL}s). A session that outlives the keypair causes isAllowed() to return true after the keypair expires, leading to unexpected wallet prompts.`))}emit(e){this.#e({...e,timestamp:Date.now()})}async resolveCredentials({key:t,contracts:n,createKey:r,createFn:i}){this.emit({type:M.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:M.SessionExpired,reason:`ttl`});else{let i=await this.decryptCredentials(e,r.signature);if(I(i,n))return this.emit({type:M.CredentialsCached,contractAddresses:n}),this.emit({type:M.CredentialsAllowed,contractAddresses:n}),i;if(P(i))return this.#a({key:t,credentials:i,requiredContracts:n});this.emit({type:M.CredentialsExpired,contractAddresses:n})}if(P(e)){if(F(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:M.CredentialsCached,contractAddresses:n}),this.emit({type:M.CredentialsAllowed,contractAddresses:n}),i}let r=await this.signForContracts(e,e.contractAddresses),i=await this.decryptCredentials(e,r);return this.#a({key:t,credentials:i,requiredContracts:n})}this.emit({type:M.CredentialsExpired,contractAddresses:n})}}catch(n){if(n instanceof e.a)throw n;console.warn(`[zama-sdk] Credential resolution failed, recreating:`,n),this.emit({type:M.CredentialsCorrupted,error:T(n)}),await this.#s(t)}return(!this.#t||this.#n!==r)&&(this.#n=r,this.#t=i().then(e=>(this.emit({type:M.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),!I(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:M.CredentialsRevoked,...t?{contractAddresses:t}:{}})}async checkAllowed(e,t){if(t.length===0)return!1;let n=await this.sessionSignatures.get(e);if(n===null||this.sessionSignatures.isExpired(n))return!1;try{let n=await this.storage.get(e);return n?(this.assertEncrypted(n),I(n,t)):!1}catch{return!1}}async clearAll(e){await this.sessionSignatures.delete(e),this.clearCaches(),await this.#s(e)}clearCaches(){this.crypto.clearCache(),this.#i=null}async createCredentials({key:t,contractAddresses:n,createFn:r,errorContext:i}){this.emit({type:M.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:M.CredentialsCreated,contractAddresses:n}),e}catch(t){if(t instanceof e.a)throw t;return a(t,i)}}async#a({key:e,credentials:t,requiredContracts:n}){if(this.#r){let e=await this.#r;if(F(e.contractAddresses,n))return this.emit({type:M.CredentialsAllowed,contractAddresses:n}),e;t=e}else if(this.#i){let e=this.#i;if(F(e.contractAddresses,n))return this.emit({type:M.CredentialsAllowed,contractAddresses:n}),e;t=e}let r=this.#o({key:e,credentials:t,requiredContracts:n});this.#r=r;try{let e=await r;return this.#i=e,e}finally{this.#r===r&&(this.#r=null)}}async#o({key:e,credentials:t,requiredContracts:n}){let r=L([...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:M.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),this.emit({type:M.CredentialsPersistFailed,error:T(e)})}}async#s(e){try{await this.storage.delete(e)}catch(e){console.warn(`[zama-sdk] Failed to delete credentials:`,e),this.emit({type:M.CredentialsPersistFailed,error:T(e)})}}};function ye(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 B=class e extends z{#e;#t=null;#n=null;static async computeStoreKey(e,t){return R((0,n.getAddress)(e),t)}constructor(e){super(e),this.#e=e.relayer,ye(typeof globalThis<`u`?Reflect.get(globalThis,`chrome`):void 0)&&e.sessionStorage instanceof j&&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=L(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 revokeByKey(e){await this.revokeSession(e)}async isAllowed(e){return this.checkAllowed(await this.#r(),e)}async clear(){await this.clearAll(await this.#r())}async create(e){let t=L(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){N(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}},be=class e extends z{#e;#t=null;#n=null;static async computeStoreKey(e,t,r){return R((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=L(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,t){return this.checkAllowed(await this.#i((0,n.getAddress)(e)),t)}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){_e(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)}})}};function xe(e){if(!Se(e))return!1;let t=e.constructor;if(t===void 0)return!0;let n=t.prototype;return!(!Se(n)||!n.hasOwnProperty(`isPrototypeOf`))}function Se(e){return Object.prototype.toString.call(e)===`[object Object]`}function Ce(e){let{gcTime:t,staleTime:n,enabled:r,select:i,refetchInterval:a,refetchOnMount:o,refetchOnWindowFocus:s,refetchOnReconnect:c,retry:l,retryDelay:u,retryOnMount:d,queryFn:f,queryKey:p,queryKeyHashFn:m,initialData:h,initialDataUpdatedAt:g,placeholderData:_,structuralSharing:v,throwOnError:y,meta:ee,query:b,pollingInterval:x,...S}=e;return S}function we(e){return JSON.stringify(e,(e,t)=>xe(t)?Object.keys(t).toSorted().reduce((e,n)=>(e[n]=t[n],e),{}):typeof t==`bigint`?t.toString():t)}async function Te(e,t=1/0){if(Number.isFinite(t)&&t<=0)throw Error(`maxConcurrency must be a positive number`);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++;e[t]&&(n[t]=await e[t]())}}return await Promise.all(Array.from({length:t},i)),n}var Ee=class r{credentials;delegatedCredentials;relayer;signer;address;storage;cache;#e;constructor(e){let t={relayer:e.relayer,signer:e.signer,storage:e.storage,sessionStorage:e.sessionStorage,keypairTTL:e.keypairTTL??2592e3,sessionTTL:e.sessionTTL??2592e3,onEvent:e.onEvent};this.credentials=e.credentials??new B(t),this.delegatedCredentials=e.delegatedCredentials??new be(t),this.relayer=e.relayer,this.signer=e.signer,this.address=(0,n.getAddress)(e.address),this.storage=e.storage,this.cache=e.cache??new A(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.f(this.address,t.c))}async isWrapper(){return await this.signer.readContract(t.f(this.address,t.l))}static async batchDecryptBalances(e,t){if(e.length===0)return new Map;let{handles:n,owner:i,onError:a,maxConcurrency:o}=t??{},s=e[0],c=r.assertSameRelayer(e),l=i??await s.signer.getAddress();return r.#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:i,owner:a,onError:o,maxConcurrency:s}=t,c=a??n,l=e[0];return r.assertSameRelayer(e),r.#t({tokens:e,handles:i,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:r,ownerAddress:i,onError:a,maxConcurrency:o,obtainCreds:s,decrypt:c,errorPrefix:l}=t,u=n[0],d=r??await Promise.all(n.map(e=>e.readConfidentialBalanceOf(i)));if(n.length!==d.length)throw new e.r(`tokens.length (${n.length}) must equal handles.length (${d.length})`);let f=new Map,p=[],m=await Promise.all(n.map((e,t)=>{let n=d[t];return e.isZeroHandle(n)?0n:u.cache.get(i,e.address,n)}));for(let e=0;e<n.length;e++){let t=n[e],r=d[e],i=m[e];if(i!=null){C(i,`batchDecryptCore: cached`),f.set(t.address,i);continue}p.push({token:t,handle:r})}if(p.length===0)return f;t.preFlightCheck&&await t.preFlightCheck();let h=await s(p.map(e=>e.token.address)),g=[],_=[];for(let{token:t,handle:n}of p)_.push(()=>c(h,n,t.address).then(async r=>{let a=r[n];if(a===void 0)throw new e.r(`${l} returned no value for handle ${n} on token ${t.address}`);C(a,`batchDecryptCore: result[handle]`),f.set(t.address,a),u.cache.set(i,t.address,n,a)}).catch(e=>{let n=T(e);if(a)try{f.set(t.address,a(n,t.address))}catch(e){g.push({address:t.address,error:T(e)})}else g.push({address:t.address,error:n})}));if(await Te(_,o),g.length>0){let t=g.map(e=>`${e.address}: ${e.error.message}`).join(`; `);throw new e.r(`${l} failed for ${g.length} token(s): ${t}`)}return f}async underlyingToken(){return this.signer.readContract(t.m(this.address))}async allowance(e,r){let i=(0,n.getAddress)(e),a=await this.signer.readContract(t.m(i)),o=r?(0,n.getAddress)(r):await this.signer.getAddress();return this.signer.readContract(le(a,o,i))}async name(){return this.signer.readContract(D(this.address))}async symbol(){return this.signer.readContract(ae(this.address))}async decimals(){return this.signer.readContract(oe(this.address))}async allow(){await this.credentials.allow(this.address)}async isAllowed(){return this.credentials.isAllowed([this.address])}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===k?!0:t>await this.signer.getBlockTimestamp()}async getDelegationExpiry({delegatorAddress:e,delegateAddress:t}){let r=await this.getAclAddress();return this.signer.readContract(pe(r,(0,n.getAddress)(e),(0,n.getAddress)(t),this.address))}async#n(e){let t=await this.signer.getAddress(),n=await this.getDelegationExpiry({delegatorAddress:e,delegateAddress:t});if(n===0n)throw new d(`No active delegation from ${e} to ${t} for ${this.address}`);if(n!==k&&n<=await this.signer.getBlockTimestamp())throw new f(`Delegation from ${e} to ${t} for ${this.address} has expired`)}async readConfidentialBalanceOf(e){return await this.signer.readContract(t.g(this.address,e))}isZeroHandle(e){return e===`0x0000000000000000000000000000000000000000000000000000000000000000`||e===`0x`}async decryptBalanceAs({delegatorAddress:t,owner:r}){let i=(0,n.getAddress)(t),a=r?(0,n.getAddress)(r):i,o=await this.readConfidentialBalanceOf(a);if(this.isZeroHandle(o))return 0n;let s=await this.cache.get(a,this.address,o);if(s!==null)return C(s,`decryptBalanceAs: cached`),s;await this.#n(i);let c=Date.now();try{this.emit({type:M.DecryptStart,handles:[o]});let t=await this.delegatedCredentials.allow(i,this.address),n=await this.relayer.delegatedUserDecrypt({handles:[o],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:M.DecryptEnd,durationMs:Date.now()-c,handles:[o],result:n});let r=n[o];if(r===void 0)throw new e.r(`Delegated decryption returned no value for handle ${o}`);return C(r,`decryptBalanceAs: result[handle]`),await this.cache.set(a,this.address,o,r),r}catch(e){throw this.emit({type:M.DecryptError,error:T(e),durationMs:Date.now()-c,handles:[o]}),y(e,`Failed to decrypt delegated balance`,!0)}}async decryptBalance(t,n){if(this.isZeroHandle(t))return 0n;let r=n??await this.signer.getAddress(),i=await this.cache.get(r,this.address,t);if(i!==null)return C(i,`decryptBalance: cached`),i;let a=await this.credentials.allow(this.address),o=Date.now();try{this.emit({type:M.DecryptStart,handles:[t]});let n=await this.relayer.userDecrypt({handles:[t],contractAddress:this.address,signedContractAddresses:a.contractAddresses,privateKey:a.privateKey,publicKey:a.publicKey,signature:a.signature,signerAddress:r,startTimestamp:a.startTimestamp,durationDays:a.durationDays});this.emit({type:M.DecryptEnd,durationMs:Date.now()-o,handles:[t],result:n});let i=n[t];if(i===void 0)throw new e.r(`Decryption returned no value for handle ${t}`);return C(i,`decryptBalance: result[handle]`),await this.cache.set(r,this.address,t,i),i}catch(e){throw this.emit({type:M.DecryptError,error:T(e),durationMs:Date.now()-o,handles:[t]}),y(e,`Failed to decrypt balance`)}}async decryptHandles(t,n){let r=new Map,i=[];for(let e of t)this.isZeroHandle(e)?r.set(e,0n):i.push(e);if(i.length===0)return r;let a=await this.credentials.allow(this.address),o=Date.now();try{this.emit({type:M.DecryptStart,handles:i});let t=await this.relayer.userDecrypt({handles:i,contractAddress:this.address,signedContractAddresses:a.contractAddresses,privateKey:a.privateKey,publicKey:a.publicKey,signature:a.signature,signerAddress:n??await this.signer.getAddress(),startTimestamp:a.startTimestamp,durationDays:a.durationDays});this.emit({type:M.DecryptEnd,durationMs:Date.now()-o,handles:i,result:t});for(let n of i){let i=t[n];if(i===void 0)throw new e.r(`Decryption returned no value for handle ${n}`);r.set(n,i)}}catch(e){throw this.emit({type:M.DecryptError,error:T(e),durationMs:Date.now()-o,handles:i}),y(e,`Failed to decrypt handles`)}return r}static assertSameRelayer(t){let n=t[0].relayer;for(let r=1;r<t.length;r++)if(t[r].relayer!==n)throw new e.t(`All tokens in a batch operation must share the same relayer instance`);return n}};const V={ConfidentialTransfer:`0x67500e8d0ed826d2194f514dd0d8124f35648ab6e3fb5e6ed867134cffe661e9`,Wrapped:`0x4700c1726b4198077cd40320a32c45265a1910521eb0ef713dd1d8412413d7fc`,UnwrapRequested:`0x77d02d353c5629272875d11f1b34ec4c65d7430b075575b78cd2502034c469ee`,UnwrappedFinalized:`0x2d4edf3c2943002120f53dab3f8940043f34799f4a92ab90f2f81f7dd004a49e`,UnwrappedStarted:`0x3838891d4843c6d7f9f494570b6fd8843f4e3c3ddb817c1411760bd31b819806`};function H(e){return(0,n.getAddress)(E(e.slice(-40)))}function De(e){return BigInt(e)}function Oe(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 W(e,t){return(0,n.getAddress)(E(U(e,t).slice(-40)))}function G(e,t){return BigInt(`0x`+U(e,t))}function ke(e,t){return BigInt(`0x`+U(e,t))!==0n}function K(e,t){return E(U(e,t))}function Ae(e){return e.topics[0]!==V.ConfidentialTransfer||e.topics.length<4?null:{eventName:`ConfidentialTransfer`,from:H(e.topics[1]),to:H(e.topics[2]),encryptedAmountHandle:Oe(e.topics[3])}}function q(e){return e.topics[0]!==V.Wrapped||e.topics.length<2?null:{eventName:`Wrapped`,to:H(e.topics[1]),amountIn:G(e.data,0)}}function J(e){return e.topics[0]!==V.UnwrapRequested||e.topics.length<2?null:{eventName:`UnwrapRequested`,receiver:H(e.topics[1]),encryptedAmount:K(e.data,0)}}function je(e){return e.topics[0]!==V.UnwrappedFinalized||e.topics.length<2?null:{eventName:`UnwrappedFinalized`,receiver:H(e.topics[1]),encryptedAmount:K(e.data,0),cleartextAmount:G(e.data,1)}}function Me(e){return e.topics[0]!==V.UnwrappedStarted||e.topics.length<4?null:{eventName:`UnwrappedStarted`,requestId:De(e.topics[1]),txId:De(e.topics[2]),to:H(e.topics[3]),returnVal:ke(e.data,0),refund:W(e.data,1),requestedAmount:K(e.data,2),burnAmount:K(e.data,3)}}function Y(e){return Ae(e)??q(e)??J(e)??je(e)??Me(e)}function Ne(e){let t=[];for(let n of e){let e=Y(n);e&&t.push(e)}return t}function Pe(e){for(let t of e){let e=J(t);if(e)return e}return null}function Fe(e){for(let t of e){let e=q(t);if(e)return e}return null}const Ie=[V.ConfidentialTransfer,V.Wrapped,V.UnwrapRequested,V.UnwrappedFinalized,V.UnwrappedStarted],X={DelegatedForUserDecryption:`0x527b025d7ff06689c1ab9d32dfd7881c964cce72ce8ac5b2fe1d3be8cfda5bfc`,RevokedDelegationForUserDecryption:`0x7aca80b6b7928b9038f186e3d9922a0fc5d52c398fbf144725c142c52a5277e4`};function Z(e){return e.topics[0]!==X.DelegatedForUserDecryption||e.topics.length<3?null:{eventName:`DelegatedForUserDecryption`,delegator:H(e.topics[1]),delegate:H(e.topics[2]),contractAddress:W(e.data,0),delegationCounter:G(e.data,1),oldExpirationDate:G(e.data,2),newExpirationDate:G(e.data,3)}}function Q(e){return e.topics[0]!==X.RevokedDelegationForUserDecryption||e.topics.length<3?null:{eventName:`RevokedDelegationForUserDecryption`,delegator:H(e.topics[1]),delegate:H(e.topics[2]),contractAddress:W(e.data,0),delegationCounter:G(e.data,1),oldExpirationDate:G(e.data,2)}}function Le(e){return Z(e)??Q(e)}function Re(e){let t=[];for(let n of e){let e=Le(n);e&&t.push(e)}return t}function ze(e){for(let t of e){let e=Z(t);if(e)return e}return null}function Be(e){for(let t of e){let e=Q(t);if(e)return e}return null}const Ve=[X.DelegatedForUserDecryption,X.RevokedDelegationForUserDecryption];function He(e,t){return e.toLowerCase()===t.toLowerCase()}function $(e,t,n){let r=t!==void 0&&He(e,t),i=n!==void 0&&He(e,n);return r&&i?`self`:r?`outgoing`:`incoming`}function Ue(e,t,n){switch(e.eventName){case`ConfidentialTransfer`:return We(e,t,n);case`Wrapped`:return Ge(e,t,n);case`UnwrapRequested`:return Ke(e,t,n);case`UnwrappedStarted`:return qe(e,t,n);case`UnwrappedFinalized`:return Je(e,t,n);default:throw Error(`Unknown event: ${e.eventName}`)}}function We(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 Ge(e,t,n){return{type:`shield`,direction:$(t,void 0,e.to),amount:{type:`clear`,value:e.amountIn},to:e.to,metadata:n,rawEvent:e}}function Ke(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 qe(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 Je(e,t,n){return{type:`unshield_finalized`,direction:$(t,void 0,e.receiver),amount:{type:`clear`,value:e.cleartextAmount},to:e.receiver,metadata:n,rawEvent:e}}function Ye(e,t){let n=[];for(let r of e){let e=Y(r);if(!e)continue;let i={transactionHash:r.transactionHash,blockNumber:r.blockNumber,logIndex:r.logIndex};n.push(Ue(e,t,i))}return n}function Xe(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 Ze(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:(C(n,`applyDecryptedValues: value`),{...e,amount:{type:`encrypted`,handle:e.amount.handle,decryptedValue:n}})})}function Qe(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,`$`,{enumerable:!0,get:function(){return ne}}),Object.defineProperty(exports,`A`,{enumerable:!0,get:function(){return be}}),Object.defineProperty(exports,`B`,{enumerable:!0,get:function(){return fe}}),Object.defineProperty(exports,`C`,{enumerable:!0,get:function(){return Fe}}),Object.defineProperty(exports,`D`,{enumerable:!0,get:function(){return`0x0000000000000000000000000000000000000000000000000000000000000000`}}),Object.defineProperty(exports,`E`,{enumerable:!0,get:function(){return Te}}),Object.defineProperty(exports,`F`,{enumerable:!0,get:function(){return A}}),Object.defineProperty(exports,`G`,{enumerable:!0,get:function(){return se}}),Object.defineProperty(exports,`H`,{enumerable:!0,get:function(){return ue}}),Object.defineProperty(exports,`I`,{enumerable:!0,get:function(){return k}}),Object.defineProperty(exports,`J`,{enumerable:!0,get:function(){return ie}}),Object.defineProperty(exports,`K`,{enumerable:!0,get:function(){return D}}),Object.defineProperty(exports,`L`,{enumerable:!0,get:function(){return de}}),Object.defineProperty(exports,`M`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`N`,{enumerable:!0,get:function(){return j}}),Object.defineProperty(exports,`O`,{enumerable:!0,get:function(){return Ce}}),Object.defineProperty(exports,`P`,{enumerable:!0,get:function(){return he}}),Object.defineProperty(exports,`Q`,{enumerable:!0,get:function(){return b}}),Object.defineProperty(exports,`R`,{enumerable:!0,get:function(){return pe}}),Object.defineProperty(exports,`S`,{enumerable:!0,get:function(){return Pe}}),Object.defineProperty(exports,`T`,{enumerable:!0,get:function(){return`0x0000000000000000000000000000000000000000000000000000000000000000`}}),Object.defineProperty(exports,`U`,{enumerable:!0,get:function(){return ce}}),Object.defineProperty(exports,`V`,{enumerable:!0,get:function(){return le}}),Object.defineProperty(exports,`W`,{enumerable:!0,get:function(){return oe}}),Object.defineProperty(exports,`X`,{enumerable:!0,get:function(){return re}}),Object.defineProperty(exports,`Y`,{enumerable:!0,get:function(){return T}}),Object.defineProperty(exports,`Z`,{enumerable:!0,get:function(){return ee}}),Object.defineProperty(exports,`_`,{enumerable:!0,get:function(){return je}}),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return Ve}}),Object.defineProperty(exports,`at`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`b`,{enumerable:!0,get:function(){return ze}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return V}}),Object.defineProperty(exports,`ct`,{enumerable:!0,get:function(){return d}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return Ae}}),Object.defineProperty(exports,`dt`,{enumerable:!0,get:function(){return s}}),Object.defineProperty(exports,`et`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return Z}}),Object.defineProperty(exports,`ft`,{enumerable:!0,get:function(){return o}}),Object.defineProperty(exports,`g`,{enumerable:!0,get:function(){return J}}),Object.defineProperty(exports,`h`,{enumerable:!0,get:function(){return Q}}),Object.defineProperty(exports,`ht`,{enumerable:!0,get:function(){return r}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return Qe}}),Object.defineProperty(exports,`it`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`j`,{enumerable:!0,get:function(){return B}}),Object.defineProperty(exports,`k`,{enumerable:!0,get:function(){return we}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return Le}}),Object.defineProperty(exports,`lt`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return Ne}}),Object.defineProperty(exports,`mt`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return Xe}}),Object.defineProperty(exports,`nt`,{enumerable:!0,get:function(){return h}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return X}}),Object.defineProperty(exports,`ot`,{enumerable:!0,get:function(){return f}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return Y}}),Object.defineProperty(exports,`pt`,{enumerable:!0,get:function(){return c}}),Object.defineProperty(exports,`q`,{enumerable:!0,get:function(){return ae}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return Ye}}),Object.defineProperty(exports,`rt`,{enumerable:!0,get:function(){return u}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return Ie}}),Object.defineProperty(exports,`st`,{enumerable:!0,get:function(){return p}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return Ze}}),Object.defineProperty(exports,`tt`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return Re}}),Object.defineProperty(exports,`ut`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`v`,{enumerable:!0,get:function(){return Me}}),Object.defineProperty(exports,`w`,{enumerable:!0,get:function(){return Ee}}),Object.defineProperty(exports,`x`,{enumerable:!0,get:function(){return Be}}),Object.defineProperty(exports,`y`,{enumerable:!0,get:function(){return q}}),Object.defineProperty(exports,`z`,{enumerable:!0,get:function(){return me}});
|
|
2
2
|
//# sourceMappingURL=activity.cjs.map
|