@merkl/api 0.10.128 → 0.10.130

Sign up to get free protection for your applications and to get access to all the features.
Files changed (402) hide show
  1. package/dist/database/api/.generated/default.js +1 -0
  2. package/dist/database/api/.generated/edge.js +609 -0
  3. package/dist/database/api/.generated/index-browser.js +586 -0
  4. package/dist/database/api/.generated/index.js +638 -0
  5. package/dist/database/api/.generated/runtime/edge-esm.js +31 -0
  6. package/dist/database/api/.generated/runtime/edge.js +31 -0
  7. package/dist/database/api/.generated/runtime/index-browser.js +13 -0
  8. package/dist/database/api/.generated/runtime/library.js +143 -0
  9. package/dist/database/api/.generated/runtime/react-native.js +80 -0
  10. package/dist/database/api/.generated/runtime/wasm.js +32 -0
  11. package/dist/database/api/.generated/wasm.js +586 -0
  12. package/dist/database/api/seeder/resources/protocol.js +341 -0
  13. package/dist/database/engine/.generated/default.js +1 -0
  14. package/dist/database/engine/.generated/edge.js +438 -0
  15. package/dist/database/engine/.generated/index-browser.js +415 -0
  16. package/dist/database/engine/.generated/index.js +467 -0
  17. package/dist/database/engine/.generated/runtime/edge-esm.js +31 -0
  18. package/dist/database/engine/.generated/runtime/edge.js +31 -0
  19. package/dist/database/engine/.generated/runtime/index-browser.js +13 -0
  20. package/dist/database/engine/.generated/runtime/library.js +143 -0
  21. package/dist/database/engine/.generated/runtime/react-native.js +80 -0
  22. package/dist/database/engine/.generated/runtime/wasm.js +32 -0
  23. package/dist/database/engine/.generated/wasm.js +415 -0
  24. package/dist/node_modules/@elysiajs/eden/eden/LICENSE +7 -0
  25. package/dist/node_modules/@elysiajs/eden/eden/README.md +46 -0
  26. package/dist/node_modules/@elysiajs/eden/eden/bunfig.toml +2 -0
  27. package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-2IHGLN7W.mjs +1 -0
  28. package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-7WO4HTSU.mjs +1 -0
  29. package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-XYW4OUFN.mjs +1 -0
  30. package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-YAG46HFR.mjs +1 -0
  31. package/dist/node_modules/@elysiajs/eden/eden/dist/errors.d.ts +5 -0
  32. package/dist/node_modules/@elysiajs/eden/eden/dist/fetch/index.d.ts +4 -0
  33. package/dist/node_modules/@elysiajs/eden/eden/dist/fetch/types.d.ts +44 -0
  34. package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.d.mts +48 -0
  35. package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.d.ts +48 -0
  36. package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.global.js +1 -0
  37. package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.js +1 -0
  38. package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.mjs +1 -0
  39. package/dist/node_modules/@elysiajs/eden/eden/dist/index.d.mts +5 -0
  40. package/dist/node_modules/@elysiajs/eden/eden/dist/index.d.ts +5 -0
  41. package/dist/node_modules/@elysiajs/eden/eden/dist/index.global.js +1 -0
  42. package/dist/node_modules/@elysiajs/eden/eden/dist/index.js +1 -0
  43. package/dist/node_modules/@elysiajs/eden/eden/dist/index.mjs +1 -0
  44. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty/index.d.ts +17 -0
  45. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty/types.d.ts +99 -0
  46. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty/utils.d.ts +1 -0
  47. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.d.mts +114 -0
  48. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.d.ts +114 -0
  49. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.global.js +1 -0
  50. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.js +1 -0
  51. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.mjs +1 -0
  52. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2/index.d.ts +5 -0
  53. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2/types.d.ts +86 -0
  54. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2/ws.d.ts +14 -0
  55. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.d.mts +103 -0
  56. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.d.ts +103 -0
  57. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.global.js +1 -0
  58. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.js +1 -0
  59. package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.mjs +1 -0
  60. package/dist/node_modules/@elysiajs/eden/eden/dist/types-C41kuZ-K.d.mts +44 -0
  61. package/dist/node_modules/@elysiajs/eden/eden/dist/types-C41kuZ-K.d.ts +44 -0
  62. package/dist/node_modules/@elysiajs/eden/eden/dist/types.d.ts +39 -0
  63. package/dist/node_modules/@elysiajs/eden/eden/dist/utils/parsingUtils.d.ts +6 -0
  64. package/dist/node_modules/@elysiajs/eden/eden/package.json +85 -0
  65. package/dist/package.json +2 -2
  66. package/dist/src/backgroundJobs/index.js +44 -0
  67. package/dist/src/backgroundJobs/jobs/campaignsCacheUpdater.js +160 -0
  68. package/dist/src/backgroundJobs/jobs/health.js +15 -0
  69. package/dist/src/backgroundJobs/jobs/opportunityUpdater.js +63 -0
  70. package/dist/src/backgroundJobs/jobs/priceUpdater.js +16 -0
  71. package/dist/src/backgroundJobs/jobs/sync.js +33 -0
  72. package/dist/src/cache/declaration.js +146 -0
  73. package/dist/src/cache/index.js +152 -0
  74. package/dist/src/cache/redis.js +49 -0
  75. package/dist/src/constants.js +119 -0
  76. package/dist/src/entities/campaign.js +134 -0
  77. package/dist/src/entities/opportunity.js +549 -0
  78. package/dist/src/errors/BadRequest.error.js +7 -0
  79. package/dist/src/errors/Conflict.error.js +7 -0
  80. package/dist/src/errors/HttpError.js +11 -0
  81. package/dist/src/errors/NotFound.error.js +7 -0
  82. package/dist/src/errors/Opportunity.error.js +11 -0
  83. package/dist/src/errors/Unauthorized.error.js +7 -0
  84. package/dist/src/errors/index.js +5 -0
  85. package/dist/src/guards/BackOffice.guard.js +10 -0
  86. package/dist/src/guards/Engine.guard.js +10 -0
  87. package/dist/src/guards/TokenAuth.guard.js +10 -0
  88. package/dist/src/hooks/checkQueryAddressValidity.js +7 -0
  89. package/dist/src/hooks/checkQueryChainIdValidity.js +7 -0
  90. package/dist/src/index.js +79 -0
  91. package/dist/src/internal/controllers/endingCampaigns.js +41 -0
  92. package/dist/src/internal/controllers/unclaimed.js +36 -0
  93. package/dist/src/internal/index.js +30 -0
  94. package/dist/src/libs/campaigns/campaignTypes/AjnaDynamicData.js +111 -0
  95. package/dist/src/libs/campaigns/campaignTypes/BadgerDynamicData.js +93 -0
  96. package/dist/src/libs/campaigns/campaignTypes/CLAMMDynamicData.js +942 -0
  97. package/dist/src/libs/campaigns/campaignTypes/CompoundDynamicData.js +90 -0
  98. package/dist/src/libs/campaigns/campaignTypes/DolomiteDynamicData.js +60 -0
  99. package/dist/src/libs/campaigns/campaignTypes/ERC20DynamicData.js +162 -0
  100. package/dist/src/libs/campaigns/campaignTypes/ERC20DynamicDataRefacto.js +159 -0
  101. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/eulerVaultNames.js +13 -0
  102. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/factoryFinder.js +29 -0
  103. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/getBlacklistedSupply.js +22 -0
  104. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/metamorphoTvl.js +35 -0
  105. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/spliceTVL.js +21 -0
  106. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/tokenType.js +106 -0
  107. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/AaveProcessor.js +26 -0
  108. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/AssetProcessor.js +47 -0
  109. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/AuraProcessor.js +103 -0
  110. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/BalancerGaugeProcessor.js +83 -0
  111. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/BalancerPoolProcessor.js +99 -0
  112. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/BeefyProcessor.js +51 -0
  113. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/CompoundProcessor.js +36 -0
  114. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/EnzymeProcessor.js +51 -0
  115. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/EulerBorrowProcessor.js +46 -0
  116. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/EulerLendProcessor.js +47 -0
  117. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/FluidProcessor.js +36 -0
  118. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/FraxProcessor.js +41 -0
  119. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/GearboxProcessor.js +44 -0
  120. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/GenericProcessor.js +239 -0
  121. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/MetamorphoProcessor.js +43 -0
  122. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/PendleProcessor.js +31 -0
  123. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/RadiantProcessor.js +58 -0
  124. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/RfxProcessor.js +64 -0
  125. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/SpliceProcessor.js +35 -0
  126. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/SturdySiloProcessor.js +37 -0
  127. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/TemplateProcessor.js +40 -0
  128. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/TorosProcessor.js +33 -0
  129. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/UniswapProcessor.js +48 -0
  130. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/WoofiProcessor.js +40 -0
  131. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/curveProcessor.js +68 -0
  132. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/processorMapping.js +77 -0
  133. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesPrices.js +583 -0
  134. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesPricesRefactoFinal.js +24 -0
  135. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound1.js +1209 -0
  136. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound1RefactoFinal.js +194 -0
  137. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound2.js +645 -0
  138. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound2RefactoFinal.js +22 -0
  139. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound3.js +392 -0
  140. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound3RefactoFinal.js +22 -0
  141. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound4.js +323 -0
  142. package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound4RefactoFinal.js +22 -0
  143. package/dist/src/libs/campaigns/campaignTypes/ERC20_SNAPSHOTDynamicData.js +38 -0
  144. package/dist/src/libs/campaigns/campaignTypes/EulerDynamicData.js +165 -0
  145. package/dist/src/libs/campaigns/campaignTypes/JSON_AIRDROPDynamicData.js +19 -0
  146. package/dist/src/libs/campaigns/campaignTypes/MORPHODynamicData.js +120 -0
  147. package/dist/src/libs/campaigns/campaignTypes/RadiantDynamicData.js +112 -0
  148. package/dist/src/libs/campaigns/campaignTypes/SILODynamicData.js +113 -0
  149. package/dist/src/libs/campaigns/campaignsDynamicData.js +83 -0
  150. package/dist/src/libs/campaigns/campaignsDynamicDataRefacto.js +78 -0
  151. package/dist/src/libs/campaigns/getCampaigns.js +18 -0
  152. package/dist/src/libs/campaigns/utils/fetchA51Strategies.js +44 -0
  153. package/dist/src/libs/campaigns/utils/fetchClamInfo.js +27 -0
  154. package/dist/src/libs/campaigns/utils/fetchLogs.js +91 -0
  155. package/dist/src/libs/campaigns/utils/getCompV2ForksVaults.js +122 -0
  156. package/dist/src/libs/campaigns/utils/getContractCreationBlock.js +44 -0
  157. package/dist/src/libs/campaigns/utils/getDolomiteMarkets.js +50 -0
  158. package/dist/src/libs/campaigns/utils/getEulerV2Vaults.js +87 -0
  159. package/dist/src/libs/campaigns/utils/getLastEligibilityRatio.js +56 -0
  160. package/dist/src/libs/computeFee.js +34 -0
  161. package/dist/src/libs/custom/twtParticipants.js +54 -0
  162. package/dist/src/libs/deprecated-merklv3/index.js +184 -0
  163. package/dist/src/libs/getTokensList.js +37 -0
  164. package/dist/src/libs/merklChainData.js +129 -0
  165. package/dist/src/libs/parse/marketsWithCache.js +8 -0
  166. package/dist/src/libs/positions/ajna/index.js +107 -0
  167. package/dist/src/libs/positions/badger/index.js +79 -0
  168. package/dist/src/libs/positions/clamm/index.js +419 -0
  169. package/dist/src/libs/positions/clamm/thegraph/fetchAlmPositions.js +35 -0
  170. package/dist/src/libs/positions/clamm/thegraph/fetchAmmPositions.js +35 -0
  171. package/dist/src/libs/positions/clamm/thegraph/fetchFarmedPositions.js +44 -0
  172. package/dist/src/libs/positions/clamm/thegraph/index.js +162 -0
  173. package/dist/src/libs/positions/compound/index.js +93 -0
  174. package/dist/src/libs/positions/dolomite/index.js +49 -0
  175. package/dist/src/libs/positions/erc20/index.js +55 -0
  176. package/dist/src/libs/positions/euler/index.js +57 -0
  177. package/dist/src/libs/positions/index.js +48 -0
  178. package/dist/src/libs/positions/morpho/index.js +177 -0
  179. package/dist/src/libs/positions/prepareFetch.js +339 -0
  180. package/dist/src/libs/positions/silo/index.js +67 -0
  181. package/dist/src/libs/positions/types.js +1 -0
  182. package/dist/src/libs/reports/campaignReport.js +37 -0
  183. package/dist/src/libs/reports/mainParameterRewards.js +48 -0
  184. package/dist/src/libs/rewards/userRewards.js +154 -0
  185. package/dist/src/libs/staticCampaigns.js +10 -0
  186. package/dist/src/libs/tokens/balances.js +126 -0
  187. package/dist/src/libs/tokens/tokenInfo.js +22 -0
  188. package/dist/src/modules/v4/accounting/accounting.controller.js +66 -0
  189. package/dist/src/modules/v4/accounting/accounting.model.js +32 -0
  190. package/dist/src/modules/v4/accounting/accounting.repository.js +100 -0
  191. package/dist/src/modules/v4/accounting/accounting.service.js +78 -0
  192. package/dist/src/modules/v4/accounting/index.js +3 -0
  193. package/dist/src/modules/v4/apr/apr.controller.js +1 -0
  194. package/dist/src/modules/v4/apr/apr.model.js +1 -0
  195. package/dist/src/modules/v4/apr/apr.repository.js +1 -0
  196. package/dist/src/modules/v4/apr/apr.service.js +40 -0
  197. package/dist/src/modules/v4/apr/index.js +2 -0
  198. package/dist/src/modules/v4/blacklist/blacklist.controller.js +45 -0
  199. package/dist/src/modules/v4/blacklist/blacklist.model.js +13 -0
  200. package/dist/src/modules/v4/blacklist/blacklist.repository.js +56 -0
  201. package/dist/src/modules/v4/blacklist/blacklist.service.js +24 -0
  202. package/dist/src/modules/v4/blacklist/index.js +3 -0
  203. package/dist/src/modules/v4/cache/cache.model.js +14 -0
  204. package/dist/src/modules/v4/cache/cache.repository.js +10 -0
  205. package/dist/src/modules/v4/cache/cache.service.js +44 -0
  206. package/dist/src/modules/v4/cache/index.js +1 -0
  207. package/dist/src/modules/v4/campaign/campaign.controller.js +56 -0
  208. package/dist/src/modules/v4/campaign/campaign.model.js +54 -0
  209. package/dist/src/modules/v4/campaign/campaign.repository.js +346 -0
  210. package/dist/src/modules/v4/campaign/campaign.service.js +203 -0
  211. package/dist/src/modules/v4/campaign/index.js +3 -0
  212. package/dist/src/modules/v4/chain/chain.controller.js +40 -0
  213. package/dist/src/modules/v4/chain/chain.model.js +17 -0
  214. package/dist/src/modules/v4/chain/chain.repository.js +64 -0
  215. package/dist/src/modules/v4/chain/chain.service.js +42 -0
  216. package/dist/src/modules/v4/chain/index.js +3 -0
  217. package/dist/src/modules/v4/dynamicData/dynamicData.controller.js +19 -0
  218. package/dist/src/modules/v4/dynamicData/dynamicData.model.js +6 -0
  219. package/dist/src/modules/v4/dynamicData/dynamicData.repository.js +1 -0
  220. package/dist/src/modules/v4/dynamicData/dynamicData.service.js +49 -0
  221. package/dist/src/modules/v4/dynamicData/index.js +3 -0
  222. package/dist/src/modules/v4/enso/enso.model.js +108 -0
  223. package/dist/src/modules/v4/enso/enso.service.js +46 -0
  224. package/dist/src/modules/v4/explorer/explorer.model.js +2 -0
  225. package/dist/src/modules/v4/explorer/explorer.repository.js +23 -0
  226. package/dist/src/modules/v4/explorer/explorer.service.js +24 -0
  227. package/dist/src/modules/v4/explorer/index.js +1 -0
  228. package/dist/src/modules/v4/index.js +4 -0
  229. package/dist/src/modules/v4/merklRoot/index.js +3 -0
  230. package/dist/src/modules/v4/merklRoot/merklRoot.controller.js +19 -0
  231. package/dist/src/modules/v4/merklRoot/merklRoot.model.js +6 -0
  232. package/dist/src/modules/v4/merklRoot/merklRoot.repository.js +31 -0
  233. package/dist/src/modules/v4/merklRoot/merklRoot.service.js +38 -0
  234. package/dist/src/modules/v4/opportunity/index.js +3 -0
  235. package/dist/src/modules/v4/opportunity/opportunity.controller.js +69 -0
  236. package/dist/src/modules/v4/opportunity/opportunity.model.js +36 -0
  237. package/dist/src/modules/v4/opportunity/opportunity.repository.d.ts +14 -0
  238. package/dist/src/modules/v4/opportunity/opportunity.repository.js +217 -0
  239. package/dist/src/modules/v4/opportunity/opportunity.service.d.ts +0 -15
  240. package/dist/src/modules/v4/opportunity/opportunity.service.js +180 -0
  241. package/dist/src/modules/v4/opportunity/subservices/getAjnaMetadata.service.js +50 -0
  242. package/dist/src/modules/v4/opportunity/subservices/getBadgerMetadata.service.js +23 -0
  243. package/dist/src/modules/v4/opportunity/subservices/getClammMetadata.service.js +33 -0
  244. package/dist/src/modules/v4/opportunity/subservices/getCompoundMetadata.service.js +18 -0
  245. package/dist/src/modules/v4/opportunity/subservices/getDolomiteMetadata.service.js +15 -0
  246. package/dist/src/modules/v4/opportunity/subservices/getErc20Metadata.service.js +63 -0
  247. package/dist/src/modules/v4/opportunity/subservices/getErc20SnapshotMetadata.service.js +8 -0
  248. package/dist/src/modules/v4/opportunity/subservices/getEulerMetadata.service.js +30 -0
  249. package/dist/src/modules/v4/opportunity/subservices/getJsonAirDropMetadata.service.js +36 -0
  250. package/dist/src/modules/v4/opportunity/subservices/getMorphoMetadata.service.js +19 -0
  251. package/dist/src/modules/v4/opportunity/subservices/getRadiantMetadata.service.js +9 -0
  252. package/dist/src/modules/v4/opportunity/subservices/getSiloMetadata.service.js +13 -0
  253. package/dist/src/modules/v4/opportunity/transform-id.pipe.js +6 -0
  254. package/dist/src/modules/v4/opportunity/validate-id.pipe.js +12 -0
  255. package/dist/src/modules/v4/participate/participate.controller.js +66 -0
  256. package/dist/src/modules/v4/participate/participate.model.js +24 -0
  257. package/dist/src/modules/v4/participate/participate.service.js +33 -0
  258. package/dist/src/modules/v4/price/index.js +3 -0
  259. package/dist/src/modules/v4/price/price.controller.js +62 -0
  260. package/dist/src/modules/v4/price/price.model.js +12 -0
  261. package/dist/src/modules/v4/price/price.repository.js +18 -0
  262. package/dist/src/modules/v4/price/price.service.js +44 -0
  263. package/dist/src/modules/v4/prisma/index.js +1 -0
  264. package/dist/src/modules/v4/protocol/index.js +3 -0
  265. package/dist/src/modules/v4/protocol/protocol.controller.js +23 -0
  266. package/dist/src/modules/v4/protocol/protocol.model.js +68 -0
  267. package/dist/src/modules/v4/protocol/protocol.repository.js +37 -0
  268. package/dist/src/modules/v4/protocol/protocol.service.js +77 -0
  269. package/dist/src/modules/v4/reward/index.js +3 -0
  270. package/dist/src/modules/v4/reward/reward.controller.js +52 -0
  271. package/dist/src/modules/v4/reward/reward.model.js +104 -0
  272. package/dist/src/modules/v4/reward/reward.repository.js +237 -0
  273. package/dist/src/modules/v4/reward/reward.service.js +283 -0
  274. package/dist/src/modules/v4/reward/rewardConvertor.service.js +136 -0
  275. package/dist/src/modules/v4/router.js +57 -0
  276. package/dist/src/modules/v4/status/index.js +3 -0
  277. package/dist/src/modules/v4/status/status.controller.js +48 -0
  278. package/dist/src/modules/v4/status/status.model.js +24 -0
  279. package/dist/src/modules/v4/status/status.repository.js +88 -0
  280. package/dist/src/modules/v4/status/status.service.js +60 -0
  281. package/dist/src/modules/v4/token/index.js +3 -0
  282. package/dist/src/modules/v4/token/token.controller.js +32 -0
  283. package/dist/src/modules/v4/token/token.model.js +23 -0
  284. package/dist/src/modules/v4/token/token.repository.js +128 -0
  285. package/dist/src/modules/v4/token/token.service.js +268 -0
  286. package/dist/src/modules/v4/tvl/index.js +2 -0
  287. package/dist/src/modules/v4/tvl/tvl.controller.js +1 -0
  288. package/dist/src/modules/v4/tvl/tvl.model.js +1 -0
  289. package/dist/src/modules/v4/tvl/tvl.repository.js +1 -0
  290. package/dist/src/modules/v4/tvl/tvl.service.js +49 -0
  291. package/dist/src/modules/v4/uniswapV4/index.js +4 -0
  292. package/dist/src/modules/v4/uniswapV4/uniswapV4.controller.js +11 -0
  293. package/dist/src/modules/v4/uniswapV4/uniswapV4.model.js +17 -0
  294. package/dist/src/modules/v4/uniswapV4/uniswapV4.repository.js +2 -0
  295. package/dist/src/modules/v4/uniswapV4/uniswapV4.service.js +73 -0
  296. package/dist/src/modules/v4/user/index.js +3 -0
  297. package/dist/src/modules/v4/user/user.controller.js +69 -0
  298. package/dist/src/modules/v4/user/user.model.js +18 -0
  299. package/dist/src/modules/v4/user/user.repository.js +38 -0
  300. package/dist/src/modules/v4/user/user.service.js +50 -0
  301. package/dist/src/plugins/error-handling.plugin.js +28 -0
  302. package/dist/src/plugins/logger.plugin.js +22 -0
  303. package/dist/src/routes/v1/allowances.js +115 -0
  304. package/dist/src/routes/v1/balances.js +25 -0
  305. package/dist/src/routes/v1/prices.js +11 -0
  306. package/dist/src/routes/v1/tokens.js +17 -0
  307. package/dist/src/routes/v2/merkl.js +13 -0
  308. package/dist/src/routes/v3/ERC20Campaigns.js +63 -0
  309. package/dist/src/routes/v3/app.js +18 -0
  310. package/dist/src/routes/v3/blacklist.js +18 -0
  311. package/dist/src/routes/v3/campaign/delay.js +78 -0
  312. package/dist/src/routes/v3/campaignClaims.js +24 -0
  313. package/dist/src/routes/v3/campaignReport.js +22 -0
  314. package/dist/src/routes/v3/campaignUnclaimed.js +28 -0
  315. package/dist/src/routes/v3/campaigns.js +101 -0
  316. package/dist/src/routes/v3/campaignsForMainParameter.js +19 -0
  317. package/dist/src/routes/v3/campaignsInfo.js +54 -0
  318. package/dist/src/routes/v3/campaignsRewardsReport.js +47 -0
  319. package/dist/src/routes/v3/claims.js +45 -0
  320. package/dist/src/routes/v3/compoundV2.js +9 -0
  321. package/dist/src/routes/v3/createCampaign.js +66 -0
  322. package/dist/src/routes/v3/dolomite.js +9 -0
  323. package/dist/src/routes/v3/euler.js +9 -0
  324. package/dist/src/routes/v3/exports/campaigns.js +28 -0
  325. package/dist/src/routes/v3/fetch.js +27 -0
  326. package/dist/src/routes/v3/health.js +13 -0
  327. package/dist/src/routes/v3/lostyield.js +98 -0
  328. package/dist/src/routes/v3/merkl.js +119 -0
  329. package/dist/src/routes/v3/morphoMarkets.js +27 -0
  330. package/dist/src/routes/v3/morphoVaults.js +22 -0
  331. package/dist/src/routes/v3/multiChainPositions.js +69 -0
  332. package/dist/src/routes/v3/opportunity.js +63 -0
  333. package/dist/src/routes/v3/overview.js +73 -0
  334. package/dist/src/routes/v3/parse.js +23 -0
  335. package/dist/src/routes/v3/payload.js +40 -0
  336. package/dist/src/routes/v3/poolInfo.js +88 -0
  337. package/dist/src/routes/v3/positions.js +62 -0
  338. package/dist/src/routes/v3/radiant.js +26 -0
  339. package/dist/src/routes/v3/recipients.js +20 -0
  340. package/dist/src/routes/v3/rewards.js +33 -0
  341. package/dist/src/routes/v3/rewardsReport.js +51 -0
  342. package/dist/src/routes/v3/rootForTimestamp.js +47 -0
  343. package/dist/src/routes/v3/silo.js +20 -0
  344. package/dist/src/routes/v3/token.js +24 -0
  345. package/dist/src/routes/v3/tokenUnclaimed.js +24 -0
  346. package/dist/src/routes/v3/twt/participants.js +11 -0
  347. package/dist/src/routes/v3/updates.js +47 -0
  348. package/dist/src/routes/v3/userRewards.js +59 -0
  349. package/dist/src/types/index.js +6 -0
  350. package/dist/src/types/parameters/Action.js +11 -0
  351. package/dist/src/types/parameters/Chain.js +13 -0
  352. package/dist/src/types/parameters/ChainCampaignId.js +13 -0
  353. package/dist/src/types/parameters/MainParameter.js +19 -0
  354. package/dist/src/types/parameters/OpportunityId.js +14 -0
  355. package/dist/src/types/parameters/Timestamp.js +16 -0
  356. package/dist/src/types/parameters/Type.js +15 -0
  357. package/dist/src/types/parameters/index.js +17 -0
  358. package/dist/src/types/returnTypes.js +1 -0
  359. package/dist/src/types/utils.js +1 -0
  360. package/dist/src/utils/addString.js +6 -0
  361. package/dist/src/utils/bigintToString.js +20 -0
  362. package/dist/src/utils/crypto.js +4 -0
  363. package/dist/src/utils/decodeCalls.js +170 -0
  364. package/dist/src/utils/encodeCalls.js +240 -0
  365. package/dist/src/utils/error.js +90 -0
  366. package/dist/src/utils/execute.js +41 -0
  367. package/dist/src/utils/generateCardName.js +89 -0
  368. package/dist/src/utils/generic.js +117 -0
  369. package/dist/src/utils/hashArray.js +4 -0
  370. package/dist/src/utils/lastBlockBefore.js +78 -0
  371. package/dist/src/utils/logger.js +52 -0
  372. package/dist/src/utils/pricer.js +180 -0
  373. package/dist/src/utils/prices/chainlinkRead.js +8 -0
  374. package/dist/src/utils/prices/curveVirtualPrice.js +7 -0
  375. package/dist/src/utils/prices/getDQUICK.js +8 -0
  376. package/dist/src/utils/prices/priceFetcherFactory.js +29 -0
  377. package/dist/src/utils/prices/priceService.js +328 -0
  378. package/dist/src/utils/prices/services/coinGeckoService.js +53 -0
  379. package/dist/src/utils/prices/services/defillamaService.js +53 -0
  380. package/dist/src/utils/prices/services/dexScreenerService.js +62 -0
  381. package/dist/src/utils/prices/services/erc4626Service.js +30 -0
  382. package/dist/src/utils/prices/services/getERC4626.js +11 -0
  383. package/dist/src/utils/prices/services/indexCoopService.js +55 -0
  384. package/dist/src/utils/prices/services/priceFetcher.js +1 -0
  385. package/dist/src/utils/prices/uniV2Price.js +40 -0
  386. package/dist/src/utils/prisma.js +12 -0
  387. package/dist/src/utils/providers.js +30 -0
  388. package/dist/src/utils/queries/activeCampaigns.js +22 -0
  389. package/dist/src/utils/queries/allCampaigns.js +51 -0
  390. package/dist/src/utils/queries/campaignsForMainParameter.js +23 -0
  391. package/dist/src/utils/queries/claimsOverTime.js +111 -0
  392. package/dist/src/utils/queries/endingCampaigns.js +21 -0
  393. package/dist/src/utils/queries/futureCampaigns.js +19 -0
  394. package/dist/src/utils/queries/mainParameterCampaigns.js +11 -0
  395. package/dist/src/utils/queries/rewardsAmount.js +106 -0
  396. package/dist/src/utils/queries/unclaimed.js +81 -0
  397. package/dist/src/utils/rateLimit.js +13 -0
  398. package/dist/src/utils/stryke.js +4 -0
  399. package/dist/src/utils/throw.js +27 -0
  400. package/dist/src/utils/validation.js +20 -0
  401. package/dist/tsconfig.package.tsbuildinfo +1 -1
  402. package/package.json +2 -2
@@ -0,0 +1,419 @@
1
+ import { ALM, AMMAlgorithmMapping, BN2Number, NETWORK_LABELS, NFTManagerAddress, NonFungiblePositionManagerInterface, PoolInterface, PoolState, SqrtPrice, YEAR, getAmountsForLiquidity, getSupportedNFPWrapperMapping, getTickAtSqrtRatio, spNFTInterface, } from "@sdk";
2
+ import { BigNumber, Contract, utils } from "ethers";
3
+ import JSBI from "jsbi";
4
+ import { log } from "../../../utils/logger";
5
+ import { Pricer } from "../../../utils/pricer";
6
+ import { providers } from "../../../utils/providers";
7
+ import { fetchAlmPositionsV2 } from "./thegraph/fetchAlmPositions";
8
+ import { fetchAmmPositionsV2 } from "./thegraph/fetchAmmPositions";
9
+ import { fetchFarmedPositionsV2WithCache } from "./thegraph/fetchFarmedPositions";
10
+ export async function getClammUserPositions(user, chainId, poolsByAmm) {
11
+ const pricer = await Pricer.load();
12
+ /**
13
+ * Fetch user positions
14
+ */
15
+ const promisePositions = [
16
+ fetchAmmPositionsV2(chainId, user, (!!poolsByAmm ? Object.keys(poolsByAmm) : [])),
17
+ fetchAlmPositionsV2(chainId, user),
18
+ ];
19
+ /**
20
+ * Per pool mapping to store all ids of positions that were wrapped into a farm
21
+ * @notice see line 110 for more context
22
+ */
23
+ const farmedTokenIds = {};
24
+ const calls = [];
25
+ const callsByAmm = {};
26
+ let startingIndex = 0;
27
+ /** Add on onchain calls at the pool level */
28
+ if (!!poolsByAmm) {
29
+ for (const [amm, poolDatas] of Object.entries(poolsByAmm)) {
30
+ const pools = Object.keys(poolDatas);
31
+ if (!callsByAmm[amm]) {
32
+ callsByAmm[amm] = {
33
+ start: startingIndex,
34
+ poolCalls: pools.length,
35
+ wrapperCalls: {},
36
+ };
37
+ }
38
+ for (const pool of pools) {
39
+ calls.push({
40
+ allowFailure: true,
41
+ callData: PoolInterface[AMMAlgorithmMapping[amm]].encodeFunctionData(PoolState[AMMAlgorithmMapping[amm]]),
42
+ target: pool,
43
+ });
44
+ startingIndex++;
45
+ }
46
+ if (getSupportedNFPWrapperMapping(chainId, amm).length > 0) {
47
+ farmedTokenIds[amm] = (await fetchFarmedPositionsV2WithCache(chainId, [user], Number(amm)));
48
+ }
49
+ for (const wrapper of getSupportedNFPWrapperMapping(chainId, amm)) {
50
+ if (!!farmedTokenIds &&
51
+ !!farmedTokenIds?.[amm] &&
52
+ !!farmedTokenIds?.[amm]?.[wrapper] &&
53
+ farmedTokenIds?.[amm]?.[wrapper].length > 0) {
54
+ if (!callsByAmm[amm].wrapperCalls[wrapper]) {
55
+ callsByAmm[amm].wrapperCalls[wrapper] = 0;
56
+ }
57
+ farmedTokenIds?.[amm]?.[wrapper]
58
+ ?.map((pos) => pos.id)
59
+ ?.forEach((tokenId) => {
60
+ calls.push({
61
+ allowFailure: true,
62
+ callData: NonFungiblePositionManagerInterface[AMMAlgorithmMapping[amm]].encodeFunctionData("positions", [tokenId]),
63
+ target: NFTManagerAddress[chainId][amm],
64
+ });
65
+ callsByAmm[amm].wrapperCalls[wrapper]++;
66
+ startingIndex++;
67
+ });
68
+ }
69
+ }
70
+ }
71
+ }
72
+ // Calls
73
+ // all pool calls
74
+ // all NonFungiblePositionManagerInterface calls by wrapper
75
+ return {
76
+ cached: false,
77
+ call: {
78
+ callData: calls,
79
+ handler: () => { },
80
+ reducer: async (result) => {
81
+ const [promisePosition, promiseALMPosition] = await Promise.all(promisePositions);
82
+ const positions = Object.values((await Promise.resolve(promisePosition))).reduce((acc, val) => {
83
+ return acc.concat(val.nft).concat(val.direct);
84
+ }, []);
85
+ /** Fill user positions */
86
+ const finalRes = {};
87
+ if (!!poolsByAmm) {
88
+ for (const [amm, poolDatas] of Object.entries(poolsByAmm)) {
89
+ const pools = Object.keys(poolDatas);
90
+ let i = callsByAmm[amm].start;
91
+ for (const p of pools) {
92
+ try {
93
+ const res = {
94
+ userPositions: [],
95
+ apr: {},
96
+ };
97
+ const updateUserPosition = (x) => {
98
+ res.userPositions?.push(x);
99
+ // Update global data logic
100
+ res.userTVL += x.tvl ?? 0;
101
+ res.userBalanceToken0 += x.balance0 ?? 0;
102
+ res.userBalanceToken1 += x.balance1 ?? 0;
103
+ res.userTotalLiquidity += x.totalLiquidity ?? 0;
104
+ res.userInRangeLiquidity += x.inRangeLiquidity ?? 0;
105
+ };
106
+ const sqrtPriceX96 = PoolInterface[AMMAlgorithmMapping[amm]]
107
+ .decodeFunctionResult(PoolState[AMMAlgorithmMapping[amm]], result[i++])[SqrtPrice[AMMAlgorithmMapping[amm]]].toString();
108
+ res.tick = getTickAtSqrtRatio(JSBI.BigInt(sqrtPriceX96));
109
+ res.userTVL = 0;
110
+ res.userBalanceToken0 = 0;
111
+ res.userBalanceToken1 = 0;
112
+ res.userTotalLiquidity = 0;
113
+ res.userInRangeLiquidity = 0;
114
+ const priceToken0 = (await pricer.get({
115
+ address: poolDatas[p].token0,
116
+ chainId,
117
+ symbol: poolDatas[p].symbolToken0,
118
+ }));
119
+ const priceToken1 = (await pricer.get({
120
+ address: poolDatas[p].token1,
121
+ chainId,
122
+ symbol: poolDatas[p].symbolToken1,
123
+ }));
124
+ /** 1_ User Liquidity Positions */
125
+ const userNonALMPositions = positions?.filter((x) => utils.getAddress(x.pool.id) === utils.getAddress(p));
126
+ for (const pos of userNonALMPositions) {
127
+ try {
128
+ const [amount0, amount1] = getAmountsForLiquidity(sqrtPriceX96, Number.parseInt(pos.tickLower), Number.parseInt(pos.tickUpper), BigNumber.from(pos.liquidity));
129
+ const balance0 = BN2Number(amount0, poolDatas[p].decimalsToken0);
130
+ const balance1 = BN2Number(amount1, poolDatas[p].decimalsToken1);
131
+ const tvl = balance0 * priceToken0 + balance1 * priceToken1;
132
+ updateUserPosition({
133
+ balance0,
134
+ balance1,
135
+ id: pos.id,
136
+ inRangeLiquidity: balance0 > 0 && balance1 > 0 ? BN2Number(pos.liquidity) : 0,
137
+ lowerTick: Number.parseInt(pos.tickLower),
138
+ origin: -1,
139
+ totalLiquidity: BN2Number(pos.liquidity),
140
+ tvl,
141
+ upperTick: Number.parseInt(pos.tickUpper),
142
+ });
143
+ }
144
+ catch {
145
+ log.local(`Merkl User Data: error handling positions for pool ${NETWORK_LABELS[chainId]}-${p}`);
146
+ }
147
+ }
148
+ /** 2_ User Positions through ALMs */
149
+ for (const almAddress of Object.keys(promiseALMPosition).filter(almAddress => !!poolDatas[p].forwarders[utils.getAddress(almAddress)])) {
150
+ try {
151
+ const almDetail = poolDatas[p].forwarders[utils.getAddress(almAddress)];
152
+ let balance;
153
+ if (almDetail.origin === ALM.spNFT) {
154
+ const tokenId = promiseALMPosition[almAddress];
155
+ balance = (await new Contract(almAddress, spNFTInterface, providers[chainId]).getStakingPosition(tokenId))[0];
156
+ }
157
+ else {
158
+ balance = promiseALMPosition[almAddress];
159
+ }
160
+ for (const pos of almDetail.positions) {
161
+ updateUserPosition({
162
+ almAddress: almAddress, // FIXME: typing is bypassed here
163
+ balance0: (BN2Number(balance) * pos?.balance0) / almDetail.totalSupply,
164
+ balance1: (BN2Number(balance) * pos?.balance1) / almDetail.totalSupply,
165
+ id: pos.id,
166
+ inRangeLiquidity: (BN2Number(balance) * pos?.inRangeLiquidity) / almDetail.totalSupply,
167
+ lowerTick: pos.lowerTick,
168
+ origin: almDetail.origin,
169
+ totalLiquidity: (BN2Number(balance) * pos?.totalLiquidity) / almDetail.totalSupply,
170
+ tvl: (BN2Number(balance) * pos?.tvl) / almDetail.totalSupply,
171
+ upperTick: pos.upperTick,
172
+ });
173
+ }
174
+ }
175
+ catch (_error) {
176
+ log.local(`Merkl User Data: error handling alm positions for pool ${NETWORK_LABELS[chainId]}-${p}`);
177
+ }
178
+ }
179
+ /** 3_ User positions that were deposited on non fungible positions wrapper contracts (eg. farms) */
180
+ let j = callsByAmm[amm].start + callsByAmm[amm].poolCalls;
181
+ if (getSupportedNFPWrapperMapping(chainId, amm).length > 0) {
182
+ const nonFungiblePositionManagerInterface = NonFungiblePositionManagerInterface[AMMAlgorithmMapping[amm]];
183
+ for (const wrapper of getSupportedNFPWrapperMapping(chainId, amm)) {
184
+ if (!!farmedTokenIds?.[amm] && farmedTokenIds?.[amm][wrapper].length > 0) {
185
+ for (let k = 0; k < farmedTokenIds[amm][wrapper].length; k++) {
186
+ if (farmedTokenIds[amm][wrapper][k].pool !== p.toLowerCase()) {
187
+ j++;
188
+ continue;
189
+ }
190
+ const posLiquidity = nonFungiblePositionManagerInterface.decodeFunctionResult("positions", result[j]).liquidity;
191
+ const tickLower = Number.parseFloat(nonFungiblePositionManagerInterface
192
+ .decodeFunctionResult("positions", result[j])
193
+ .tickLower.toString());
194
+ const tickUpper = Number.parseFloat(nonFungiblePositionManagerInterface
195
+ .decodeFunctionResult("positions", result[j++])
196
+ .tickUpper.toString());
197
+ try {
198
+ const [amount0, amount1] = getAmountsForLiquidity(sqrtPriceX96, tickLower, tickUpper, posLiquidity);
199
+ const balance0 = BN2Number(amount0, poolDatas[p].decimalsToken0);
200
+ const balance1 = BN2Number(amount1, poolDatas[p].decimalsToken1);
201
+ const priceToken0 = (await pricer.get({
202
+ address: poolDatas[p].token0,
203
+ chainId,
204
+ symbol: poolDatas[p].symbolToken0,
205
+ }));
206
+ const priceToken1 = (await pricer.get({
207
+ address: poolDatas[p].token1,
208
+ chainId,
209
+ symbol: poolDatas[p].symbolToken1,
210
+ }));
211
+ const tvl = balance0 * priceToken0 + balance1 * priceToken1;
212
+ updateUserPosition({
213
+ almAddress: farmedTokenIds[amm][wrapper][k].farmAddress,
214
+ balance0,
215
+ balance1,
216
+ id: farmedTokenIds[amm][wrapper][k].id,
217
+ inRangeLiquidity: balance0 > 0 && balance1 > 0 ? BN2Number(posLiquidity) : 0,
218
+ lowerTick: tickLower,
219
+ origin: -2 - Number.parseInt(String(wrapper)), // -2 - X means NFT Wrapper
220
+ totalLiquidity: BN2Number(posLiquidity),
221
+ tvl,
222
+ upperTick: tickUpper,
223
+ });
224
+ }
225
+ catch (_e) {
226
+ log.local(`Merkl User Data: error handling positions for pool ${NETWORK_LABELS[chainId]}-${p}`);
227
+ }
228
+ }
229
+ }
230
+ }
231
+ }
232
+ /** Individual APRs */
233
+ let individualApr = 0;
234
+ const oneDistributionIsBoosted = false;
235
+ for (const campaignDatas of Object.values(poolDatas[p].campaigns)) {
236
+ const campaignData = campaignDatas;
237
+ let userBalance0 = res.userBalanceToken0;
238
+ let userBalance1 = res.userBalanceToken1;
239
+ let userInRangeLiquidity = res.userInRangeLiquidity;
240
+ let userTotalLiquidity = res.userTotalLiquidity;
241
+ const priceRewardToken = (await pricer.get({
242
+ address: campaignData.rewardToken,
243
+ chainId,
244
+ symbol: campaignData.symbolRewardToken,
245
+ }));
246
+ /** Handle whitelist to compute APR */
247
+ if (campaignData.whitelist.length > 0) {
248
+ const aux = campaignData.whitelist.reduce((acc, whitelistedAddress) => {
249
+ /** 1_ User is whitelisted */
250
+ if (user.toLowerCase() === whitelistedAddress.toLowerCase()) {
251
+ acc.balance0 += res.userBalanceToken0;
252
+ acc.balance1 += res.userBalanceToken1;
253
+ acc.inRangeLiquidity += res.userInRangeLiquidity;
254
+ acc.totalLiquidity += res.userTotalLiquidity;
255
+ }
256
+ else if (res.userPositions
257
+ .map((w) => (!!w?.almAddress ? w?.almAddress?.toLowerCase() : null))
258
+ ?.filter((a) => !!a)
259
+ .includes(whitelistedAddress.toLowerCase())) {
260
+ /**
261
+ * 2_ ALM is whitelisted and/or Nf positions vault is whitelisted
262
+ * @dev for simplicity purposes, vault address is marked as `almAddress`
263
+ */
264
+ let index = -1;
265
+ const positionsAddresses = res.userPositions.map((w) => w.almAddress?.toLowerCase());
266
+ while (true) {
267
+ const newIndex = positionsAddresses
268
+ .slice(index + 1)
269
+ .indexOf(whitelistedAddress.toLowerCase());
270
+ if (newIndex === -1)
271
+ break;
272
+ index = index + 1 + newIndex;
273
+ acc.balance0 += res.userPositions[index].balance0;
274
+ acc.balance1 += res.userPositions[index].balance1;
275
+ acc.inRangeLiquidity += res.userPositions[index].inRangeLiquidity;
276
+ acc.totalLiquidity += res.userPositions[index].totalLiquidity;
277
+ }
278
+ }
279
+ else if (res.userPositions
280
+ .map((w) => !!w?.almAddress
281
+ ? poolDatas[p].forwarders[utils.getAddress(w?.almAddress)]?.target?.toLowerCase()
282
+ : null)
283
+ ?.filter((a) => !!a)
284
+ .includes(whitelistedAddress?.toLowerCase())) {
285
+ /** 3_ ALM target is whitelisted */
286
+ let index = -1;
287
+ const positionsAddresses = res.userPositions.map((w) => !!w?.almAddress &&
288
+ poolDatas[p].forwarders[utils.getAddress(w?.almAddress)]?.target.toLowerCase());
289
+ while (true) {
290
+ const newIndex = positionsAddresses
291
+ .slice(index + 1)
292
+ .indexOf(whitelistedAddress.toLowerCase());
293
+ if (newIndex === -1)
294
+ break;
295
+ index = index + 1 + newIndex;
296
+ acc.balance0 += res.userPositions[index].balance0;
297
+ acc.balance1 += res.userPositions[index].balance1;
298
+ acc.inRangeLiquidity += res.userPositions[index].inRangeLiquidity;
299
+ acc.totalLiquidity += res.userPositions[index].totalLiquidity;
300
+ }
301
+ }
302
+ return acc;
303
+ }, {
304
+ balance0: 0,
305
+ balance1: 0,
306
+ inRangeLiquidity: 0,
307
+ totalLiquidity: 0,
308
+ });
309
+ userBalance0 = Math.max(0, aux.balance0);
310
+ userBalance1 = Math.max(0, aux.balance1);
311
+ userInRangeLiquidity = Math.max(0, aux.inRangeLiquidity);
312
+ userTotalLiquidity = Math.max(0, aux.inRangeLiquidity);
313
+ }
314
+ else if (campaignData.blacklist.length > 0) {
315
+ /** Handle blacklist to compute APR */
316
+ const aux = campaignData.blacklist.reduce((acc, blacklistedAddress) => {
317
+ /** 1_ User is blacklisted */
318
+ if (user.toLowerCase() === blacklistedAddress.toLowerCase()) {
319
+ acc.balance0 -= res.userBalanceToken0;
320
+ acc.balance1 -= res.userBalanceToken1;
321
+ acc.inRangeLiquidity -= res.userInRangeLiquidity;
322
+ }
323
+ else if (res.userPositions
324
+ .map((w) => (!!w?.almAddress ? w?.almAddress?.toLowerCase() : null))
325
+ ?.filter((a) => !!a)
326
+ .includes(blacklistedAddress.toLowerCase())) {
327
+ /** 2_ ALM and/or NFP vault is blacklisted */
328
+ let index = -1;
329
+ const positionsAddresses = res.userPositions.map((w) => w.almAddress?.toLowerCase());
330
+ while (true) {
331
+ const newIndex = positionsAddresses
332
+ .slice(index + 1)
333
+ .indexOf(blacklistedAddress.toLowerCase());
334
+ if (newIndex === -1)
335
+ break;
336
+ index = index + 1 + newIndex;
337
+ acc.balance0 -= res.userPositions[index].balance0;
338
+ acc.balance1 -= res.userPositions[index].balance1;
339
+ acc.inRangeLiquidity -= res.userPositions[index].inRangeLiquidity;
340
+ acc.totalLiquidity -= res.userPositions[index].totalLiquidity;
341
+ }
342
+ }
343
+ else if (
344
+ /** 3_ Target is blacklisted */
345
+ res.userPositions
346
+ .map((w) => !!w?.almAddress
347
+ ? poolDatas[p].forwarders[utils.getAddress(w?.almAddress)]?.target?.toLowerCase()
348
+ : null)
349
+ ?.filter((a) => !!a)
350
+ .includes(blacklistedAddress.toLowerCase())) {
351
+ let index = -1;
352
+ const positionsAddresses = res.userPositions.map((w) => !!w?.almAddress &&
353
+ poolDatas[p].forwarders[utils.getAddress(w?.almAddress)]?.target.toLowerCase());
354
+ while (true) {
355
+ const newIndex = positionsAddresses
356
+ .slice(index + 1)
357
+ .indexOf(blacklistedAddress.toLowerCase());
358
+ if (newIndex === -1)
359
+ break;
360
+ index = index + 1 + newIndex;
361
+ acc.balance0 -= res.userPositions[index].balance0;
362
+ acc.balance1 -= res.userPositions[index].balance1;
363
+ acc.inRangeLiquidity -= res.userPositions[index].inRangeLiquidity;
364
+ acc.totalLiquidity -= res.userPositions[index].totalLiquidity;
365
+ }
366
+ }
367
+ return acc;
368
+ }, {
369
+ balance0: res.userBalanceToken0,
370
+ balance1: res.userBalanceToken1,
371
+ inRangeLiquidity: res.userInRangeLiquidity,
372
+ totalLiquidity: 0,
373
+ });
374
+ userBalance0 = Math.max(0, aux.balance0);
375
+ userBalance1 = Math.max(0, aux.balance1);
376
+ userInRangeLiquidity = Math.max(0, aux.inRangeLiquidity);
377
+ userTotalLiquidity = Math.max(0, aux.inRangeLiquidity);
378
+ }
379
+ /** Yearly rewards in $ */
380
+ const distributionDuration = campaignData.endTimestamp - campaignData.startTimestamp;
381
+ const yearlyAmountDistributed = priceRewardToken * campaignData.amount * YEAR;
382
+ const yearlyToken0Rewards = (campaignData.propToken0 * yearlyAmountDistributed) / distributionDuration;
383
+ const yearlyToken1Rewards = (campaignData.propToken1 * yearlyAmountDistributed) / distributionDuration;
384
+ const yearlyFeeRewards = (campaignData.propFees * yearlyAmountDistributed) / distributionDuration;
385
+ // Approximation because it uses `poolTotalLiquidity` which may contain out of range liquidity
386
+ // Approximation as well because the out of range / in range is for all positions and not "per position"
387
+ let campaignIndividualAPR = !campaignData.isOutOfRangeIncentivized && (!userBalance0 || !userBalance1)
388
+ ? 0
389
+ : ((yearlyToken0Rewards * userBalance0) /
390
+ (poolDatas[p].poolBalanceToken0 - (campaignData.blacklistedBalance0 ?? 0)) +
391
+ (yearlyToken1Rewards * userBalance1) /
392
+ (poolDatas[p].poolBalanceToken1 - (campaignData.blacklistedBalance1 ?? 0)) +
393
+ (yearlyFeeRewards *
394
+ (campaignData.isOutOfRangeIncentivized ? userTotalLiquidity : userInRangeLiquidity)) /
395
+ (poolDatas[p].poolTotalLiquidity - (campaignData.blacklistedLiquidity ?? 0))) /
396
+ res.userTVL;
397
+ campaignIndividualAPR =
398
+ !campaignIndividualAPR || Number.isNaN(campaignIndividualAPR) ? 0 : campaignIndividualAPR;
399
+ individualApr += campaignIndividualAPR;
400
+ }
401
+ if (!!individualApr) {
402
+ res.apr[`User current APR ${oneDistributionIsBoosted ? "(based on last distribution boost)" : ""}`] =
403
+ individualApr;
404
+ }
405
+ if (res.userPositions.length > 0) {
406
+ finalRes[`2_${Object.values(poolDatas[p].campaigns)[0].mainParameter}`] = { ...res };
407
+ }
408
+ }
409
+ catch (_e) {
410
+ log.local(`merkl User Data: error for pool ${NETWORK_LABELS[chainId]}-${p}`);
411
+ }
412
+ }
413
+ }
414
+ }
415
+ return finalRes;
416
+ },
417
+ },
418
+ };
419
+ }
@@ -0,0 +1,35 @@
1
+ import { ALM, NETWORK_LABELS, merklSubgraphALMEndpoints, withTimeout } from "@sdk";
2
+ import { BigNumber } from "ethers";
3
+ import { request } from "graphql-request";
4
+ import { almBalancesQuery, almNFTBalancesQuery } from ".";
5
+ import { MERKL_USER_POSITION_FETCHING_TIMEOUT } from "../../../../constants";
6
+ import { log } from "../../../../utils/logger";
7
+ export async function fetchAlmPositionsV2(chainId, user) {
8
+ const res = {};
9
+ const availableALMEndpoints = merklSubgraphALMEndpoints[chainId];
10
+ if (Object.keys(availableALMEndpoints).length > 0) {
11
+ const almPromises = Object.keys(availableALMEndpoints).map(async (alm) => {
12
+ // FIXME: find another way to assess this issue
13
+ const tgURL = availableALMEndpoints[alm];
14
+ if (!!tgURL) {
15
+ const query = Number.parseInt(alm) === ALM.spNFT ||
16
+ Number.parseInt(alm) === ALM.ConcentricStaker ||
17
+ Number.parseInt(alm) === ALM.GammaChef
18
+ ? almNFTBalancesQuery
19
+ : almBalancesQuery;
20
+ await withTimeout(request(tgURL, query, {
21
+ owner: user.toLowerCase(),
22
+ }).then(requestRes => {
23
+ requestRes.holders.forEach(holder => {
24
+ res[holder.token] = BigNumber.from(Number.parseInt(alm) === ALM.spNFT ? holder.tokenId : holder.balance);
25
+ });
26
+ }), MERKL_USER_POSITION_FETCHING_TIMEOUT).catch(error => {
27
+ const service = `Merkl ALM Subgraph for ${NETWORK_LABELS[chainId]} ${ALM[alm]}`;
28
+ log.error(service, error, service, tgURL);
29
+ });
30
+ }
31
+ });
32
+ await Promise.all(almPromises);
33
+ }
34
+ return res;
35
+ }
@@ -0,0 +1,35 @@
1
+ import { AMM, NETWORK_LABELS, merklSubgraphAMMEndpoints, withTimeout } from "@sdk";
2
+ import { request } from "graphql-request";
3
+ import { positionsQuery } from ".";
4
+ import { MERKL_USER_POSITION_FETCHING_TIMEOUT } from "../../../../constants";
5
+ import { log } from "../../../../utils/logger";
6
+ export async function fetchAmmPositionsV2(chainId, user, amms) {
7
+ const res = {};
8
+ const promises = amms.map(async (amm) => {
9
+ const tgURL = merklSubgraphAMMEndpoints[chainId][amm];
10
+ if (!!tgURL && tgURL !== "") {
11
+ await withTimeout(request(tgURL, positionsQuery, {
12
+ owner: user?.toLowerCase(),
13
+ }), MERKL_USER_POSITION_FETCHING_TIMEOUT)
14
+ .then(fetchedData => {
15
+ res[amm] = {};
16
+ res[amm].nft = fetchedData?.nft?.reduce((prev, curr) => {
17
+ if (!prev.map(i => i.id).includes(curr.id))
18
+ prev.push(curr);
19
+ return prev;
20
+ }, []);
21
+ res[amm].direct = fetchedData?.direct?.reduce((prev, curr) => {
22
+ if (!prev.map(i => i.id).includes(curr.id))
23
+ prev.push(curr);
24
+ return prev;
25
+ }, []);
26
+ })
27
+ .catch(error => {
28
+ const service = `Merkl AMM Subgraph for ${NETWORK_LABELS[chainId]} ${AMM[amm]}`;
29
+ log.error(service, error, service, tgURL);
30
+ });
31
+ }
32
+ });
33
+ await Promise.all(promises);
34
+ return res;
35
+ }
@@ -0,0 +1,44 @@
1
+ import { Redis } from "../../../../cache";
2
+ import { MERKL_USER_POSITION_FETCHING_TIMEOUT } from "../../../../constants";
3
+ import { hashArray } from "../../../../utils/hashArray";
4
+ import { AMM, NETWORK_LABELS, getSupportedNFPWrapperMapping, merklSubgraphNFPWrapperEndpoints, withTimeout, } from "@sdk";
5
+ import { request } from "graphql-request";
6
+ import { nftWrapperPositionsQuery } from ".";
7
+ import { log } from "../../../../utils/logger";
8
+ export async function fetchFarmedPositionsV2(chainId, owners, amm) {
9
+ const res = {};
10
+ const promises = getSupportedNFPWrapperMapping(chainId, amm).map(async (wrapper) => {
11
+ const tgURL = merklSubgraphNFPWrapperEndpoints[chainId][wrapper];
12
+ if (!!tgURL) {
13
+ await withTimeout((async () => {
14
+ let hasFollowingPage = true;
15
+ let skip = 0;
16
+ while (hasFollowingPage) {
17
+ const auxRes = await request(tgURL, nftWrapperPositionsQuery, {
18
+ first: 1_000,
19
+ owners: owners.map(owner => owner.toLowerCase()),
20
+ skip,
21
+ });
22
+ if (auxRes.holderNFTs.length < 1000) {
23
+ hasFollowingPage = false;
24
+ }
25
+ skip += 1000;
26
+ res[wrapper] = (res[wrapper] ?? []).concat(auxRes.holderNFTs.map(p => {
27
+ return {
28
+ farmAddress: p.id.split("_")[2],
29
+ id: p.tokenId,
30
+ pool: p.token,
31
+ holder: p.holder,
32
+ };
33
+ }));
34
+ }
35
+ })(), MERKL_USER_POSITION_FETCHING_TIMEOUT).catch(error => {
36
+ const service = `merkl non fungible pos wrapper subgraph for ${NETWORK_LABELS[chainId]} ${AMM[amm]}`;
37
+ log.error(service, error, service, tgURL);
38
+ });
39
+ }
40
+ });
41
+ await Promise.all(promises);
42
+ return res;
43
+ }
44
+ export const fetchFarmedPositionsV2WithCache = async (chainId, user, amm) => await Redis.getOrSet(`FarmedPositions_${hashArray(chainId, user, amm)}$`, fetchFarmedPositionsV2, chainId, user, amm);