@aave/client 0.2.0 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
- 'use strict';var graphql=require('@aave/graphql');var r={tokenName:graphql.OrderDirection.Asc};function G(e,{chainIds:t,borrowsOrderBy:u=r,suppliesOrderBy:s=r,user:n}){return e.query(graphql.MarketsQuery,{request:{chainIds:t,user:n},borrowsOrderBy:u,suppliesOrderBy:s})}function J(e,{address:t,chainId:u,user:s,borrowsOrderBy:n=r,suppliesOrderBy:o=r}){return e.query(graphql.MarketQuery,{request:{address:t,chainId:u,user:s},borrowsOrderBy:n,suppliesOrderBy:o})}function X(e,t){return e.query(graphql.UserMarketStateQuery,{request:t})}function $(e){return e.query(graphql.HealthQuery,{})}function ee(e,t=graphql.ChainsFilter.ALL){return e.query(graphql.ChainsQuery,{filter:t})}function te(e,t){return e.query(graphql.UsdExchangeRatesQuery,{request:t})}function re(e,t){return e.query(graphql.HasProcessedKnownTransactionQuery,{request:t})}function ne(e,t){return e.query(graphql.PermitTypedDataQuery,{request:t})}function ie(e,t){return e.query(graphql.ReserveQuery,{request:t})}function pe(e,t){return e.query(graphql.BorrowAPYHistoryQuery,{request:t})}function ye(e,t){return e.query(graphql.SupplyAPYHistoryQuery,{request:t})}function Re(e,t){return e.query(graphql.BorrowQuery,{request:t})}function de(e,t){return e.query(graphql.SupplyQuery,{request:t})}function qe(e,t){return e.query(graphql.RepayQuery,{request:t})}function Ae(e,t){return e.query(graphql.WithdrawQuery,{request:t})}function ve(e,t){return e.query(graphql.UserSetEmodeQuery,{request:t})}function xe(e,t){return e.query(graphql.VaultDepositQuery,{request:t})}function me(e,t){return e.query(graphql.VaultRedeemSharesQuery,{request:t})}function Ue(e,t){return e.query(graphql.VaultDeployQuery,{request:t})}function fe(e,t){return e.query(graphql.VaultSetFeeQuery,{request:t})}function Ee(e,t){return e.query(graphql.VaultWithdrawFeesQuery,{request:t})}function Ce(e,t){return e.query(graphql.VaultWithdrawQuery,{request:t})}function we(e,t){return e.query(graphql.VaultMintSharesQuery,{request:t})}function Pe(e,t){return e.query(graphql.CollateralToggleQuery,{request:t})}function Ve(e,t){return e.query(graphql.LiquidateQuery,{request:t})}function he(e,t){return e.query(graphql.ApproveBorrowCreditDelegationQuery,{request:t})}function Te(e,t){return e.query(graphql.CreditDelegateeAllowanceQuery,{request:t})}function ke(e,t){return e.query(graphql.UserSuppliesQuery,{request:t})}function Me(e,t){return e.query(graphql.UserBorrowsQuery,{request:t})}function ge(e,t){return e.query(graphql.UserTransactionHistoryQuery,{request:t})}function He(e,t){return e.query(graphql.VaultQuery,{request:t})}function We(e,t){return e.query(graphql.VaultsQuery,{request:t})}function Oe(e,t){return e.query(graphql.UserVaultsQuery,{request:t})}function Ye(e,t){return e.query(graphql.VaultPreviewDepositQuery,{request:t})}function Fe(e,t){return e.query(graphql.VaultPreviewMintQuery,{request:t})}function be(e,t){return e.query(graphql.VaultPreviewWithdrawQuery,{request:t})}function Ie(e,t){return e.query(graphql.VaultPreviewRedeemQuery,{request:t})}function Le(e,t){return e.query(graphql.VaultUserTransactionHistoryQuery,{request:t})}exports.approveBorrowCreditDelegation=he;exports.borrow=Re;exports.borrowAPYHistory=pe;exports.chains=ee;exports.collateralToggle=Pe;exports.creditDelegateeAllowance=Te;exports.defaultMarketReservesRequestOrderBy=r;exports.hasProcessedKnownTransaction=re;exports.health=$;exports.liquidate=Ve;exports.market=J;exports.markets=G;exports.permitTypedData=ne;exports.repay=qe;exports.reserve=ie;exports.supply=de;exports.supplyAPYHistory=ye;exports.usdExchangeRates=te;exports.userBorrows=Me;exports.userMarketState=X;exports.userSetEmode=ve;exports.userSupplies=ke;exports.userTransactionHistory=ge;exports.userVaults=Oe;exports.vault=He;exports.vaultDeploy=Ue;exports.vaultDeposit=xe;exports.vaultMintShares=we;exports.vaultPreviewDeposit=Ye;exports.vaultPreviewMint=Fe;exports.vaultPreviewRedeem=Ie;exports.vaultPreviewWithdraw=be;exports.vaultRedeemShares=me;exports.vaultSetFee=fe;exports.vaultUserTransactionHistory=Le;exports.vaultWithdraw=Ce;exports.vaultWithdrawFees=Ee;exports.vaults=We;exports.withdraw=Ae;//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var graphql=require('@aave/graphql');var r={tokenName:graphql.OrderDirection.Asc};function J(e,{chainIds:t,borrowsOrderBy:u=r,suppliesOrderBy:s=r,user:n}){return e.query(graphql.MarketsQuery,{request:{chainIds:t,user:n},borrowsOrderBy:u,suppliesOrderBy:s})}function X(e,{address:t,chainId:u,user:s,borrowsOrderBy:n=r,suppliesOrderBy:o=r}){return e.query(graphql.MarketQuery,{request:{address:t,chainId:u,user:s},borrowsOrderBy:n,suppliesOrderBy:o})}function Z(e,t){return e.query(graphql.UserMarketStateQuery,{request:t})}function ee(e){return e.query(graphql.HealthQuery,{})}function te(e,t=graphql.ChainsFilter.ALL){return e.query(graphql.ChainsQuery,{filter:t})}function re(e,t){return e.query(graphql.UsdExchangeRatesQuery,{request:t})}function ue(e,t){return e.query(graphql.HasProcessedKnownTransactionQuery,{request:t})}function se(e,t){return e.query(graphql.HealthFactorPreviewQuery,{request:t})}function ae(e,t){return e.query(graphql.PermitTypedDataQuery,{request:t})}function ye(e,t){return e.query(graphql.ReserveQuery,{request:t})}function le(e,t){return e.query(graphql.BorrowAPYHistoryQuery,{request:t})}function ce(e,t){return e.query(graphql.SupplyAPYHistoryQuery,{request:t})}function qe(e,t){return e.query(graphql.BorrowQuery,{request:t})}function Ae(e,t){return e.query(graphql.SupplyQuery,{request:t})}function ve(e,t){return e.query(graphql.RepayQuery,{request:t})}function xe(e,t){return e.query(graphql.WithdrawQuery,{request:t})}function me(e,t){return e.query(graphql.UserSetEmodeQuery,{request:t})}function Ue(e,t){return e.query(graphql.VaultDepositQuery,{request:t})}function fe(e,t){return e.query(graphql.VaultRedeemSharesQuery,{request:t})}function Ee(e,t){return e.query(graphql.VaultDeployQuery,{request:t})}function we(e,t){return e.query(graphql.VaultSetFeeQuery,{request:t})}function Ce(e,t){return e.query(graphql.VaultWithdrawFeesQuery,{request:t})}function Pe(e,t){return e.query(graphql.VaultWithdrawQuery,{request:t})}function Ve(e,t){return e.query(graphql.VaultMintSharesQuery,{request:t})}function he(e,t){return e.query(graphql.CollateralToggleQuery,{request:t})}function Te(e,t){return e.query(graphql.LiquidateQuery,{request:t})}function Qe(e,t){return e.query(graphql.ApproveBorrowCreditDelegationQuery,{request:t})}function Se(e,t){return e.query(graphql.CreditDelegateeAllowanceQuery,{request:t})}function ge(e,t){return e.query(graphql.UserSuppliesQuery,{request:t})}function He(e,t){return e.query(graphql.UserBorrowsQuery,{request:t})}function Be(e,t){return e.query(graphql.UserTransactionHistoryQuery,{request:t})}function We(e,t){return e.query(graphql.VaultQuery,{request:t})}function Oe(e,t){return e.query(graphql.VaultsQuery,{request:t})}function Ye(e,t){return e.query(graphql.UserVaultsQuery,{request:t})}function be(e,t){return e.query(graphql.VaultPreviewDepositQuery,{request:t})}function Ie(e,t){return e.query(graphql.VaultPreviewMintQuery,{request:t})}function Le(e,t){return e.query(graphql.VaultPreviewWithdrawQuery,{request:t})}function Ke(e,t){return e.query(graphql.VaultPreviewRedeemQuery,{request:t})}function Ne(e,t){return e.query(graphql.VaultUserTransactionHistoryQuery,{request:t})}exports.approveBorrowCreditDelegation=Qe;exports.borrow=qe;exports.borrowAPYHistory=le;exports.chains=te;exports.collateralToggle=he;exports.creditDelegateeAllowance=Se;exports.defaultMarketReservesRequestOrderBy=r;exports.hasProcessedKnownTransaction=ue;exports.health=ee;exports.healthFactorPreview=se;exports.liquidate=Te;exports.market=X;exports.markets=J;exports.permitTypedData=ae;exports.repay=ve;exports.reserve=ye;exports.supply=Ae;exports.supplyAPYHistory=ce;exports.usdExchangeRates=re;exports.userBorrows=He;exports.userMarketState=Z;exports.userSetEmode=me;exports.userSupplies=ge;exports.userTransactionHistory=Be;exports.userVaults=Ye;exports.vault=We;exports.vaultDeploy=Ee;exports.vaultDeposit=Ue;exports.vaultMintShares=Ve;exports.vaultPreviewDeposit=be;exports.vaultPreviewMint=Ie;exports.vaultPreviewRedeem=Ke;exports.vaultPreviewWithdraw=Le;exports.vaultRedeemShares=fe;exports.vaultSetFee=we;exports.vaultUserTransactionHistory=Ne;exports.vaultWithdraw=Pe;exports.vaultWithdrawFees=Ce;exports.vaults=Oe;exports.withdraw=xe;//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/actions/markets.ts","../../src/actions/misc.ts","../../src/actions/permits.ts","../../src/actions/reserve.ts","../../src/actions/transactions.ts","../../src/actions/user.ts","../../src/actions/vaults.ts"],"names":["defaultMarketReservesRequestOrderBy","OrderDirection","markets","client","chainIds","borrowsOrderBy","suppliesOrderBy","user","MarketsQuery","market","address","chainId","MarketQuery","userMarketState","request","UserMarketStateQuery","health","HealthQuery","chains","filter","ChainsFilter","ChainsQuery","usdExchangeRates","UsdExchangeRatesQuery","hasProcessedKnownTransaction","HasProcessedKnownTransactionQuery","permitTypedData","PermitTypedDataQuery","reserve","ReserveQuery","borrowAPYHistory","BorrowAPYHistoryQuery","supplyAPYHistory","SupplyAPYHistoryQuery","borrow","BorrowQuery","supply","SupplyQuery","repay","RepayQuery","withdraw","WithdrawQuery","userSetEmode","UserSetEmodeQuery","vaultDeposit","VaultDepositQuery","vaultRedeemShares","VaultRedeemSharesQuery","vaultDeploy","VaultDeployQuery","vaultSetFee","VaultSetFeeQuery","vaultWithdrawFees","VaultWithdrawFeesQuery","vaultWithdraw","VaultWithdrawQuery","vaultMintShares","VaultMintSharesQuery","collateralToggle","CollateralToggleQuery","liquidate","LiquidateQuery","approveBorrowCreditDelegation","ApproveBorrowCreditDelegationQuery","creditDelegateeAllowance","CreditDelegateeAllowanceQuery","userSupplies","UserSuppliesQuery","userBorrows","UserBorrowsQuery","userTransactionHistory","UserTransactionHistoryQuery","vault","VaultQuery","vaults","VaultsQuery","userVaults","UserVaultsQuery","vaultPreviewDeposit","VaultPreviewDepositQuery","vaultPreviewMint","VaultPreviewMintQuery","vaultPreviewWithdraw","VaultPreviewWithdrawQuery","vaultPreviewRedeem","VaultPreviewRedeemQuery","vaultUserTransactionHistory","VaultUserTransactionHistoryQuery"],"mappings":"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","file":"index.cjs","sourcesContent":["import {\n type Market,\n MarketQuery,\n type MarketReservesRequestOrderBy,\n MarketsQuery,\n type MarketUserState,\n OrderDirection,\n UserMarketStateQuery,\n type UserMarketStateRequest,\n} from '@aave/graphql';\nimport type { ChainId, EvmAddress, ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\nexport const defaultMarketReservesRequestOrderBy: MarketReservesRequestOrderBy =\n {\n tokenName: OrderDirection.Asc,\n };\n\nexport type MarketsRequest = {\n /**\n * The markets you want to see based on the chain ids.\n */\n chainIds: ChainId[];\n /**\n * The user viewing the market (e.g., the connected wallet).\n *\n * If not provided, user fields will not be included.\n */\n user?: EvmAddress;\n /**\n * The order by clause for the borrow reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n borrowsOrderBy?: MarketReservesRequestOrderBy;\n /**\n * The order by clause for the supply reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n suppliesOrderBy?: MarketReservesRequestOrderBy;\n};\n\n/**\n * Fetches all markets for the specified chain IDs.\n *\n * ```ts\n * const result = await markets(client, {\n * chainIds: [chainId(1), chainId(8453)],\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The markets request parameters.\n * @returns The list of markets.\n */\nexport function markets(\n client: AaveClient,\n {\n chainIds,\n borrowsOrderBy = defaultMarketReservesRequestOrderBy,\n suppliesOrderBy = defaultMarketReservesRequestOrderBy,\n user,\n }: MarketsRequest,\n): ResultAsync<Market[], UnexpectedError> {\n return client.query(MarketsQuery, {\n request: { chainIds, user },\n borrowsOrderBy,\n suppliesOrderBy,\n });\n}\n\nexport type MarketRequest = {\n /**\n * The pool address for the market.\n */\n address: EvmAddress;\n\n /**\n * The chain id the market pool address is deployed on.\n */\n chainId: ChainId;\n /**\n * The user viewing the market (e.g., the connected wallet).\n *\n * If not provided, user fields will not be included.\n */\n user?: EvmAddress;\n /**\n * The order by clause for the borrow reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n borrowsOrderBy?: MarketReservesRequestOrderBy;\n /**\n * The order by clause for the supply reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n suppliesOrderBy?: MarketReservesRequestOrderBy;\n};\n\n/**\n * Fetches a specific market by address and chain ID.\n *\n * ```ts\n * const result = await market(client, {\n * address: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The market request parameters.\n * @returns The market data, or null if not found.\n */\nexport function market(\n client: AaveClient,\n {\n address,\n chainId,\n user,\n borrowsOrderBy = defaultMarketReservesRequestOrderBy,\n suppliesOrderBy = defaultMarketReservesRequestOrderBy,\n }: MarketRequest,\n): ResultAsync<Market | null, UnexpectedError> {\n return client.query(MarketQuery, {\n request: { address, chainId, user },\n borrowsOrderBy,\n suppliesOrderBy,\n });\n}\n\n/**\n * Fetches user account market data across all reserves.\n *\n * ```ts\n * const result = await userMarketState(client, {\n * market: evmAddress('0x1234…'),\n * user: evmAddress('0x5678…'),\n * chainId: chainId(1)\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user market state request parameters.\n * @returns The user's market state.\n */\nexport function userMarketState(\n client: AaveClient,\n request: UserMarketStateRequest,\n): ResultAsync<MarketUserState, UnexpectedError> {\n return client.query(UserMarketStateQuery, { request });\n}\n","import {\n type Chain,\n ChainsFilter,\n ChainsQuery,\n HasProcessedKnownTransactionQuery,\n type HasProcessedKnownTransactionRequest,\n HealthQuery,\n type UsdExchangeRate,\n UsdExchangeRatesQuery,\n type UsdExchangeRatesRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Health check query.\n *\n * ```ts\n * const result = await health(client);\n * ```\n *\n * @param client - Aave client.\n * @returns True or false\n */\nexport function health(\n client: AaveClient,\n): ResultAsync<boolean, UnexpectedError> {\n return client.query(HealthQuery, {});\n}\n\n/**\n * Fetches the list of supported chains.\n *\n * ```ts\n * const result = await chains(client, { filter: ChainsFilter.MAINNET_ONLY });\n * ```\n *\n * @param client - Aave client.\n * @param filter - The filter for the chains.\n * @returns The list of supported chains.\n */\nexport function chains(\n client: AaveClient,\n filter: ChainsFilter = ChainsFilter.ALL,\n): ResultAsync<Chain[], UnexpectedError> {\n return client.query(ChainsQuery, { filter });\n}\n\n/**\n * Fetches USD exchange rates for different tokens on a given market.\n *\n * ```ts\n * const result = await usdExchangeRates(client, {\n * market: evmAddress('0x1234…'),\n * underlyingTokens: [evmAddress('0x5678…'), evmAddress('0x90ab…')],\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The USD exchange rates request parameters.\n * @returns The list of USD exchange rates.\n */\nexport function usdExchangeRates(\n client: AaveClient,\n request: UsdExchangeRatesRequest,\n): ResultAsync<UsdExchangeRate[], UnexpectedError> {\n return client.query(UsdExchangeRatesQuery, { request });\n}\n\n/**\n * Checks if the API has processed a known transaction hash.\n *\n * This is useful to know when cached data has been invalidated after\n * a transaction is complete, as the API uses caching and has an\n * invalidation task that may take 100-200ms longer.\n *\n * ```ts\n * const result = await borrow(client, request)\n * .andThen(sendWith(wallet))\n * .andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * // Check if the transaction has been processed by the API\n * const processed = await hasProcessedKnownTransaction(client, {\n * txHash: result.value,\n * operation: OperationType.Borrow\n * });\n *\n * if (processed.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * if (processed.value) {\n * // Transaction processed, cached data is up to date\n * console.log('Transaction processed, data is fresh');\n * } else {\n * // Transaction not yet processed, may need to wait\n * console.log('Transaction not yet processed');\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The request containing transaction hash and operation type 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(HasProcessedKnownTransactionQuery, { request });\n}\n","import {\n PermitTypedDataQuery,\n type PermitTypedDataRequest,\n type PermitTypedDataResponse,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Generates EIP-712 typed data for ERC-20 permit signature.\n *\n * ```ts\n * const result = await permitTypedData(client, {\n * market: evmAddress('0x87870bca...'),\n * underlyingToken: evmAddress('0xa0b86a33...'),\n * amount: '1.5',\n * chainId: chainId(1),\n * spender: evmAddress('0x123...'),\n * owner: evmAddress('0x456...'),\n * });\n *\n * if (result.isOk()) {\n * const typedData = result.value;\n * // Use typedData for permit signing\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The permit typed data request parameters.\n * @returns The EIP-712 typed data for permit signature.\n */\nexport function permitTypedData(\n client: AaveClient,\n request: PermitTypedDataRequest,\n): ResultAsync<PermitTypedDataResponse, UnexpectedError> {\n return client.query(PermitTypedDataQuery, { request });\n}\n","import {\n type APYSample,\n BorrowAPYHistoryQuery,\n type BorrowAPYHistoryRequest,\n type Reserve,\n ReserveQuery,\n type ReserveRequest,\n SupplyAPYHistoryQuery,\n type SupplyAPYHistoryRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Fetches a specific reserve by market address, token address, and chain ID.\n *\n * ```ts\n * const result = await reserve(client, {\n * market: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * underlyingToken: evmAddress('0xa0b86a33e6441c8c5f0bb9b7e5e1f8bbf5b78b5c'),\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The reserve request parameters.\n * @returns The reserve data, or null if not found.\n */\nexport function reserve(\n client: AaveClient,\n request: ReserveRequest,\n): ResultAsync<Reserve | null, UnexpectedError> {\n return client.query(ReserveQuery, {\n request,\n });\n}\n\n/**\n * Fetches historical borrow APY data for a given underlying asset on a specific market,\n * within a defined time window.\n *\n * The returned data represents APY samples over time, or `null` if unavailable.\n *\n * @param client - The Aave client instance used to perform the query.\n * @param request - The borrow APY history request parameters.\n * @returns A `ResultAsync` containing an array of APY samples, or `null` if not found.\n */\n\nexport function borrowAPYHistory(\n client: AaveClient,\n request: BorrowAPYHistoryRequest,\n): ResultAsync<APYSample[] | null, UnexpectedError> {\n return client.query(BorrowAPYHistoryQuery, {\n request,\n });\n}\n\n/**\n * Fetches historical supply APY data for a given underlying asset on a specific market,\n * within a defined time window.\n *\n * The returned data represents APY samples over time, or `null` if unavailable.\n *\n * @param client - The Aave client instance used to perform the query.\n * @param request - The supply APY history request parameters.\n * @returns A `ResultAsync` containing an array of APY samples, or `null` if not found.\n */\n\nexport function supplyAPYHistory(\n client: AaveClient,\n request: SupplyAPYHistoryRequest,\n): ResultAsync<APYSample[] | null, UnexpectedError> {\n return client.query(SupplyAPYHistoryQuery, {\n request,\n });\n}\n","import {\n ApproveBorrowCreditDelegationQuery,\n type ApproveBorrowCreditDelegatorRequest,\n BorrowQuery,\n type BorrowRequest,\n CollateralToggleQuery,\n type CollateralToggleRequest,\n CreditDelegateeAllowanceQuery,\n type CreditDelegateeAmountRequest,\n type ExecutionPlan,\n LiquidateQuery,\n type LiquidateRequest,\n RepayQuery,\n type RepayRequest,\n SupplyQuery,\n type SupplyRequest,\n type TokenAmount,\n type TransactionRequest,\n UserSetEmodeQuery,\n type UserSetEmodeRequest,\n VaultDeployQuery,\n type VaultDeployRequest,\n VaultDepositQuery,\n type VaultDepositRequest,\n VaultMintSharesQuery,\n type VaultMintSharesRequest,\n VaultRedeemSharesQuery,\n type VaultRedeemSharesRequest,\n VaultSetFeeQuery,\n type VaultSetFeeRequest,\n VaultWithdrawFeesQuery,\n type VaultWithdrawFeesRequest,\n VaultWithdrawQuery,\n type VaultWithdrawRequest,\n WithdrawQuery,\n type WithdrawRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Creates a transaction to borrow from a market.\n *\n * ```ts\n * const result = await borrow(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: '1000',\n * },\n * },\n * borrower: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The borrow request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function borrow(\n client: AaveClient,\n request: BorrowRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(BorrowQuery, { request });\n}\n\n/**\n * Creates a transaction to supply to a market.\n *\n * ```ts\n * const result = await supply(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: '1000',\n * },\n * },\n * supplier: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The supply request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function supply(\n client: AaveClient,\n request: SupplyRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(SupplyQuery, { request });\n}\n\n/**\n * Creates a transaction to repay to a market.\n *\n * ```ts\n * const result = await repay(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: '500',\n * },\n * },\n * borrower: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The repay request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function repay(\n client: AaveClient,\n request: RepayRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(RepayQuery, { request });\n}\n\n/**\n * Creates a transaction to withdraw from a market.\n *\n * ```ts\n * const result = await withdraw(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: { exact: '750' },\n * },\n * },\n * supplier: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The withdraw request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function withdraw(\n client: AaveClient,\n request: WithdrawRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(WithdrawQuery, { request });\n}\n\n/**\n * Creates a transaction to enable/disable the user's eMode for a market.\n *\n * **Example: Enable a Specific eMode**\n * ```ts\n * const result = await userSetEmode(client, {\n * market: market.address,\n * user: evmAddress('0x5678…'),\n * categoryId: market.eModeCategories[0].id,\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * **Example: Disable eMode**\n * ```ts\n * const result = await userSetEmode(client, {\n * market: market.address,\n * user: evmAddress('0x5678…'),\n * categoryId: null,\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The user set eMode request parameters.\n * @returns The transaction request data to set eMode.\n */\nexport function userSetEmode(\n client: AaveClient,\n request: UserSetEmodeRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(UserSetEmodeQuery, { request });\n}\n\n/**\n * Creates a transaction to deposit assets into a vault and mint shares.\n *\n * ```ts\n * const result = await vaultDeposit(client, {\n * vault: evmAddress('0x1234…'),\n * amount: {\n * currency: evmAddress('0x5678…'),\n * value: '1000',\n * },\n * depositor: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault deposit request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function vaultDeposit(\n client: AaveClient,\n request: VaultDepositRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(VaultDepositQuery, { request });\n}\n\n/**\n * Creates a transaction to redeem vault shares for underlying assets.\n *\n * ```ts\n * const result = await vaultRedeemShares(client, {\n * vault: evmAddress('0x1234…'),\n * shares: {\n * amount: '500',\n * asAToken: false,\n * },\n * sharesOwner: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The redeem vault shares request parameters.\n * @returns The transaction request data to redeem shares.\n */\nexport function vaultRedeemShares(\n client: AaveClient,\n request: VaultRedeemSharesRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultRedeemSharesQuery, { request });\n}\n\n/**\n * Creates an execution plan to deploy a new vault.\n *\n * ```ts\n * const result = await vaultDeploy(client, {\n * underlyingToken: evmAddress('0x1234…'),\n * market: evmAddress('0x5678…'),\n * deployer: evmAddress('0x9abc…'),\n * initialFee: '0.1',\n * shareName: 'Aave Vault Shares',\n * shareSymbol: 'avs',\n * initialLockDeposit: '1000',\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, insufficient balance, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The deploy vault request parameters.\n * @returns The execution plan data to deploy a vault. May require approval transactions.\n */\nexport function vaultDeploy(\n client: AaveClient,\n request: VaultDeployRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(VaultDeployQuery, { request });\n}\n\n/**\n * Creates a transaction to set the vault fee (owner only).\n *\n * ```ts\n * const result = await vaultSetFee(client, {\n * vault: evmAddress('0x1234…'),\n * newFee: '0.2',\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The set vault fee request parameters.\n * @returns The transaction request data to set vault fee.\n */\nexport function vaultSetFee(\n client: AaveClient,\n request: VaultSetFeeRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultSetFeeQuery, { request });\n}\n\n/**\n * Creates a transaction to withdraw accumulated fees from a vault (owner only).\n *\n * ```ts\n * const result = await vaultWithdrawFees(client, {\n * vault: evmAddress('0x1234…'),\n * amount: '100',\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The withdraw vault fees request parameters.\n * @returns The transaction request data to withdraw vault fees.\n */\nexport function vaultWithdrawFees(\n client: AaveClient,\n request: VaultWithdrawFeesRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultWithdrawFeesQuery, { request });\n}\n\n/**\n * Creates a transaction to withdraw assets from a vault, burning shares.\n *\n * ```ts\n * const result = await vaultWithdraw(client, {\n * vault: evmAddress('0x1234…'),\n * shares: {\n * amount: '500',\n * asAToken: false,\n * },\n * sharesOwner: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The withdraw vault request parameters.\n * @returns The transaction request data to withdraw from vault.\n */\nexport function vaultWithdraw(\n client: AaveClient,\n request: VaultWithdrawRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultWithdrawQuery, { request });\n}\n\n/**\n * Creates a transaction to mint exact amount of vault shares by depositing calculated assets.\n *\n * ```ts\n * const result = await vaultMintShares(client, {\n * vault: evmAddress('0x1234…'),\n * shares: {\n * amount: '1000',\n * asAToken: false,\n * },\n * minter: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The mint vault shares request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function vaultMintShares(\n client: AaveClient,\n request: VaultMintSharesRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(VaultMintSharesQuery, { request });\n}\n\n/**\n * Creates a transaction to enable/disable a specific supplied asset as collateral.\n *\n * ```ts\n * const result = await collateralToggle(client, {\n * market: market.address,\n * underlyingToken: market.supplyReserves[n].underlyingToken.address,\n * user: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The collateral toggle request parameters.\n * @returns The transaction request data to toggle collateral.\n */\nexport function collateralToggle(\n client: AaveClient,\n request: CollateralToggleRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(CollateralToggleQuery, { request });\n}\n\n/**\n * Creates a transaction to liquidate a non-healthy position with Health Factor below 1.\n *\n * ```ts\n * const result = await liquidate(client, {\n * collateralToken: evmAddress('0x1234…'),\n * debtToken: evmAddress('0x5678…'),\n * user: evmAddress('0x9abc…'),\n * debtToCover: { max: true },\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The liquidate request parameters.\n * @returns The transaction request data to liquidate position.\n */\nexport function liquidate(\n client: AaveClient,\n request: LiquidateRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(LiquidateQuery, { request });\n}\n\n/**\n * Creates a transaction to approve a credit borrow delegator to be able to borrow on your behalf.\n *\n * ```ts\n * const result = await approveBorrowCreditDelegation(client, {\n * market: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * underlyingToken: evmAddress('0xa0b86a33e6441c8c5f0bb9b7e5e1f8bbf5b78b5c'),\n * amount: '1000',\n * user: evmAddress('0x742d35cc6e5c4ce3b69a2a8c7c8e5f7e9a0b1234'),\n * delegatee: evmAddress('0x5678…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The approve borrow credit delegation request parameters.\n * @returns The transaction request data to approve credit delegation.\n */\nexport function approveBorrowCreditDelegation(\n client: AaveClient,\n request: ApproveBorrowCreditDelegatorRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(ApproveBorrowCreditDelegationQuery, { request });\n}\n\n/**\n * Gets the amount delegated to the credit delegatee that can borrow on your behalf.\n *\n * ```ts\n * const result = await creditDelegateeAllowance(client, {\n * market: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * underlyingToken: evmAddress('0xa0b86a33e6441c8c5f0bb9b7e5e1f8bbf5b78b5c'),\n * user: evmAddress('0x742d35cc6e5c4ce3b69a2a8c7c8e5f7e9a0b1234'),\n * delegatee: evmAddress('0x5678…'),\n * chainId: chainId(1),\n * });\n *\n * if (result.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * // result.value: TokenAmount with credit delegation allowance\n * ```\n *\n * @param client - Aave client.\n * @param request - The credit delegatee allowance request parameters.\n * @returns The token amount representing the credit delegation allowance.\n */\nexport function creditDelegateeAllowance(\n client: AaveClient,\n request: CreditDelegateeAmountRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(CreditDelegateeAllowanceQuery, { request });\n}\n","import {\n type MarketUserReserveBorrowPosition,\n type MarketUserReserveSupplyPosition,\n type PaginatedUserTransactionHistoryResult,\n UserBorrowsQuery,\n type UserBorrowsRequest,\n UserSuppliesQuery,\n type UserSuppliesRequest,\n UserTransactionHistoryQuery,\n type UserTransactionHistoryRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Fetches all user supply positions across the specified markets.\n *\n * ```ts\n * const result = await userSupplies(client, {\n * markets: [{ address: evmAddress('0x87870bca…'), chainId: chainId(1) }],\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user supplies request parameters.\n * @returns The user's supply positions.\n */\nexport function userSupplies(\n client: AaveClient,\n request: UserSuppliesRequest,\n): ResultAsync<MarketUserReserveSupplyPosition[], UnexpectedError> {\n return client.query(UserSuppliesQuery, { request });\n}\n\n/**\n * Fetches all user borrow positions.\n *\n * ```ts\n * const result = await userBorrows(client, {\n * markets: [{ address: evmAddress('0x87870bca…'), chainId: chainId(1) }],\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user borrows request parameters.\n * @returns The user's borrow positions.\n */\nexport function userBorrows(\n client: AaveClient,\n request: UserBorrowsRequest,\n): ResultAsync<MarketUserReserveBorrowPosition[], UnexpectedError> {\n return client.query(UserBorrowsQuery, { request });\n}\n\n/**\n * Fetches the user's transaction history for a given market.\n *\n * ```ts\n * const result = await userTransactionHistory(client, {\n * chainId: chainId(1),\n * market: evmAddress('0x87870bca…'),\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user transaction history request parameters.\n * @returns The user's paginated transaction history.\n */\nexport function userTransactionHistory(\n client: AaveClient,\n request: UserTransactionHistoryRequest,\n): ResultAsync<PaginatedUserTransactionHistoryResult, UnexpectedError> {\n return client.query(UserTransactionHistoryQuery, { request });\n}\n","import {\n type PaginatedVaultsResult,\n type PaginatedVaultUserTransactionHistoryResult,\n type TokenAmount,\n UserVaultsQuery,\n type UserVaultsRequest,\n type Vault,\n VaultPreviewDepositQuery,\n type VaultPreviewDepositRequest,\n VaultPreviewMintQuery,\n type VaultPreviewMintRequest,\n VaultPreviewRedeemQuery,\n type VaultPreviewRedeemRequest,\n VaultPreviewWithdrawQuery,\n type VaultPreviewWithdrawRequest,\n VaultQuery,\n type VaultRequest,\n VaultsQuery,\n type VaultsRequest,\n VaultUserTransactionHistoryQuery,\n type VaultUserTransactionHistoryRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Fetches a specific vault by address and chain ID.\n *\n * **Example: By Address**\n * ```ts\n * const result = await vault(client, {\n * by: {\n * address: evmAddress('0x1234…'),\n * },\n * chainId: chainId(1),\n * user: evmAddress('0x5678…'),\n * });\n * ```\n *\n * **Example: Tx Hash**\n * ```ts\n * const result = await vault(client, {\n * by: {\n * txHash: txHash('0x1234…'),\n * },\n * chainId: chainId(1),\n * user: evmAddress('0x5678…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault request parameters.\n * @returns The vault data, or null if not found.\n */\nexport function vault(\n client: AaveClient,\n request: VaultRequest,\n): ResultAsync<Vault | null, UnexpectedError> {\n return client.query(VaultQuery, {\n request,\n });\n}\n\n/**\n * Fetches vaults based on filter criteria.\n *\n * ```ts\n * const result = await vaults(client, {\n * criteria: {\n * ownedBy: [evmAddress('0x1234…')]\n * },\n * pageSize: PageSize.Ten,\n * user: evmAddress('0x5678…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The vaults request parameters.\n * @returns The paginated vaults result.\n */\nexport function vaults(\n client: AaveClient,\n request: VaultsRequest,\n): ResultAsync<PaginatedVaultsResult, UnexpectedError> {\n return client.query(VaultsQuery, {\n request,\n });\n}\n\n/**\n * Fetches vaults that a user has shares in.\n *\n * ```ts\n * const result = await userVaults(client, {\n * user: evmAddress('0x1234…'),\n * filters: {\n * markets: [evmAddress('0x5678…')]\n * },\n * orderBy: { shares: OrderDirection.Desc },\n * pageSize: PageSize.Fifty,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user vaults request parameters.\n * @returns The paginated user vaults result.\n */\nexport function userVaults(\n client: AaveClient,\n request: UserVaultsRequest,\n): ResultAsync<PaginatedVaultsResult, UnexpectedError> {\n return client.query(UserVaultsQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of shares that would be received for a deposit.\n *\n * ```ts\n * const result = await vaultPreviewDeposit(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('1000'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Shares to receive:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview deposit request parameters.\n * @returns The simulated shares amount that would be received.\n */\nexport function vaultPreviewDeposit(\n client: AaveClient,\n request: VaultPreviewDepositRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewDepositQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of assets that would be required to mint a specific amount of vault shares.\n *\n * ```ts\n * const result = await vaultPreviewMint(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('500'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Assets required:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview mint request parameters.\n * @returns The simulated assets amount that would be required.\n */\nexport function vaultPreviewMint(\n client: AaveClient,\n request: VaultPreviewMintRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewMintQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of shares that would be burned for a withdrawal.\n *\n * ```ts\n * const result = await vaultPreviewWithdraw(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('750'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Shares to burn:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview withdraw request parameters.\n * @returns The simulated shares amount that would be burned.\n */\nexport function vaultPreviewWithdraw(\n client: AaveClient,\n request: VaultPreviewWithdrawRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewWithdrawQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of assets that would be received for redeeming a specific amount of vault shares.\n *\n * ```ts\n * const result = await vaultPreviewRedeem(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('200'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Assets to receive:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview redeem request parameters.\n * @returns The simulated assets amount that would be received.\n */\nexport function vaultPreviewRedeem(\n client: AaveClient,\n request: VaultPreviewRedeemRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewRedeemQuery, {\n request,\n });\n}\n\n/**\n * Fetches the user transaction history for a vault.\n *\n * ```ts\n * const result = await vaultUserTransactionHistory(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * user: evmAddress('0x5678901234567890abcdef1234567890abcdef12'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Transaction count:', result.value.items.length);\n * result.value.items.forEach(tx => {\n * if (tx.__typename === 'VaultUserDepositItem') {\n * console.log('Deposit:', tx.asset.amount.value, 'shares:', tx.shares.amount.value);\n * } else if (tx.__typename === 'VaultUserWithdrawItem') {\n * console.log('Withdraw:', tx.asset.amount.value, 'shares:', tx.shares.amount.value);\n * }\n * });\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault user transaction history request parameters.\n * @returns The paginated vault user transaction history result.\n */\nexport function vaultUserTransactionHistory(\n client: AaveClient,\n request: VaultUserTransactionHistoryRequest,\n): ResultAsync<PaginatedVaultUserTransactionHistoryResult, UnexpectedError> {\n return client.query(VaultUserTransactionHistoryQuery, {\n request,\n });\n}\n"]}
1
+ {"version":3,"sources":["../../src/actions/markets.ts","../../src/actions/misc.ts","../../src/actions/permits.ts","../../src/actions/reserve.ts","../../src/actions/transactions.ts","../../src/actions/user.ts","../../src/actions/vaults.ts"],"names":["defaultMarketReservesRequestOrderBy","OrderDirection","markets","client","chainIds","borrowsOrderBy","suppliesOrderBy","user","MarketsQuery","market","address","chainId","MarketQuery","userMarketState","request","UserMarketStateQuery","health","HealthQuery","chains","filter","ChainsFilter","ChainsQuery","usdExchangeRates","UsdExchangeRatesQuery","hasProcessedKnownTransaction","HasProcessedKnownTransactionQuery","healthFactorPreview","HealthFactorPreviewQuery","permitTypedData","PermitTypedDataQuery","reserve","ReserveQuery","borrowAPYHistory","BorrowAPYHistoryQuery","supplyAPYHistory","SupplyAPYHistoryQuery","borrow","BorrowQuery","supply","SupplyQuery","repay","RepayQuery","withdraw","WithdrawQuery","userSetEmode","UserSetEmodeQuery","vaultDeposit","VaultDepositQuery","vaultRedeemShares","VaultRedeemSharesQuery","vaultDeploy","VaultDeployQuery","vaultSetFee","VaultSetFeeQuery","vaultWithdrawFees","VaultWithdrawFeesQuery","vaultWithdraw","VaultWithdrawQuery","vaultMintShares","VaultMintSharesQuery","collateralToggle","CollateralToggleQuery","liquidate","LiquidateQuery","approveBorrowCreditDelegation","ApproveBorrowCreditDelegationQuery","creditDelegateeAllowance","CreditDelegateeAllowanceQuery","userSupplies","UserSuppliesQuery","userBorrows","UserBorrowsQuery","userTransactionHistory","UserTransactionHistoryQuery","vault","VaultQuery","vaults","VaultsQuery","userVaults","UserVaultsQuery","vaultPreviewDeposit","VaultPreviewDepositQuery","vaultPreviewMint","VaultPreviewMintQuery","vaultPreviewWithdraw","VaultPreviewWithdrawQuery","vaultPreviewRedeem","VaultPreviewRedeemQuery","vaultUserTransactionHistory","VaultUserTransactionHistoryQuery"],"mappings":"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","file":"index.cjs","sourcesContent":["import {\n type Market,\n MarketQuery,\n type MarketReservesRequestOrderBy,\n MarketsQuery,\n type MarketUserState,\n OrderDirection,\n UserMarketStateQuery,\n type UserMarketStateRequest,\n} from '@aave/graphql';\nimport type { ChainId, EvmAddress, ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\nexport const defaultMarketReservesRequestOrderBy: MarketReservesRequestOrderBy =\n {\n tokenName: OrderDirection.Asc,\n };\n\nexport type MarketsRequest = {\n /**\n * The markets you want to see based on the chain ids.\n */\n chainIds: ChainId[];\n /**\n * The user viewing the market (e.g., the connected wallet).\n *\n * If not provided, user fields will not be included.\n */\n user?: EvmAddress;\n /**\n * The order by clause for the borrow reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n borrowsOrderBy?: MarketReservesRequestOrderBy;\n /**\n * The order by clause for the supply reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n suppliesOrderBy?: MarketReservesRequestOrderBy;\n};\n\n/**\n * Fetches all markets for the specified chain IDs.\n *\n * ```ts\n * const result = await markets(client, {\n * chainIds: [chainId(1), chainId(8453)],\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The markets request parameters.\n * @returns The list of markets.\n */\nexport function markets(\n client: AaveClient,\n {\n chainIds,\n borrowsOrderBy = defaultMarketReservesRequestOrderBy,\n suppliesOrderBy = defaultMarketReservesRequestOrderBy,\n user,\n }: MarketsRequest,\n): ResultAsync<Market[], UnexpectedError> {\n return client.query(MarketsQuery, {\n request: { chainIds, user },\n borrowsOrderBy,\n suppliesOrderBy,\n });\n}\n\nexport type MarketRequest = {\n /**\n * The pool address for the market.\n */\n address: EvmAddress;\n\n /**\n * The chain id the market pool address is deployed on.\n */\n chainId: ChainId;\n /**\n * The user viewing the market (e.g., the connected wallet).\n *\n * If not provided, user fields will not be included.\n */\n user?: EvmAddress;\n /**\n * The order by clause for the borrow reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n borrowsOrderBy?: MarketReservesRequestOrderBy;\n /**\n * The order by clause for the supply reserves in the market.\n *\n * @defaultValue { tokenName: OrderDirection.Asc }\n */\n suppliesOrderBy?: MarketReservesRequestOrderBy;\n};\n\n/**\n * Fetches a specific market by address and chain ID.\n *\n * ```ts\n * const result = await market(client, {\n * address: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The market request parameters.\n * @returns The market data, or null if not found.\n */\nexport function market(\n client: AaveClient,\n {\n address,\n chainId,\n user,\n borrowsOrderBy = defaultMarketReservesRequestOrderBy,\n suppliesOrderBy = defaultMarketReservesRequestOrderBy,\n }: MarketRequest,\n): ResultAsync<Market | null, UnexpectedError> {\n return client.query(MarketQuery, {\n request: { address, chainId, user },\n borrowsOrderBy,\n suppliesOrderBy,\n });\n}\n\n/**\n * Fetches user account market data across all reserves.\n *\n * ```ts\n * const result = await userMarketState(client, {\n * market: evmAddress('0x1234…'),\n * user: evmAddress('0x5678…'),\n * chainId: chainId(1)\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user market state request parameters.\n * @returns The user's market state.\n */\nexport function userMarketState(\n client: AaveClient,\n request: UserMarketStateRequest,\n): ResultAsync<MarketUserState, UnexpectedError> {\n return client.query(UserMarketStateQuery, { request });\n}\n","import {\n type Chain,\n ChainsFilter,\n ChainsQuery,\n HasProcessedKnownTransactionQuery,\n type HasProcessedKnownTransactionRequest,\n HealthFactorPreviewQuery,\n type HealthFactorPreviewRequest,\n type HealthFactorPreviewResponse,\n HealthQuery,\n type UsdExchangeRate,\n UsdExchangeRatesQuery,\n type UsdExchangeRatesRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Health check query.\n *\n * ```ts\n * const result = await health(client);\n * ```\n *\n * @param client - Aave client.\n * @returns True or false\n */\nexport function health(\n client: AaveClient,\n): ResultAsync<boolean, UnexpectedError> {\n return client.query(HealthQuery, {});\n}\n\n/**\n * Fetches the list of supported chains.\n *\n * ```ts\n * const result = await chains(client, ChainsFilter.MAINNET_ONLY);\n * ```\n *\n * @param client - Aave client.\n * @param filter - The filter for the chains.\n * @returns The list of supported chains.\n */\nexport function chains(\n client: AaveClient,\n filter: ChainsFilter = ChainsFilter.ALL,\n): ResultAsync<Chain[], UnexpectedError> {\n return client.query(ChainsQuery, { filter });\n}\n\n/**\n * Fetches USD exchange rates for different tokens on a given market.\n *\n * ```ts\n * const result = await usdExchangeRates(client, {\n * market: evmAddress('0x1234…'),\n * underlyingTokens: [evmAddress('0x5678…'), evmAddress('0x90ab…')],\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The USD exchange rates request parameters.\n * @returns The list of USD exchange rates.\n */\nexport function usdExchangeRates(\n client: AaveClient,\n request: UsdExchangeRatesRequest,\n): ResultAsync<UsdExchangeRate[], UnexpectedError> {\n return client.query(UsdExchangeRatesQuery, { request });\n}\n\n/**\n * Checks if the API has processed a known transaction hash.\n *\n * This is useful to know when cached data has been invalidated after\n * a transaction is complete, as the API uses caching and has an\n * invalidation task that may take 100-200ms longer.\n *\n * ```ts\n * const result = await borrow(client, request)\n * .andThen(sendWith(wallet))\n * .andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * // Check if the transaction has been processed by the API\n * const processed = await hasProcessedKnownTransaction(client, {\n * txHash: result.value,\n * operation: OperationType.Borrow\n * });\n *\n * if (processed.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * if (processed.value) {\n * // Transaction processed, cached data is up to date\n * console.log('Transaction processed, data is fresh');\n * } else {\n * // Transaction not yet processed, may need to wait\n * console.log('Transaction not yet processed');\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The request containing transaction hash and operation type 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(HasProcessedKnownTransactionQuery, { request });\n}\n\n/**\n * Fetches health factor preview for a given market action.\n *\n * ```ts\n * const result = await healthFactorPreview(client, {\n * action: {\n * borrow: {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: '1000',\n * },\n * },\n * borrower: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * },\n * },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The health factor preview request parameters.\n * @returns The health factor preview response with before and after values.\n */\nexport function healthFactorPreview(\n client: AaveClient,\n request: HealthFactorPreviewRequest,\n): ResultAsync<HealthFactorPreviewResponse, UnexpectedError> {\n return client.query(HealthFactorPreviewQuery, { request });\n}\n","import {\n PermitTypedDataQuery,\n type PermitTypedDataRequest,\n type PermitTypedDataResponse,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Generates EIP-712 typed data for ERC-20 permit signature.\n *\n * ```ts\n * const result = await permitTypedData(client, {\n * market: evmAddress('0x87870bca...'),\n * underlyingToken: evmAddress('0xa0b86a33...'),\n * amount: '1.5',\n * chainId: chainId(1),\n * spender: evmAddress('0x123...'),\n * owner: evmAddress('0x456...'),\n * });\n *\n * if (result.isOk()) {\n * const typedData = result.value;\n * // Use typedData for permit signing\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The permit typed data request parameters.\n * @returns The EIP-712 typed data for permit signature.\n */\nexport function permitTypedData(\n client: AaveClient,\n request: PermitTypedDataRequest,\n): ResultAsync<PermitTypedDataResponse, UnexpectedError> {\n return client.query(PermitTypedDataQuery, { request });\n}\n","import {\n type APYSample,\n BorrowAPYHistoryQuery,\n type BorrowAPYHistoryRequest,\n type Reserve,\n ReserveQuery,\n type ReserveRequest,\n SupplyAPYHistoryQuery,\n type SupplyAPYHistoryRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Fetches a specific reserve by market address, token address, and chain ID.\n *\n * ```ts\n * const result = await reserve(client, {\n * market: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * underlyingToken: evmAddress('0xa0b86a33e6441c8c5f0bb9b7e5e1f8bbf5b78b5c'),\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The reserve request parameters.\n * @returns The reserve data, or null if not found.\n */\nexport function reserve(\n client: AaveClient,\n request: ReserveRequest,\n): ResultAsync<Reserve | null, UnexpectedError> {\n return client.query(ReserveQuery, {\n request,\n });\n}\n\n/**\n * Fetches historical borrow APY data for a given underlying asset on a specific market,\n * within a defined time window.\n *\n * The returned data represents APY samples over time, or `null` if unavailable.\n *\n * @param client - The Aave client instance used to perform the query.\n * @param request - The borrow APY history request parameters.\n * @returns A `ResultAsync` containing an array of APY samples, or `null` if not found.\n */\n\nexport function borrowAPYHistory(\n client: AaveClient,\n request: BorrowAPYHistoryRequest,\n): ResultAsync<APYSample[] | null, UnexpectedError> {\n return client.query(BorrowAPYHistoryQuery, {\n request,\n });\n}\n\n/**\n * Fetches historical supply APY data for a given underlying asset on a specific market,\n * within a defined time window.\n *\n * The returned data represents APY samples over time, or `null` if unavailable.\n *\n * @param client - The Aave client instance used to perform the query.\n * @param request - The supply APY history request parameters.\n * @returns A `ResultAsync` containing an array of APY samples, or `null` if not found.\n */\n\nexport function supplyAPYHistory(\n client: AaveClient,\n request: SupplyAPYHistoryRequest,\n): ResultAsync<APYSample[] | null, UnexpectedError> {\n return client.query(SupplyAPYHistoryQuery, {\n request,\n });\n}\n","import {\n ApproveBorrowCreditDelegationQuery,\n type ApproveBorrowCreditDelegatorRequest,\n BorrowQuery,\n type BorrowRequest,\n CollateralToggleQuery,\n type CollateralToggleRequest,\n CreditDelegateeAllowanceQuery,\n type CreditDelegateeAmountRequest,\n type ExecutionPlan,\n LiquidateQuery,\n type LiquidateRequest,\n RepayQuery,\n type RepayRequest,\n SupplyQuery,\n type SupplyRequest,\n type TokenAmount,\n type TransactionRequest,\n UserSetEmodeQuery,\n type UserSetEmodeRequest,\n VaultDeployQuery,\n type VaultDeployRequest,\n VaultDepositQuery,\n type VaultDepositRequest,\n VaultMintSharesQuery,\n type VaultMintSharesRequest,\n VaultRedeemSharesQuery,\n type VaultRedeemSharesRequest,\n VaultSetFeeQuery,\n type VaultSetFeeRequest,\n VaultWithdrawFeesQuery,\n type VaultWithdrawFeesRequest,\n VaultWithdrawQuery,\n type VaultWithdrawRequest,\n WithdrawQuery,\n type WithdrawRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Creates a transaction to borrow from a market.\n *\n * ```ts\n * const result = await borrow(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: '1000',\n * },\n * },\n * borrower: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The borrow request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function borrow(\n client: AaveClient,\n request: BorrowRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(BorrowQuery, { request });\n}\n\n/**\n * Creates a transaction to supply to a market.\n *\n * ```ts\n * const result = await supply(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: '1000',\n * },\n * },\n * supplier: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The supply request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function supply(\n client: AaveClient,\n request: SupplyRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(SupplyQuery, { request });\n}\n\n/**\n * Creates a transaction to repay to a market.\n *\n * ```ts\n * const result = await repay(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: {\n * exact: '500',\n * },\n * },\n * },\n * borrower: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The repay request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function repay(\n client: AaveClient,\n request: RepayRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(RepayQuery, { request });\n}\n\n/**\n * Creates a transaction to withdraw from a market.\n *\n * ```ts\n * const result = await withdraw(client, {\n * market: market.address,\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: { exact: '750' },\n * },\n * },\n * supplier: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The withdraw request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function withdraw(\n client: AaveClient,\n request: WithdrawRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(WithdrawQuery, { request });\n}\n\n/**\n * Creates a transaction to enable/disable the user's eMode for a market.\n *\n * **Example: Enable a Specific eMode**\n * ```ts\n * const result = await userSetEmode(client, {\n * market: market.address,\n * user: evmAddress('0x5678…'),\n * categoryId: market.eModeCategories[0].id,\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * **Example: Disable eMode**\n * ```ts\n * const result = await userSetEmode(client, {\n * market: market.address,\n * user: evmAddress('0x5678…'),\n * categoryId: null,\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The user set eMode request parameters.\n * @returns The transaction request data to set eMode.\n */\nexport function userSetEmode(\n client: AaveClient,\n request: UserSetEmodeRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(UserSetEmodeQuery, { request });\n}\n\n/**\n * Creates a transaction to deposit assets into a vault and mint shares.\n *\n * ```ts\n * const result = await vaultDeposit(client, {\n * vault: evmAddress('0x1234…'),\n * amount: {\n * currency: evmAddress('0x5678…'),\n * value: '1000',\n * },\n * depositor: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault deposit request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function vaultDeposit(\n client: AaveClient,\n request: VaultDepositRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(VaultDepositQuery, { request });\n}\n\n/**\n * Creates a transaction to redeem vault shares for underlying assets.\n *\n * ```ts\n * const result = await vaultRedeemShares(client, {\n * vault: evmAddress('0x1234…'),\n * shares: {\n * amount: '500',\n * asAToken: false,\n * },\n * sharesOwner: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The redeem vault shares request parameters.\n * @returns The transaction request data to redeem shares.\n */\nexport function vaultRedeemShares(\n client: AaveClient,\n request: VaultRedeemSharesRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultRedeemSharesQuery, { request });\n}\n\n/**\n * Creates an execution plan to deploy a new vault.\n *\n * ```ts\n * const result = await vaultDeploy(client, {\n * underlyingToken: evmAddress('0x1234…'),\n * market: evmAddress('0x5678…'),\n * deployer: evmAddress('0x9abc…'),\n * initialFee: '0.1',\n * shareName: 'Aave Vault Shares',\n * shareSymbol: 'avs',\n * initialLockDeposit: '1000',\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, insufficient balance, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The deploy vault request parameters.\n * @returns The execution plan data to deploy a vault. May require approval transactions.\n */\nexport function vaultDeploy(\n client: AaveClient,\n request: VaultDeployRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(VaultDeployQuery, { request });\n}\n\n/**\n * Creates a transaction to set the vault fee (owner only).\n *\n * ```ts\n * const result = await vaultSetFee(client, {\n * vault: evmAddress('0x1234…'),\n * newFee: '0.2',\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The set vault fee request parameters.\n * @returns The transaction request data to set vault fee.\n */\nexport function vaultSetFee(\n client: AaveClient,\n request: VaultSetFeeRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultSetFeeQuery, { request });\n}\n\n/**\n * Creates a transaction to withdraw accumulated fees from a vault (owner only).\n *\n * ```ts\n * const result = await vaultWithdrawFees(client, {\n * vault: evmAddress('0x1234…'),\n * amount: '100',\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The withdraw vault fees request parameters.\n * @returns The transaction request data to withdraw vault fees.\n */\nexport function vaultWithdrawFees(\n client: AaveClient,\n request: VaultWithdrawFeesRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultWithdrawFeesQuery, { request });\n}\n\n/**\n * Creates a transaction to withdraw assets from a vault, burning shares.\n *\n * ```ts\n * const result = await vaultWithdraw(client, {\n * vault: evmAddress('0x1234…'),\n * shares: {\n * amount: '500',\n * asAToken: false,\n * },\n * sharesOwner: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The withdraw vault request parameters.\n * @returns The transaction request data to withdraw from vault.\n */\nexport function vaultWithdraw(\n client: AaveClient,\n request: VaultWithdrawRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(VaultWithdrawQuery, { request });\n}\n\n/**\n * Creates a transaction to mint exact amount of vault shares by depositing calculated assets.\n *\n * ```ts\n * const result = await vaultMintShares(client, {\n * vault: evmAddress('0x1234…'),\n * shares: {\n * amount: '1000',\n * asAToken: false,\n * },\n * minter: evmAddress('0x9abc…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. insufficient balance, signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The mint vault shares request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function vaultMintShares(\n client: AaveClient,\n request: VaultMintSharesRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(VaultMintSharesQuery, { request });\n}\n\n/**\n * Creates a transaction to enable/disable a specific supplied asset as collateral.\n *\n * ```ts\n * const result = await collateralToggle(client, {\n * market: market.address,\n * underlyingToken: market.supplyReserves[n].underlyingToken.address,\n * user: evmAddress('0x9abc…'),\n * chainId: market.chain.chainId,\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The collateral toggle request parameters.\n * @returns The transaction request data to toggle collateral.\n */\nexport function collateralToggle(\n client: AaveClient,\n request: CollateralToggleRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(CollateralToggleQuery, { request });\n}\n\n/**\n * Creates a transaction to liquidate a non-healthy position with Health Factor below 1.\n *\n * ```ts\n * const result = await liquidate(client, {\n * collateralToken: evmAddress('0x1234…'),\n * debtToken: evmAddress('0x5678…'),\n * user: evmAddress('0x9abc…'),\n * debtToCover: { max: true },\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The liquidate request parameters.\n * @returns The transaction request data to liquidate position.\n */\nexport function liquidate(\n client: AaveClient,\n request: LiquidateRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(LiquidateQuery, { request });\n}\n\n/**\n * Creates a transaction to approve a credit borrow delegator to be able to borrow on your behalf.\n *\n * ```ts\n * const result = await approveBorrowCreditDelegation(client, {\n * market: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * underlyingToken: evmAddress('0xa0b86a33e6441c8c5f0bb9b7e5e1f8bbf5b78b5c'),\n * amount: '1000',\n * user: evmAddress('0x742d35cc6e5c4ce3b69a2a8c7c8e5f7e9a0b1234'),\n * delegatee: evmAddress('0x5678…'),\n * chainId: chainId(1),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error, e.g. signing error, etc.\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n * @param client - Aave client.\n * @param request - The approve borrow credit delegation request parameters.\n * @returns The transaction request data to approve credit delegation.\n */\nexport function approveBorrowCreditDelegation(\n client: AaveClient,\n request: ApproveBorrowCreditDelegatorRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(ApproveBorrowCreditDelegationQuery, { request });\n}\n\n/**\n * Gets the amount delegated to the credit delegatee that can borrow on your behalf.\n *\n * ```ts\n * const result = await creditDelegateeAllowance(client, {\n * market: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),\n * underlyingToken: evmAddress('0xa0b86a33e6441c8c5f0bb9b7e5e1f8bbf5b78b5c'),\n * user: evmAddress('0x742d35cc6e5c4ce3b69a2a8c7c8e5f7e9a0b1234'),\n * delegatee: evmAddress('0x5678…'),\n * chainId: chainId(1),\n * });\n *\n * if (result.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * // result.value: TokenAmount with credit delegation allowance\n * ```\n *\n * @param client - Aave client.\n * @param request - The credit delegatee allowance request parameters.\n * @returns The token amount representing the credit delegation allowance.\n */\nexport function creditDelegateeAllowance(\n client: AaveClient,\n request: CreditDelegateeAmountRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(CreditDelegateeAllowanceQuery, { request });\n}\n","import {\n type MarketUserReserveBorrowPosition,\n type MarketUserReserveSupplyPosition,\n type PaginatedUserTransactionHistoryResult,\n UserBorrowsQuery,\n type UserBorrowsRequest,\n UserSuppliesQuery,\n type UserSuppliesRequest,\n UserTransactionHistoryQuery,\n type UserTransactionHistoryRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Fetches all user supply positions across the specified markets.\n *\n * ```ts\n * const result = await userSupplies(client, {\n * markets: [{ address: evmAddress('0x87870bca…'), chainId: chainId(1) }],\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user supplies request parameters.\n * @returns The user's supply positions.\n */\nexport function userSupplies(\n client: AaveClient,\n request: UserSuppliesRequest,\n): ResultAsync<MarketUserReserveSupplyPosition[], UnexpectedError> {\n return client.query(UserSuppliesQuery, { request });\n}\n\n/**\n * Fetches all user borrow positions.\n *\n * ```ts\n * const result = await userBorrows(client, {\n * markets: [{ address: evmAddress('0x87870bca…'), chainId: chainId(1) }],\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user borrows request parameters.\n * @returns The user's borrow positions.\n */\nexport function userBorrows(\n client: AaveClient,\n request: UserBorrowsRequest,\n): ResultAsync<MarketUserReserveBorrowPosition[], UnexpectedError> {\n return client.query(UserBorrowsQuery, { request });\n}\n\n/**\n * Fetches the user's transaction history for a given market.\n *\n * ```ts\n * const result = await userTransactionHistory(client, {\n * chainId: chainId(1),\n * market: evmAddress('0x87870bca…'),\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user transaction history request parameters.\n * @returns The user's paginated transaction history.\n */\nexport function userTransactionHistory(\n client: AaveClient,\n request: UserTransactionHistoryRequest,\n): ResultAsync<PaginatedUserTransactionHistoryResult, UnexpectedError> {\n return client.query(UserTransactionHistoryQuery, { request });\n}\n","import {\n type PaginatedVaultsResult,\n type PaginatedVaultUserTransactionHistoryResult,\n type TokenAmount,\n UserVaultsQuery,\n type UserVaultsRequest,\n type Vault,\n VaultPreviewDepositQuery,\n type VaultPreviewDepositRequest,\n VaultPreviewMintQuery,\n type VaultPreviewMintRequest,\n VaultPreviewRedeemQuery,\n type VaultPreviewRedeemRequest,\n VaultPreviewWithdrawQuery,\n type VaultPreviewWithdrawRequest,\n VaultQuery,\n type VaultRequest,\n VaultsQuery,\n type VaultsRequest,\n VaultUserTransactionHistoryQuery,\n type VaultUserTransactionHistoryRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../client';\nimport type { UnexpectedError } from '../errors';\n\n/**\n * Fetches a specific vault by address and chain ID.\n *\n * **Example: By Address**\n * ```ts\n * const result = await vault(client, {\n * by: {\n * address: evmAddress('0x1234…'),\n * },\n * chainId: chainId(1),\n * user: evmAddress('0x5678…'),\n * });\n * ```\n *\n * **Example: Tx Hash**\n * ```ts\n * const result = await vault(client, {\n * by: {\n * txHash: txHash('0x1234…'),\n * },\n * chainId: chainId(1),\n * user: evmAddress('0x5678…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault request parameters.\n * @returns The vault data, or null if not found.\n */\nexport function vault(\n client: AaveClient,\n request: VaultRequest,\n): ResultAsync<Vault | null, UnexpectedError> {\n return client.query(VaultQuery, {\n request,\n });\n}\n\n/**\n * Fetches vaults based on filter criteria.\n *\n * ```ts\n * const result = await vaults(client, {\n * criteria: {\n * ownedBy: [evmAddress('0x1234…')]\n * },\n * pageSize: PageSize.Ten,\n * user: evmAddress('0x5678…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The vaults request parameters.\n * @returns The paginated vaults result.\n */\nexport function vaults(\n client: AaveClient,\n request: VaultsRequest,\n): ResultAsync<PaginatedVaultsResult, UnexpectedError> {\n return client.query(VaultsQuery, {\n request,\n });\n}\n\n/**\n * Fetches vaults that a user has shares in.\n *\n * ```ts\n * const result = await userVaults(client, {\n * user: evmAddress('0x1234…'),\n * filters: {\n * markets: [evmAddress('0x5678…')]\n * },\n * orderBy: { shares: OrderDirection.Desc },\n * pageSize: PageSize.Fifty,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user vaults request parameters.\n * @returns The paginated user vaults result.\n */\nexport function userVaults(\n client: AaveClient,\n request: UserVaultsRequest,\n): ResultAsync<PaginatedVaultsResult, UnexpectedError> {\n return client.query(UserVaultsQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of shares that would be received for a deposit.\n *\n * ```ts\n * const result = await vaultPreviewDeposit(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('1000'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Shares to receive:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview deposit request parameters.\n * @returns The simulated shares amount that would be received.\n */\nexport function vaultPreviewDeposit(\n client: AaveClient,\n request: VaultPreviewDepositRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewDepositQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of assets that would be required to mint a specific amount of vault shares.\n *\n * ```ts\n * const result = await vaultPreviewMint(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('500'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Assets required:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview mint request parameters.\n * @returns The simulated assets amount that would be required.\n */\nexport function vaultPreviewMint(\n client: AaveClient,\n request: VaultPreviewMintRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewMintQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of shares that would be burned for a withdrawal.\n *\n * ```ts\n * const result = await vaultPreviewWithdraw(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('750'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Shares to burn:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview withdraw request parameters.\n * @returns The simulated shares amount that would be burned.\n */\nexport function vaultPreviewWithdraw(\n client: AaveClient,\n request: VaultPreviewWithdrawRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewWithdrawQuery, {\n request,\n });\n}\n\n/**\n * Determines the amount of assets that would be received for redeeming a specific amount of vault shares.\n *\n * ```ts\n * const result = await vaultPreviewRedeem(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * amount: bigDecimal('200'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Assets to receive:', result.value.amount.value);\n * console.log('USD value:', result.value.usd);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault preview redeem request parameters.\n * @returns The simulated assets amount that would be received.\n */\nexport function vaultPreviewRedeem(\n client: AaveClient,\n request: VaultPreviewRedeemRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(VaultPreviewRedeemQuery, {\n request,\n });\n}\n\n/**\n * Fetches the user transaction history for a vault.\n *\n * ```ts\n * const result = await vaultUserTransactionHistory(client, {\n * vault: evmAddress('0x1234567890abcdef1234567890abcdef12345678'),\n * chainId: chainId(1),\n * user: evmAddress('0x5678901234567890abcdef1234567890abcdef12'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Transaction count:', result.value.items.length);\n * result.value.items.forEach(tx => {\n * if (tx.__typename === 'VaultUserDepositItem') {\n * console.log('Deposit:', tx.asset.amount.value, 'shares:', tx.shares.amount.value);\n * } else if (tx.__typename === 'VaultUserWithdrawItem') {\n * console.log('Withdraw:', tx.asset.amount.value, 'shares:', tx.shares.amount.value);\n * }\n * });\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault user transaction history request parameters.\n * @returns The paginated vault user transaction history result.\n */\nexport function vaultUserTransactionHistory(\n client: AaveClient,\n request: VaultUserTransactionHistoryRequest,\n): ResultAsync<PaginatedVaultUserTransactionHistoryResult, UnexpectedError> {\n return client.query(VaultUserTransactionHistoryQuery, {\n request,\n });\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { MarketReservesRequestOrderBy, Market, UserMarketStateRequest, MarketUserState, ChainsFilter, Chain, UsdExchangeRatesRequest, UsdExchangeRate, HasProcessedKnownTransactionRequest, PermitTypedDataRequest, PermitTypedDataResponse, ReserveRequest, Reserve, BorrowAPYHistoryRequest, APYSample, SupplyAPYHistoryRequest, BorrowRequest, ExecutionPlan, SupplyRequest, RepayRequest, WithdrawRequest, UserSetEmodeRequest, TransactionRequest, VaultDepositRequest, VaultRedeemSharesRequest, VaultDeployRequest, VaultSetFeeRequest, VaultWithdrawFeesRequest, VaultWithdrawRequest, VaultMintSharesRequest, CollateralToggleRequest, LiquidateRequest, ApproveBorrowCreditDelegatorRequest, CreditDelegateeAmountRequest, TokenAmount, UserSuppliesRequest, MarketUserReserveSupplyPosition, UserBorrowsRequest, MarketUserReserveBorrowPosition, UserTransactionHistoryRequest, PaginatedUserTransactionHistoryResult, VaultRequest, Vault, VaultsRequest, PaginatedVaultsResult, UserVaultsRequest, VaultPreviewDepositRequest, VaultPreviewMintRequest, VaultPreviewWithdrawRequest, VaultPreviewRedeemRequest, VaultUserTransactionHistoryRequest, PaginatedVaultUserTransactionHistoryResult } from '@aave/graphql';
1
+ import { MarketReservesRequestOrderBy, Market, UserMarketStateRequest, MarketUserState, ChainsFilter, Chain, UsdExchangeRatesRequest, UsdExchangeRate, HasProcessedKnownTransactionRequest, HealthFactorPreviewRequest, HealthFactorPreviewResponse, PermitTypedDataRequest, PermitTypedDataResponse, ReserveRequest, Reserve, BorrowAPYHistoryRequest, APYSample, SupplyAPYHistoryRequest, BorrowRequest, ExecutionPlan, SupplyRequest, RepayRequest, WithdrawRequest, UserSetEmodeRequest, TransactionRequest, VaultDepositRequest, VaultRedeemSharesRequest, VaultDeployRequest, VaultSetFeeRequest, VaultWithdrawFeesRequest, VaultWithdrawRequest, VaultMintSharesRequest, CollateralToggleRequest, LiquidateRequest, ApproveBorrowCreditDelegatorRequest, CreditDelegateeAmountRequest, TokenAmount, UserSuppliesRequest, MarketUserReserveSupplyPosition, UserBorrowsRequest, MarketUserReserveBorrowPosition, UserTransactionHistoryRequest, PaginatedUserTransactionHistoryResult, VaultRequest, Vault, VaultsRequest, PaginatedVaultsResult, UserVaultsRequest, VaultPreviewDepositRequest, VaultPreviewMintRequest, VaultPreviewWithdrawRequest, VaultPreviewRedeemRequest, VaultUserTransactionHistoryRequest, PaginatedVaultUserTransactionHistoryResult } from '@aave/graphql';
2
2
  import { ChainId, EvmAddress, ResultAsync } from '@aave/types';
3
3
  import { AaveClient } from '../index.cjs';
4
4
  import { U as UnexpectedError } from '../types-DwXCLJq5.cjs';
@@ -118,7 +118,7 @@ declare function health(client: AaveClient): ResultAsync<boolean, UnexpectedErro
118
118
  * Fetches the list of supported chains.
119
119
  *
120
120
  * ```ts
121
- * const result = await chains(client, { filter: ChainsFilter.MAINNET_ONLY });
121
+ * const result = await chains(client, ChainsFilter.MAINNET_ONLY);
122
122
  * ```
123
123
  *
124
124
  * @param client - Aave client.
@@ -184,6 +184,32 @@ declare function usdExchangeRates(client: AaveClient, request: UsdExchangeRatesR
184
184
  * @returns True if the transaction has been processed, false otherwise.
185
185
  */
186
186
  declare function hasProcessedKnownTransaction(client: AaveClient, request: HasProcessedKnownTransactionRequest): ResultAsync<boolean, UnexpectedError>;
187
+ /**
188
+ * Fetches health factor preview for a given market action.
189
+ *
190
+ * ```ts
191
+ * const result = await healthFactorPreview(client, {
192
+ * action: {
193
+ * borrow: {
194
+ * market: market.address,
195
+ * amount: {
196
+ * erc20: {
197
+ * currency: evmAddress('0x5678…'),
198
+ * value: '1000',
199
+ * },
200
+ * },
201
+ * borrower: evmAddress('0x9abc…'),
202
+ * chainId: market.chain.chainId,
203
+ * },
204
+ * },
205
+ * });
206
+ * ```
207
+ *
208
+ * @param client - Aave client.
209
+ * @param request - The health factor preview request parameters.
210
+ * @returns The health factor preview response with before and after values.
211
+ */
212
+ declare function healthFactorPreview(client: AaveClient, request: HealthFactorPreviewRequest): ResultAsync<HealthFactorPreviewResponse, UnexpectedError>;
187
213
 
188
214
  /**
189
215
  * Generates EIP-712 typed data for ERC-20 permit signature.
@@ -316,7 +342,9 @@ declare function supply(client: AaveClient, request: SupplyRequest): ResultAsync
316
342
  * amount: {
317
343
  * erc20: {
318
344
  * currency: evmAddress('0x5678…'),
319
- * value: '500',
345
+ * value: {
346
+ * exact: '500',
347
+ * },
320
348
  * },
321
349
  * },
322
350
  * borrower: evmAddress('0x9abc…'),
@@ -916,4 +944,4 @@ declare function vaultPreviewRedeem(client: AaveClient, request: VaultPreviewRed
916
944
  */
917
945
  declare function vaultUserTransactionHistory(client: AaveClient, request: VaultUserTransactionHistoryRequest): ResultAsync<PaginatedVaultUserTransactionHistoryResult, UnexpectedError>;
918
946
 
919
- export { type MarketRequest, type MarketsRequest, approveBorrowCreditDelegation, borrow, borrowAPYHistory, chains, collateralToggle, creditDelegateeAllowance, defaultMarketReservesRequestOrderBy, hasProcessedKnownTransaction, health, liquidate, market, markets, permitTypedData, repay, reserve, supply, supplyAPYHistory, usdExchangeRates, userBorrows, userMarketState, userSetEmode, userSupplies, userTransactionHistory, userVaults, vault, vaultDeploy, vaultDeposit, vaultMintShares, vaultPreviewDeposit, vaultPreviewMint, vaultPreviewRedeem, vaultPreviewWithdraw, vaultRedeemShares, vaultSetFee, vaultUserTransactionHistory, vaultWithdraw, vaultWithdrawFees, vaults, withdraw };
947
+ export { type MarketRequest, type MarketsRequest, approveBorrowCreditDelegation, borrow, borrowAPYHistory, chains, collateralToggle, creditDelegateeAllowance, defaultMarketReservesRequestOrderBy, hasProcessedKnownTransaction, health, healthFactorPreview, liquidate, market, markets, permitTypedData, repay, reserve, supply, supplyAPYHistory, usdExchangeRates, userBorrows, userMarketState, userSetEmode, userSupplies, userTransactionHistory, userVaults, vault, vaultDeploy, vaultDeposit, vaultMintShares, vaultPreviewDeposit, vaultPreviewMint, vaultPreviewRedeem, vaultPreviewWithdraw, vaultRedeemShares, vaultSetFee, vaultUserTransactionHistory, vaultWithdraw, vaultWithdrawFees, vaults, withdraw };
@@ -1,4 +1,4 @@
1
- import { MarketReservesRequestOrderBy, Market, UserMarketStateRequest, MarketUserState, ChainsFilter, Chain, UsdExchangeRatesRequest, UsdExchangeRate, HasProcessedKnownTransactionRequest, PermitTypedDataRequest, PermitTypedDataResponse, ReserveRequest, Reserve, BorrowAPYHistoryRequest, APYSample, SupplyAPYHistoryRequest, BorrowRequest, ExecutionPlan, SupplyRequest, RepayRequest, WithdrawRequest, UserSetEmodeRequest, TransactionRequest, VaultDepositRequest, VaultRedeemSharesRequest, VaultDeployRequest, VaultSetFeeRequest, VaultWithdrawFeesRequest, VaultWithdrawRequest, VaultMintSharesRequest, CollateralToggleRequest, LiquidateRequest, ApproveBorrowCreditDelegatorRequest, CreditDelegateeAmountRequest, TokenAmount, UserSuppliesRequest, MarketUserReserveSupplyPosition, UserBorrowsRequest, MarketUserReserveBorrowPosition, UserTransactionHistoryRequest, PaginatedUserTransactionHistoryResult, VaultRequest, Vault, VaultsRequest, PaginatedVaultsResult, UserVaultsRequest, VaultPreviewDepositRequest, VaultPreviewMintRequest, VaultPreviewWithdrawRequest, VaultPreviewRedeemRequest, VaultUserTransactionHistoryRequest, PaginatedVaultUserTransactionHistoryResult } from '@aave/graphql';
1
+ import { MarketReservesRequestOrderBy, Market, UserMarketStateRequest, MarketUserState, ChainsFilter, Chain, UsdExchangeRatesRequest, UsdExchangeRate, HasProcessedKnownTransactionRequest, HealthFactorPreviewRequest, HealthFactorPreviewResponse, PermitTypedDataRequest, PermitTypedDataResponse, ReserveRequest, Reserve, BorrowAPYHistoryRequest, APYSample, SupplyAPYHistoryRequest, BorrowRequest, ExecutionPlan, SupplyRequest, RepayRequest, WithdrawRequest, UserSetEmodeRequest, TransactionRequest, VaultDepositRequest, VaultRedeemSharesRequest, VaultDeployRequest, VaultSetFeeRequest, VaultWithdrawFeesRequest, VaultWithdrawRequest, VaultMintSharesRequest, CollateralToggleRequest, LiquidateRequest, ApproveBorrowCreditDelegatorRequest, CreditDelegateeAmountRequest, TokenAmount, UserSuppliesRequest, MarketUserReserveSupplyPosition, UserBorrowsRequest, MarketUserReserveBorrowPosition, UserTransactionHistoryRequest, PaginatedUserTransactionHistoryResult, VaultRequest, Vault, VaultsRequest, PaginatedVaultsResult, UserVaultsRequest, VaultPreviewDepositRequest, VaultPreviewMintRequest, VaultPreviewWithdrawRequest, VaultPreviewRedeemRequest, VaultUserTransactionHistoryRequest, PaginatedVaultUserTransactionHistoryResult } from '@aave/graphql';
2
2
  import { ChainId, EvmAddress, ResultAsync } from '@aave/types';
3
3
  import { AaveClient } from '../index.js';
4
4
  import { U as UnexpectedError } from '../types-DwXCLJq5.js';
@@ -118,7 +118,7 @@ declare function health(client: AaveClient): ResultAsync<boolean, UnexpectedErro
118
118
  * Fetches the list of supported chains.
119
119
  *
120
120
  * ```ts
121
- * const result = await chains(client, { filter: ChainsFilter.MAINNET_ONLY });
121
+ * const result = await chains(client, ChainsFilter.MAINNET_ONLY);
122
122
  * ```
123
123
  *
124
124
  * @param client - Aave client.
@@ -184,6 +184,32 @@ declare function usdExchangeRates(client: AaveClient, request: UsdExchangeRatesR
184
184
  * @returns True if the transaction has been processed, false otherwise.
185
185
  */
186
186
  declare function hasProcessedKnownTransaction(client: AaveClient, request: HasProcessedKnownTransactionRequest): ResultAsync<boolean, UnexpectedError>;
187
+ /**
188
+ * Fetches health factor preview for a given market action.
189
+ *
190
+ * ```ts
191
+ * const result = await healthFactorPreview(client, {
192
+ * action: {
193
+ * borrow: {
194
+ * market: market.address,
195
+ * amount: {
196
+ * erc20: {
197
+ * currency: evmAddress('0x5678…'),
198
+ * value: '1000',
199
+ * },
200
+ * },
201
+ * borrower: evmAddress('0x9abc…'),
202
+ * chainId: market.chain.chainId,
203
+ * },
204
+ * },
205
+ * });
206
+ * ```
207
+ *
208
+ * @param client - Aave client.
209
+ * @param request - The health factor preview request parameters.
210
+ * @returns The health factor preview response with before and after values.
211
+ */
212
+ declare function healthFactorPreview(client: AaveClient, request: HealthFactorPreviewRequest): ResultAsync<HealthFactorPreviewResponse, UnexpectedError>;
187
213
 
188
214
  /**
189
215
  * Generates EIP-712 typed data for ERC-20 permit signature.
@@ -316,7 +342,9 @@ declare function supply(client: AaveClient, request: SupplyRequest): ResultAsync
316
342
  * amount: {
317
343
  * erc20: {
318
344
  * currency: evmAddress('0x5678…'),
319
- * value: '500',
345
+ * value: {
346
+ * exact: '500',
347
+ * },
320
348
  * },
321
349
  * },
322
350
  * borrower: evmAddress('0x9abc…'),
@@ -916,4 +944,4 @@ declare function vaultPreviewRedeem(client: AaveClient, request: VaultPreviewRed
916
944
  */
917
945
  declare function vaultUserTransactionHistory(client: AaveClient, request: VaultUserTransactionHistoryRequest): ResultAsync<PaginatedVaultUserTransactionHistoryResult, UnexpectedError>;
918
946
 
919
- export { type MarketRequest, type MarketsRequest, approveBorrowCreditDelegation, borrow, borrowAPYHistory, chains, collateralToggle, creditDelegateeAllowance, defaultMarketReservesRequestOrderBy, hasProcessedKnownTransaction, health, liquidate, market, markets, permitTypedData, repay, reserve, supply, supplyAPYHistory, usdExchangeRates, userBorrows, userMarketState, userSetEmode, userSupplies, userTransactionHistory, userVaults, vault, vaultDeploy, vaultDeposit, vaultMintShares, vaultPreviewDeposit, vaultPreviewMint, vaultPreviewRedeem, vaultPreviewWithdraw, vaultRedeemShares, vaultSetFee, vaultUserTransactionHistory, vaultWithdraw, vaultWithdrawFees, vaults, withdraw };
947
+ export { type MarketRequest, type MarketsRequest, approveBorrowCreditDelegation, borrow, borrowAPYHistory, chains, collateralToggle, creditDelegateeAllowance, defaultMarketReservesRequestOrderBy, hasProcessedKnownTransaction, health, healthFactorPreview, liquidate, market, markets, permitTypedData, repay, reserve, supply, supplyAPYHistory, usdExchangeRates, userBorrows, userMarketState, userSetEmode, userSupplies, userTransactionHistory, userVaults, vault, vaultDeploy, vaultDeposit, vaultMintShares, vaultPreviewDeposit, vaultPreviewMint, vaultPreviewRedeem, vaultPreviewWithdraw, vaultRedeemShares, vaultSetFee, vaultUserTransactionHistory, vaultWithdraw, vaultWithdrawFees, vaults, withdraw };
@@ -1,2 +1,2 @@
1
- export{A as approveBorrowCreditDelegation,m as borrow,k as borrowAPYHistory,f as chains,y as collateralToggle,B as creditDelegateeAllowance,a as defaultMarketReservesRequestOrderBy,h as hasProcessedKnownTransaction,e as health,z as liquidate,c as market,b as markets,i as permitTypedData,o as repay,j as reserve,n as supply,l as supplyAPYHistory,g as usdExchangeRates,D as userBorrows,d as userMarketState,q as userSetEmode,C as userSupplies,E as userTransactionHistory,H as userVaults,F as vault,t as vaultDeploy,r as vaultDeposit,x as vaultMintShares,I as vaultPreviewDeposit,J as vaultPreviewMint,L as vaultPreviewRedeem,K as vaultPreviewWithdraw,s as vaultRedeemShares,u as vaultSetFee,M as vaultUserTransactionHistory,w as vaultWithdraw,v as vaultWithdrawFees,G as vaults,p as withdraw}from'../chunk-TNK2KAUO.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
1
+ export{B as approveBorrowCreditDelegation,n as borrow,l as borrowAPYHistory,f as chains,z as collateralToggle,C as creditDelegateeAllowance,a as defaultMarketReservesRequestOrderBy,h as hasProcessedKnownTransaction,e as health,i as healthFactorPreview,A as liquidate,c as market,b as markets,j as permitTypedData,p as repay,k as reserve,o as supply,m as supplyAPYHistory,g as usdExchangeRates,E as userBorrows,d as userMarketState,r as userSetEmode,D as userSupplies,F as userTransactionHistory,I as userVaults,G as vault,u as vaultDeploy,s as vaultDeposit,y as vaultMintShares,J as vaultPreviewDeposit,K as vaultPreviewMint,M as vaultPreviewRedeem,L as vaultPreviewWithdraw,t as vaultRedeemShares,v as vaultSetFee,N as vaultUserTransactionHistory,x as vaultWithdraw,w as vaultWithdrawFees,H as vaults,q as withdraw}from'../chunk-UT2XHWIJ.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,3 +1,3 @@
1
- import {c,f as f$1}from'./chunk-QYPBLR6B.js';import {h}from'./chunk-TNK2KAUO.js';import {ResultAsync,invariant,errAsync,okAsync,Deferred,never}from'@aave/types';import {createClient,fetchExchange}from'@urql/core';import {Kind,visit,OperationTypeNode}from'graphql';var N={name:"production",backend:"https://api.v3.aave.com/graphql",indexingTimeout:6e4,pollingInterval:100},Y={name:"staging",backend:"https://api.v3.staging.aave.com/graphql",indexingTimeout:6e4,pollingInterval:100},z={name:"local",backend:"http://localhost:3011/graphql",indexingTimeout:6e4,pollingInterval:1e3};var p=class{queries=[];addQuery=(t,e)=>{invariant(this.queries.length<10,"Batch queries supports a maximum of 10 queries");let n=`value_${this.queries.length}`,r=new Deferred;return this.queries.push({alias:n,document:t,variables:e,deferred:r}),ResultAsync.fromPromise(r.promise,o=>c.is(o)?o:c.from(o))};build(){let t=new Map,e=[],n=[],r={},o=0;for(let{alias:u,document:y,variables:I}of this.queries){let[b,P]=Q(y);for(let a of P){let c=a.name.value;t.has(c)||t.set(c,a);}let v=new Map,_=b.variableDefinitions?.map(a=>{let c=`${a.variable.name.value}_${o++}`;return v.set(a.variable.name.value,c),r[c]=I[a.variable.name.value]??never(),{...a,variable:{...a.variable,name:{kind:Kind.NAME,value:c}}}})??[];n.push(..._);let H=visit(b.selectionSet,{Variable(a){let c=v.get(a.name.value);return c?{...a,name:{kind:Kind.NAME,value:c}}:a},Field(a){return {...a,alias:{kind:Kind.NAME,value:u}}}});e.push(...H.selections);}let i={kind:Kind.OPERATION_DEFINITION,operation:OperationTypeNode.QUERY,variableDefinitions:n,selectionSet:{kind:Kind.SELECTION_SET,selections:e}};return [{kind:Kind.DOCUMENT,definitions:[i,...t.values()]},r]}resolve(t){for(let{alias:e,deferred:n}of this.queries)Object.hasOwn(t,e)&&t[e]!==void 0?n.resolve(t[e]):n.reject(c.from(`Missing response data for query alias "${e}". Please report this issue to the Avara team.`));}};function Q(s){let t,e=[];for(let n of s.definitions)switch(n.kind){case Kind.OPERATION_DEFINITION:invariant(n.operation===OperationTypeNode.QUERY,"Only query operations are supported"),invariant(t===void 0,"Only one operation definition is supported"),t=n;break;case Kind.FRAGMENT_DEFINITION:e.push(n);break;default:never(`Unexpected definition kind: ${n.kind}`);}return invariant(t,"No operation definition found in the document"),[t,e]}var R=class{constructor(t){this.document=t;this._fragmentSpreads=new Map,this._recursivelyReferencedFragments=new Map;}_fragments;_fragmentSpreads;_recursivelyReferencedFragments;dedupe(){let t=[],e=[],n=[];return visit(this.document,{OperationDefinition:r=>(t.push(r),false),FragmentDefinition:r=>(e.push(r),false),Document:{leave:()=>{let r=Object.create(null);for(let o of t)for(let i of this.getRecursivelyReferencedFragments(o))r[i.name.value]=true;for(let o of e){let i=o.name.value;r[i]!==true&&n.push(o);}}}}),visit(this.document,{FragmentDefinition:r=>n.indexOf(r)!==-1?null:r})}getRecursivelyReferencedFragments(t){let e=this._recursivelyReferencedFragments.get(t);if(!e){e=[];let n=Object.create(null),r=[t.selectionSet],o;for(;o=r.pop();)for(let i of this.getFragmentSpreads(o)){let E=i.name.value;if(n[E]!==true){n[E]=true;let u=this.getFragment(E);u&&(e.push(u),r.push(u.selectionSet));}}this._recursivelyReferencedFragments.set(t,e);}return e}getFragmentSpreads(t){let e=this._fragmentSpreads.get(t);if(!e){e=[];let n=[t],r;for(;r=n.pop();)for(let o of r.selections)o.kind===Kind.FRAGMENT_SPREAD?e.push(o):o.selectionSet&&n.push(o.selectionSet);this._fragmentSpreads.set(t,e);}return e}getFragment(t){let e;if(this._fragments)e=this._fragments;else {e=Object.create(null);for(let n of this.document.definitions)n.kind===Kind.FRAGMENT_DEFINITION&&(e[n.name.value]=n);this._fragments=e;}return e[t]}},m=class s{constructor(t){this.fragments=t;}static from(t){let e=new Map;for(let n of t)for(let r of n.definitions)invariant(r.kind==="FragmentDefinition",`expected a fragment definition, got ${n.definitions[0]?.kind}`),invariant(!e.has(r.name.value),`Duplicate fragment detected. A fragment named "${r.name.value}" has already been provided, either directly or as part of another fragment document.`),e.set(r.name.value,r);return new s(e)}replaceFrom(t){let e=visit(t,{FragmentDefinition:n=>this.fragments.has(n.name.value)?null:n,Document:{leave:n=>({...n,definitions:[...n.definitions,...this.fragments.values()]})}});return new R(e).dedupe()}};function O(s){return {environment:s.environment??N,headers:s.headers,cache:s.cache??false,debug:s.debug??false,fragments:m.from(s.fragments??[])}}var f=class s{level;name;constructor(t,e=3){this.name=t,this.level=e,this.replaceMethods();}static named(t,e=3){return new s(t,e)}trace=()=>{};debug=()=>{};info=()=>{};warn=()=>{};error=()=>{};log=()=>{};replaceMethods(){["trace","debug","info","warn","error"].forEach((t,e)=>{e>=this.level?this[t]=()=>{}:this[t]=(...n)=>console[t==="debug"?"log":t](`[${this.name}]`,...n);}),this.log=this.debug;}};function q(s){return s.operation!==null}function M(s){return new Promise(t=>setTimeout(t,s))}function k({data:s,error:t}){return invariant(s,`Expected a value, got: ${t?.message}`),s.value}var C=class s{constructor(t){this.context=t;this.logger=f.named(this.constructor.name,t.debug?1:5),this.urql=createClient({url:t.environment.backend,fetchOptions:{credentials:"omit",headers:t.headers},exchanges:this.exchanges()});}urql;logger;static create(t){return new s(O(t??{}))}query(t,e){let n=this.context.fragments.replaceFrom(t);return this.resultFrom(this.urql.query(n,e)).map(k)}mutation(t,e){return this.resultFrom(this.urql.mutation(t,e)).map(k)}batch(t){let e=new p,n=Object.create(this,{query:{value:e.addQuery}}),r=ResultAsync.combine(t(n)),[o,i]=e.build(),E=this.context.fragments.replaceFrom(o);return this.resultFrom(this.urql.query(E,i)).andTee(({data:u,error:y})=>{invariant(u,`Expected a value, got: ${y?.message}`),e.resolve(u);}).andThen(()=>r)}waitForTransaction=t=>(invariant(q(t),"Received a transaction result for an untracked operation. Make sure you're following the instructions in the docs."),ResultAsync.fromPromise(this.pollTransactionStatus(t),e=>e instanceof f$1||e instanceof c?e:c.from(e)));async pollTransactionStatus(t){let e=Date.now();for(;Date.now()-e<this.context.environment.indexingTimeout;){if(await h(this,t).match(r=>r,r=>{throw r}))return t.txHash;await M(this.context.environment.pollingInterval);}throw f$1.from(`Timeout waiting for transaction ${t.txHash} to be processed.`)}exchanges(){return [fetchExchange]}resultFrom(t){return ResultAsync.fromPromise(t.toPromise(),e=>(this.logger.error(e),console.log(e),c.from(e))).andThen(e=>e.error?.networkError?errAsync(c.from(e.error.networkError)):okAsync(e))}};
2
- export{N as a,Y as b,z as c,C as d};//# sourceMappingURL=chunk-ELKWKN2P.js.map
3
- //# sourceMappingURL=chunk-ELKWKN2P.js.map
1
+ import {c,f as f$1}from'./chunk-QYPBLR6B.js';import {h}from'./chunk-UT2XHWIJ.js';import {ResultAsync,invariant,errAsync,okAsync,Deferred,never}from'@aave/types';import {createClient,fetchExchange}from'@urql/core';import {Kind,visit,OperationTypeNode}from'graphql';var N={name:"production",backend:"https://api.v3.aave.com/graphql",indexingTimeout:6e4,pollingInterval:100},Y={name:"staging",backend:"https://api.v3.staging.aave.com/graphql",indexingTimeout:6e4,pollingInterval:100},z={name:"local",backend:"http://localhost:3011/graphql",indexingTimeout:6e4,pollingInterval:1e3};var p=class{queries=[];addQuery=(t,e)=>{invariant(this.queries.length<10,"Batch queries supports a maximum of 10 queries");let n=`value_${this.queries.length}`,r=new Deferred;return this.queries.push({alias:n,document:t,variables:e,deferred:r}),ResultAsync.fromPromise(r.promise,o=>c.is(o)?o:c.from(o))};build(){let t=new Map,e=[],n=[],r={},o=0;for(let{alias:u,document:y,variables:I}of this.queries){let[b,P]=Q(y);for(let a of P){let c=a.name.value;t.has(c)||t.set(c,a);}let v=new Map,_=b.variableDefinitions?.map(a=>{let c=`${a.variable.name.value}_${o++}`;return v.set(a.variable.name.value,c),r[c]=I[a.variable.name.value]??never(),{...a,variable:{...a.variable,name:{kind:Kind.NAME,value:c}}}})??[];n.push(..._);let H=visit(b.selectionSet,{Variable(a){let c=v.get(a.name.value);return c?{...a,name:{kind:Kind.NAME,value:c}}:a},Field(a){return {...a,alias:{kind:Kind.NAME,value:u}}}});e.push(...H.selections);}let i={kind:Kind.OPERATION_DEFINITION,operation:OperationTypeNode.QUERY,variableDefinitions:n,selectionSet:{kind:Kind.SELECTION_SET,selections:e}};return [{kind:Kind.DOCUMENT,definitions:[i,...t.values()]},r]}resolve(t){for(let{alias:e,deferred:n}of this.queries)Object.hasOwn(t,e)&&t[e]!==void 0?n.resolve(t[e]):n.reject(c.from(`Missing response data for query alias "${e}". Please report this issue to the Avara team.`));}};function Q(s){let t,e=[];for(let n of s.definitions)switch(n.kind){case Kind.OPERATION_DEFINITION:invariant(n.operation===OperationTypeNode.QUERY,"Only query operations are supported"),invariant(t===void 0,"Only one operation definition is supported"),t=n;break;case Kind.FRAGMENT_DEFINITION:e.push(n);break;default:never(`Unexpected definition kind: ${n.kind}`);}return invariant(t,"No operation definition found in the document"),[t,e]}var R=class{constructor(t){this.document=t;this._fragmentSpreads=new Map,this._recursivelyReferencedFragments=new Map;}_fragments;_fragmentSpreads;_recursivelyReferencedFragments;dedupe(){let t=[],e=[],n=[];return visit(this.document,{OperationDefinition:r=>(t.push(r),false),FragmentDefinition:r=>(e.push(r),false),Document:{leave:()=>{let r=Object.create(null);for(let o of t)for(let i of this.getRecursivelyReferencedFragments(o))r[i.name.value]=true;for(let o of e){let i=o.name.value;r[i]!==true&&n.push(o);}}}}),visit(this.document,{FragmentDefinition:r=>n.indexOf(r)!==-1?null:r})}getRecursivelyReferencedFragments(t){let e=this._recursivelyReferencedFragments.get(t);if(!e){e=[];let n=Object.create(null),r=[t.selectionSet],o;for(;o=r.pop();)for(let i of this.getFragmentSpreads(o)){let E=i.name.value;if(n[E]!==true){n[E]=true;let u=this.getFragment(E);u&&(e.push(u),r.push(u.selectionSet));}}this._recursivelyReferencedFragments.set(t,e);}return e}getFragmentSpreads(t){let e=this._fragmentSpreads.get(t);if(!e){e=[];let n=[t],r;for(;r=n.pop();)for(let o of r.selections)o.kind===Kind.FRAGMENT_SPREAD?e.push(o):o.selectionSet&&n.push(o.selectionSet);this._fragmentSpreads.set(t,e);}return e}getFragment(t){let e;if(this._fragments)e=this._fragments;else {e=Object.create(null);for(let n of this.document.definitions)n.kind===Kind.FRAGMENT_DEFINITION&&(e[n.name.value]=n);this._fragments=e;}return e[t]}},m=class s{constructor(t){this.fragments=t;}static from(t){let e=new Map;for(let n of t)for(let r of n.definitions)invariant(r.kind==="FragmentDefinition",`expected a fragment definition, got ${n.definitions[0]?.kind}`),invariant(!e.has(r.name.value),`Duplicate fragment detected. A fragment named "${r.name.value}" has already been provided, either directly or as part of another fragment document.`),e.set(r.name.value,r);return new s(e)}replaceFrom(t){let e=visit(t,{FragmentDefinition:n=>this.fragments.has(n.name.value)?null:n,Document:{leave:n=>({...n,definitions:[...n.definitions,...this.fragments.values()]})}});return new R(e).dedupe()}};function O(s){return {environment:s.environment??N,headers:s.headers,cache:s.cache??false,debug:s.debug??false,fragments:m.from(s.fragments??[])}}var f=class s{level;name;constructor(t,e=3){this.name=t,this.level=e,this.replaceMethods();}static named(t,e=3){return new s(t,e)}trace=()=>{};debug=()=>{};info=()=>{};warn=()=>{};error=()=>{};log=()=>{};replaceMethods(){["trace","debug","info","warn","error"].forEach((t,e)=>{e>=this.level?this[t]=()=>{}:this[t]=(...n)=>console[t==="debug"?"log":t](`[${this.name}]`,...n);}),this.log=this.debug;}};function q(s){return s.operation!==null}function M(s){return new Promise(t=>setTimeout(t,s))}function k({data:s,error:t}){return invariant(s,`Expected a value, got: ${t?.message}`),s.value}var C=class s{constructor(t){this.context=t;this.logger=f.named(this.constructor.name,t.debug?1:5),this.urql=createClient({url:t.environment.backend,fetchOptions:{credentials:"omit",headers:t.headers},exchanges:this.exchanges()});}urql;logger;static create(t){return new s(O(t??{}))}query(t,e){let n=this.context.fragments.replaceFrom(t);return this.resultFrom(this.urql.query(n,e)).map(k)}mutation(t,e){return this.resultFrom(this.urql.mutation(t,e)).map(k)}batch(t){let e=new p,n=Object.create(this,{query:{value:e.addQuery}}),r=ResultAsync.combine(t(n)),[o,i]=e.build(),E=this.context.fragments.replaceFrom(o);return this.resultFrom(this.urql.query(E,i)).andTee(({data:u,error:y})=>{invariant(u,`Expected a value, got: ${y?.message}`),e.resolve(u);}).andThen(()=>r)}waitForTransaction=t=>(invariant(q(t),"Received a transaction result for an untracked operation. Make sure you're following the instructions in the docs."),ResultAsync.fromPromise(this.pollTransactionStatus(t),e=>e instanceof f$1||e instanceof c?e:c.from(e)));async pollTransactionStatus(t){let e=Date.now();for(;Date.now()-e<this.context.environment.indexingTimeout;){if(await h(this,t).match(r=>r,r=>{throw r}))return t.txHash;await M(this.context.environment.pollingInterval);}throw f$1.from(`Timeout waiting for transaction ${t.txHash} to be processed.`)}exchanges(){return [fetchExchange]}resultFrom(t){return ResultAsync.fromPromise(t.toPromise(),e=>(this.logger.error(e),console.log(e),c.from(e))).andThen(e=>e.error?.networkError?errAsync(c.from(e.error.networkError)):okAsync(e))}};
2
+ export{N as a,Y as b,z as c,C as d};//# sourceMappingURL=chunk-DJVVTQZZ.js.map
3
+ //# sourceMappingURL=chunk-DJVVTQZZ.js.map