@aave/client 0.8.0 → 4.0.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/README.md +35 -27
  2. package/dist/{AaveClient-C-OkXfVz.d.ts → AaveClient-CgHY2iS9.d.ts} +12 -15
  3. package/dist/{AaveClient-PHUEzt7l.d.cts → AaveClient-L3v8kWvn.d.cts} +12 -15
  4. package/dist/actions/index.cjs +1 -1
  5. package/dist/actions/index.cjs.map +1 -1
  6. package/dist/actions/index.d.cts +626 -710
  7. package/dist/actions/index.d.ts +626 -710
  8. package/dist/actions/index.js +1 -1
  9. package/dist/chunk-2TNQ52OQ.js +3 -0
  10. package/dist/chunk-2TNQ52OQ.js.map +1 -0
  11. package/dist/chunk-BQFM5RT3.js +2 -0
  12. package/dist/chunk-BQFM5RT3.js.map +1 -0
  13. package/dist/chunk-BQNVAUS6.js +3 -0
  14. package/dist/chunk-BQNVAUS6.js.map +1 -0
  15. package/dist/ethers.cjs +1 -1
  16. package/dist/ethers.cjs.map +1 -1
  17. package/dist/ethers.d.cts +28 -12
  18. package/dist/ethers.d.ts +28 -12
  19. package/dist/ethers.js +1 -1
  20. package/dist/ethers.js.map +1 -1
  21. package/dist/index.cjs +2 -2
  22. package/dist/index.cjs.map +1 -1
  23. package/dist/index.d.cts +3 -2
  24. package/dist/index.d.ts +3 -2
  25. package/dist/index.js +1 -1
  26. package/dist/options-vB2peXdE.d.cts +35 -0
  27. package/dist/options-vB2peXdE.d.ts +35 -0
  28. package/dist/privy.cjs +2 -2
  29. package/dist/privy.cjs.map +1 -1
  30. package/dist/privy.d.cts +21 -9
  31. package/dist/privy.d.ts +21 -9
  32. package/dist/privy.js +1 -1
  33. package/dist/privy.js.map +1 -1
  34. package/dist/test-utils.cjs +2 -449
  35. package/dist/test-utils.cjs.map +1 -1
  36. package/dist/test-utils.d.cts +28 -20
  37. package/dist/test-utils.d.ts +28 -20
  38. package/dist/test-utils.js +2 -437
  39. package/dist/test-utils.js.map +1 -1
  40. package/dist/thirdweb.cjs +2 -2
  41. package/dist/thirdweb.cjs.map +1 -1
  42. package/dist/thirdweb.d.cts +21 -9
  43. package/dist/thirdweb.d.ts +21 -9
  44. package/dist/thirdweb.js +2 -2
  45. package/dist/thirdweb.js.map +1 -1
  46. package/dist/types-Bu63z0x6.d.cts +21 -0
  47. package/dist/types-Bu63z0x6.d.ts +21 -0
  48. package/dist/utils/index.cjs +2 -0
  49. package/dist/utils/index.cjs.map +1 -0
  50. package/dist/utils/index.d.cts +18 -0
  51. package/dist/utils/index.d.ts +18 -0
  52. package/dist/utils/index.js +2 -0
  53. package/dist/utils/index.js.map +1 -0
  54. package/dist/viem.cjs +2 -2
  55. package/dist/viem.cjs.map +1 -1
  56. package/dist/viem.d.cts +32 -12
  57. package/dist/viem.d.ts +32 -12
  58. package/dist/viem.js +1 -1
  59. package/package.json +32 -8
  60. package/dist/chunk-BLZHGYNH.js +0 -2
  61. package/dist/chunk-BLZHGYNH.js.map +0 -1
  62. package/dist/chunk-FW4363Y4.js +0 -2
  63. package/dist/chunk-FW4363Y4.js.map +0 -1
  64. package/dist/chunk-QQSK6HIZ.js +0 -3
  65. package/dist/chunk-QQSK6HIZ.js.map +0 -1
  66. package/dist/chunk-V4DWF6LT.js +0 -3
  67. package/dist/chunk-V4DWF6LT.js.map +0 -1
  68. package/dist/magic-string.es-PTUXR566.js +0 -14
  69. package/dist/magic-string.es-PTUXR566.js.map +0 -1
  70. package/dist/types-ieyj0UmJ.d.cts +0 -16
  71. package/dist/types-ieyj0UmJ.d.ts +0 -16
package/README.md CHANGED
@@ -1,41 +1,49 @@
1
1
  # `@aave/client`
2
2
 
3
- The official TypeScript library for interacting with Aave Protocol.
3
+ The official TypeScript client for interacting with Aave Protocol v4.
4
4
 
5
5
  ---
6
6
 
7
+ `@aave/client` exposes the core Aave v4 actions through a type-safe interface with integrated error handling and result types.
7
8
 
8
- The `@aave/client` package contains the core functionality to query markets, execute transactions, and manage user positions across Aave lending markets and vaults. It provides a type-safe interface with built-in error handling and result types.
9
9
 
10
+ ## Install SDK
10
11
 
11
- ## Usage
12
+ First, install the AaveKit TypeScript package using your package manager of choice.
13
+
14
+ ```bash
15
+ pnpm add @aave/client@v4
16
+
17
+ // OR
18
+
19
+ yarn add @aave/client@v4
20
+
21
+ // OR
22
+
23
+ npm install @aave/client@v4
24
+ ```
25
+
26
+ ## Setup Client
12
27
 
13
28
  ```ts
14
- import { AaveClient, evmAddress, chainId } from '@aave/client';
15
- import { supply, userSupplies } from '@aave/client/actions';
16
- import { sendWith } from '@aave/client/viem';
29
+ // client.ts
30
+ import { AaveClient } from "@aave/client";
31
+
32
+ export const client = AaveClient.create();
33
+ ```
17
34
 
18
- // Create client
19
- const client = AaveClient.create();
35
+ ## Usage
36
+
37
+ ```ts
38
+ import { chains, userSupplies } from '@aave/client/actions';
39
+ import { client } from './client';
20
40
 
21
41
  // Query user positions
22
- const positions = await userSupplies(client, {
23
- markets: [evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2')],
24
- user: evmAddress('0x742d35cc6e5c4ce3b69a2a8c7c8e5f7e9a0b1234'),
25
- });
26
-
27
- // Execute transactions
28
- const result = await supply(client, {
29
- market: evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2'),
30
- amount: {
31
- erc20: {
32
- currency: evmAddress('0xa0b86a33e6441c8c5f0bb9b7e5e1f8bbf5b78b5c'),
33
- value: '1000'
34
- }
35
- },
36
- supplier: evmAddress('0x742d35cc6e5c4ce3b69a2a8c7c8e5f7e9a0b1234'),
37
- chainId: chainId(1),
38
- })
39
- .andThen(sendWith(wallet))
40
- .andThen(client.waitForTransaction);
42
+ const chains = await chains(client);
43
+
44
+ if (result.isOk()) {
45
+ console.log("Chains:", result.value); // Chain[]
46
+ } else {
47
+ console.error("Error:", result.error);
48
+ }
41
49
  ```
@@ -1,8 +1,8 @@
1
- import { Context, GqlClient, TimeoutError, UnexpectedError } from '@aave/core';
1
+ import { GqlClient, TimeoutError, UnexpectedError, StandardData } from '@aave/core';
2
2
  import { HasProcessedKnownTransactionRequest } from '@aave/graphql';
3
- import { ResultAsync, TxHash } from '@aave/types';
3
+ import { ResultAsync, TxHash, AnyVariables } from '@aave/types';
4
4
  import { TypedDocumentNode } from '@urql/core';
5
- import { T as TransactionExecutionResult } from './types-ieyj0UmJ.js';
5
+ import { T as TransactionResult } from './types-Bu63z0x6.js';
6
6
 
7
7
  /**
8
8
  * The environment configuration type.
@@ -12,6 +12,7 @@ type EnvironmentConfig = {
12
12
  backend: string;
13
13
  indexingTimeout: number;
14
14
  pollingInterval: number;
15
+ exchangeRateInterval?: number;
15
16
  };
16
17
 
17
18
  /**
@@ -30,7 +31,7 @@ type ClientConfig = {
30
31
  /**
31
32
  * Whether to enable caching.
32
33
  *
33
- * @defaultValue `false`
34
+ * @defaultValue `true`
34
35
  */
35
36
  cache?: boolean;
36
37
  /**
@@ -46,10 +47,6 @@ type ClientConfig = {
46
47
  */
47
48
  fragments?: TypedDocumentNode[];
48
49
  };
49
- /**
50
- * @internal
51
- */
52
- declare function configureContext(from: ClientConfig): Context;
53
50
 
54
51
  declare class AaveClient extends GqlClient {
55
52
  /**
@@ -65,21 +62,21 @@ declare class AaveClient extends GqlClient {
65
62
  * @returns The new instance of the client.
66
63
  */
67
64
  static create(options?: ClientConfig): AaveClient;
68
- /**
69
- * @internal
70
- */
71
- readonly waitForSupportedTransaction: (result: TransactionExecutionResult) => ResultAsync<TxHash, TimeoutError | UnexpectedError>;
72
65
  /**
73
66
  * Given the transaction hash of an Aave protocol transaction, wait for the transaction to be
74
- * processed by the Aave v3 API.
67
+ * processed by the Aave v4 API.
75
68
  *
76
69
  * Returns a {@link TimeoutError} if the transaction is not processed within the expected timeout period.
77
70
  *
78
71
  * @param result - The transaction execution result to wait for.
79
72
  * @returns The transaction hash or a TimeoutError
80
73
  */
81
- readonly waitForTransaction: (result: TransactionExecutionResult) => ResultAsync<TxHash, TimeoutError | UnexpectedError>;
74
+ readonly waitForTransaction: (result: TransactionResult) => ResultAsync<TxHash, TimeoutError | UnexpectedError>;
75
+ /**
76
+ * @internal
77
+ */
78
+ refreshQueryWhere<TValue, TVariables extends AnyVariables>(document: TypedDocumentNode<StandardData<TValue>, TVariables>, predicate: (variables: TVariables, data: TValue) => boolean | Promise<boolean>): Promise<void>;
82
79
  protected pollTransactionStatus(request: HasProcessedKnownTransactionRequest): Promise<TxHash>;
83
80
  }
84
81
 
85
- export { AaveClient as A, type ClientConfig as C, configureContext as c };
82
+ export { AaveClient as A, type ClientConfig as C };
@@ -1,8 +1,8 @@
1
- import { Context, GqlClient, TimeoutError, UnexpectedError } from '@aave/core';
1
+ import { GqlClient, TimeoutError, UnexpectedError, StandardData } from '@aave/core';
2
2
  import { HasProcessedKnownTransactionRequest } from '@aave/graphql';
3
- import { ResultAsync, TxHash } from '@aave/types';
3
+ import { ResultAsync, TxHash, AnyVariables } from '@aave/types';
4
4
  import { TypedDocumentNode } from '@urql/core';
5
- import { T as TransactionExecutionResult } from './types-ieyj0UmJ.cjs';
5
+ import { T as TransactionResult } from './types-Bu63z0x6.cjs';
6
6
 
7
7
  /**
8
8
  * The environment configuration type.
@@ -12,6 +12,7 @@ type EnvironmentConfig = {
12
12
  backend: string;
13
13
  indexingTimeout: number;
14
14
  pollingInterval: number;
15
+ exchangeRateInterval?: number;
15
16
  };
16
17
 
17
18
  /**
@@ -30,7 +31,7 @@ type ClientConfig = {
30
31
  /**
31
32
  * Whether to enable caching.
32
33
  *
33
- * @defaultValue `false`
34
+ * @defaultValue `true`
34
35
  */
35
36
  cache?: boolean;
36
37
  /**
@@ -46,10 +47,6 @@ type ClientConfig = {
46
47
  */
47
48
  fragments?: TypedDocumentNode[];
48
49
  };
49
- /**
50
- * @internal
51
- */
52
- declare function configureContext(from: ClientConfig): Context;
53
50
 
54
51
  declare class AaveClient extends GqlClient {
55
52
  /**
@@ -65,21 +62,21 @@ declare class AaveClient extends GqlClient {
65
62
  * @returns The new instance of the client.
66
63
  */
67
64
  static create(options?: ClientConfig): AaveClient;
68
- /**
69
- * @internal
70
- */
71
- readonly waitForSupportedTransaction: (result: TransactionExecutionResult) => ResultAsync<TxHash, TimeoutError | UnexpectedError>;
72
65
  /**
73
66
  * Given the transaction hash of an Aave protocol transaction, wait for the transaction to be
74
- * processed by the Aave v3 API.
67
+ * processed by the Aave v4 API.
75
68
  *
76
69
  * Returns a {@link TimeoutError} if the transaction is not processed within the expected timeout period.
77
70
  *
78
71
  * @param result - The transaction execution result to wait for.
79
72
  * @returns The transaction hash or a TimeoutError
80
73
  */
81
- readonly waitForTransaction: (result: TransactionExecutionResult) => ResultAsync<TxHash, TimeoutError | UnexpectedError>;
74
+ readonly waitForTransaction: (result: TransactionResult) => ResultAsync<TxHash, TimeoutError | UnexpectedError>;
75
+ /**
76
+ * @internal
77
+ */
78
+ refreshQueryWhere<TValue, TVariables extends AnyVariables>(document: TypedDocumentNode<StandardData<TValue>, TVariables>, predicate: (variables: TVariables, data: TValue) => boolean | Promise<boolean>): Promise<void>;
82
79
  protected pollTransactionStatus(request: HasProcessedKnownTransactionRequest): Promise<TxHash>;
83
80
  }
84
81
 
85
- export { AaveClient as A, type ClientConfig as C, configureContext as c };
82
+ export { AaveClient as A, type ClientConfig as C };
@@ -1,2 +1,2 @@
1
- 'use strict';var graphql=require('@aave/graphql');function ue(e,t){return e.query(graphql.SavingsGhoBalanceQuery,{request:t})}function se(e,t){return e.query(graphql.SavingsGhoWithdrawQuery,{request:t})}function oe(e,t){return e.query(graphql.SavingsGhoDepositQuery,{request:t})}function pe(e,t){return e.query(graphql.UserMeritRewardsQuery,{request:t})}var r={tokenName:graphql.OrderDirection.Asc};function ce(e,{chainIds:t,borrowsOrderBy:n=r,suppliesOrderBy:u=r,user:s}){return e.query(graphql.MarketsQuery,{request:{chainIds:t,user:s},borrowsOrderBy:n,suppliesOrderBy:u})}function Re(e,{address:t,chainId:n,user:u,borrowsOrderBy:s=r,suppliesOrderBy:o=r}){return e.query(graphql.MarketQuery,{request:{address:t,chainId:n,user:u},borrowsOrderBy:s,suppliesOrderBy:o})}function ve(e,t){return e.query(graphql.UserMarketStateQuery,{request:t})}function de(e){return e.query(graphql.HealthQuery,{})}function xe(e,t=graphql.ChainsFilter.ALL){return e.query(graphql.ChainsQuery,{filter:t})}function me(e,t){return e.query(graphql.UsdExchangeRatesQuery,{request:t})}function fe(e,t){return e.query(graphql.HasProcessedKnownTransactionQuery,{request:t})}function Ce(e,t){return e.query(graphql.HealthFactorPreviewQuery,{request:t})}function we(e,t){return e.query(graphql.PermitTypedDataQuery,{request:t})}function Pe(e,t){return e.query(graphql.ReserveQuery,{request:t})}function ge(e,t){return e.query(graphql.BorrowAPYHistoryQuery,{request:t})}function Te(e,t){return e.query(graphql.SupplyAPYHistoryQuery,{request:t})}function ke(e,t){return e.query(graphql.BorrowQuery,{request:t})}function Me(e,t){return e.query(graphql.SupplyQuery,{request:t})}function Be(e,t){return e.query(graphql.RepayQuery,{request:t})}function De(e,t){return e.query(graphql.WithdrawQuery,{request:t})}function He(e,t){return e.query(graphql.UserSetEmodeQuery,{request:t})}function We(e,t){return e.query(graphql.VaultDepositQuery,{request:t})}function Fe(e,t){return e.query(graphql.VaultRedeemSharesQuery,{request:t})}function Oe(e,t){return e.query(graphql.VaultDeployQuery,{request:t})}function Ge(e,t){return e.query(graphql.VaultSetFeeQuery,{request:t})}function Ye(e,t){return e.query(graphql.VaultWithdrawFeesQuery,{request:t})}function be(e,t){return e.query(graphql.VaultWithdrawQuery,{request:t})}function Ie(e,t){return e.query(graphql.VaultMintSharesQuery,{request:t})}function Le(e,t){return e.query(graphql.CollateralToggleQuery,{request:t})}function Ke(e,t){return e.query(graphql.LiquidateQuery,{request:t})}function Ne(e,t){return e.query(graphql.ApproveBorrowCreditDelegationQuery,{request:t})}function je(e,t){return e.query(graphql.CreditDelegateeAllowanceQuery,{request:t})}function Xe(e,t){return e.query(graphql.UserSuppliesQuery,{request:t})}function Ze(e,t){return e.query(graphql.UserBorrowsQuery,{request:t})}function _e(e,t){return e.query(graphql.UserTransactionHistoryQuery,{request:t})}function tt(e,t){return e.query(graphql.VaultQuery,{request:t})}function rt(e,t){return e.query(graphql.VaultsQuery,{request:t})}function nt(e,t){return e.query(graphql.UserVaultsQuery,{request:t})}function ut(e,t){return e.query(graphql.VaultPreviewDepositQuery,{request:t})}function st(e,t){return e.query(graphql.VaultPreviewMintQuery,{request:t})}function ot(e,t){return e.query(graphql.VaultPreviewWithdrawQuery,{request:t})}function at(e,t){return e.query(graphql.VaultPreviewRedeemQuery,{request:t})}function it(e,t){return e.query(graphql.VaultUserTransactionHistoryQuery,{request:t})}function pt(e,t){return e.query(graphql.VaultUserActivityQuery,{request:t})}function yt(e,t){return e.query(graphql.vaultTransferOwnershipQuery,{request:t})}function lt(e,t){return e.query(graphql.vaultCreateRecipientsConfigurationQuery,{request:t})}function ct(e,t){return e.query(graphql.vaultRecipientConfigurationQuery,{request:t})}function Rt(e,t){return e.query(graphql.vaultSetRecipientsConfigurationQuery,{request:t})}exports.approveBorrowCreditDelegation=Ne;exports.borrow=ke;exports.borrowAPYHistory=ge;exports.chains=xe;exports.collateralToggle=Le;exports.creditDelegateeAllowance=je;exports.defaultMarketReservesRequestOrderBy=r;exports.hasProcessedKnownTransaction=fe;exports.health=de;exports.healthFactorPreview=Ce;exports.liquidate=Ke;exports.market=Re;exports.markets=ce;exports.permitTypedData=we;exports.repay=Be;exports.reserve=Pe;exports.savingsGhoBalance=ue;exports.savingsGhoDeposit=oe;exports.savingsGhoWithdraw=se;exports.supply=Me;exports.supplyAPYHistory=Te;exports.usdExchangeRates=me;exports.userBorrows=Ze;exports.userMarketState=ve;exports.userMeritRewards=pe;exports.userSetEmode=He;exports.userSupplies=Xe;exports.userTransactionHistory=_e;exports.userVaults=nt;exports.vault=tt;exports.vaultCreateRecipientsConfiguration=lt;exports.vaultDeploy=Oe;exports.vaultDeposit=We;exports.vaultMintShares=Ie;exports.vaultPreviewDeposit=ut;exports.vaultPreviewMint=st;exports.vaultPreviewRedeem=at;exports.vaultPreviewWithdraw=ot;exports.vaultRecipientConfiguration=ct;exports.vaultRedeemShares=Fe;exports.vaultSetFee=Ge;exports.vaultSetRecipientsConfiguration=Rt;exports.vaultTransferOwnership=yt;exports.vaultUserActivity=pt;exports.vaultUserTransactionHistory=it;exports.vaultWithdraw=be;exports.vaultWithdrawFees=Ye;exports.vaults=rt;exports.withdraw=De;//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var graphql=require('@aave/graphql'),core=require('@aave/core'),types=require('@aave/types');var s={currency:graphql.Currency.Usd,timeWindow:graphql.TimeWindow.LastDay,requestPolicy:"cache-and-network"};function Re(e,r,t=s){return e.query(graphql.HubQuery,{request:r,currency:t.currency??s.currency},t.requestPolicy??s.requestPolicy)}function me(e,r,t=s){return e.query(graphql.HubsQuery,{request:r,...t})}function qe(e,r,t=s){return e.query(graphql.HubAssetsQuery,{request:r,...t})}function Ue(e,r){return e.query(graphql.ChainQuery,{request:r})}function xe(e,r=graphql.ChainsFilter.ALL){return e.query(graphql.ChainsQuery,{filter:r})}function de(e,r){return e.query(graphql.HasProcessedKnownTransactionQuery,{request:r},"network-only")}function Pe(e,r){return e.query(graphql.ExchangeRateQuery,{request:r})}function fe(e,r){return e.query(graphql.PermitTypedDataQuery,{request:r})}function Oe(e,r,t=s){return e.query(graphql.AssetQuery,{request:r,currency:t.currency??s.currency,timeWindow:t.timeWindow??s.timeWindow},t.requestPolicy??s.requestPolicy)}function Te(e,r,t=s){return e.query(graphql.AssetPriceHistoryQuery,{request:r},t.requestPolicy??s.requestPolicy)}function ke(e,r,t=s){return e.query(graphql.AssetSupplyHistoryQuery,{request:r},t.requestPolicy??s.requestPolicy)}function He(e,r,t=s){return e.query(graphql.AssetBorrowHistoryQuery,{request:r},t.requestPolicy??s.requestPolicy)}function Be(e,r,t=s){return e.query(graphql.ReserveQuery,{request:r,...t})}function Me(e,r,t=s){return e.query(graphql.ReservesQuery,{request:r,...t})}function We(e,r){return e.query(graphql.BorrowApyHistoryQuery,{request:r})}function De(e,r){return e.query(graphql.SupplyApyHistoryQuery,{request:r})}function Ie(e,r){return e.query(graphql.SpokeQuery,{request:r})}function Ye(e,r){return e.query(graphql.SpokesQuery,{request:r})}function Le(e,r){return e.query(graphql.SpokePositionManagersQuery,{request:r})}function Ne(e,r){return e.query(graphql.SpokeUserPositionManagersQuery,{request:r})}function Je(e,r,t=s){return e.query(graphql.SwapQuoteQuery,{request:r,...t})}function Ve(e,r){return e.query(graphql.SwappableTokensQuery,{request:r})}function Xe(e,r,t=s){return e.query(graphql.PrepareSwapQuery,{request:r,...t})}function L(e,r,t=s){return e.query(graphql.SwapStatusQuery,{request:r,...t})}function Ze(e){return r=>{let t=async n=>{let y=Date.now();for(;Date.now()-y<e.context.environment.indexingTimeout;){let u=await L(e,n).match(o=>o,o=>{throw o});switch(u.__typename){case "SwapCancelled":case "SwapExpired":case "SwapFulfilled":return u;default:await core.delay(e.context.environment.pollingInterval);continue}}throw core.TimeoutError.from(`Timeout waiting for swap ${n.id} to reach final outcome.`)};return types.ResultAsync.fromPromise(t({id:r.id}),n=>n instanceof core.TimeoutError||n instanceof core.UnexpectedError?n:core.UnexpectedError.from(n))}}function er(e,r){return e.query(graphql.SwapQuery,{request:r})}function rr(e,r){return e.query(graphql.PrepareSwapCancelQuery,{request:r})}function tr(e,r){return e.query(graphql.CancelSwapQuery,{request:r})}function sr(e,r,t=s){return e.query(graphql.UserSwapsQuery,{request:r,...t})}function ir(e,r){return e.query(graphql.BorrowQuery,{request:r})}function pr(e,r){return e.query(graphql.SupplyQuery,{request:r})}function yr(e,r){return e.query(graphql.RepayQuery,{request:r})}function ar(e,r){return e.query(graphql.WithdrawQuery,{request:r})}function cr(e,r){return e.query(graphql.RenounceSpokeUserPositionManagerQuery,{request:r})}function lr(e,r){return e.query(graphql.UpdateUserDynamicConfigQuery,{request:r})}function Rr(e,r){return e.query(graphql.UpdateUserRiskPremiumQuery,{request:r})}function mr(e,r){return e.query(graphql.LiquidatePositionQuery,{request:r})}function qr(e,r){return e.query(graphql.SetSpokeUserPositionManagerQuery,{request:r})}function Ar(e,r,t=s){return e.query(graphql.PreviewQuery,{request:r,...t})}function Sr(e,r){return e.query(graphql.SetUserSupplyAsCollateralQuery,{request:r})}function Ur(e,r,t=s){return e.query(graphql.ActivitiesQuery,{request:r,currency:t.currency??s.currency},t.requestPolicy??s.requestPolicy)}function wr(e,r,t=s){return e.query(graphql.UserSuppliesQuery,{request:r,...t})}function Cr(e,r,t=s){return e.query(graphql.UserBorrowsQuery,{request:r,...t})}function fr(e,r,{currency:t=s.currency,timeWindow:n=s.timeWindow}=s){return e.query(graphql.UserSummaryQuery,{request:r,currency:t,timeWindow:n})}function vr(e,r,{currency:t=s.currency,timeWindow:n=s.timeWindow}=s){return e.query(graphql.UserPositionsQuery,{request:r,currency:t,timeWindow:n})}function Qr(e,r,{currency:t=s.currency,timeWindow:n=s.timeWindow}=s){return e.query(graphql.UserPositionQuery,{request:r,currency:t,timeWindow:n})}function Er(e,r,t=s){return e.query(graphql.UserBalancesQuery,{request:r,...t})}function Or(e,r,t=s){return e.query(graphql.UserSummaryHistoryQuery,{request:r,...t})}exports.activities=Ur;exports.asset=Oe;exports.assetBorrowHistory=He;exports.assetPriceHistory=Te;exports.assetSupplyHistory=ke;exports.borrow=ir;exports.borrowApyHistory=We;exports.cancelSwap=tr;exports.chain=Ue;exports.chains=xe;exports.exchangeRate=Pe;exports.hasProcessedKnownTransaction=de;exports.hub=Re;exports.hubAssets=qe;exports.hubs=me;exports.liquidatePosition=mr;exports.permitTypedData=fe;exports.prepareSwap=Xe;exports.prepareSwapCancel=rr;exports.preview=Ar;exports.renounceSpokeUserPositionManager=cr;exports.repay=yr;exports.reserve=Be;exports.reserves=Me;exports.setSpokeUserPositionManager=qr;exports.setUserSupplyAsCollateral=Sr;exports.spoke=Ie;exports.spokePositionManagers=Le;exports.spokeUserPositionManagers=Ne;exports.spokes=Ye;exports.supply=pr;exports.supplyApyHistory=De;exports.swap=er;exports.swapQuote=Je;exports.swapStatus=L;exports.swappableTokens=Ve;exports.updateUserDynamicConfig=lr;exports.updateUserRiskPremium=Rr;exports.userBalances=Er;exports.userBorrows=Cr;exports.userPosition=Qr;exports.userPositions=vr;exports.userSummary=fr;exports.userSummaryHistory=Or;exports.userSupplies=wr;exports.userSwaps=sr;exports.waitForSwapOutcome=Ze;exports.withdraw=ar;//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/actions/gho.ts","../../src/actions/incentives.ts","../../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":["savingsGhoBalance","client","request","SavingsGhoBalanceQuery","savingsGhoWithdraw","SavingsGhoWithdrawQuery","savingsGhoDeposit","SavingsGhoDepositQuery","userMeritRewards","UserMeritRewardsQuery","defaultMarketReservesRequestOrderBy","OrderDirection","markets","chainIds","borrowsOrderBy","suppliesOrderBy","user","MarketsQuery","market","address","chainId","MarketQuery","userMarketState","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","vaultUserActivity","VaultUserActivityQuery","vaultTransferOwnership","vaultTransferOwnershipQuery","vaultCreateRecipientsConfiguration","vaultCreateRecipientsConfigurationQuery","vaultRecipientConfiguration","vaultRecipientConfigurationQuery","vaultSetRecipientsConfiguration","vaultSetRecipientsConfigurationQuery"],"mappings":"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","file":"index.cjs","sourcesContent":["import type { UnexpectedError } from '@aave/core';\nimport {\n type ExecutionPlan,\n SavingsGhoBalanceQuery,\n type SavingsGhoBalanceRequest,\n SavingsGhoDepositQuery,\n type SavingsGhoDepositRequest,\n SavingsGhoWithdrawQuery,\n type SavingsGhoWithdrawRequest,\n type TokenAmount,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\n\n/**\n * Fetches the current sGHO balance for a user.\n *\n * ```ts\n * const result = await savingsGhoBalance(client, {\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The sGHO balance request parameters.\n * @returns The user's sGHO balance.\n */\nexport function savingsGhoBalance(\n client: AaveClient,\n request: SavingsGhoBalanceRequest,\n): ResultAsync<TokenAmount, UnexpectedError> {\n return client.query(SavingsGhoBalanceQuery, { request });\n}\n\n/**\n * Creates a transaction to withdraw sGHO.\n *\n * ```ts\n * const result = await savingsGhoWithdraw(client, {\n * amount: {\n * exact: '1000',\n * },\n * sharesOwner: evmAddress('0x9abc…'),\n * }).andThen(sendWith(wallet))\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 sGHO withdraw request parameters.\n * @returns The transaction request data to withdraw sGHO.\n */\nexport function savingsGhoWithdraw(\n client: AaveClient,\n request: SavingsGhoWithdrawRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(SavingsGhoWithdrawQuery, { request });\n}\n\n/**\n * Creates a transaction to deposit GHO into sGHO.\n *\n * ```ts\n * const result = await savingsGhoDeposit(client, {\n * amount: {\n * value: '1000',\n * },\n * depositor: evmAddress('0x9abc…'),\n * }).andThen(sendWith(wallet))\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 sGHO deposit request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function savingsGhoDeposit(\n client: AaveClient,\n request: SavingsGhoDepositRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(SavingsGhoDepositQuery, { request });\n}\n","import {\n UserMeritRewardsQuery,\n type UserMeritRewardsRequest,\n} from '@aave/graphql';\nimport type { AaveClient } from '../AaveClient';\n\n/**\n * Fetches Merit rewards for a user with the transaction request to claim them.\n *\n * ```ts\n * const result = await userMeritRewards(client, {\n * user: evmAddress('0x742d35cc…'),\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The merit claim rewards request parameters.\n * @returns The rewards with the transaction request.\n */\nexport function userMeritRewards(\n client: AaveClient,\n request: UserMeritRewardsRequest,\n) {\n return client.query(UserMeritRewardsQuery, { request });\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\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 '../AaveClient';\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 type { UnexpectedError } from '@aave/core';\nimport {\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 '../AaveClient';\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 type { UnexpectedError } from '@aave/core';\nimport {\n PermitTypedDataQuery,\n type PermitTypedDataRequest,\n type PermitTypedDataResponse,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\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 type { UnexpectedError } from '@aave/core';\nimport {\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 '../AaveClient';\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 type { UnexpectedError } from '@aave/core';\nimport {\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 '../AaveClient';\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 * 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 * amount: {\n * value: '500',\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 type { UnexpectedError } from '@aave/core';\nimport {\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 '../AaveClient';\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 type { UnexpectedError } from '@aave/core';\nimport {\n type PaginatedVaultsResult,\n type PaginatedVaultUserTransactionHistoryResult,\n type TokenAmount,\n type TransactionRequest,\n UserVaultsQuery,\n type UserVaultsRequest,\n type Vault,\n type VaultCreateRecipientsConfigurationRequest,\n type VaultFeesRecipientsConfiguration,\n VaultPreviewDepositQuery,\n type VaultPreviewDepositRequest,\n VaultPreviewMintQuery,\n type VaultPreviewMintRequest,\n VaultPreviewRedeemQuery,\n type VaultPreviewRedeemRequest,\n VaultPreviewWithdrawQuery,\n type VaultPreviewWithdrawRequest,\n VaultQuery,\n type VaultRecipientConfigurationRequest,\n type VaultRequest,\n type VaultSetRecipientsConfigurationRequest,\n VaultsQuery,\n type VaultsRequest,\n type VaultTransferOwnershipRequest,\n VaultUserActivityQuery,\n type VaultUserActivityRequest,\n type VaultUserActivityResult,\n VaultUserTransactionHistoryQuery,\n type VaultUserTransactionHistoryRequest,\n vaultCreateRecipientsConfigurationQuery,\n vaultRecipientConfigurationQuery,\n vaultSetRecipientsConfigurationQuery,\n vaultTransferOwnershipQuery,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\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('0x1234…'),\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('0x1234…'),\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('0x1234…'),\n * chainId: chainId(1),\n * user: evmAddress('0x5678…'),\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\n/**\n * Fetches the user activity data for a vault, including earnings breakdown over time.\n *\n * ```ts\n * const result = await vaultUserActivity(client, {\n * vault: evmAddress('0x1234…'),\n * chainId: chainId(1),\n * user: evmAddress('0x5678…'),\n * });\n *\n * if (result.isOk()) {\n * console.log('Total earned:', result.value.earned.amount.value);\n * console.log('Activity breakdown count:', result.value.breakdown.length);\n * result.value.breakdown.forEach(activity => {\n * console.log('Date:', activity.date);\n * console.log('Balance:', activity.balance.amount.value);\n * console.log('Earned:', activity.earned.amount.value);\n * });\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault user activity request parameters.\n * @returns The vault user activity result.\n */\nexport function vaultUserActivity(\n client: AaveClient,\n request: VaultUserActivityRequest,\n): ResultAsync<VaultUserActivityResult, UnexpectedError> {\n return client.query(VaultUserActivityQuery, {\n request,\n });\n}\n\n/**\n * Creates a transaction to transfer ownership of a vault.\n *\n * ```ts\n * const result = await vaultTransferOwnership(client, {\n * vault: evmAddress('0x1234…'),\n * chainId: chainId(1),\n * newOwner: evmAddress('0x5678…'),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n * ```\n *\n * @param client - Aave client.\n * @param request - The vault transfer ownership request parameters.\n * @returns The transaction data for transferring vault ownership.\n */\nexport function vaultTransferOwnership(\n client: AaveClient,\n request: VaultTransferOwnershipRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(vaultTransferOwnershipQuery, {\n request,\n });\n}\n\n/**\n * @internal\n */\nexport function vaultCreateRecipientsConfiguration(\n client: AaveClient,\n request: VaultCreateRecipientsConfigurationRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(vaultCreateRecipientsConfigurationQuery, {\n request,\n });\n}\n\n/**\n * @internal\n */\nexport function vaultRecipientConfiguration(\n client: AaveClient,\n request: VaultRecipientConfigurationRequest,\n): ResultAsync<VaultFeesRecipientsConfiguration | null, UnexpectedError> {\n return client.query(vaultRecipientConfigurationQuery, {\n request,\n });\n}\n\n/**\n * @internal\n */\nexport function vaultSetRecipientsConfiguration(\n client: AaveClient,\n request: VaultSetRecipientsConfigurationRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(vaultSetRecipientsConfigurationQuery, {\n request,\n });\n}\n"]}
1
+ {"version":3,"sources":["../../src/options.ts","../../src/actions/hubs.ts","../../src/actions/misc.ts","../../src/actions/permits.ts","../../src/actions/protocol.ts","../../src/actions/reserves.ts","../../src/actions/spokes.ts","../../src/actions/swap.ts","../../src/actions/transactions.ts","../../src/actions/user.ts"],"names":["DEFAULT_QUERY_OPTIONS","Currency","TimeWindow","hub","client","request","options","HubQuery","hubs","HubsQuery","hubAssets","HubAssetsQuery","chain","ChainQuery","chains","filter","ChainsFilter","ChainsQuery","hasProcessedKnownTransaction","HasProcessedKnownTransactionQuery","exchangeRate","ExchangeRateQuery","permitTypedData","PermitTypedDataQuery","asset","AssetQuery","assetPriceHistory","AssetPriceHistoryQuery","assetSupplyHistory","AssetSupplyHistoryQuery","assetBorrowHistory","AssetBorrowHistoryQuery","reserve","ReserveQuery","reserves","ReservesQuery","borrowApyHistory","BorrowApyHistoryQuery","supplyApyHistory","SupplyApyHistoryQuery","spoke","SpokeQuery","spokes","SpokesQuery","spokePositionManagers","SpokePositionManagersQuery","spokeUserPositionManagers","SpokeUserPositionManagersQuery","swapQuote","SwapQuoteQuery","swappableTokens","SwappableTokensQuery","prepareSwap","PrepareSwapQuery","swapStatus","SwapStatusQuery","waitForSwapOutcome","receipt","pollForSwapOutcome","startedAt","status","ok","err","delay","TimeoutError","ResultAsync","error","UnexpectedError","swap","SwapQuery","prepareSwapCancel","PrepareSwapCancelQuery","cancelSwap","CancelSwapQuery","userSwaps","UserSwapsQuery","borrow","BorrowQuery","supply","SupplyQuery","repay","RepayQuery","withdraw","WithdrawQuery","renounceSpokeUserPositionManager","RenounceSpokeUserPositionManagerQuery","updateUserDynamicConfig","UpdateUserDynamicConfigQuery","updateUserRiskPremium","UpdateUserRiskPremiumQuery","liquidatePosition","LiquidatePositionQuery","setSpokeUserPositionManager","SetSpokeUserPositionManagerQuery","preview","PreviewQuery","setUserSupplyAsCollateral","SetUserSupplyAsCollateralQuery","activities","ActivitiesQuery","userSupplies","UserSuppliesQuery","userBorrows","UserBorrowsQuery","userSummary","currency","timeWindow","UserSummaryQuery","userPositions","UserPositionsQuery","userPosition","UserPositionQuery","userBalances","UserBalancesQuery","userSummaryHistory","UserSummaryHistoryQuery"],"mappings":"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","file":"index.cjs","sourcesContent":["import { Currency, TimeWindow } from '@aave/graphql';\nimport type { RequestPolicy } from '@urql/core';\n\nexport type CurrencyQueryOptions = {\n /**\n * The currency for fiat amounts.\n *\n * @defaultValue {@link Currency.Usd}\n */\n currency?: Currency;\n};\n\nexport type TimeWindowQueryOptions = {\n /**\n * The time window for historical data changes.\n *\n * @defaultValue {@link TimeWindow.LastDay}\n */\n timeWindow?: TimeWindow;\n};\n\nexport type RequestPolicyOptions = {\n /**\n * The request policy to use.\n *\n * @internal This is used for testing purposes and could be changed without notice.\n * @defaultValue `cache-and-network`\n */\n requestPolicy?: RequestPolicy;\n};\n\nexport const DEFAULT_QUERY_OPTIONS = {\n currency: Currency.Usd,\n timeWindow: TimeWindow.LastDay,\n requestPolicy: 'cache-and-network',\n} as const;\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type Hub,\n type HubAsset,\n HubAssetsQuery,\n type HubAssetsRequest,\n HubQuery,\n type HubRequest,\n HubsQuery,\n type HubsRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport {\n type CurrencyQueryOptions,\n DEFAULT_QUERY_OPTIONS,\n type RequestPolicyOptions,\n} from '../options';\n\n/**\n * Fetches a specific hub by ID or by address and chain ID.\n *\n * ```ts\n * const result = await hub(client, {\n * query: { hubId: hubId('SGVsbG8h') }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The hub request parameters.\n * @param options - The query options.\n * @returns The hub data, or null if not found.\n */\nexport function hub(\n client: AaveClient,\n request: HubRequest,\n options: CurrencyQueryOptions & RequestPolicyOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<Hub | null, UnexpectedError> {\n return client.query(\n HubQuery,\n { request, currency: options.currency ?? DEFAULT_QUERY_OPTIONS.currency },\n options.requestPolicy ?? DEFAULT_QUERY_OPTIONS.requestPolicy,\n );\n}\n\n/**\n * Fetches multiple hubs based on specified criteria.\n *\n * ```ts\n * const result = await hubs(client, {\n * query: {\n * chainIds: [chainId(1)]\n * }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The hubs request parameters (either tokens or chainIds).\n * @param options - The query options.\n * @returns Array of hub data.\n */\nexport function hubs(\n client: AaveClient,\n request: HubsRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<Hub[], UnexpectedError> {\n return client.query(HubsQuery, { request, ...options });\n}\n\n/**\n * Fetches hub assets for a specific hub by ID or by address and chain ID.\n *\n * ```ts\n * const result = await hubAssets(client, {\n * query: { hubId: hubId('SGVsbG8h') },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The hub assets request parameters.\n * @param options - The query options.\n * @returns The hub assets array.\n */\nexport function hubAssets(\n client: AaveClient,\n request: HubAssetsRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<HubAsset[], UnexpectedError> {\n return client.query(HubAssetsQuery, { request, ...options });\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type Chain,\n ChainQuery,\n type ChainRequest,\n ChainsFilter,\n ChainsQuery,\n ExchangeRateQuery,\n type ExchangeRateRequest,\n type FiatAmount,\n HasProcessedKnownTransactionQuery,\n type HasProcessedKnownTransactionRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\n\n/**\n * Fetches a specific chain by chain ID.\n *\n * ```ts\n * const result = await chain(client, {\n * chainId: chainId(1),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The chain request parameters.\n * @returns The chain data, or null if not found.\n */\nexport function chain(\n client: AaveClient,\n request: ChainRequest,\n): ResultAsync<Chain | null, UnexpectedError> {\n return client.query(ChainQuery, { request });\n}\n\n/**\n * Fetches the list of supported chains.\n *\n * ```ts\n * const chains = await chains(client, { filter: ChainsFilter.ALL });\n * ```\n *\n * @param client - Aave client.\n * @param filter - The filter for chains.\n * @returns Array 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 * Check if a transaction has been processed by the Aave API.\n *\n * @param client - Aave client.\n * @param request - The request containing transaction hash and operations to check.\n * @returns True if the transaction has been processed, false otherwise.\n */\nexport function hasProcessedKnownTransaction(\n client: AaveClient,\n request: HasProcessedKnownTransactionRequest,\n): ResultAsync<boolean, UnexpectedError> {\n return client.query(\n HasProcessedKnownTransactionQuery,\n { request },\n 'network-only',\n );\n}\n\n/**\n * Fetches the exchange rate between tokens and fiat currencies.\n *\n * ```ts\n * const result = await exchangeRate(client, {\n * from: { erc20: { chainId: chainId(1), address: evmAddress('0xA0b86a33E6...') } },\n * to: Currency.Usd,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The exchange rate request parameters.\n * @returns The exchange rate information as a fiat amount.\n */\nexport function exchangeRate(\n client: AaveClient,\n request: ExchangeRateRequest,\n): ResultAsync<FiatAmount, UnexpectedError> {\n return client.query(ExchangeRateQuery, { request });\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type PermitRequest,\n PermitTypedDataQuery,\n type PermitTypedDataResponse,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\n\nimport type { AaveClient } from '../AaveClient';\n\n/**\n * Generates EIP-712 typed data for permit signatures.\n *\n * ```ts\n * const result = await permitTypedData(client, {\n * spender: evmAddress('0x87870bca…'),\n * currency: evmAddress('0xa0b86991c431c924b2047c7094daf21b77e…'),\n * amount: '1000.5',\n * });\n *\n * if (result.isOk()) {\n * // Use the typed data to create a signature\n * const signature = await wallet.signTypedData(result.value);\n * }\n * ```\n *\n * @param client - Aave client.\n * @param request - The permit request parameters.\n * @returns The EIP-712 typed data for permit signature.\n */\nexport function permitTypedData(\n client: AaveClient,\n request: PermitRequest,\n): ResultAsync<PermitTypedDataResponse, UnexpectedError> {\n return client.query(PermitTypedDataQuery, { request });\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type Asset,\n AssetBorrowHistoryQuery,\n type AssetBorrowHistoryRequest,\n type AssetBorrowSample,\n AssetPriceHistoryQuery,\n type AssetPriceHistoryRequest,\n type AssetPriceSample,\n AssetQuery,\n type AssetRequest,\n AssetSupplyHistoryQuery,\n type AssetSupplyHistoryRequest,\n type AssetSupplySample,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport {\n type CurrencyQueryOptions,\n DEFAULT_QUERY_OPTIONS,\n type RequestPolicyOptions,\n type TimeWindowQueryOptions,\n} from '../options';\n\n/**\n * Fetches information about a specific asset (ERC20 token) in the protocol by ID or by token.\n *\n * ```ts\n * const result = await asset(client, {\n * query: { assetId: assetId('SGVsbG8h') }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The asset request parameters.\n * @param options - The query options including currency and time window.\n * @returns The asset data, or null if not found.\n */\nexport function asset(\n client: AaveClient,\n request: AssetRequest,\n options: CurrencyQueryOptions &\n TimeWindowQueryOptions &\n RequestPolicyOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<Asset | null, UnexpectedError> {\n return client.query(\n AssetQuery,\n {\n request,\n currency: options.currency ?? DEFAULT_QUERY_OPTIONS.currency,\n timeWindow: options.timeWindow ?? DEFAULT_QUERY_OPTIONS.timeWindow,\n },\n options.requestPolicy ?? DEFAULT_QUERY_OPTIONS.requestPolicy,\n );\n}\n\n/**\n * Fetches historical price data for a specific asset.\n *\n * ```ts\n * const result = await assetPriceHistory(client, {\n * token: { chainId: chainId(1), address: evmAddress('0x123…') },\n * currency: Currency.Usd,\n * window: TimeWindow.LastWeek,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The asset price history request parameters.\n * @param options - The query options.\n * @returns Array of asset price samples over time.\n */\nexport function assetPriceHistory(\n client: AaveClient,\n request: AssetPriceHistoryRequest,\n options: Required<RequestPolicyOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<AssetPriceSample[], UnexpectedError> {\n return client.query(\n AssetPriceHistoryQuery,\n { request },\n options.requestPolicy ?? DEFAULT_QUERY_OPTIONS.requestPolicy,\n );\n}\n\n/**\n * Fetches historical supply data for a specific asset.\n *\n * ```ts\n * const result = await assetSupplyHistory(client, {\n * token: { chainId: chainId(1), address: evmAddress('0x123…') },\n * window: TimeWindow.LastWeek,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The asset supply history request parameters.\n * @param options - The query options.\n * @returns Array of asset supply samples over time.\n */\nexport function assetSupplyHistory(\n client: AaveClient,\n request: AssetSupplyHistoryRequest,\n options: Required<RequestPolicyOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<AssetSupplySample[], UnexpectedError> {\n return client.query(\n AssetSupplyHistoryQuery,\n { request },\n options.requestPolicy ?? DEFAULT_QUERY_OPTIONS.requestPolicy,\n );\n}\n\n/**\n * Fetches historical borrow data for a specific asset.\n *\n * ```ts\n * const result = await assetBorrowHistory(client, {\n * token: { chainId: chainId(1), address: evmAddress('0x123…') },\n * window: TimeWindow.LastWeek,\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The asset borrow history request parameters.\n * @param options - The query options.\n * @returns Array of asset borrow samples over time.\n */\nexport function assetBorrowHistory(\n client: AaveClient,\n request: AssetBorrowHistoryRequest,\n options: Required<RequestPolicyOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<AssetBorrowSample[], UnexpectedError> {\n return client.query(\n AssetBorrowHistoryQuery,\n { request },\n options.requestPolicy ?? DEFAULT_QUERY_OPTIONS.requestPolicy,\n );\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type APYSample,\n type BorrowAPYHistoryRequest,\n BorrowApyHistoryQuery,\n type Reserve,\n ReserveQuery,\n type ReserveRequest,\n ReservesQuery,\n type ReservesRequest,\n type SupplyAPYHistoryRequest,\n SupplyApyHistoryQuery,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport { type CurrencyQueryOptions, DEFAULT_QUERY_OPTIONS } from '../options';\n\n/**\n * Fetches a specific reserve by reserve ID, spoke, and chain.\n *\n * ```ts\n * const result = await reserve(client, {\n * reserve: reserveId('SGVsbG8h'),\n * user: evmAddress('0x742d35cc…'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The reserve request parameters.\n * @param options - The query options.\n * @returns The reserve data, or null if not found.\n */\nexport function reserve(\n client: AaveClient,\n request: ReserveRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<Reserve | null, UnexpectedError> {\n return client.query(ReserveQuery, { request, ...options });\n}\n\n/**\n * Fetches reserves based on specified criteria.\n *\n * ```ts\n * const result = await reserves(client, {\n * query: {\n * spoke: {\n * address: evmAddress('0x123...'),\n * chainId: chainId(1)\n * }\n * },\n * filter: ReservesRequestFilter.All,\n * orderBy: { name: 'ASC' }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The reserves request parameters.\n * @param options - The query options.\n * @returns Array of reserves matching the criteria.\n */\nexport function reserves(\n client: AaveClient,\n request: ReservesRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<Reserve[], UnexpectedError> {\n return client.query(ReservesQuery, { request, ...options });\n}\n\n/**\n * Fetches borrow APY history for a specific reserve over time.\n *\n * ```ts\n * const result = await borrowApyHistory(client, {\n * reserve: reserveId('SGVsbG8h'),\n * window: TimeWindow.LastWeek\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The borrow APY history request parameters.\n * @returns The borrow APY history samples.\n */\nexport function borrowApyHistory(\n client: AaveClient,\n request: BorrowAPYHistoryRequest,\n): ResultAsync<APYSample[], UnexpectedError> {\n return client.query(BorrowApyHistoryQuery, { request });\n}\n\n/**\n * Fetches supply APY history for a specific reserve over time.\n *\n * ```ts\n * const result = await supplyApyHistory(client, {\n * reserve: reserveId('SGVsbG8h'),\n * window: TimeWindow.LastWeek\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The supply APY history request parameters.\n * @returns The supply APY history samples.\n */\nexport function supplyApyHistory(\n client: AaveClient,\n request: SupplyAPYHistoryRequest,\n): ResultAsync<APYSample[], UnexpectedError> {\n return client.query(SupplyApyHistoryQuery, { request });\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type PaginatedSpokePositionManagerResult,\n type PaginatedSpokeUserPositionManagerResult,\n type Spoke,\n SpokePositionManagersQuery,\n type SpokePositionManagersRequest,\n SpokeQuery,\n type SpokeRequest,\n SpokesQuery,\n type SpokesRequest,\n SpokeUserPositionManagersQuery,\n type SpokeUserPositionManagersRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\n\n/**\n * Fetches a specific spoke.\n *\n * ```ts\n * const result = await spoke(client, {\n * query: { spokeId: spokeId('SGVsbG8h') }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The spoke request parameters.\n * @returns The spoke data, or null if not found.\n */\nexport function spoke(\n client: AaveClient,\n request: SpokeRequest,\n): ResultAsync<Spoke | null, UnexpectedError> {\n return client.query(SpokeQuery, { request });\n}\n\n/**\n * Fetches spokes based on specified criteria.\n *\n * ```ts\n * const result = await spokes(client, {\n * query: { chainIds: [chainId(1)] }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The spokes request parameters.\n * @returns Array of spokes matching the criteria.\n */\nexport function spokes(\n client: AaveClient,\n request: SpokesRequest,\n): ResultAsync<Spoke[], UnexpectedError> {\n return client.query(SpokesQuery, { request });\n}\n\n/**\n * Fetches all positions manager for a specific spoke.\n *\n * ```ts\n * const result = await spokePositionManagers(client, {\n * spoke: spokeId('SGVsbG8h'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The spokes request parameters.\n * @returns Array of spokes matching the criteria.\n */\nexport function spokePositionManagers(\n client: AaveClient,\n request: SpokePositionManagersRequest,\n): ResultAsync<PaginatedSpokePositionManagerResult, UnexpectedError> {\n return client.query(SpokePositionManagersQuery, { request });\n}\n\n/**\n * Fetches all the positions managers of a user for a specific spoke.\n *\n * ```ts\n * const result = await spokeUserPositionManagers(client, {\n * spoke: spokeId('SGVsbG8h'),\n * user: evmAddress('0x123...'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The spokes and pagination request parameters.\n * @returns Array of position managers of a user for a specific spoke.\n */\nexport function spokeUserPositionManagers(\n client: AaveClient,\n request: SpokeUserPositionManagersRequest,\n): ResultAsync<PaginatedSpokeUserPositionManagerResult, UnexpectedError> {\n return client.query(SpokeUserPositionManagersQuery, { request });\n}\n","import { delay, TimeoutError, UnexpectedError } from '@aave/core';\nimport type {\n CancelSwapExecutionPlan,\n CancelSwapRequest,\n PaginatedUserSwapsResult,\n PrepareSwapCancelRequest,\n PrepareSwapCancelResult,\n PrepareSwapRequest,\n PrepareSwapResult,\n SwapCancelled,\n SwapExecutionPlan,\n SwapExpired,\n SwapFulfilled,\n SwappableTokensRequest,\n SwapQuote,\n SwapQuoteRequest,\n SwapReceipt,\n SwapRequest,\n SwapStatus,\n SwapStatusRequest,\n Token,\n UserSwapsRequest,\n} from '@aave/graphql';\nimport {\n CancelSwapQuery,\n PrepareSwapCancelQuery,\n PrepareSwapQuery,\n SwappableTokensQuery,\n SwapQuery,\n SwapQuoteQuery,\n SwapStatusQuery,\n UserSwapsQuery,\n} from '@aave/graphql';\nimport { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport { type CurrencyQueryOptions, DEFAULT_QUERY_OPTIONS } from '../options';\n\n/**\n * @internal\n * Fetches a swap quote for the specified trade parameters.\n *\n * ```ts\n * const result = await swapQuote(client, {\n * chainId: chainId(1),\n * buy: { erc20: evmAddress('0xA0b86a33E6...') },\n * sell: { erc20: evmAddress('0x6B175474E...') },\n * amount: bigDecimal('1000'),\n * kind: SwapKind.SELL,\n * from: evmAddress('0x742d35cc...'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The swap quote request parameters.\n * @param options - The query options.\n * @returns The swap quote including pricing and cost information.\n */\nexport function swapQuote(\n client: AaveClient,\n request: SwapQuoteRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<SwapQuote, UnexpectedError> {\n return client.query(SwapQuoteQuery, { request, ...options });\n}\n\n/**\n * @internal\n * Fetches the list of tokens available for swapping on a specific chain.\n *\n * ```ts\n * const result = await swappableTokens(client, {\n * query: { chainIds: [chainId(1)] },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The swappable tokens request parameters.\n * @returns The list of tokens available for swapping.\n */\nexport function swappableTokens(\n client: AaveClient,\n request: SwappableTokensRequest,\n): ResultAsync<Token[], UnexpectedError> {\n return client.query(SwappableTokensQuery, { request });\n}\n\n/**\n * @internal\n * Prepares a swap for the specified trade parameters.\n *\n * ```ts\n * const result = await prepareSwap(client, {\n * market: {\n * chainId: chainId(1),\n * buy: { erc20: evmAddress('0xA0b86a33E6...') },\n * sell: { erc20: evmAddress('0x6B175474E...') },\n * amount: bigDecimal('1000'),\n * kind: SwapKind.SELL,\n * user: evmAddress('0x742d35cc...'),\n * },\n * }).andThen(plan => {\n * switch (plan.__typename) {\n * case 'SwapByIntent':\n * return signSwapByIntentWith(plan.data)\n * .andThen((signature) => swap({ intent: { quoteId: quote.quoteId, signature } }))\n * .andThen((plan) => {\n * // …\n * });\n * );\n *\n * case 'SwapByIntentWithApprovalRequired':\n * return sendTransaction(plan.transaction)\n * .andThen(signSwapByIntentWith(plan.data))\n * .andThen((signature) => swap({ intent: { quoteId: quote.quoteId, signature } }))\n * .andThen((plan) => {\n * // …\n * });\n * );\n *\n * case 'SwapByTransaction':\n * return swap({ transaction: { quoteId: quote.quoteId } })\n * .andThen((plan) => {\n * // …\n * });\n * );\n *\n * case 'InsufficientBalanceError':\n * return errAsync(new Error(`Insufficient balance: ${plan.required.value} required.`));\n * }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The prepare swap request parameters.\n * @param options - The query options.\n * @returns The prepared swap result containing details of the swap.\n */\nexport function prepareSwap(\n client: AaveClient,\n request: PrepareSwapRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<PrepareSwapResult, UnexpectedError> {\n return client.query(PrepareSwapQuery, { request, ...options });\n}\n\n/**\n * @internal\n * Fetches the status of a specific swap.\n *\n * ```ts\n * const result = await swapStatus(client, {\n * id: swapId('swap_123'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The swap status request parameters.\n * @param options - The query options.\n * @returns The current status of the swap.\n */\nexport function swapStatus(\n client: AaveClient,\n request: SwapStatusRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<SwapStatus, UnexpectedError> {\n return client.query(SwapStatusQuery, { request, ...options });\n}\n\nexport type SwapOutcome = SwapCancelled | SwapExpired | SwapFulfilled;\n\n/**\n * @internal\n * Waits for a swap to reach a final outcome (cancelled, expired, or fulfilled).\n *\n * ```ts\n * const result = waitForSwapOutcome(client)(swapReceipt);\n *\n * if (result.isOk()) {\n * const outcome = result.value;\n * switch (outcome.__typename) {\n * case 'SwapFulfilled':\n * console.log('Swap completed successfully:', outcome.txHash);\n * break;\n * case 'SwapCancelled':\n * console.log('Swap was cancelled:', outcome.cancelledAt);\n * break;\n * case 'SwapExpired':\n * console.log('Swap expired:', outcome.expiredAt);\n * break;\n * }\n * }\n * ```\n *\n * @param client - Aave client configured with polling settings.\n * @returns A function that takes a SwapReceipt and returns a ResultAsync with the final outcome.\n */\nexport function waitForSwapOutcome(\n client: AaveClient,\n): (\n receipt: SwapReceipt,\n) => ResultAsync<SwapOutcome, TimeoutError | UnexpectedError> {\n return (receipt: SwapReceipt) => {\n const pollForSwapOutcome = async (\n request: SwapStatusRequest,\n ): Promise<SwapOutcome> => {\n const startedAt = Date.now();\n\n while (\n Date.now() - startedAt <\n client.context.environment.indexingTimeout\n ) {\n const status = await swapStatus(client, request).match(\n (ok) => ok,\n (err) => {\n throw err;\n },\n );\n\n switch (status.__typename) {\n case 'SwapCancelled':\n case 'SwapExpired':\n case 'SwapFulfilled':\n return status;\n\n default:\n await delay(client.context.environment.pollingInterval);\n continue;\n }\n }\n\n throw TimeoutError.from(\n `Timeout waiting for swap ${request.id} to reach final outcome.`,\n );\n };\n\n return ResultAsync.fromPromise(\n pollForSwapOutcome({ id: receipt.id }),\n (error) => {\n if (error instanceof TimeoutError || error instanceof UnexpectedError) {\n return error;\n }\n return UnexpectedError.from(error);\n },\n );\n };\n}\n\n/**\n * @internal\n * Executes a swap for the specified request parameters.\n *\n * ```ts\n * const result = await swap(client, {\n * intent: {\n * quoteId: swapQuoteId('123...'),\n * signature: {\n * value: signature('0x456...'),\n * deadline: 1234567890,\n * },\n * },\n * }).andThen((plan) => {\n * switch (plan.__typename) {\n * case 'SwapTransactionRequest':\n * return sendTransaction(plan.transaction)\n * .map(() => plan.orderReceipt);\n *\n * case 'SwapApprovalRequired':\n * return sendTransaction(plan.transaction)\n * .andThen(() => sendTransaction(plan.originalTransaction))\n * .map(() => plan.originalTransaction.orderReceipt);\n *\n * case 'SwapReceipt':\n * return okAsync(plan.orderReceipt);\n *\n * case 'InsufficientBalanceError':\n * return errAsync(new Error(`Insufficient balance: ${plan.required.value} required.`));\n * }\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Order receipt:', result.value);\n * ```\n *\n * @param client - Aave client.\n * @param request - The swap request parameters.\n * @returns The swap execution plan containing transaction details or receipt.\n */\nexport function swap(\n client: AaveClient,\n request: SwapRequest,\n): ResultAsync<SwapExecutionPlan, UnexpectedError> {\n return client.query(SwapQuery, { request });\n}\n\n/**\n * @internal\n * Prepares a swap cancellation for the specified swap ID.\n *\n * ```ts\n * const result = await prepareSwapCancel(client, {\n * id: swapId('123...'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The prepare swap cancel request parameters.\n * @returns The prepared swap cancel result containing typed data for signing.\n */\nexport function prepareSwapCancel(\n client: AaveClient,\n request: PrepareSwapCancelRequest,\n): ResultAsync<PrepareSwapCancelResult, UnexpectedError> {\n return client.query(PrepareSwapCancelQuery, { request });\n}\n\n/**\n * @internal\n * Executes a swap cancellation for the specified request parameters.\n *\n * ```ts\n * const result = await cancelSwap(client, {\n * intent: {\n * id: swapId('123...'),\n * signature: {\n * value: signature('0x456...'),\n * deadline: 1234567890,\n * },\n * },\n * }).andThen((plan) => {\n * switch (plan.__typename) {\n * case 'TransactionRequest':\n * return sendTransaction(plan)\n * .map(() => ({ success: true }));\n *\n * case 'SwapCancelled':\n * return okAsync(plan);\n * }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The cancel swap request parameters.\n * @returns The cancel swap execution plan containing transaction details or cancellation receipt.\n */\nexport function cancelSwap(\n client: AaveClient,\n request: CancelSwapRequest,\n): ResultAsync<CancelSwapExecutionPlan, UnexpectedError> {\n return client.query(CancelSwapQuery, { request });\n}\n\n/**\n * @internal\n * Fetches the user's swap history for a specific chain.\n *\n * ```ts\n * const result = await userSwaps(client, {\n * chainId: chainId(1),\n * user: evmAddress('0x742d35cc...'),\n * filterBy: [SwapStatusFilter.FULFILLED, SwapStatusFilter.OPEN],\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user swaps request parameters.\n * @param options - The query options.\n * @returns The paginated list of user swaps with their status information.\n */\nexport function userSwaps(\n client: AaveClient,\n request: UserSwapsRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<PaginatedUserSwapsResult, UnexpectedError> {\n return client.query(UserSwapsQuery, { request, ...options });\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\n ActivitiesQuery,\n type ActivitiesRequest,\n BorrowQuery,\n type BorrowRequest,\n type ExecutionPlan,\n LiquidatePositionQuery,\n type LiquidatePositionRequest,\n type PaginatedActivitiesResult,\n PreviewQuery,\n type PreviewRequest,\n type PreviewUserPosition,\n RenounceSpokeUserPositionManagerQuery,\n type RenounceSpokeUserPositionManagerRequest,\n RepayQuery,\n type RepayRequest,\n SetSpokeUserPositionManagerQuery,\n type SetSpokeUserPositionManagerRequest,\n SetUserSupplyAsCollateralQuery,\n type SetUserSupplyAsCollateralRequest,\n SupplyQuery,\n type SupplyRequest,\n type TransactionRequest,\n UpdateUserDynamicConfigQuery,\n type UpdateUserDynamicConfigRequest,\n UpdateUserRiskPremiumQuery,\n type UpdateUserRiskPremiumRequest,\n WithdrawQuery,\n type WithdrawRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport {\n type CurrencyQueryOptions,\n DEFAULT_QUERY_OPTIONS,\n type RequestPolicyOptions,\n} from '../options';\n\n/**\n * Creates a transaction to borrow from a market.\n *\n * ```ts\n * const result = await borrow(client, {\n * amount: {\n * erc20: {\n * value: bigDecimal('1000'),\n * },\n * },\n * reserve: reserveId('SGVsbG8h'),\n * sender: evmAddress('0x9abc…'),\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 * reserve: {\n * reserveId: \"1234567890\",\n * spoke: evmAddress('0x8787…'),\n * chainId: chainId(1),\n * },\n * amount: {\n * erc20: {\n * value: bigDecimal('1000'),\n * },\n * },\n * enableCollateral: true, // Optional, defaults to true\n * sender: evmAddress('0x9abc…'),\n * });\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 * amount: {\n * erc20: {\n * value: {\n * exact: bigDecimal('500'),\n * },\n * },\n * },\n * sender: evmAddress('0x9abc…'),\n * reserve: reserveId('SGVsbG8h'),\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 reserve.\n *\n * ```ts\n * const result = await withdraw(client, {\n * reserve: reserveId('SGVsbG8h'),\n * amount: {\n * erc20: {\n * exact: bigDecimal('750.5'),\n * },\n * },\n * sender: evmAddress('0x9abc…'),\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 * **Withdraw specific amount:**\n * ```ts\n * amount: {\n * erc20: {\n * exact: bigDecimal('100.5'), // Exact amount to withdraw\n * }\n * }\n * ```\n *\n * **Withdraw all available:**\n * ```ts\n * amount: {\n * erc20: {\n * max: true, // Withdraw the full position\n * }\n * }\n * ```\n *\n * **Withdraw native token:**\n * ```ts\n * amount: {\n * native: bigDecimal('0.5'), // For ETH on Ethereum\n * }\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 renounce a position manager of a user in a specific spoke.\n *\n * ```ts\n * const result = await renounceSpokeUserPositionManager(client, {\n * manager: evmAddress('0x9abc…'),\n * managing: evmAddress('0xdef0…'),\n * spoke: spokeId('SGVsbG8h'),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n *\n * @param client - Aave client.\n * @param request - The renounce spoke user position manager request parameters.\n * @returns The transaction data.\n */\nexport function renounceSpokeUserPositionManager(\n client: AaveClient,\n request: RenounceSpokeUserPositionManagerRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(RenounceSpokeUserPositionManagerQuery, { request });\n}\n\n/**\n * Creates a transaction to update user dynamic config for a specific spoke.\n *\n * ```ts\n * const result = await updateUserDynamicConfig(client, {\n * sender: evmAddress('0x9abc…'),\n * spoke: spokeId('SGVsbG8h'),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n *\n * @param client - Aave client.\n * @param request - The update user dynamic config request parameters.\n * @returns The transaction data.\n */\n\nexport function updateUserDynamicConfig(\n client: AaveClient,\n request: UpdateUserDynamicConfigRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(UpdateUserDynamicConfigQuery, { request });\n}\n\n/**\n * Creates a transaction to update user risk premium for a specific spoke.\n *\n * ```ts\n * const result = await updateUserRiskPremium(client, {\n * sender: evmAddress('0x9abc…'),\n * spoke: spokeId('SGVsbG8h'),\n * }).andThen(sendWith(wallet)).andThen(client.waitForTransaction);\n *\n * if (result.isErr()) {\n * // Handle error\n * return;\n * }\n *\n * // result.value: TxHash\n * ```\n *\n *\n * @param client - Aave client.\n * @param request - The update user risk premium request parameters.\n * @returns The transaction data.\n */\nexport function updateUserRiskPremium(\n client: AaveClient,\n request: UpdateUserRiskPremiumRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(UpdateUserRiskPremiumQuery, { request });\n}\n\n/**\n * Creates a transaction to liquidate a user's position.\n *\n * ```ts\n * const result = await liquidatePosition(client, {\n * collateral: reserveId('SGVsbG8h'),\n * debt: reserveId('Q2lhbyE= '),\n * amount: {\n * exact: bigDecimal('1000'),\n * },\n * liquidator: evmAddress('0x9abc…'),\n * user: evmAddress('0xdef0…'),\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 position request parameters.\n * @returns The transaction data, approval requirements, or insufficient balance error.\n */\nexport function liquidatePosition(\n client: AaveClient,\n request: LiquidatePositionRequest,\n): ResultAsync<ExecutionPlan, UnexpectedError> {\n return client.query(LiquidatePositionQuery, { request });\n}\n\n/**\n * Sets or removes a position manager for a user on a specific spoke.\n *\n * **Position managers** can perform transactions on behalf of other users, including:\n * - Supply assets\n * - Borrow assets\n * - Withdraw assets\n * - Enable/disable collateral\n *\n * The `signature` parameter is an **ERC712 signature** that must be signed by the **user**\n * (the account granting permissions) to authorize the position manager. The signature contains:\n * - `value`: The actual cryptographic signature\n * - `deadline`: Unix timestamp when the authorization expires\n *\n * ```ts\n * const result = await setSpokeUserPositionManager(client, {\n * spoke: spokeId('SGVsbG8h'),\n * manager: evmAddress('0x9abc…'), // Address that will become the position manager\n * approve: true, // true to approve, false to remove the manager\n * user: evmAddress('0xdef0…'), // User granting the permission (must sign the signature)\n * signature: {\n * value: '0x1234...', // ERC712 signature signed by the user\n * deadline: 1735689600, // Unix timestamp when signature expires\n * },\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 spoke set for the position manager request parameters.\n * @returns The transaction request data to set position manager.\n */\nexport function setSpokeUserPositionManager(\n client: AaveClient,\n request: SetSpokeUserPositionManagerRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(SetSpokeUserPositionManagerQuery, { request });\n}\n\n/**\n * Previews the impact of a potential action on a user's position.\n *\n * ```ts\n * const result = await preview(client, {\n * action: {\n * supply: {\n * reserve: reserveId('SGVsbG8h'),\n * amount: {\n * erc20: {\n * value: '1000',\n * },\n * },\n * sender: evmAddress('0x9abc…'),\n * },\n * },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The preview request parameters containing the action to preview.\n * @param options - The query options.\n * @returns The preview result showing position changes.\n */\nexport function preview(\n client: AaveClient,\n request: PreviewRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<PreviewUserPosition, UnexpectedError> {\n return client.query(PreviewQuery, { request, ...options });\n}\n\n/**\n * Sets whether a user's supply should be used as collateral.\n *\n * ```ts\n * const result = await setUserSupplyAsCollateral(client, {\n * reserve: reserveId('SGVsbG8h'),\n * sender: evmAddress('0x456...'),\n * enableCollateral: true\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The set user supply as collateral request parameters.\n * @returns The transaction request to set collateral status.\n */\nexport function setUserSupplyAsCollateral(\n client: AaveClient,\n request: SetUserSupplyAsCollateralRequest,\n): ResultAsync<TransactionRequest, UnexpectedError> {\n return client.query(SetUserSupplyAsCollateralQuery, { request });\n}\n\n/**\n * Fetches paginated list of activities.\n *\n * ```ts\n * const result = await activities(client, {\n * query: {\n * chainIds: [chainId(1)],\n * },\n * user: evmAddress('0x742d35cc…'), // Optional\n * types: [ActivityType.Supply, ActivityType.Borrow, ActivityType.Withdraw, ActivityType.Repay],\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The activities request parameters.\n * @param options - The query options.\n * @returns The paginated list of activities.\n */\nexport function activities(\n client: AaveClient,\n request: ActivitiesRequest,\n options: CurrencyQueryOptions & RequestPolicyOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<PaginatedActivitiesResult, UnexpectedError> {\n return client.query(\n ActivitiesQuery,\n { request, currency: options.currency ?? DEFAULT_QUERY_OPTIONS.currency },\n options.requestPolicy ?? DEFAULT_QUERY_OPTIONS.requestPolicy,\n );\n}\n","import type { UnexpectedError } from '@aave/core';\nimport {\n type UserBalance,\n UserBalancesQuery,\n type UserBalancesRequest,\n type UserBorrowItem,\n UserBorrowsQuery,\n type UserBorrowsRequest,\n type UserPosition,\n UserPositionQuery,\n type UserPositionRequest,\n UserPositionsQuery,\n type UserPositionsRequest,\n type UserSummary,\n type UserSummaryHistoryItem,\n UserSummaryHistoryQuery,\n type UserSummaryHistoryRequest,\n UserSummaryQuery,\n type UserSummaryRequest,\n UserSuppliesQuery,\n type UserSuppliesRequest,\n type UserSupplyItem,\n} from '@aave/graphql';\nimport type { Prettify, ResultAsync } from '@aave/types';\nimport type { AaveClient } from '../AaveClient';\nimport {\n type CurrencyQueryOptions,\n DEFAULT_QUERY_OPTIONS,\n type TimeWindowQueryOptions,\n} from '../options';\n\n/**\n * Fetches all user supply positions across the specified spoke.\n *\n * ```ts\n * const result = await userSupplies(client, {\n * query: {\n * userSpoke: {\n * spoke: { address: evmAddress('0x87870bca…'), chainId: chainId(1) },\n * user: evmAddress('0x742d35cc…'),\n * },\n * },\n * orderBy: { name: 'ASC' },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user supplies request parameters.\n * @param options - The query options.\n * @returns The user's supply positions.\n */\nexport function userSupplies(\n client: AaveClient,\n request: UserSuppliesRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<UserSupplyItem[], UnexpectedError> {\n return client.query(UserSuppliesQuery, { request, ...options });\n}\n\n/**\n * Fetches all user borrow positions across the specified spoke.\n *\n * ```ts\n * const result = await userBorrows(client, {\n * query: {\n * userSpoke: {\n * spoke: { address: evmAddress('0x87870bca…'), chainId: chainId(1) },\n * user: evmAddress('0x742d35cc…'),\n * },\n * },\n * orderBy: { name: 'ASC' },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user borrows request parameters.\n * @param options - The query options.\n * @returns The user's borrow positions.\n */\nexport function userBorrows(\n client: AaveClient,\n request: UserBorrowsRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<UserBorrowItem[], UnexpectedError> {\n return client.query(UserBorrowsQuery, { request, ...options });\n}\n\nexport type UserSummaryQueryOptions = Prettify<\n CurrencyQueryOptions & TimeWindowQueryOptions\n>;\n\n/**\n * Fetches a user's summary across all positions.\n *\n * ```ts\n * const result = await userSummary(client, {\n * user: evmAddress('0x742d35cc…'),\n * filter: {\n * spoke: { address: evmAddress('0x87870bca…'), chainId: chainId(1) },\n * },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user summary request parameters.\n * @param options - The query options.\n * @returns The user's financial summary.\n */\nexport function userSummary(\n client: AaveClient,\n request: UserSummaryRequest,\n {\n currency = DEFAULT_QUERY_OPTIONS.currency,\n timeWindow = DEFAULT_QUERY_OPTIONS.timeWindow,\n }: UserSummaryQueryOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<UserSummary, UnexpectedError> {\n return client.query(UserSummaryQuery, {\n request,\n currency,\n timeWindow,\n });\n}\n\nexport type UserPositionQueryOptions = CurrencyQueryOptions &\n TimeWindowQueryOptions;\n\n/**\n * Fetches all user positions across specified chains.\n *\n * ```ts\n * const result = await userPositions(client, {\n * user: evmAddress('0x742d35cc…'),\n * filter: {\n * chainIds: [chainId(1), chainId(137)],\n * },\n * orderBy: { balance: 'DESC' },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user positions request parameters.\n * @param options - The query options.\n * @returns The user's positions across all specified chains.\n */\nexport function userPositions(\n client: AaveClient,\n request: UserPositionsRequest,\n {\n currency = DEFAULT_QUERY_OPTIONS.currency,\n timeWindow = DEFAULT_QUERY_OPTIONS.timeWindow,\n }: UserPositionQueryOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<UserPosition[], UnexpectedError> {\n return client.query(UserPositionsQuery, { request, currency, timeWindow });\n}\n\n/**\n * Fetches a specific user position by ID.\n *\n * ```ts\n * const result = await userPosition(client, {\n * id: userPositionId('SGVsbG8h'),\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user position request parameters.\n * @param options - The query options.\n * @returns The specific user position or null if not found.\n */\nexport function userPosition(\n client: AaveClient,\n request: UserPositionRequest,\n {\n currency = DEFAULT_QUERY_OPTIONS.currency,\n timeWindow = DEFAULT_QUERY_OPTIONS.timeWindow,\n }: UserPositionQueryOptions = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<UserPosition | null, UnexpectedError> {\n return client.query(UserPositionQuery, { request, currency, timeWindow });\n}\n\n/**\n * Fetches all user balances across specified chains.\n *\n * ```ts\n * const result = await userBalances(client, {\n * user: evmAddress('0x742d35cc…'),\n * filter: {\n * chainIds: [chainId(1), chainId(137)],\n * },\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user balances request parameters.\n * @param options - The query options.\n * @returns The user's balances across all specified chains.\n **/\nexport function userBalances(\n client: AaveClient,\n request: UserBalancesRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<UserBalance[], UnexpectedError> {\n return client.query(UserBalancesQuery, { request, ...options });\n}\n\n/**\n * Fetches user summary history over time.\n *\n * ```ts\n * const result = await userSummaryHistory(client, {\n * user: evmAddress('0x742d35cc…'),\n * window: TimeWindow.LastWeek,\n * filter: {\n * chainIds: [chainId(1)]\n * }\n * });\n * ```\n *\n * @param client - Aave client.\n * @param request - The user summary history request parameters.\n * @param options - The query options.\n * @returns The user summary history items.\n */\nexport function userSummaryHistory(\n client: AaveClient,\n request: UserSummaryHistoryRequest,\n options: Required<CurrencyQueryOptions> = DEFAULT_QUERY_OPTIONS,\n): ResultAsync<UserSummaryHistoryItem[], UnexpectedError> {\n return client.query(UserSummaryHistoryQuery, { request, ...options });\n}\n"]}