@pufferfinance/puffer-sdk 1.8.1 → 1.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (197) hide show
  1. package/dist/api/puffer-client-helpers.cjs +1 -1
  2. package/dist/api/puffer-client-helpers.cjs.map +1 -1
  3. package/dist/api/puffer-client-helpers.js +82 -81
  4. package/dist/api/puffer-client-helpers.js.map +1 -1
  5. package/dist/api/puffer-client.cjs +1 -1
  6. package/dist/api/puffer-client.cjs.map +1 -1
  7. package/dist/api/puffer-client.d.ts +3 -0
  8. package/dist/api/puffer-client.js +56 -49
  9. package/dist/api/puffer-client.js.map +1 -1
  10. package/dist/ccip-BO_b9tFc.cjs +2 -0
  11. package/dist/ccip-BO_b9tFc.cjs.map +1 -0
  12. package/dist/ccip-DLDO0_x2.js +148 -0
  13. package/dist/ccip-DLDO0_x2.js.map +1 -0
  14. package/dist/chains/constants.cjs +1 -1
  15. package/dist/chains/constants.js +1 -1
  16. package/dist/constants-BjRNQpT2.js +1997 -0
  17. package/dist/constants-BjRNQpT2.js.map +1 -0
  18. package/dist/constants-DA2xUb9r.cjs +9 -0
  19. package/dist/constants-DA2xUb9r.cjs.map +1 -0
  20. package/dist/contracts/abis/holesky/PufferDepositor.cjs.map +1 -1
  21. package/dist/contracts/abis/holesky/PufferDepositor.js.map +1 -1
  22. package/dist/contracts/abis/holesky/PufferVaultV2.cjs.map +1 -1
  23. package/dist/contracts/abis/holesky/PufferVaultV2.js.map +1 -1
  24. package/dist/contracts/abis/l1-reward-manager-abis.cjs +1 -1
  25. package/dist/contracts/abis/l1-reward-manager-abis.cjs.map +1 -1
  26. package/dist/contracts/abis/l1-reward-manager-abis.js +1 -1
  27. package/dist/contracts/abis/l2-reward-manager-abis.cjs +1 -1
  28. package/dist/contracts/abis/l2-reward-manager-abis.cjs.map +1 -1
  29. package/dist/contracts/abis/l2-reward-manager-abis.js +1 -1
  30. package/dist/contracts/abis/mainnet/Accountant.cjs.map +1 -1
  31. package/dist/contracts/abis/mainnet/Accountant.js.map +1 -1
  32. package/dist/contracts/abis/mainnet/AtomicQueue.cjs +2 -0
  33. package/dist/contracts/abis/mainnet/AtomicQueue.cjs.map +1 -0
  34. package/dist/contracts/abis/mainnet/AtomicQueue.d.ts +328 -0
  35. package/dist/contracts/abis/mainnet/AtomicQueue.js +237 -0
  36. package/dist/contracts/abis/mainnet/AtomicQueue.js.map +1 -0
  37. package/dist/contracts/abis/mainnet/BoringVault.cjs.map +1 -1
  38. package/dist/contracts/abis/mainnet/BoringVault.js.map +1 -1
  39. package/dist/contracts/abis/mainnet/ERC20Permit.cjs.map +1 -1
  40. package/dist/contracts/abis/mainnet/ERC20Permit.js.map +1 -1
  41. package/dist/contracts/abis/mainnet/L1RewardManager.cjs.map +1 -1
  42. package/dist/contracts/abis/mainnet/L1RewardManager.js.map +1 -1
  43. package/dist/contracts/abis/mainnet/L2RewardManager.cjs.map +1 -1
  44. package/dist/contracts/abis/mainnet/L2RewardManager.js.map +1 -1
  45. package/dist/contracts/abis/mainnet/PufLocker.cjs.map +1 -1
  46. package/dist/contracts/abis/mainnet/PufLocker.js.map +1 -1
  47. package/dist/contracts/abis/mainnet/PufferDepositor.cjs.map +1 -1
  48. package/dist/contracts/abis/mainnet/PufferDepositor.js.map +1 -1
  49. package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs.map +1 -1
  50. package/dist/contracts/abis/mainnet/PufferL2Depositor.js.map +1 -1
  51. package/dist/contracts/abis/mainnet/PufferVaultV2.cjs.map +1 -1
  52. package/dist/contracts/abis/mainnet/PufferVaultV2.js.map +1 -1
  53. package/dist/contracts/abis/mainnet/PufferWithdrawalManager.cjs.map +1 -1
  54. package/dist/contracts/abis/mainnet/PufferWithdrawalManager.js.map +1 -1
  55. package/dist/contracts/abis/mainnet/Teller.cjs.map +1 -1
  56. package/dist/contracts/abis/mainnet/Teller.js.map +1 -1
  57. package/dist/contracts/abis/nucleus-accountant-abis.cjs +1 -1
  58. package/dist/contracts/abis/nucleus-accountant-abis.cjs.map +1 -1
  59. package/dist/contracts/abis/nucleus-accountant-abis.js +1 -1
  60. package/dist/contracts/abis/nucleus-atomic-queue-abis.cjs +2 -0
  61. package/dist/contracts/abis/nucleus-atomic-queue-abis.cjs.map +1 -0
  62. package/dist/contracts/abis/nucleus-atomic-queue-abis.d.ts +332 -0
  63. package/dist/contracts/abis/nucleus-atomic-queue-abis.js +9 -0
  64. package/dist/contracts/abis/nucleus-atomic-queue-abis.js.map +1 -0
  65. package/dist/contracts/abis/nucleus-boring-vault-abis.cjs +1 -1
  66. package/dist/contracts/abis/nucleus-boring-vault-abis.cjs.map +1 -1
  67. package/dist/contracts/abis/nucleus-boring-vault-abis.js +1 -1
  68. package/dist/contracts/abis/nucleus-teller-abis.cjs +1 -1
  69. package/dist/contracts/abis/nucleus-teller-abis.cjs.map +1 -1
  70. package/dist/contracts/abis/nucleus-teller-abis.js +1 -1
  71. package/dist/contracts/abis/puf-locker-abis.cjs +1 -1
  72. package/dist/contracts/abis/puf-locker-abis.cjs.map +1 -1
  73. package/dist/contracts/abis/puf-locker-abis.js +1 -1
  74. package/dist/contracts/abis/puffer-depositor-abis.cjs +1 -1
  75. package/dist/contracts/abis/puffer-depositor-abis.cjs.map +1 -1
  76. package/dist/contracts/abis/puffer-depositor-abis.js +1 -1
  77. package/dist/contracts/abis/puffer-depositor-abis.js.map +1 -1
  78. package/dist/contracts/abis/puffer-vault-abis.cjs +1 -1
  79. package/dist/contracts/abis/puffer-vault-abis.cjs.map +1 -1
  80. package/dist/contracts/abis/puffer-vault-abis.js +1 -1
  81. package/dist/contracts/abis/puffer-vault-abis.js.map +1 -1
  82. package/dist/contracts/abis/puffer-withdrawal-manager-abis.cjs +1 -1
  83. package/dist/contracts/abis/puffer-withdrawal-manager-abis.cjs.map +1 -1
  84. package/dist/contracts/abis/puffer-withdrawal-manager-abis.js +1 -1
  85. package/dist/contracts/addresses.cjs +1 -1
  86. package/dist/contracts/addresses.cjs.map +1 -1
  87. package/dist/contracts/addresses.d.ts +14 -0
  88. package/dist/contracts/addresses.js +3 -2
  89. package/dist/contracts/addresses.js.map +1 -1
  90. package/dist/contracts/handlers/erc20-permit-handler.cjs +1 -1
  91. package/dist/contracts/handlers/erc20-permit-handler.cjs.map +1 -1
  92. package/dist/contracts/handlers/erc20-permit-handler.d.ts +11128 -2714
  93. package/dist/contracts/handlers/erc20-permit-handler.js +3 -3
  94. package/dist/contracts/handlers/erc20-permit-handler.js.map +1 -1
  95. package/dist/contracts/handlers/l1-reward-manager-handler.cjs +1 -1
  96. package/dist/contracts/handlers/l1-reward-manager-handler.cjs.map +1 -1
  97. package/dist/contracts/handlers/l1-reward-manager-handler.d.ts +11128 -2714
  98. package/dist/contracts/handlers/l1-reward-manager-handler.js +2 -2
  99. package/dist/contracts/handlers/l1-reward-manager-handler.js.map +1 -1
  100. package/dist/contracts/handlers/l2-reward-manager-handler.cjs +1 -1
  101. package/dist/contracts/handlers/l2-reward-manager-handler.cjs.map +1 -1
  102. package/dist/contracts/handlers/l2-reward-manager-handler.d.ts +11128 -2714
  103. package/dist/contracts/handlers/l2-reward-manager-handler.js +2 -2
  104. package/dist/contracts/handlers/l2-reward-manager-handler.js.map +1 -1
  105. package/dist/contracts/handlers/nucleus-accountant-handler.cjs +1 -1
  106. package/dist/contracts/handlers/nucleus-accountant-handler.cjs.map +1 -1
  107. package/dist/contracts/handlers/nucleus-accountant-handler.d.ts +11128 -2714
  108. package/dist/contracts/handlers/nucleus-accountant-handler.js +1 -1
  109. package/dist/contracts/handlers/nucleus-accountant-handler.js.map +1 -1
  110. package/dist/contracts/handlers/nucleus-atomic-queue-handler.cjs +2 -0
  111. package/dist/contracts/handlers/nucleus-atomic-queue-handler.cjs.map +1 -0
  112. package/dist/contracts/handlers/nucleus-atomic-queue-handler.d.ts +14923 -0
  113. package/dist/contracts/handlers/nucleus-atomic-queue-handler.js +89 -0
  114. package/dist/contracts/handlers/nucleus-atomic-queue-handler.js.map +1 -0
  115. package/dist/contracts/handlers/nucleus-boring-vault-handler.cjs +1 -1
  116. package/dist/contracts/handlers/nucleus-boring-vault-handler.cjs.map +1 -1
  117. package/dist/contracts/handlers/nucleus-boring-vault-handler.d.ts +11128 -2714
  118. package/dist/contracts/handlers/nucleus-boring-vault-handler.js +2 -2
  119. package/dist/contracts/handlers/nucleus-boring-vault-handler.js.map +1 -1
  120. package/dist/contracts/handlers/nucleus-teller-handler.cjs +1 -1
  121. package/dist/contracts/handlers/nucleus-teller-handler.cjs.map +1 -1
  122. package/dist/contracts/handlers/nucleus-teller-handler.d.ts +11128 -2714
  123. package/dist/contracts/handlers/nucleus-teller-handler.js +2 -2
  124. package/dist/contracts/handlers/nucleus-teller-handler.js.map +1 -1
  125. package/dist/contracts/handlers/puf-locker-handler.cjs +1 -1
  126. package/dist/contracts/handlers/puf-locker-handler.cjs.map +1 -1
  127. package/dist/contracts/handlers/puf-locker-handler.d.ts +11128 -2714
  128. package/dist/contracts/handlers/puf-locker-handler.js +2 -2
  129. package/dist/contracts/handlers/puf-locker-handler.js.map +1 -1
  130. package/dist/contracts/handlers/puffer-depositor-handler.cjs +1 -1
  131. package/dist/contracts/handlers/puffer-depositor-handler.cjs.map +1 -1
  132. package/dist/contracts/handlers/puffer-depositor-handler.d.ts +11128 -2714
  133. package/dist/contracts/handlers/puffer-depositor-handler.js +2 -2
  134. package/dist/contracts/handlers/puffer-depositor-handler.js.map +1 -1
  135. package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs +1 -1
  136. package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs.map +1 -1
  137. package/dist/contracts/handlers/puffer-l2-depositor-handler.d.ts +11128 -2714
  138. package/dist/contracts/handlers/puffer-l2-depositor-handler.js +2 -2
  139. package/dist/contracts/handlers/puffer-l2-depositor-handler.js.map +1 -1
  140. package/dist/contracts/handlers/puffer-vault-handler.cjs +1 -1
  141. package/dist/contracts/handlers/puffer-vault-handler.cjs.map +1 -1
  142. package/dist/contracts/handlers/puffer-vault-handler.d.ts +11128 -2714
  143. package/dist/contracts/handlers/puffer-vault-handler.js +2 -2
  144. package/dist/contracts/handlers/puffer-vault-handler.js.map +1 -1
  145. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.cjs +1 -1
  146. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.cjs.map +1 -1
  147. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.d.ts +11128 -2714
  148. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js +2 -2
  149. package/dist/contracts/handlers/puffer-withdrawal-manager-handler.js.map +1 -1
  150. package/dist/contracts/tokens.cjs +1 -1
  151. package/dist/contracts/tokens.cjs.map +1 -1
  152. package/dist/contracts/tokens.js +1 -1
  153. package/dist/contracts/tokens.js.map +1 -1
  154. package/dist/createWalletClient-BuLYysrp.cjs +4 -0
  155. package/dist/createWalletClient-BuLYysrp.cjs.map +1 -0
  156. package/dist/createWalletClient-DNcW-ENe.js +2028 -0
  157. package/dist/createWalletClient-DNcW-ENe.js.map +1 -0
  158. package/dist/errors/base-error.cjs.map +1 -1
  159. package/dist/errors/base-error.js.map +1 -1
  160. package/dist/{getContract-MrPLx6gp.cjs → getContract-3QbyfZBF.cjs} +2 -2
  161. package/dist/getContract-3QbyfZBF.cjs.map +1 -0
  162. package/dist/{getContract-B3Spz0SO.js → getContract-CezEyDf-.js} +2 -2
  163. package/dist/{getContract-MrPLx6gp.cjs.map → getContract-CezEyDf-.js.map} +1 -1
  164. package/dist/main.cjs +1 -1
  165. package/dist/main.js +1 -1
  166. package/dist/secp256k1-3OC5y4qp.js +1579 -0
  167. package/dist/secp256k1-3OC5y4qp.js.map +1 -0
  168. package/dist/secp256k1-bcahnPX9.cjs +2 -0
  169. package/dist/secp256k1-bcahnPX9.cjs.map +1 -0
  170. package/dist/utils/version.cjs +1 -1
  171. package/dist/utils/version.js +1 -1
  172. package/dist/writeContract-ChuHpJLC.js +3799 -0
  173. package/dist/writeContract-ChuHpJLC.js.map +1 -0
  174. package/dist/writeContract-D97dSJQe.cjs +32 -0
  175. package/dist/writeContract-D97dSJQe.cjs.map +1 -0
  176. package/package.json +13 -13
  177. package/dist/ccip-D4klNwCt.js +0 -159
  178. package/dist/ccip-D4klNwCt.js.map +0 -1
  179. package/dist/ccip-DLDqFodf.cjs +0 -2
  180. package/dist/ccip-DLDqFodf.cjs.map +0 -1
  181. package/dist/constants-BvU-JhfL.cjs +0 -9
  182. package/dist/constants-BvU-JhfL.cjs.map +0 -1
  183. package/dist/constants-rWWWhxR_.js +0 -2099
  184. package/dist/constants-rWWWhxR_.js.map +0 -1
  185. package/dist/createWalletClient-Bmopj8MM.cjs +0 -4
  186. package/dist/createWalletClient-Bmopj8MM.cjs.map +0 -1
  187. package/dist/createWalletClient-DKcpswHR.js +0 -2007
  188. package/dist/createWalletClient-DKcpswHR.js.map +0 -1
  189. package/dist/getContract-B3Spz0SO.js.map +0 -1
  190. package/dist/secp256k1-BLbXMlpX.js +0 -1172
  191. package/dist/secp256k1-BLbXMlpX.js.map +0 -1
  192. package/dist/secp256k1-CFnFaJ0H.cjs +0 -2
  193. package/dist/secp256k1-CFnFaJ0H.cjs.map +0 -1
  194. package/dist/writeContract-BBHpAss8.cjs +0 -32
  195. package/dist/writeContract-BBHpAss8.cjs.map +0 -1
  196. package/dist/writeContract-RluxM31W.js +0 -3833
  197. package/dist/writeContract-RluxM31W.js.map +0 -1
@@ -1,12 +1,12 @@
1
1
  var f = Object.defineProperty;
2
2
  var S = (r, t, e) => t in r ? f(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e;
3
3
  var o = (r, t, e) => S(r, typeof t != "symbol" ? t + "" : t, e);
4
- import { V as k, p as l } from "../../constants-rWWWhxR_.js";
4
+ import { V as k, p as l } from "../../constants-BjRNQpT2.js";
5
5
  import { PUF_LOCKER_ABIS as v } from "../abis/puf-locker-abis.js";
6
6
  import { CONTRACT_ADDRESSES as p } from "../addresses.js";
7
7
  import { TOKENS_ADDRESSES as n } from "../tokens.js";
8
8
  import { ERC20PermitHandler as D } from "./erc20-permit-handler.js";
9
- import { g as A } from "../../getContract-B3Spz0SO.js";
9
+ import { g as A } from "../../getContract-CezEyDf-.js";
10
10
  class y {
11
11
  /**
12
12
  * Create the handler for the `PufLocker` contract exposing methods to
@@ -1 +1 @@
1
- {"version":3,"file":"puf-locker-handler.js","sources":["../../../lib/contracts/handlers/puf-locker-handler.ts"],"sourcesContent":["import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n padHex,\n GetContractReturnType,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport { PUF_LOCKER_ABIS } from '../abis/puf-locker-abis';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { UnifiToken, TOKENS_ADDRESSES } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\n\nexport type LockerDepositParams = {\n token: UnifiToken;\n account: Address;\n recipient: Address;\n value: bigint;\n lockPeriod: bigint;\n isPreapproved?: boolean;\n};\n\n/**\n * Handler for the `PufLocker` contract exposing methods to interact\n * with the contract.\n */\nexport class PufLockerHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufLocker` contract exposing methods to\n * interact with the contract.\n *\n * @param chain Chain to use for the client.\n * @param walletClient The wallet client to use for wallet\n * interactions.\n * @param publicClient The public client to use for public\n * interactions.\n */\n constructor(\n private chain: Chain,\n private walletClient: WalletClient,\n private publicClient: PublicClient,\n ) {\n this.viemChain = VIEM_CHAINS[chain];\n this.erc20PermitHandler = new ERC20PermitHandler(\n chain,\n walletClient,\n publicClient,\n );\n }\n\n /**\n * Get the contract. This is a method because the typings are complex\n * and lost when trying to make it a member.\n *\n * @returns The viem contract.\n */\n public getContract() {\n const address = CONTRACT_ADDRESSES[this.chain].PufLocker as Address;\n const abi = PUF_LOCKER_ABIS[this.chain].PufLocker;\n const client = { public: this.publicClient, wallet: this.walletClient };\n\n return getContract({ address, abi, client }) as GetContractReturnType<\n typeof abi,\n typeof client,\n Address\n >;\n }\n\n /**\n * Get all deposits of the given account address.\n *\n * @param pufToken The PufToken to get the deposits for.\n * @param walletAddress The wallet address to get the deposits for.\n * @returns The amount and deposits of the given account address.\n */\n public getAllDeposits(pufToken: UnifiToken, walletAddress: Address) {\n return this.getContract().read.getAllDeposits([\n TOKENS_ADDRESSES[pufToken][this.chain],\n walletAddress,\n ]);\n }\n\n /**\n * Get the user's deposits for the given token and deposit index.\n *\n * @param pufToken PufToken to get the deposits of.\n * @param userAddress User address to get the deposits for.\n * @param start The starting index of the deposits.\n * @param limit The maximum number of deposits to retrieve.\n * @returns The amount and release time of the deposits.\n */\n public getDeposits(\n pufToken: UnifiToken,\n userAddress: Address,\n start: bigint,\n limit: bigint,\n ) {\n return this.getContract().read.getDeposits([\n userAddress,\n TOKENS_ADDRESSES[pufToken][this.chain],\n start,\n limit,\n ]);\n }\n\n /**\n * Get the minimum and maximum lock periods allowed for deposits.\n *\n * @returns The minimum and maximum lock period in seconds.\n * (`[minLock, maxLock]`)\n */\n public getLockPeriods() {\n return this.getContract().read.getLockPeriods();\n }\n\n /**\n * Deposit the given PufToken into the locker. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param depositParams.pufToken PufToken to deposit.\n * @param depositParams.account Wallet address of the depositor.\n * @param depositParams.recipient Recipient of the deposit.\n * @param depositParams.value Amount of the deposit.\n * @param depositParams.lockPeriod The period for the deposit in\n * seconds.\n * @param depositParams.isPreapproved Whether the token is\n * pre-approved or needs a permit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async deposit(depositParams: LockerDepositParams) {\n const {\n token,\n account,\n recipient,\n value,\n lockPeriod,\n isPreapproved = false,\n } = depositParams;\n\n // Only `amount` is needed if `Token.approve()` is already called.\n // So using mock values for other properties.\n let permitData = {\n r: padHex('0x', { size: 32 }),\n s: padHex('0x', { size: 32 }),\n v: 0,\n deadline: 0n,\n amount: value,\n };\n\n if (!isPreapproved) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(token)\n .getPermitSignature(\n account,\n CONTRACT_ADDRESSES[this.chain].PufLocker as Address,\n value,\n );\n /* istanbul ignore next */\n permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n }\n\n const depositArgs = <const>[\n TOKENS_ADDRESSES[token][this.chain],\n recipient,\n lockPeriod,\n permitData,\n ];\n\n const transact = () =>\n this.getContract().write.deposit(depositArgs, {\n account,\n chain: this.viemChain,\n });\n const estimate = () =>\n this.getContract().estimateGas.deposit(depositArgs, {\n account,\n });\n\n return { transact, estimate };\n }\n\n /**\n * Withdraw the deposits identified by the deposit indexes from the\n * locker.\n *\n * @param pufToken PufToken to withdraw.\n * @param walletAddress Address of the account making the transaction.\n * @param recipient Recipient of the withdrawal.\n * @param depositIndexes Deposit indexes to withdraw.\n * @returns Hash of the withdrawal transaction.\n */\n public withdraw(\n pufToken: UnifiToken,\n walletAddress: Address,\n recipient: Address,\n depositIndexes: bigint[],\n ) {\n const withdrawArgs = <const>[\n TOKENS_ADDRESSES[pufToken][this.chain],\n depositIndexes,\n recipient,\n ];\n\n const transact = () =>\n this.getContract().write.withdraw(withdrawArgs, {\n account: walletAddress,\n chain: this.viemChain,\n });\n const estimate = () =>\n this.getContract().estimateGas.withdraw(withdrawArgs, {\n account: walletAddress,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["PufLockerHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PUF_LOCKER_ABIS","client","getContract","pufToken","walletAddress","TOKENS_ADDRESSES","userAddress","start","limit","depositParams","token","account","recipient","value","lockPeriod","isPreapproved","permitData","padHex","r","s","v","yParity","deadline","depositArgs","depositIndexes","withdrawArgs"],"mappings":"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"}
1
+ {"version":3,"file":"puf-locker-handler.js","sources":["../../../lib/contracts/handlers/puf-locker-handler.ts"],"sourcesContent":["import {\n WalletClient,\n PublicClient,\n getContract,\n Address,\n padHex,\n GetContractReturnType,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport { PUF_LOCKER_ABIS } from '../abis/puf-locker-abis';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { UnifiToken, TOKENS_ADDRESSES } from '../tokens';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\n\nexport type LockerDepositParams = {\n token: UnifiToken;\n account: Address;\n recipient: Address;\n value: bigint;\n lockPeriod: bigint;\n isPreapproved?: boolean;\n};\n\n/**\n * Handler for the `PufLocker` contract exposing methods to interact\n * with the contract.\n */\nexport class PufLockerHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufLocker` contract exposing methods to\n * interact with the contract.\n *\n * @param chain Chain to use for the client.\n * @param walletClient The wallet client to use for wallet\n * interactions.\n * @param publicClient The public client to use for public\n * interactions.\n */\n constructor(\n private chain: Chain,\n private walletClient: WalletClient,\n private publicClient: PublicClient,\n ) {\n this.viemChain = VIEM_CHAINS[chain];\n this.erc20PermitHandler = new ERC20PermitHandler(\n chain,\n walletClient,\n publicClient,\n );\n }\n\n /**\n * Get the contract. This is a method because the typings are complex\n * and lost when trying to make it a member.\n *\n * @returns The viem contract.\n */\n public getContract() {\n const address = CONTRACT_ADDRESSES[this.chain].PufLocker as Address;\n const abi = PUF_LOCKER_ABIS[this.chain].PufLocker;\n const client = { public: this.publicClient, wallet: this.walletClient };\n\n return getContract({ address, abi, client }) as GetContractReturnType<\n typeof abi,\n typeof client,\n Address\n >;\n }\n\n /**\n * Get all deposits of the given account address.\n *\n * @param pufToken The PufToken to get the deposits for.\n * @param walletAddress The wallet address to get the deposits for.\n * @returns The amount and deposits of the given account address.\n */\n public getAllDeposits(pufToken: UnifiToken, walletAddress: Address) {\n return this.getContract().read.getAllDeposits([\n TOKENS_ADDRESSES[pufToken][this.chain],\n walletAddress,\n ]);\n }\n\n /**\n * Get the user's deposits for the given token and deposit index.\n *\n * @param pufToken PufToken to get the deposits of.\n * @param userAddress User address to get the deposits for.\n * @param start The starting index of the deposits.\n * @param limit The maximum number of deposits to retrieve.\n * @returns The amount and release time of the deposits.\n */\n public getDeposits(\n pufToken: UnifiToken,\n userAddress: Address,\n start: bigint,\n limit: bigint,\n ) {\n return this.getContract().read.getDeposits([\n userAddress,\n TOKENS_ADDRESSES[pufToken][this.chain],\n start,\n limit,\n ]);\n }\n\n /**\n * Get the minimum and maximum lock periods allowed for deposits.\n *\n * @returns The minimum and maximum lock period in seconds.\n * (`[minLock, maxLock]`)\n */\n public getLockPeriods() {\n return this.getContract().read.getLockPeriods();\n }\n\n /**\n * Deposit the given PufToken into the locker. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param depositParams.pufToken PufToken to deposit.\n * @param depositParams.account Wallet address of the depositor.\n * @param depositParams.recipient Recipient of the deposit.\n * @param depositParams.value Amount of the deposit.\n * @param depositParams.lockPeriod The period for the deposit in\n * seconds.\n * @param depositParams.isPreapproved Whether the token is\n * pre-approved or needs a permit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async deposit(depositParams: LockerDepositParams) {\n const {\n token,\n account,\n recipient,\n value,\n lockPeriod,\n isPreapproved = false,\n } = depositParams;\n\n // Only `amount` is needed if `Token.approve()` is already called.\n // So using mock values for other properties.\n let permitData = {\n r: padHex('0x', { size: 32 }),\n s: padHex('0x', { size: 32 }),\n v: 0,\n deadline: 0n,\n amount: value,\n };\n\n if (!isPreapproved) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(token)\n .getPermitSignature(\n account,\n CONTRACT_ADDRESSES[this.chain].PufLocker as Address,\n value,\n );\n /* istanbul ignore next */\n permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n }\n\n const depositArgs = <const>[\n TOKENS_ADDRESSES[token][this.chain],\n recipient,\n lockPeriod,\n permitData,\n ];\n\n const transact = () =>\n this.getContract().write.deposit(depositArgs, {\n account,\n chain: this.viemChain,\n });\n const estimate = () =>\n this.getContract().estimateGas.deposit(depositArgs, {\n account,\n });\n\n return { transact, estimate };\n }\n\n /**\n * Withdraw the deposits identified by the deposit indexes from the\n * locker.\n *\n * @param pufToken PufToken to withdraw.\n * @param walletAddress Address of the account making the transaction.\n * @param recipient Recipient of the withdrawal.\n * @param depositIndexes Deposit indexes to withdraw.\n * @returns Hash of the withdrawal transaction.\n */\n public withdraw(\n pufToken: UnifiToken,\n walletAddress: Address,\n recipient: Address,\n depositIndexes: bigint[],\n ) {\n const withdrawArgs = <const>[\n TOKENS_ADDRESSES[pufToken][this.chain],\n depositIndexes,\n recipient,\n ];\n\n const transact = () =>\n this.getContract().write.withdraw(withdrawArgs, {\n account: walletAddress,\n chain: this.viemChain,\n });\n const estimate = () =>\n this.getContract().estimateGas.withdraw(withdrawArgs, {\n account: walletAddress,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["PufLockerHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PUF_LOCKER_ABIS","client","getContract","pufToken","walletAddress","TOKENS_ADDRESSES","userAddress","start","limit","depositParams","token","account","recipient","value","lockPeriod","isPreapproved","permitData","padHex","r","s","v","yParity","deadline","depositArgs","depositIndexes","withdrawArgs"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";var p=Object.defineProperty;var P=(n,t,e)=>t in n?p(n,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[t]=e;var h=(n,t,e)=>P(n,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("../../constants-BvU-JhfL.cjs"),E=require("../abis/puffer-depositor-abis.cjs"),u=require("../addresses.cjs"),H=require("./erc20-permit-handler.cjs"),m=require("../tokens.cjs"),D=require("../../getContract-MrPLx6gp.cjs");class f{constructor(t,e,i){h(this,"viemChain");h(this,"erc20PermitHandler");this.chain=t,this.walletClient=e,this.publicClient=i,this.viemChain=S.VIEM_CHAINS[t],this.erc20PermitHandler=new H.ERC20PermitHandler(t,e,i)}getContract(){const t=u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e=E.PUFFER_DEPOSITOR_ABIS[this.chain].PufferDepositor,i={public:this.publicClient,wallet:this.walletClient};return D.getContract({address:t,abi:e,client:i})}async depositStETH(t,e){const{r:i,s:a,v:s,yParity:c,deadline:o}=await this.erc20PermitHandler.withToken(m.Token.stETH).getPermitSignature(t,u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e),r={r:i,s:a,v:Number(s??c),deadline:o,amount:e};return{transact:async()=>await this.getContract().write.depositStETH([r,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositStETH([r,t],{account:t})}}async depositWstETH(t,e){const{r:i,s:a,v:s,yParity:c,deadline:o}=await this.erc20PermitHandler.withToken(m.Token.wstETH).getPermitSignature(t,u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e),r={r:i,s:a,v:Number(s??c),deadline:o,amount:e};return{transact:async()=>await this.getContract().write.depositWstETH([r,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositWstETH([r,t],{account:t})}}}exports.PufferDepositorHandler=f;
1
+ "use strict";var p=Object.defineProperty;var P=(n,t,e)=>t in n?p(n,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[t]=e;var h=(n,t,e)=>P(n,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("../../constants-DA2xUb9r.cjs"),E=require("../abis/puffer-depositor-abis.cjs"),u=require("../addresses.cjs"),H=require("./erc20-permit-handler.cjs"),m=require("../tokens.cjs"),D=require("../../getContract-3QbyfZBF.cjs");class f{constructor(t,e,i){h(this,"viemChain");h(this,"erc20PermitHandler");this.chain=t,this.walletClient=e,this.publicClient=i,this.viemChain=S.VIEM_CHAINS[t],this.erc20PermitHandler=new H.ERC20PermitHandler(t,e,i)}getContract(){const t=u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e=E.PUFFER_DEPOSITOR_ABIS[this.chain].PufferDepositor,i={public:this.publicClient,wallet:this.walletClient};return D.getContract({address:t,abi:e,client:i})}async depositStETH(t,e){const{r:i,s:a,v:s,yParity:c,deadline:o}=await this.erc20PermitHandler.withToken(m.Token.stETH).getPermitSignature(t,u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e),r={r:i,s:a,v:Number(s??c),deadline:o,amount:e};return{transact:async()=>await this.getContract().write.depositStETH([r,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositStETH([r,t],{account:t})}}async depositWstETH(t,e){const{r:i,s:a,v:s,yParity:c,deadline:o}=await this.erc20PermitHandler.withToken(m.Token.wstETH).getPermitSignature(t,u.CONTRACT_ADDRESSES[this.chain].PufferDepositor,e),r={r:i,s:a,v:Number(s??c),deadline:o,amount:e};return{transact:async()=>await this.getContract().write.depositWstETH([r,t],{account:t,chain:this.viemChain}),estimate:async()=>await this.getContract().estimateGas.depositWstETH([r,t],{account:t})}}}exports.PufferDepositorHandler=f;
2
2
  //# sourceMappingURL=puffer-depositor-handler.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"puffer-depositor-handler.cjs","sources":["../../../lib/contracts/handlers/puffer-depositor-handler.ts"],"sourcesContent":["import {\n Address,\n GetContractReturnType,\n PublicClient,\n WalletClient,\n getContract,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport { PUFFER_DEPOSITOR_ABIS } from '../abis/puffer-depositor-abis';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\nimport { Token } from '../tokens';\n\n/**\n * Handler for the `PufferDepositor` contract exposing methods to\n * interact with the contract.\n */\nexport class PufferDepositorHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufferDepositor` contract exposing\n * methods to interact with the contract.\n *\n * @param chain Chain to use for the client.\n * @param walletClient The wallet client to use for wallet\n * interactions.\n * @param publicClient The public client to use for public\n * interactions.\n */\n constructor(\n private chain: Chain,\n private walletClient: WalletClient,\n private publicClient: PublicClient,\n ) {\n this.viemChain = VIEM_CHAINS[chain];\n this.erc20PermitHandler = new ERC20PermitHandler(\n chain,\n walletClient,\n publicClient,\n );\n }\n\n /**\n * Get the contract. This is a method because the typings are complex\n * and lost when trying to make it a member.\n *\n * @returns The viem contract.\n */\n public getContract() {\n const address = CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address;\n const abi = PUFFER_DEPOSITOR_ABIS[this.chain].PufferDepositor;\n const client = { public: this.publicClient, wallet: this.walletClient };\n\n return getContract({ address, abi, client }) as GetContractReturnType<\n typeof abi,\n typeof client,\n Address\n >;\n }\n\n /**\n * Deposit stETH in exchange for pufETH. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param walletAddress Wallet address to get the stETH from.\n * @param value Value in wei of the stETH to deposit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async depositStETH(walletAddress: Address, value: bigint) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(Token.stETH)\n .getPermitSignature(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n value,\n );\n /* istanbul ignore next */\n const permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n\n const transact = async () =>\n await this.getContract().write.depositStETH([permitData, walletAddress], {\n account: walletAddress,\n chain: this.viemChain,\n });\n const estimate = async () =>\n await this.getContract().estimateGas.depositStETH(\n [permitData, walletAddress],\n { account: walletAddress },\n );\n\n return { transact, estimate };\n }\n\n /**\n * Deposit wstETH in exchange for pufETH. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param walletAddress Wallet address to get the stETH from.\n * @param value Value in wei of the wstETH to deposit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async depositWstETH(walletAddress: Address, value: bigint) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(Token.wstETH)\n .getPermitSignature(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n value,\n );\n /* istanbul ignore next */\n const permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n\n const transact = async () =>\n await this.getContract().write.depositWstETH(\n [permitData, walletAddress],\n {\n account: walletAddress,\n chain: this.viemChain,\n },\n );\n const estimate = async () =>\n await this.getContract().estimateGas.depositWstETH(\n [permitData, walletAddress],\n { account: walletAddress },\n );\n\n return { transact, estimate };\n }\n}\n"],"names":["PufferDepositorHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PUFFER_DEPOSITOR_ABIS","client","getContract","walletAddress","value","r","s","v","yParity","deadline","Token","permitData"],"mappings":"geAiBO,MAAMA,CAAuB,CAclC,YACUC,EACAC,EACAC,EACR,CAjBMC,EAAA,kBACAA,EAAA,2BAaE,KAAA,MAAAH,EACA,KAAA,aAAAC,EACA,KAAA,aAAAC,EAEH,KAAA,UAAYE,cAAYJ,CAAK,EAClC,KAAK,mBAAqB,IAAIK,EAAA,mBAC5BL,EACAC,EACAC,CAAA,CAEJ,CAQO,aAAc,CACnB,MAAMI,EAAUC,EAAA,mBAAmB,KAAK,KAAK,EAAE,gBACzCC,EAAMC,EAAA,sBAAsB,KAAK,KAAK,EAAE,gBACxCC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,cAEzD,OAAOC,EAAY,YAAA,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,CAAQ,CAAA,CAK7C,CAeA,MAAa,aAAaE,EAAwBC,EAAe,CAC/D,KAAM,CAAE,EAAAC,EAAG,EAAAC,EAAG,EAAAC,EAAG,QAAAC,EAAS,SAAAC,CAAA,EAAa,MAAM,KAAK,mBAC/C,UAAUC,EAAAA,MAAM,KAAK,EACrB,mBACCP,EACAL,qBAAmB,KAAK,KAAK,EAAE,gBAC/BM,CAAA,EAGEO,EAAa,CACjB,EAAAN,EACA,EAAAC,EACA,EAAG,OAAOC,GAAKC,CAAO,EACtB,SAAAC,EACA,OAAQL,CAAA,EAcH,MAAA,CAAE,SAXQ,SACf,MAAM,KAAK,YAAA,EAAc,MAAM,aAAa,CAACO,EAAYR,CAAa,EAAG,CACvE,QAASA,EACT,MAAO,KAAK,SAAA,CACb,EAOgB,SANF,SACf,MAAM,KAAK,cAAc,YAAY,aACnC,CAACQ,EAAYR,CAAa,EAC1B,CAAE,QAASA,CAAc,CAAA,EAI/B,CAeA,MAAa,cAAcA,EAAwBC,EAAe,CAChE,KAAM,CAAE,EAAAC,EAAG,EAAAC,EAAG,EAAAC,EAAG,QAAAC,EAAS,SAAAC,CAAA,EAAa,MAAM,KAAK,mBAC/C,UAAUC,EAAAA,MAAM,MAAM,EACtB,mBACCP,EACAL,qBAAmB,KAAK,KAAK,EAAE,gBAC/BM,CAAA,EAGEO,EAAa,CACjB,EAAAN,EACA,EAAAC,EACA,EAAG,OAAOC,GAAKC,CAAO,EACtB,SAAAC,EACA,OAAQL,CAAA,EAiBH,MAAA,CAAE,SAdQ,SACf,MAAM,KAAK,cAAc,MAAM,cAC7B,CAACO,EAAYR,CAAa,EAC1B,CACE,QAASA,EACT,MAAO,KAAK,SACd,CAAA,EAQe,SANF,SACf,MAAM,KAAK,cAAc,YAAY,cACnC,CAACQ,EAAYR,CAAa,EAC1B,CAAE,QAASA,CAAc,CAAA,EAI/B,CACF"}
1
+ {"version":3,"file":"puffer-depositor-handler.cjs","sources":["../../../lib/contracts/handlers/puffer-depositor-handler.ts"],"sourcesContent":["import {\n Address,\n GetContractReturnType,\n PublicClient,\n WalletClient,\n getContract,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport { PUFFER_DEPOSITOR_ABIS } from '../abis/puffer-depositor-abis';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { ERC20PermitHandler } from './erc20-permit-handler';\nimport { Token } from '../tokens';\n\n/**\n * Handler for the `PufferDepositor` contract exposing methods to\n * interact with the contract.\n */\nexport class PufferDepositorHandler {\n private viemChain: ViemChain;\n private erc20PermitHandler: ERC20PermitHandler;\n\n /**\n * Create the handler for the `PufferDepositor` contract exposing\n * methods to interact with the contract.\n *\n * @param chain Chain to use for the client.\n * @param walletClient The wallet client to use for wallet\n * interactions.\n * @param publicClient The public client to use for public\n * interactions.\n */\n constructor(\n private chain: Chain,\n private walletClient: WalletClient,\n private publicClient: PublicClient,\n ) {\n this.viemChain = VIEM_CHAINS[chain];\n this.erc20PermitHandler = new ERC20PermitHandler(\n chain,\n walletClient,\n publicClient,\n );\n }\n\n /**\n * Get the contract. This is a method because the typings are complex\n * and lost when trying to make it a member.\n *\n * @returns The viem contract.\n */\n public getContract() {\n const address = CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address;\n const abi = PUFFER_DEPOSITOR_ABIS[this.chain].PufferDepositor;\n const client = { public: this.publicClient, wallet: this.walletClient };\n\n return getContract({ address, abi, client }) as GetContractReturnType<\n typeof abi,\n typeof client,\n Address\n >;\n }\n\n /**\n * Deposit stETH in exchange for pufETH. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param walletAddress Wallet address to get the stETH from.\n * @param value Value in wei of the stETH to deposit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async depositStETH(walletAddress: Address, value: bigint) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(Token.stETH)\n .getPermitSignature(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n value,\n );\n /* istanbul ignore next */\n const permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n\n const transact = async () =>\n await this.getContract().write.depositStETH([permitData, walletAddress], {\n account: walletAddress,\n chain: this.viemChain,\n });\n const estimate = async () =>\n await this.getContract().estimateGas.depositStETH(\n [permitData, walletAddress],\n { account: walletAddress },\n );\n\n return { transact, estimate };\n }\n\n /**\n * Deposit wstETH in exchange for pufETH. This doesn't make the\n * transaction but returns two methods namely `transact` and\n * `estimate`.\n *\n * @param walletAddress Wallet address to get the stETH from.\n * @param value Value in wei of the wstETH to deposit.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n */\n public async depositWstETH(walletAddress: Address, value: bigint) {\n const { r, s, v, yParity, deadline } = await this.erc20PermitHandler\n .withToken(Token.wstETH)\n .getPermitSignature(\n walletAddress,\n CONTRACT_ADDRESSES[this.chain].PufferDepositor as Address,\n value,\n );\n /* istanbul ignore next */\n const permitData = {\n r,\n s,\n v: Number(v ?? yParity),\n deadline,\n amount: value,\n };\n\n const transact = async () =>\n await this.getContract().write.depositWstETH(\n [permitData, walletAddress],\n {\n account: walletAddress,\n chain: this.viemChain,\n },\n );\n const estimate = async () =>\n await this.getContract().estimateGas.depositWstETH(\n [permitData, walletAddress],\n { account: walletAddress },\n );\n\n return { transact, estimate };\n }\n}\n"],"names":["PufferDepositorHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","ERC20PermitHandler","address","CONTRACT_ADDRESSES","abi","PUFFER_DEPOSITOR_ABIS","client","getContract","walletAddress","value","r","s","v","yParity","deadline","Token","permitData"],"mappings":"geAiBO,MAAMA,CAAuB,CAclC,YACUC,EACAC,EACAC,EACR,CAjBMC,EAAA,kBACAA,EAAA,2BAaE,KAAA,MAAAH,EACA,KAAA,aAAAC,EACA,KAAA,aAAAC,EAEH,KAAA,UAAYE,cAAYJ,CAAK,EAClC,KAAK,mBAAqB,IAAIK,EAAA,mBAC5BL,EACAC,EACAC,CACF,CAAA,CASK,aAAc,CACnB,MAAMI,EAAUC,EAAA,mBAAmB,KAAK,KAAK,EAAE,gBACzCC,EAAMC,EAAA,sBAAsB,KAAK,KAAK,EAAE,gBACxCC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,YAAa,EAEtE,OAAOC,EAAY,YAAA,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,EAAQ,CAAA,CAoB7C,MAAa,aAAaE,EAAwBC,EAAe,CAC/D,KAAM,CAAE,EAAAC,EAAG,EAAAC,EAAG,EAAAC,EAAG,QAAAC,EAAS,SAAAC,CAAA,EAAa,MAAM,KAAK,mBAC/C,UAAUC,EAAAA,MAAM,KAAK,EACrB,mBACCP,EACAL,qBAAmB,KAAK,KAAK,EAAE,gBAC/BM,CACF,EAEIO,EAAa,CACjB,EAAAN,EACA,EAAAC,EACA,EAAG,OAAOC,GAAKC,CAAO,EACtB,SAAAC,EACA,OAAQL,CACV,EAaO,MAAA,CAAE,SAXQ,SACf,MAAM,KAAK,YAAA,EAAc,MAAM,aAAa,CAACO,EAAYR,CAAa,EAAG,CACvE,QAASA,EACT,MAAO,KAAK,SAAA,CACb,EAOgB,SANF,SACf,MAAM,KAAK,cAAc,YAAY,aACnC,CAACQ,EAAYR,CAAa,EAC1B,CAAE,QAASA,CAAc,CAC3B,CAE0B,CAAA,CAgB9B,MAAa,cAAcA,EAAwBC,EAAe,CAChE,KAAM,CAAE,EAAAC,EAAG,EAAAC,EAAG,EAAAC,EAAG,QAAAC,EAAS,SAAAC,CAAA,EAAa,MAAM,KAAK,mBAC/C,UAAUC,EAAAA,MAAM,MAAM,EACtB,mBACCP,EACAL,qBAAmB,KAAK,KAAK,EAAE,gBAC/BM,CACF,EAEIO,EAAa,CACjB,EAAAN,EACA,EAAAC,EACA,EAAG,OAAOC,GAAKC,CAAO,EACtB,SAAAC,EACA,OAAQL,CACV,EAgBO,MAAA,CAAE,SAdQ,SACf,MAAM,KAAK,cAAc,MAAM,cAC7B,CAACO,EAAYR,CAAa,EAC1B,CACE,QAASA,EACT,MAAO,KAAK,SAAA,CAEhB,EAOiB,SANF,SACf,MAAM,KAAK,cAAc,YAAY,cACnC,CAACQ,EAAYR,CAAa,EAC1B,CAAE,QAASA,CAAc,CAC3B,CAE0B,CAAA,CAEhC"}