@subwallet/extension-base 1.1.28-0 → 1.1.28-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/background/KoniTypes.d.ts +92 -68
- package/background/KoniTypes.js +16 -13
- package/background/errors/TransactionError.js +9 -0
- package/cjs/background/KoniTypes.js +17 -16
- package/cjs/background/errors/TransactionError.js +9 -0
- package/cjs/constants/index.js +9 -3
- package/cjs/koni/api/dotsama/balance.js +464 -0
- package/cjs/koni/api/nft/config.js +33 -23
- package/cjs/koni/api/nft/index.js +14 -0
- package/cjs/koni/api/nft/nft.js +1 -22
- package/cjs/koni/api/nft/ordinal_nft/constants.js +21 -0
- package/cjs/koni/api/nft/ordinal_nft/index.js +121 -0
- package/cjs/koni/api/nft/ordinal_nft/utils.js +41 -0
- package/cjs/koni/api/staking/bonding/amplitude.js +17 -15
- package/cjs/koni/api/staking/bonding/astar.js +11 -10
- package/cjs/koni/api/staking/bonding/index.js +4 -1
- package/cjs/koni/api/staking/bonding/paraChain.js +25 -23
- package/cjs/koni/api/staking/bonding/relayChain.js +48 -45
- package/cjs/koni/api/staking/bonding/utils.js +104 -86
- package/cjs/koni/api/staking/index.js +6 -5
- package/cjs/koni/api/staking/paraChain.js +6 -5
- package/cjs/koni/api/staking/relayChain.js +3 -2
- package/cjs/koni/api/yield/helper/utils.js +46 -0
- package/cjs/koni/background/cron.js +2 -0
- package/cjs/koni/background/handlers/Extension.js +323 -69
- package/cjs/koni/background/handlers/State.js +57 -4
- package/cjs/koni/background/handlers/index.js +4 -2
- package/cjs/koni/background/subscription.js +89 -19
- package/cjs/packageInfo.js +1 -1
- package/cjs/services/campaign-service/index.js +9 -6
- package/cjs/services/chain-service/constants.js +2 -16
- package/cjs/services/chain-service/utils.js +7 -1
- package/cjs/services/earning-service/constants/chains.js +29 -0
- package/cjs/services/earning-service/constants/index.js +27 -0
- package/cjs/services/earning-service/constants/step.js +18 -0
- package/cjs/services/earning-service/handlers/base.js +202 -0
- package/cjs/services/earning-service/handlers/index.js +60 -0
- package/cjs/services/earning-service/handlers/lending/base.js +20 -0
- package/cjs/services/earning-service/handlers/lending/index.js +13 -0
- package/cjs/services/earning-service/handlers/lending/interlay.js +168 -0
- package/cjs/services/earning-service/handlers/liquid-staking/acala.js +196 -0
- package/cjs/services/earning-service/handlers/liquid-staking/base.js +39 -0
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost.js +257 -0
- package/cjs/services/earning-service/handlers/liquid-staking/index.js +34 -0
- package/cjs/services/earning-service/handlers/liquid-staking/parallel.js +180 -0
- package/cjs/services/earning-service/handlers/liquid-staking/stella-swap.js +373 -0
- package/cjs/services/earning-service/handlers/native-staking/amplitude.js +359 -0
- package/cjs/services/earning-service/handlers/native-staking/astar.js +426 -0
- package/cjs/services/earning-service/handlers/native-staking/base-para.js +137 -0
- package/cjs/services/earning-service/handlers/native-staking/base.js +109 -0
- package/cjs/services/earning-service/handlers/native-staking/index.js +34 -0
- package/cjs/services/earning-service/handlers/native-staking/para-chain.js +361 -0
- package/cjs/services/earning-service/handlers/native-staking/relay-chain.js +512 -0
- package/cjs/services/earning-service/handlers/nomination-pool/index.js +501 -0
- package/cjs/services/earning-service/handlers/special.js +387 -0
- package/cjs/services/earning-service/service.js +327 -0
- package/cjs/services/earning-service/utils/index.js +111 -0
- package/cjs/services/event-service/index.js +4 -0
- package/cjs/services/keyring-service/index.js +14 -2
- package/cjs/services/migration-service/scripts/DeleteEarningData.js +21 -0
- package/cjs/services/migration-service/scripts/EnableEarningChains.js +21 -0
- package/cjs/services/migration-service/scripts/MigrateEthProvider.js +17 -0
- package/cjs/services/migration-service/scripts/MigrateLedgerAccount.js +1 -1
- package/cjs/services/migration-service/scripts/MigratePioneerProvider.js +17 -0
- package/cjs/services/migration-service/scripts/MigrateProvider.js +29 -0
- package/cjs/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
- package/cjs/services/migration-service/scripts/index.js +4 -0
- package/cjs/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +149 -0
- package/cjs/services/mint-campaign-service/campaigns/index.js +13 -0
- package/cjs/services/mint-campaign-service/constants.js +11 -0
- package/cjs/services/mint-campaign-service/index.js +18 -0
- package/cjs/services/notification-service/NotificationService.js +1 -1
- package/cjs/services/storage-service/DatabaseService.js +47 -0
- package/cjs/services/storage-service/databases/index.js +4 -0
- package/cjs/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/cjs/services/storage-service/db-stores/YieldPoolStore.js +36 -0
- package/cjs/services/storage-service/db-stores/YieldPositionStore.js +65 -0
- package/cjs/services/storage-service/index.js +241 -0
- package/cjs/services/transaction-service/event-parser/index.js +58 -0
- package/cjs/services/transaction-service/helpers/index.js +3 -1
- package/cjs/services/transaction-service/index.js +180 -74
- package/cjs/services/transaction-service/utils.js +1 -0
- package/cjs/types/campaigns/index.js +16 -0
- package/cjs/types/campaigns/unlock-dot.js +1 -0
- package/cjs/types/index.js +44 -0
- package/cjs/types/ordinal.js +1 -0
- package/cjs/types/transaction.js +1 -0
- package/cjs/types/yield/actions/index.js +27 -0
- package/cjs/types/yield/actions/join/index.js +38 -0
- package/cjs/types/yield/actions/join/step.js +37 -0
- package/cjs/types/yield/actions/join/submit.js +1 -0
- package/cjs/types/yield/actions/join/validate.js +16 -0
- package/cjs/types/yield/actions/others.js +1 -0
- package/cjs/types/yield/index.js +27 -0
- package/cjs/types/yield/info/account/index.js +49 -0
- package/cjs/types/yield/info/account/info.js +1 -0
- package/cjs/types/yield/info/account/reward.js +1 -0
- package/cjs/types/yield/info/account/target.js +32 -0
- package/cjs/types/yield/info/account/unstake.js +27 -0
- package/cjs/types/yield/info/base.js +34 -0
- package/cjs/types/yield/info/chain/index.js +27 -0
- package/cjs/types/yield/info/chain/info.js +1 -0
- package/cjs/types/yield/info/chain/target.js +1 -0
- package/cjs/types/yield/info/index.js +49 -0
- package/cjs/types/yield/info/pallet.js +15 -0
- package/cjs/types.js +1 -0
- package/cjs/utils/address.js +34 -0
- package/cjs/utils/fetchStaticData.js +2 -1
- package/cjs/utils/index.js +89 -1
- package/cjs/utils/keyring.js +57 -0
- package/cjs/utils/object.js +12 -0
- package/constants/index.d.ts +2 -0
- package/constants/index.js +2 -0
- package/koni/api/nft/config.js +33 -23
- package/koni/api/nft/index.js +15 -1
- package/koni/api/nft/nft.js +2 -23
- package/koni/api/nft/ordinal_nft/constants.d.ts +9 -0
- package/koni/api/nft/ordinal_nft/constants.js +12 -0
- package/koni/api/nft/ordinal_nft/index.d.ts +8 -0
- package/koni/api/nft/ordinal_nft/index.js +114 -0
- package/koni/api/nft/ordinal_nft/utils.d.ts +2 -0
- package/koni/api/nft/ordinal_nft/utils.js +33 -0
- package/koni/api/staking/bonding/amplitude.js +11 -9
- package/koni/api/staking/bonding/astar.js +9 -8
- package/koni/api/staking/bonding/index.d.ts +1 -1
- package/koni/api/staking/bonding/index.js +5 -1
- package/koni/api/staking/bonding/paraChain.js +12 -10
- package/koni/api/staking/bonding/relayChain.d.ts +2 -2
- package/koni/api/staking/bonding/relayChain.js +33 -30
- package/koni/api/staking/bonding/utils.d.ts +15 -38
- package/koni/api/staking/bonding/utils.js +85 -69
- package/koni/api/staking/index.js +2 -1
- package/koni/api/staking/paraChain.js +7 -6
- package/koni/api/staking/relayChain.js +4 -3
- package/koni/api/yield/helper/utils.d.ts +10 -0
- package/koni/api/yield/helper/utils.js +32 -0
- package/koni/background/cron.js +2 -0
- package/koni/background/handlers/Extension.d.ts +14 -1
- package/koni/background/handlers/Extension.js +282 -30
- package/koni/background/handlers/State.d.ts +18 -2
- package/koni/background/handlers/State.js +56 -4
- package/koni/background/handlers/index.js +4 -2
- package/koni/background/subscription.d.ts +5 -1
- package/koni/background/subscription.js +91 -21
- package/package.json +311 -8
- package/packageInfo.js +1 -1
- package/services/campaign-service/index.js +9 -6
- package/services/chain-service/constants.d.ts +0 -11
- package/services/chain-service/constants.js +1 -14
- package/services/chain-service/utils.d.ts +1 -0
- package/services/chain-service/utils.js +5 -1
- package/services/earning-service/constants/abis/compound_finance_v2_abi.json +1235 -0
- package/services/earning-service/constants/abis/st_liquid_token_abi.json +1355 -0
- package/services/earning-service/constants/chains.d.ts +14 -0
- package/services/earning-service/constants/chains.js +21 -0
- package/services/earning-service/constants/index.d.ts +2 -0
- package/services/earning-service/constants/index.js +5 -0
- package/services/earning-service/constants/step.d.ts +3 -0
- package/services/earning-service/constants/step.js +10 -0
- package/services/earning-service/handlers/base.d.ts +105 -0
- package/services/earning-service/handlers/base.js +195 -0
- package/services/earning-service/handlers/index.d.ts +5 -0
- package/services/earning-service/handlers/index.js +8 -0
- package/services/earning-service/handlers/lending/base.d.ts +6 -0
- package/services/earning-service/handlers/lending/base.js +12 -0
- package/services/earning-service/handlers/lending/index.d.ts +1 -0
- package/services/earning-service/handlers/lending/index.js +4 -0
- package/services/earning-service/handlers/lending/interlay.d.ts +22 -0
- package/services/earning-service/handlers/lending/interlay.js +160 -0
- package/services/earning-service/handlers/liquid-staking/acala.d.ts +27 -0
- package/services/earning-service/handlers/liquid-staking/acala.js +188 -0
- package/services/earning-service/handlers/liquid-staking/base.d.ts +8 -0
- package/services/earning-service/handlers/liquid-staking/base.js +31 -0
- package/services/earning-service/handlers/liquid-staking/bifrost.d.ts +44 -0
- package/services/earning-service/handlers/liquid-staking/bifrost.js +246 -0
- package/services/earning-service/handlers/liquid-staking/index.d.ts +4 -0
- package/services/earning-service/handlers/liquid-staking/index.js +7 -0
- package/services/earning-service/handlers/liquid-staking/parallel.d.ts +27 -0
- package/services/earning-service/handlers/liquid-staking/parallel.js +172 -0
- package/services/earning-service/handlers/liquid-staking/stella-swap.d.ts +36 -0
- package/services/earning-service/handlers/liquid-staking/stella-swap.js +363 -0
- package/services/earning-service/handlers/native-staking/amplitude.d.ts +22 -0
- package/services/earning-service/handlers/native-staking/amplitude.js +350 -0
- package/services/earning-service/handlers/native-staking/astar.d.ts +18 -0
- package/services/earning-service/handlers/native-staking/astar.js +416 -0
- package/services/earning-service/handlers/native-staking/base-para.d.ts +11 -0
- package/services/earning-service/handlers/native-staking/base-para.js +129 -0
- package/services/earning-service/handlers/native-staking/base.d.ts +19 -0
- package/services/earning-service/handlers/native-staking/base.js +101 -0
- package/services/earning-service/handlers/native-staking/index.d.ts +4 -0
- package/services/earning-service/handlers/native-staking/index.js +7 -0
- package/services/earning-service/handlers/native-staking/para-chain.d.ts +15 -0
- package/services/earning-service/handlers/native-staking/para-chain.js +353 -0
- package/services/earning-service/handlers/native-staking/relay-chain.d.ts +21 -0
- package/services/earning-service/handlers/native-staking/relay-chain.js +503 -0
- package/services/earning-service/handlers/nomination-pool/index.d.ts +33 -0
- package/services/earning-service/handlers/nomination-pool/index.js +492 -0
- package/services/earning-service/handlers/special.d.ts +56 -0
- package/services/earning-service/handlers/special.js +379 -0
- package/services/earning-service/service.d.ts +36 -0
- package/services/earning-service/service.js +320 -0
- package/services/earning-service/utils/index.d.ts +14 -0
- package/services/earning-service/utils/index.js +100 -0
- package/services/event-service/index.d.ts +1 -0
- package/services/event-service/index.js +4 -0
- package/services/event-service/types.d.ts +8 -0
- package/services/keyring-service/index.d.ts +2 -1
- package/services/keyring-service/index.js +14 -2
- package/services/migration-service/scripts/DeleteEarningData.d.ts +4 -0
- package/services/migration-service/scripts/DeleteEarningData.js +13 -0
- package/services/migration-service/scripts/EnableEarningChains.d.ts +4 -0
- package/services/migration-service/scripts/EnableEarningChains.js +13 -0
- package/services/migration-service/scripts/MigrateLedgerAccount.js +1 -1
- package/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
- package/services/migration-service/scripts/index.js +4 -0
- package/services/mint-campaign-service/campaigns/UnlockDotCampaign.d.ts +13 -0
- package/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +139 -0
- package/services/mint-campaign-service/campaigns/index.d.ts +1 -0
- package/services/mint-campaign-service/campaigns/index.js +4 -0
- package/services/mint-campaign-service/constants.d.ts +1 -0
- package/services/mint-campaign-service/constants.js +4 -0
- package/services/mint-campaign-service/index.d.ts +7 -0
- package/services/mint-campaign-service/index.js +11 -0
- package/services/notification-service/NotificationService.js +1 -1
- package/services/storage-service/DatabaseService.d.ts +17 -1
- package/services/storage-service/DatabaseService.js +47 -0
- package/services/storage-service/databases/index.d.ts +3 -1
- package/services/storage-service/databases/index.js +4 -0
- package/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/services/storage-service/db-stores/YieldPoolStore.d.ts +10 -0
- package/services/storage-service/db-stores/YieldPoolStore.js +28 -0
- package/services/storage-service/db-stores/YieldPositionStore.d.ts +9 -0
- package/services/storage-service/db-stores/YieldPositionStore.js +57 -0
- package/services/subscan-service/index.d.ts +2 -2
- package/services/transaction-service/event-parser/index.d.ts +3 -1
- package/services/transaction-service/event-parser/index.js +57 -1
- package/services/transaction-service/helpers/index.js +3 -1
- package/services/transaction-service/index.d.ts +4 -15
- package/services/transaction-service/index.js +178 -72
- package/services/transaction-service/types.d.ts +2 -0
- package/services/transaction-service/utils.js +1 -0
- package/types/campaigns/index.d.ts +1 -0
- package/types/campaigns/index.js +4 -0
- package/types/campaigns/unlock-dot.d.ts +71 -0
- package/types/campaigns/unlock-dot.js +1 -0
- package/types/index.d.ts +5 -0
- package/types/index.js +5 -1
- package/types/ordinal.d.ts +69 -0
- package/types/ordinal.js +1 -0
- package/types/transaction.d.ts +3 -0
- package/types/transaction.js +1 -0
- package/types/yield/actions/index.d.ts +2 -0
- package/types/yield/actions/index.js +5 -0
- package/types/yield/actions/join/index.d.ts +3 -0
- package/types/yield/actions/join/index.js +6 -0
- package/types/yield/actions/join/step.d.ts +75 -0
- package/types/yield/actions/join/step.js +34 -0
- package/types/yield/actions/join/submit.d.ts +53 -0
- package/types/yield/actions/join/submit.js +1 -0
- package/types/yield/actions/join/validate.d.ts +18 -0
- package/types/yield/actions/join/validate.js +10 -0
- package/types/yield/actions/others.d.ts +60 -0
- package/types/yield/actions/others.js +1 -0
- package/types/yield/index.d.ts +2 -0
- package/types/yield/index.js +5 -0
- package/types/yield/info/account/index.d.ts +4 -0
- package/types/yield/info/account/index.js +7 -0
- package/types/yield/info/account/info.d.ts +112 -0
- package/types/yield/info/account/info.js +1 -0
- package/types/yield/info/account/reward.d.ts +41 -0
- package/types/yield/info/account/reward.js +1 -0
- package/types/yield/info/account/target.d.ts +43 -0
- package/types/yield/info/account/target.js +27 -0
- package/types/yield/info/account/unstake.d.ts +31 -0
- package/types/yield/info/account/unstake.js +22 -0
- package/types/yield/info/base.d.ts +28 -0
- package/types/yield/info/base.js +28 -0
- package/types/yield/info/chain/index.d.ts +2 -0
- package/types/yield/info/chain/index.js +5 -0
- package/types/yield/info/chain/info.d.ts +190 -0
- package/types/yield/info/chain/info.js +1 -0
- package/types/yield/info/chain/target.d.ts +33 -0
- package/types/yield/info/chain/target.js +1 -0
- package/types/yield/info/index.d.ts +4 -0
- package/types/yield/info/index.js +7 -0
- package/types/yield/info/pallet.d.ts +143 -0
- package/types/yield/info/pallet.js +9 -0
- package/utils/fetchStaticData.js +2 -1
- package/utils/index.d.ts +5 -0
- package/utils/index.js +53 -1
- package/utils/object.d.ts +1 -0
- package/utils/object.js +6 -0
|
@@ -0,0 +1,492 @@
|
|
|
1
|
+
// Copyright 2019-2022 @subwallet/extension-base
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { TransactionError } from '@subwallet/extension-base/background/errors/TransactionError';
|
|
5
|
+
import { APIItemState, BasicTxErrorType, ExtrinsicType, StakingTxErrorType, StakingType } from '@subwallet/extension-base/background/KoniTypes';
|
|
6
|
+
import { calculateChainStakedReturn, calculateInflation, getExistUnstakeErrorMessage, getMinStakeErrorMessage, parsePoolStashAddress } from '@subwallet/extension-base/koni/api/staking/bonding/utils';
|
|
7
|
+
import { _STAKING_ERA_LENGTH_MAP } from '@subwallet/extension-base/services/chain-service/constants';
|
|
8
|
+
import { _getChainSubstrateAddressPrefix } from '@subwallet/extension-base/services/chain-service/utils';
|
|
9
|
+
import { EarningStatus, UnstakingStatus, YieldPoolType, YieldStepType } from '@subwallet/extension-base/types';
|
|
10
|
+
import { balanceFormatter, formatNumber, reformatAddress } from '@subwallet/extension-base/utils';
|
|
11
|
+
import BigN from 'bignumber.js';
|
|
12
|
+
import { t } from 'i18next';
|
|
13
|
+
import { BN, BN_ZERO, hexToString, isHex } from '@polkadot/util';
|
|
14
|
+
import BasePoolHandler from "../base.js";
|
|
15
|
+
export default class NominationPoolHandler extends BasePoolHandler {
|
|
16
|
+
type = YieldPoolType.NOMINATION_POOL;
|
|
17
|
+
constructor(state, chain) {
|
|
18
|
+
super(state, chain);
|
|
19
|
+
const _chainAsset = this.nativeToken;
|
|
20
|
+
const _chainInfo = this.chainInfo;
|
|
21
|
+
const symbol = _chainAsset.symbol;
|
|
22
|
+
const tokenName = _chainAsset.name;
|
|
23
|
+
this.slug = `${symbol}___nomination_pool___${_chainInfo.slug}`;
|
|
24
|
+
this.name = `${tokenName} Nomination Pool`;
|
|
25
|
+
this.shortName = _chainInfo.name.replaceAll(' Relay Chain', '');
|
|
26
|
+
this.description = `Start staking with just {{amount}} ${symbol}`;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/* Subscribe pool info */
|
|
30
|
+
|
|
31
|
+
async subscribePoolInfo(callback) {
|
|
32
|
+
var _substrateApi$api$que;
|
|
33
|
+
let cancel = false;
|
|
34
|
+
const substrateApi = this.substrateApi;
|
|
35
|
+
const chainInfo = this.chainInfo;
|
|
36
|
+
const nativeToken = this.nativeToken;
|
|
37
|
+
const defaultData = this.defaultInfo;
|
|
38
|
+
await substrateApi.isReady;
|
|
39
|
+
const unsub = await ((_substrateApi$api$que = substrateApi.api.query.staking) === null || _substrateApi$api$que === void 0 ? void 0 : _substrateApi$api$que.currentEra(async _currentEra => {
|
|
40
|
+
var _substrateApi$api$que2, _substrateApi$api$que3, _substrateApi$api$que4;
|
|
41
|
+
if (cancel) {
|
|
42
|
+
unsub();
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
if (!substrateApi.api.query.nominationPools) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const currentEra = _currentEra.toString();
|
|
49
|
+
const maxUnlockingChunks = substrateApi.api.consts.staking.maxUnlockingChunks.toString();
|
|
50
|
+
const unlockingEras = substrateApi.api.consts.staking.bondingDuration.toString();
|
|
51
|
+
const [_totalEraStake, _totalIssuance, _auctionCounter, _minPoolJoin] = await Promise.all([substrateApi.api.query.staking.erasTotalStake(parseInt(currentEra)), substrateApi.api.query.balances.totalIssuance(), (_substrateApi$api$que2 = substrateApi.api.query.auctions) === null || _substrateApi$api$que2 === void 0 ? void 0 : _substrateApi$api$que2.auctionCounter(), (_substrateApi$api$que3 = substrateApi.api.query) === null || _substrateApi$api$que3 === void 0 ? void 0 : (_substrateApi$api$que4 = _substrateApi$api$que3.nominationPools) === null || _substrateApi$api$que4 === void 0 ? void 0 : _substrateApi$api$que4.minJoinBond()]);
|
|
52
|
+
const rawTotalEraStake = _totalEraStake.toString();
|
|
53
|
+
const rawTotalIssuance = _totalIssuance.toString();
|
|
54
|
+
const numAuctions = _auctionCounter ? _auctionCounter.toHuman() : 0;
|
|
55
|
+
const bnTotalEraStake = new BN(rawTotalEraStake);
|
|
56
|
+
const bnTotalIssuance = new BN(rawTotalIssuance);
|
|
57
|
+
const inflation = calculateInflation(bnTotalEraStake, bnTotalIssuance, numAuctions, chainInfo.slug);
|
|
58
|
+
const minPoolJoin = (_minPoolJoin === null || _minPoolJoin === void 0 ? void 0 : _minPoolJoin.toString()) || undefined;
|
|
59
|
+
const expectedReturn = calculateChainStakedReturn(inflation, bnTotalEraStake, bnTotalIssuance, chainInfo.slug);
|
|
60
|
+
const unlockingPeriod = parseInt(unlockingEras) * (_STAKING_ERA_LENGTH_MAP[chainInfo.slug] || _STAKING_ERA_LENGTH_MAP.default); // in hours
|
|
61
|
+
|
|
62
|
+
const minToHuman = formatNumber(minPoolJoin || '0', nativeToken.decimals || 0, balanceFormatter);
|
|
63
|
+
const data = {
|
|
64
|
+
// TODO
|
|
65
|
+
...defaultData,
|
|
66
|
+
description: this.description.replaceAll('{{amount}}', minToHuman),
|
|
67
|
+
type: this.type,
|
|
68
|
+
metadata: {
|
|
69
|
+
inputAsset: nativeToken.slug,
|
|
70
|
+
isAvailable: true,
|
|
71
|
+
maxCandidatePerFarmer: 1,
|
|
72
|
+
maxWithdrawalRequestPerFarmer: parseInt(maxUnlockingChunks),
|
|
73
|
+
// TODO recheck
|
|
74
|
+
minJoinPool: minPoolJoin || '0',
|
|
75
|
+
farmerCount: 0,
|
|
76
|
+
// TODO recheck
|
|
77
|
+
era: parseInt(currentEra),
|
|
78
|
+
tvl: bnTotalEraStake.toString(),
|
|
79
|
+
// TODO recheck
|
|
80
|
+
totalApy: expectedReturn,
|
|
81
|
+
// TODO recheck
|
|
82
|
+
unstakingPeriod: unlockingPeriod,
|
|
83
|
+
allowCancelUnstaking: false,
|
|
84
|
+
inflation: inflation
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
callback(data);
|
|
88
|
+
}));
|
|
89
|
+
return () => {
|
|
90
|
+
cancel = true;
|
|
91
|
+
unsub();
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/* Subscribe pool info */
|
|
96
|
+
|
|
97
|
+
/* Subscribe pool position */
|
|
98
|
+
|
|
99
|
+
async parsePoolMemberMetadata(substrateApi, poolMemberInfo) {
|
|
100
|
+
const chainInfo = this.chainInfo;
|
|
101
|
+
const unlimitedNominatorRewarded = substrateApi.api.consts.staking.maxExposurePageSize !== undefined;
|
|
102
|
+
const _maxNominatorRewardedPerValidator = (substrateApi.api.consts.staking.maxNominatorRewardedPerValidator || 0).toString();
|
|
103
|
+
const maxNominatorRewardedPerValidator = parseInt(_maxNominatorRewardedPerValidator);
|
|
104
|
+
const poolsPalletId = substrateApi.api.consts.nominationPools.palletId.toString();
|
|
105
|
+
const poolStashAccount = parsePoolStashAddress(substrateApi.api, 0, poolMemberInfo.poolId, poolsPalletId);
|
|
106
|
+
const [_nominations, _poolMetadata, _currentEra] = await Promise.all([substrateApi.api.query.staking.nominators(poolStashAccount), substrateApi.api.query.nominationPools.metadata(poolMemberInfo.poolId), substrateApi.api.query.staking.currentEra()]);
|
|
107
|
+
const poolMetadata = _poolMetadata.toPrimitive();
|
|
108
|
+
const currentEra = _currentEra.toString();
|
|
109
|
+
const nominations = _nominations.toJSON();
|
|
110
|
+
const poolName = isHex(poolMetadata) ? hexToString(poolMetadata) : poolMetadata;
|
|
111
|
+
let stakingStatus = EarningStatus.NOT_EARNING;
|
|
112
|
+
if (nominations) {
|
|
113
|
+
const validatorList = nominations.targets;
|
|
114
|
+
await Promise.all(validatorList.map(async validatorAddress => {
|
|
115
|
+
const _eraStaker = await substrateApi.api.query.staking.erasStakers(currentEra, validatorAddress);
|
|
116
|
+
const eraStaker = _eraStaker.toPrimitive();
|
|
117
|
+
const sortedNominators = eraStaker.others.sort((a, b) => {
|
|
118
|
+
return new BigN(b.value).minus(a.value).toNumber();
|
|
119
|
+
});
|
|
120
|
+
const topNominators = sortedNominators.map(nominator => {
|
|
121
|
+
return nominator.who;
|
|
122
|
+
}).slice(0, unlimitedNominatorRewarded ? undefined : maxNominatorRewardedPerValidator);
|
|
123
|
+
if (topNominators.includes(reformatAddress(poolStashAccount, _getChainSubstrateAddressPrefix(chainInfo)))) {
|
|
124
|
+
// if address in top nominators
|
|
125
|
+
stakingStatus = EarningStatus.EARNING_REWARD;
|
|
126
|
+
}
|
|
127
|
+
}));
|
|
128
|
+
}
|
|
129
|
+
const joinedPoolInfo = {
|
|
130
|
+
activeStake: poolMemberInfo.points.toString(),
|
|
131
|
+
chain: chainInfo.slug,
|
|
132
|
+
status: stakingStatus,
|
|
133
|
+
validatorIdentity: poolName,
|
|
134
|
+
validatorAddress: poolMemberInfo.poolId.toString(),
|
|
135
|
+
// use poolId
|
|
136
|
+
hasUnstaking: poolMemberInfo.unbondingEras && Object.keys(poolMemberInfo.unbondingEras).length > 0
|
|
137
|
+
};
|
|
138
|
+
const unstakings = [];
|
|
139
|
+
let unstakingBalance = BN_ZERO;
|
|
140
|
+
Object.entries(poolMemberInfo.unbondingEras).forEach(([unlockingEra, amount]) => {
|
|
141
|
+
const remainingEra = parseInt(unlockingEra) - parseInt(currentEra);
|
|
142
|
+
const isClaimable = remainingEra < 0;
|
|
143
|
+
const waitingTime = remainingEra * _STAKING_ERA_LENGTH_MAP[chainInfo.slug];
|
|
144
|
+
unstakingBalance = unstakingBalance.add(new BN(amount));
|
|
145
|
+
unstakings.push({
|
|
146
|
+
chain: chainInfo.slug,
|
|
147
|
+
status: isClaimable ? UnstakingStatus.CLAIMABLE : UnstakingStatus.UNLOCKING,
|
|
148
|
+
claimable: amount.toString(),
|
|
149
|
+
waitingTime: waitingTime
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
const bnActiveStake = new BN(poolMemberInfo.points.toString());
|
|
153
|
+
const bnTotalStake = bnActiveStake.add(unstakingBalance);
|
|
154
|
+
if (!bnActiveStake.gt(BN_ZERO)) {
|
|
155
|
+
stakingStatus = EarningStatus.NOT_EARNING;
|
|
156
|
+
}
|
|
157
|
+
return {
|
|
158
|
+
status: stakingStatus,
|
|
159
|
+
balanceToken: this.nativeToken.slug,
|
|
160
|
+
totalStake: bnTotalStake.toString(),
|
|
161
|
+
activeStake: bnActiveStake.toString(),
|
|
162
|
+
unstakeBalance: unstakingBalance.toString(),
|
|
163
|
+
isBondedBefore: bnTotalStake.gt(BN_ZERO),
|
|
164
|
+
nominations: [joinedPoolInfo],
|
|
165
|
+
// can only join 1 pool at a time
|
|
166
|
+
unstakings
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
170
|
+
var _substrateApi$api$que5, _substrateApi$api$que6;
|
|
171
|
+
let cancel = false;
|
|
172
|
+
const substrateApi = this.substrateApi;
|
|
173
|
+
const defaultInfo = this.defaultInfo;
|
|
174
|
+
await substrateApi.isReady;
|
|
175
|
+
const unsub = await ((_substrateApi$api$que5 = substrateApi.api.query) === null || _substrateApi$api$que5 === void 0 ? void 0 : (_substrateApi$api$que6 = _substrateApi$api$que5.nominationPools) === null || _substrateApi$api$que6 === void 0 ? void 0 : _substrateApi$api$que6.poolMembers.multi(useAddresses, async ledgers => {
|
|
176
|
+
if (cancel) {
|
|
177
|
+
unsub();
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
if (ledgers) {
|
|
181
|
+
await Promise.all(ledgers.map(async (_poolMemberInfo, i) => {
|
|
182
|
+
const poolMemberInfo = _poolMemberInfo.toPrimitive();
|
|
183
|
+
const owner = reformatAddress(useAddresses[i], 42);
|
|
184
|
+
if (poolMemberInfo) {
|
|
185
|
+
const nominatorMetadata = await this.parsePoolMemberMetadata(substrateApi, poolMemberInfo);
|
|
186
|
+
resultCallback({
|
|
187
|
+
...defaultInfo,
|
|
188
|
+
...nominatorMetadata,
|
|
189
|
+
address: owner,
|
|
190
|
+
type: this.type
|
|
191
|
+
});
|
|
192
|
+
} else {
|
|
193
|
+
resultCallback({
|
|
194
|
+
...defaultInfo,
|
|
195
|
+
type: this.type,
|
|
196
|
+
address: owner,
|
|
197
|
+
balanceToken: this.nativeToken.slug,
|
|
198
|
+
totalStake: '0',
|
|
199
|
+
activeStake: '0',
|
|
200
|
+
unstakeBalance: '0',
|
|
201
|
+
isBondedBefore: false,
|
|
202
|
+
status: EarningStatus.NOT_STAKING,
|
|
203
|
+
nominations: [],
|
|
204
|
+
// can only join 1 pool at a time
|
|
205
|
+
unstakings: []
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
}));
|
|
209
|
+
}
|
|
210
|
+
}));
|
|
211
|
+
return () => {
|
|
212
|
+
cancel = true;
|
|
213
|
+
unsub();
|
|
214
|
+
};
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
/* Subscribe pool position */
|
|
218
|
+
|
|
219
|
+
/* Get pool reward */
|
|
220
|
+
|
|
221
|
+
async getPoolReward(useAddresses, callBack) {
|
|
222
|
+
let cancel = false;
|
|
223
|
+
const substrateApi = this.substrateApi;
|
|
224
|
+
await substrateApi.isReady;
|
|
225
|
+
if (substrateApi.api.call.nominationPoolsApi) {
|
|
226
|
+
for (const address of useAddresses) {
|
|
227
|
+
if (!cancel) {
|
|
228
|
+
var _substrateApi$api$cal, _substrateApi$api$cal2;
|
|
229
|
+
const _unclaimedReward = await ((_substrateApi$api$cal = substrateApi.api.call) === null || _substrateApi$api$cal === void 0 ? void 0 : (_substrateApi$api$cal2 = _substrateApi$api$cal.nominationPoolsApi) === null || _substrateApi$api$cal2 === void 0 ? void 0 : _substrateApi$api$cal2.pendingRewards(address));
|
|
230
|
+
if (_unclaimedReward) {
|
|
231
|
+
callBack({
|
|
232
|
+
...this.defaultInfo,
|
|
233
|
+
address: address,
|
|
234
|
+
type: this.type,
|
|
235
|
+
unclaimedReward: _unclaimedReward.toString(),
|
|
236
|
+
state: APIItemState.READY
|
|
237
|
+
});
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
return () => {
|
|
243
|
+
cancel = false;
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
/* Get pool reward */
|
|
248
|
+
|
|
249
|
+
/* Get pool targets */
|
|
250
|
+
|
|
251
|
+
async getPoolTargets() {
|
|
252
|
+
const substrateApi = await this.substrateApi.isReady;
|
|
253
|
+
const nominationPools = [];
|
|
254
|
+
const _allPoolsInfo = await substrateApi.api.query.nominationPools.reversePoolIdLookup.entries();
|
|
255
|
+
await Promise.all(_allPoolsInfo.map(async _poolInfo => {
|
|
256
|
+
var _bondedPool$points;
|
|
257
|
+
const poolAddressList = _poolInfo[0].toHuman();
|
|
258
|
+
const poolAddress = poolAddressList[0];
|
|
259
|
+
const poolId = _poolInfo[1].toPrimitive();
|
|
260
|
+
const poolsPalletId = substrateApi.api.consts.nominationPools.palletId.toString();
|
|
261
|
+
const poolStashAccount = parsePoolStashAddress(substrateApi.api, 0, poolId, poolsPalletId);
|
|
262
|
+
const [_nominations, _bondedPool, _metadata, _minimumActiveStake] = await Promise.all([substrateApi.api.query.staking.nominators(poolStashAccount), substrateApi.api.query.nominationPools.bondedPools(poolId), substrateApi.api.query.nominationPools.metadata(poolId), substrateApi.api.query.staking.minimumActiveStake()]);
|
|
263
|
+
const minimumActiveStake = _minimumActiveStake.toPrimitive();
|
|
264
|
+
const nominations = _nominations.toJSON();
|
|
265
|
+
const poolMetadata = _metadata.toPrimitive();
|
|
266
|
+
const bondedPool = _bondedPool.toPrimitive();
|
|
267
|
+
const poolName = isHex(poolMetadata) ? hexToString(poolMetadata) : poolMetadata;
|
|
268
|
+
const isPoolOpen = bondedPool.state === 'Open';
|
|
269
|
+
const isPoolNominating = !!nominations && nominations.targets.length > 0;
|
|
270
|
+
const isPoolEarningReward = bondedPool.points > minimumActiveStake;
|
|
271
|
+
nominationPools.push({
|
|
272
|
+
id: poolId,
|
|
273
|
+
address: poolAddress,
|
|
274
|
+
name: poolName,
|
|
275
|
+
bondedAmount: ((_bondedPool$points = bondedPool.points) === null || _bondedPool$points === void 0 ? void 0 : _bondedPool$points.toString()) || '0',
|
|
276
|
+
roles: bondedPool.roles,
|
|
277
|
+
memberCounter: bondedPool.memberCounter,
|
|
278
|
+
state: bondedPool.state,
|
|
279
|
+
isProfitable: isPoolOpen && isPoolNominating && isPoolEarningReward
|
|
280
|
+
});
|
|
281
|
+
}));
|
|
282
|
+
return nominationPools;
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
/* Get pool targets */
|
|
286
|
+
|
|
287
|
+
/* Join pool action */
|
|
288
|
+
|
|
289
|
+
get defaultSubmitStep() {
|
|
290
|
+
return [{
|
|
291
|
+
name: 'Join nomination pool',
|
|
292
|
+
type: YieldStepType.JOIN_NOMINATION_POOL
|
|
293
|
+
}, {
|
|
294
|
+
slug: this.nativeToken.slug,
|
|
295
|
+
amount: '0'
|
|
296
|
+
}];
|
|
297
|
+
}
|
|
298
|
+
async getSubmitStep(params) {
|
|
299
|
+
const {
|
|
300
|
+
address,
|
|
301
|
+
amount,
|
|
302
|
+
slug,
|
|
303
|
+
targets
|
|
304
|
+
} = params;
|
|
305
|
+
if (!targets || !targets.length) {
|
|
306
|
+
return Promise.reject(new TransactionError(BasicTxErrorType.INVALID_PARAMS));
|
|
307
|
+
}
|
|
308
|
+
const data = {
|
|
309
|
+
amount,
|
|
310
|
+
address,
|
|
311
|
+
slug,
|
|
312
|
+
selectedPool: targets[0]
|
|
313
|
+
};
|
|
314
|
+
const positionInfo = await this.getPoolPosition(address);
|
|
315
|
+
const [, fee] = await this.createJoinExtrinsic(data, positionInfo);
|
|
316
|
+
return [{
|
|
317
|
+
name: 'Join nomination pool',
|
|
318
|
+
type: YieldStepType.JOIN_NOMINATION_POOL,
|
|
319
|
+
metadata: {
|
|
320
|
+
amount: amount
|
|
321
|
+
}
|
|
322
|
+
}, fee];
|
|
323
|
+
}
|
|
324
|
+
async validateYieldJoin(data, path) {
|
|
325
|
+
const {
|
|
326
|
+
address,
|
|
327
|
+
amount,
|
|
328
|
+
selectedPool
|
|
329
|
+
} = data;
|
|
330
|
+
const _poolInfo = await this.getPoolInfo();
|
|
331
|
+
if (!_poolInfo) {
|
|
332
|
+
return Promise.resolve([new TransactionError(BasicTxErrorType.INTERNAL_ERROR)]);
|
|
333
|
+
}
|
|
334
|
+
const poolInfo = _poolInfo;
|
|
335
|
+
const chainInfo = this.chainInfo;
|
|
336
|
+
const positionInfo = await this.getPoolPosition(address);
|
|
337
|
+
|
|
338
|
+
// cannot stake when unstake all
|
|
339
|
+
// amount >= min stake
|
|
340
|
+
const errors = [];
|
|
341
|
+
let bnTotalStake = new BN(amount);
|
|
342
|
+
const bnMinStake = new BN(poolInfo.metadata.minJoinPool || '0');
|
|
343
|
+
const minStakeErrorMessage = getMinStakeErrorMessage(chainInfo, bnMinStake);
|
|
344
|
+
const existUnstakeErrorMessage = getExistUnstakeErrorMessage(chainInfo.slug, StakingType.POOLED, true);
|
|
345
|
+
if (selectedPool.state !== 'Open') {
|
|
346
|
+
errors.push(new TransactionError(StakingTxErrorType.INACTIVE_NOMINATION_POOL));
|
|
347
|
+
}
|
|
348
|
+
if (positionInfo) {
|
|
349
|
+
const bnCurrentActiveStake = new BN(positionInfo.activeStake);
|
|
350
|
+
bnTotalStake = bnTotalStake.add(bnCurrentActiveStake);
|
|
351
|
+
if (positionInfo.unstakings.length > 0 && bnCurrentActiveStake.isZero()) {
|
|
352
|
+
errors.push(new TransactionError(StakingTxErrorType.EXIST_UNSTAKING_REQUEST, existUnstakeErrorMessage));
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
if (!bnTotalStake.gte(bnMinStake)) {
|
|
356
|
+
errors.push(new TransactionError(StakingTxErrorType.NOT_ENOUGH_MIN_STAKE, minStakeErrorMessage));
|
|
357
|
+
}
|
|
358
|
+
return errors;
|
|
359
|
+
}
|
|
360
|
+
async createJoinExtrinsic(data, positionInfo) {
|
|
361
|
+
const {
|
|
362
|
+
address,
|
|
363
|
+
amount,
|
|
364
|
+
selectedPool: {
|
|
365
|
+
id: selectedPoolId
|
|
366
|
+
}
|
|
367
|
+
} = data;
|
|
368
|
+
const chainApi = await this.substrateApi.isReady;
|
|
369
|
+
const bnActiveStake = new BN((positionInfo === null || positionInfo === void 0 ? void 0 : positionInfo.activeStake) || '0');
|
|
370
|
+
const compoundResult = async extrinsic => {
|
|
371
|
+
const tokenSlug = this.nativeToken.slug;
|
|
372
|
+
const feeInfo = await extrinsic.paymentInfo(address);
|
|
373
|
+
const fee = feeInfo.toPrimitive();
|
|
374
|
+
return [extrinsic, {
|
|
375
|
+
slug: tokenSlug,
|
|
376
|
+
amount: fee.partialFee.toString()
|
|
377
|
+
}];
|
|
378
|
+
};
|
|
379
|
+
if (bnActiveStake.gt(BN_ZERO)) {
|
|
380
|
+
// already joined a pool
|
|
381
|
+
const extrinsic = chainApi.api.tx.nominationPools.bondExtra({
|
|
382
|
+
FreeBalance: amount
|
|
383
|
+
});
|
|
384
|
+
return compoundResult(extrinsic);
|
|
385
|
+
}
|
|
386
|
+
const extrinsic = chainApi.api.tx.nominationPools.join(amount, selectedPoolId);
|
|
387
|
+
return compoundResult(extrinsic);
|
|
388
|
+
}
|
|
389
|
+
async handleYieldJoin(_data, path, currentStep) {
|
|
390
|
+
const data = _data;
|
|
391
|
+
const {
|
|
392
|
+
address,
|
|
393
|
+
amount,
|
|
394
|
+
selectedPool
|
|
395
|
+
} = data;
|
|
396
|
+
const positionInfo = await this.getPoolPosition(address);
|
|
397
|
+
const [extrinsic] = await this.createJoinExtrinsic(data);
|
|
398
|
+
const joinPoolData = {
|
|
399
|
+
poolPosition: positionInfo,
|
|
400
|
+
slug: this.slug,
|
|
401
|
+
selectedPool,
|
|
402
|
+
amount,
|
|
403
|
+
address
|
|
404
|
+
};
|
|
405
|
+
return {
|
|
406
|
+
txChain: this.chain,
|
|
407
|
+
extrinsicType: ExtrinsicType.STAKING_JOIN_POOL,
|
|
408
|
+
extrinsic,
|
|
409
|
+
txData: joinPoolData,
|
|
410
|
+
transferNativeAmount: amount
|
|
411
|
+
};
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
/* Join pool action */
|
|
415
|
+
|
|
416
|
+
/* Leave pool action */
|
|
417
|
+
|
|
418
|
+
/**
|
|
419
|
+
* @todo Recheck
|
|
420
|
+
* */
|
|
421
|
+
async validateYieldLeave(amount, address, fastLeave, selectedTarget) {
|
|
422
|
+
const errors = [];
|
|
423
|
+
const poolInfo = await this.getPoolInfo();
|
|
424
|
+
const poolPosition = await this.getPoolPosition(address);
|
|
425
|
+
if (!poolInfo || !poolPosition || fastLeave) {
|
|
426
|
+
return [new TransactionError(BasicTxErrorType.INTERNAL_ERROR)];
|
|
427
|
+
}
|
|
428
|
+
if (fastLeave) {
|
|
429
|
+
return [new TransactionError(BasicTxErrorType.INVALID_PARAMS)];
|
|
430
|
+
}
|
|
431
|
+
const bnActiveStake = new BN(poolPosition.activeStake);
|
|
432
|
+
const bnRemainingStake = bnActiveStake.sub(new BN(amount));
|
|
433
|
+
const minStake = new BN(poolInfo.metadata.minJoinPool || '0');
|
|
434
|
+
const maxUnstake = poolInfo.metadata.maxWithdrawalRequestPerFarmer;
|
|
435
|
+
if (!(bnRemainingStake.isZero() || bnRemainingStake.gte(minStake))) {
|
|
436
|
+
errors.push(new TransactionError(StakingTxErrorType.INVALID_ACTIVE_STAKE));
|
|
437
|
+
}
|
|
438
|
+
if (poolPosition.unstakings.length > maxUnstake) {
|
|
439
|
+
errors.push(new TransactionError(StakingTxErrorType.EXCEED_MAX_UNSTAKING, t('You cannot unstake more than {{number}} times', {
|
|
440
|
+
replace: {
|
|
441
|
+
number: maxUnstake
|
|
442
|
+
}
|
|
443
|
+
})));
|
|
444
|
+
}
|
|
445
|
+
return Promise.resolve(errors);
|
|
446
|
+
}
|
|
447
|
+
async handleYieldRedeem(amount, address, selectedTarget) {
|
|
448
|
+
return Promise.reject(new TransactionError(BasicTxErrorType.UNSUPPORTED));
|
|
449
|
+
}
|
|
450
|
+
async handleYieldUnstake(amount, address, selectedTarget) {
|
|
451
|
+
const chainApi = await this.substrateApi.isReady;
|
|
452
|
+
const poolPosition = await this.getPoolPosition(address);
|
|
453
|
+
if (!poolPosition) {
|
|
454
|
+
return Promise.reject(new TransactionError(BasicTxErrorType.INTERNAL_ERROR));
|
|
455
|
+
}
|
|
456
|
+
const extrinsic = chainApi.api.tx.nominationPools.unbond({
|
|
457
|
+
Id: poolPosition.address
|
|
458
|
+
}, amount);
|
|
459
|
+
return [ExtrinsicType.STAKING_LEAVE_POOL, extrinsic];
|
|
460
|
+
}
|
|
461
|
+
|
|
462
|
+
/* Leave pool action */
|
|
463
|
+
|
|
464
|
+
/* Other action */
|
|
465
|
+
|
|
466
|
+
handleYieldCancelUnstake(params) {
|
|
467
|
+
return Promise.reject(new TransactionError(BasicTxErrorType.UNSUPPORTED));
|
|
468
|
+
}
|
|
469
|
+
async handleYieldClaimReward(address, bondReward) {
|
|
470
|
+
const chainApi = await this.substrateApi.isReady;
|
|
471
|
+
if (bondReward) {
|
|
472
|
+
return chainApi.api.tx.nominationPools.bondExtra('Rewards');
|
|
473
|
+
}
|
|
474
|
+
return chainApi.api.tx.nominationPools.claimPayout();
|
|
475
|
+
}
|
|
476
|
+
async handleYieldWithdraw(address, unstakingInfo) {
|
|
477
|
+
const chainApi = await this.substrateApi.isReady;
|
|
478
|
+
if (chainApi.api.tx.nominationPools.withdrawUnbonded.meta.args.length === 2) {
|
|
479
|
+
const _slashingSpans = (await chainApi.api.query.staking.slashingSpans(address)).toHuman();
|
|
480
|
+
const slashingSpanCount = _slashingSpans !== null ? _slashingSpans.spanIndex : '0';
|
|
481
|
+
return chainApi.api.tx.nominationPools.withdrawUnbonded({
|
|
482
|
+
Id: address
|
|
483
|
+
}, slashingSpanCount);
|
|
484
|
+
} else {
|
|
485
|
+
return chainApi.api.tx.nominationPools.withdrawUnbonded({
|
|
486
|
+
Id: address
|
|
487
|
+
});
|
|
488
|
+
}
|
|
489
|
+
}
|
|
490
|
+
|
|
491
|
+
/* Other actions */
|
|
492
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { TransactionError } from '@subwallet/extension-base/background/errors/TransactionError';
|
|
2
|
+
import { ExtrinsicType } from '@subwallet/extension-base/background/KoniTypes';
|
|
3
|
+
import { BaseYieldStepDetail, HandleYieldStepData, OptimalYieldPath, OptimalYieldPathParams, SpecialYieldPoolInfo, SpecialYieldPoolMetadata, SubmitYieldJoinData, TransactionData, UnstakingInfo, YieldPoolInfo, YieldPoolTarget, YieldStepBaseInfo, YieldTokenBaseInfo } from '@subwallet/extension-base/types';
|
|
4
|
+
import BN from 'bn.js';
|
|
5
|
+
import BasePoolHandler from './base';
|
|
6
|
+
export default abstract class BaseSpecialStakingPoolHandler extends BasePoolHandler {
|
|
7
|
+
protected abstract altInputAsset: string;
|
|
8
|
+
protected abstract derivativeAssets: string[];
|
|
9
|
+
protected abstract inputAsset: string;
|
|
10
|
+
protected abstract rewardAssets: string[];
|
|
11
|
+
protected abstract feeAssets: string[];
|
|
12
|
+
/** Allow to create default unstake transaction */
|
|
13
|
+
protected readonly allowDefaultUnstake: boolean;
|
|
14
|
+
/** Allow to create fast unstake transaction */
|
|
15
|
+
protected readonly allowFastUnstake: boolean;
|
|
16
|
+
protected get baseMetadata(): Pick<SpecialYieldPoolMetadata, 'altInputAssets' | 'derivativeAssets' | 'inputAsset' | 'rewardAssets' | 'feeAssets'>;
|
|
17
|
+
get isPoolSupportAlternativeFee(): boolean;
|
|
18
|
+
get group(): string;
|
|
19
|
+
abstract getPoolStat(): Promise<SpecialYieldPoolInfo>;
|
|
20
|
+
subscribePoolInfo(callback: (data: YieldPoolInfo) => void): Promise<VoidFunction>;
|
|
21
|
+
getPoolReward(): Promise<VoidFunction>;
|
|
22
|
+
getPoolTargets(): Promise<YieldPoolTarget[]>;
|
|
23
|
+
/**
|
|
24
|
+
* @async
|
|
25
|
+
* @function getXcmStep
|
|
26
|
+
* */
|
|
27
|
+
getXcmStep(params: OptimalYieldPathParams): Promise<[BaseYieldStepDetail, YieldTokenBaseInfo] | undefined>;
|
|
28
|
+
protected get defaultSubmitStep(): YieldStepBaseInfo;
|
|
29
|
+
/**
|
|
30
|
+
* @function submitJoinStepInfo
|
|
31
|
+
* @description Base info of submit step
|
|
32
|
+
* @return Fee of the submitting step
|
|
33
|
+
* */
|
|
34
|
+
abstract get submitJoinStepInfo(): BaseYieldStepDetail;
|
|
35
|
+
/**
|
|
36
|
+
* @async
|
|
37
|
+
* @function getSubmitStepFee
|
|
38
|
+
* @description Get submit step fee
|
|
39
|
+
* @return {Promise<YieldTokenBaseInfo>} Fee of the submitting step
|
|
40
|
+
* */
|
|
41
|
+
abstract getSubmitStepFee(params: OptimalYieldPathParams): Promise<YieldTokenBaseInfo>;
|
|
42
|
+
protected getSubmitStep(params: OptimalYieldPathParams): Promise<YieldStepBaseInfo>;
|
|
43
|
+
protected validateTokenApproveStep(params: OptimalYieldPathParams, path: OptimalYieldPath): Promise<TransactionError[]>;
|
|
44
|
+
protected validateXcmStep(params: OptimalYieldPathParams, path: OptimalYieldPath, bnInputTokenBalance: BN): Promise<TransactionError[]>;
|
|
45
|
+
protected validateJoinStep(id: number, params: OptimalYieldPathParams, path: OptimalYieldPath, bnInputTokenBalance: BN, isXcmOk: boolean): Promise<TransactionError[]>;
|
|
46
|
+
validateYieldJoin(params: SubmitYieldJoinData, path: OptimalYieldPath): Promise<TransactionError[]>;
|
|
47
|
+
protected handleTokenApproveStep(data: SubmitYieldJoinData, path: OptimalYieldPath): Promise<HandleYieldStepData>;
|
|
48
|
+
handleXcmStep(data: SubmitYieldJoinData, path: OptimalYieldPath, xcmFee: string): Promise<HandleYieldStepData>;
|
|
49
|
+
abstract handleSubmitStep(data: SubmitYieldJoinData, path: OptimalYieldPath): Promise<HandleYieldStepData>;
|
|
50
|
+
handleYieldJoin(data: SubmitYieldJoinData, path: OptimalYieldPath, currentStep: number): Promise<HandleYieldStepData>;
|
|
51
|
+
validateYieldLeave(amount: string, address: string, fastLeave: boolean, selectedTarget?: string): Promise<TransactionError[]>;
|
|
52
|
+
handleYieldUnstake(amount: string, address: string, selectedTarget?: string): Promise<[ExtrinsicType, TransactionData]>;
|
|
53
|
+
handleYieldCancelUnstake(): Promise<TransactionData>;
|
|
54
|
+
handleYieldClaimReward(address: string, bondReward?: boolean): Promise<TransactionData>;
|
|
55
|
+
handleYieldWithdraw(address: string, unstakingInfo: UnstakingInfo): Promise<TransactionData>;
|
|
56
|
+
}
|