@pufferfinance/puffer-sdk 1.4.2 → 1.5.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 (203) hide show
  1. package/dist/api/puffer-client-helpers.cjs +2 -0
  2. package/dist/api/puffer-client-helpers.cjs.map +1 -0
  3. package/dist/api/puffer-client-helpers.d.ts +0 -1
  4. package/dist/api/puffer-client-helpers.js +142 -0
  5. package/dist/api/puffer-client-helpers.js.map +1 -0
  6. package/dist/api/puffer-client.cjs +2 -0
  7. package/dist/api/puffer-client.cjs.map +1 -0
  8. package/dist/api/puffer-client.d.ts +6 -1
  9. package/dist/api/puffer-client.js +97 -0
  10. package/dist/api/puffer-client.js.map +1 -0
  11. package/dist/{ccip-ZoYOXsGl.js → ccip-D4klNwCt.js} +28 -27
  12. package/dist/{ccip-ZoYOXsGl.js.map → ccip-D4klNwCt.js.map} +1 -1
  13. package/dist/ccip-DLDqFodf.cjs +2 -0
  14. package/dist/{ccip-Dv116NSL.cjs.map → ccip-DLDqFodf.cjs.map} +1 -1
  15. package/dist/chains/constants.cjs +2 -0
  16. package/dist/chains/constants.cjs.map +1 -0
  17. package/dist/chains/constants.d.ts +3 -2
  18. package/dist/chains/constants.js +6 -0
  19. package/dist/chains/constants.js.map +1 -0
  20. package/dist/constants-BvU-JhfL.cjs +9 -0
  21. package/dist/constants-BvU-JhfL.cjs.map +1 -0
  22. package/dist/constants-rWWWhxR_.js +2099 -0
  23. package/dist/constants-rWWWhxR_.js.map +1 -0
  24. package/dist/contracts/abis/holesky/PufferDepositor.cjs +2 -0
  25. package/dist/contracts/abis/holesky/PufferDepositor.cjs.map +1 -0
  26. package/dist/contracts/abis/holesky/PufferDepositor.js +377 -0
  27. package/dist/contracts/abis/holesky/PufferDepositor.js.map +1 -0
  28. package/dist/contracts/abis/holesky/PufferVaultV2.cjs +2 -0
  29. package/dist/contracts/abis/holesky/PufferVaultV2.cjs.map +1 -0
  30. package/dist/contracts/abis/holesky/PufferVaultV2.js +1787 -0
  31. package/dist/contracts/abis/holesky/PufferVaultV2.js.map +1 -0
  32. package/dist/contracts/abis/l1-reward-manager-abis.cjs +2 -0
  33. package/dist/contracts/abis/l1-reward-manager-abis.cjs.map +1 -0
  34. package/dist/contracts/abis/l1-reward-manager-abis.d.ts +527 -0
  35. package/dist/contracts/abis/l1-reward-manager-abis.js +9 -0
  36. package/dist/contracts/abis/l1-reward-manager-abis.js.map +1 -0
  37. package/dist/contracts/abis/l2-reward-manager-abis.cjs +2 -0
  38. package/dist/contracts/abis/l2-reward-manager-abis.cjs.map +1 -0
  39. package/dist/contracts/abis/l2-reward-manager-abis.d.ts +685 -0
  40. package/dist/contracts/abis/l2-reward-manager-abis.js +9 -0
  41. package/dist/contracts/abis/l2-reward-manager-abis.js.map +1 -0
  42. package/dist/contracts/abis/mainnet/ERC20Permit.cjs +2 -0
  43. package/dist/contracts/abis/mainnet/ERC20Permit.cjs.map +1 -0
  44. package/dist/contracts/abis/mainnet/ERC20Permit.js +524 -0
  45. package/dist/contracts/abis/mainnet/ERC20Permit.js.map +1 -0
  46. package/dist/contracts/abis/mainnet/L1RewardManager.cjs +2 -0
  47. package/dist/contracts/abis/mainnet/L1RewardManager.cjs.map +1 -0
  48. package/dist/contracts/abis/mainnet/L1RewardManager.d.ts +523 -0
  49. package/dist/contracts/abis/mainnet/L1RewardManager.js +447 -0
  50. package/dist/contracts/abis/mainnet/L1RewardManager.js.map +1 -0
  51. package/dist/contracts/abis/mainnet/L2RewardManager.cjs +2 -0
  52. package/dist/contracts/abis/mainnet/L2RewardManager.cjs.map +1 -0
  53. package/dist/contracts/abis/mainnet/L2RewardManager.d.ts +681 -0
  54. package/dist/contracts/abis/mainnet/L2RewardManager.js +538 -0
  55. package/dist/contracts/abis/mainnet/L2RewardManager.js.map +1 -0
  56. package/dist/contracts/abis/mainnet/PufLocker.cjs +2 -0
  57. package/dist/contracts/abis/mainnet/PufLocker.cjs.map +1 -0
  58. package/dist/contracts/abis/mainnet/PufLocker.js +362 -0
  59. package/dist/contracts/abis/mainnet/PufLocker.js.map +1 -0
  60. package/dist/contracts/abis/mainnet/PufToken.cjs +2 -0
  61. package/dist/contracts/abis/mainnet/PufToken.cjs.map +1 -0
  62. package/dist/contracts/abis/mainnet/PufToken.js +883 -0
  63. package/dist/contracts/abis/mainnet/PufToken.js.map +1 -0
  64. package/dist/contracts/abis/mainnet/PufferDepositor.cjs +2 -0
  65. package/dist/contracts/abis/mainnet/PufferDepositor.cjs.map +1 -0
  66. package/dist/contracts/abis/mainnet/PufferDepositor.js +377 -0
  67. package/dist/contracts/abis/mainnet/PufferDepositor.js.map +1 -0
  68. package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs +2 -0
  69. package/dist/contracts/abis/mainnet/PufferL2Depositor.cjs.map +1 -0
  70. package/dist/contracts/abis/mainnet/PufferL2Depositor.js +300 -0
  71. package/dist/contracts/abis/mainnet/PufferL2Depositor.js.map +1 -0
  72. package/dist/contracts/abis/mainnet/PufferVaultV2.cjs +2 -0
  73. package/dist/contracts/abis/mainnet/PufferVaultV2.cjs.map +1 -0
  74. package/dist/contracts/abis/mainnet/PufferVaultV2.js +1864 -0
  75. package/dist/contracts/abis/mainnet/PufferVaultV2.js.map +1 -0
  76. package/dist/contracts/abis/puf-locker-abis.cjs +2 -0
  77. package/dist/contracts/abis/puf-locker-abis.cjs.map +1 -0
  78. package/dist/contracts/abis/puf-locker-abis.js +10 -0
  79. package/dist/contracts/abis/puf-locker-abis.js.map +1 -0
  80. package/dist/contracts/abis/puf-token-abis.cjs +2 -0
  81. package/dist/contracts/abis/puf-token-abis.cjs.map +1 -0
  82. package/dist/contracts/abis/puf-token-abis.js +10 -0
  83. package/dist/contracts/abis/puf-token-abis.js.map +1 -0
  84. package/dist/contracts/abis/puffer-depositor-abis.cjs +2 -0
  85. package/dist/contracts/abis/puffer-depositor-abis.cjs.map +1 -0
  86. package/dist/contracts/abis/puffer-depositor-abis.js +20 -0
  87. package/dist/contracts/abis/puffer-depositor-abis.js.map +1 -0
  88. package/dist/contracts/abis/puffer-vault-abis.cjs +2 -0
  89. package/dist/contracts/abis/puffer-vault-abis.cjs.map +1 -0
  90. package/dist/contracts/abis/puffer-vault-abis.js +15 -0
  91. package/dist/contracts/abis/puffer-vault-abis.js.map +1 -0
  92. package/dist/contracts/abis/tokens-abis.cjs +2 -0
  93. package/dist/contracts/abis/tokens-abis.cjs.map +1 -0
  94. package/dist/contracts/abis/tokens-abis.js +6 -0
  95. package/dist/contracts/abis/tokens-abis.js.map +1 -0
  96. package/dist/contracts/addresses.cjs +2 -0
  97. package/dist/contracts/addresses.cjs.map +1 -0
  98. package/dist/contracts/addresses.d.ts +23 -0
  99. package/dist/contracts/addresses.js +27 -0
  100. package/dist/contracts/addresses.js.map +1 -0
  101. package/dist/contracts/handlers/erc20-permit-handler.cjs +2 -0
  102. package/dist/contracts/handlers/erc20-permit-handler.cjs.map +1 -0
  103. package/dist/contracts/handlers/erc20-permit-handler.d.ts +579 -579
  104. package/dist/contracts/handlers/erc20-permit-handler.js +124 -0
  105. package/dist/contracts/handlers/erc20-permit-handler.js.map +1 -0
  106. package/dist/contracts/handlers/l1-reward-manager-handler.cjs +2 -0
  107. package/dist/contracts/handlers/l1-reward-manager-handler.cjs.map +1 -0
  108. package/dist/contracts/handlers/l1-reward-manager-handler.d.ts +6693 -0
  109. package/dist/contracts/handlers/l1-reward-manager-handler.js +68 -0
  110. package/dist/contracts/handlers/l1-reward-manager-handler.js.map +1 -0
  111. package/dist/contracts/handlers/l2-reward-manager-handler.cjs +2 -0
  112. package/dist/contracts/handlers/l2-reward-manager-handler.cjs.map +1 -0
  113. package/dist/contracts/handlers/l2-reward-manager-handler.d.ts +6912 -0
  114. package/dist/contracts/handlers/l2-reward-manager-handler.js +137 -0
  115. package/dist/contracts/handlers/l2-reward-manager-handler.js.map +1 -0
  116. package/dist/contracts/handlers/puf-locker-handler.cjs +2 -0
  117. package/dist/contracts/handlers/puf-locker-handler.cjs.map +1 -0
  118. package/dist/contracts/handlers/puf-locker-handler.d.ts +579 -579
  119. package/dist/contracts/handlers/puf-locker-handler.js +168 -0
  120. package/dist/contracts/handlers/puf-locker-handler.js.map +1 -0
  121. package/dist/contracts/handlers/puf-token-handler.cjs +2 -0
  122. package/dist/contracts/handlers/puf-token-handler.cjs.map +1 -0
  123. package/dist/contracts/handlers/puf-token-handler.d.ts +579 -579
  124. package/dist/contracts/handlers/puf-token-handler.js +174 -0
  125. package/dist/contracts/handlers/puf-token-handler.js.map +1 -0
  126. package/dist/contracts/handlers/puffer-depositor-handler.cjs +2 -0
  127. package/dist/contracts/handlers/puffer-depositor-handler.cjs.map +1 -0
  128. package/dist/contracts/handlers/puffer-depositor-handler.d.ts +579 -579
  129. package/dist/contracts/handlers/puffer-depositor-handler.js +113 -0
  130. package/dist/contracts/handlers/puffer-depositor-handler.js.map +1 -0
  131. package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs +2 -0
  132. package/dist/contracts/handlers/puffer-l2-depositor-handler.cjs.map +1 -0
  133. package/dist/contracts/handlers/puffer-l2-depositor-handler.d.ts +579 -579
  134. package/dist/contracts/handlers/puffer-l2-depositor-handler.js +112 -0
  135. package/dist/contracts/handlers/puffer-l2-depositor-handler.js.map +1 -0
  136. package/dist/contracts/handlers/puffer-vault-handler.cjs +2 -0
  137. package/dist/contracts/handlers/puffer-vault-handler.cjs.map +1 -0
  138. package/dist/contracts/handlers/puffer-vault-handler.d.ts +579 -579
  139. package/dist/contracts/handlers/puffer-vault-handler.js +185 -0
  140. package/dist/contracts/handlers/puffer-vault-handler.js.map +1 -0
  141. package/dist/contracts/tokens.cjs +2 -0
  142. package/dist/contracts/tokens.cjs.map +1 -0
  143. package/dist/contracts/tokens.d.ts +0 -1
  144. package/dist/contracts/tokens.js +134 -0
  145. package/dist/contracts/tokens.js.map +1 -0
  146. package/dist/createWalletClient-Bmopj8MM.cjs +4 -0
  147. package/dist/createWalletClient-Bmopj8MM.cjs.map +1 -0
  148. package/dist/createWalletClient-DKcpswHR.js +2007 -0
  149. package/dist/createWalletClient-DKcpswHR.js.map +1 -0
  150. package/dist/errors/base-error.cjs +3 -0
  151. package/dist/errors/base-error.cjs.map +1 -0
  152. package/dist/errors/base-error.d.ts +0 -1
  153. package/dist/errors/base-error.js +23 -0
  154. package/dist/errors/base-error.js.map +1 -0
  155. package/dist/errors/types.cjs +2 -0
  156. package/dist/errors/types.cjs.map +1 -0
  157. package/dist/errors/types.js +2 -0
  158. package/dist/errors/types.js.map +1 -0
  159. package/dist/errors/validation-errors.cjs +2 -0
  160. package/dist/errors/validation-errors.cjs.map +1 -0
  161. package/dist/errors/validation-errors.d.ts +2 -1
  162. package/dist/errors/validation-errors.js +10 -0
  163. package/dist/errors/validation-errors.js.map +1 -0
  164. package/dist/getContract-B3Spz0SO.js +115 -0
  165. package/dist/getContract-B3Spz0SO.js.map +1 -0
  166. package/dist/getContract-MrPLx6gp.cjs +2 -0
  167. package/dist/getContract-MrPLx6gp.cjs.map +1 -0
  168. package/dist/main.cjs +1 -1
  169. package/dist/main.d.ts +8 -0
  170. package/dist/main.js +31 -11
  171. package/dist/main.js.map +1 -1
  172. package/dist/secp256k1-BLbXMlpX.js +1172 -0
  173. package/dist/secp256k1-BLbXMlpX.js.map +1 -0
  174. package/dist/secp256k1-CFnFaJ0H.cjs +2 -0
  175. package/dist/secp256k1-CFnFaJ0H.cjs.map +1 -0
  176. package/dist/utils/time.cjs +2 -0
  177. package/dist/utils/time.cjs.map +1 -0
  178. package/dist/utils/time.js +5 -0
  179. package/dist/utils/time.js.map +1 -0
  180. package/dist/utils/types.cjs +2 -0
  181. package/dist/utils/types.cjs.map +1 -0
  182. package/dist/utils/types.js +2 -0
  183. package/dist/utils/types.js.map +1 -0
  184. package/dist/utils/version.cjs +2 -0
  185. package/dist/utils/version.cjs.map +1 -0
  186. package/dist/utils/version.js +5 -0
  187. package/dist/utils/version.js.map +1 -0
  188. package/dist/writeContract-BBHpAss8.cjs +32 -0
  189. package/dist/writeContract-BBHpAss8.cjs.map +1 -0
  190. package/dist/writeContract-RluxM31W.js +3833 -0
  191. package/dist/writeContract-RluxM31W.js.map +1 -0
  192. package/package.json +22 -11
  193. package/dist/ccip-Dv116NSL.cjs +0 -2
  194. package/dist/contracts/handlers/erc20-permit-handler.test.d.ts +0 -1
  195. package/dist/contracts/handlers/puf-locker-handler.test.d.ts +0 -1
  196. package/dist/contracts/handlers/puf-token-handler.test.d.ts +0 -1
  197. package/dist/contracts/handlers/puffer-depositor-handler.test.d.ts +0 -1
  198. package/dist/contracts/handlers/puffer-l2-depositor-handler.test.d.ts +0 -1
  199. package/dist/contracts/handlers/puffer-vault-handler.test.d.ts +0 -1
  200. package/dist/main-69HiNG3t.js +0 -16001
  201. package/dist/main-69HiNG3t.js.map +0 -1
  202. package/dist/main-IyjWcdJ1.cjs +0 -41
  203. package/dist/main-IyjWcdJ1.cjs.map +0 -1
@@ -0,0 +1,68 @@
1
+ var s = Object.defineProperty;
2
+ var n = (a, t, e) => t in a ? s(a, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : a[t] = e;
3
+ var r = (a, t, e) => n(a, typeof t != "symbol" ? t + "" : t, e);
4
+ import { V as o } from "../../constants-rWWWhxR_.js";
5
+ import { CONTRACT_ADDRESSES as c } from "../addresses.js";
6
+ import { L1_REWARD_MANAGER_ABIS as h } from "../abis/l1-reward-manager-abis.js";
7
+ import { g as l } from "../../getContract-B3Spz0SO.js";
8
+ class A {
9
+ /**
10
+ * Create the handler for the `L1RewardManager` contract exposing
11
+ * methods to interact with the contract.
12
+ *
13
+ * @param chain Chain to use for the client.
14
+ * @param walletClient The wallet client to use for wallet
15
+ * interactions.
16
+ * @param publicClient The public client to use for public
17
+ * interactions.
18
+ */
19
+ constructor(t, e, i) {
20
+ r(this, "viemChain");
21
+ this.chain = t, this.walletClient = e, this.publicClient = i, this.viemChain = o[t];
22
+ }
23
+ /**
24
+ * Get the contract. This is a method because the typings are complex
25
+ * and lost when trying to make it a member.
26
+ *
27
+ * @returns The viem contract.
28
+ */
29
+ getContract() {
30
+ const t = c[this.chain].L1RewardManager, e = h[this.chain].L1RewardManager, i = { public: this.publicClient, wallet: this.walletClient };
31
+ return l({ address: t, abi: e, client: i });
32
+ }
33
+ /**
34
+ * Get the bridge data for the given bridge address.
35
+ *
36
+ * @param bridgeAddress Address of the bridge.
37
+ * @returns The bridge data.
38
+ */
39
+ getBridge(t) {
40
+ return this.getContract().read.getBridge([t]);
41
+ }
42
+ /**
43
+ * Sets the rewards claimer on L2. Smart contracts might not be able
44
+ * to to own the same address on L2. This function allows to set a
45
+ * different address as the claimer.
46
+ *
47
+ * @param account The account to make the transaction with.
48
+ * @param bridge Address of the bridge.
49
+ * @param claimer Address of the new claimer.
50
+ * @returns `transact: () => Promise<Address>` - Used to make the
51
+ * transaction.
52
+ *
53
+ * `estimate: () => Promise<bigint>` - Gas estimate of the
54
+ * transaction.
55
+ */
56
+ setL2RewardClaimer(t, e, i) {
57
+ return { transact: () => this.getContract().write.setL2RewardClaimer([e, i], {
58
+ chain: this.viemChain,
59
+ account: t
60
+ }), estimate: () => this.getContract().estimateGas.setL2RewardClaimer([e, i], {
61
+ account: t
62
+ }) };
63
+ }
64
+ }
65
+ export {
66
+ A as L1RewardManagerHandler
67
+ };
68
+ //# sourceMappingURL=l1-reward-manager-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"l1-reward-manager-handler.js","sources":["../../../lib/contracts/handlers/l1-reward-manager-handler.ts"],"sourcesContent":["import {\n Address,\n getContract,\n GetContractReturnType,\n PublicClient,\n WalletClient,\n} from 'viem';\nimport { Chain, VIEM_CHAINS, ViemChain } from '../../chains/constants';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { L1_REWARD_MANAGER_ABIS } from '../abis/l1-reward-manager-abis';\n\n/**\n * Handler for the `L1RewardManager` contract.\n */\nexport class L1RewardManagerHandler {\n private viemChain: ViemChain;\n\n /**\n * Create the handler for the `L1RewardManager` 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 }\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].L1RewardManager as Address;\n const abi = L1_REWARD_MANAGER_ABIS[this.chain].L1RewardManager;\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 the bridge data for the given bridge address.\n *\n * @param bridgeAddress Address of the bridge.\n * @returns The bridge data.\n */\n public getBridge(bridgeAddress: Address) {\n return this.getContract().read.getBridge([bridgeAddress]);\n }\n\n /**\n * Sets the rewards claimer on L2. Smart contracts might not be able\n * to to own the same address on L2. This function allows to set a\n * different address as the claimer.\n *\n * @param account The account to make the transaction with.\n * @param bridge Address of the bridge.\n * @param claimer Address of the new claimer.\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 setL2RewardClaimer(\n account: Address,\n bridge: Address,\n claimer: Address,\n ) {\n const transact = () =>\n this.getContract().write.setL2RewardClaimer([bridge, claimer], {\n chain: this.viemChain,\n account,\n });\n const estimate = () =>\n this.getContract().estimateGas.setL2RewardClaimer([bridge, claimer], {\n account,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["L1RewardManagerHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","address","CONTRACT_ADDRESSES","abi","L1_REWARD_MANAGER_ABIS","client","getContract","bridgeAddress","account","bridge","claimer"],"mappings":";;;;;;;AAcO,MAAMA,EAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAalC,YACUC,GACAC,GACAC,GACR;AAhBM,IAAAC,EAAA;AAaE,SAAA,QAAAH,GACA,KAAA,eAAAC,GACA,KAAA,eAAAC,GAEH,KAAA,YAAYE,EAAYJ,CAAK;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,cAAc;AACnB,UAAMK,IAAUC,EAAmB,KAAK,KAAK,EAAE,iBACzCC,IAAMC,EAAuB,KAAK,KAAK,EAAE,iBACzCC,IAAS,EAAE,QAAQ,KAAK,cAAc,QAAQ,KAAK;AAEzD,WAAOC,EAAY,EAAE,SAAAL,GAAS,KAAAE,GAAK,QAAAE,EAAQ,CAAA;AAAA,EAK7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAUE,GAAwB;AACvC,WAAO,KAAK,cAAc,KAAK,UAAU,CAACA,CAAa,CAAC;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAgBO,mBACLC,GACAC,GACAC,GACA;AAWO,WAAA,EAAE,UAVQ,MACf,KAAK,YAAY,EAAE,MAAM,mBAAmB,CAACD,GAAQC,CAAO,GAAG;AAAA,MAC7D,OAAO,KAAK;AAAA,MACZ,SAAAF;AAAA,IAAA,CACD,GAMgB,UALF,MACf,KAAK,YAAY,EAAE,YAAY,mBAAmB,CAACC,GAAQC,CAAO,GAAG;AAAA,MACnE,SAAAF;AAAA,IAAA,CACD;EAGL;AACF;"}
@@ -0,0 +1,2 @@
1
+ "use strict";var n=Object.defineProperty;var s=(r,t,e)=>t in r?n(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e;var i=(r,t,e)=>s(r,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("../../constants-BvU-JhfL.cjs"),o=require("../addresses.cjs"),l=require("../abis/l2-reward-manager-abis.cjs"),d=require("../../errors/validation-errors.cjs"),g=require("../../getContract-MrPLx6gp.cjs");class h{constructor(t,e,a){i(this,"viemChain");this.chain=t,this.walletClient=e,this.publicClient=a,this.viemChain=c.VIEM_CHAINS[t]}getContract(){const t=o.CONTRACT_ADDRESSES[this.chain].L2RewardManager,e=l.L2_REWARD_MANAGER_ABIS[this.chain].L2RewardManager,a={public:this.publicClient,wallet:this.walletClient};return g.getContract({address:t,abi:e,client:a})}authority(){return this.getContract().read.authority()}getClaimingDelay(){return this.getContract().read.getClaimingDelay()}getEpochRecord(t){return this.getContract().read.getEpochRecord([t])}getIntervalId(t,e){return this.getContract().read.getIntervalId([t,e])}getRewardsClaimer(t){return this.getContract().read.getRewardsClaimer([t])}isClaimed(t,e){return this.getContract().read.isClaimed([e,t])}isClaimingLocked(t){return this.getContract().read.isClaimingLocked([t])}claimRewards(t,e){if(e.length===0)throw new d.InvalidInputError("`claimOrders` cannot be empty and must be specified",{fixMessage:"Specify at least one or more claim orders to claim rewards"});return{transact:()=>this.getContract().write.claimRewards([e],{chain:this.viemChain,account:t}),estimate:()=>this.getContract().estimateGas.claimRewards([e],{account:t})}}}exports.L2RewardManagerHandler=h;
2
+ //# sourceMappingURL=l2-reward-manager-handler.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"l2-reward-manager-handler.cjs","sources":["../../../lib/contracts/handlers/l2-reward-manager-handler.ts"],"sourcesContent":["import {\n Address,\n WalletClient,\n PublicClient,\n getContract,\n GetContractReturnType,\n} from 'viem';\nimport { ViemChain, VIEM_CHAINS, Chain } from '../../chains/constants';\nimport { CONTRACT_ADDRESSES } from '../addresses';\nimport { L2_REWARD_MANAGER_ABIS } from '../abis/l2-reward-manager-abis';\nimport { InvalidInputError } from '../../errors/validation-errors';\n\nexport type ClaimOrder = {\n account: Address;\n amount: bigint;\n intervalId: Address;\n merkleProof: Address[];\n};\n\n/**\n * Handler for the `L2RewardManager` contract.\n */\nexport class L2RewardManagerHandler {\n private viemChain: ViemChain;\n\n /**\n * Create the handler for the `L2RewardManager` 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 }\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].L2RewardManager as Address;\n const abi = L2_REWARD_MANAGER_ABIS[this.chain].L2RewardManager;\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 the authority address.\n *\n * @returns The authority address.\n */\n public authority() {\n return this.getContract().read.authority();\n }\n\n /**\n * Get the claiming delay.\n *\n * @returns The claiming delay.\n */\n public getClaimingDelay() {\n return this.getContract().read.getClaimingDelay();\n }\n\n /**\n * Get the epoch record for a specific period.\n *\n * @param intervalId The interval ID for a given start and end epoch.\n * See `getInternvalId`.\n * @returns The epoch record of exchange rate and reward root.\n */\n public getEpochRecord(intervalId: Address) {\n return this.getContract().read.getEpochRecord([intervalId]);\n }\n\n /**\n * Returns the interval ID for a given start and end epoch.\n *\n * @param startEpoch Start epoch of the interval.\n * @param endEpoch End epoch of the interval.\n * @returns Interval ID for the given start and end epoch.\n */\n public getIntervalId(startEpoch: bigint, endEpoch: bigint) {\n return this.getContract().read.getIntervalId([startEpoch, endEpoch]);\n }\n\n /**\n * Get the rewards claimer for a specific `account`.\n *\n * @param account Account for which to get the rewards claimer.\n * @returns Rewards claimer address.\n */\n public getRewardsClaimer(account: Address) {\n return this.getContract().read.getRewardsClaimer([account]);\n }\n\n /**\n * Check if the reward has been claimed for an account and a specific\n * interval.\n *\n * @param account The address of the account to check.\n * @param intervalId The claiming interval ID. See `getIntervalId`.\n * @returns Whether the reward has been claimed.\n */\n public isClaimed(account: Address, intervalId: Address) {\n return this.getContract().read.isClaimed([intervalId, account]);\n }\n\n /**\n * Check whether the claiming is locked for the given interval.\n *\n * @param intervalId The interval to check the claiming lock for. See\n * `getIntervalId`.\n * @returns Whether the claiming is locked for the given interval.\n */\n public isClaimingLocked(intervalId: Address) {\n return this.getContract().read.isClaimingLocked([intervalId]);\n }\n\n /**\n * Claims the rewards for a specific epoch range based on the\n * `ClaimOrder`.\n *\n * @param account The account using which to claim the rewards.\n * @param claimOrders One or more claim orders.\n * @param claimOrders[].account Account of the claim order.\n * @param claimOrders[].amount Amount of the claim order.\n * @param claimOrders[].intervalId Interval ID of the claim order. See\n * `getIntervalId`.\n * @param claimOrders[].merkleProof Merkle proof of the claim order.\n * @returns `transact: () => Promise<Address>` - Used to make the\n * transaction.\n *\n * `estimate: () => Promise<bigint>` - Gas estimate of the\n * transaction.\n * @throws {InvalidInputError} If `claimOrders` is empty.\n */\n public claimRewards(account: Address, claimOrders: ClaimOrder[]) {\n if (claimOrders.length === 0) {\n throw new InvalidInputError(\n '`claimOrders` cannot be empty and must be specified',\n {\n fixMessage:\n 'Specify at least one or more claim orders to claim rewards',\n },\n );\n }\n\n const transact = () =>\n this.getContract().write.claimRewards([claimOrders], {\n chain: this.viemChain,\n account,\n });\n const estimate = () =>\n this.getContract().estimateGas.claimRewards([claimOrders], {\n account,\n });\n\n return { transact, estimate };\n }\n}\n"],"names":["L2RewardManagerHandler","chain","walletClient","publicClient","__publicField","VIEM_CHAINS","address","CONTRACT_ADDRESSES","abi","L2_REWARD_MANAGER_ABIS","client","getContract","intervalId","startEpoch","endEpoch","account","claimOrders","InvalidInputError"],"mappings":"8cAsBO,MAAMA,CAAuB,CAalC,YACUC,EACAC,EACAC,EACR,CAhBMC,EAAA,kBAaE,KAAA,MAAAH,EACA,KAAA,aAAAC,EACA,KAAA,aAAAC,EAEH,KAAA,UAAYE,cAAYJ,CAAK,CACpC,CAQO,aAAc,CACnB,MAAMK,EAAUC,EAAA,mBAAmB,KAAK,KAAK,EAAE,gBACzCC,EAAMC,EAAA,uBAAuB,KAAK,KAAK,EAAE,gBACzCC,EAAS,CAAE,OAAQ,KAAK,aAAc,OAAQ,KAAK,cAEzD,OAAOC,EAAY,YAAA,CAAE,QAAAL,EAAS,IAAAE,EAAK,OAAAE,CAAQ,CAAA,CAK7C,CAOO,WAAY,CACjB,OAAO,KAAK,YAAA,EAAc,KAAK,UAAU,CAC3C,CAOO,kBAAmB,CACxB,OAAO,KAAK,YAAA,EAAc,KAAK,iBAAiB,CAClD,CASO,eAAeE,EAAqB,CACzC,OAAO,KAAK,cAAc,KAAK,eAAe,CAACA,CAAU,CAAC,CAC5D,CASO,cAAcC,EAAoBC,EAAkB,CAClD,OAAA,KAAK,cAAc,KAAK,cAAc,CAACD,EAAYC,CAAQ,CAAC,CACrE,CAQO,kBAAkBC,EAAkB,CACzC,OAAO,KAAK,cAAc,KAAK,kBAAkB,CAACA,CAAO,CAAC,CAC5D,CAUO,UAAUA,EAAkBH,EAAqB,CAC/C,OAAA,KAAK,cAAc,KAAK,UAAU,CAACA,EAAYG,CAAO,CAAC,CAChE,CASO,iBAAiBH,EAAqB,CAC3C,OAAO,KAAK,cAAc,KAAK,iBAAiB,CAACA,CAAU,CAAC,CAC9D,CAoBO,aAAaG,EAAkBC,EAA2B,CAC3D,GAAAA,EAAY,SAAW,EACzB,MAAM,IAAIC,EAAA,kBACR,sDACA,CACE,WACE,4DACJ,CAAA,EAcG,MAAA,CAAE,SAVQ,IACf,KAAK,YAAA,EAAc,MAAM,aAAa,CAACD,CAAW,EAAG,CACnD,MAAO,KAAK,UACZ,QAAAD,CAAA,CACD,EAMgB,SALF,IACf,KAAK,YAAA,EAAc,YAAY,aAAa,CAACC,CAAW,EAAG,CACzD,QAAAD,CAAA,CACD,EAGL,CACF"}