@subwallet/extension-base 1.1.31-beta.0 → 1.1.32-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 (307) hide show
  1. package/background/KoniTypes.d.ts +69 -111
  2. package/background/KoniTypes.js +13 -19
  3. package/background/errors/TransactionError.js +0 -9
  4. package/cjs/background/KoniTypes.js +16 -20
  5. package/cjs/background/errors/TransactionError.js +0 -9
  6. package/cjs/constants/index.js +4 -19
  7. package/cjs/koni/api/nft/config.js +23 -33
  8. package/cjs/koni/api/nft/index.js +0 -14
  9. package/cjs/koni/api/nft/nft.js +22 -1
  10. package/cjs/koni/api/staking/bonding/amplitude.js +15 -17
  11. package/cjs/koni/api/staking/bonding/astar.js +10 -11
  12. package/cjs/koni/api/staking/bonding/index.js +3 -4
  13. package/cjs/koni/api/staking/bonding/paraChain.js +29 -28
  14. package/cjs/koni/api/staking/bonding/relayChain.js +45 -48
  15. package/cjs/koni/api/staking/bonding/utils.js +86 -104
  16. package/cjs/koni/api/staking/index.js +5 -6
  17. package/cjs/koni/api/staking/paraChain.js +5 -6
  18. package/cjs/koni/api/staking/relayChain.js +2 -3
  19. package/cjs/koni/background/cron.js +1 -11
  20. package/cjs/koni/background/handlers/Extension.js +69 -362
  21. package/cjs/koni/background/handlers/State.js +3 -51
  22. package/cjs/koni/background/handlers/index.js +2 -4
  23. package/cjs/koni/background/subscription.js +37 -95
  24. package/cjs/packageInfo.js +1 -1
  25. package/cjs/services/campaign-service/index.js +6 -9
  26. package/cjs/services/chain-service/constants.js +18 -3
  27. package/cjs/services/chain-service/index.js +2 -3
  28. package/cjs/services/chain-service/utils.js +1 -7
  29. package/cjs/services/event-service/index.js +0 -4
  30. package/cjs/services/keyring-service/index.js +2 -14
  31. package/cjs/services/migration-service/scripts/MigrateLedgerAccount.js +1 -1
  32. package/cjs/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
  33. package/cjs/services/migration-service/scripts/index.js +1 -7
  34. package/cjs/services/notification-service/NotificationService.js +1 -1
  35. package/cjs/services/storage-service/DatabaseService.js +0 -51
  36. package/cjs/services/storage-service/databases/index.js +0 -4
  37. package/cjs/services/storage-service/db-stores/NominatorMetadata.js +3 -3
  38. package/cjs/services/subscan-service/index.js +0 -16
  39. package/cjs/services/transaction-service/event-parser/index.js +0 -58
  40. package/cjs/services/transaction-service/helpers/index.js +1 -3
  41. package/cjs/services/transaction-service/index.js +75 -231
  42. package/cjs/services/transaction-service/utils.js +0 -1
  43. package/cjs/types/index.js +0 -44
  44. package/cjs/utils/fetchStaticData.js +1 -2
  45. package/cjs/utils/index.js +1 -89
  46. package/cjs/utils/number.js +1 -3
  47. package/constants/index.d.ts +1 -6
  48. package/constants/index.js +1 -6
  49. package/koni/api/nft/config.js +23 -33
  50. package/koni/api/nft/index.js +1 -15
  51. package/koni/api/nft/nft.js +23 -2
  52. package/koni/api/staking/bonding/amplitude.js +9 -11
  53. package/koni/api/staking/bonding/astar.js +8 -9
  54. package/koni/api/staking/bonding/index.d.ts +2 -1
  55. package/koni/api/staking/bonding/index.js +3 -5
  56. package/koni/api/staking/bonding/paraChain.js +16 -15
  57. package/koni/api/staking/bonding/relayChain.d.ts +2 -2
  58. package/koni/api/staking/bonding/relayChain.js +30 -33
  59. package/koni/api/staking/bonding/utils.d.ts +38 -15
  60. package/koni/api/staking/bonding/utils.js +69 -85
  61. package/koni/api/staking/index.js +1 -2
  62. package/koni/api/staking/paraChain.js +6 -7
  63. package/koni/api/staking/relayChain.js +3 -4
  64. package/koni/background/cron.d.ts +0 -1
  65. package/koni/background/cron.js +2 -12
  66. package/koni/background/handlers/Extension.d.ts +1 -17
  67. package/koni/background/handlers/Extension.js +30 -321
  68. package/koni/background/handlers/State.d.ts +2 -18
  69. package/koni/background/handlers/State.js +3 -50
  70. package/koni/background/handlers/index.js +2 -4
  71. package/koni/background/subscription.d.ts +1 -6
  72. package/koni/background/subscription.js +38 -97
  73. package/package.json +8 -321
  74. package/packageInfo.js +1 -1
  75. package/services/campaign-service/index.js +6 -9
  76. package/services/chain-service/constants.d.ts +11 -0
  77. package/services/chain-service/constants.js +16 -2
  78. package/services/chain-service/index.js +2 -3
  79. package/services/chain-service/utils.d.ts +0 -1
  80. package/services/chain-service/utils.js +1 -5
  81. package/services/event-service/index.d.ts +0 -1
  82. package/services/event-service/index.js +0 -4
  83. package/services/event-service/types.d.ts +0 -8
  84. package/services/keyring-service/index.d.ts +1 -2
  85. package/services/keyring-service/index.js +2 -14
  86. package/services/migration-service/scripts/MigrateLedgerAccount.js +1 -1
  87. package/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
  88. package/services/migration-service/scripts/index.js +1 -7
  89. package/services/notification-service/NotificationService.js +1 -1
  90. package/services/storage-service/DatabaseService.d.ts +1 -18
  91. package/services/storage-service/DatabaseService.js +0 -51
  92. package/services/storage-service/databases/index.d.ts +1 -3
  93. package/services/storage-service/databases/index.js +0 -4
  94. package/services/storage-service/db-stores/NominatorMetadata.js +3 -3
  95. package/services/subscan-service/index.d.ts +2 -3
  96. package/services/subscan-service/index.js +0 -15
  97. package/services/subscan-service/types.d.ts +0 -20
  98. package/services/transaction-service/event-parser/index.d.ts +1 -3
  99. package/services/transaction-service/event-parser/index.js +1 -57
  100. package/services/transaction-service/helpers/index.js +1 -3
  101. package/services/transaction-service/index.d.ts +15 -4
  102. package/services/transaction-service/index.js +73 -229
  103. package/services/transaction-service/types.d.ts +0 -2
  104. package/services/transaction-service/utils.js +0 -1
  105. package/types/index.d.ts +0 -5
  106. package/types/index.js +1 -5
  107. package/utils/fetchStaticData.js +1 -2
  108. package/utils/index.d.ts +0 -5
  109. package/utils/index.js +1 -53
  110. package/utils/number.d.ts +1 -1
  111. package/utils/number.js +1 -1
  112. package/cjs/koni/api/dotsama/balance.js +0 -464
  113. package/cjs/koni/api/nft/ordinal_nft/constants.js +0 -21
  114. package/cjs/koni/api/nft/ordinal_nft/index.js +0 -121
  115. package/cjs/koni/api/nft/ordinal_nft/utils.js +0 -41
  116. package/cjs/koni/api/yield/helper/utils.js +0 -46
  117. package/cjs/services/earning-service/constants/chains.js +0 -29
  118. package/cjs/services/earning-service/constants/index.js +0 -27
  119. package/cjs/services/earning-service/constants/step.js +0 -18
  120. package/cjs/services/earning-service/handlers/base.js +0 -259
  121. package/cjs/services/earning-service/handlers/index.js +0 -60
  122. package/cjs/services/earning-service/handlers/lending/base.js +0 -20
  123. package/cjs/services/earning-service/handlers/lending/index.js +0 -13
  124. package/cjs/services/earning-service/handlers/lending/interlay.js +0 -191
  125. package/cjs/services/earning-service/handlers/liquid-staking/acala.js +0 -239
  126. package/cjs/services/earning-service/handlers/liquid-staking/base.js +0 -43
  127. package/cjs/services/earning-service/handlers/liquid-staking/bifrost.js +0 -297
  128. package/cjs/services/earning-service/handlers/liquid-staking/index.js +0 -34
  129. package/cjs/services/earning-service/handlers/liquid-staking/parallel.js +0 -226
  130. package/cjs/services/earning-service/handlers/liquid-staking/stella-swap.js +0 -395
  131. package/cjs/services/earning-service/handlers/native-staking/amplitude.js +0 -384
  132. package/cjs/services/earning-service/handlers/native-staking/astar.js +0 -461
  133. package/cjs/services/earning-service/handlers/native-staking/base-para.js +0 -146
  134. package/cjs/services/earning-service/handlers/native-staking/base.js +0 -159
  135. package/cjs/services/earning-service/handlers/native-staking/index.js +0 -34
  136. package/cjs/services/earning-service/handlers/native-staking/para-chain.js +0 -385
  137. package/cjs/services/earning-service/handlers/native-staking/relay-chain.js +0 -558
  138. package/cjs/services/earning-service/handlers/nomination-pool/index.js +0 -560
  139. package/cjs/services/earning-service/handlers/special.js +0 -503
  140. package/cjs/services/earning-service/service.js +0 -387
  141. package/cjs/services/earning-service/utils/index.js +0 -128
  142. package/cjs/services/migration-service/scripts/DeleteEarningData.js +0 -21
  143. package/cjs/services/migration-service/scripts/EnableEarningChains.js +0 -21
  144. package/cjs/services/migration-service/scripts/MigrateEthProvider.js +0 -17
  145. package/cjs/services/migration-service/scripts/MigratePioneerProvider.js +0 -17
  146. package/cjs/services/migration-service/scripts/MigrateProvider.js +0 -29
  147. package/cjs/services/migration-service/scripts/databases/MigrateEarningHistory.js +0 -21
  148. package/cjs/services/migration-service/scripts/databases/MigrateEarningVersion.js +0 -21
  149. package/cjs/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +0 -149
  150. package/cjs/services/mint-campaign-service/campaigns/index.js +0 -13
  151. package/cjs/services/mint-campaign-service/constants.js +0 -11
  152. package/cjs/services/mint-campaign-service/index.js +0 -18
  153. package/cjs/services/storage-service/db-stores/YieldPoolStore.js +0 -36
  154. package/cjs/services/storage-service/db-stores/YieldPositionStore.js +0 -65
  155. package/cjs/services/storage-service/index.js +0 -241
  156. package/cjs/types/campaigns/index.js +0 -16
  157. package/cjs/types/campaigns/unlock-dot.js +0 -1
  158. package/cjs/types/ordinal.js +0 -1
  159. package/cjs/types/transaction.js +0 -1
  160. package/cjs/types/yield/actions/index.js +0 -27
  161. package/cjs/types/yield/actions/join/index.js +0 -38
  162. package/cjs/types/yield/actions/join/step.js +0 -47
  163. package/cjs/types/yield/actions/join/submit.js +0 -1
  164. package/cjs/types/yield/actions/join/validate.js +0 -16
  165. package/cjs/types/yield/actions/others.js +0 -1
  166. package/cjs/types/yield/index.js +0 -27
  167. package/cjs/types/yield/info/account/index.js +0 -49
  168. package/cjs/types/yield/info/account/info.js +0 -1
  169. package/cjs/types/yield/info/account/reward.js +0 -1
  170. package/cjs/types/yield/info/account/target.js +0 -32
  171. package/cjs/types/yield/info/account/unstake.js +0 -27
  172. package/cjs/types/yield/info/base.js +0 -41
  173. package/cjs/types/yield/info/chain/index.js +0 -27
  174. package/cjs/types/yield/info/chain/info.js +0 -1
  175. package/cjs/types/yield/info/chain/target.js +0 -1
  176. package/cjs/types/yield/info/index.js +0 -49
  177. package/cjs/types/yield/info/pallet.js +0 -15
  178. package/cjs/types.js +0 -1
  179. package/cjs/utils/address.js +0 -34
  180. package/cjs/utils/keyring.js +0 -57
  181. package/cjs/utils/object.js +0 -12
  182. package/koni/api/nft/ordinal_nft/constants.d.ts +0 -9
  183. package/koni/api/nft/ordinal_nft/constants.js +0 -12
  184. package/koni/api/nft/ordinal_nft/index.d.ts +0 -8
  185. package/koni/api/nft/ordinal_nft/index.js +0 -114
  186. package/koni/api/nft/ordinal_nft/utils.d.ts +0 -2
  187. package/koni/api/nft/ordinal_nft/utils.js +0 -33
  188. package/koni/api/yield/helper/utils.d.ts +0 -10
  189. package/koni/api/yield/helper/utils.js +0 -32
  190. package/services/earning-service/constants/abis/compound_finance_v2_abi.json +0 -1235
  191. package/services/earning-service/constants/abis/st_liquid_token_abi.json +0 -1355
  192. package/services/earning-service/constants/chains.d.ts +0 -14
  193. package/services/earning-service/constants/chains.js +0 -21
  194. package/services/earning-service/constants/index.d.ts +0 -2
  195. package/services/earning-service/constants/index.js +0 -5
  196. package/services/earning-service/constants/step.d.ts +0 -3
  197. package/services/earning-service/constants/step.js +0 -10
  198. package/services/earning-service/handlers/base.d.ts +0 -112
  199. package/services/earning-service/handlers/base.js +0 -253
  200. package/services/earning-service/handlers/index.d.ts +0 -5
  201. package/services/earning-service/handlers/index.js +0 -8
  202. package/services/earning-service/handlers/lending/base.d.ts +0 -6
  203. package/services/earning-service/handlers/lending/base.js +0 -12
  204. package/services/earning-service/handlers/lending/index.d.ts +0 -1
  205. package/services/earning-service/handlers/lending/index.js +0 -4
  206. package/services/earning-service/handlers/lending/interlay.d.ts +0 -24
  207. package/services/earning-service/handlers/lending/interlay.js +0 -183
  208. package/services/earning-service/handlers/liquid-staking/acala.d.ts +0 -27
  209. package/services/earning-service/handlers/liquid-staking/acala.js +0 -231
  210. package/services/earning-service/handlers/liquid-staking/base.d.ts +0 -9
  211. package/services/earning-service/handlers/liquid-staking/base.js +0 -35
  212. package/services/earning-service/handlers/liquid-staking/bifrost.d.ts +0 -46
  213. package/services/earning-service/handlers/liquid-staking/bifrost.js +0 -286
  214. package/services/earning-service/handlers/liquid-staking/index.d.ts +0 -4
  215. package/services/earning-service/handlers/liquid-staking/index.js +0 -7
  216. package/services/earning-service/handlers/liquid-staking/parallel.d.ts +0 -26
  217. package/services/earning-service/handlers/liquid-staking/parallel.js +0 -218
  218. package/services/earning-service/handlers/liquid-staking/stella-swap.d.ts +0 -34
  219. package/services/earning-service/handlers/liquid-staking/stella-swap.js +0 -385
  220. package/services/earning-service/handlers/native-staking/amplitude.d.ts +0 -22
  221. package/services/earning-service/handlers/native-staking/amplitude.js +0 -375
  222. package/services/earning-service/handlers/native-staking/astar.d.ts +0 -19
  223. package/services/earning-service/handlers/native-staking/astar.js +0 -451
  224. package/services/earning-service/handlers/native-staking/base-para.d.ts +0 -11
  225. package/services/earning-service/handlers/native-staking/base-para.js +0 -138
  226. package/services/earning-service/handlers/native-staking/base.d.ts +0 -21
  227. package/services/earning-service/handlers/native-staking/base.js +0 -150
  228. package/services/earning-service/handlers/native-staking/index.d.ts +0 -4
  229. package/services/earning-service/handlers/native-staking/index.js +0 -7
  230. package/services/earning-service/handlers/native-staking/para-chain.d.ts +0 -15
  231. package/services/earning-service/handlers/native-staking/para-chain.js +0 -377
  232. package/services/earning-service/handlers/native-staking/relay-chain.d.ts +0 -21
  233. package/services/earning-service/handlers/native-staking/relay-chain.js +0 -549
  234. package/services/earning-service/handlers/nomination-pool/index.d.ts +0 -36
  235. package/services/earning-service/handlers/nomination-pool/index.js +0 -550
  236. package/services/earning-service/handlers/special.d.ts +0 -65
  237. package/services/earning-service/handlers/special.js +0 -495
  238. package/services/earning-service/service.d.ts +0 -45
  239. package/services/earning-service/service.js +0 -379
  240. package/services/earning-service/utils/index.d.ts +0 -18
  241. package/services/earning-service/utils/index.js +0 -112
  242. package/services/migration-service/scripts/DeleteEarningData.d.ts +0 -4
  243. package/services/migration-service/scripts/DeleteEarningData.js +0 -13
  244. package/services/migration-service/scripts/EnableEarningChains.d.ts +0 -4
  245. package/services/migration-service/scripts/EnableEarningChains.js +0 -13
  246. package/services/migration-service/scripts/databases/MigrateEarningHistory.d.ts +0 -4
  247. package/services/migration-service/scripts/databases/MigrateEarningHistory.js +0 -13
  248. package/services/migration-service/scripts/databases/MigrateEarningVersion.d.ts +0 -4
  249. package/services/migration-service/scripts/databases/MigrateEarningVersion.js +0 -13
  250. package/services/mint-campaign-service/campaigns/UnlockDotCampaign.d.ts +0 -13
  251. package/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +0 -139
  252. package/services/mint-campaign-service/campaigns/index.d.ts +0 -1
  253. package/services/mint-campaign-service/campaigns/index.js +0 -4
  254. package/services/mint-campaign-service/constants.d.ts +0 -1
  255. package/services/mint-campaign-service/constants.js +0 -4
  256. package/services/mint-campaign-service/index.d.ts +0 -7
  257. package/services/mint-campaign-service/index.js +0 -11
  258. package/services/storage-service/db-stores/YieldPoolStore.d.ts +0 -10
  259. package/services/storage-service/db-stores/YieldPoolStore.js +0 -28
  260. package/services/storage-service/db-stores/YieldPositionStore.d.ts +0 -9
  261. package/services/storage-service/db-stores/YieldPositionStore.js +0 -57
  262. package/types/campaigns/index.d.ts +0 -1
  263. package/types/campaigns/index.js +0 -4
  264. package/types/campaigns/unlock-dot.d.ts +0 -71
  265. package/types/campaigns/unlock-dot.js +0 -1
  266. package/types/ordinal.d.ts +0 -69
  267. package/types/ordinal.js +0 -1
  268. package/types/transaction.d.ts +0 -3
  269. package/types/transaction.js +0 -1
  270. package/types/yield/actions/index.d.ts +0 -2
  271. package/types/yield/actions/index.js +0 -5
  272. package/types/yield/actions/join/index.d.ts +0 -3
  273. package/types/yield/actions/join/index.js +0 -6
  274. package/types/yield/actions/join/step.d.ts +0 -95
  275. package/types/yield/actions/join/step.js +0 -46
  276. package/types/yield/actions/join/submit.d.ts +0 -57
  277. package/types/yield/actions/join/submit.js +0 -1
  278. package/types/yield/actions/join/validate.d.ts +0 -18
  279. package/types/yield/actions/join/validate.js +0 -10
  280. package/types/yield/actions/others.d.ts +0 -85
  281. package/types/yield/actions/others.js +0 -1
  282. package/types/yield/index.d.ts +0 -2
  283. package/types/yield/index.js +0 -5
  284. package/types/yield/info/account/index.d.ts +0 -4
  285. package/types/yield/info/account/index.js +0 -7
  286. package/types/yield/info/account/info.d.ts +0 -92
  287. package/types/yield/info/account/info.js +0 -1
  288. package/types/yield/info/account/reward.d.ts +0 -45
  289. package/types/yield/info/account/reward.js +0 -1
  290. package/types/yield/info/account/target.d.ts +0 -43
  291. package/types/yield/info/account/target.js +0 -27
  292. package/types/yield/info/account/unstake.d.ts +0 -31
  293. package/types/yield/info/account/unstake.js +0 -22
  294. package/types/yield/info/base.d.ts +0 -45
  295. package/types/yield/info/base.js +0 -36
  296. package/types/yield/info/chain/index.d.ts +0 -2
  297. package/types/yield/info/chain/index.js +0 -5
  298. package/types/yield/info/chain/info.d.ts +0 -251
  299. package/types/yield/info/chain/info.js +0 -1
  300. package/types/yield/info/chain/target.d.ts +0 -37
  301. package/types/yield/info/chain/target.js +0 -1
  302. package/types/yield/info/index.d.ts +0 -4
  303. package/types/yield/info/index.js +0 -7
  304. package/types/yield/info/pallet.d.ts +0 -143
  305. package/types/yield/info/pallet.js +0 -9
  306. package/utils/object.d.ts +0 -1
  307. package/utils/object.js +0 -6
@@ -1,395 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.getStellaswapLiquidStakingContract = exports.default = void 0;
8
- var _TransactionError = require("@subwallet/extension-base/background/errors/TransactionError");
9
- var _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
10
- var _web = require("@subwallet/extension-base/koni/api/tokens/evm/web3");
11
- var _utils = require("@subwallet/extension-base/services/chain-service/utils");
12
- var _types = require("@subwallet/extension-base/types");
13
- var _eth = require("@subwallet/extension-base/utils/eth");
14
- var _crossFetch = _interopRequireDefault(require("cross-fetch"));
15
- var _util = require("@polkadot/util");
16
- var _constants = require("../../constants");
17
- var _base = _interopRequireDefault(require("./base"));
18
- // Copyright 2019-2022 @subwallet/extension-base
19
- // SPDX-License-Identifier: Apache-2.0
20
-
21
- const getStellaswapLiquidStakingContract = function (networkKey, assetAddress, evmApi) {
22
- let options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
23
- // @ts-ignore
24
- // eslint-disable-next-line @typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-member-access
25
- return new evmApi.api.eth.Contract(_constants.ST_LIQUID_TOKEN_ABI, assetAddress, options);
26
- };
27
- exports.getStellaswapLiquidStakingContract = getStellaswapLiquidStakingContract;
28
- const APR_STATS_URL = 'https://apr-api.stellaswap.com/api/v1/stdot';
29
- const SUBWALLET_REFERRAL = '0x7e6815f45E624768548d085231f2d453f16FD7DD';
30
- const MAX_INT = '115792089237316195423570985008687907853269984665640564039457584007913129639935';
31
- class StellaSwapLiquidStakingPoolHandler extends _base.default {
32
- inputAsset = 'moonbeam-LOCAL-xcDOT';
33
- altInputAsset = '';
34
- derivativeAssets = ['moonbeam-ERC20-stDOT-0xbc7E02c4178a7dF7d3E564323a5c359dc96C4db4'];
35
- rewardAssets = ['moonbeam-LOCAL-xcDOT'];
36
- feeAssets = ['moonbeam-NATIVE-GLMR'];
37
- transactionChainType = _KoniTypes.ChainType.EVM;
38
- rateDecimals = 10; // Derivative asset decimals
39
- availableMethod = {
40
- join: true,
41
- defaultUnstake: true,
42
- fastUnstake: false,
43
- cancelUnstake: false,
44
- withdraw: true,
45
- claimReward: false
46
- };
47
- constructor(state, chain) {
48
- super(state, chain);
49
- this.slug = 'xcDOT___liquid_staking___stellaswap';
50
- this.name = 'Stellaswap Liquid Staking';
51
- this._logo = 'stellaswap';
52
- this.shortName = 'Stellaswap';
53
- }
54
- getDescription() {
55
- return 'Earn rewards by staking xcDOT for stDOT';
56
- }
57
-
58
- /* Subscribe pool info */
59
-
60
- async getPoolStat() {
61
- const evmApi = this.evmApi;
62
- const derivativeTokenSlug = this.derivativeAssets[0];
63
- const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
64
- const stakingContract = getStellaswapLiquidStakingContract(this.chain, (0, _utils._getContractAddressOfToken)(derivativeTokenInfo), evmApi);
65
- const aprPromise = new Promise(function (resolve) {
66
- (0, _crossFetch.default)(APR_STATS_URL, {
67
- method: 'GET'
68
- }).then(res => {
69
- resolve(res.json());
70
- }).catch(console.error);
71
- });
72
- const sampleTokenShare = 10 ** (0, _utils._getAssetDecimals)(derivativeTokenInfo);
73
-
74
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
75
- const tvlCall = stakingContract.methods.fundRaisedBalance();
76
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
77
- const exchangeRateCall = stakingContract.methods.getPooledTokenByShares(sampleTokenShare);
78
-
79
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
80
- const [aprObject, tvl, equivalentTokenShare] = await Promise.all([aprPromise,
81
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
82
- tvlCall.call(),
83
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
84
- exchangeRateCall.call()]);
85
- const rate = equivalentTokenShare;
86
- const exchangeRate = rate / 10 ** (0, _utils._getAssetDecimals)(derivativeTokenInfo);
87
- this.updateExchangeRate(rate);
88
- return {
89
- ...this.baseInfo,
90
- type: this.type,
91
- metadata: {
92
- ...this.metadataInfo,
93
- description: this.getDescription()
94
- },
95
- statistic: {
96
- assetEarning: [{
97
- slug: this.rewardAssets[0],
98
- apr: aprObject.result,
99
- exchangeRate: exchangeRate
100
- }],
101
- unstakingPeriod: 24 * 28,
102
- maxCandidatePerFarmer: 1,
103
- maxWithdrawalRequestPerFarmer: 1,
104
- earningThreshold: {
105
- join: '0',
106
- defaultUnstake: '0',
107
- fastUnstake: '0'
108
- },
109
- totalApr: aprObject.result,
110
- tvl: tvl.toString()
111
- }
112
- };
113
- }
114
-
115
- /* Subscribe pool info */
116
-
117
- /* Subscribe pool position */
118
-
119
- // eslint-disable-next-line @typescript-eslint/require-await
120
- async subscribePoolPosition(useAddresses, resultCallback) {
121
- var _this$derivativeAsset;
122
- let cancel = false;
123
- const evmApi = this.evmApi;
124
- const derivativeTokenSlug = ((_this$derivativeAsset = this.derivativeAssets) === null || _this$derivativeAsset === void 0 ? void 0 : _this$derivativeAsset[0]) || '';
125
- const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
126
- const contract = getStellaswapLiquidStakingContract(this.chain, (0, _utils._getContractAddressOfToken)(derivativeTokenInfo), evmApi);
127
- const getTokenBalance = () => {
128
- if (!cancel) {
129
- useAddresses.map(async address => {
130
- if (cancel) {
131
- return;
132
- }
133
- const rate = await this.getExchangeRate();
134
- const exchangeRate = new _util.BN(rate);
135
- const decimals = _util.BN_TEN.pow(new _util.BN(this.rateDecimals));
136
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
137
- const balance = await contract.methods.balanceOf(address).call();
138
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
139
- const unbondedObject = await contract.methods.getUnbonded(address).call();
140
- const unstakings = [];
141
- let unlockBalance = _util.BN_ZERO;
142
- if (parseInt(unbondedObject.unbonded) > 0) {
143
- unlockBalance = unlockBalance.add(new _util.BN(unbondedObject.unbonded));
144
- unstakings.push({
145
- chain: this.chain,
146
- claimable: unbondedObject.unbonded,
147
- status: _types.UnstakingStatus.CLAIMABLE,
148
- waitingTime: 0
149
- });
150
- }
151
- if (parseInt(unbondedObject.waiting) > 0) {
152
- unlockBalance = unlockBalance.add(new _util.BN(unbondedObject.waiting));
153
- unstakings.push({
154
- chain: this.chain,
155
- claimable: unbondedObject.waiting,
156
- status: _types.UnstakingStatus.UNLOCKING
157
- });
158
- }
159
- const acviteToTotal = new _util.BN(balance).mul(exchangeRate).div(decimals);
160
- const totalBalance = acviteToTotal.add(unlockBalance);
161
- const result = {
162
- ...this.baseInfo,
163
- type: this.type,
164
- address,
165
- balanceToken: this.inputAsset,
166
- totalStake: totalBalance.toString(),
167
- activeStake: balance.toString(),
168
- unstakeBalance: unlockBalance.toString(),
169
- isBondedBefore: totalBalance.gt(_util.BN_ZERO),
170
- derivativeToken: derivativeTokenSlug,
171
- status: _types.EarningStatus.EARNING_REWARD,
172
- nominations: [],
173
- unstakings
174
- };
175
- resultCallback(result);
176
- });
177
- }
178
- };
179
- getTokenBalance();
180
- const interval = setInterval(getTokenBalance, 30000);
181
- return () => {
182
- cancel = true;
183
- clearInterval(interval);
184
- };
185
- }
186
-
187
- /* Subscribe pool position */
188
-
189
- /* Join pool action */
190
-
191
- get submitJoinStepInfo() {
192
- return {
193
- name: 'Mint stDOT',
194
- type: _types.YieldStepType.MINT_STDOT
195
- };
196
- }
197
- async getTokenApproveStep(params) {
198
- const evmApi = this.evmApi;
199
- const derivativeTokenSlug = this.derivativeAssets[0];
200
- const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
201
- const inputTokenSlug = this.inputAsset;
202
- const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
203
- const inputTokenContract = (0, _web.getERC20Contract)(this.chain, (0, _utils._getContractAddressOfToken)(inputTokenInfo), this.state.getEvmApiMap());
204
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
205
- const allowanceCall = inputTokenContract.methods.allowance(params.address, (0, _utils._getContractAddressOfToken)(derivativeTokenInfo));
206
- const [allowance, gasPrice] = await Promise.all([
207
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
208
- await allowanceCall.call(), evmApi.api.eth.getGasPrice()]);
209
- if (!allowance || parseInt(allowance) <= 0) {
210
- const step = {
211
- name: 'Authorize token approval',
212
- type: _types.YieldStepType.TOKEN_APPROVAL
213
- };
214
-
215
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
216
- const estimatedGas = await allowanceCall.estimateGas();
217
- const fee = {
218
- slug: this.feeAssets[0],
219
- amount: (estimatedGas * parseInt(gasPrice)).toString()
220
- };
221
- return [step, fee];
222
- }
223
- return undefined;
224
- }
225
- async getSubmitStepFee(params) {
226
- const evmApi = this.evmApi;
227
- const derivativeTokenSlug = this.derivativeAssets[0];
228
- const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
229
- if (new _util.BN(params.amount).gt(_util.BN_ZERO)) {
230
- const stakingContract = getStellaswapLiquidStakingContract(this.chain, (0, _utils._getContractAddressOfToken)(derivativeTokenInfo), evmApi);
231
-
232
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
233
- const depositCall = stakingContract.methods.deposit(params.amount);
234
-
235
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
236
- const estimatedDepositGas = await depositCall.estimateGas();
237
- const gasPrice = await evmApi.api.eth.getGasPrice();
238
- return {
239
- slug: this.feeAssets[0],
240
- amount: (estimatedDepositGas * parseInt(gasPrice)).toString()
241
- };
242
- } else {
243
- return {
244
- slug: this.feeAssets[0],
245
- amount: '0'
246
- };
247
- }
248
- }
249
- async validateTokenApproveStep(params, path) {
250
- return Promise.resolve([]);
251
- }
252
- async handleTokenApproveStep(data, path) {
253
- const {
254
- address
255
- } = data;
256
- const inputTokenSlug = this.inputAsset;
257
- const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
258
- const derivativeTokenInfo = this.state.getAssetBySlug(this.derivativeAssets[0]);
259
- const derivativeTokenContractAddress = (0, _utils._getContractAddressOfToken)(derivativeTokenInfo);
260
- const evmApi = this.evmApi;
261
- const inputTokenContract = (0, _web.getERC20Contract)(this.chain, (0, _utils._getContractAddressOfToken)(inputTokenInfo), this.state.getEvmApiMap());
262
-
263
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
264
- const approveCall = inputTokenContract.methods.approve(derivativeTokenContractAddress, MAX_INT); // TODO: need test
265
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
266
- const approveEncodedCall = approveCall.encodeABI();
267
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
268
- const gasLimit = await approveCall.estimateGas({
269
- from: address
270
- });
271
- const _price = await evmApi.api.eth.getGasPrice();
272
- const gasPrice = (0, _eth.recalculateGasPrice)(_price, this.chain);
273
- const transactionObject = {
274
- from: address,
275
- to: (0, _utils._getContractAddressOfToken)(inputTokenInfo),
276
- data: approveEncodedCall,
277
- gasPrice: gasPrice,
278
- gas: gasLimit
279
- };
280
- const _data = {
281
- inputTokenSlug: inputTokenSlug,
282
- spenderTokenSlug: this.derivativeAssets[0]
283
- };
284
- return Promise.resolve({
285
- txChain: this.chain,
286
- extrinsicType: _KoniTypes.ExtrinsicType.TOKEN_APPROVE,
287
- extrinsic: transactionObject,
288
- txData: _data,
289
- transferNativeAmount: '0'
290
- });
291
- }
292
- async handleSubmitStep(data, path) {
293
- const {
294
- address,
295
- amount
296
- } = data;
297
- const evmApi = this.evmApi;
298
- const derivativeTokenSlug = this.derivativeAssets[0];
299
- const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
300
- const stakingContract = getStellaswapLiquidStakingContract(this.chain, (0, _utils._getContractAddressOfToken)(derivativeTokenInfo), evmApi);
301
-
302
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
303
- const depositCall = stakingContract.methods.deposit(amount, SUBWALLET_REFERRAL); // TODO: need test
304
-
305
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
306
- const depositEncodedCall = depositCall.encodeABI();
307
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
308
- const gasLimit = await depositCall.estimateGas({
309
- from: address
310
- });
311
- const _price = await evmApi.api.eth.getGasPrice();
312
- const gasPrice = (0, _eth.recalculateGasPrice)(_price, this.chain);
313
- const transactionObject = {
314
- from: address,
315
- to: (0, _utils._getContractAddressOfToken)(derivativeTokenInfo),
316
- data: depositEncodedCall,
317
- gasPrice: gasPrice,
318
- gas: gasLimit
319
- };
320
- return {
321
- txChain: this.chain,
322
- extrinsicType: _KoniTypes.ExtrinsicType.MINT_STDOT,
323
- extrinsic: transactionObject,
324
- txData: data,
325
- transferNativeAmount: '0'
326
- };
327
- }
328
-
329
- /* Join pool action */
330
-
331
- /* Leave pool action */
332
-
333
- async handleYieldRedeem(amount, address, selectedTarget) {
334
- return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.UNSUPPORTED));
335
- }
336
- async handleYieldUnstake(amount, address, selectedTarget) {
337
- const evmApi = this.evmApi;
338
- const derivativeTokenSlug = this.derivativeAssets[0];
339
- const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
340
- const stakingContract = getStellaswapLiquidStakingContract(this.chain, (0, _utils._getContractAddressOfToken)(derivativeTokenInfo), evmApi);
341
-
342
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
343
- const redeemCall = stakingContract.methods.redeem(amount);
344
-
345
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
346
- const redeemEncodedCall = redeemCall.encodeABI();
347
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
348
- const gasLimit = await redeemCall.estimateGas({
349
- from: address
350
- });
351
- const _price = await evmApi.api.eth.getGasPrice();
352
- const gasPrice = (0, _eth.recalculateGasPrice)(_price, this.chain);
353
- const transaction = {
354
- from: address,
355
- to: (0, _utils._getContractAddressOfToken)(derivativeTokenInfo),
356
- data: redeemEncodedCall,
357
- gasPrice: gasPrice,
358
- gas: gasLimit
359
- };
360
- return [_KoniTypes.ExtrinsicType.UNSTAKE_STDOT, transaction];
361
- }
362
-
363
- /* Leave pool action */
364
-
365
- /* Other actions */
366
-
367
- async handleYieldWithdraw(address, unstakingInfo) {
368
- const evmApi = this.evmApi;
369
- const derivativeTokenSlug = this.derivativeAssets[0];
370
- const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
371
- const stakingContract = getStellaswapLiquidStakingContract(this.chain, (0, _utils._getContractAddressOfToken)(derivativeTokenInfo), evmApi);
372
-
373
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
374
- const withdrawCall = stakingContract.methods.claimUnbonded();
375
-
376
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
377
- const withdrawEncodedCall = withdrawCall.encodeABI();
378
- // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
379
- const gasLimit = await withdrawCall.estimateGas({
380
- from: address
381
- });
382
- const _price = await evmApi.api.eth.getGasPrice();
383
- const gasPrice = (0, _eth.recalculateGasPrice)(_price, this.chain);
384
- return {
385
- from: address,
386
- to: (0, _utils._getContractAddressOfToken)(derivativeTokenInfo),
387
- data: withdrawEncodedCall,
388
- gasPrice: gasPrice,
389
- gas: gasLimit
390
- }; // TODO: check tx history parsing
391
- }
392
-
393
- /* Other actions */
394
- }
395
- exports.default = StellaSwapLiquidStakingPoolHandler;