@aave/client 4.0.0-next.47 → 4.0.0-next.49

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/thirdweb.js CHANGED
@@ -1,2 +1,2 @@
1
- import {a}from'./chunk-N4LXBTGY.js';import {f}from'./chunk-O65KFH4O.js';import {ValidationError,SigningError,UnexpectedError,TransactionError}from'@aave/core';import {chainId,okAsync,errAsync,ResultAsync,signatureFrom,txHash,invariant}from'@aave/types';import {defineChain,waitForReceipt,Engine}from'thirdweb';import {sepolia,mainnet}from'thirdweb/chains';function w(e){switch(e.chainId){case chainId(mainnet.id):return mainnet;case chainId(sepolia.id):return sepolia}return defineChain({id:e.chainId,name:e.name,nativeCurrency:{name:e.nativeInfo.name,symbol:e.nativeInfo.symbol,decimals:e.nativeInfo.decimals},rpcUrls:{default:{http:[e.rpcUrl]}},blockExplorers:{default:{name:`${e.name} Explorer`,url:e.explorerUrl}}})}function D(e,r){switch(r){case chainId(mainnet.id):return okAsync(mainnet);case chainId(sepolia.id):return okAsync(sepolia)}return f(e,{chainId:r},{batch:false}).andThen(n=>(invariant(n,`Chain ${r} is not supported`),okAsync(w(n))))}async function b(e,r,n){let a=await Engine.serverWallet({client:e,chain:r,address:n.from}).sendTransaction({type:"eip1559",chainId:r.id,to:n.to,value:BigInt(n.value),data:n.data});return txHash(a.transactionHash)}function o(e,r,n){return D(e,n.chainId).andThen(t=>ResultAsync.fromPromise(b(r,t,n),a=>SigningError.from(a)).andThen(a=>ResultAsync.fromPromise(waitForReceipt({client:r,chain:t,transactionHash:a}),s=>UnexpectedError.from(s))).andThen(a=>{let s=txHash(a.transactionHash);return a.status==="reverted"?errAsync(TransactionError.new({txHash:s,request:n})):okAsync({txHash:s,operations:n.operations})}))}function m(e,r,n){switch(n.__typename){case "TransactionRequest":return o(e,r,n);case "Erc20ApprovalRequired":return n.approvals.reduce((t,a)=>t.andThen(()=>o(e,r,a.byTransaction)),okAsync(void 0)).andThen(()=>o(e,r,n.originalTransaction));case "PreContractActionRequired":return o(e,r,n.transaction).andThen(()=>o(e,r,n.originalTransaction));case "InsufficientBalanceError":return errAsync(ValidationError.fromGqlNode(n))}}function F(e,r,n){return n?m(e,r,n):m.bind(null,e,r)}function _(e,r){return r().andThen(n=>{if(a(n)){let t=n.approvals[0].bySignature;return S(e,t).map(a=>({deadline:t.message.deadline,value:a})).andThen(a=>r(a))}return okAsync(n)})}function y(e,r){return ResultAsync.fromPromise(e.signTypedData({types:r.types,domain:r.domain,primaryType:r.primaryType,message:r.message}),n=>SigningError.from(n)).map(signatureFrom)}function S(e,r){return r===void 0?n=>y(e,n):y(e,r)}export{_ as permitWith,F as sendWith,S as signTypedDataWith,w as toThirdwebChain};//# sourceMappingURL=thirdweb.js.map
1
+ import {a}from'./chunk-N4LXBTGY.js';import {f}from'./chunk-2GSAKHLR.js';import {ValidationError,SigningError,UnexpectedError,TransactionError}from'@aave/core';import {chainId,okAsync,errAsync,ResultAsync,signatureFrom,txHash,invariant}from'@aave/types';import {defineChain,waitForReceipt,Engine}from'thirdweb';import {sepolia,mainnet}from'thirdweb/chains';function w(e){switch(e.chainId){case chainId(mainnet.id):return mainnet;case chainId(sepolia.id):return sepolia}return defineChain({id:e.chainId,name:e.name,nativeCurrency:{name:e.nativeInfo.name,symbol:e.nativeInfo.symbol,decimals:e.nativeInfo.decimals},rpcUrls:{default:{http:[e.rpcUrl]}},blockExplorers:{default:{name:`${e.name} Explorer`,url:e.explorerUrl}}})}function D(e,r){switch(r){case chainId(mainnet.id):return okAsync(mainnet);case chainId(sepolia.id):return okAsync(sepolia)}return f(e,{chainId:r},{batch:false}).andThen(n=>(invariant(n,`Chain ${r} is not supported`),okAsync(w(n))))}async function b(e,r,n){let a=await Engine.serverWallet({client:e,chain:r,address:n.from}).sendTransaction({type:"eip1559",chainId:r.id,to:n.to,value:BigInt(n.value),data:n.data});return txHash(a.transactionHash)}function o(e,r,n){return D(e,n.chainId).andThen(t=>ResultAsync.fromPromise(b(r,t,n),a=>SigningError.from(a)).andThen(a=>ResultAsync.fromPromise(waitForReceipt({client:r,chain:t,transactionHash:a}),s=>UnexpectedError.from(s))).andThen(a=>{let s=txHash(a.transactionHash);return a.status==="reverted"?errAsync(TransactionError.new({txHash:s,request:n})):okAsync({txHash:s,operations:n.operations})}))}function m(e,r,n){switch(n.__typename){case "TransactionRequest":return o(e,r,n);case "Erc20ApprovalRequired":return n.approvals.reduce((t,a)=>t.andThen(()=>o(e,r,a.byTransaction)),okAsync(void 0)).andThen(()=>o(e,r,n.originalTransaction));case "PreContractActionRequired":return o(e,r,n.transaction).andThen(()=>o(e,r,n.originalTransaction));case "InsufficientBalanceError":return errAsync(ValidationError.fromGqlNode(n))}}function F(e,r,n){return n?m(e,r,n):m.bind(null,e,r)}function _(e,r){return r().andThen(n=>{if(a(n)){let t=n.approvals[0].bySignature;return S(e,t).map(a=>({deadline:t.message.deadline,value:a})).andThen(a=>r(a))}return okAsync(n)})}function y(e,r){return ResultAsync.fromPromise(e.signTypedData({types:r.types,domain:r.domain,primaryType:r.primaryType,message:r.message}),n=>SigningError.from(n)).map(signatureFrom)}function S(e,r){return r===void 0?n=>y(e,n):y(e,r)}export{_ as permitWith,F as sendWith,S as signTypedDataWith,w as toThirdwebChain};//# sourceMappingURL=thirdweb.js.map
2
2
  //# sourceMappingURL=thirdweb.js.map
package/dist/viem.cjs CHANGED
@@ -1,2 +1,2 @@
1
- 'use strict';var core=require('@aave/core'),types=require('@aave/types'),viem=require('viem'),actions=require('viem/actions'),chains=require('viem/chains'),graphql=require('@aave/graphql');var p={currency:graphql.Currency.Usd,timeWindow:graphql.TimeWindow.LastDay,requestPolicy:"cache-and-network",batch:true};function h(n,e,{batch:r=p.batch,requestPolicy:t=p.requestPolicy}=p){return n.query(graphql.ChainQuery,{request:e},{batch:r,requestPolicy:t})}function H(n){return typeof n=="object"&&n!==null&&"approvals"in n&&Array.isArray(n.approvals)}function E(n){return H(n)&&types.isOneEntryArray(n.approvals)&&!!n.approvals[0].bySignature}function m(n){return types.isObject(n)&&"code"in n&&"message"in n}function j(n){return types.isObject(n)&&"name"in n&&"message"in n&&"originalError"in n?m(n.originalError)&&"code"in n.originalError:true}function g(n,e){return types.invariant(n.account,"Wallet account is required to sign typed data"),types.ResultAsync.fromPromise(n.signTypedData({account:n.account,domain:e.domain,types:e.types,primaryType:e.primaryType,message:e.message}),r=>r instanceof viem.UserRejectedRequestError?core.CancelError.from(r):core.SigningError.from(r)).map(types.signatureFrom)}function W(n){switch(n.chainId){case types.chainId(chains.mainnet.id):return chains.mainnet;case types.chainId(chains.sepolia.id):return chains.sepolia}return viem.defineChain({id:n.chainId,name:n.name,nativeCurrency:{name:n.nativeInfo.name,symbol:n.nativeInfo.symbol,decimals:n.nativeInfo.decimals},rpcUrls:{default:{http:[n.rpcUrl]}},blockExplorers:{default:{name:`${n.name} Explorer`,url:n.explorerUrl}}})}function fn(n){return n.map(W)}function Tn(n,e,r){return types.ResultAsync.fromPromise(e.getChainId(),t=>core.SigningError.from(t)).andThen(t=>t===r.chainId?types.okAsync():h(n,{chainId:r.chainId},{batch:false}).andThen(a=>(types.invariant(a,`Chain ${r.chainId} is not supported`),types.ResultAsync.fromPromise(e.switchChain({id:r.chainId}),o=>core.SigningError.from(o)).orElse(o=>(m(o.cause)?o.cause.code:j(o.cause)?o.cause.data?.originalError?.code:void 0)===viem.SwitchChainError.code?types.ResultAsync.fromPromise(e.addChain({chain:W(a)}),u=>m(u)&&u.code===viem.UserRejectedRequestError.code?core.CancelError.from(u):core.SigningError.from(u)):o.asResultAsync()))))}function G(n,e){return types.ResultAsync.fromPromise(actions.estimateGas(n,{account:n.account,data:e.data,to:e.to,value:BigInt(e.value)}),r=>core.SigningError.from(r)).map(r=>r*115n/100n)}function K(n,e){return G(n,e).andThen(r=>types.ResultAsync.fromPromise(actions.sendTransaction(n,{account:n.account,data:e.data,to:e.to,value:BigInt(e.value),chain:n.chain,gas:r}),t=>{if(t instanceof viem.TransactionExecutionError){let a=t.walk(o=>o instanceof viem.UserRejectedRequestError);if(a)return core.CancelError.from(a)}return core.SigningError.from(t)})).map(types.txHash)}function L(n){return n.account!==void 0}function $(n,e){return types.invariant(L(n),"Wallet client with account is required"),K(n,e)}function N(n,e,r){let t=n?.blockExplorers?.default?.url,a=t&&new URL(`/tx/${e}`,t).toString();return core.TransactionError.new({txHash:e,request:r,link:a})}function Y(n,e,r){return types.ResultAsync.fromPromise(actions.waitForTransactionReceipt(n,{hash:r,pollingInterval:100,retryCount:20,retryDelay:50}),t=>core.UnexpectedError.from(t)).andThen(t=>{let a=types.txHash(t.transactionHash);switch(t.status){case "reverted":return r!==a?types.errAsync(core.CancelError.from(`Transaction replaced by ${a}`)):types.errAsync(N(n.chain,a,e));case "success":return types.okAsync({txHash:a,operations:e.operations})}})}function c(n,e){return $(n,e).andThen(r=>Y(n,e,r))}function A(n,e){switch(e.__typename){case "TransactionRequest":return c(n,e);case "Erc20ApprovalRequired":return e.approvals.reduce((r,t)=>r.andThen(()=>c(n,t.byTransaction)),types.okAsync(void 0)).andThen(()=>c(n,e.originalTransaction));case "PreContractActionRequired":return c(n,e.transaction).andThen(()=>c(n,e.originalTransaction));case "InsufficientBalanceError":return types.errAsync(core.ValidationError.fromGqlNode(e))}}function hn(n,e){return e?A(n,e):A.bind(null,n)}function z(n,e){return e===void 0?g.bind(null,n):g(n,e)}function En(n,e){return e().andThen(r=>{if(E(r)){let t=r.approvals[0].bySignature;return z(n,t).map(a=>({deadline:t.message.deadline,value:a})).andThen(a=>e(a))}return types.okAsync(r)})}exports.ensureChain=Tn;exports.permitWith=En;exports.sendTransaction=$;exports.sendWith=hn;exports.signTypedDataWith=z;exports.toViemChain=W;exports.transactionError=N;exports.viemChainsFrom=fn;exports.waitForTransactionResult=Y;//# sourceMappingURL=viem.cjs.map
1
+ 'use strict';var core=require('@aave/core'),types=require('@aave/types'),viem=require('viem'),actions=require('viem/actions'),chains=require('viem/chains'),graphql=require('@aave/graphql');var p={currency:graphql.Currency.Usd,timeWindow:graphql.TimeWindow.LastDay,requestPolicy:"cache-and-network",batch:true};function h(e,n,{batch:r=p.batch,requestPolicy:t=p.requestPolicy}=p){return e.query(graphql.ChainQuery,{request:n},{batch:r,requestPolicy:t})}function H(e){return typeof e=="object"&&e!==null&&"approvals"in e&&Array.isArray(e.approvals)}function E(e){return H(e)&&types.isOneEntryArray(e.approvals)&&!!e.approvals[0].bySignature}function m(e){return types.isObject(e)&&"code"in e&&"message"in e}function j(e){return types.isObject(e)&&"name"in e&&"message"in e&&"originalError"in e?m(e.originalError)&&"code"in e.originalError:true}function g(e,n){return types.invariant(e.account,"Wallet account is required to sign typed data"),types.ResultAsync.fromPromise(e.signTypedData({account:e.account,domain:n.domain,types:n.types,primaryType:n.primaryType,message:n.message}),r=>r instanceof viem.UserRejectedRequestError?core.CancelError.from(r):core.SigningError.from(r)).map(types.signatureFrom)}function W(e){switch(e.chainId){case types.chainId(chains.mainnet.id):return chains.mainnet;case types.chainId(chains.sepolia.id):return chains.sepolia}return viem.defineChain({id:e.chainId,name:e.name,nativeCurrency:{name:e.nativeInfo.name,symbol:e.nativeInfo.symbol,decimals:e.nativeInfo.decimals},rpcUrls:{default:{http:[e.rpcUrl]}},blockExplorers:{default:{name:`${e.name} Explorer`,url:e.explorerUrl}}})}function me(e){return e.map(W)}function fe(e,n,r){return types.ResultAsync.fromPromise(n.getChainId(),t=>core.SigningError.from(t)).andThen(t=>t===r.chainId?types.okAsync():h(e,{chainId:r.chainId},{batch:false}).andThen(a=>(types.invariant(a,`Chain ${r.chainId} is not supported`),types.ResultAsync.fromPromise(n.switchChain({id:r.chainId}),o=>core.SigningError.from(o)).orElse(o=>(m(o.cause)?o.cause.code:j(o.cause)?o.cause.data?.originalError?.code:void 0)===viem.SwitchChainError.code?types.ResultAsync.fromPromise(n.addChain({chain:W(a)}),u=>m(u)&&u.code===viem.UserRejectedRequestError.code?core.CancelError.from(u):core.SigningError.from(u)):o.asResultAsync()))))}function G(e,n){return types.ResultAsync.fromPromise(actions.estimateGas(e,{account:e.account,data:n.data,to:n.to,value:BigInt(n.value),prepare:false}),r=>core.SigningError.from(r)).map(r=>r*115n/100n)}function K(e,n){return G(e,n).andThen(r=>types.ResultAsync.fromPromise(actions.sendTransaction(e,{account:e.account,data:n.data,to:n.to,value:BigInt(n.value),chain:e.chain,gas:r}),t=>{if(t instanceof viem.TransactionExecutionError){let a=t.walk(o=>o instanceof viem.UserRejectedRequestError);if(a)return core.CancelError.from(a)}return core.SigningError.from(t)})).map(types.txHash)}function L(e){return e.account!==void 0}function $(e,n){return types.invariant(L(e),"Wallet client with account is required"),K(e,n)}function N(e,n,r){let t=e?.blockExplorers?.default?.url,a=t&&new URL(`/tx/${n}`,t).toString();return core.TransactionError.new({txHash:n,request:r,link:a})}function Y(e,n,r){return types.ResultAsync.fromPromise(actions.waitForTransactionReceipt(e,{hash:r,pollingInterval:100,retryCount:20,retryDelay:50}),t=>core.UnexpectedError.from(t)).andThen(t=>{let a=types.txHash(t.transactionHash);switch(t.status){case "reverted":return r!==a?types.errAsync(core.CancelError.from(`Transaction replaced by ${a}`)):types.errAsync(N(e.chain,a,n));case "success":return types.okAsync({txHash:a,operations:n.operations})}})}function c(e,n){return $(e,n).andThen(r=>Y(e,n,r))}function A(e,n){switch(n.__typename){case "TransactionRequest":return c(e,n);case "Erc20ApprovalRequired":return n.approvals.reduce((r,t)=>r.andThen(()=>c(e,t.byTransaction)),types.okAsync(void 0)).andThen(()=>c(e,n.originalTransaction));case "PreContractActionRequired":return c(e,n.transaction).andThen(()=>c(e,n.originalTransaction));case "InsufficientBalanceError":return types.errAsync(core.ValidationError.fromGqlNode(n))}}function Te(e,n){return n?A(e,n):A.bind(null,e)}function z(e,n){return n===void 0?g.bind(null,e):g(e,n)}function he(e,n){return n().andThen(r=>{if(E(r)){let t=r.approvals[0].bySignature;return z(e,t).map(a=>({deadline:t.message.deadline,value:a})).andThen(a=>n(a))}return types.okAsync(r)})}exports.ensureChain=fe;exports.permitWith=he;exports.sendTransaction=$;exports.sendWith=Te;exports.signTypedDataWith=z;exports.toViemChain=W;exports.transactionError=N;exports.viemChainsFrom=me;exports.waitForTransactionResult=Y;//# sourceMappingURL=viem.cjs.map
2
2
  //# sourceMappingURL=viem.cjs.map
package/dist/viem.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/options.ts","../src/actions/misc.ts","../src/adapters.ts","../src/viem.ts"],"names":["DEFAULT_QUERY_OPTIONS","Currency","TimeWindow","chain","client","request","batch","requestPolicy","ChainQuery","hasApprovals","plan","supportsPermit","isOneEntryArray","isRpcError","err","isObject","isProviderRpcError","signTypedData","walletClient","data","invariant","ResultAsync","UserRejectedRequestError","CancelError","SigningError","signatureFrom","toViemChain","chainId","mainnet","sepolia","defineChain","viemChainsFrom","chains","ensureChain","aaveClient","okAsync","SwitchChainError","estimateGas","estimateGasWithViem","gas","sendEip1559Transaction","sendTransactionWithViem","TransactionExecutionError","rejected","txHash","isWalletClientWithAccount","sendTransaction","transactionError","baseUrl","link","TransactionError","waitForTransactionResult","initialTxHash","waitForTransactionReceipt","UnexpectedError","receipt","hash","errAsync","sendTransactionAndWait","executePlan","result","approval","ValidationError","sendWith","signTypedDataWith","permitWith","action","permitTypedData","signature","permitSig"],"mappings":"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","file":"viem.cjs","sourcesContent":["import { Currency, TimeWindow } from '@aave/graphql';\nimport type { RequestPolicy } from '@urql/core';\n\nexport type CurrencyQueryOptions = {\n /**\n * The currency for fiat amounts.\n *\n * @defaultValue {@link Currency.Usd}\n */\n currency?: Currency;\n};\n\nexport type TimeWindowQueryOptions = {\n /**\n * The time window for historical data changes.\n *\n * @defaultValue {@link TimeWindow.LastDay}\n */\n timeWindow?: TimeWindow;\n};\n\n/**\n * @internal\n */\nexport type RequestPolicyOptions = {\n /**\n * The request policy to use.\n *\n * @internal This is used for testing purposes and could be changed without notice.\n * @defaultValue `cache-and-network`\n */\n requestPolicy?: RequestPolicy;\n};\n\n/**\n * @internal\n */\nexport type BatchOptions = {\n /**\n * Whether to batch the query or not.\n *\n * @internal This is used to turn off batching for a single query.\n * @defaultValue `true`\n */\n batch?: boolean;\n};\n\nexport const DEFAULT_QUERY_OPTIONS = {\n currency: Currency.Usd,\n timeWindow: TimeWindow.LastDay,\n requestPolicy: 'cache-and-network',\n batch: true,\n} as const;\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type Chain,\n ChainQuery,\n type ChainRequest,\n ChainsQuery,\n type ChainsRequest,\n type ExchangeAmount,\n ExchangeRateQuery,\n type ExchangeRateRequest,\n HasProcessedKnownTransactionQuery,\n type HasProcessedKnownTransactionRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport {\n type BatchOptions,\n DEFAULT_QUERY_OPTIONS,\n type RequestPolicyOptions,\n} from '../options';\n\n/**\n * Fetches a specific chain by chain ID.\n *\n * ```ts\n * const result = await chain(client, {\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The chain request parameters.\n * @param options - The query options.\n * @returns The chain data, or null if not found.\n */\nexport function chain(\n client: AaveClient,\n request: ChainRequest,\n {\n batch = DEFAULT_QUERY_OPTIONS.batch,\n requestPolicy = DEFAULT_QUERY_OPTIONS.requestPolicy,\n }: BatchOptions & RequestPolicyOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<Chain | null, UnexpectedError> {\n return client.query(ChainQuery, { request }, { batch, requestPolicy });\n}\n\n/**\n * Fetches the list of supported chains.\n *\n * ```ts\n * const chains = await chains(client, {\n * query: { filter: ChainsFilter.ALL }\n * });\n * ```\n *\n * ```ts\n * const chains = await chains(client, {\n * query: { chainIds: [chainId(1), chainId(137)] }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The chains request parameters.\n * @returns Array of supported chains.\n */\nexport function chains(\n client: AaveClient,\n request: ChainsRequest,\n): ResultAsync<Chain[], UnexpectedError> {\n return client.query(ChainsQuery, { request });\n}\n\n/**\n * Check if a transaction has been processed by the Aave API.\n *\n * @param client - Aave client.\n * @param request - The request containing transaction hash and operations to check.\n * @returns True if the transaction has been processed, false otherwise.\n */\nexport function hasProcessedKnownTransaction(\n client: AaveClient,\n request: HasProcessedKnownTransactionRequest,\n): ResultAsync<boolean, UnexpectedError> {\n return client.query(\n HasProcessedKnownTransactionQuery,\n { request },\n {\n requestPolicy: 'network-only', // alwats hit the network\n batch: false, // never batch, always run ASAP\n },\n );\n}\n\n/**\n * Fetches the exchange rate between tokens and fiat currencies.\n *\n * ```ts\n * const result = await exchangeRate(client, {\n * from: { erc20: { chainId: chainId(1), address: evmAddress('0xA0b86a33E6...') } },\n * to: Currency.Usd,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The exchange rate request parameters.\n * @param options - The query options.\n * @returns The exchange rate information as a fiat amount.\n */\nexport function exchangeRate(\n client: AaveClient,\n request: ExchangeRateRequest,\n {\n requestPolicy = DEFAULT_QUERY_OPTIONS.requestPolicy,\n }: RequestPolicyOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<ExchangeAmount, UnexpectedError> {\n return client.query(ExchangeRateQuery, { request }, { requestPolicy });\n}\n","import type { Erc20Approval, PermitTypedData } from '@aave/graphql';\nimport { isOneEntryArray } from '@aave/types';\n\ntype WithApprovals = { approvals: Erc20Approval[] };\n\nfunction hasApprovals(plan: unknown): plan is WithApprovals {\n return (\n typeof plan === 'object' &&\n plan !== null &&\n 'approvals' in plan &&\n Array.isArray(plan.approvals)\n );\n}\n\n/**\n * Checks if a plan supports permit (single approval with bySignature).\n * Works with union types - picks any member that has an `approvals` array\n * with a single entry containing `bySignature`.\n *\n * @internal\n */\nexport function supportsPermit<T>(plan: T): plan is T &\n Extract<T, WithApprovals> & {\n approvals: [Erc20Approval & { bySignature: PermitTypedData }];\n } {\n return (\n hasApprovals(plan) &&\n isOneEntryArray(plan.approvals) &&\n !!plan.approvals[0].bySignature\n );\n}\n","import {\n CancelError,\n SigningError,\n TransactionError,\n UnexpectedError,\n ValidationError,\n} from '@aave/core';\nimport type {\n Chain,\n ERC20PermitSignature,\n ExecutionPlan,\n TransactionRequest,\n} from '@aave/graphql';\nimport {\n chainId,\n errAsync,\n invariant,\n isObject,\n okAsync,\n ResultAsync,\n type Signature,\n signatureFrom,\n type TxHash,\n txHash,\n} from '@aave/types';\nimport {\n type Account,\n defineChain,\n type ProviderRpcError,\n type RpcError,\n SwitchChainError,\n TransactionExecutionError,\n type Transport,\n UserRejectedRequestError,\n type Chain as ViemChain,\n type WalletClient,\n} from 'viem';\nimport {\n estimateGas as estimateGasWithViem,\n sendTransaction as sendTransactionWithViem,\n waitForTransactionReceipt,\n} from 'viem/actions';\nimport { mainnet, sepolia } from 'viem/chains';\nimport type { AaveClient } from './AaveClient';\nimport { chain as fetchChain } from './actions';\nimport { supportsPermit } from './adapters';\nimport type {\n ExecutionPlanHandler,\n SignTypedDataError,\n TransactionResult,\n TypedData,\n TypedDataHandler,\n} from './types';\n\nfunction isRpcError(err: unknown): err is RpcError {\n return isObject(err) && 'code' in err && 'message' in err;\n}\n\nfunction isProviderRpcError(\n err: unknown,\n): err is ProviderRpcError<{ originalError?: { code: number } }> {\n return isObject(err) &&\n 'name' in err &&\n 'message' in err &&\n 'originalError' in err\n ? isRpcError(err.originalError) && 'code' in err.originalError\n : true;\n}\n\nfunction signTypedData(\n walletClient: WalletClient,\n data: TypedData,\n): ResultAsync<Signature, SignTypedDataError> {\n invariant(\n walletClient.account,\n 'Wallet account is required to sign typed data',\n );\n\n return ResultAsync.fromPromise(\n walletClient.signTypedData({\n account: walletClient.account,\n domain: data.domain,\n types: data.types,\n primaryType: data.primaryType,\n message: data.message,\n }),\n (err) => {\n if (err instanceof UserRejectedRequestError) {\n return CancelError.from(err);\n }\n return SigningError.from(err);\n },\n ).map(signatureFrom);\n}\n\n/**\n * @internal\n */\nexport function toViemChain(chain: Chain): ViemChain {\n // known chains\n switch (chain.chainId) {\n case chainId(mainnet.id):\n return mainnet;\n\n case chainId(sepolia.id):\n return sepolia;\n }\n\n // most likely a tenderly fork\n return defineChain({\n id: chain.chainId,\n name: chain.name,\n nativeCurrency: {\n name: chain.nativeInfo.name,\n symbol: chain.nativeInfo.symbol,\n decimals: chain.nativeInfo.decimals,\n },\n rpcUrls: { default: { http: [chain.rpcUrl] } },\n blockExplorers: {\n default: {\n name: `${chain.name} Explorer`,\n url: chain.explorerUrl,\n },\n },\n });\n}\n\n/**\n * @internal\n */\nexport function viemChainsFrom(chains: Chain[]): ViemChain[] {\n return chains.map(toViemChain);\n}\n\n/**\n * @internal\n */\nexport function ensureChain(\n aaveClient: AaveClient,\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<void, CancelError | SigningError | UnexpectedError> {\n return ResultAsync.fromPromise(walletClient.getChainId(), (err) =>\n SigningError.from(err),\n ).andThen((chainId) => {\n if (chainId === request.chainId) {\n return okAsync();\n }\n\n return fetchChain(\n aaveClient,\n { chainId: request.chainId },\n { batch: false },\n ).andThen((chain) => {\n invariant(chain, `Chain ${request.chainId} is not supported`);\n\n return ResultAsync.fromPromise(\n walletClient.switchChain({ id: request.chainId }),\n (err) => SigningError.from(err),\n ).orElse((err) => {\n const code = isRpcError(err.cause)\n ? err.cause.code\n : // Unwrapping for MetaMask Mobile\n // https://github.com/MetaMask/metamask-mobile/issues/2944#issuecomment-976988719\n isProviderRpcError(err.cause)\n ? err.cause.data?.originalError?.code\n : undefined;\n\n if (code === SwitchChainError.code) {\n return ResultAsync.fromPromise(\n walletClient.addChain({ chain: toViemChain(chain) }),\n (err) => {\n if (\n isRpcError(err) &&\n err.code === UserRejectedRequestError.code\n ) {\n return CancelError.from(err);\n }\n return SigningError.from(err);\n },\n );\n }\n\n return err.asResultAsync();\n });\n });\n });\n}\n\nfunction estimateGas(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<bigint, SigningError> {\n return ResultAsync.fromPromise(\n estimateGasWithViem(walletClient, {\n account: walletClient.account,\n data: request.data,\n to: request.to,\n value: BigInt(request.value),\n }),\n (err) => SigningError.from(err),\n ).map((gas) => (gas * 115n) / 100n); // 15% buffer\n}\n\nfunction sendEip1559Transaction(\n walletClient: WalletClient<Transport, ViemChain, Account>,\n request: TransactionRequest,\n): ResultAsync<TxHash, CancelError | SigningError> {\n return estimateGas(walletClient, request)\n .andThen((gas) =>\n ResultAsync.fromPromise(\n sendTransactionWithViem(walletClient, {\n account: walletClient.account,\n data: request.data,\n to: request.to,\n value: BigInt(request.value),\n chain: walletClient.chain,\n gas,\n }),\n (err) => {\n if (err instanceof TransactionExecutionError) {\n const rejected = err.walk(\n (err) => err instanceof UserRejectedRequestError,\n );\n\n if (rejected) {\n return CancelError.from(rejected);\n }\n }\n return SigningError.from(err);\n },\n ),\n )\n .map(txHash);\n}\n\nfunction isWalletClientWithAccount(\n walletClient: WalletClient,\n): walletClient is WalletClient<Transport, ViemChain, Account> {\n return walletClient.account !== undefined;\n}\n\n/**\n * @internal\n */\nexport function sendTransaction(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<TxHash, CancelError | SigningError> {\n invariant(\n isWalletClientWithAccount(walletClient),\n 'Wallet client with account is required',\n );\n\n return sendEip1559Transaction(walletClient, request);\n}\n\n/**\n * @internal\n */\nexport function transactionError(\n chain: ViemChain | undefined,\n txHash: TxHash,\n request: TransactionRequest,\n): TransactionError {\n const baseUrl = chain?.blockExplorers?.default?.url;\n const link = baseUrl && new URL(`/tx/${txHash}`, baseUrl).toString();\n\n return TransactionError.new({ txHash, request, link });\n}\n\n/**\n * @internal\n */\nexport function waitForTransactionResult(\n walletClient: WalletClient,\n request: TransactionRequest,\n initialTxHash: TxHash,\n): ResultAsync<\n TransactionResult,\n CancelError | TransactionError | UnexpectedError\n> {\n return ResultAsync.fromPromise(\n waitForTransactionReceipt(walletClient, {\n hash: initialTxHash,\n pollingInterval: 100,\n retryCount: 20,\n retryDelay: 50,\n }),\n (err) => UnexpectedError.from(err),\n ).andThen((receipt) => {\n const hash = txHash(receipt.transactionHash);\n\n switch (receipt.status) {\n case 'reverted':\n if (initialTxHash !== hash) {\n return errAsync(CancelError.from(`Transaction replaced by ${hash}`));\n }\n return errAsync(transactionError(walletClient.chain, hash, request));\n case 'success':\n return okAsync({\n // viem's waitForTransactionReceipt supports transaction replacement\n // so it's important to use the transaction hash from the receipt\n txHash: hash,\n operations: request.operations,\n });\n }\n });\n}\n\nfunction sendTransactionAndWait(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<\n TransactionResult,\n CancelError | SigningError | TransactionError | UnexpectedError\n> {\n return sendTransaction(walletClient, request).andThen((hash) =>\n waitForTransactionResult(walletClient, request, hash),\n );\n}\n\nfunction executePlan(\n walletClient: WalletClient,\n result: ExecutionPlan,\n): ReturnType<ExecutionPlanHandler> {\n switch (result.__typename) {\n case 'TransactionRequest':\n return sendTransactionAndWait(walletClient, result);\n\n case 'Erc20ApprovalRequired':\n return result.approvals\n .reduce<ReturnType<typeof sendTransactionAndWait>>(\n (chain, approval) =>\n chain.andThen(() =>\n sendTransactionAndWait(walletClient, approval.byTransaction),\n ),\n okAsync(undefined as never),\n )\n .andThen(() =>\n sendTransactionAndWait(walletClient, result.originalTransaction),\n );\n\n case 'PreContractActionRequired':\n return sendTransactionAndWait(walletClient, result.transaction).andThen(\n () => sendTransactionAndWait(walletClient, result.originalTransaction),\n );\n\n case 'InsufficientBalanceError':\n return errAsync(ValidationError.fromGqlNode(result));\n }\n}\n\n/**\n * Creates an execution plan handler that sends transactions using the provided wallet client.\n */\nexport function sendWith(walletClient: WalletClient): ExecutionPlanHandler;\n/**\n * Sends execution plan transactions using the provided wallet client.\n */\nexport function sendWith<T extends ExecutionPlan = ExecutionPlan>(\n walletClient: WalletClient,\n result: T,\n): ReturnType<ExecutionPlanHandler<T>>;\nexport function sendWith<T extends ExecutionPlan = ExecutionPlan>(\n walletClient: WalletClient,\n result?: T,\n): ExecutionPlanHandler<T> | ReturnType<ExecutionPlanHandler<T>> {\n return result\n ? executePlan(walletClient, result)\n : executePlan.bind(null, walletClient);\n}\n\n/**\n * Creates a function that signs EIP-712 typed data (ERC-20 permits, swap intents, etc.) using the provided wallet client.\n *\n * @param walletClient - The wallet client to use for signing.\n * @returns A function that takes typed data and returns a ResultAsync containing the raw signature.\n *\n * ```ts\n * const result = await prepareSwapCancel(client, request)\n * .andThen(signTypedDataWith(wallet));\n * ```\n */\nexport function signTypedDataWith(walletClient: WalletClient): TypedDataHandler;\n\n/**\n * Signs EIP-712 typed data (ERC-20 permits, swap intents, etc.) using the provided wallet client.\n *\n * @param walletClient - The wallet client to use for signing.\n * @param data - The typed data to sign.\n * @returns A ResultAsync containing the raw signature.\n *\n * ```ts\n * const result = await signTypedDataWith(wallet, typedData);\n * ```\n */\nexport function signTypedDataWith(\n walletClient: WalletClient,\n data: TypedData,\n): ReturnType<TypedDataHandler>;\n\nexport function signTypedDataWith(\n walletClient: WalletClient,\n data?: TypedData,\n): TypedDataHandler | ReturnType<TypedDataHandler> {\n if (data === undefined) {\n return signTypedData.bind(null, walletClient);\n }\n return signTypedData(walletClient, data);\n}\n\n/**\n * Handles ERC20 permit signing for actions that require token approval.\n *\n * Calls the action to get an initial execution plan. If the plan requires ERC20 approval\n * and the token supports permit signatures, signs the permit and re-calls the action\n * with the signature to get a new plan that can be sent directly.\n *\n * ```ts\n * const result = await permitWith(walletClient, (permitSig) =>\n * supply(client, {\n * reserve: reserve.id,\n * amount: { erc20: { value: amount, permitSig } },\n * sender: evmAddress(walletClient.account.address),\n * })\n * )\n * .andThen(sendWith(walletClient))\n * .andThen(client.waitForTransaction);\n * ```\n *\n * @param walletClient - The wallet client to use for signing permits.\n * @param action - A function that returns an execution plan, accepting an optional permit signature.\n * @returns A ResultAsync containing the resolved ExecutionPlan ready to be sent with `sendWith`.\n */\nexport function permitWith<E>(\n walletClient: WalletClient,\n action: (permitSig?: ERC20PermitSignature) => ResultAsync<ExecutionPlan, E>,\n): ResultAsync<ExecutionPlan, E | SignTypedDataError> {\n return action().andThen((result) => {\n if (supportsPermit(result)) {\n const permitTypedData = result.approvals[0].bySignature;\n // Sign and wrap with deadline\n return signTypedDataWith(walletClient, permitTypedData)\n .map((signature) => ({\n deadline: permitTypedData.message.deadline as number,\n value: signature,\n }))\n .andThen((permitSig) => action(permitSig));\n }\n return okAsync(result);\n });\n}\n"]}
1
+ {"version":3,"sources":["../src/options.ts","../src/actions/misc.ts","../src/adapters.ts","../src/viem.ts"],"names":["DEFAULT_QUERY_OPTIONS","Currency","TimeWindow","chain","client","request","batch","requestPolicy","ChainQuery","hasApprovals","plan","supportsPermit","isOneEntryArray","isRpcError","err","isObject","isProviderRpcError","signTypedData","walletClient","data","invariant","ResultAsync","UserRejectedRequestError","CancelError","SigningError","signatureFrom","toViemChain","chainId","mainnet","sepolia","defineChain","viemChainsFrom","chains","ensureChain","aaveClient","okAsync","SwitchChainError","estimateGas","estimateGasWithViem","gas","sendEip1559Transaction","sendTransactionWithViem","TransactionExecutionError","rejected","txHash","isWalletClientWithAccount","sendTransaction","transactionError","baseUrl","link","TransactionError","waitForTransactionResult","initialTxHash","waitForTransactionReceipt","UnexpectedError","receipt","hash","errAsync","sendTransactionAndWait","executePlan","result","approval","ValidationError","sendWith","signTypedDataWith","permitWith","action","permitTypedData","signature","permitSig"],"mappings":"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","file":"viem.cjs","sourcesContent":["import { Currency, TimeWindow } from '@aave/graphql';\nimport type { RequestPolicy } from '@urql/core';\n\nexport type CurrencyQueryOptions = {\n /**\n * The currency for fiat amounts.\n *\n * @defaultValue {@link Currency.Usd}\n */\n currency?: Currency;\n};\n\nexport type TimeWindowQueryOptions = {\n /**\n * The time window for historical data changes.\n *\n * @defaultValue {@link TimeWindow.LastDay}\n */\n timeWindow?: TimeWindow;\n};\n\n/**\n * @internal\n */\nexport type RequestPolicyOptions = {\n /**\n * The request policy to use.\n *\n * @internal This is used for testing purposes and could be changed without notice.\n * @defaultValue `cache-and-network`\n */\n requestPolicy?: RequestPolicy;\n};\n\n/**\n * @internal\n */\nexport type BatchOptions = {\n /**\n * Whether to batch the query or not.\n *\n * @internal This is used to turn off batching for a single query.\n * @defaultValue `true`\n */\n batch?: boolean;\n};\n\nexport const DEFAULT_QUERY_OPTIONS = {\n currency: Currency.Usd,\n timeWindow: TimeWindow.LastDay,\n requestPolicy: 'cache-and-network',\n batch: true,\n} as const;\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type Chain,\n ChainQuery,\n type ChainRequest,\n ChainsQuery,\n type ChainsRequest,\n type ExchangeAmount,\n ExchangeRateQuery,\n type ExchangeRateRequest,\n HasProcessedKnownTransactionQuery,\n type HasProcessedKnownTransactionRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport {\n type BatchOptions,\n DEFAULT_QUERY_OPTIONS,\n type RequestPolicyOptions,\n} from '../options';\n\n/**\n * Fetches a specific chain by chain ID.\n *\n * ```ts\n * const result = await chain(client, {\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The chain request parameters.\n * @param options - The query options.\n * @returns The chain data, or null if not found.\n */\nexport function chain(\n client: AaveClient,\n request: ChainRequest,\n {\n batch = DEFAULT_QUERY_OPTIONS.batch,\n requestPolicy = DEFAULT_QUERY_OPTIONS.requestPolicy,\n }: BatchOptions & RequestPolicyOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<Chain | null, UnexpectedError> {\n return client.query(ChainQuery, { request }, { batch, requestPolicy });\n}\n\n/**\n * Fetches the list of supported chains.\n *\n * ```ts\n * const chains = await chains(client, {\n * query: { filter: ChainsFilter.ALL }\n * });\n * ```\n *\n * ```ts\n * const chains = await chains(client, {\n * query: { chainIds: [chainId(1), chainId(137)] }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The chains request parameters.\n * @returns Array of supported chains.\n */\nexport function chains(\n client: AaveClient,\n request: ChainsRequest,\n): ResultAsync<Chain[], UnexpectedError> {\n return client.query(ChainsQuery, { request });\n}\n\n/**\n * Check if a transaction has been processed by the Aave API.\n *\n * @param client - Aave client.\n * @param request - The request containing transaction hash and operations to check.\n * @returns True if the transaction has been processed, false otherwise.\n */\nexport function hasProcessedKnownTransaction(\n client: AaveClient,\n request: HasProcessedKnownTransactionRequest,\n): ResultAsync<boolean, UnexpectedError> {\n return client.query(\n HasProcessedKnownTransactionQuery,\n { request },\n {\n requestPolicy: 'network-only', // alwats hit the network\n batch: false, // never batch, always run ASAP\n },\n );\n}\n\n/**\n * Fetches the exchange rate between tokens and fiat currencies.\n *\n * ```ts\n * const result = await exchangeRate(client, {\n * from: { erc20: { chainId: chainId(1), address: evmAddress('0xA0b86a33E6...') } },\n * to: Currency.Usd,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The exchange rate request parameters.\n * @param options - The query options.\n * @returns The exchange rate information as a fiat amount.\n */\nexport function exchangeRate(\n client: AaveClient,\n request: ExchangeRateRequest,\n {\n requestPolicy = DEFAULT_QUERY_OPTIONS.requestPolicy,\n }: RequestPolicyOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<ExchangeAmount, UnexpectedError> {\n return client.query(ExchangeRateQuery, { request }, { requestPolicy });\n}\n","import type { Erc20Approval, PermitTypedData } from '@aave/graphql';\nimport { isOneEntryArray } from '@aave/types';\n\ntype WithApprovals = { approvals: Erc20Approval[] };\n\nfunction hasApprovals(plan: unknown): plan is WithApprovals {\n return (\n typeof plan === 'object' &&\n plan !== null &&\n 'approvals' in plan &&\n Array.isArray(plan.approvals)\n );\n}\n\n/**\n * Checks if a plan supports permit (single approval with bySignature).\n * Works with union types - picks any member that has an `approvals` array\n * with a single entry containing `bySignature`.\n *\n * @internal\n */\nexport function supportsPermit<T>(plan: T): plan is T &\n Extract<T, WithApprovals> & {\n approvals: [Erc20Approval & { bySignature: PermitTypedData }];\n } {\n return (\n hasApprovals(plan) &&\n isOneEntryArray(plan.approvals) &&\n !!plan.approvals[0].bySignature\n );\n}\n","import {\n CancelError,\n SigningError,\n TransactionError,\n UnexpectedError,\n ValidationError,\n} from '@aave/core';\nimport type {\n Chain,\n ERC20PermitSignature,\n ExecutionPlan,\n TransactionRequest,\n} from '@aave/graphql';\nimport {\n chainId,\n errAsync,\n invariant,\n isObject,\n okAsync,\n ResultAsync,\n type Signature,\n signatureFrom,\n type TxHash,\n txHash,\n} from '@aave/types';\nimport {\n type Account,\n defineChain,\n type ProviderRpcError,\n type RpcError,\n SwitchChainError,\n TransactionExecutionError,\n type Transport,\n UserRejectedRequestError,\n type Chain as ViemChain,\n type WalletClient,\n} from 'viem';\nimport {\n estimateGas as estimateGasWithViem,\n sendTransaction as sendTransactionWithViem,\n waitForTransactionReceipt,\n} from 'viem/actions';\nimport { mainnet, sepolia } from 'viem/chains';\nimport type { AaveClient } from './AaveClient';\nimport { chain as fetchChain } from './actions';\nimport { supportsPermit } from './adapters';\nimport type {\n ExecutionPlanHandler,\n SignTypedDataError,\n TransactionResult,\n TypedData,\n TypedDataHandler,\n} from './types';\n\nfunction isRpcError(err: unknown): err is RpcError {\n return isObject(err) && 'code' in err && 'message' in err;\n}\n\nfunction isProviderRpcError(\n err: unknown,\n): err is ProviderRpcError<{ originalError?: { code: number } }> {\n return isObject(err) &&\n 'name' in err &&\n 'message' in err &&\n 'originalError' in err\n ? isRpcError(err.originalError) && 'code' in err.originalError\n : true;\n}\n\nfunction signTypedData(\n walletClient: WalletClient,\n data: TypedData,\n): ResultAsync<Signature, SignTypedDataError> {\n invariant(\n walletClient.account,\n 'Wallet account is required to sign typed data',\n );\n\n return ResultAsync.fromPromise(\n walletClient.signTypedData({\n account: walletClient.account,\n domain: data.domain,\n types: data.types,\n primaryType: data.primaryType,\n message: data.message,\n }),\n (err) => {\n if (err instanceof UserRejectedRequestError) {\n return CancelError.from(err);\n }\n return SigningError.from(err);\n },\n ).map(signatureFrom);\n}\n\n/**\n * @internal\n */\nexport function toViemChain(chain: Chain): ViemChain {\n // known chains\n switch (chain.chainId) {\n case chainId(mainnet.id):\n return mainnet;\n\n case chainId(sepolia.id):\n return sepolia;\n }\n\n // most likely a tenderly fork\n return defineChain({\n id: chain.chainId,\n name: chain.name,\n nativeCurrency: {\n name: chain.nativeInfo.name,\n symbol: chain.nativeInfo.symbol,\n decimals: chain.nativeInfo.decimals,\n },\n rpcUrls: { default: { http: [chain.rpcUrl] } },\n blockExplorers: {\n default: {\n name: `${chain.name} Explorer`,\n url: chain.explorerUrl,\n },\n },\n });\n}\n\n/**\n * @internal\n */\nexport function viemChainsFrom(chains: Chain[]): ViemChain[] {\n return chains.map(toViemChain);\n}\n\n/**\n * @internal\n */\nexport function ensureChain(\n aaveClient: AaveClient,\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<void, CancelError | SigningError | UnexpectedError> {\n return ResultAsync.fromPromise(walletClient.getChainId(), (err) =>\n SigningError.from(err),\n ).andThen((chainId) => {\n if (chainId === request.chainId) {\n return okAsync();\n }\n\n return fetchChain(\n aaveClient,\n { chainId: request.chainId },\n { batch: false },\n ).andThen((chain) => {\n invariant(chain, `Chain ${request.chainId} is not supported`);\n\n return ResultAsync.fromPromise(\n walletClient.switchChain({ id: request.chainId }),\n (err) => SigningError.from(err),\n ).orElse((err) => {\n const code = isRpcError(err.cause)\n ? err.cause.code\n : // Unwrapping for MetaMask Mobile\n // https://github.com/MetaMask/metamask-mobile/issues/2944#issuecomment-976988719\n isProviderRpcError(err.cause)\n ? err.cause.data?.originalError?.code\n : undefined;\n\n if (code === SwitchChainError.code) {\n return ResultAsync.fromPromise(\n walletClient.addChain({ chain: toViemChain(chain) }),\n (err) => {\n if (\n isRpcError(err) &&\n err.code === UserRejectedRequestError.code\n ) {\n return CancelError.from(err);\n }\n return SigningError.from(err);\n },\n );\n }\n\n return err.asResultAsync();\n });\n });\n });\n}\n\nfunction estimateGas(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<bigint, SigningError> {\n return ResultAsync.fromPromise(\n estimateGasWithViem(walletClient, {\n account: walletClient.account,\n data: request.data,\n to: request.to,\n value: BigInt(request.value),\n prepare: false,\n }),\n (err) => SigningError.from(err),\n ).map((gas) => (gas * 115n) / 100n); // 15% buffer\n}\n\nfunction sendEip1559Transaction(\n walletClient: WalletClient<Transport, ViemChain, Account>,\n request: TransactionRequest,\n): ResultAsync<TxHash, CancelError | SigningError> {\n return estimateGas(walletClient, request)\n .andThen((gas) =>\n ResultAsync.fromPromise(\n sendTransactionWithViem(walletClient, {\n account: walletClient.account,\n data: request.data,\n to: request.to,\n value: BigInt(request.value),\n chain: walletClient.chain,\n gas,\n }),\n (err) => {\n if (err instanceof TransactionExecutionError) {\n const rejected = err.walk(\n (err) => err instanceof UserRejectedRequestError,\n );\n\n if (rejected) {\n return CancelError.from(rejected);\n }\n }\n return SigningError.from(err);\n },\n ),\n )\n .map(txHash);\n}\n\nfunction isWalletClientWithAccount(\n walletClient: WalletClient,\n): walletClient is WalletClient<Transport, ViemChain, Account> {\n return walletClient.account !== undefined;\n}\n\n/**\n * @internal\n */\nexport function sendTransaction(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<TxHash, CancelError | SigningError> {\n invariant(\n isWalletClientWithAccount(walletClient),\n 'Wallet client with account is required',\n );\n\n return sendEip1559Transaction(walletClient, request);\n}\n\n/**\n * @internal\n */\nexport function transactionError(\n chain: ViemChain | undefined,\n txHash: TxHash,\n request: TransactionRequest,\n): TransactionError {\n const baseUrl = chain?.blockExplorers?.default?.url;\n const link = baseUrl && new URL(`/tx/${txHash}`, baseUrl).toString();\n\n return TransactionError.new({ txHash, request, link });\n}\n\n/**\n * @internal\n */\nexport function waitForTransactionResult(\n walletClient: WalletClient,\n request: TransactionRequest,\n initialTxHash: TxHash,\n): ResultAsync<\n TransactionResult,\n CancelError | TransactionError | UnexpectedError\n> {\n return ResultAsync.fromPromise(\n waitForTransactionReceipt(walletClient, {\n hash: initialTxHash,\n pollingInterval: 100,\n retryCount: 20,\n retryDelay: 50,\n }),\n (err) => UnexpectedError.from(err),\n ).andThen((receipt) => {\n const hash = txHash(receipt.transactionHash);\n\n switch (receipt.status) {\n case 'reverted':\n if (initialTxHash !== hash) {\n return errAsync(CancelError.from(`Transaction replaced by ${hash}`));\n }\n return errAsync(transactionError(walletClient.chain, hash, request));\n case 'success':\n return okAsync({\n // viem's waitForTransactionReceipt supports transaction replacement\n // so it's important to use the transaction hash from the receipt\n txHash: hash,\n operations: request.operations,\n });\n }\n });\n}\n\nfunction sendTransactionAndWait(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<\n TransactionResult,\n CancelError | SigningError | TransactionError | UnexpectedError\n> {\n return sendTransaction(walletClient, request).andThen((hash) =>\n waitForTransactionResult(walletClient, request, hash),\n );\n}\n\nfunction executePlan(\n walletClient: WalletClient,\n result: ExecutionPlan,\n): ReturnType<ExecutionPlanHandler> {\n switch (result.__typename) {\n case 'TransactionRequest':\n return sendTransactionAndWait(walletClient, result);\n\n case 'Erc20ApprovalRequired':\n return result.approvals\n .reduce<ReturnType<typeof sendTransactionAndWait>>(\n (chain, approval) =>\n chain.andThen(() =>\n sendTransactionAndWait(walletClient, approval.byTransaction),\n ),\n okAsync(undefined as never),\n )\n .andThen(() =>\n sendTransactionAndWait(walletClient, result.originalTransaction),\n );\n\n case 'PreContractActionRequired':\n return sendTransactionAndWait(walletClient, result.transaction).andThen(\n () => sendTransactionAndWait(walletClient, result.originalTransaction),\n );\n\n case 'InsufficientBalanceError':\n return errAsync(ValidationError.fromGqlNode(result));\n }\n}\n\n/**\n * Creates an execution plan handler that sends transactions using the provided wallet client.\n */\nexport function sendWith(walletClient: WalletClient): ExecutionPlanHandler;\n/**\n * Sends execution plan transactions using the provided wallet client.\n */\nexport function sendWith<T extends ExecutionPlan = ExecutionPlan>(\n walletClient: WalletClient,\n result: T,\n): ReturnType<ExecutionPlanHandler<T>>;\nexport function sendWith<T extends ExecutionPlan = ExecutionPlan>(\n walletClient: WalletClient,\n result?: T,\n): ExecutionPlanHandler<T> | ReturnType<ExecutionPlanHandler<T>> {\n return result\n ? executePlan(walletClient, result)\n : executePlan.bind(null, walletClient);\n}\n\n/**\n * Creates a function that signs EIP-712 typed data (ERC-20 permits, swap intents, etc.) using the provided wallet client.\n *\n * @param walletClient - The wallet client to use for signing.\n * @returns A function that takes typed data and returns a ResultAsync containing the raw signature.\n *\n * ```ts\n * const result = await prepareSwapCancel(client, request)\n * .andThen(signTypedDataWith(wallet));\n * ```\n */\nexport function signTypedDataWith(walletClient: WalletClient): TypedDataHandler;\n\n/**\n * Signs EIP-712 typed data (ERC-20 permits, swap intents, etc.) using the provided wallet client.\n *\n * @param walletClient - The wallet client to use for signing.\n * @param data - The typed data to sign.\n * @returns A ResultAsync containing the raw signature.\n *\n * ```ts\n * const result = await signTypedDataWith(wallet, typedData);\n * ```\n */\nexport function signTypedDataWith(\n walletClient: WalletClient,\n data: TypedData,\n): ReturnType<TypedDataHandler>;\n\nexport function signTypedDataWith(\n walletClient: WalletClient,\n data?: TypedData,\n): TypedDataHandler | ReturnType<TypedDataHandler> {\n if (data === undefined) {\n return signTypedData.bind(null, walletClient);\n }\n return signTypedData(walletClient, data);\n}\n\n/**\n * Handles ERC20 permit signing for actions that require token approval.\n *\n * Calls the action to get an initial execution plan. If the plan requires ERC20 approval\n * and the token supports permit signatures, signs the permit and re-calls the action\n * with the signature to get a new plan that can be sent directly.\n *\n * ```ts\n * const result = await permitWith(walletClient, (permitSig) =>\n * supply(client, {\n * reserve: reserve.id,\n * amount: { erc20: { value: amount, permitSig } },\n * sender: evmAddress(walletClient.account.address),\n * })\n * )\n * .andThen(sendWith(walletClient))\n * .andThen(client.waitForTransaction);\n * ```\n *\n * @param walletClient - The wallet client to use for signing permits.\n * @param action - A function that returns an execution plan, accepting an optional permit signature.\n * @returns A ResultAsync containing the resolved ExecutionPlan ready to be sent with `sendWith`.\n */\nexport function permitWith<E>(\n walletClient: WalletClient,\n action: (permitSig?: ERC20PermitSignature) => ResultAsync<ExecutionPlan, E>,\n): ResultAsync<ExecutionPlan, E | SignTypedDataError> {\n return action().andThen((result) => {\n if (supportsPermit(result)) {\n const permitTypedData = result.approvals[0].bySignature;\n // Sign and wrap with deadline\n return signTypedDataWith(walletClient, permitTypedData)\n .map((signature) => ({\n deadline: permitTypedData.message.deadline as number,\n value: signature,\n }))\n .andThen((permitSig) => action(permitSig));\n }\n return okAsync(result);\n });\n}\n"]}
package/dist/viem.js CHANGED
@@ -1,2 +1,2 @@
1
- export{c as ensureChain,i as permitWith,d as sendTransaction,g as sendWith,h as signTypedDataWith,a as toViemChain,e as transactionError,b as viemChainsFrom,f as waitForTransactionResult}from'./chunk-G3SJ4NJN.js';import'./chunk-N4LXBTGY.js';import'./chunk-O65KFH4O.js';//# sourceMappingURL=viem.js.map
1
+ export{c as ensureChain,i as permitWith,d as sendTransaction,g as sendWith,h as signTypedDataWith,a as toViemChain,e as transactionError,b as viemChainsFrom,f as waitForTransactionResult}from'./chunk-2LML4TFR.js';import'./chunk-N4LXBTGY.js';import'./chunk-2GSAKHLR.js';//# sourceMappingURL=viem.js.map
2
2
  //# sourceMappingURL=viem.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aave/client",
3
- "version": "4.0.0-next.47",
3
+ "version": "4.0.0-next.49",
4
4
  "description": "The official TypeScript client for the AaveKit API",
5
5
  "keywords": [
6
6
  "aave",
@@ -88,8 +88,8 @@
88
88
  "@urql/exchange-graphcache": "^8.1.0",
89
89
  "graphql": "^16.11.0",
90
90
  "@aave/core": "1.0.0-next.18",
91
- "@aave/types": "1.0.0-next.8",
92
- "@aave/graphql": "1.0.0-next.33"
91
+ "@aave/graphql": "1.0.0-next.34",
92
+ "@aave/types": "1.0.0-next.8"
93
93
  },
94
94
  "devDependencies": {
95
95
  "@bgd-labs/aave-address-book": "^4.25.3",
@@ -101,14 +101,14 @@
101
101
  "thirdweb": "^5.105.25",
102
102
  "tsup": "^8.5.1",
103
103
  "typescript": "^5.9.2",
104
- "vitest": "^3.2.4",
105
- "viem": "^2.37.5"
104
+ "viem": "^2.47.0",
105
+ "vitest": "^3.2.4"
106
106
  },
107
107
  "peerDependencies": {
108
108
  "@privy-io/server-auth": "^1.28.8",
109
109
  "ethers": "^6.14.4",
110
110
  "thirdweb": "^5.105.25",
111
- "viem": "^2.31.6"
111
+ "viem": "^2.47.0"
112
112
  },
113
113
  "peerDependenciesMeta": {
114
114
  "ethers": {
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-N4LXBTGY.js';import {f}from'./chunk-O65KFH4O.js';import {SigningError,CancelError,TransactionError,UnexpectedError,ValidationError}from'@aave/core';import {chainId,ResultAsync,okAsync,invariant,txHash,errAsync,isObject,signatureFrom}from'@aave/types';import {defineChain,SwitchChainError,UserRejectedRequestError,TransactionExecutionError}from'viem';import {waitForTransactionReceipt,sendTransaction,estimateGas}from'viem/actions';import {sepolia,mainnet}from'viem/chains';function m(n){return isObject(n)&&"code"in n&&"message"in n}function F(n){return isObject(n)&&"name"in n&&"message"in n&&"originalError"in n?m(n.originalError)&&"code"in n.originalError:true}function R(n,e){return invariant(n.account,"Wallet account is required to sign typed data"),ResultAsync.fromPromise(n.signTypedData({account:n.account,domain:e.domain,types:e.types,primaryType:e.primaryType,message:e.message}),r=>r instanceof UserRejectedRequestError?CancelError.from(r):SigningError.from(r)).map(signatureFrom)}function v(n){switch(n.chainId){case chainId(mainnet.id):return mainnet;case chainId(sepolia.id):return sepolia}return defineChain({id:n.chainId,name:n.name,nativeCurrency:{name:n.nativeInfo.name,symbol:n.nativeInfo.symbol,decimals:n.nativeInfo.decimals},rpcUrls:{default:{http:[n.rpcUrl]}},blockExplorers:{default:{name:`${n.name} Explorer`,url:n.explorerUrl}}})}function Y(n){return n.map(v)}function Z(n,e,r){return ResultAsync.fromPromise(e.getChainId(),t=>SigningError.from(t)).andThen(t=>t===r.chainId?okAsync():f(n,{chainId:r.chainId},{batch:false}).andThen(a=>(invariant(a,`Chain ${r.chainId} is not supported`),ResultAsync.fromPromise(e.switchChain({id:r.chainId}),i=>SigningError.from(i)).orElse(i=>(m(i.cause)?i.cause.code:F(i.cause)?i.cause.data?.originalError?.code:void 0)===SwitchChainError.code?ResultAsync.fromPromise(e.addChain({chain:v(a)}),u=>m(u)&&u.code===UserRejectedRequestError.code?CancelError.from(u):SigningError.from(u)):i.asResultAsync()))))}function G(n,e){return ResultAsync.fromPromise(estimateGas(n,{account:n.account,data:e.data,to:e.to,value:BigInt(e.value)}),r=>SigningError.from(r)).map(r=>r*115n/100n)}function $(n,e){return G(n,e).andThen(r=>ResultAsync.fromPromise(sendTransaction(n,{account:n.account,data:e.data,to:e.to,value:BigInt(e.value),chain:n.chain,gas:r}),t=>{if(t instanceof TransactionExecutionError){let a=t.walk(i=>i instanceof UserRejectedRequestError);if(a)return CancelError.from(a)}return SigningError.from(t)})).map(txHash)}function j(n){return n.account!==void 0}function B(n,e){return invariant(j(n),"Wallet client with account is required"),$(n,e)}function _(n,e,r){let t=n?.blockExplorers?.default?.url,a=t&&new URL(`/tx/${e}`,t).toString();return TransactionError.new({txHash:e,request:r,link:a})}function w(n,e,r){return ResultAsync.fromPromise(waitForTransactionReceipt(n,{hash:r,pollingInterval:100,retryCount:20,retryDelay:50}),t=>UnexpectedError.from(t)).andThen(t=>{let a=txHash(t.transactionHash);switch(t.status){case "reverted":return r!==a?errAsync(CancelError.from(`Transaction replaced by ${a}`)):errAsync(_(n.chain,a,e));case "success":return okAsync({txHash:a,operations:e.operations})}})}function s(n,e){return B(n,e).andThen(r=>w(n,e,r))}function C(n,e){switch(e.__typename){case "TransactionRequest":return s(n,e);case "Erc20ApprovalRequired":return e.approvals.reduce((r,t)=>r.andThen(()=>s(n,t.byTransaction)),okAsync(void 0)).andThen(()=>s(n,e.originalTransaction));case "PreContractActionRequired":return s(n,e.transaction).andThen(()=>s(n,e.originalTransaction));case "InsufficientBalanceError":return errAsync(ValidationError.fromGqlNode(e))}}function nn(n,e){return e?C(n,e):C.bind(null,n)}function L(n,e){return e===void 0?R.bind(null,n):R(n,e)}function en(n,e){return e().andThen(r=>{if(a(r)){let t=r.approvals[0].bySignature;return L(n,t).map(a=>({deadline:t.message.deadline,value:a})).andThen(a=>e(a))}return okAsync(r)})}export{v as a,Y as b,Z as c,B as d,_ as e,w as f,nn as g,L as h,en as i};//# sourceMappingURL=chunk-G3SJ4NJN.js.map
2
- //# sourceMappingURL=chunk-G3SJ4NJN.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/viem.ts"],"names":["isRpcError","err","isObject","isProviderRpcError","signTypedData","walletClient","data","invariant","ResultAsync","UserRejectedRequestError","CancelError","SigningError","signatureFrom","toViemChain","chain","chainId","mainnet","sepolia","defineChain","viemChainsFrom","chains","ensureChain","aaveClient","request","okAsync","SwitchChainError","estimateGas","estimateGasWithViem","gas","sendEip1559Transaction","sendTransactionWithViem","TransactionExecutionError","rejected","txHash","isWalletClientWithAccount","sendTransaction","transactionError","baseUrl","link","TransactionError","waitForTransactionResult","initialTxHash","waitForTransactionReceipt","UnexpectedError","receipt","hash","errAsync","sendTransactionAndWait","executePlan","result","approval","ValidationError","sendWith","signTypedDataWith","permitWith","action","supportsPermit","permitTypedData","signature","permitSig"],"mappings":"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","file":"chunk-G3SJ4NJN.js","sourcesContent":["import {\n CancelError,\n SigningError,\n TransactionError,\n UnexpectedError,\n ValidationError,\n} from '@aave/core';\nimport type {\n Chain,\n ERC20PermitSignature,\n ExecutionPlan,\n TransactionRequest,\n} from '@aave/graphql';\nimport {\n chainId,\n errAsync,\n invariant,\n isObject,\n okAsync,\n ResultAsync,\n type Signature,\n signatureFrom,\n type TxHash,\n txHash,\n} from '@aave/types';\nimport {\n type Account,\n defineChain,\n type ProviderRpcError,\n type RpcError,\n SwitchChainError,\n TransactionExecutionError,\n type Transport,\n UserRejectedRequestError,\n type Chain as ViemChain,\n type WalletClient,\n} from 'viem';\nimport {\n estimateGas as estimateGasWithViem,\n sendTransaction as sendTransactionWithViem,\n waitForTransactionReceipt,\n} from 'viem/actions';\nimport { mainnet, sepolia } from 'viem/chains';\nimport type { AaveClient } from './AaveClient';\nimport { chain as fetchChain } from './actions';\nimport { supportsPermit } from './adapters';\nimport type {\n ExecutionPlanHandler,\n SignTypedDataError,\n TransactionResult,\n TypedData,\n TypedDataHandler,\n} from './types';\n\nfunction isRpcError(err: unknown): err is RpcError {\n return isObject(err) && 'code' in err && 'message' in err;\n}\n\nfunction isProviderRpcError(\n err: unknown,\n): err is ProviderRpcError<{ originalError?: { code: number } }> {\n return isObject(err) &&\n 'name' in err &&\n 'message' in err &&\n 'originalError' in err\n ? isRpcError(err.originalError) && 'code' in err.originalError\n : true;\n}\n\nfunction signTypedData(\n walletClient: WalletClient,\n data: TypedData,\n): ResultAsync<Signature, SignTypedDataError> {\n invariant(\n walletClient.account,\n 'Wallet account is required to sign typed data',\n );\n\n return ResultAsync.fromPromise(\n walletClient.signTypedData({\n account: walletClient.account,\n domain: data.domain,\n types: data.types,\n primaryType: data.primaryType,\n message: data.message,\n }),\n (err) => {\n if (err instanceof UserRejectedRequestError) {\n return CancelError.from(err);\n }\n return SigningError.from(err);\n },\n ).map(signatureFrom);\n}\n\n/**\n * @internal\n */\nexport function toViemChain(chain: Chain): ViemChain {\n // known chains\n switch (chain.chainId) {\n case chainId(mainnet.id):\n return mainnet;\n\n case chainId(sepolia.id):\n return sepolia;\n }\n\n // most likely a tenderly fork\n return defineChain({\n id: chain.chainId,\n name: chain.name,\n nativeCurrency: {\n name: chain.nativeInfo.name,\n symbol: chain.nativeInfo.symbol,\n decimals: chain.nativeInfo.decimals,\n },\n rpcUrls: { default: { http: [chain.rpcUrl] } },\n blockExplorers: {\n default: {\n name: `${chain.name} Explorer`,\n url: chain.explorerUrl,\n },\n },\n });\n}\n\n/**\n * @internal\n */\nexport function viemChainsFrom(chains: Chain[]): ViemChain[] {\n return chains.map(toViemChain);\n}\n\n/**\n * @internal\n */\nexport function ensureChain(\n aaveClient: AaveClient,\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<void, CancelError | SigningError | UnexpectedError> {\n return ResultAsync.fromPromise(walletClient.getChainId(), (err) =>\n SigningError.from(err),\n ).andThen((chainId) => {\n if (chainId === request.chainId) {\n return okAsync();\n }\n\n return fetchChain(\n aaveClient,\n { chainId: request.chainId },\n { batch: false },\n ).andThen((chain) => {\n invariant(chain, `Chain ${request.chainId} is not supported`);\n\n return ResultAsync.fromPromise(\n walletClient.switchChain({ id: request.chainId }),\n (err) => SigningError.from(err),\n ).orElse((err) => {\n const code = isRpcError(err.cause)\n ? err.cause.code\n : // Unwrapping for MetaMask Mobile\n // https://github.com/MetaMask/metamask-mobile/issues/2944#issuecomment-976988719\n isProviderRpcError(err.cause)\n ? err.cause.data?.originalError?.code\n : undefined;\n\n if (code === SwitchChainError.code) {\n return ResultAsync.fromPromise(\n walletClient.addChain({ chain: toViemChain(chain) }),\n (err) => {\n if (\n isRpcError(err) &&\n err.code === UserRejectedRequestError.code\n ) {\n return CancelError.from(err);\n }\n return SigningError.from(err);\n },\n );\n }\n\n return err.asResultAsync();\n });\n });\n });\n}\n\nfunction estimateGas(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<bigint, SigningError> {\n return ResultAsync.fromPromise(\n estimateGasWithViem(walletClient, {\n account: walletClient.account,\n data: request.data,\n to: request.to,\n value: BigInt(request.value),\n }),\n (err) => SigningError.from(err),\n ).map((gas) => (gas * 115n) / 100n); // 15% buffer\n}\n\nfunction sendEip1559Transaction(\n walletClient: WalletClient<Transport, ViemChain, Account>,\n request: TransactionRequest,\n): ResultAsync<TxHash, CancelError | SigningError> {\n return estimateGas(walletClient, request)\n .andThen((gas) =>\n ResultAsync.fromPromise(\n sendTransactionWithViem(walletClient, {\n account: walletClient.account,\n data: request.data,\n to: request.to,\n value: BigInt(request.value),\n chain: walletClient.chain,\n gas,\n }),\n (err) => {\n if (err instanceof TransactionExecutionError) {\n const rejected = err.walk(\n (err) => err instanceof UserRejectedRequestError,\n );\n\n if (rejected) {\n return CancelError.from(rejected);\n }\n }\n return SigningError.from(err);\n },\n ),\n )\n .map(txHash);\n}\n\nfunction isWalletClientWithAccount(\n walletClient: WalletClient,\n): walletClient is WalletClient<Transport, ViemChain, Account> {\n return walletClient.account !== undefined;\n}\n\n/**\n * @internal\n */\nexport function sendTransaction(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<TxHash, CancelError | SigningError> {\n invariant(\n isWalletClientWithAccount(walletClient),\n 'Wallet client with account is required',\n );\n\n return sendEip1559Transaction(walletClient, request);\n}\n\n/**\n * @internal\n */\nexport function transactionError(\n chain: ViemChain | undefined,\n txHash: TxHash,\n request: TransactionRequest,\n): TransactionError {\n const baseUrl = chain?.blockExplorers?.default?.url;\n const link = baseUrl && new URL(`/tx/${txHash}`, baseUrl).toString();\n\n return TransactionError.new({ txHash, request, link });\n}\n\n/**\n * @internal\n */\nexport function waitForTransactionResult(\n walletClient: WalletClient,\n request: TransactionRequest,\n initialTxHash: TxHash,\n): ResultAsync<\n TransactionResult,\n CancelError | TransactionError | UnexpectedError\n> {\n return ResultAsync.fromPromise(\n waitForTransactionReceipt(walletClient, {\n hash: initialTxHash,\n pollingInterval: 100,\n retryCount: 20,\n retryDelay: 50,\n }),\n (err) => UnexpectedError.from(err),\n ).andThen((receipt) => {\n const hash = txHash(receipt.transactionHash);\n\n switch (receipt.status) {\n case 'reverted':\n if (initialTxHash !== hash) {\n return errAsync(CancelError.from(`Transaction replaced by ${hash}`));\n }\n return errAsync(transactionError(walletClient.chain, hash, request));\n case 'success':\n return okAsync({\n // viem's waitForTransactionReceipt supports transaction replacement\n // so it's important to use the transaction hash from the receipt\n txHash: hash,\n operations: request.operations,\n });\n }\n });\n}\n\nfunction sendTransactionAndWait(\n walletClient: WalletClient,\n request: TransactionRequest,\n): ResultAsync<\n TransactionResult,\n CancelError | SigningError | TransactionError | UnexpectedError\n> {\n return sendTransaction(walletClient, request).andThen((hash) =>\n waitForTransactionResult(walletClient, request, hash),\n );\n}\n\nfunction executePlan(\n walletClient: WalletClient,\n result: ExecutionPlan,\n): ReturnType<ExecutionPlanHandler> {\n switch (result.__typename) {\n case 'TransactionRequest':\n return sendTransactionAndWait(walletClient, result);\n\n case 'Erc20ApprovalRequired':\n return result.approvals\n .reduce<ReturnType<typeof sendTransactionAndWait>>(\n (chain, approval) =>\n chain.andThen(() =>\n sendTransactionAndWait(walletClient, approval.byTransaction),\n ),\n okAsync(undefined as never),\n )\n .andThen(() =>\n sendTransactionAndWait(walletClient, result.originalTransaction),\n );\n\n case 'PreContractActionRequired':\n return sendTransactionAndWait(walletClient, result.transaction).andThen(\n () => sendTransactionAndWait(walletClient, result.originalTransaction),\n );\n\n case 'InsufficientBalanceError':\n return errAsync(ValidationError.fromGqlNode(result));\n }\n}\n\n/**\n * Creates an execution plan handler that sends transactions using the provided wallet client.\n */\nexport function sendWith(walletClient: WalletClient): ExecutionPlanHandler;\n/**\n * Sends execution plan transactions using the provided wallet client.\n */\nexport function sendWith<T extends ExecutionPlan = ExecutionPlan>(\n walletClient: WalletClient,\n result: T,\n): ReturnType<ExecutionPlanHandler<T>>;\nexport function sendWith<T extends ExecutionPlan = ExecutionPlan>(\n walletClient: WalletClient,\n result?: T,\n): ExecutionPlanHandler<T> | ReturnType<ExecutionPlanHandler<T>> {\n return result\n ? executePlan(walletClient, result)\n : executePlan.bind(null, walletClient);\n}\n\n/**\n * Creates a function that signs EIP-712 typed data (ERC-20 permits, swap intents, etc.) using the provided wallet client.\n *\n * @param walletClient - The wallet client to use for signing.\n * @returns A function that takes typed data and returns a ResultAsync containing the raw signature.\n *\n * ```ts\n * const result = await prepareSwapCancel(client, request)\n * .andThen(signTypedDataWith(wallet));\n * ```\n */\nexport function signTypedDataWith(walletClient: WalletClient): TypedDataHandler;\n\n/**\n * Signs EIP-712 typed data (ERC-20 permits, swap intents, etc.) using the provided wallet client.\n *\n * @param walletClient - The wallet client to use for signing.\n * @param data - The typed data to sign.\n * @returns A ResultAsync containing the raw signature.\n *\n * ```ts\n * const result = await signTypedDataWith(wallet, typedData);\n * ```\n */\nexport function signTypedDataWith(\n walletClient: WalletClient,\n data: TypedData,\n): ReturnType<TypedDataHandler>;\n\nexport function signTypedDataWith(\n walletClient: WalletClient,\n data?: TypedData,\n): TypedDataHandler | ReturnType<TypedDataHandler> {\n if (data === undefined) {\n return signTypedData.bind(null, walletClient);\n }\n return signTypedData(walletClient, data);\n}\n\n/**\n * Handles ERC20 permit signing for actions that require token approval.\n *\n * Calls the action to get an initial execution plan. If the plan requires ERC20 approval\n * and the token supports permit signatures, signs the permit and re-calls the action\n * with the signature to get a new plan that can be sent directly.\n *\n * ```ts\n * const result = await permitWith(walletClient, (permitSig) =>\n * supply(client, {\n * reserve: reserve.id,\n * amount: { erc20: { value: amount, permitSig } },\n * sender: evmAddress(walletClient.account.address),\n * })\n * )\n * .andThen(sendWith(walletClient))\n * .andThen(client.waitForTransaction);\n * ```\n *\n * @param walletClient - The wallet client to use for signing permits.\n * @param action - A function that returns an execution plan, accepting an optional permit signature.\n * @returns A ResultAsync containing the resolved ExecutionPlan ready to be sent with `sendWith`.\n */\nexport function permitWith<E>(\n walletClient: WalletClient,\n action: (permitSig?: ERC20PermitSignature) => ResultAsync<ExecutionPlan, E>,\n): ResultAsync<ExecutionPlan, E | SignTypedDataError> {\n return action().andThen((result) => {\n if (supportsPermit(result)) {\n const permitTypedData = result.approvals[0].bySignature;\n // Sign and wrap with deadline\n return signTypedDataWith(walletClient, permitTypedData)\n .map((signature) => ({\n deadline: permitTypedData.message.deadline as number,\n value: signature,\n }))\n .andThen((permitSig) => action(permitSig));\n }\n return okAsync(result);\n });\n}\n"]}