@berachain/berajs 0.1.0 → 0.1.2

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 (502) hide show
  1. package/dist/{dex-jD95agMv.d.cts → HoneyConfigProvider-6PXZJMSU.d.cts} +172 -172
  2. package/dist/{dex-CxzGqVLe.d.ts → HoneyConfigProvider-CwDFrt02.d.ts} +172 -172
  3. package/dist/abi/index.cjs +2 -1
  4. package/dist/abi/index.cjs.map +1 -0
  5. package/dist/abi/index.mjs +2 -1
  6. package/dist/abi/index.mjs.map +1 -0
  7. package/dist/actions/index.cjs +2 -1
  8. package/dist/actions/index.cjs.map +1 -0
  9. package/dist/actions/index.d.cts +8 -8
  10. package/dist/actions/index.d.ts +8 -8
  11. package/dist/actions/index.mjs +2 -1
  12. package/dist/actions/index.mjs.map +1 -0
  13. package/dist/chunk-22MQVFHP.cjs +2 -0
  14. package/dist/chunk-22MQVFHP.cjs.map +1 -0
  15. package/dist/chunk-3TKSVFZ3.mjs +2 -0
  16. package/dist/chunk-3TKSVFZ3.mjs.map +1 -0
  17. package/dist/chunk-6VF3RF53.cjs +3 -0
  18. package/dist/chunk-6VF3RF53.cjs.map +1 -0
  19. package/dist/{chunk-2422CKAT.mjs → chunk-6W22TFYA.mjs} +2 -1
  20. package/dist/chunk-6W22TFYA.mjs.map +1 -0
  21. package/dist/chunk-AMRJ4B36.mjs +2 -0
  22. package/dist/chunk-AMRJ4B36.mjs.map +1 -0
  23. package/dist/{chunk-4IBBLGNS.mjs → chunk-DS2ZDVKU.mjs} +1 -0
  24. package/dist/chunk-DS2ZDVKU.mjs.map +1 -0
  25. package/dist/{chunk-B47PDJZM.cjs → chunk-ED43NYSE.cjs} +2 -1
  26. package/dist/chunk-ED43NYSE.cjs.map +1 -0
  27. package/dist/chunk-EU4WFADK.cjs +2 -0
  28. package/dist/chunk-EU4WFADK.cjs.map +1 -0
  29. package/dist/{chunk-ASRHUDAH.mjs → chunk-HCTFDGXL.mjs} +1 -0
  30. package/dist/chunk-HCTFDGXL.mjs.map +1 -0
  31. package/dist/{chunk-K4NZIO2Z.mjs → chunk-IOSYBHKU.mjs} +1 -0
  32. package/dist/chunk-IOSYBHKU.mjs.map +1 -0
  33. package/dist/{chunk-4GY57XKG.cjs → chunk-JMKLDDKY.cjs} +1 -0
  34. package/dist/chunk-JMKLDDKY.cjs.map +1 -0
  35. package/dist/chunk-KMKUXP2S.mjs +3 -0
  36. package/dist/chunk-KMKUXP2S.mjs.map +1 -0
  37. package/dist/chunk-OJXJ6CZ4.mjs +4 -0
  38. package/dist/chunk-OJXJ6CZ4.mjs.map +1 -0
  39. package/dist/{chunk-VA37UBED.mjs → chunk-PHIOKO3A.mjs} +2 -1
  40. package/dist/chunk-PHIOKO3A.mjs.map +1 -0
  41. package/dist/{chunk-IKAE7CQU.cjs → chunk-QCK474XD.cjs} +1 -0
  42. package/dist/chunk-QCK474XD.cjs.map +1 -0
  43. package/dist/chunk-REDXXUK7.cjs +2 -0
  44. package/dist/chunk-REDXXUK7.cjs.map +1 -0
  45. package/dist/{chunk-K2FCHQHA.cjs → chunk-S74ZMG2G.cjs} +2 -1
  46. package/dist/chunk-S74ZMG2G.cjs.map +1 -0
  47. package/dist/{chunk-NOV7UCGA.cjs → chunk-TOAXF4YW.cjs} +1 -0
  48. package/dist/chunk-TOAXF4YW.cjs.map +1 -0
  49. package/dist/chunk-UZ5CB33M.cjs +2 -0
  50. package/dist/chunk-UZ5CB33M.cjs.map +1 -0
  51. package/dist/chunk-VYWYJR63.mjs +2 -0
  52. package/dist/chunk-VYWYJR63.mjs.map +1 -0
  53. package/dist/{chunk-WZLPSG5R.cjs → chunk-XFPTQMAK.cjs} +3 -2
  54. package/dist/chunk-XFPTQMAK.cjs.map +1 -0
  55. package/dist/chunk-YK4NINF5.mjs +2 -0
  56. package/dist/chunk-YK4NINF5.mjs.map +1 -0
  57. package/dist/contexts/index.cjs +2 -1
  58. package/dist/contexts/index.cjs.map +1 -0
  59. package/dist/contexts/index.d.cts +7 -5
  60. package/dist/contexts/index.d.ts +7 -5
  61. package/dist/contexts/index.mjs +2 -1
  62. package/dist/contexts/index.mjs.map +1 -0
  63. package/dist/enum/index.cjs +2 -1
  64. package/dist/enum/index.cjs.map +1 -0
  65. package/dist/enum/index.d.cts +1 -1
  66. package/dist/enum/index.d.ts +1 -1
  67. package/dist/enum/index.mjs +2 -1
  68. package/dist/enum/index.mjs.map +1 -0
  69. package/dist/errors/index.cjs +2 -1
  70. package/dist/errors/index.cjs.map +1 -0
  71. package/dist/errors/index.d.cts +1 -1
  72. package/dist/errors/index.d.ts +1 -1
  73. package/dist/errors/index.mjs +2 -1
  74. package/dist/errors/index.mjs.map +1 -0
  75. package/dist/{getValidatorQueuedOperatorAddress-9jSXlAse.d.ts → getValidatorQueuedOperatorAddress-9xY2RUGe.d.cts} +2 -2
  76. package/dist/{getValidatorQueuedOperatorAddress-BCYlvah3.d.cts → getValidatorQueuedOperatorAddress-Ne2zoiiV.d.ts} +2 -2
  77. package/dist/hooks/index.cjs +3 -2
  78. package/dist/hooks/index.cjs.map +1 -0
  79. package/dist/hooks/index.d.cts +9 -9
  80. package/dist/hooks/index.d.ts +9 -9
  81. package/dist/hooks/index.mjs +3 -2
  82. package/dist/hooks/index.mjs.map +1 -0
  83. package/dist/{staking-Bw46L2PT.d.ts → staking-F9Nx9TKD.d.ts} +1 -1
  84. package/dist/{staking-BxYDlMtj.d.cts → staking-f4BpYH7l.d.cts} +1 -1
  85. package/dist/{txnEnum-Diichv9Z.d.cts → txnEnum-BQKDfaeH.d.cts} +1 -0
  86. package/dist/{txnEnum-Diichv9Z.d.ts → txnEnum-BQKDfaeH.d.ts} +1 -0
  87. package/dist/types/index.cjs +2 -1
  88. package/dist/types/index.cjs.map +1 -0
  89. package/dist/types/index.d.cts +5 -5
  90. package/dist/types/index.d.ts +5 -5
  91. package/dist/types/index.mjs +2 -1
  92. package/dist/types/index.mjs.map +1 -0
  93. package/dist/{useHoneySwapState-YfMSTWY3.d.cts → useHoneySwapState-C-9BV4VB.d.cts} +1 -1
  94. package/dist/{useHoneySwapState-CD8v6y1k.d.ts → useHoneySwapState-CUY5Sm1b.d.ts} +1 -1
  95. package/dist/utils/index.cjs +2 -1
  96. package/dist/utils/index.cjs.map +1 -0
  97. package/dist/utils/index.d.cts +5 -5
  98. package/dist/utils/index.d.ts +5 -5
  99. package/dist/utils/index.mjs +2 -1
  100. package/dist/utils/index.mjs.map +1 -0
  101. package/package.json +4 -3
  102. package/src/abi/bend/bundler.ts +60 -0
  103. package/src/abi/bend/generalAdapter.ts +362 -0
  104. package/src/abi/bend/metaMorpho.ts +2584 -0
  105. package/src/abi/bend/morpho.ts +444 -0
  106. package/src/abi/bend/morphoVault.ts +1456 -0
  107. package/src/abi/bend/publicAllocator.ts +355 -0
  108. package/src/abi/bex/aggregatorsRouter.ts +492 -0
  109. package/src/abi/bex/balancerComposableStablePoolFactoryV6.ts +283 -0
  110. package/src/abi/bex/balancerPoolCreationHelper.ts +267 -0
  111. package/src/abi/bex/balancerVault.ts +757 -0
  112. package/src/abi/enso/ensoRouterAbi.ts +140 -0
  113. package/src/abi/governance/governance.ts +1016 -0
  114. package/src/abi/governance/governanceTimelock.ts +589 -0
  115. package/src/abi/honey/collateralVault.ts +1144 -0
  116. package/src/abi/honey/honey.ts +563 -0
  117. package/src/abi/honey/honeyFactory.ts +1270 -0
  118. package/src/abi/honey/honeyFactoryReader.ts +894 -0
  119. package/src/abi/honey/honeyRootOracle.ts +492 -0
  120. package/src/abi/honey/pythPriceOracle.ts +619 -0
  121. package/src/abi/honey/pythWrapper.ts +446 -0
  122. package/src/abi/index.ts +35 -0
  123. package/src/abi/pol/beaconDeposit.ts +595 -0
  124. package/src/abi/pol/beraChef.ts +1019 -0
  125. package/src/abi/pol/bgt.ts +1008 -0
  126. package/src/abi/pol/bgtIncentiveDistributor.ts +640 -0
  127. package/src/abi/pol/bgtStaker.ts +1034 -0
  128. package/src/abi/pol/rewardAllocationFactory.ts +408 -0
  129. package/src/abi/pol/rewardVault.ts +1928 -0
  130. package/src/abi/pol/rewardVaultFactory.ts +586 -0
  131. package/src/abi/pol/rewardVaultHelper.ts +882 -0
  132. package/src/abi/pol/stakeBeraVault.ts +1116 -0
  133. package/src/abi/pol/stakeBeraVaultWithdrawalRequest.ts +618 -0
  134. package/src/abi/pol/wbera.ts +366 -0
  135. package/src/abi/pyth/pyth.ts +566 -0
  136. package/src/abi/pyth/pythErrors.ts +72 -0
  137. package/src/abi/utils/EIP7702StatelessDelegator.ts +523 -0
  138. package/src/abi/utils/bundler3errors.ts +6 -0
  139. package/src/abi/utils/commonAbiErrors.ts +9 -0
  140. package/src/abi/utils/erc20errors.ts +74 -0
  141. package/src/abi/utils/merkleDistributor.ts +838 -0
  142. package/src/abi/utils/multicall3.ts +242 -0
  143. package/src/abi/utils/openChainErrors.ts +139 -0
  144. package/src/abi/utils/upgradableBeacon.ts +86 -0
  145. package/src/actions/bend/getConvertToAssets.ts +23 -0
  146. package/src/actions/bend/getMaxDeposit.ts +21 -0
  147. package/src/actions/clients/BeraApolloClient.ts +125 -0
  148. package/src/actions/clients/getApolloClient.ts +109 -0
  149. package/src/actions/clients/getEnsoClient.ts +24 -0
  150. package/src/actions/dex/__tests__/aggregators.unit.test.ts +112 -0
  151. package/src/actions/dex/__tests__/allPools.integration.test.ts +13 -0
  152. package/src/actions/dex/__tests__/getOnChainPool.unit.test.ts +15 -0
  153. package/src/actions/dex/__tests__/haiku.integration.test.ts +40 -0
  154. package/src/actions/dex/aggregators/base.ts +174 -0
  155. package/src/actions/dex/aggregators/bex.ts +255 -0
  156. package/src/actions/dex/aggregators/bgt.ts +50 -0
  157. package/src/actions/dex/aggregators/enso.ts +113 -0
  158. package/src/actions/dex/aggregators/fly.ts +136 -0
  159. package/src/actions/dex/aggregators/haiku.ts +171 -0
  160. package/src/actions/dex/aggregators/honey.ts +245 -0
  161. package/src/actions/dex/aggregators/kyberswap.ts +142 -0
  162. package/src/actions/dex/aggregators/oogabooga.ts +110 -0
  163. package/src/actions/dex/aggregators/openOcean.ts +142 -0
  164. package/src/actions/dex/aggregators/wbera.ts +72 -0
  165. package/src/actions/dex/b-sdk.ts +48 -0
  166. package/src/actions/dex/getAllPools.ts +60 -0
  167. package/src/actions/dex/getApiPool.ts +47 -0
  168. package/src/actions/dex/getGlobalLiquidityAndSwapVolume.ts +29 -0
  169. package/src/actions/dex/getIsTokenExploited.ts +63 -0
  170. package/src/actions/dex/getOnChainPool.ts +216 -0
  171. package/src/actions/dex/getPoolEvents.ts +35 -0
  172. package/src/actions/dex/getPoolHistoricalData.ts +51 -0
  173. package/src/actions/dex/getPoolPausedState.ts +40 -0
  174. package/src/actions/dex/getPoolWithState.ts +24 -0
  175. package/src/actions/dex/getSubgraphPool.ts +30 -0
  176. package/src/actions/dex/getTransactionCount.ts +29 -0
  177. package/src/actions/dex/getVaultPausedState.ts +21 -0
  178. package/src/actions/enso/bend.ts +143 -0
  179. package/src/actions/enso/getEnsoUserToken.debug.test.ts +57 -0
  180. package/src/actions/enso/getEnsoUserToken.ts +133 -0
  181. package/src/actions/enso/util.ts +60 -0
  182. package/src/actions/enso/zap.ts +78 -0
  183. package/src/actions/governance/__tests__/checkProposalField.unit.test.ts +108 -0
  184. package/src/actions/governance/__tests__/getDecodedFunctionData.integration.test.ts +127 -0
  185. package/src/actions/governance/__tests__/getQuorum.integration.test.ts +39 -0
  186. package/src/actions/governance/checkProposalField.ts +211 -0
  187. package/src/actions/governance/computeActualStatus.ts +154 -0
  188. package/src/actions/governance/constants.ts +7 -0
  189. package/src/actions/governance/getAllProposals.ts +75 -0
  190. package/src/actions/governance/getBodyErrors.ts +28 -0
  191. package/src/actions/governance/getDecodedFunctionData.ts +170 -0
  192. package/src/actions/governance/getProposalDetails.ts +40 -0
  193. package/src/actions/governance/getProposalFromTx.ts +101 -0
  194. package/src/actions/governance/getProposalParams.ts +247 -0
  195. package/src/actions/governance/getProposalVotes.ts +20 -0
  196. package/src/actions/governance/getQuorum.ts +38 -0
  197. package/src/actions/governance/parseProposalBody.ts +73 -0
  198. package/src/actions/honey/getChartData.ts +27 -0
  199. package/src/actions/honey/getCollateralWeights.ts +50 -0
  200. package/src/actions/honey/getGlobalCapLimit.ts +148 -0
  201. package/src/actions/honey/getHoneyCollaterals.ts +139 -0
  202. package/src/actions/honey/getHoneyFees.ts +100 -0
  203. package/src/actions/honey/getHoneyGlobalData.ts +21 -0
  204. package/src/actions/honey/getHoneyPausedState.ts +25 -0
  205. package/src/actions/honey/getHoneyPreview.ts +152 -0
  206. package/src/actions/honey/getHoneyPythPriceOracle.ts +21 -0
  207. package/src/actions/honey/getHoneyRootPriceOracle.ts +23 -0
  208. package/src/actions/honey/getHoneyVaultsBalance.ts +86 -0
  209. package/src/actions/honey/getPythLatestPrices.ts +54 -0
  210. package/src/actions/honey/getRelativeCapLimit.ts +83 -0
  211. package/src/actions/honey/getSharesWithoutFees.ts +65 -0
  212. package/src/actions/honey/getSwapPayload.ts +128 -0
  213. package/src/actions/honey/isBadCollateralAsset.ts +77 -0
  214. package/src/actions/honey/isBasketModeEnabled.ts +47 -0
  215. package/src/actions/honey/tests/pyth.integration.test.ts +63 -0
  216. package/src/actions/index.ts +105 -0
  217. package/src/actions/misc/getBlockTimestamp.ts +41 -0
  218. package/src/actions/pol/__tests__/getAllValidators.integration.test.ts +55 -0
  219. package/src/actions/pol/__tests__/getValidator.integration.test.ts +32 -0
  220. package/src/actions/pol/__tests__/rewardVaults.integration.test.ts +34 -0
  221. package/src/actions/pol/getBGTGlobalInfo.ts +43 -0
  222. package/src/actions/pol/getBgtAprSimulation.ts +207 -0
  223. package/src/actions/pol/getBgtAprSimultaion.unit.test.ts +297 -0
  224. package/src/actions/pol/getBgtTokenTotalBoosts.ts +30 -0
  225. package/src/actions/pol/getBgtTokenTotalSupply.ts +29 -0
  226. package/src/actions/pol/getBlockTime.ts +43 -0
  227. package/src/actions/pol/getGlobalCuttingBoard.ts +25 -0
  228. package/src/actions/pol/getGlobalData.ts +74 -0
  229. package/src/actions/pol/getIncentiveFeeClaimStats.ts +43 -0
  230. package/src/actions/pol/getMarkets.ts +36 -0
  231. package/src/actions/pol/getRewardProofsByValidator.ts +49 -0
  232. package/src/actions/pol/getRewardTokenToBeraRate.ts +30 -0
  233. package/src/actions/pol/getRewardVault.ts +54 -0
  234. package/src/actions/pol/getRewardVaultBeaconImplementation.integration.test.ts +18 -0
  235. package/src/actions/pol/getRewardVaultBeaconImplementation.ts +35 -0
  236. package/src/actions/pol/getRewardVaultDurationConstants.integration.test.ts +24 -0
  237. package/src/actions/pol/getRewardVaultDurationConstants.ts +45 -0
  238. package/src/actions/pol/getRewardVaultFromToken.ts +30 -0
  239. package/src/actions/pol/getRewardVaultIncentives.ts +122 -0
  240. package/src/actions/pol/getRewardVaultRewards.ts +109 -0
  241. package/src/actions/pol/getRewardVaultStakingToken.ts +19 -0
  242. package/src/actions/pol/getRewardVaults.ts +106 -0
  243. package/src/actions/pol/getSWBeraVaultMetadata.ts +166 -0
  244. package/src/actions/pol/getSWBeraWithdrawal.ts +165 -0
  245. package/src/actions/pol/getStakeWithdrawalCooldown.ts +21 -0
  246. package/src/actions/pol/getStakedBeraAPR.ts +56 -0
  247. package/src/actions/pol/getStakedBeraSnapshots.ts +48 -0
  248. package/src/actions/pol/getStakingTokenInformation.ts +60 -0
  249. package/src/actions/pol/getUserClaimableIncentives.ts +40 -0
  250. package/src/actions/pol/getUserVaultInfo.ts +52 -0
  251. package/src/actions/pol/getUserVaults.ts +185 -0
  252. package/src/actions/pol/getUserVaultsBalance.ts +54 -0
  253. package/src/actions/pol/getUserVaultsReward.ts +32 -0
  254. package/src/actions/pol/getVaultHistory.ts +43 -0
  255. package/src/actions/pol/getVaultValidators.ts +31 -0
  256. package/src/actions/pol/getVaultsSupply.ts +28 -0
  257. package/src/actions/prices/__tests__/prices.integration.test.ts +29 -0
  258. package/src/actions/prices/getTokenCurrentPrices.ts +79 -0
  259. package/src/actions/pyth/getHoneyPythFeeds.ts +46 -0
  260. package/src/actions/pyth/getUpdateFee.ts +27 -0
  261. package/src/actions/tokens/getAllowances.ts +59 -0
  262. package/src/actions/tokens/getTokenInformation.ts +57 -0
  263. package/src/actions/tokens/getTokens.ts +19 -0
  264. package/src/actions/tokens/getWalletBalances.integration.test.ts +40 -0
  265. package/src/actions/tokens/getWalletBalances.ts +123 -0
  266. package/src/actions/transactions/beraWriteContract.integration.test.ts +251 -0
  267. package/src/actions/transactions/beraWriteContract.ts +722 -0
  268. package/src/actions/validators/getActiveBoostAndCommissionChangeDelay.integration.test.ts +40 -0
  269. package/src/actions/validators/getActiveBoostAndCommissionChangeDelay.ts +109 -0
  270. package/src/actions/validators/getAllValidators.ts +33 -0
  271. package/src/actions/validators/getApiEnrichedAllocation.ts +33 -0
  272. package/src/actions/validators/getApiValidator.ts +38 -0
  273. package/src/actions/validators/getBaselineRewardAllocation.ts +26 -0
  274. package/src/actions/validators/getDailyValidatorBlockStats.ts +37 -0
  275. package/src/actions/validators/getDefaultRewardAllocation.ts +39 -0
  276. package/src/actions/validators/getManagedValidatorByAccount.ts +32 -0
  277. package/src/actions/validators/getStakingPoolBatch.ts +20 -0
  278. package/src/actions/validators/getUserActiveValidators.ts +101 -0
  279. package/src/actions/validators/getUserBoosts.ts +28 -0
  280. package/src/actions/validators/getUserBoostsOnValidator.ts +70 -0
  281. package/src/actions/validators/getUserStakingPositions.ts +225 -0
  282. package/src/actions/validators/getValidatorAnalytics.ts +34 -0
  283. package/src/actions/validators/getValidatorCommission.ts +24 -0
  284. package/src/actions/validators/getValidatorEstimatedBgtPerYear.ts +25 -0
  285. package/src/actions/validators/getValidatorOperatorAddress.ts +27 -0
  286. package/src/actions/validators/getValidatorQueuedCommission.ts +30 -0
  287. package/src/actions/validators/getValidatorQueuedOperatorAddress.ts +32 -0
  288. package/src/actions/validators/getValidatorQueuedRewardAllocation.ts +31 -0
  289. package/src/actions/validators/getValidatorRewardAllocation.ts +158 -0
  290. package/src/actions/validators/getValidatorRewardAllocatorAddress.ts +38 -0
  291. package/src/actions/validators/utils/__tests__/validatorUtils.integration.test.ts +36 -0
  292. package/src/actions/validators/utils/getValidatorBoostApy.ts +59 -0
  293. package/src/contexts/BeraFlags/BeraFlags.tsx +69 -0
  294. package/src/contexts/BeraFlags/defaultFlags.ts +42 -0
  295. package/src/contexts/BexStatusProvider.tsx +125 -0
  296. package/src/contexts/HoneyConfigProvider.tsx +73 -0
  297. package/src/contexts/SwrFallback.tsx +34 -0
  298. package/src/contexts/TokensProvider.tsx +66 -0
  299. package/src/contexts/berajsProvider/context.tsx +49 -0
  300. package/src/contexts/berajsProvider/index.ts +2 -0
  301. package/src/contexts/berajsProvider/useBeraJs.ts +18 -0
  302. package/src/contexts/block-time-provider.tsx +34 -0
  303. package/src/contexts/index.ts +14 -0
  304. package/src/data/contracts.ts +398 -0
  305. package/src/enum/dex.ts +10 -0
  306. package/src/enum/index.ts +4 -0
  307. package/src/enum/polling.ts +8 -0
  308. package/src/enum/slippage.ts +19 -0
  309. package/src/enum/txnEnum.ts +101 -0
  310. package/src/errors/BeraError.ts +202 -0
  311. package/src/errors/InvalidArgumentError.ts +81 -0
  312. package/src/errors/NotFoundError.ts +34 -0
  313. package/src/errors/RequestError.ts +207 -0
  314. package/src/errors/TransactionFailedError.ts +93 -0
  315. package/src/errors/assert.ts +144 -0
  316. package/src/errors/assert.unit.test.ts +110 -0
  317. package/src/errors/errorMap.ts +1157 -0
  318. package/src/errors/getErrorMessage.ts +40 -0
  319. package/src/errors/getRevertReason.integration.test.ts +449 -0
  320. package/src/errors/getRevertReason.ts +179 -0
  321. package/src/errors/index.ts +8 -0
  322. package/src/errors/initBeraError.ts +46 -0
  323. package/src/errors/parseViemError.ts +239 -0
  324. package/src/hooks/bend/useGetConvertToAssets.ts +42 -0
  325. package/src/hooks/dex/useAggregatorsQuotes.ts +502 -0
  326. package/src/hooks/dex/useAggregatorsRouterFeeBps.ts +34 -0
  327. package/src/hooks/dex/useAllUserPools.ts +38 -0
  328. package/src/hooks/dex/useApiPool.ts +53 -0
  329. package/src/hooks/dex/useBexStatus.ts +1 -0
  330. package/src/hooks/dex/useCreatePool.ts +437 -0
  331. package/src/hooks/dex/useExploitedTokens.ts +57 -0
  332. package/src/hooks/dex/useGlobalLiquidityAndSwapVolume.ts +22 -0
  333. package/src/hooks/dex/useLiquidityMismatch.ts +195 -0
  334. package/src/hooks/dex/useLpPosition.ts +115 -0
  335. package/src/hooks/dex/useMultipleTokenApprovalsWithSlippage.ts +92 -0
  336. package/src/hooks/dex/useOnChainPoolData.ts +126 -0
  337. package/src/hooks/dex/usePollPoolCreationRelayerApproval.ts +54 -0
  338. package/src/hooks/dex/usePollVaultIsPaused.ts +30 -0
  339. package/src/hooks/dex/usePool.ts +59 -0
  340. package/src/hooks/dex/usePoolEvents.ts +22 -0
  341. package/src/hooks/dex/usePoolHistoricalData.ts +44 -0
  342. package/src/hooks/dex/usePools.ts +83 -0
  343. package/src/hooks/enso/useBendTransactionRequests.ts +247 -0
  344. package/src/hooks/enso/useEnsoZap.ts +166 -0
  345. package/src/hooks/enso/useZapTransactionRequests.ts +81 -0
  346. package/src/hooks/governance/useCreateProposal.ts +88 -0
  347. package/src/hooks/governance/useGetPastVotes.ts +63 -0
  348. package/src/hooks/governance/useHasVoted.ts +38 -0
  349. package/src/hooks/governance/useIsCanceller.ts +43 -0
  350. package/src/hooks/governance/usePollAllProposals.ts +232 -0
  351. package/src/hooks/governance/usePollProposal.ts +96 -0
  352. package/src/hooks/governance/usePollProposalThreshold.ts +41 -0
  353. package/src/hooks/governance/usePollProposalVotes.ts +64 -0
  354. package/src/hooks/governance/usePollUserDelegates.ts +70 -0
  355. package/src/hooks/governance/useProposalFromTx.ts +37 -0
  356. package/src/hooks/governance/useProposalSnapshot.ts +44 -0
  357. package/src/hooks/governance/useProposalState.ts +48 -0
  358. package/src/hooks/governance/useProposalTimelockState.ts +61 -0
  359. package/src/hooks/governance/useQuorum.ts +42 -0
  360. package/src/hooks/honey/useCappedGlobally.ts +92 -0
  361. package/src/hooks/honey/useCappedRelatively.ts +88 -0
  362. package/src/hooks/honey/useCollateralWeights.ts +48 -0
  363. package/src/hooks/honey/useHoneyAlerts.ts +314 -0
  364. package/src/hooks/honey/useHoneyBalances.ts +79 -0
  365. package/src/hooks/honey/useHoneyChartData.ts +17 -0
  366. package/src/hooks/honey/useHoneyGlobalData.ts +22 -0
  367. package/src/hooks/honey/useHoneySwapState.ts +202 -0
  368. package/src/hooks/honey/useHoneyVaultsBalance.ts +41 -0
  369. package/src/hooks/honey/useIsBadCollateralAsset.ts +73 -0
  370. package/src/hooks/honey/useIsBasketModeEnabled.ts +70 -0
  371. package/src/hooks/honey/usePythLatestPrices.ts +41 -0
  372. package/src/hooks/index.ts +124 -0
  373. package/src/hooks/perps/usePythUpdateFee.ts +43 -0
  374. package/src/hooks/pol/useBgtAprSimulation.ts +22 -0
  375. package/src/hooks/pol/useBgtUnstakedBalance.ts +50 -0
  376. package/src/hooks/pol/useClaimableFees.ts +38 -0
  377. package/src/hooks/pol/useEarnedStakedBeraVault.ts +59 -0
  378. package/src/hooks/pol/useHighestVaultsAPR.ts +57 -0
  379. package/src/hooks/pol/useOnChainRewardVault.ts +114 -0
  380. package/src/hooks/pol/usePollGlobalData.ts +31 -0
  381. package/src/hooks/pol/usePollMarkets.ts +32 -0
  382. package/src/hooks/pol/useQueuedBeraUnlock.ts +70 -0
  383. package/src/hooks/pol/useRewardTokenToBeraRate.ts +45 -0
  384. package/src/hooks/pol/useRewardVault.ts +51 -0
  385. package/src/hooks/pol/useRewardVaultBalanceFromStakingToken.ts +82 -0
  386. package/src/hooks/pol/useRewardVaultFromToken.ts +58 -0
  387. package/src/hooks/pol/useRewardVaultIncentives.ts +37 -0
  388. package/src/hooks/pol/useRewardVaultRewards.ts +37 -0
  389. package/src/hooks/pol/useRewardVaults.ts +45 -0
  390. package/src/hooks/pol/useStakedBeraSnapshots.ts +27 -0
  391. package/src/hooks/pol/useUserVaultInfo.ts +46 -0
  392. package/src/hooks/pol/useUserVaults.ts +40 -0
  393. package/src/hooks/pol/useVaultAddress.ts +31 -0
  394. package/src/hooks/pol/useVaultHistory.ts +29 -0
  395. package/src/hooks/pol/useVaultValidators.ts +33 -0
  396. package/src/hooks/tokens/useBeraCurrentPrice.ts +12 -0
  397. package/src/hooks/tokens/useMultipleTokenInformation.ts +62 -0
  398. package/src/hooks/tokens/usePollAllowances.ts +60 -0
  399. package/src/hooks/tokens/usePollBalance.ts +113 -0
  400. package/src/hooks/tokens/usePollWalletBalances.ts +75 -0
  401. package/src/hooks/tokens/useStakingTokenInformation.ts +54 -0
  402. package/src/hooks/tokens/useTokenCurrentPrice.ts +19 -0
  403. package/src/hooks/tokens/useTokenCurrentPrices.ts +57 -0
  404. package/src/hooks/tokens/useTokenInformation.ts +59 -0
  405. package/src/hooks/tokens/useTokens.ts +26 -0
  406. package/src/hooks/tokens/useTotalSupply.ts +22 -0
  407. package/src/hooks/transactions/TransactionStoreContext.tsx +59 -0
  408. package/src/hooks/transactions/transactionStore.ts +275 -0
  409. package/src/hooks/transactions/transactionStore.unit.test.ts +508 -0
  410. package/src/hooks/transactions/useAddRecentTransaction.ts +29 -0
  411. package/src/hooks/transactions/useRecentTransactions.ts +27 -0
  412. package/src/hooks/useBlockToTimestamp.ts +51 -0
  413. package/src/hooks/useContractWrite/index.ts +2 -0
  414. package/src/hooks/useContractWrite/stateReducer.ts +60 -0
  415. package/src/hooks/useContractWrite/types.ts +88 -0
  416. package/src/hooks/useContractWrite/useBeraContractWrite.ts +137 -0
  417. package/src/hooks/useGetVerifiedAbi.ts +47 -0
  418. package/src/hooks/useHistoryState.ts +64 -0
  419. package/src/hooks/usePrevious.ts +13 -0
  420. package/src/hooks/validators/useAllValidators.ts +48 -0
  421. package/src/hooks/validators/useApiEnrichedAllocation.ts +17 -0
  422. package/src/hooks/validators/useApiValidator.ts +37 -0
  423. package/src/hooks/validators/useBaselineRewardAllocation.ts +16 -0
  424. package/src/hooks/validators/useDailyValidatorBlockStats.ts +35 -0
  425. package/src/hooks/validators/useDefaultRewardAllocation.ts +32 -0
  426. package/src/hooks/validators/useManagedValidatorByAccount.ts +40 -0
  427. package/src/hooks/validators/useManagedValidatorRole.ts +119 -0
  428. package/src/hooks/validators/useOnChainValidator.ts +66 -0
  429. package/src/hooks/validators/useStakingPoolBatch.ts +45 -0
  430. package/src/hooks/validators/useSubgraphUserValidators.ts +36 -0
  431. package/src/hooks/validators/useUserActiveValidators.ts +44 -0
  432. package/src/hooks/validators/useUserBoostsOnValidator.ts +45 -0
  433. package/src/hooks/validators/useUserClaimableIncentives.ts +149 -0
  434. package/src/hooks/validators/useUserStakingPositions.ts +62 -0
  435. package/src/hooks/validators/useValidator.ts +83 -0
  436. package/src/hooks/validators/useValidatorAnalytics.ts +36 -0
  437. package/src/hooks/validators/useValidatorCommission.ts +36 -0
  438. package/src/hooks/validators/useValidatorEstimatedBgtPerYear.ts +24 -0
  439. package/src/hooks/validators/useValidatorQueuedCommission.ts +41 -0
  440. package/src/hooks/validators/useValidatorQueuedOperatorAddress.ts +39 -0
  441. package/src/hooks/validators/useValidatorQueuedRewardAllocation.ts +37 -0
  442. package/src/hooks/validators/useValidatorRewardAllocation.ts +36 -0
  443. package/src/hooks/validators/validatorRoleManager.ts +0 -0
  444. package/src/types/bribe-boost.ts +50 -0
  445. package/src/types/dex.ts +196 -0
  446. package/src/types/enso.ts +42 -0
  447. package/src/types/global.ts +230 -0
  448. package/src/types/governance.ts +174 -0
  449. package/src/types/honeySwap.ts +35 -0
  450. package/src/types/index.ts +8 -0
  451. package/src/types/pol.ts +52 -0
  452. package/src/types/staking.ts +7 -0
  453. package/src/utils/beraFetch.ts +55 -0
  454. package/src/utils/constants.ts +35 -0
  455. package/src/utils/formatAggregatorsQuotes.ts +57 -0
  456. package/src/utils/formatAggregatorsQuotes.unit.test.ts +191 -0
  457. package/src/utils/formatIncentivesTokenMap.ts +19 -0
  458. package/src/utils/formatInputTokenValue.ts +12 -0
  459. package/src/utils/formatNumber.ts +225 -0
  460. package/src/utils/formatNumber.unit.test.ts +245 -0
  461. package/src/utils/formatTimestamps.ts +155 -0
  462. package/src/utils/formatTimestamps.unit.test.ts +395 -0
  463. package/src/utils/formatTokenList.ts +61 -0
  464. package/src/utils/formatUsd.ts +46 -0
  465. package/src/utils/getContractName.ts +27 -0
  466. package/src/utils/getContractName.unit.test.ts +64 -0
  467. package/src/utils/getErrorResponse.ts +20 -0
  468. package/src/utils/getHoneySwapMessage.test.ts +116 -0
  469. package/src/utils/getHoneySwapMessage.ts +70 -0
  470. package/src/utils/getServerSideClient.ts +49 -0
  471. package/src/utils/getTestClient.ts +19 -0
  472. package/src/utils/hasAnyTruthyValues.ts +17 -0
  473. package/src/utils/index.ts +27 -0
  474. package/src/utils/isDifferenceExceedingThreshold.ts +13 -0
  475. package/src/utils/isSubgraphStale.ts +10 -0
  476. package/src/utils/math.ts +28 -0
  477. package/src/utils/math.unit.test.ts +49 -0
  478. package/src/utils/parseBaseArgs.ts +23 -0
  479. package/src/utils/parseBaseArgs.unit.test.ts +55 -0
  480. package/src/utils/poolNamings.ts +54 -0
  481. package/src/utils/pythHoneyUtils.ts +3 -0
  482. package/src/utils/sentryBeforeSend.ts +52 -0
  483. package/src/utils/test-utils.ts +2 -0
  484. package/src/utils/time.ts +106 -0
  485. package/src/utils/time.unit.test.ts +76 -0
  486. package/src/utils/tokenWrapping.ts +16 -0
  487. package/src/utils/tokens.ts +106 -0
  488. package/src/utils/tokens.unit.test.ts +98 -0
  489. package/src/utils/truncateHash.ts +20 -0
  490. package/src/utils/truncateHash.unit.test.ts +19 -0
  491. package/src/utils/validatorUptimeStatus.ts +30 -0
  492. package/dist/chunk-3V2MGZRD.mjs +0 -2
  493. package/dist/chunk-4E5JGLUM.cjs +0 -1
  494. package/dist/chunk-AHAZC5K3.mjs +0 -1
  495. package/dist/chunk-ELUMRVNE.mjs +0 -1
  496. package/dist/chunk-JHCSZSJS.mjs +0 -1
  497. package/dist/chunk-KIA6GUIN.cjs +0 -1
  498. package/dist/chunk-LX5CM4Y6.cjs +0 -1
  499. package/dist/chunk-LZPBQLKP.mjs +0 -3
  500. package/dist/chunk-M5BKM52U.cjs +0 -1
  501. package/dist/chunk-MTBICGRP.mjs +0 -1
  502. package/dist/chunk-WDFIETJS.cjs +0 -2
@@ -0,0 +1,78 @@
1
+ import type { BundleAction } from "@ensofinance/sdk";
2
+ import { ethAddress, zeroAddress } from "viem";
3
+
4
+ import { InvalidArgumentError } from "~/errors/InvalidArgumentError";
5
+ import type {
6
+ GetZapTransactionRequestsArgs,
7
+ GetZapTransactionResponse,
8
+ } from "~/types";
9
+ import { getTransactionsFromBundle } from "./util";
10
+
11
+ export async function getZapTransactionRequests({
12
+ fromAddress,
13
+ amountIn,
14
+ tokenIn,
15
+ tokenOut,
16
+ chainId,
17
+ ensoClient,
18
+ destinationChainId,
19
+ slippage,
20
+ publicClient,
21
+ }: GetZapTransactionRequestsArgs): Promise<GetZapTransactionResponse> {
22
+ if (!fromAddress) {
23
+ throw new InvalidArgumentError({
24
+ property: "fromAddress",
25
+ value: fromAddress,
26
+ expected: "address",
27
+ });
28
+ }
29
+ if (tokenOut === zeroAddress) tokenOut = ethAddress;
30
+
31
+ const bundleAction: BundleAction = {
32
+ protocol: "enso",
33
+ action: "route",
34
+ args: {
35
+ tokenIn,
36
+ tokenOut,
37
+ amountIn,
38
+ slippage: slippage * 100, // Enso expects slippage in basis points
39
+ },
40
+ };
41
+ /**
42
+ * If the zap is cross chain, we need to add the destination chain id and the refund receiver.
43
+ *
44
+ * Enso still need to update the sdk types to support this.
45
+ */
46
+ if (destinationChainId && destinationChainId !== chainId) {
47
+ bundleAction.args = {
48
+ ...bundleAction.args,
49
+ //@ts-expect-error enso are releasing a fix in the next 2 weeks for this.
50
+ destinationChainId: destinationChainId,
51
+ refundReceiver: fromAddress,
52
+ };
53
+ }
54
+
55
+ const bundle = await ensoClient.getBundleData(
56
+ {
57
+ fromAddress: fromAddress,
58
+ receiver: fromAddress,
59
+ spender: fromAddress,
60
+ chainId: chainId,
61
+ routingStrategy: "router",
62
+ },
63
+ [bundleAction],
64
+ );
65
+ const transactions = await getTransactionsFromBundle({
66
+ fromAddress,
67
+ amountIn,
68
+ tokenIn,
69
+ chainId,
70
+ ensoClient,
71
+ bundle,
72
+ publicClient,
73
+ });
74
+ return {
75
+ bundle,
76
+ transactions,
77
+ };
78
+ }
@@ -0,0 +1,108 @@
1
+ import { describe, expect, it } from "vitest";
2
+
3
+ import { parseBaseArgs } from "~/utils/parseBaseArgs";
4
+ import { beraChefAbi } from "../../../abi/pol/beraChef";
5
+ import { ProposalErrorCodes } from "../../../types/governance";
6
+ import { checkProposalField } from "../checkProposalField";
7
+
8
+ describe("checkProposalField", () => {
9
+ const { config } = parseBaseArgs({});
10
+ it("should check invalid address", () => {
11
+ expect(checkProposalField({ fieldOrType: "address", value: "0x123" })).toBe(
12
+ ProposalErrorCodes.INVALID_ADDRESS,
13
+ );
14
+ expect(
15
+ checkProposalField({
16
+ fieldOrType: "address",
17
+ value: config.pol.beraChef,
18
+ }),
19
+ ).toBe(null);
20
+ expect(
21
+ checkProposalField({
22
+ fieldOrType: "address",
23
+ value: config.pol.beraChef.toLowerCase(),
24
+ }),
25
+ ).toBe(null);
26
+ });
27
+
28
+ it.todo("should check invalid hex");
29
+
30
+ it.todo("should check invalid abi");
31
+
32
+ it.todo("should check invalid string");
33
+
34
+ it.todo("should check invalid bool");
35
+
36
+ it.todo("should check invalid action");
37
+
38
+ it.todo("should check invalid title");
39
+
40
+ it.todo("should check invalid forumLink");
41
+
42
+ it.todo("should check invalid description");
43
+
44
+ it.todo("should check invalid logoURI");
45
+
46
+ it.todo("should check invalid url");
47
+
48
+ it("should check invalid amount", () => {
49
+ expect(checkProposalField({ fieldOrType: "uint256", value: "100a0" })).toBe(
50
+ ProposalErrorCodes.INVALID_AMOUNT,
51
+ );
52
+
53
+ expect(
54
+ checkProposalField({ fieldOrType: "uint64", value: "100invalid" }),
55
+ ).toBe(ProposalErrorCodes.INVALID_AMOUNT);
56
+
57
+ expect(checkProposalField({ fieldOrType: "uint64", value: "-100" })).toBe(
58
+ ProposalErrorCodes.NEGATIVE_AMOUNT,
59
+ );
60
+
61
+ expect(checkProposalField({ fieldOrType: "int64", value: "-100" })).toBe(
62
+ null,
63
+ );
64
+
65
+ expect(checkProposalField({ fieldOrType: "uint256", value: "1000" })).toBe(
66
+ null,
67
+ );
68
+ expect(checkProposalField({ fieldOrType: "uint64", value: "1" })).toBe(
69
+ null,
70
+ );
71
+ });
72
+
73
+ it("should check nested fields", () => {
74
+ const abi = beraChefAbi.find(
75
+ (abi) =>
76
+ abi.type === "function" && abi.name === "setDefaultRewardAllocation",
77
+ );
78
+
79
+ if (!abi) {
80
+ throw new Error("BeraChef ABI not found");
81
+ }
82
+
83
+ const error = checkProposalField({
84
+ fieldOrType: abi.inputs[0].type,
85
+ value: {
86
+ startBlock: "0ds",
87
+ weights: [
88
+ {
89
+ receiver: "0x123",
90
+ percentageNumerator: "100a0",
91
+ },
92
+ ],
93
+ },
94
+
95
+ components: abi.inputs[0].components,
96
+ });
97
+
98
+ expect(error).toEqual({
99
+ startBlock: ProposalErrorCodes.INVALID_AMOUNT,
100
+ weights: [
101
+ {
102
+ percentageNumerator: ProposalErrorCodes.INVALID_AMOUNT,
103
+ receiver: ProposalErrorCodes.INVALID_ADDRESS,
104
+ },
105
+ ],
106
+ });
107
+ });
108
+ });
@@ -0,0 +1,127 @@
1
+ import { encodeFunctionData, zeroAddress } from "viem";
2
+ import { describe, expect, it } from "vitest";
3
+
4
+ import { ChainId, defaultChainId } from "@berachain/config/internal";
5
+
6
+ import { beraChefAbi } from "~/abi/pol/beraChef";
7
+ import { getServerSidePublicClient } from "~/utils/getServerSideClient";
8
+ import { parseBaseArgs } from "~/utils/parseBaseArgs";
9
+ import { getDecodedFunctionData } from "../getDecodedFunctionData";
10
+
11
+ describe.skipIf(defaultChainId !== ChainId.MAINNET)(
12
+ "getDecodedFunctionData",
13
+
14
+ async () => {
15
+ const { config: chainConfig, chainId } = parseBaseArgs({});
16
+ const publicClient = getServerSidePublicClient();
17
+ it.concurrent("should match local abi", async () => {
18
+ const calldata = encodeFunctionData({
19
+ abi: beraChefAbi,
20
+ functionName: "isQueuedRewardAllocationReady",
21
+ args: ["0x00", 12345n],
22
+ });
23
+ const data = await getDecodedFunctionData({
24
+ address: zeroAddress,
25
+ publicClient,
26
+ callData: calldata,
27
+ chainId,
28
+ });
29
+
30
+ expect(data.functionSignature).toBe(
31
+ "isQueuedRewardAllocationReady(bytes,uint256)",
32
+ );
33
+ expect(data.abiItem).toBeDefined();
34
+ expect(data.args).toEqual(["0x00", 12345n]);
35
+ expect(data.functionName).toBe("isQueuedRewardAllocationReady");
36
+ });
37
+
38
+ // requires upgrade once we add more ABIs
39
+ it.concurrent(
40
+ "should match remote abi for immutable contract",
41
+ {
42
+ // Fails frequently on CI probably because of connection issues?
43
+ retry: 3,
44
+ },
45
+ async () => {
46
+ // setDefaultFeeBps(10)
47
+ const calldata =
48
+ "0x4488b652000000000000000000000000000000000000000000000000000000000000000a";
49
+ const data = await getDecodedFunctionData({
50
+ address: chainConfig.tokens.wbtc,
51
+ callData: calldata,
52
+ chainId,
53
+ publicClient,
54
+ });
55
+
56
+ expect(data.functionSignature).toBe("setDefaultFeeBps(uint16)");
57
+ expect(data.abiItem).toBeDefined();
58
+ expect(data.args).toEqual([10]);
59
+ expect(data.functionName).toBe("setDefaultFeeBps");
60
+ },
61
+ );
62
+
63
+ // requires upgrade once we add more ABIs
64
+ it.concurrent(
65
+ "should not match remote abi for wrong immutable contract",
66
+ async () => {
67
+ // setDefaultFeeBps(10)
68
+ const calldata =
69
+ "0x4488b652000000000000000000000000000000000000000000000000000000000000000a";
70
+ const data = await getDecodedFunctionData({
71
+ // purposely use a wrong contract, method is from wbtc
72
+ address: chainConfig.tokens.wbera,
73
+ callData: calldata,
74
+ chainId,
75
+ publicClient,
76
+ });
77
+
78
+ expect(data.args).toEqual([]);
79
+ expect(data.functionSignature).toBeUndefined();
80
+ expect(data.abiItem).toBeUndefined();
81
+ expect(data.functionName).toBeUndefined();
82
+ },
83
+ );
84
+
85
+ // requires upgrade once we add more ABIs
86
+ it.concurrent(
87
+ "should match remote abi for upgradeable contract",
88
+ async () => {
89
+ // mint(wbera, 100e18)
90
+ const calldata =
91
+ "0x40c10f1900000000000000000000000069696969696969696969696969696969696969690000000000000000000000000000000000000000000000056bc75e2d63100000";
92
+ const data = await getDecodedFunctionData({
93
+ address: chainConfig.honey.token,
94
+ callData: calldata,
95
+ chainId,
96
+ publicClient,
97
+ });
98
+
99
+ expect(data.functionSignature).toBe("mint(address,uint256)");
100
+ expect(data.abiItem).toBeDefined();
101
+ expect(data.args).toEqual([chainConfig.tokens.wbera, BigInt(100e18)]);
102
+ expect(data.functionName).toBe("mint");
103
+ },
104
+ );
105
+
106
+ // requires upgrade once we add more ABIs
107
+ it.concurrent(
108
+ "should not match remote abi for unverified/non-contract",
109
+ async () => {
110
+ // mint(wbera, 100e18)
111
+ const calldata =
112
+ "0x40c10f1900000000000000000000000069696969696969696969696969696969696969690000000000000000000000000000000000000000000000056bc75e2d63100000";
113
+ const data = await getDecodedFunctionData({
114
+ address: "0x000000000000000000000000000000000000dEaD",
115
+ callData: calldata,
116
+ chainId,
117
+ publicClient,
118
+ });
119
+
120
+ expect(data.args).toEqual([]);
121
+ expect(data.functionSignature).toBeUndefined();
122
+ expect(data.abiItem).toBeUndefined();
123
+ expect(data.functionName).toBeUndefined();
124
+ },
125
+ );
126
+ },
127
+ );
@@ -0,0 +1,39 @@
1
+ import { describe, expect, it } from "vitest";
2
+
3
+ import { ChainId, defaultChainId } from "@berachain/config/internal";
4
+
5
+ import { getServerSidePublicClient } from "~/utils";
6
+ import { getTestClient } from "~/utils/getTestClient";
7
+ import { getQuorum } from "../getQuorum";
8
+
9
+ describe("getQuorum", () => {
10
+ const publicClient = getServerSidePublicClient();
11
+
12
+ const quorums: Record<ChainId, Record<number, string>> = {
13
+ [ChainId.MAINNET]: {
14
+ 1744113202: "1538677.785029999354705024",
15
+ },
16
+ [ChainId.BEPOLIA]: {
17
+ 1748442752: "201123.520829556120148328",
18
+ },
19
+ } as const;
20
+
21
+ it.each(Object.entries(quorums[defaultChainId as ChainId]))(
22
+ "should match the quorum at %s",
23
+ async (at, shouldBe) => {
24
+ const quorum = await getQuorum({ publicClient, at });
25
+ expect(quorum).toBe(shouldBe);
26
+ },
27
+ );
28
+
29
+ it("should have a quorum for the current time", async () => {
30
+ const testClient = getTestClient();
31
+
32
+ await testClient.setNextBlockTimestamp({
33
+ timestamp: BigInt(Math.ceil(Date.now() / 1000)),
34
+ });
35
+
36
+ const quorum = await getQuorum({ publicClient });
37
+ expect(quorum).toBeDefined();
38
+ });
39
+ });
@@ -0,0 +1,211 @@
1
+ import { type AbiParameter, isAddress, isHex } from "viem";
2
+
3
+ import { ProposalErrorCodes } from "~/types";
4
+
5
+ type CheckProposalFieldResultMinimal = ProposalErrorCodes | null;
6
+
7
+ type CheckProposalFieldResult =
8
+ | ProposalErrorCodes
9
+ | null
10
+ | CheckProposalFieldResultMinimal[]
11
+ | Record<string, CheckProposalFieldResultMinimal>;
12
+
13
+ interface CheckProposalField {
14
+ (arg: {
15
+ fieldOrType:
16
+ | "address"
17
+ | "hex"
18
+ | "abi"
19
+ | "string"
20
+ | "bool"
21
+ | `uint${string}`
22
+ | `int${string}`
23
+ | "action"
24
+ | "title"
25
+ | "forumLink"
26
+ | "description"
27
+ | "logoURI"
28
+ | "url";
29
+ value: any;
30
+ required?: boolean;
31
+ baseUrl?: string;
32
+ components?: readonly (AbiParameter | readonly AbiParameter[])[];
33
+ }): CheckProposalFieldResultMinimal;
34
+ (arg: {
35
+ fieldOrType: "tuple[]" | "tuple";
36
+ value: any;
37
+ required?: boolean;
38
+ baseUrl?: string;
39
+ components?: readonly (AbiParameter | readonly AbiParameter[])[];
40
+ }): CheckProposalFieldResult;
41
+ }
42
+ // @ts-expect-error TODO: this is not typed, will throw if not valid
43
+ export const checkProposalField: CheckProposalField = ({
44
+ fieldOrType,
45
+ value,
46
+ required = true,
47
+ baseUrl,
48
+ components,
49
+ }) => {
50
+ const notRequiredAbiTypes = ["bool", "string"];
51
+
52
+ if (
53
+ !notRequiredAbiTypes.includes(fieldOrType) &&
54
+ required &&
55
+ (value === undefined || value === null || value === "")
56
+ ) {
57
+ return ProposalErrorCodes.REQUIRED;
58
+ }
59
+
60
+ if (fieldOrType.startsWith("uint") || fieldOrType.startsWith("int")) {
61
+ if (typeof value !== "string") {
62
+ return ProposalErrorCodes.INVALID_AMOUNT;
63
+ }
64
+
65
+ try {
66
+ const valueBN = BigInt(value);
67
+ if (fieldOrType.startsWith("uint")) {
68
+ if (valueBN < 0n) {
69
+ return ProposalErrorCodes.NEGATIVE_AMOUNT;
70
+ }
71
+ }
72
+ } catch {
73
+ return ProposalErrorCodes.INVALID_AMOUNT;
74
+ }
75
+ return null;
76
+ }
77
+
78
+ switch (fieldOrType) {
79
+ case "string":
80
+ if (value !== undefined && typeof value !== "string") {
81
+ return ProposalErrorCodes.INVALID_AMOUNT;
82
+ }
83
+ return null;
84
+
85
+ case "bool":
86
+ if (typeof value !== "boolean") {
87
+ return ProposalErrorCodes.INVALID_AMOUNT;
88
+ }
89
+ return null;
90
+
91
+ case "title":
92
+ if (value.length === 0) {
93
+ return ProposalErrorCodes.REQUIRED;
94
+ }
95
+ return null;
96
+
97
+ case "description":
98
+ if (value.length === 0) {
99
+ return ProposalErrorCodes.REQUIRED;
100
+ }
101
+ return null;
102
+
103
+ case "forumLink":
104
+ if (value.length === 0) {
105
+ return ProposalErrorCodes.REQUIRED;
106
+ }
107
+
108
+ if (!URL.canParse(value)) {
109
+ return ProposalErrorCodes.INVALID_ADDRESS;
110
+ }
111
+
112
+ // biome-ignore lint/correctness/noSwitchDeclarations: <explanation>
113
+ const base = new URL(baseUrl as string);
114
+
115
+ // base.pathname = "/c/";
116
+
117
+ if (!value.startsWith(base.toString())) {
118
+ return ProposalErrorCodes.INVALID_BASEPATH;
119
+ }
120
+
121
+ return null;
122
+
123
+ case "address":
124
+ if (!isAddress(value, { strict: true })) {
125
+ return ProposalErrorCodes.INVALID_ADDRESS;
126
+ }
127
+
128
+ return null;
129
+
130
+ case "hex":
131
+ if (!isHex(value, { strict: true })) {
132
+ return ProposalErrorCodes.INVALID_ADDRESS;
133
+ }
134
+ return null;
135
+
136
+ case "abi":
137
+ try {
138
+ JSON.parse(value);
139
+ } catch {
140
+ return ProposalErrorCodes.INVALID_ABI;
141
+ }
142
+ return null;
143
+
144
+ case "action":
145
+ if (!isAddress(value, { strict: true })) {
146
+ return ProposalErrorCodes.INVALID_ADDRESS;
147
+ }
148
+ return null;
149
+
150
+ case "tuple":
151
+ if (typeof value === "object" && Array.isArray(components)) {
152
+ const errors: Record<string, ProposalErrorCodes | null> = {};
153
+
154
+ for (const component of components) {
155
+ errors[component.name!] = checkProposalField({
156
+ fieldOrType: component.type,
157
+ value: value[component.name!],
158
+ components: component.components,
159
+ });
160
+ }
161
+
162
+ if (Object.values(errors).every((v) => v === null)) {
163
+ return null;
164
+ }
165
+
166
+ return errors;
167
+ }
168
+
169
+ return null;
170
+
171
+ case "tuple[]":
172
+ if (Array.isArray(value)) {
173
+ const errors = value.map((v) =>
174
+ checkProposalField({
175
+ fieldOrType: "tuple",
176
+ value: v,
177
+ components,
178
+ }),
179
+ );
180
+
181
+ if (errors.every((v) => v === null)) {
182
+ return null;
183
+ }
184
+
185
+ return errors;
186
+ }
187
+
188
+ return null;
189
+ case "logoURI": {
190
+ if (value === undefined || value === "") {
191
+ return null;
192
+ }
193
+ if (URL.canParse(value) && new URL(value).protocol === "https:") {
194
+ return null;
195
+ }
196
+ return ProposalErrorCodes.MUST_BE_HTTPS_OR_IPFS;
197
+ }
198
+ case "url": {
199
+ if (value === undefined || value === "") {
200
+ return null;
201
+ }
202
+ if (URL.canParse(value) && new URL(value).protocol === "https:") {
203
+ return null;
204
+ }
205
+ return ProposalErrorCodes.MUST_BE_HTTPS;
206
+ }
207
+ default:
208
+ console.error(`Invalid field or type: ${fieldOrType}`);
209
+ return null;
210
+ }
211
+ };