@zama-fhe/sdk 2.3.1-alpha.4 → 2.4.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -39
- package/dist/cjs/activity.cjs +1 -1
- package/dist/cjs/activity.cjs.map +1 -1
- package/dist/cjs/ethers/index.cjs +1 -1
- package/dist/cjs/ethers/index.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/cjs/viem/index.cjs +1 -1
- package/dist/cjs/viem/index.cjs.map +1 -1
- package/dist/cjs/wrappers-registry.cjs +1 -1
- package/dist/cjs/wrappers-registry.cjs.map +1 -1
- package/dist/esm/activity-CZagNo7y.js +2 -0
- package/dist/esm/activity-CZagNo7y.js.map +1 -0
- package/dist/esm/{index-BXdXzzx4.d.ts → activity-DbEbjVUg.d.ts} +2721 -11442
- package/dist/esm/cleartext/index.d.ts +2 -2
- package/dist/esm/cleartext/index.js +1 -1
- package/dist/esm/{cleartext-Bzxet3H7.js → cleartext-Cs28cTsa.js} +1 -1
- package/dist/esm/{cleartext-Bzxet3H7.js.map → cleartext-Cs28cTsa.js.map} +1 -1
- package/dist/esm/{eip1193-subscribe-Cp2QVN0m.js → eip1193-subscribe-Cl_wlVuQ.js} +1 -1
- package/dist/esm/{eip1193-subscribe-Cp2QVN0m.js.map → eip1193-subscribe-Cl_wlVuQ.js.map} +1 -1
- package/dist/esm/ethers/index.d.ts +2 -7
- package/dist/esm/ethers/index.js +1 -1
- package/dist/esm/ethers/index.js.map +1 -1
- package/dist/esm/index.d.ts +5 -6
- package/dist/esm/index.js +2 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/node/index.d.ts +3 -3
- package/dist/esm/query/index.d.ts +4 -60
- package/dist/esm/query/index.js +1 -1
- package/dist/esm/query/index.js.map +1 -1
- package/dist/esm/{relayer-sdk-C_4bkxxH.d.ts → relayer-sdk-DPqytEbO.d.ts} +2 -2
- package/dist/esm/{relayer-sdk.types-C9GAgQ7q.d.ts → relayer-sdk.types-CGfXwKcB.d.ts} +1 -3
- package/dist/esm/{relayer-utils-BcTAyZOr.d.ts → relayer-utils-iSPis4x-.d.ts} +1 -1
- package/dist/esm/viem/index.d.ts +2 -7
- package/dist/esm/viem/index.js +1 -1
- package/dist/esm/viem/index.js.map +1 -1
- package/dist/esm/wrappers-registry-BAz8Adry.js +2 -0
- package/dist/esm/wrappers-registry-BAz8Adry.js.map +1 -0
- package/package.json +1 -1
- package/dist/cjs/transfer-batcher.cjs +0 -2
- package/dist/cjs/transfer-batcher.cjs.map +0 -1
- package/dist/esm/activity-0x2RDRTM.d.ts +0 -2061
- package/dist/esm/activity-b2RsqKHW.js +0 -2
- package/dist/esm/activity-b2RsqKHW.js.map +0 -1
- package/dist/esm/transfer-batcher-BXIo7hnu.js +0 -2
- package/dist/esm/transfer-batcher-BXIo7hnu.js.map +0 -1
- package/dist/esm/wrappers-registry-DqPr_JG2.js +0 -2
- package/dist/esm/wrappers-registry-DqPr_JG2.js.map +0 -1
package/README.md
CHANGED
|
@@ -181,7 +181,6 @@ Full read/write interface for a single confidential ERC-20. Extends `ReadonlyTok
|
|
|
181
181
|
| Method | Description |
|
|
182
182
|
| ---------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
|
183
183
|
| `shield(amount, options?)` | Shield (wrap) public ERC-20 tokens. Handles approval automatically. Options: `{ approvalStrategy: "max" \| "exact" \| "skip" }` (default `"exact"`). `"skip"` bypasses approval (use when already approved). |
|
|
184
|
-
| `shieldETH(amount, value?)` | Shield (wrap) native ETH. `value` defaults to `amount`. Use when the underlying token is the zero address (native ETH). |
|
|
185
184
|
| `unshield(amount, callbacks?)` | Unwrap a specific amount and finalize in one call. Orchestrates: unwrap → wait receipt → parse event → finalizeUnwrap. Optional `UnshieldCallbacks` for progress tracking. |
|
|
186
185
|
| `unshieldAll(callbacks?)` | Unwrap the entire balance and finalize in one call. Orchestrates: unwrapAll → wait receipt → parse event → finalizeUnwrap. Optional `UnshieldCallbacks` for progress tracking. |
|
|
187
186
|
| `unwrap(amount)` | Request unwrap for a specific amount (low-level, requires manual finalization). |
|
|
@@ -539,49 +538,23 @@ interface ContractCallConfig {
|
|
|
539
538
|
| `confidentialTotalSupplyContract(token)` | Read encrypted total supply handle. |
|
|
540
539
|
| `totalSupplyContract(token)` | Read plaintext total supply. |
|
|
541
540
|
| `rateContract(token)` | Read conversion rate. |
|
|
542
|
-
| `deploymentCoordinatorContract(token)` | Read deployment coordinator address. |
|
|
543
|
-
| `isFinalizeUnwrapOperatorContract(token, holder, operator)` | Check finalize-unwrap operator status. |
|
|
544
|
-
| `setFinalizeUnwrapOperatorContract(token, operator, timestamp?)` | Set finalize-unwrap operator. |
|
|
545
541
|
|
|
546
542
|
### Wrapper
|
|
547
543
|
|
|
548
544
|
| Function | Description |
|
|
549
545
|
| ---------------------------------------------------------------- | --------------------------------------------- |
|
|
550
546
|
| `wrapContract(wrapper, to, amount)` | Wrap ERC-20 tokens. |
|
|
551
|
-
| `wrapETHContract(wrapper, to, amount, value)` | Wrap native ETH. |
|
|
552
547
|
| `unwrapContract(token, from, to, encryptedAmount, inputProof)` | Request unwrap with encrypted amount. |
|
|
553
548
|
| `unwrapFromBalanceContract(token, from, to, encryptedBalance)` | Request unwrap using on-chain balance handle. |
|
|
554
549
|
| `finalizeUnwrapContract(wrapper, burntAmount, cleartext, proof)` | Finalize unwrap with decryption proof. |
|
|
555
550
|
| `underlyingContract(wrapper)` | Read underlying ERC-20 address. |
|
|
556
551
|
|
|
557
|
-
### Deployment Coordinator
|
|
558
|
-
|
|
559
|
-
| Function | Description |
|
|
560
|
-
| ------------------------------------------- | ---------------------------- |
|
|
561
|
-
| `getWrapperContract(coordinator, token)` | Look up wrapper for a token. |
|
|
562
|
-
| `wrapperExistsContract(coordinator, token)` | Check if wrapper exists. |
|
|
563
|
-
|
|
564
552
|
### ERC-165
|
|
565
553
|
|
|
566
554
|
| Function | Description |
|
|
567
555
|
| ----------------------------------------------- | ------------------------ |
|
|
568
556
|
| `supportsInterfaceContract(token, interfaceId)` | ERC-165 interface check. |
|
|
569
557
|
|
|
570
|
-
### Fee Manager
|
|
571
|
-
|
|
572
|
-
| Function | Description |
|
|
573
|
-
| ---------------------------------------------------- | -------------------------- |
|
|
574
|
-
| `getWrapFeeContract(feeManager, amount, from, to)` | Calculate wrap fee. |
|
|
575
|
-
| `getUnwrapFeeContract(feeManager, amount, from, to)` | Calculate unwrap fee. |
|
|
576
|
-
| `getBatchTransferFeeContract(feeManager)` | Get batch transfer fee. |
|
|
577
|
-
| `getFeeRecipientContract(feeManager)` | Get fee recipient address. |
|
|
578
|
-
|
|
579
|
-
### Transfer Batcher
|
|
580
|
-
|
|
581
|
-
| Function | Description |
|
|
582
|
-
| -------------------------------------------------------------------------- | ----------------------------------- |
|
|
583
|
-
| `confidentialBatchTransferContract(batcher, token, from, transfers, fees)` | Batch multiple encrypted transfers. |
|
|
584
|
-
|
|
585
558
|
## Library-Specific Contract Helpers
|
|
586
559
|
|
|
587
560
|
Both the `/viem` and `/ethers` sub-paths export convenience wrappers that execute contract calls directly with library-native clients.
|
|
@@ -609,9 +582,9 @@ const txHash = await writeConfidentialTransferContract(
|
|
|
609
582
|
);
|
|
610
583
|
```
|
|
611
584
|
|
|
612
|
-
**Read helpers:** `readConfidentialBalanceOfContract`, `readUnderlyingTokenContract`, `
|
|
585
|
+
**Read helpers:** `readConfidentialBalanceOfContract`, `readUnderlyingTokenContract`, `readSupportsInterfaceContract` (legacy — prefer `sdk.registry.getConfidentialToken()`).
|
|
613
586
|
|
|
614
|
-
**Write helpers:** `writeConfidentialTransferContract`, `
|
|
587
|
+
**Write helpers:** `writeConfidentialTransferContract`, `writeUnwrapContract`, `writeUnwrapFromBalanceContract`, `writeFinalizeUnwrapContract`, `writeSetOperatorContract`, `writeWrapContract`.
|
|
615
588
|
|
|
616
589
|
### ethers (`@zama-fhe/sdk/ethers`)
|
|
617
590
|
|
|
@@ -654,15 +627,15 @@ Individual topic hashes are accessible via the `Topics` object: `Topics.Confiden
|
|
|
654
627
|
|
|
655
628
|
### Decoders
|
|
656
629
|
|
|
657
|
-
| Function | Returns
|
|
658
|
-
| --------------------------------- |
|
|
659
|
-
| `decodeConfidentialTransfer(log)` | `ConfidentialTransferEvent \| null` — `{ from, to, encryptedAmountHandle }`
|
|
660
|
-
| `decodeWrapped(log)` | `WrappedEvent \| null` — `{
|
|
661
|
-
| `decodeUnwrapRequested(log)` | `UnwrapRequestedEvent \| null` — `{ receiver, encryptedAmount }`
|
|
662
|
-
| `decodeUnwrappedFinalized(log)` | `UnwrappedFinalizedEvent \| null` — `{
|
|
663
|
-
| `decodeUnwrappedStarted(log)` | `UnwrappedStartedEvent \| null` — `{ returnVal, requestId, txId, to, refund, requestedAmount, burnAmount }`
|
|
664
|
-
| `decodeOnChainEvent(log)` | `OnChainEvent \| null` — tries all decoders
|
|
665
|
-
| `decodeOnChainEvents(logs)` | `OnChainEvent[]` — batch decode, skips unrecognized logs
|
|
630
|
+
| Function | Returns |
|
|
631
|
+
| --------------------------------- | ----------------------------------------------------------------------------------------------------------- |
|
|
632
|
+
| `decodeConfidentialTransfer(log)` | `ConfidentialTransferEvent \| null` — `{ from, to, encryptedAmountHandle }` |
|
|
633
|
+
| `decodeWrapped(log)` | `WrappedEvent \| null` — `{ to, amountIn }` |
|
|
634
|
+
| `decodeUnwrapRequested(log)` | `UnwrapRequestedEvent \| null` — `{ receiver, encryptedAmount }` |
|
|
635
|
+
| `decodeUnwrappedFinalized(log)` | `UnwrappedFinalizedEvent \| null` — `{ receiver, encryptedAmount, cleartextAmount }` |
|
|
636
|
+
| `decodeUnwrappedStarted(log)` | `UnwrappedStartedEvent \| null` — `{ returnVal, requestId, txId, to, refund, requestedAmount, burnAmount }` |
|
|
637
|
+
| `decodeOnChainEvent(log)` | `OnChainEvent \| null` — tries all decoders |
|
|
638
|
+
| `decodeOnChainEvents(logs)` | `OnChainEvent[]` — batch decode, skips unrecognized logs |
|
|
666
639
|
|
|
667
640
|
### Finder Helpers
|
|
668
641
|
|
|
@@ -855,4 +828,4 @@ Low-level FHE operations are available on the relayer backend via `sdk.relayer`:
|
|
|
855
828
|
|
|
856
829
|
For direct use with viem, ethers, or any ABI-compatible library:
|
|
857
830
|
|
|
858
|
-
`ERC20_ABI`, `ERC20_METADATA_ABI`, `ENCRYPTION_ABI`, `WRAPPER_ABI`, `DEPLOYMENT_COORDINATOR_ABI`, `ERC165_ABI`, `
|
|
831
|
+
`ERC20_ABI`, `ERC20_METADATA_ABI`, `ENCRYPTION_ABI`, `WRAPPER_ABI`, `DEPLOYMENT_COORDINATOR_ABI`, `ERC165_ABI`, `TRANSFER_BATCHER_ABI`, `BATCH_SWAP_ABI`.
|
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`}},ee=class extends e.a{constructor(t,n){super(e.o.DelegationCooldown,t,n),this.name=`DelegationCooldownError`}},u=class extends e.a{constructor(t,n){super(e.o.DelegationNotFound,t,n),this.name=`DelegationNotFoundError`}},d=class extends e.a{constructor(t,n){super(e.o.DelegationExpired,t,n),this.name=`DelegationExpiredError`}},f=class extends e.a{constructor(t,n){super(e.o.DelegationExpiryUnchanged,t,n),this.name=`DelegationExpiryUnchangedError`}},p=class extends e.a{constructor(t,n){super(e.o.DelegationDelegateEqualsContract,t,n),this.name=`DelegationDelegateEqualsContractError`}},m=class extends e.a{constructor(t,n){super(e.o.DelegationContractIsSelf,t,n),this.name=`DelegationContractIsSelfError`}},h=class extends e.a{constructor(t,n){super(e.o.AclPaused,t,n),this.name=`AclPausedError`}},g=class extends e.a{constructor(t,n){super(e.o.DelegationExpirationTooSoon,t,n),this.name=`DelegationExpirationTooSoonError`}},_=class extends e.a{constructor(t,n){super(e.o.DelegationNotPropagated,t,n),this.name=`DelegationNotPropagatedError`}};function te(e,t){if(e==null)throw TypeError(`${t} must not be null or undefined`)}function v(e,t){if(typeof e!=`object`||!e||Array.isArray(e))throw TypeError(`${t} must be an object, got ${typeof e}`)}function y(e,t){if(typeof e!=`string`)throw TypeError(`${t} must be a string, got ${typeof e}`)}function ne(e,t){if(!Array.isArray(e))throw TypeError(`${t} must be an array, got ${typeof e}`)}function re(e,t){if(typeof e!=`function`)throw TypeError(`${t} must be a function, got ${typeof e}`)}function ie(e,t,n){y(e[t],n)}function ae(e,t,n){re(e[t],n)}function b(e,t){if(!e)throw TypeError(t)}function x(e){return e instanceof Error?e:typeof e==`object`&&e&&`message`in e?Error(String(e.message)):Error(String(e))}function oe(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 S(e){return e.startsWith(`0x`)?e:`0x${e}`}function se(e){return{address:e,abi:n.erc20Abi,functionName:`name`,args:[]}}function ce(e){return{address:e,abi:n.erc20Abi,functionName:`symbol`,args:[]}}function le(e){return{address:e,abi:n.erc20Abi,functionName:`decimals`,args:[]}}function ue(e){return{address:e,abi:n.erc20Abi,functionName:`totalSupply`,args:[]}}function de(e,t){return{address:e,abi:n.erc20Abi,functionName:`balanceOf`,args:[t]}}function fe(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`allowance`,args:[t,r]}}function pe(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`approve`,args:[t,r]}}const C=[{inputs:[{internalType:`uint64`,name:`wrapFeeBasisPoints_`,type:`uint64`},{internalType:`uint64`,name:`unwrapFeeBasisPoints_`,type:`uint64`},{internalType:`uint64`,name:`deployFee_`,type:`uint64`},{internalType:`uint64`,name:`batchTransferFee_`,type:`uint64`},{internalType:`address`,name:`feeRecipient_`,type:`address`}],stateMutability:`nonpayable`,type:`constructor`},{inputs:[],name:`AccessControlBadConfirmation`,type:`error`},{inputs:[{internalType:`address`,name:`account`,type:`address`},{internalType:`bytes32`,name:`neededRole`,type:`bytes32`}],name:`AccessControlUnauthorizedAccount`,type:`error`},{inputs:[],name:`FeeExceedsMaximum`,type:`error`},{inputs:[],name:`ZeroAddressFeeRecipient`,type:`error`},{anonymous:!1,inputs:[{indexed:!1,internalType:`uint64`,name:`oldBatchTransferFee`,type:`uint64`},{indexed:!1,internalType:`uint64`,name:`newBatchTransferFee`,type:`uint64`}],name:`BatchTransferFeeUpdated`,type:`event`},{anonymous:!1,inputs:[{indexed:!1,internalType:`uint64`,name:`oldDeployFee`,type:`uint64`},{indexed:!1,internalType:`uint64`,name:`newDeployFee`,type:`uint64`}],name:`DeployFeeUpdated`,type:`event`},{anonymous:!1,inputs:[{indexed:!0,internalType:`address`,name:`oldRecipient`,type:`address`},{indexed:!0,internalType:`address`,name:`newRecipient`,type:`address`}],name:`FeeRecipientUpdated`,type:`event`},{anonymous:!1,inputs:[{indexed:!0,internalType:`bytes32`,name:`role`,type:`bytes32`},{indexed:!0,internalType:`bytes32`,name:`previousAdminRole`,type:`bytes32`},{indexed:!0,internalType:`bytes32`,name:`newAdminRole`,type:`bytes32`}],name:`RoleAdminChanged`,type:`event`},{anonymous:!1,inputs:[{indexed:!0,internalType:`bytes32`,name:`role`,type:`bytes32`},{indexed:!0,internalType:`address`,name:`account`,type:`address`},{indexed:!0,internalType:`address`,name:`sender`,type:`address`}],name:`RoleGranted`,type:`event`},{anonymous:!1,inputs:[{indexed:!0,internalType:`bytes32`,name:`role`,type:`bytes32`},{indexed:!0,internalType:`address`,name:`account`,type:`address`},{indexed:!0,internalType:`address`,name:`sender`,type:`address`}],name:`RoleRevoked`,type:`event`},{anonymous:!1,inputs:[{indexed:!1,internalType:`bool`,name:`active`,type:`bool`}],name:`SwapperFeeWaiverUpdated`,type:`event`},{anonymous:!1,inputs:[{indexed:!1,internalType:`uint64`,name:`oldFeeBasisPoints`,type:`uint64`},{indexed:!1,internalType:`uint64`,name:`newFeeBasisPoints`,type:`uint64`}],name:`UnwrapFeeBasisPointsUpdated`,type:`event`},{anonymous:!1,inputs:[{indexed:!1,internalType:`uint64`,name:`oldFeeBasisPoints`,type:`uint64`},{indexed:!1,internalType:`uint64`,name:`newFeeBasisPoints`,type:`uint64`}],name:`WrapFeeBasisPointsUpdated`,type:`event`},{inputs:[],name:`DEFAULT_ADMIN_ROLE`,outputs:[{internalType:`bytes32`,name:``,type:`bytes32`}],stateMutability:`view`,type:`function`},{inputs:[],name:`FEE_MANAGER_ROLE`,outputs:[{internalType:`bytes32`,name:``,type:`bytes32`}],stateMutability:`view`,type:`function`},{inputs:[],name:`MAX_BASIS_POINTS`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`SWAPPER_ROLE`,outputs:[{internalType:`bytes32`,name:``,type:`bytes32`}],stateMutability:`view`,type:`function`},{inputs:[],name:`batchTransferFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`deployFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`feeRecipient`,outputs:[{internalType:`address`,name:``,type:`address`}],stateMutability:`view`,type:`function`},{inputs:[],name:`getBatchTransferFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[{internalType:`address`,name:`deployer`,type:`address`}],name:`getDeployFee`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`getFeeRecipient`,outputs:[{internalType:`address`,name:``,type:`address`}],stateMutability:`view`,type:`function`},{inputs:[{internalType:`bytes32`,name:`role`,type:`bytes32`}],name:`getRoleAdmin`,outputs:[{internalType:`bytes32`,name:``,type:`bytes32`}],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:[{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:`bytes32`,name:`role`,type:`bytes32`},{internalType:`address`,name:`account`,type:`address`}],name:`grantRole`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`bytes32`,name:`role`,type:`bytes32`},{internalType:`address`,name:`account`,type:`address`}],name:`hasRole`,outputs:[{internalType:`bool`,name:``,type:`bool`}],stateMutability:`view`,type:`function`},{inputs:[],name:`protocolId`,outputs:[{internalType:`uint256`,name:``,type:`uint256`}],stateMutability:`pure`,type:`function`},{inputs:[{internalType:`bytes32`,name:`role`,type:`bytes32`},{internalType:`address`,name:`callerConfirmation`,type:`address`}],name:`renounceRole`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`bytes32`,name:`role`,type:`bytes32`},{internalType:`address`,name:`account`,type:`address`}],name:`revokeRole`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`uint64`,name:`newBatchTransferFee`,type:`uint64`}],name:`setBatchTransferFee`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`uint64`,name:`newDeployFee`,type:`uint64`}],name:`setDeployFee`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`address`,name:`recipient`,type:`address`}],name:`setFeeRecipient`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`bool`,name:`active`,type:`bool`}],name:`setSwapperFeeWaiverActive`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`uint64`,name:`feeBasisPoints`,type:`uint64`}],name:`setUnwrapFeeBasisPoints`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`uint64`,name:`feeBasisPoints`,type:`uint64`}],name:`setWrapFeeBasisPoints`,outputs:[],stateMutability:`nonpayable`,type:`function`},{inputs:[{internalType:`bytes4`,name:`interfaceId`,type:`bytes4`}],name:`supportsInterface`,outputs:[{internalType:`bool`,name:``,type:`bool`}],stateMutability:`view`,type:`function`},{inputs:[],name:`swapperFeeWaiverActive`,outputs:[{internalType:`bool`,name:``,type:`bool`}],stateMutability:`view`,type:`function`},{inputs:[],name:`unwrapFeeBasisPoints`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`},{inputs:[],name:`wrapFeeBasisPoints`,outputs:[{internalType:`uint64`,name:``,type:`uint64`}],stateMutability:`view`,type:`function`}];function me(e,t,n,r){return{address:e,abi:C,functionName:`getWrapFee`,args:[t,n,r]}}function he(e,t,n,r){return{address:e,abi:C,functionName:`getUnwrapFee`,args:[t,n,r]}}function ge(e){return{address:e,abi:C,functionName:`getBatchTransferFee`,args:[]}}function _e(e){return{address:e,abi:C,functionName:`getFeeRecipient`,args:[]}}const w=[{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 ve(e,t,n,r){return{address:e,abi:w,functionName:`delegateForUserDecryption`,args:[t,n,r]}}function ye(e,t,n){return{address:e,abi:w,functionName:`revokeDelegationForUserDecryption`,args:[t,n]}}function be(e,t,n,r){return{address:e,abi:w,functionName:`getUserDecryptionDelegationExpirationDate`,args:[t,n,r]}}function xe(e,t,n,r,i){return{address:e,abi:w,functionName:`isHandleDelegatedForUserDecryption`,args:[t,n,r,i]}}const T=2n**64n-1n;var E=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 E,D={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 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),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 S(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 O(e){v(e,`Stored credentials`),y(e.publicKey,`credentials.publicKey`),ne(e.contractAddresses,`credentials.contractAddresses`);for(let t of e.contractAddresses)b(typeof t==`string`&&(0,n.isAddress)(t,{strict:!1}),`Expected each contractAddress to be a valid hex address`);v(e.encryptedPrivateKey,`credentials.encryptedPrivateKey`),y(e.encryptedPrivateKey.iv,`encryptedPrivateKey.iv`),y(e.encryptedPrivateKey.ciphertext,`encryptedPrivateKey.ciphertext`),b(typeof e.startTimestamp==`number`,`Expected credentials.startTimestamp to be a number`),b(typeof e.durationDays==`number`,`Expected credentials.durationDays to be a number`)}function we(e){O(e);let t=e;b(typeof t.delegatorAddress==`string`&&(0,n.isAddress)(t.delegatorAddress,{strict:!1}),`Expected credentials.delegatorAddress to be a valid address`),b(typeof t.delegateAddress==`string`&&(0,n.isAddress)(t.delegateAddress,{strict:!1}),`Expected credentials.delegateAddress to be a valid address`),b(typeof t.startTimestamp==`number`,`Expected startTimestamp to be a number`),b(typeof t.durationDays==`number`,`Expected durationDays to be a number`)}function k(e){return Math.floor(Date.now()/1e3)<e.startTimestamp+e.durationDays*86400}function A(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 j(e,t){return k(e)?A(e.contractAddresses,t):!1}function M(e){return[...new Set(e.map(e=>(0,n.getAddress)(e)))].toSorted()}async function N(...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 Te=class{#e;constructor(e){this.#e=e}#t(e){v(e,`Session entry`),y(e.signature,`session.signature`),b(typeof e.createdAt==`number`,`Expected session.createdAt to be a number`),b(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}},P=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 Te(e.sessionStorage),this.crypto=new Ce,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:D.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:D.SessionExpired,reason:`ttl`});else{let i=await this.decryptCredentials(e,r.signature);if(j(i,n))return this.emit({type:D.CredentialsCached,contractAddresses:n}),this.emit({type:D.CredentialsAllowed,contractAddresses:n}),i;if(k(i))return this.#i({key:t,credentials:i,requiredContracts:n});this.emit({type:D.CredentialsExpired,contractAddresses:n})}if(k(e)){if(A(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:D.CredentialsCached,contractAddresses:n}),this.emit({type:D.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:D.CredentialsExpired,contractAddresses:n})}}catch(n){if(n instanceof e.a)throw n;console.warn(`[zama-sdk] Credential resolution failed, recreating:`,n),this.emit({type:D.CredentialsCorrupted,error:x(n)}),await this.#o(t)}return(!this.#t||this.#n!==r)&&(this.#n=r,this.#t=i().then(e=>(this.emit({type:D.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),!j(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:D.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:D.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:D.CredentialsCreated,contractAddresses:n}),e}catch(t){if(t instanceof e.a)throw t;a(t,i)}}async#i({key:e,credentials:t,requiredContracts:n}){if(this.#r){let e=await this.#r;if(A(e.contractAddresses,n))return this.emit({type:D.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=M([...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:D.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:D.CredentialsPersistFailed,error:x(e)})}}async#o(e){try{await this.storage.delete(e)}catch(e){console.warn(`[zama-sdk] Failed to delete credentials:`,e),this.emit({type:D.CredentialsPersistFailed,error:x(e)})}}};function Ee(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 De=class e extends P{#e;#t=null;#n=null;static async computeStoreKey(e,t){return N((0,n.getAddress)(e),t)}constructor(e){super(e),this.#e=e.relayer,Ee(typeof globalThis<`u`?Reflect.get(globalThis,`chrome`):void 0)&&e.sessionStorage instanceof E&&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=M(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(){return this.checkAllowed(await this.#r())}async clear(){await this.clearAll(await this.#r())}async create(e){let t=M(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){O(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}},Oe=class e extends P{#e;#t=null;#n=null;static async computeStoreKey(e,t,r){return N((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=M(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){we(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 ke=`zama:balances`;function Ae(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(Ae(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=Ae(n,r,i);try{await t.set(o,a.toString()),await Me(t,o)}catch{}}const je=new WeakMap;async function Me(e,t){let n=(je.get(e)??Promise.resolve()).then(async()=>{let n=await e.get(ke),r=n?JSON.parse(n):[];r.includes(t)||(r.push(t),await e.set(ke,JSON.stringify(r)))});return je.set(e,n.catch(()=>{})),n}async function Ne(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 Pe=class r{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??2592e3,sessionTTL:e.sessionTTL??2592e3,onEvent:e.onEvent};this.credentials=e.credentials??new De(t),this.delegatedCredentials=e.delegatedCredentials??new Oe(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.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,ee=n[0],u=r??await Promise.all(n.map(e=>e.readConfidentialBalanceOf(i)));if(n.length!==u.length)throw new e.r(`tokens.length (${n.length}) must equal handles.length (${u.length})`);let d=ee.storage,f=new Map,p=[],m=await Promise.all(n.map((e,t)=>{let n=u[t];return e.isZeroHandle(n)?0n:F({storage:d,tokenAddress:e.address,owner:i,handle:n})}));for(let e=0;e<n.length;e++){let t=n[e],r=u[e],i=m[e];if(i!=null){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}`);f.set(t.address,a);try{await I({storage:d,tokenAddress:t.address,owner:i,handle:n,value:a})}catch(e){console.warn(`[zama-sdk] Cache write failed (non-blocking):`,e)}}).catch(e=>{let n=x(e);if(a)try{f.set(t.address,a(n,t.address))}catch(e){g.push({address:t.address,error:x(e)})}else g.push({address:t.address,error:n})}));if(await Ne(_,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(fe(a,o,i))}async name(){return this.signer.readContract(se(this.address))}async symbol(){return this.signer.readContract(ce(this.address))}async decimals(){return this.signer.readContract(le(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===T?!0:t>await this.signer.getBlockTimestamp()}async getDelegationExpiry({delegatorAddress:e,delegateAddress:t}){let r=await this.getAclAddress();return this.signer.readContract(be(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 u(`No active delegation from ${e} to ${t} for ${this.address}`);if(n!==T&&n<=await this.signer.getBlockTimestamp())throw new d(`Delegation from ${e} to ${t} for ${this.address} has expired`)}async readConfidentialBalanceOf(e){return await this.signer.readContract(t._(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 F({storage:this.storage,tokenAddress:this.address,owner:a,handle:o});if(s!==null)return s;await this.#n(i);let c=Date.now();try{this.emit({type:D.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:D.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}`);try{await I({storage:this.storage,tokenAddress:this.address,owner:a,handle:o,value:r})}catch(e){console.warn(`[zama-sdk] Cache write failed (non-blocking):`,e)}return r}catch(e){throw this.emit({type:D.DecryptError,error:x(e),durationMs:Date.now()-c}),L(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 F({storage:this.storage,tokenAddress:this.address,owner:r,handle:t});if(i!==null)return i;let a=await this.credentials.allow(this.address),o=Date.now();try{this.emit({type:D.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:D.DecryptEnd,durationMs:Date.now()-o});let i=n[t];if(i===void 0)throw new e.r(`Decryption returned no value for handle ${t}`);try{await I({storage:this.storage,tokenAddress:this.address,owner:r,handle:t,value:i})}catch(e){console.warn(`[zama-sdk] Cache write failed (non-blocking):`,e)}return i}catch(e){throw this.emit({type:D.DecryptError,error:x(e),durationMs:Date.now()-o}),L(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:D.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:D.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:D.DecryptError,error:x(e),durationMs:Date.now()-o}),L(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 L(t,n,a=!1){if(t instanceof e.r||t instanceof c||t instanceof e.n||t instanceof _||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 _(`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 R={ConfidentialTransfer:`0x67500e8d0ed826d2194f514dd0d8124f35648ab6e3fb5e6ed867134cffe661e9`,Wrapped:`0x1f7907f4d84043abe0fb7c74e8865ee5fe93fe4f691c54a7b8fa9d6fb17c7cba`,UnwrapRequested:`0x77d02d353c5629272875d11f1b34ec4c65d7430b075575b78cd2502034c469ee`,UnwrappedFinalized:`0xc64e7c81b18b674fc5b037d8a0041bfe3332d86c780a4688f404ee01fbabb152`,UnwrappedStarted:`0x3838891d4843c6d7f9f494570b6fd8843f4e3c3ddb817c1411760bd31b819806`};function z(e){return(0,n.getAddress)(S(e.slice(-40)))}function B(e){return BigInt(e)}function Fe(e){return e}function V(e,t){let n=2+t*64,r=e.slice(n,n+64);return r.length===64?r:r.padEnd(64,`0`)}function H(e,t){return(0,n.getAddress)(S(V(e,t).slice(-40)))}function U(e,t){return BigInt(`0x`+V(e,t))}function W(e,t){return BigInt(`0x`+V(e,t))!==0n}function G(e,t){return S(V(e,t))}function Ie(e){return e.topics[0]!==R.ConfidentialTransfer||e.topics.length<4?null:{eventName:`ConfidentialTransfer`,from:z(e.topics[1]),to:z(e.topics[2]),encryptedAmountHandle:Fe(e.topics[3])}}function K(e){return e.topics[0]!==R.Wrapped||e.topics.length<3?null:{eventName:`Wrapped`,to:z(e.topics[1]),mintTxId:B(e.topics[2]),mintAmount:U(e.data,0),amountIn:U(e.data,1),feeAmount:U(e.data,2)}}function q(e){return e.topics[0]!==R.UnwrapRequested||e.topics.length<2?null:{eventName:`UnwrapRequested`,receiver:z(e.topics[1]),encryptedAmount:G(e.data,0)}}function Le(e){return e.topics[0]!==R.UnwrappedFinalized||e.topics.length<3?null:{eventName:`UnwrappedFinalized`,burntAmountHandle:Fe(e.topics[1]),nextTxId:B(e.topics[2]),finalizeSuccess:W(e.data,0),feeTransferSuccess:W(e.data,1),burnAmount:U(e.data,2),unwrapAmount:U(e.data,3),feeAmount:U(e.data,4)}}function Re(e){return e.topics[0]!==R.UnwrappedStarted||e.topics.length<4?null:{eventName:`UnwrappedStarted`,requestId:B(e.topics[1]),txId:B(e.topics[2]),to:z(e.topics[3]),returnVal:W(e.data,0),refund:H(e.data,1),requestedAmount:G(e.data,2),burnAmount:G(e.data,3)}}function J(e){return Ie(e)??K(e)??q(e)??Le(e)??Re(e)}function ze(e){let t=[];for(let n of e){let e=J(n);e&&t.push(e)}return t}function Be(e){for(let t of e){let e=q(t);if(e)return e}return null}function Ve(e){for(let t of e){let e=K(t);if(e)return e}return null}const He=[R.ConfidentialTransfer,R.Wrapped,R.UnwrapRequested,R.UnwrappedFinalized,R.UnwrappedStarted],Y={DelegatedForUserDecryption:`0x527b025d7ff06689c1ab9d32dfd7881c964cce72ce8ac5b2fe1d3be8cfda5bfc`,RevokedDelegationForUserDecryption:`0x7aca80b6b7928b9038f186e3d9922a0fc5d52c398fbf144725c142c52a5277e4`};function X(e){return e.topics[0]!==Y.DelegatedForUserDecryption||e.topics.length<3?null:{eventName:`DelegatedForUserDecryption`,delegator:z(e.topics[1]),delegate:z(e.topics[2]),contractAddress:H(e.data,0),delegationCounter:U(e.data,1),oldExpirationDate:U(e.data,2),newExpirationDate:U(e.data,3)}}function Z(e){return e.topics[0]!==Y.RevokedDelegationForUserDecryption||e.topics.length<3?null:{eventName:`RevokedDelegationForUserDecryption`,delegator:z(e.topics[1]),delegate:z(e.topics[2]),contractAddress:H(e.data,0),delegationCounter:U(e.data,1),oldExpirationDate:U(e.data,2)}}function Ue(e){return X(e)??Z(e)}function We(e){let t=[];for(let n of e){let e=Ue(n);e&&t.push(e)}return t}function Ge(e){for(let t of e){let e=X(t);if(e)return e}return null}function Ke(e){for(let t of e){let e=Z(t);if(e)return e}return null}const qe=[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 Je(e,t,n){switch(e.eventName){case`ConfidentialTransfer`:return Ye(e,t,n);case`Wrapped`:return Xe(e,t,n);case`UnwrapRequested`:return Ze(e,t,n);case`UnwrappedStarted`:return Qe(e,t,n);case`UnwrappedFinalized`:return $e(e,n)}}function Ye(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 Xe(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 Ze(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 $e(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 et(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(Je(e,t,i))}return n}function tt(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 nt(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 rt(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 ie}}),Object.defineProperty(exports,`A`,{enumerable:!0,get:function(){return E}}),Object.defineProperty(exports,`B`,{enumerable:!0,get:function(){return me}}),Object.defineProperty(exports,`C`,{enumerable:!0,get:function(){return Ve}}),Object.defineProperty(exports,`D`,{enumerable:!0,get:function(){return Oe}}),Object.defineProperty(exports,`E`,{enumerable:!0,get:function(){return F}}),Object.defineProperty(exports,`F`,{enumerable:!0,get:function(){return xe}}),Object.defineProperty(exports,`G`,{enumerable:!0,get:function(){return ue}}),Object.defineProperty(exports,`H`,{enumerable:!0,get:function(){return pe}}),Object.defineProperty(exports,`I`,{enumerable:!0,get:function(){return ye}}),Object.defineProperty(exports,`J`,{enumerable:!0,get:function(){return oe}}),Object.defineProperty(exports,`K`,{enumerable:!0,get:function(){return se}}),Object.defineProperty(exports,`L`,{enumerable:!0,get:function(){return ge}}),Object.defineProperty(exports,`M`,{enumerable:!0,get:function(){return T}}),Object.defineProperty(exports,`N`,{enumerable:!0,get:function(){return ve}}),Object.defineProperty(exports,`O`,{enumerable:!0,get:function(){return De}}),Object.defineProperty(exports,`P`,{enumerable:!0,get:function(){return be}}),Object.defineProperty(exports,`Q`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`R`,{enumerable:!0,get:function(){return _e}}),Object.defineProperty(exports,`S`,{enumerable:!0,get:function(){return Be}}),Object.defineProperty(exports,`T`,{enumerable:!0,get:function(){return`0x0000000000000000000000000000000000000000000000000000000000000000`}}),Object.defineProperty(exports,`U`,{enumerable:!0,get:function(){return de}}),Object.defineProperty(exports,`V`,{enumerable:!0,get:function(){return fe}}),Object.defineProperty(exports,`W`,{enumerable:!0,get:function(){return le}}),Object.defineProperty(exports,`X`,{enumerable:!0,get:function(){return ae}}),Object.defineProperty(exports,`Y`,{enumerable:!0,get:function(){return x}}),Object.defineProperty(exports,`Z`,{enumerable:!0,get:function(){return te}}),Object.defineProperty(exports,`_`,{enumerable:!0,get:function(){return Le}}),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return qe}}),Object.defineProperty(exports,`at`,{enumerable:!0,get:function(){return d}}),Object.defineProperty(exports,`b`,{enumerable:!0,get:function(){return Ge}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return R}}),Object.defineProperty(exports,`ct`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return Ie}}),Object.defineProperty(exports,`dt`,{enumerable:!0,get:function(){return o}}),Object.defineProperty(exports,`et`,{enumerable:!0,get:function(){return h}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return X}}),Object.defineProperty(exports,`ft`,{enumerable:!0,get:function(){return c}}),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 rt}}),Object.defineProperty(exports,`it`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`j`,{enumerable:!0,get:function(){return Se}}),Object.defineProperty(exports,`k`,{enumerable:!0,get:function(){return D}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return Ue}}),Object.defineProperty(exports,`lt`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return ze}}),Object.defineProperty(exports,`mt`,{enumerable:!0,get:function(){return r}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return tt}}),Object.defineProperty(exports,`nt`,{enumerable:!0,get:function(){return ee}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return Y}}),Object.defineProperty(exports,`ot`,{enumerable:!0,get:function(){return f}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return J}}),Object.defineProperty(exports,`pt`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`q`,{enumerable:!0,get:function(){return ce}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return et}}),Object.defineProperty(exports,`rt`,{enumerable:!0,get:function(){return p}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return He}}),Object.defineProperty(exports,`st`,{enumerable:!0,get:function(){return u}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return nt}}),Object.defineProperty(exports,`tt`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return We}}),Object.defineProperty(exports,`ut`,{enumerable:!0,get:function(){return s}}),Object.defineProperty(exports,`v`,{enumerable:!0,get:function(){return Re}}),Object.defineProperty(exports,`w`,{enumerable:!0,get:function(){return Pe}}),Object.defineProperty(exports,`x`,{enumerable:!0,get:function(){return Ke}}),Object.defineProperty(exports,`y`,{enumerable:!0,get:function(){return K}}),Object.defineProperty(exports,`z`,{enumerable:!0,get:function(){return he}});
|
|
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`}},ee=class extends e.a{constructor(t,n){super(e.o.DelegationCooldown,t,n),this.name=`DelegationCooldownError`}},u=class extends e.a{constructor(t,n){super(e.o.DelegationNotFound,t,n),this.name=`DelegationNotFoundError`}},d=class extends e.a{constructor(t,n){super(e.o.DelegationExpired,t,n),this.name=`DelegationExpiredError`}},f=class extends e.a{constructor(t,n){super(e.o.DelegationExpiryUnchanged,t,n),this.name=`DelegationExpiryUnchangedError`}},p=class extends e.a{constructor(t,n){super(e.o.DelegationDelegateEqualsContract,t,n),this.name=`DelegationDelegateEqualsContractError`}},m=class extends e.a{constructor(t,n){super(e.o.DelegationContractIsSelf,t,n),this.name=`DelegationContractIsSelfError`}},te=class extends e.a{constructor(t,n){super(e.o.AclPaused,t,n),this.name=`AclPausedError`}},h=class extends e.a{constructor(t,n){super(e.o.DelegationExpirationTooSoon,t,n),this.name=`DelegationExpirationTooSoonError`}},g=class extends e.a{constructor(t,n){super(e.o.DelegationNotPropagated,t,n),this.name=`DelegationNotPropagatedError`}};function ne(e,t){if(e==null)throw TypeError(`${t} must not be null or undefined`)}function _(e,t){if(typeof e!=`object`||!e||Array.isArray(e))throw TypeError(`${t} must be an object, got ${typeof e}`)}function v(e,t){if(typeof e!=`string`)throw TypeError(`${t} must be a string, got ${typeof e}`)}function re(e,t){if(!Array.isArray(e))throw TypeError(`${t} must be an array, got ${typeof e}`)}function ie(e,t){if(typeof e!=`function`)throw TypeError(`${t} must be a function, got ${typeof e}`)}function ae(e,t,n){v(e[t],n)}function oe(e,t,n){ie(e[t],n)}function y(e,t){if(!e)throw TypeError(t)}function b(e){return e instanceof Error?e:typeof e==`object`&&e&&`message`in e?Error(String(e.message)):Error(String(e))}function se(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 x(e){return e.startsWith(`0x`)?e:`0x${e}`}function ce(e){return{address:e,abi:n.erc20Abi,functionName:`name`,args:[]}}function le(e){return{address:e,abi:n.erc20Abi,functionName:`symbol`,args:[]}}function ue(e){return{address:e,abi:n.erc20Abi,functionName:`decimals`,args:[]}}function de(e){return{address:e,abi:n.erc20Abi,functionName:`totalSupply`,args:[]}}function fe(e,t){return{address:e,abi:n.erc20Abi,functionName:`balanceOf`,args:[t]}}function pe(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`allowance`,args:[t,r]}}function me(e,t,r){return{address:e,abi:n.erc20Abi,functionName:`approve`,args:[t,r]}}const S=[{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 he(e,t,n,r){return{address:e,abi:S,functionName:`delegateForUserDecryption`,args:[t,n,r]}}function ge(e,t,n){return{address:e,abi:S,functionName:`revokeDelegationForUserDecryption`,args:[t,n]}}function _e(e,t,n,r){return{address:e,abi:S,functionName:`getUserDecryptionDelegationExpirationDate`,args:[t,n,r]}}function ve(e,t,n,r,i){return{address:e,abi:S,functionName:`isHandleDelegatedForUserDecryption`,args:[t,n,r,i]}}const C=2n**64n-1n;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 ye=new w,T={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 be=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 x(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 E(e){_(e,`Stored credentials`),v(e.publicKey,`credentials.publicKey`),re(e.contractAddresses,`credentials.contractAddresses`);for(let t of e.contractAddresses)y(typeof t==`string`&&(0,n.isAddress)(t,{strict:!1}),`Expected each contractAddress to be a valid hex address`);_(e.encryptedPrivateKey,`credentials.encryptedPrivateKey`),v(e.encryptedPrivateKey.iv,`encryptedPrivateKey.iv`),v(e.encryptedPrivateKey.ciphertext,`encryptedPrivateKey.ciphertext`),y(typeof e.startTimestamp==`number`,`Expected credentials.startTimestamp to be a number`),y(typeof e.durationDays==`number`,`Expected credentials.durationDays to be a number`)}function xe(e){E(e);let t=e;y(typeof t.delegatorAddress==`string`&&(0,n.isAddress)(t.delegatorAddress,{strict:!1}),`Expected credentials.delegatorAddress to be a valid address`),y(typeof t.delegateAddress==`string`&&(0,n.isAddress)(t.delegateAddress,{strict:!1}),`Expected credentials.delegateAddress to be a valid address`),y(typeof t.startTimestamp==`number`,`Expected startTimestamp to be a number`),y(typeof t.durationDays==`number`,`Expected durationDays to be a number`)}function D(e){return Math.floor(Date.now()/1e3)<e.startTimestamp+e.durationDays*86400}function O(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 k(e,t){return D(e)?O(e.contractAddresses,t):!1}function A(e){return[...new Set(e.map(e=>(0,n.getAddress)(e)))].toSorted()}async function j(...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 Se=class{#e;constructor(e){this.#e=e}#t(e){_(e,`Session entry`),v(e.signature,`session.signature`),y(typeof e.createdAt==`number`,`Expected session.createdAt to be a number`),y(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}},M=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 Se(e.sessionStorage),this.crypto=new be,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:T.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:T.SessionExpired,reason:`ttl`});else{let i=await this.decryptCredentials(e,r.signature);if(k(i,n))return this.emit({type:T.CredentialsCached,contractAddresses:n}),this.emit({type:T.CredentialsAllowed,contractAddresses:n}),i;if(D(i))return this.#a({key:t,credentials:i,requiredContracts:n});this.emit({type:T.CredentialsExpired,contractAddresses:n})}if(D(e)){if(O(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:T.CredentialsCached,contractAddresses:n}),this.emit({type:T.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:T.CredentialsExpired,contractAddresses:n})}}catch(n){if(n instanceof e.a)throw n;console.warn(`[zama-sdk] Credential resolution failed, recreating:`,n),this.emit({type:T.CredentialsCorrupted,error:b(n)}),await this.#s(t)}return(!this.#t||this.#n!==r)&&(this.#n=r,this.#t=i().then(e=>(this.emit({type:T.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),!k(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:T.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.#s(e)}clearCaches(){this.crypto.clearCache(),this.#i=null}async createCredentials({key:t,contractAddresses:n,createFn:r,errorContext:i}){this.emit({type:T.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:T.CredentialsCreated,contractAddresses:n}),e}catch(t){if(t instanceof e.a)throw t;a(t,i)}}async#a({key:e,credentials:t,requiredContracts:n}){if(this.#r){let e=await this.#r;if(O(e.contractAddresses,n))return this.emit({type:T.CredentialsAllowed,contractAddresses:n}),e;t=e}else if(this.#i){let e=this.#i;if(O(e.contractAddresses,n))return this.emit({type:T.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=A([...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:T.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:T.CredentialsPersistFailed,error:b(e)})}}async#s(e){try{await this.storage.delete(e)}catch(e){console.warn(`[zama-sdk] Failed to delete credentials:`,e),this.emit({type:T.CredentialsPersistFailed,error:b(e)})}}};function Ce(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 N=class e extends M{#e;#t=null;#n=null;static async computeStoreKey(e,t){return j((0,n.getAddress)(e),t)}constructor(e){super(e),this.#e=e.relayer,Ce(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=A(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(){return this.checkAllowed(await this.#r())}async clear(){await this.clearAll(await this.#r())}async create(e){let t=A(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){E(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}},P=class e extends M{#e;#t=null;#n=null;static async computeStoreKey(e,t,r){return j((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=A(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){xe(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 F=`zama:balances`;function I(e,t,r){return`zama:balance:${(0,n.getAddress)(e)}:${(0,n.getAddress)(t)}:${r.toLowerCase()}`}async function L({storage:e,tokenAddress:t,owner:n,handle:r}){try{let i=await e.get(I(t,n,r));return i===null?null:BigInt(i)}catch(e){return console.warn(`[zama-sdk] Balance cache read failed:`,e),null}}async function R(e){let{storage:t,tokenAddress:n,owner:r,handle:i,value:a}=e,o=I(n,r,i);try{await t.set(o,a.toString()),await Te(t,o)}catch{}}const we=new WeakMap;async function Te(e,t){let n=(we.get(e)??Promise.resolve()).then(async()=>{let n=await e.get(F),r=n?JSON.parse(n):[];r.includes(t)||(r.push(t),await e.set(F,JSON.stringify(r)))});return we.set(e,n.catch(()=>{})),n}async function Ee(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 De=class r{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??2592e3,sessionTTL:e.sessionTTL??2592e3,onEvent:e.onEvent};this.credentials=e.credentials??new N(t),this.delegatedCredentials=e.delegatedCredentials??new P(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.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,ee=n[0],u=r??await Promise.all(n.map(e=>e.readConfidentialBalanceOf(i)));if(n.length!==u.length)throw new e.r(`tokens.length (${n.length}) must equal handles.length (${u.length})`);let d=ee.storage,f=new Map,p=[],m=await Promise.all(n.map((e,t)=>{let n=u[t];return e.isZeroHandle(n)?0n:L({storage:d,tokenAddress:e.address,owner:i,handle:n})}));for(let e=0;e<n.length;e++){let t=n[e],r=u[e],i=m[e];if(i!=null){f.set(t.address,i);continue}p.push({token:t,handle:r})}if(p.length===0)return f;t.preFlightCheck&&await t.preFlightCheck();let te=await s(p.map(e=>e.token.address)),h=[],g=[];for(let{token:t,handle:n}of p)g.push(()=>c(te,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}`);f.set(t.address,a);try{await R({storage:d,tokenAddress:t.address,owner:i,handle:n,value:a})}catch(e){console.warn(`[zama-sdk] Cache write failed (non-blocking):`,e)}}).catch(e=>{let n=b(e);if(a)try{f.set(t.address,a(n,t.address))}catch(e){h.push({address:t.address,error:b(e)})}else h.push({address:t.address,error:n})}));if(await Ee(g,o),h.length>0){let t=h.map(e=>`${e.address}: ${e.error.message}`).join(`; `);throw new e.r(`${l} failed for ${h.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(pe(a,o,i))}async name(){return this.signer.readContract(ce(this.address))}async symbol(){return this.signer.readContract(le(this.address))}async decimals(){return this.signer.readContract(ue(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===C?!0:t>await this.signer.getBlockTimestamp()}async getDelegationExpiry({delegatorAddress:e,delegateAddress:t}){let r=await this.getAclAddress();return this.signer.readContract(_e(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 u(`No active delegation from ${e} to ${t} for ${this.address}`);if(n!==C&&n<=await this.signer.getBlockTimestamp())throw new d(`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 L({storage:this.storage,tokenAddress:this.address,owner:a,handle:o});if(s!==null)return s;await this.#n(i);let c=Date.now();try{this.emit({type:T.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:T.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}`);try{await R({storage:this.storage,tokenAddress:this.address,owner:a,handle:o,value:r})}catch(e){console.warn(`[zama-sdk] Cache write failed (non-blocking):`,e)}return r}catch(e){throw this.emit({type:T.DecryptError,error:b(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 L({storage:this.storage,tokenAddress:this.address,owner:r,handle:t});if(i!==null)return i;let a=await this.credentials.allow(this.address),o=Date.now();try{this.emit({type:T.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:T.DecryptEnd,durationMs:Date.now()-o});let i=n[t];if(i===void 0)throw new e.r(`Decryption returned no value for handle ${t}`);try{await R({storage:this.storage,tokenAddress:this.address,owner:r,handle:t,value:i})}catch(e){console.warn(`[zama-sdk] Cache write failed (non-blocking):`,e)}return i}catch(e){throw this.emit({type:T.DecryptError,error:b(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:T.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:T.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:T.DecryptError,error:b(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 g||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 g(`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)(x(e.slice(-40)))}function Oe(e){return BigInt(e)}function ke(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)(x(H(e,t).slice(-40)))}function W(e,t){return BigInt(`0x`+H(e,t))}function Ae(e,t){return BigInt(`0x`+H(e,t))!==0n}function G(e,t){return x(H(e,t))}function je(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:ke(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 Me(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 Ne(e){return e.topics[0]!==B.UnwrappedStarted||e.topics.length<4?null:{eventName:`UnwrappedStarted`,requestId:Oe(e.topics[1]),txId:Oe(e.topics[2]),to:V(e.topics[3]),returnVal:Ae(e.data,0),refund:U(e.data,1),requestedAmount:G(e.data,2),burnAmount:G(e.data,3)}}function J(e){return je(e)??K(e)??q(e)??Me(e)??Ne(e)}function Pe(e){let t=[];for(let n of e){let e=J(n);e&&t.push(e)}return t}function Fe(e){for(let t of e){let e=q(t);if(e)return e}return null}function Ie(e){for(let t of e){let e=K(t);if(e)return e}return null}const Le=[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 Re(e){return X(e)??Z(e)}function ze(e){let t=[];for(let n of e){let e=Re(n);e&&t.push(e)}return t}function Be(e){for(let t of e){let e=X(t);if(e)return e}return null}function Ve(e){for(let t of e){let e=Z(t);if(e)return e}return null}const He=[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 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)}}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=J(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:{...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 p}}),Object.defineProperty(exports,`A`,{enumerable:!0,get:function(){return w}}),Object.defineProperty(exports,`B`,{enumerable:!0,get:function(){return ue}}),Object.defineProperty(exports,`C`,{enumerable:!0,get:function(){return Ie}}),Object.defineProperty(exports,`D`,{enumerable:!0,get:function(){return P}}),Object.defineProperty(exports,`E`,{enumerable:!0,get:function(){return L}}),Object.defineProperty(exports,`F`,{enumerable:!0,get:function(){return ve}}),Object.defineProperty(exports,`G`,{enumerable:!0,get:function(){return b}}),Object.defineProperty(exports,`H`,{enumerable:!0,get:function(){return ce}}),Object.defineProperty(exports,`I`,{enumerable:!0,get:function(){return ge}}),Object.defineProperty(exports,`J`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`K`,{enumerable:!0,get:function(){return oe}}),Object.defineProperty(exports,`L`,{enumerable:!0,get:function(){return pe}}),Object.defineProperty(exports,`M`,{enumerable:!0,get:function(){return C}}),Object.defineProperty(exports,`N`,{enumerable:!0,get:function(){return he}}),Object.defineProperty(exports,`O`,{enumerable:!0,get:function(){return N}}),Object.defineProperty(exports,`P`,{enumerable:!0,get:function(){return _e}}),Object.defineProperty(exports,`Q`,{enumerable:!0,get:function(){return ee}}),Object.defineProperty(exports,`R`,{enumerable:!0,get:function(){return me}}),Object.defineProperty(exports,`S`,{enumerable:!0,get:function(){return Fe}}),Object.defineProperty(exports,`T`,{enumerable:!0,get:function(){return`0x0000000000000000000000000000000000000000000000000000000000000000`}}),Object.defineProperty(exports,`U`,{enumerable:!0,get:function(){return le}}),Object.defineProperty(exports,`V`,{enumerable:!0,get:function(){return de}}),Object.defineProperty(exports,`W`,{enumerable:!0,get:function(){return se}}),Object.defineProperty(exports,`X`,{enumerable:!0,get:function(){return te}}),Object.defineProperty(exports,`Y`,{enumerable:!0,get:function(){return ae}}),Object.defineProperty(exports,`Z`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`_`,{enumerable:!0,get:function(){return Me}}),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return He}}),Object.defineProperty(exports,`at`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`b`,{enumerable:!0,get:function(){return Be}}),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 je}}),Object.defineProperty(exports,`et`,{enumerable:!0,get:function(){return h}}),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 Qe}}),Object.defineProperty(exports,`it`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`j`,{enumerable:!0,get:function(){return ye}}),Object.defineProperty(exports,`k`,{enumerable:!0,get:function(){return T}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return Re}}),Object.defineProperty(exports,`lt`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return Pe}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return Xe}}),Object.defineProperty(exports,`nt`,{enumerable:!0,get:function(){return f}}),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 ne}}),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 Le}}),Object.defineProperty(exports,`st`,{enumerable:!0,get:function(){return o}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return Ze}}),Object.defineProperty(exports,`tt`,{enumerable:!0,get:function(){return d}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return ze}}),Object.defineProperty(exports,`ut`,{enumerable:!0,get:function(){return r}}),Object.defineProperty(exports,`v`,{enumerable:!0,get:function(){return Ne}}),Object.defineProperty(exports,`w`,{enumerable:!0,get:function(){return De}}),Object.defineProperty(exports,`x`,{enumerable:!0,get:function(){return Ve}}),Object.defineProperty(exports,`y`,{enumerable:!0,get:function(){return K}}),Object.defineProperty(exports,`z`,{enumerable:!0,get:function(){return fe}});
|
|
2
2
|
//# sourceMappingURL=activity.cjs.map
|