@stake-dao/reader 0.1.3 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (286) hide show
  1. package/dist/esm/bytecodes/index.js +16 -0
  2. package/dist/esm/bytecodes/index.js.map +1 -0
  3. package/dist/esm/bytecodes/strategies/batches/batchBalancerStrats.js +68 -0
  4. package/dist/esm/bytecodes/strategies/batches/batchBalancerStrats.js.map +1 -0
  5. package/dist/esm/{batches/curveStrats.js → bytecodes/strategies/batches/batchCurveStrats.js} +3 -3
  6. package/dist/esm/bytecodes/strategies/batches/batchCurveStrats.js.map +1 -0
  7. package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.js +61 -0
  8. package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.js.map +1 -0
  9. package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapPositions.js +44 -0
  10. package/dist/esm/bytecodes/strategies/batches/batchPancakeSwapPositions.js.map +1 -0
  11. package/dist/esm/bytecodes/strategies/batches/batchPancakeswapStrats.js +48 -0
  12. package/dist/esm/bytecodes/strategies/batches/batchPancakeswapStrats.js.map +1 -0
  13. package/dist/esm/bytecodes/strategies/batches/batchPendleStrats.js +63 -0
  14. package/dist/esm/bytecodes/strategies/batches/batchPendleStrats.js.map +1 -0
  15. package/dist/esm/bytecodes/strategies/builds/buildBalancerStrats.js +54 -0
  16. package/dist/esm/bytecodes/strategies/builds/buildBalancerStrats.js.map +1 -0
  17. package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.js +64 -0
  18. package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.js.map +1 -0
  19. package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapStrats.js +51 -0
  20. package/dist/esm/bytecodes/strategies/builds/buildPancakeSwapStrats.js.map +1 -0
  21. package/dist/esm/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.js +54 -0
  22. package/dist/esm/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.js.map +1 -0
  23. package/dist/esm/bytecodes/strategies/builds/buildPendleStrats.js +39 -0
  24. package/dist/esm/bytecodes/strategies/builds/buildPendleStrats.js.map +1 -0
  25. package/dist/esm/{batches → bytecodes/strategies/builds}/buildYearnStrats.js +2 -2
  26. package/dist/esm/bytecodes/strategies/builds/buildYearnStrats.js.map +1 -0
  27. package/dist/esm/bytecodes/strategies/fetchYearnGauges.js.map +1 -0
  28. package/dist/esm/{batches → bytecodes/strategies}/sdtGaugeRewards.js +1 -1
  29. package/dist/esm/bytecodes/strategies/sdtGaugeRewards.js.map +1 -0
  30. package/dist/esm/bytecodes/tokenData.js.map +1 -0
  31. package/dist/esm/{batches → bytecodes}/types.js.map +1 -1
  32. package/dist/esm/endpoints.js +1 -0
  33. package/dist/esm/endpoints.js.map +1 -1
  34. package/dist/esm/index.js +33 -5
  35. package/dist/esm/index.js.map +1 -1
  36. package/dist/esm/lockers/utils/endpoints.js +1 -1
  37. package/dist/esm/lockers/utils/endpoints.js.map +1 -1
  38. package/dist/esm/prices.js +39 -3
  39. package/dist/esm/prices.js.map +1 -1
  40. package/dist/esm/strategies/balancer/build.js +51 -0
  41. package/dist/esm/strategies/balancer/build.js.map +1 -0
  42. package/dist/esm/strategies/balancer/endpoints.js +27 -0
  43. package/dist/esm/strategies/balancer/endpoints.js.map +1 -0
  44. package/dist/esm/strategies/balancer/fetch.js +190 -0
  45. package/dist/esm/strategies/balancer/fetch.js.map +1 -0
  46. package/dist/esm/strategies/curve/build.js +4 -3
  47. package/dist/esm/strategies/curve/build.js.map +1 -1
  48. package/dist/esm/strategies/curve/fetch/curveApiData/bytecode.js +0 -1
  49. package/dist/esm/strategies/curve/fetch/curveApiData/bytecode.js.map +1 -1
  50. package/dist/esm/strategies/curve/fetch/curveApiData/getCurveApiData.js +3 -2
  51. package/dist/esm/strategies/curve/fetch/curveApiData/getCurveApiData.js.map +1 -1
  52. package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.js +3 -2
  53. package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.js.map +1 -1
  54. package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesWeights.js +2 -1
  55. package/dist/esm/strategies/curve/fetch/curveApiData/getGaugesWeights.js.map +1 -1
  56. package/dist/esm/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.js +2 -1
  57. package/dist/esm/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.js.map +1 -1
  58. package/dist/esm/strategies/curve/fetch/index.js +22 -4
  59. package/dist/esm/strategies/curve/fetch/index.js.map +1 -1
  60. package/dist/esm/strategies/curve/httpCalls.js +3 -3
  61. package/dist/esm/strategies/curve/httpCalls.js.map +1 -1
  62. package/dist/esm/strategies/curve/onChainCalls.js +3 -2
  63. package/dist/esm/strategies/curve/onChainCalls.js.map +1 -1
  64. package/dist/esm/strategies/pancakeswap/abis/PancakeSwapMasterchef.json +1575 -0
  65. package/dist/esm/strategies/pancakeswap/build.js +48 -0
  66. package/dist/esm/strategies/pancakeswap/build.js.map +1 -0
  67. package/dist/esm/strategies/pancakeswap/buildErc20.js +63 -0
  68. package/dist/esm/strategies/pancakeswap/buildErc20.js.map +1 -0
  69. package/dist/esm/strategies/pancakeswap/config.js +7 -0
  70. package/dist/esm/strategies/pancakeswap/config.js.map +1 -0
  71. package/dist/esm/strategies/pancakeswap/endpoints.js +10 -0
  72. package/dist/esm/strategies/pancakeswap/endpoints.js.map +1 -0
  73. package/dist/esm/strategies/pancakeswap/fetch/getPancakeApisData.js +24 -0
  74. package/dist/esm/strategies/pancakeswap/fetch/getPancakeApisData.js.map +1 -0
  75. package/dist/esm/strategies/pancakeswap/fetch/getPancakeErc20Vaults.js +134 -0
  76. package/dist/esm/strategies/pancakeswap/fetch/getPancakeErc20Vaults.js.map +1 -0
  77. package/dist/esm/strategies/pancakeswap/fetch/getPancakeNotDeployed.js +102 -0
  78. package/dist/esm/strategies/pancakeswap/fetch/getPancakeNotDeployed.js.map +1 -0
  79. package/dist/esm/strategies/pancakeswap/fetch/getPancakeV3Vaults.js +142 -0
  80. package/dist/esm/strategies/pancakeswap/fetch/getPancakeV3Vaults.js.map +1 -0
  81. package/dist/esm/strategies/pancakeswap/fetch/index.js +25 -0
  82. package/dist/esm/strategies/pancakeswap/fetch/index.js.map +1 -0
  83. package/dist/esm/strategies/pancakeswap/fetch/pancakePositions.js +87 -0
  84. package/dist/esm/strategies/pancakeswap/fetch/pancakePositions.js.map +1 -0
  85. package/dist/esm/strategies/pancakeswap/fetch/pancakeswapMath.js +199 -0
  86. package/dist/esm/strategies/pancakeswap/fetch/pancakeswapMath.js.map +1 -0
  87. package/dist/esm/strategies/pendle/abis/MulticallPendleStratsAbi.json +103 -0
  88. package/dist/esm/strategies/pendle/build.js +70 -0
  89. package/dist/esm/strategies/pendle/build.js.map +1 -0
  90. package/dist/esm/strategies/pendle/fetch.js +267 -0
  91. package/dist/esm/strategies/pendle/fetch.js.map +1 -0
  92. package/dist/esm/strategies/pendle/getPendleApiData.js +15 -0
  93. package/dist/esm/strategies/pendle/getPendleApiData.js.map +1 -0
  94. package/dist/esm/strategies/pendle/pendlePoints.js +71 -0
  95. package/dist/esm/strategies/pendle/pendlePoints.js.map +1 -0
  96. package/dist/esm/strategies/utils/getAprBreakdown.js +9 -9
  97. package/dist/esm/strategies/utils/getAprBreakdown.js.map +1 -1
  98. package/dist/esm/strategies/utils/index.js +10 -1
  99. package/dist/esm/strategies/utils/index.js.map +1 -1
  100. package/dist/esm/strategies/yearn/build.js +5 -4
  101. package/dist/esm/strategies/yearn/build.js.map +1 -1
  102. package/dist/esm/strategies/yearn/fetch/fetchAllYearnGauges.js +3 -2
  103. package/dist/esm/strategies/yearn/fetch/fetchAllYearnGauges.js.map +1 -1
  104. package/dist/esm/strategies/yearn/fetch/index.js +1 -1
  105. package/dist/esm/strategies/yearn/fetch/index.js.map +1 -1
  106. package/dist/esm/tsconfig.build.tsbuildinfo +1 -1
  107. package/dist/esm/utils.js +1 -1
  108. package/dist/esm/utils.js.map +1 -1
  109. package/dist/types/bytecodes/index.d.ts +16 -0
  110. package/dist/types/bytecodes/index.d.ts.map +1 -0
  111. package/dist/types/bytecodes/strategies/batches/batchBalancerStrats.d.ts +4 -0
  112. package/dist/types/bytecodes/strategies/batches/batchBalancerStrats.d.ts.map +1 -0
  113. package/dist/types/bytecodes/strategies/batches/batchCurveStrats.d.ts +4 -0
  114. package/dist/types/bytecodes/strategies/batches/batchCurveStrats.d.ts.map +1 -0
  115. package/dist/types/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.d.ts +4 -0
  116. package/dist/types/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.d.ts.map +1 -0
  117. package/dist/types/bytecodes/strategies/batches/batchPancakeSwapPositions.d.ts +4 -0
  118. package/dist/types/bytecodes/strategies/batches/batchPancakeSwapPositions.d.ts.map +1 -0
  119. package/dist/types/bytecodes/strategies/batches/batchPancakeswapStrats.d.ts +4 -0
  120. package/dist/types/bytecodes/strategies/batches/batchPancakeswapStrats.d.ts.map +1 -0
  121. package/dist/types/bytecodes/strategies/batches/batchPendleStrats.d.ts +4 -0
  122. package/dist/types/bytecodes/strategies/batches/batchPendleStrats.d.ts.map +1 -0
  123. package/dist/types/bytecodes/strategies/builds/buildBalancerStrats.d.ts +4 -0
  124. package/dist/types/bytecodes/strategies/builds/buildBalancerStrats.d.ts.map +1 -0
  125. package/dist/types/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.d.ts +4 -0
  126. package/dist/types/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.d.ts.map +1 -0
  127. package/dist/types/bytecodes/strategies/builds/buildPancakeSwapStrats.d.ts +4 -0
  128. package/dist/types/bytecodes/strategies/builds/buildPancakeSwapStrats.d.ts.map +1 -0
  129. package/dist/types/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.d.ts +4 -0
  130. package/dist/types/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.d.ts.map +1 -0
  131. package/dist/types/bytecodes/strategies/builds/buildPendleStrats.d.ts +4 -0
  132. package/dist/types/bytecodes/strategies/builds/buildPendleStrats.d.ts.map +1 -0
  133. package/dist/types/bytecodes/strategies/builds/buildYearnStrats.d.ts +4 -0
  134. package/dist/types/bytecodes/strategies/builds/buildYearnStrats.d.ts.map +1 -0
  135. package/dist/types/bytecodes/strategies/fetchYearnGauges.d.ts +4 -0
  136. package/dist/types/bytecodes/strategies/fetchYearnGauges.d.ts.map +1 -0
  137. package/dist/types/bytecodes/strategies/sdtGaugeRewards.d.ts +4 -0
  138. package/dist/types/bytecodes/strategies/sdtGaugeRewards.d.ts.map +1 -0
  139. package/dist/types/bytecodes/tokenData.d.ts.map +1 -0
  140. package/dist/types/bytecodes/types.d.ts.map +1 -0
  141. package/dist/types/endpoints.d.ts +1 -0
  142. package/dist/types/endpoints.d.ts.map +1 -1
  143. package/dist/types/index.d.ts +15 -5
  144. package/dist/types/index.d.ts.map +1 -1
  145. package/dist/types/lockers/utils/endpoints.d.ts +1 -1
  146. package/dist/types/lockers/utils/endpoints.d.ts.map +1 -1
  147. package/dist/types/prices.d.ts +8 -1
  148. package/dist/types/prices.d.ts.map +1 -1
  149. package/dist/types/strategies/balancer/build.d.ts +21 -0
  150. package/dist/types/strategies/balancer/build.d.ts.map +1 -0
  151. package/dist/types/strategies/balancer/endpoints.d.ts +3 -0
  152. package/dist/types/strategies/balancer/endpoints.d.ts.map +1 -0
  153. package/dist/types/strategies/balancer/fetch.d.ts +11 -0
  154. package/dist/types/strategies/balancer/fetch.d.ts.map +1 -0
  155. package/dist/types/strategies/curve/build.d.ts.map +1 -1
  156. package/dist/types/strategies/curve/fetch/curveApiData/bytecode.d.ts.map +1 -1
  157. package/dist/types/strategies/curve/fetch/curveApiData/getCurveApiData.d.ts +1 -1
  158. package/dist/types/strategies/curve/fetch/curveApiData/getCurveApiData.d.ts.map +1 -1
  159. package/dist/types/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.d.ts.map +1 -1
  160. package/dist/types/strategies/curve/fetch/curveApiData/getGaugesWeights.d.ts.map +1 -1
  161. package/dist/types/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.d.ts.map +1 -1
  162. package/dist/types/strategies/curve/fetch/index.d.ts +15 -2
  163. package/dist/types/strategies/curve/fetch/index.d.ts.map +1 -1
  164. package/dist/types/strategies/curve/onChainCalls.d.ts.map +1 -1
  165. package/dist/types/strategies/pancakeswap/build.d.ts +2 -0
  166. package/dist/types/strategies/pancakeswap/build.d.ts.map +1 -0
  167. package/dist/types/strategies/pancakeswap/buildErc20.d.ts +7 -0
  168. package/dist/types/strategies/pancakeswap/buildErc20.d.ts.map +1 -0
  169. package/dist/types/strategies/pancakeswap/config.d.ts +7 -0
  170. package/dist/types/strategies/pancakeswap/config.d.ts.map +1 -0
  171. package/dist/types/strategies/pancakeswap/endpoints.d.ts +8 -0
  172. package/dist/types/strategies/pancakeswap/endpoints.d.ts.map +1 -0
  173. package/dist/types/strategies/pancakeswap/fetch/getPancakeApisData.d.ts +10 -0
  174. package/dist/types/strategies/pancakeswap/fetch/getPancakeApisData.d.ts.map +1 -0
  175. package/dist/types/strategies/pancakeswap/fetch/getPancakeErc20Vaults.d.ts +44 -0
  176. package/dist/types/strategies/pancakeswap/fetch/getPancakeErc20Vaults.d.ts.map +1 -0
  177. package/dist/types/strategies/pancakeswap/fetch/getPancakeNotDeployed.d.ts +3 -0
  178. package/dist/types/strategies/pancakeswap/fetch/getPancakeNotDeployed.d.ts.map +1 -0
  179. package/dist/types/strategies/pancakeswap/fetch/getPancakeV3Vaults.d.ts +7 -0
  180. package/dist/types/strategies/pancakeswap/fetch/getPancakeV3Vaults.d.ts.map +1 -0
  181. package/dist/types/strategies/pancakeswap/fetch/index.d.ts +17 -0
  182. package/dist/types/strategies/pancakeswap/fetch/index.d.ts.map +1 -0
  183. package/dist/types/strategies/pancakeswap/fetch/pancakePositions.d.ts +11 -0
  184. package/dist/types/strategies/pancakeswap/fetch/pancakePositions.d.ts.map +1 -0
  185. package/dist/types/strategies/pancakeswap/fetch/pancakeswapMath.d.ts +33 -0
  186. package/dist/types/strategies/pancakeswap/fetch/pancakeswapMath.d.ts.map +1 -0
  187. package/dist/types/strategies/pendle/build.d.ts +42 -0
  188. package/dist/types/strategies/pendle/build.d.ts.map +1 -0
  189. package/dist/types/strategies/pendle/fetch.d.ts +60 -0
  190. package/dist/types/strategies/pendle/fetch.d.ts.map +1 -0
  191. package/dist/types/strategies/pendle/getPendleApiData.d.ts +3 -0
  192. package/dist/types/strategies/pendle/getPendleApiData.d.ts.map +1 -0
  193. package/dist/types/strategies/pendle/pendlePoints.d.ts +80 -0
  194. package/dist/types/strategies/pendle/pendlePoints.d.ts.map +1 -0
  195. package/dist/types/strategies/types.d.ts +17 -3
  196. package/dist/types/strategies/types.d.ts.map +1 -1
  197. package/dist/types/strategies/utils/getAprBreakdown.d.ts +1 -4
  198. package/dist/types/strategies/utils/getAprBreakdown.d.ts.map +1 -1
  199. package/dist/types/strategies/utils/index.d.ts +2 -0
  200. package/dist/types/strategies/utils/index.d.ts.map +1 -1
  201. package/dist/types/strategies/yearn/build.d.ts.map +1 -1
  202. package/dist/types/strategies/yearn/fetch/fetchAllYearnGauges.d.ts.map +1 -1
  203. package/dist/types/strategies/yearn/fetch/index.d.ts +13 -2
  204. package/dist/types/strategies/yearn/fetch/index.d.ts.map +1 -1
  205. package/dist/types/utils.d.ts.map +1 -1
  206. package/package.json +3 -2
  207. package/src/bytecodes/index.ts +18 -0
  208. package/src/bytecodes/strategies/batches/batchBalancerStrats.ts +70 -0
  209. package/src/{batches/curveStrats.ts → bytecodes/strategies/batches/batchCurveStrats.ts} +3 -3
  210. package/src/bytecodes/strategies/batches/batchPancakeSwapErc20Strats.ts +67 -0
  211. package/src/bytecodes/strategies/batches/batchPancakeSwapPositions.ts +50 -0
  212. package/src/bytecodes/strategies/batches/batchPancakeswapStrats.ts +54 -0
  213. package/src/bytecodes/strategies/batches/batchPendleStrats.ts +65 -0
  214. package/src/bytecodes/strategies/builds/buildBalancerStrats.ts +56 -0
  215. package/src/bytecodes/strategies/builds/buildPancakeSwapErc20Strats.ts +70 -0
  216. package/src/bytecodes/strategies/builds/buildPancakeSwapStrats.ts +57 -0
  217. package/src/bytecodes/strategies/builds/buildPancakeswapNotDeployedErc20Strats.ts +60 -0
  218. package/src/bytecodes/strategies/builds/buildPendleStrats.ts +41 -0
  219. package/src/{batches → bytecodes/strategies/builds}/buildYearnStrats.ts +3 -3
  220. package/src/{batches → bytecodes/strategies}/fetchYearnGauges.ts +1 -1
  221. package/src/{batches → bytecodes/strategies}/sdtGaugeRewards.ts +2 -2
  222. package/src/endpoints.ts +2 -0
  223. package/src/index.ts +43 -5
  224. package/src/lockers/utils/endpoints.ts +2 -1
  225. package/src/prices.ts +57 -6
  226. package/src/strategies/balancer/build.ts +66 -0
  227. package/src/strategies/balancer/endpoints.ts +27 -0
  228. package/src/strategies/balancer/fetch.ts +266 -0
  229. package/src/strategies/curve/build.ts +4 -3
  230. package/src/strategies/curve/fetch/curveApiData/bytecode.ts +0 -1
  231. package/src/strategies/curve/fetch/curveApiData/getCurveApiData.ts +3 -2
  232. package/src/strategies/curve/fetch/curveApiData/getGaugesFromRegistry.ts +6 -2
  233. package/src/strategies/curve/fetch/curveApiData/getGaugesWeights.ts +2 -1
  234. package/src/strategies/curve/fetch/curveApiData/getPoolsFromRegistries.ts.ts +2 -1
  235. package/src/strategies/curve/fetch/index.ts +53 -15
  236. package/src/strategies/curve/httpCalls.ts +3 -3
  237. package/src/strategies/curve/onChainCalls.ts +3 -2
  238. package/src/strategies/pancakeswap/build.ts +57 -0
  239. package/src/strategies/pancakeswap/buildErc20.ts +73 -0
  240. package/src/strategies/pancakeswap/config.ts +7 -0
  241. package/src/strategies/pancakeswap/endpoints.ts +12 -0
  242. package/src/strategies/pancakeswap/fetch/getPancakeApisData.ts +32 -0
  243. package/src/strategies/pancakeswap/fetch/getPancakeErc20Vaults.ts +184 -0
  244. package/src/strategies/pancakeswap/fetch/getPancakeNotDeployed.ts +132 -0
  245. package/src/strategies/pancakeswap/fetch/getPancakeV3Vaults.ts +191 -0
  246. package/src/strategies/pancakeswap/fetch/index.ts +50 -0
  247. package/src/strategies/pancakeswap/fetch/pancakePositions.ts +147 -0
  248. package/src/strategies/pancakeswap/fetch/pancakeswapMath.ts +305 -0
  249. package/src/strategies/pendle/build.ts +93 -0
  250. package/src/strategies/pendle/fetch.ts +348 -0
  251. package/src/strategies/pendle/getPendleApiData.ts +20 -0
  252. package/src/strategies/pendle/pendlePoints.ts +71 -0
  253. package/src/strategies/types.ts +20 -3
  254. package/src/strategies/utils/getAprBreakdown.ts +9 -9
  255. package/src/strategies/utils/index.ts +14 -1
  256. package/src/strategies/yearn/build.ts +5 -4
  257. package/src/strategies/yearn/fetch/fetchAllYearnGauges.ts +3 -2
  258. package/src/strategies/yearn/fetch/index.ts +22 -11
  259. package/src/utils.ts +1 -1
  260. package/dist/esm/batches/buildYearnStrats.js.map +0 -1
  261. package/dist/esm/batches/curveStrats.js.map +0 -1
  262. package/dist/esm/batches/fetchYearnGauges.js.map +0 -1
  263. package/dist/esm/batches/index.js +0 -6
  264. package/dist/esm/batches/index.js.map +0 -1
  265. package/dist/esm/batches/sdtGaugeRewards.js.map +0 -1
  266. package/dist/esm/batches/tokenData.js.map +0 -1
  267. package/dist/types/batches/buildYearnStrats.d.ts +0 -4
  268. package/dist/types/batches/buildYearnStrats.d.ts.map +0 -1
  269. package/dist/types/batches/curveStrats.d.ts +0 -4
  270. package/dist/types/batches/curveStrats.d.ts.map +0 -1
  271. package/dist/types/batches/fetchYearnGauges.d.ts +0 -4
  272. package/dist/types/batches/fetchYearnGauges.d.ts.map +0 -1
  273. package/dist/types/batches/index.d.ts +0 -6
  274. package/dist/types/batches/index.d.ts.map +0 -1
  275. package/dist/types/batches/sdtGaugeRewards.d.ts +0 -4
  276. package/dist/types/batches/sdtGaugeRewards.d.ts.map +0 -1
  277. package/dist/types/batches/tokenData.d.ts.map +0 -1
  278. package/dist/types/batches/types.d.ts.map +0 -1
  279. package/src/batches/index.ts +0 -5
  280. /package/dist/esm/{batches → bytecodes/strategies}/fetchYearnGauges.js +0 -0
  281. /package/dist/esm/{batches → bytecodes}/tokenData.js +0 -0
  282. /package/dist/esm/{batches → bytecodes}/types.js +0 -0
  283. /package/dist/types/{batches → bytecodes}/tokenData.d.ts +0 -0
  284. /package/dist/types/{batches → bytecodes}/types.d.ts +0 -0
  285. /package/src/{batches → bytecodes}/tokenData.ts +0 -0
  286. /package/src/{batches → bytecodes}/types.ts +0 -0
@@ -0,0 +1,147 @@
1
+ import { formatUnits } from 'viem'
2
+
3
+ import pancakeMasterchefAbi from '../abis/PancakeSwapMasterchef.json'
4
+
5
+ import { contracts, tokenWithId } from '@stake-dao/constants'
6
+ import {
7
+ getPositionFarmApr,
8
+ getPositionTradingFee,
9
+ getToken0Amount,
10
+ getToken1Amount,
11
+ tickToPrice,
12
+ } from './pancakeswapMath.js'
13
+
14
+ export const computePositionData = (
15
+ s: any,
16
+ p: any,
17
+ stratParsedData: any,
18
+ fees24H: number,
19
+ prices: any[],
20
+ token0PriceInUsd: number,
21
+ token1PriceInUsd: number,
22
+ totalAllocPoint: string,
23
+ inflationRate: string,
24
+ ) => {
25
+ const bnSqrtPriceX96 = BigInt(stratParsedData.sqrtPriceX96)
26
+
27
+ const token0Amount = formatUnits(
28
+ getToken0Amount(Number(stratParsedData.tick), p.tickLower, p.tickUpper, bnSqrtPriceX96, p.liquidity),
29
+ s.coins[0].decimals,
30
+ )
31
+ const token1Amount = formatUnits(
32
+ getToken1Amount(Number(stratParsedData.tick), p.tickLower, p.tickUpper, bnSqrtPriceX96, p.liquidity),
33
+ s.coins[1].decimals,
34
+ )
35
+
36
+ const token0AmountUsd = Number(token0Amount) * token0PriceInUsd
37
+ const token1AmountUsd = Number(token1Amount) * token1PriceInUsd
38
+ const tvlToAdd = token0AmountUsd + token1AmountUsd
39
+
40
+ const priceLower = tickToPrice(p.tickLower)
41
+ const priceUpper = tickToPrice(p.tickUpper)
42
+
43
+ const boost = Number(formatUnits(p.boostMultiplier.toString(), 12))
44
+
45
+ const apr =
46
+ getPositionFarmApr({
47
+ poolWeight: stratParsedData.allocPoint / Number(totalAllocPoint),
48
+ cakePriceUsd:
49
+ prices.find((p) => p.address.toLowerCase() === tokenWithId('cake', 56)!.address.toLowerCase())?.usdPrice || 0,
50
+ cakePerSecond: Number(inflationRate),
51
+ positionTvlUsd: token0AmountUsd + token1AmountUsd,
52
+ liquidity: p.boostLiquidity,
53
+ totalStakedLiquidity: BigInt(stratParsedData.totalBoostLiquidity),
54
+ tickCurrent: stratParsedData.tick,
55
+ tickLower: p.tickLower,
56
+ tickUpper: p.tickUpper,
57
+ }) * 0.85
58
+
59
+ const tradingApr = getPositionTradingFee({
60
+ fees24H,
61
+ sqrtRatioX96: bnSqrtPriceX96,
62
+ tickLower: p.tickLower,
63
+ tickUpper: p.tickUpper,
64
+ mostActiveLiquidity: BigInt(stratParsedData.poolLiquidity),
65
+ liquidity: p.liquidity,
66
+ positionUSD: token0AmountUsd + token1AmountUsd,
67
+ })
68
+
69
+ return {
70
+ positionData: {
71
+ ...p,
72
+ boostLiquidity: p.boostLiquidity.toString(),
73
+ boostMultiplier: p.boostMultiplier.toString(),
74
+ liquidity: p.liquidity.toString(),
75
+ pid: Number(p.pid),
76
+ reward: p.reward.toString(),
77
+ rewardGrowthInside: p.rewardGrowthInside.toString(),
78
+ tokenId: Number(p.tokenId),
79
+ token0: {
80
+ amount: token0Amount,
81
+ amountUsd: token0AmountUsd,
82
+ },
83
+ token1: {
84
+ amount: token1Amount,
85
+ amountUsd: token1AmountUsd,
86
+ },
87
+ apr: {
88
+ trading: tradingApr,
89
+ min: apr,
90
+ max: apr,
91
+ },
92
+ priceLower,
93
+ priceUpper,
94
+ },
95
+ boost,
96
+ tvlToAdd,
97
+ }
98
+ }
99
+
100
+ export const getPositionData = async (
101
+ chainId: number,
102
+ tokenId: number,
103
+ tickLower: number,
104
+ tickUpper: number,
105
+ user: string,
106
+ strat: any,
107
+ prices: any[],
108
+ provider: any,
109
+ ) => {
110
+ const positionData = await provider.readContract({
111
+ address: contracts.pancakeMasterchef![chainId],
112
+ abi: pancakeMasterchefAbi,
113
+ functionName: 'userPositionInfos',
114
+ args: [tokenId],
115
+ })
116
+
117
+ const p = {
118
+ tokenId,
119
+ liquidity: positionData[0],
120
+ boostLiquidity: positionData[1],
121
+ tickLower,
122
+ tickUpper,
123
+ rewardGrowthInside: positionData[4],
124
+ reward: positionData[5],
125
+ owner: user,
126
+ pid: positionData[7],
127
+ boostMultiplier: positionData[8],
128
+ }
129
+
130
+ const {
131
+ positionData: tokenIdPositionData,
132
+ tvlToAdd,
133
+ boost,
134
+ } = computePositionData(
135
+ strat,
136
+ p,
137
+ strat.stratsData,
138
+ strat.stratsData.fees24H,
139
+ prices,
140
+ strat.token0PriceInUsd,
141
+ strat.token1PriceInUsd,
142
+ strat.stratsData.totalAllocPoint || strat.stratsData.allocPoints,
143
+ strat.stratsData.inflationRate,
144
+ )
145
+
146
+ return { tokenIdPositionData, tvlToAdd, boost }
147
+ }
@@ -0,0 +1,305 @@
1
+ import { ONE_YEAR } from '@stake-dao/constants'
2
+ import { formatUnits, parseUnits } from 'viem'
3
+ import { Zero } from '../../../index.js'
4
+
5
+ const Q32 = BigInt(2 ** 32)
6
+ const Q96 = BigInt(2 ** 96)
7
+ const Q192 = Q96 * Q96
8
+ const MaxUint256 = BigInt('0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff')
9
+ export const MAX_TICK = 887250
10
+
11
+ function mulShift(val: bigint, mulBy: string): bigint {
12
+ return (val * BigInt(mulBy)) >> BigInt(128)
13
+ }
14
+
15
+ interface FarmAprParams {
16
+ poolWeight: number
17
+ // Total tvl staked in farm in usd
18
+ tvlUsd: number
19
+ cakePriceUsd: number
20
+ cakePerSecond: number
21
+ }
22
+
23
+ interface PositionFarmAprParams extends Omit<FarmAprParams, 'tvlUsd'> {
24
+ // Position liquidity
25
+ liquidity: bigint
26
+
27
+ // Total staked liquidity in farm
28
+ totalStakedLiquidity: bigint
29
+
30
+ // Position tvl in usd
31
+ positionTvlUsd: number
32
+
33
+ // Tick
34
+ tickCurrent: number
35
+ tickLower: number
36
+ tickUpper: number
37
+ }
38
+
39
+ interface EstimateFeeOptions {
40
+ tickLower: number
41
+ tickUpper: number
42
+ // Average 24h historical fees generated minus pancake fees in USD
43
+ fees24H: number
44
+
45
+ // The reason of using price sqrt X96 instead of tick current is that
46
+ // tick current may have rounding error since it's a floor rounding
47
+ sqrtRatioX96: bigint
48
+ // Most active liquidity of the pool
49
+ mostActiveLiquidity: bigint
50
+
51
+ liquidity: bigint
52
+ }
53
+
54
+ function getSqrtRatioAtTick(tick: number): bigint {
55
+ const absTick: number = tick < 0 ? tick * -1 : tick
56
+
57
+ let ratio: bigint =
58
+ (absTick & 0x1) !== 0 ? BigInt('0xfffcb933bd6fad37aa2d162d1a594001') : BigInt('0x100000000000000000000000000000000')
59
+ if ((absTick & 0x2) !== 0) ratio = mulShift(ratio, '0xfff97272373d413259a46990580e213a')
60
+ if ((absTick & 0x4) !== 0) ratio = mulShift(ratio, '0xfff2e50f5f656932ef12357cf3c7fdcc')
61
+ if ((absTick & 0x8) !== 0) ratio = mulShift(ratio, '0xffe5caca7e10e4e61c3624eaa0941cd0')
62
+ if ((absTick & 0x10) !== 0) ratio = mulShift(ratio, '0xffcb9843d60f6159c9db58835c926644')
63
+ if ((absTick & 0x20) !== 0) ratio = mulShift(ratio, '0xff973b41fa98c081472e6896dfb254c0')
64
+ if ((absTick & 0x40) !== 0) ratio = mulShift(ratio, '0xff2ea16466c96a3843ec78b326b52861')
65
+ if ((absTick & 0x80) !== 0) ratio = mulShift(ratio, '0xfe5dee046a99a2a811c461f1969c3053')
66
+ if ((absTick & 0x100) !== 0) ratio = mulShift(ratio, '0xfcbe86c7900a88aedcffc83b479aa3a4')
67
+ if ((absTick & 0x200) !== 0) ratio = mulShift(ratio, '0xf987a7253ac413176f2b074cf7815e54')
68
+ if ((absTick & 0x400) !== 0) ratio = mulShift(ratio, '0xf3392b0822b70005940c7a398e4b70f3')
69
+ if ((absTick & 0x800) !== 0) ratio = mulShift(ratio, '0xe7159475a2c29b7443b29c7fa6e889d9')
70
+ if ((absTick & 0x1000) !== 0) ratio = mulShift(ratio, '0xd097f3bdfd2022b8845ad8f792aa5825')
71
+ if ((absTick & 0x2000) !== 0) ratio = mulShift(ratio, '0xa9f746462d870fdf8a65dc1f90e061e5')
72
+ if ((absTick & 0x4000) !== 0) ratio = mulShift(ratio, '0x70d869a156d2a1b890bb3df62baf32f7')
73
+ if ((absTick & 0x8000) !== 0) ratio = mulShift(ratio, '0x31be135f97d08fd981231505542fcfa6')
74
+ if ((absTick & 0x10000) !== 0) ratio = mulShift(ratio, '0x9aa508b5b7a84e1c677de54f3e99bc9')
75
+ if ((absTick & 0x20000) !== 0) ratio = mulShift(ratio, '0x5d6af8dedb81196699c329225ee604')
76
+ if ((absTick & 0x40000) !== 0) ratio = mulShift(ratio, '0x2216e584f5fa1ea926041bedfe98')
77
+ if ((absTick & 0x80000) !== 0) ratio = mulShift(ratio, '0x48a170391f7dc42444e8fa2')
78
+
79
+ if (tick > 0) ratio = MaxUint256 / ratio
80
+
81
+ // back to Q96
82
+ return ratio % Q32 > Zero ? ratio / Q32 + BigInt(1) : ratio / Q32
83
+ }
84
+
85
+ function getAmount0Delta(sqrtRatioAX96: bigint, sqrtRatioBX96: bigint, liquidity: bigint): bigint {
86
+ if (sqrtRatioAX96 > sqrtRatioBX96) {
87
+ sqrtRatioAX96 = sqrtRatioBX96
88
+ sqrtRatioBX96 = sqrtRatioAX96
89
+ }
90
+
91
+ const numerator1 = liquidity << BigInt(96)
92
+ const numerator2 = sqrtRatioBX96 - sqrtRatioAX96
93
+
94
+ return (numerator1 * numerator2) / sqrtRatioBX96 / sqrtRatioAX96
95
+ }
96
+
97
+ function getAmount1Delta(sqrtRatioAX96: bigint, sqrtRatioBX96: bigint, liquidity: bigint): bigint {
98
+ if (sqrtRatioAX96 > sqrtRatioBX96) {
99
+ sqrtRatioAX96 = sqrtRatioBX96
100
+ sqrtRatioBX96 = sqrtRatioAX96
101
+ }
102
+
103
+ return (liquidity * (sqrtRatioBX96 - sqrtRatioAX96)) / Q96
104
+ }
105
+
106
+ export function getToken0Amount(
107
+ tickCurrent: number,
108
+ tickLower: number,
109
+ tickUpper: number,
110
+ sqrtRatioX96: bigint,
111
+ liquidity: bigint,
112
+ ): bigint {
113
+ if (Number.isNaN(tickCurrent) || Number.isNaN(tickLower) || Number.isNaN(tickUpper) || !sqrtRatioX96 || !liquidity) {
114
+ return Zero
115
+ }
116
+ if (tickCurrent < tickLower) {
117
+ return getAmount0Delta(getSqrtRatioAtTick(tickLower), getSqrtRatioAtTick(tickUpper), liquidity)
118
+ }
119
+ if (tickCurrent < tickUpper) {
120
+ return getAmount0Delta(sqrtRatioX96, getSqrtRatioAtTick(tickUpper), liquidity)
121
+ }
122
+ return Zero
123
+ }
124
+
125
+ export function getToken1Amount(
126
+ tickCurrent: number,
127
+ tickLower: number,
128
+ tickUpper: number,
129
+ sqrtRatioX96: bigint,
130
+ liquidity: bigint,
131
+ ): bigint {
132
+ if (Number.isNaN(tickCurrent) || Number.isNaN(tickLower) || Number.isNaN(tickUpper) || !sqrtRatioX96 || !liquidity) {
133
+ return Zero
134
+ }
135
+ if (tickCurrent < tickLower) {
136
+ return Zero
137
+ }
138
+ if (tickCurrent < tickUpper) {
139
+ return getAmount1Delta(getSqrtRatioAtTick(tickLower), sqrtRatioX96, liquidity)
140
+ }
141
+ return getAmount1Delta(getSqrtRatioAtTick(tickLower), getSqrtRatioAtTick(tickUpper), liquidity)
142
+ }
143
+
144
+ export function getFarmApr({ poolWeight, tvlUsd, cakePriceUsd, cakePerSecond }: FarmAprParams) {
145
+ if (!poolWeight || !tvlUsd || !cakePriceUsd || !cakePerSecond) {
146
+ return 0
147
+ }
148
+
149
+ const cakeRewardPerYear = cakePerSecond * ONE_YEAR
150
+ const farmApr = ((poolWeight * cakeRewardPerYear * cakePriceUsd) / tvlUsd) * 100
151
+
152
+ return farmApr
153
+ }
154
+
155
+ export function getPositionFarmAprFactor({
156
+ poolWeight,
157
+ cakePriceUsd,
158
+ cakePerSecond,
159
+ liquidity,
160
+ totalStakedLiquidity,
161
+ }: Omit<PositionFarmAprParams, 'positionTvlUsd' | 'precision' | 'tickCurrent' | 'tickLower' | 'tickUpper'>) {
162
+ if (
163
+ !poolWeight ||
164
+ !cakePriceUsd ||
165
+ !cakePerSecond ||
166
+ BigInt(liquidity) === Zero ||
167
+ BigInt(totalStakedLiquidity) === Zero
168
+ ) {
169
+ return 0
170
+ }
171
+
172
+ const cakeRewardPerYear = cakePerSecond * ONE_YEAR
173
+ const aprFactor =
174
+ ((poolWeight * cakeRewardPerYear * cakePriceUsd) /
175
+ Number(formatUnits(BigInt(liquidity) + BigInt(totalStakedLiquidity), 18))) *
176
+ 100
177
+
178
+ return aprFactor
179
+ }
180
+
181
+ export function getPositionFarmApr({
182
+ poolWeight,
183
+ positionTvlUsd,
184
+ cakePriceUsd,
185
+ cakePerSecond,
186
+ liquidity,
187
+ totalStakedLiquidity,
188
+ tickCurrent,
189
+ tickLower,
190
+ tickUpper,
191
+ }: PositionFarmAprParams) {
192
+ if (tickCurrent < tickLower || tickCurrent >= tickUpper) {
193
+ return 0
194
+ }
195
+
196
+ const aprFactor = getPositionFarmAprFactor({
197
+ poolWeight,
198
+ cakePriceUsd,
199
+ cakePerSecond,
200
+ liquidity,
201
+ totalStakedLiquidity,
202
+ })
203
+
204
+ if (!aprFactor || !positionTvlUsd) {
205
+ return 0
206
+ }
207
+
208
+ const positionApr = (aprFactor * Number(formatUnits(liquidity, 18))) / positionTvlUsd
209
+
210
+ return positionApr
211
+ }
212
+
213
+ const POWERS_OF_2 = [128, 64, 32, 16, 8, 4, 2, 1].map((pow: number): [number, bigint] => [pow, BigInt(2 ** pow)])
214
+
215
+ export function mostSignificantBit(x: bigint): number {
216
+ let msb = 0
217
+ for (const [power, min] of POWERS_OF_2) {
218
+ if (x >= min) {
219
+ // eslint-disable-next-line operator-assignment
220
+ x = x >> BigInt(power)
221
+ msb += power
222
+ }
223
+ }
224
+ return msb
225
+ }
226
+
227
+ function getTickAtSqrtRatio(sqrtRatioX96: bigint): number {
228
+ const sqrtRatioX128 = sqrtRatioX96 << BigInt(32)
229
+
230
+ const msb = mostSignificantBit(sqrtRatioX128)
231
+
232
+ let r: bigint
233
+ if (BigInt(msb) >= BigInt(128)) {
234
+ r = sqrtRatioX128 >> BigInt(msb - 127)
235
+ } else {
236
+ r = sqrtRatioX128 << BigInt(127 - msb)
237
+ }
238
+
239
+ let log_2: bigint = (BigInt(msb) - BigInt(128)) << BigInt(64)
240
+
241
+ for (let i = 0; i < 14; i++) {
242
+ r = (r * r) >> BigInt(127)
243
+ const f = r >> BigInt(128)
244
+ // eslint-disable-next-line operator-assignment
245
+ log_2 = log_2 | (f << BigInt(63 - i))
246
+ // eslint-disable-next-line operator-assignment
247
+ r = r >> f
248
+ }
249
+
250
+ const log_sqrt10001 = log_2 * parseUnits('255738958999603826347141', 0)
251
+
252
+ const tickLow = Number((log_sqrt10001 - parseUnits('3402992956809132418596140100660247210', 0)) >> BigInt(128))
253
+ const tickHigh = Number((log_sqrt10001 + parseUnits('291339464771989622907027621153398088495', 0)) >> BigInt(128))
254
+
255
+ return tickLow === tickHigh ? tickLow : getSqrtRatioAtTick(tickHigh) <= sqrtRatioX96 ? tickHigh : tickLow
256
+ }
257
+
258
+ function getEstimatedLPFeeByAmount({
259
+ fees24H,
260
+ sqrtRatioX96,
261
+ tickLower,
262
+ tickUpper,
263
+ mostActiveLiquidity,
264
+ liquidity,
265
+ }: EstimateFeeOptions): number {
266
+ const tickCurrent = getTickAtSqrtRatio(sqrtRatioX96)
267
+ if (tickCurrent < tickLower || tickCurrent >= tickUpper) {
268
+ return 0
269
+ }
270
+
271
+ if (!liquidity) {
272
+ return 0
273
+ }
274
+
275
+ return (100 * fees24H * Number(formatUnits(liquidity, 18))) / Number(formatUnits(liquidity + mostActiveLiquidity, 18))
276
+ }
277
+
278
+ export function getPositionTradingFee({
279
+ fees24H,
280
+ sqrtRatioX96,
281
+ tickLower,
282
+ tickUpper,
283
+ mostActiveLiquidity,
284
+ liquidity,
285
+ positionUSD,
286
+ }): number {
287
+ const fees24HPosition = getEstimatedLPFeeByAmount({
288
+ fees24H,
289
+ sqrtRatioX96,
290
+ tickLower,
291
+ tickUpper,
292
+ mostActiveLiquidity,
293
+ liquidity,
294
+ })
295
+
296
+ return (positionUSD + fees24HPosition * 365) / positionUSD - 1
297
+ }
298
+
299
+ export function tickToPrice(tick: number, precision = 6): number {
300
+ const sqrtRatioX96 = getSqrtRatioAtTick(tick)
301
+
302
+ const ratioX192 = sqrtRatioX96 * sqrtRatioX96
303
+
304
+ return Number((ratioX192 * BigInt(10 ** precision)) / Q192) / 10 ** precision
305
+ }
@@ -0,0 +1,93 @@
1
+ import dayjs from 'dayjs'
2
+ import utc from 'dayjs/plugin/utc.js'
3
+ import { chunk } from 'lodash-es'
4
+ import { encodeAbiParameters, parseAbiParameters } from 'viem'
5
+ import { buildPendleStrats } from '../../bytecodes/index.js'
6
+ import { batchJsonRpc, equalTlc } from '../../utils.js'
7
+ import { concatBytecode } from '../utils/index.js'
8
+
9
+ dayjs.extend(utc)
10
+
11
+ interface VaultAndLp {
12
+ vault: string
13
+ lpToken: string
14
+ }
15
+
16
+ const formatCoin = (data: any) => ({
17
+ address: data.address,
18
+ name: data.name,
19
+ symbol: data.symbol,
20
+ decimals: data.decimals,
21
+ })
22
+
23
+ export const buildPendleStrategies = async (
24
+ rpc: string,
25
+ vaultsAndLps: VaultAndLp[],
26
+ pendleApiData: any[],
27
+ chainId: number,
28
+ ) => {
29
+ const strats = vaultsAndLps.map((vlp) => {
30
+ const pendleMarketApiData = pendleApiData.find((d) => equalTlc(d.address, vlp.lpToken))
31
+ const sy = pendleMarketApiData.sy
32
+
33
+ const coin = formatCoin(pendleMarketApiData.underlyingAsset)
34
+ const underlyingCoin = formatCoin(pendleMarketApiData.accountingAsset)
35
+ const underlyingReward = formatCoin(pendleMarketApiData.basePricingAsset)
36
+
37
+ const expiryDayJs = dayjs(pendleMarketApiData.expiry).utc()
38
+
39
+ return {
40
+ key: `pendle_${sy.proSymbol.toLowerCase()}_${expiryDayJs.format('DD_MM_YYYY')}`,
41
+ name: sy.proSymbol,
42
+ subname: expiryDayJs.format('DD/MM/YYYY'),
43
+ protocol: 'pendle',
44
+ expiry: expiryDayJs.unix(),
45
+ chainId,
46
+ vault: vlp.vault,
47
+ lpToken: {
48
+ name: `${sy.proName} Pendle Market`,
49
+ symbol: `${sy.proSymbol} PENDLE LP`,
50
+ address: vlp.lpToken,
51
+ decimals: pendleMarketApiData.lp.decimals,
52
+ },
53
+ coins: [coin],
54
+ underlyingCoins: [underlyingCoin],
55
+ underlyingReward,
56
+ syToken: sy.address,
57
+ }
58
+ })
59
+
60
+ const inputsChunks = chunk(
61
+ strats.map((data) => [data.vault, data.lpToken.address]),
62
+ 30,
63
+ )
64
+
65
+ const pendleCalls = inputsChunks.map((inputParams) => {
66
+ const inputData = encodeAbiParameters(parseAbiParameters(buildPendleStrats.inputType[chainId]!) as any, [
67
+ inputParams,
68
+ ])
69
+ return concatBytecode(buildPendleStrats.bytecode[chainId]!, inputData)
70
+ })
71
+
72
+ const pendleData = await batchJsonRpc({
73
+ rpc,
74
+ calls: pendleCalls,
75
+ outputTypeAbi: buildPendleStrats.outputTypeHr[chainId],
76
+ callsKey: 'Build Pendle Strategies',
77
+ })
78
+
79
+ return strats.map((s) => {
80
+ const stratData = pendleData.find((d) => equalTlc(d.lpt, s.lpToken.address))
81
+
82
+ return {
83
+ ...s,
84
+ sdGauge: stratData.sdGauge,
85
+ rewards: stratData.rewards.map((r) => ({
86
+ name: r._name,
87
+ symbol: r._symbol,
88
+ address: r._address,
89
+ decimals: Number(r._decimals),
90
+ })),
91
+ }
92
+ })
93
+ }