@subwallet/extension-base 1.1.33-beta.1 → 1.1.34-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.
- package/background/KoniTypes.d.ts +69 -120
- package/background/KoniTypes.js +13 -22
- package/background/errors/TransactionError.js +0 -9
- package/cjs/background/KoniTypes.js +16 -23
- package/cjs/background/errors/TransactionError.js +0 -9
- package/cjs/constants/index.js +4 -19
- package/cjs/koni/api/nft/config.js +23 -33
- package/cjs/koni/api/nft/index.js +0 -14
- package/cjs/koni/api/nft/nft.js +22 -1
- package/cjs/koni/api/staking/bonding/amplitude.js +16 -19
- package/cjs/koni/api/staking/bonding/astar.js +10 -11
- package/cjs/koni/api/staking/bonding/index.js +1 -4
- package/cjs/koni/api/staking/bonding/paraChain.js +23 -25
- package/cjs/koni/api/staking/bonding/relayChain.js +45 -48
- package/cjs/koni/api/staking/bonding/utils.js +86 -104
- package/cjs/koni/api/staking/index.js +5 -6
- package/cjs/koni/api/staking/paraChain.js +17 -10
- package/cjs/koni/api/staking/relayChain.js +2 -3
- package/cjs/koni/background/cron.js +21 -3
- package/cjs/koni/background/handlers/Extension.js +69 -368
- package/cjs/koni/background/handlers/State.js +12 -18
- package/cjs/koni/background/handlers/index.js +2 -4
- package/cjs/koni/background/subscription.js +104 -7
- package/cjs/packageInfo.js +1 -1
- package/cjs/services/balance-service/helpers/subscribe/substrate/index.js +1 -3
- package/cjs/services/campaign-service/index.js +6 -9
- package/cjs/services/chain-service/constants.js +17 -2
- package/cjs/services/chain-service/index.js +3 -25
- package/cjs/services/chain-service/utils.js +1 -7
- package/cjs/services/event-service/index.js +0 -5
- package/cjs/services/keyring-service/index.js +2 -14
- package/cjs/services/migration-service/scripts/MigrateLedgerAccount.js +1 -1
- package/cjs/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
- package/cjs/services/migration-service/scripts/index.js +1 -6
- package/cjs/services/notification-service/NotificationService.js +1 -1
- package/cjs/services/storage-service/DatabaseService.js +1 -92
- package/cjs/services/storage-service/databases/index.js +0 -7
- package/cjs/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/cjs/services/subscan-service/index.js +0 -16
- package/cjs/services/transaction-service/event-parser/index.js +0 -58
- package/cjs/services/transaction-service/helpers/index.js +1 -3
- package/cjs/services/transaction-service/index.js +75 -252
- package/cjs/services/transaction-service/utils.js +0 -1
- package/cjs/types/index.js +0 -44
- package/cjs/utils/fetchStaticData.js +1 -2
- package/cjs/utils/index.js +1 -89
- package/cjs/utils/number.js +2 -6
- package/constants/index.d.ts +1 -6
- package/constants/index.js +1 -6
- package/koni/api/nft/config.js +23 -33
- package/koni/api/nft/index.js +1 -15
- package/koni/api/nft/nft.js +23 -2
- package/koni/api/staking/bonding/amplitude.js +10 -13
- package/koni/api/staking/bonding/astar.js +8 -9
- package/koni/api/staking/bonding/index.d.ts +1 -1
- package/koni/api/staking/bonding/index.js +1 -5
- package/koni/api/staking/bonding/paraChain.js +10 -12
- package/koni/api/staking/bonding/relayChain.d.ts +2 -2
- package/koni/api/staking/bonding/relayChain.js +30 -33
- package/koni/api/staking/bonding/utils.d.ts +38 -15
- package/koni/api/staking/bonding/utils.js +69 -85
- package/koni/api/staking/index.js +1 -2
- package/koni/api/staking/paraChain.js +18 -11
- package/koni/api/staking/relayChain.js +3 -4
- package/koni/background/cron.d.ts +4 -0
- package/koni/background/cron.js +22 -4
- package/koni/background/handlers/Extension.d.ts +1 -17
- package/koni/background/handlers/Extension.js +30 -327
- package/koni/background/handlers/State.d.ts +1 -6
- package/koni/background/handlers/State.js +12 -17
- package/koni/background/handlers/index.js +2 -4
- package/koni/background/subscription.d.ts +6 -1
- package/koni/background/subscription.js +104 -8
- package/package.json +8 -331
- package/packageInfo.js +1 -1
- package/services/balance-service/helpers/subscribe/substrate/index.js +2 -4
- package/services/campaign-service/index.js +6 -9
- package/services/chain-service/constants.d.ts +13 -1
- package/services/chain-service/constants.js +15 -1
- package/services/chain-service/index.d.ts +0 -2
- package/services/chain-service/index.js +3 -25
- package/services/chain-service/utils.d.ts +0 -1
- package/services/chain-service/utils.js +1 -5
- package/services/event-service/index.d.ts +0 -2
- package/services/event-service/index.js +0 -5
- package/services/event-service/types.d.ts +0 -9
- package/services/keyring-service/index.d.ts +1 -2
- package/services/keyring-service/index.js +2 -14
- 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 +1 -6
- package/services/notification-service/NotificationService.js +1 -1
- package/services/storage-service/DatabaseService.d.ts +3 -30
- package/services/storage-service/DatabaseService.js +1 -91
- package/services/storage-service/databases/index.d.ts +2 -8
- package/services/storage-service/databases/index.js +0 -7
- package/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/services/subscan-service/index.d.ts +2 -3
- package/services/subscan-service/index.js +0 -15
- package/services/subscan-service/types.d.ts +0 -20
- package/services/transaction-service/event-parser/index.d.ts +1 -3
- package/services/transaction-service/event-parser/index.js +1 -57
- package/services/transaction-service/helpers/index.js +1 -3
- package/services/transaction-service/index.d.ts +13 -6
- package/services/transaction-service/index.js +73 -250
- package/services/transaction-service/types.d.ts +0 -2
- package/services/transaction-service/utils.js +0 -1
- package/types/index.d.ts +0 -5
- package/types/index.js +1 -5
- package/utils/fetchStaticData.js +1 -2
- package/utils/index.d.ts +0 -5
- package/utils/index.js +0 -52
- package/utils/number.d.ts +1 -2
- package/utils/number.js +1 -2
- package/cjs/koni/api/dotsama/balance.js +0 -464
- package/cjs/koni/api/nft/ordinal_nft/constants.js +0 -21
- package/cjs/koni/api/nft/ordinal_nft/index.js +0 -121
- package/cjs/koni/api/nft/ordinal_nft/utils.js +0 -41
- package/cjs/koni/api/yield/helper/utils.js +0 -49
- package/cjs/services/earning-service/constants/chains.js +0 -30
- package/cjs/services/earning-service/constants/index.js +0 -27
- package/cjs/services/earning-service/constants/step.js +0 -18
- package/cjs/services/earning-service/handlers/base.js +0 -262
- package/cjs/services/earning-service/handlers/index.js +0 -60
- package/cjs/services/earning-service/handlers/lending/base.js +0 -81
- package/cjs/services/earning-service/handlers/lending/index.js +0 -13
- package/cjs/services/earning-service/handlers/lending/interlay.js +0 -192
- package/cjs/services/earning-service/handlers/liquid-staking/acala.js +0 -240
- package/cjs/services/earning-service/handlers/liquid-staking/base.js +0 -98
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost-manta.js +0 -140
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost.js +0 -299
- package/cjs/services/earning-service/handlers/liquid-staking/index.js +0 -41
- package/cjs/services/earning-service/handlers/liquid-staking/parallel.js +0 -227
- package/cjs/services/earning-service/handlers/liquid-staking/stella-swap.js +0 -404
- package/cjs/services/earning-service/handlers/native-staking/amplitude.js +0 -434
- package/cjs/services/earning-service/handlers/native-staking/astar.js +0 -466
- package/cjs/services/earning-service/handlers/native-staking/base-para.js +0 -146
- package/cjs/services/earning-service/handlers/native-staking/base.js +0 -161
- package/cjs/services/earning-service/handlers/native-staking/index.js +0 -34
- package/cjs/services/earning-service/handlers/native-staking/para-chain.js +0 -390
- package/cjs/services/earning-service/handlers/native-staking/relay-chain.js +0 -567
- package/cjs/services/earning-service/handlers/nomination-pool/index.js +0 -566
- package/cjs/services/earning-service/handlers/special.js +0 -497
- package/cjs/services/earning-service/service.js +0 -741
- package/cjs/services/earning-service/utils/index.js +0 -128
- package/cjs/services/migration-service/scripts/DeleteEarningData.js +0 -21
- package/cjs/services/migration-service/scripts/EnableEarningChains.js +0 -21
- package/cjs/services/migration-service/scripts/MigrateEthProvider.js +0 -17
- package/cjs/services/migration-service/scripts/MigratePioneerProvider.js +0 -17
- package/cjs/services/migration-service/scripts/MigrateProvider.js +0 -29
- package/cjs/services/migration-service/scripts/databases/MigrateEarningHistory.js +0 -21
- package/cjs/services/migration-service/scripts/databases/MigrateEarningVersion.js +0 -21
- package/cjs/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +0 -149
- package/cjs/services/mint-campaign-service/campaigns/index.js +0 -13
- package/cjs/services/mint-campaign-service/constants.js +0 -11
- package/cjs/services/mint-campaign-service/index.js +0 -18
- package/cjs/services/storage-service/db-stores/AssetRef.js +0 -24
- package/cjs/services/storage-service/db-stores/YieldPoolStore.js +0 -36
- package/cjs/services/storage-service/db-stores/YieldPositionStore.js +0 -71
- package/cjs/services/storage-service/index.js +0 -241
- package/cjs/types/campaigns/index.js +0 -16
- package/cjs/types/campaigns/unlock-dot.js +0 -1
- package/cjs/types/ordinal.js +0 -1
- package/cjs/types/transaction.js +0 -1
- package/cjs/types/yield/actions/index.js +0 -27
- package/cjs/types/yield/actions/join/index.js +0 -38
- package/cjs/types/yield/actions/join/step.js +0 -48
- package/cjs/types/yield/actions/join/submit.js +0 -1
- package/cjs/types/yield/actions/join/validate.js +0 -16
- package/cjs/types/yield/actions/others.js +0 -1
- package/cjs/types/yield/index.js +0 -27
- package/cjs/types/yield/info/account/index.js +0 -49
- package/cjs/types/yield/info/account/info.js +0 -1
- package/cjs/types/yield/info/account/reward.js +0 -1
- package/cjs/types/yield/info/account/target.js +0 -32
- package/cjs/types/yield/info/account/unstake.js +0 -27
- package/cjs/types/yield/info/base.js +0 -41
- package/cjs/types/yield/info/chain/index.js +0 -27
- package/cjs/types/yield/info/chain/info.js +0 -1
- package/cjs/types/yield/info/chain/target.js +0 -1
- package/cjs/types/yield/info/index.js +0 -49
- package/cjs/types/yield/info/pallet.js +0 -15
- package/cjs/types.js +0 -1
- package/cjs/utils/address.js +0 -34
- package/cjs/utils/keyring.js +0 -57
- package/cjs/utils/object.js +0 -12
- package/koni/api/nft/ordinal_nft/constants.d.ts +0 -9
- package/koni/api/nft/ordinal_nft/constants.js +0 -12
- package/koni/api/nft/ordinal_nft/index.d.ts +0 -8
- package/koni/api/nft/ordinal_nft/index.js +0 -114
- package/koni/api/nft/ordinal_nft/utils.d.ts +0 -2
- package/koni/api/nft/ordinal_nft/utils.js +0 -33
- package/koni/api/yield/helper/utils.d.ts +0 -10
- package/koni/api/yield/helper/utils.js +0 -34
- package/services/earning-service/constants/abis/compound_finance_v2_abi.json +0 -1235
- package/services/earning-service/constants/abis/st_liquid_token_abi.json +0 -1355
- package/services/earning-service/constants/chains.d.ts +0 -15
- package/services/earning-service/constants/chains.js +0 -22
- package/services/earning-service/constants/index.d.ts +0 -2
- package/services/earning-service/constants/index.js +0 -5
- package/services/earning-service/constants/step.d.ts +0 -3
- package/services/earning-service/constants/step.js +0 -10
- package/services/earning-service/handlers/base.d.ts +0 -113
- package/services/earning-service/handlers/base.js +0 -256
- package/services/earning-service/handlers/index.d.ts +0 -5
- package/services/earning-service/handlers/index.js +0 -8
- package/services/earning-service/handlers/lending/base.d.ts +0 -8
- package/services/earning-service/handlers/lending/base.js +0 -73
- package/services/earning-service/handlers/lending/index.d.ts +0 -1
- package/services/earning-service/handlers/lending/index.js +0 -4
- package/services/earning-service/handlers/lending/interlay.d.ts +0 -24
- package/services/earning-service/handlers/lending/interlay.js +0 -184
- package/services/earning-service/handlers/liquid-staking/acala.d.ts +0 -27
- package/services/earning-service/handlers/liquid-staking/acala.js +0 -232
- package/services/earning-service/handlers/liquid-staking/base.d.ts +0 -11
- package/services/earning-service/handlers/liquid-staking/base.js +0 -90
- package/services/earning-service/handlers/liquid-staking/bifrost-manta.d.ts +0 -37
- package/services/earning-service/handlers/liquid-staking/bifrost-manta.js +0 -132
- package/services/earning-service/handlers/liquid-staking/bifrost.d.ts +0 -46
- package/services/earning-service/handlers/liquid-staking/bifrost.js +0 -288
- package/services/earning-service/handlers/liquid-staking/index.d.ts +0 -5
- package/services/earning-service/handlers/liquid-staking/index.js +0 -8
- package/services/earning-service/handlers/liquid-staking/parallel.d.ts +0 -26
- package/services/earning-service/handlers/liquid-staking/parallel.js +0 -219
- package/services/earning-service/handlers/liquid-staking/stella-swap.d.ts +0 -34
- package/services/earning-service/handlers/liquid-staking/stella-swap.js +0 -394
- package/services/earning-service/handlers/native-staking/amplitude.d.ts +0 -22
- package/services/earning-service/handlers/native-staking/amplitude.js +0 -425
- package/services/earning-service/handlers/native-staking/astar.d.ts +0 -19
- package/services/earning-service/handlers/native-staking/astar.js +0 -456
- package/services/earning-service/handlers/native-staking/base-para.d.ts +0 -11
- package/services/earning-service/handlers/native-staking/base-para.js +0 -138
- package/services/earning-service/handlers/native-staking/base.d.ts +0 -21
- package/services/earning-service/handlers/native-staking/base.js +0 -152
- package/services/earning-service/handlers/native-staking/index.d.ts +0 -4
- package/services/earning-service/handlers/native-staking/index.js +0 -7
- package/services/earning-service/handlers/native-staking/para-chain.d.ts +0 -15
- package/services/earning-service/handlers/native-staking/para-chain.js +0 -382
- package/services/earning-service/handlers/native-staking/relay-chain.d.ts +0 -21
- package/services/earning-service/handlers/native-staking/relay-chain.js +0 -558
- package/services/earning-service/handlers/nomination-pool/index.d.ts +0 -36
- package/services/earning-service/handlers/nomination-pool/index.js +0 -556
- package/services/earning-service/handlers/special.d.ts +0 -64
- package/services/earning-service/handlers/special.js +0 -489
- package/services/earning-service/service.d.ts +0 -94
- package/services/earning-service/service.js +0 -730
- package/services/earning-service/utils/index.d.ts +0 -18
- package/services/earning-service/utils/index.js +0 -112
- package/services/migration-service/scripts/DeleteEarningData.d.ts +0 -4
- package/services/migration-service/scripts/DeleteEarningData.js +0 -13
- package/services/migration-service/scripts/EnableEarningChains.d.ts +0 -4
- package/services/migration-service/scripts/EnableEarningChains.js +0 -13
- package/services/migration-service/scripts/databases/MigrateEarningHistory.d.ts +0 -4
- package/services/migration-service/scripts/databases/MigrateEarningHistory.js +0 -13
- package/services/migration-service/scripts/databases/MigrateEarningVersion.d.ts +0 -4
- package/services/migration-service/scripts/databases/MigrateEarningVersion.js +0 -13
- package/services/mint-campaign-service/campaigns/UnlockDotCampaign.d.ts +0 -13
- package/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +0 -139
- package/services/mint-campaign-service/campaigns/index.d.ts +0 -1
- package/services/mint-campaign-service/campaigns/index.js +0 -4
- package/services/mint-campaign-service/constants.d.ts +0 -1
- package/services/mint-campaign-service/constants.js +0 -4
- package/services/mint-campaign-service/index.d.ts +0 -7
- package/services/mint-campaign-service/index.js +0 -11
- package/services/storage-service/db-stores/AssetRef.d.ts +0 -7
- package/services/storage-service/db-stores/AssetRef.js +0 -16
- package/services/storage-service/db-stores/YieldPoolStore.d.ts +0 -10
- package/services/storage-service/db-stores/YieldPoolStore.js +0 -28
- package/services/storage-service/db-stores/YieldPositionStore.d.ts +0 -11
- package/services/storage-service/db-stores/YieldPositionStore.js +0 -63
- package/types/campaigns/index.d.ts +0 -1
- package/types/campaigns/index.js +0 -4
- package/types/campaigns/unlock-dot.d.ts +0 -71
- package/types/campaigns/unlock-dot.js +0 -1
- package/types/ordinal.d.ts +0 -69
- package/types/ordinal.js +0 -1
- package/types/transaction.d.ts +0 -3
- package/types/transaction.js +0 -1
- package/types/yield/actions/index.d.ts +0 -2
- package/types/yield/actions/index.js +0 -5
- package/types/yield/actions/join/index.d.ts +0 -3
- package/types/yield/actions/join/index.js +0 -6
- package/types/yield/actions/join/step.d.ts +0 -96
- package/types/yield/actions/join/step.js +0 -47
- package/types/yield/actions/join/submit.d.ts +0 -58
- package/types/yield/actions/join/submit.js +0 -1
- package/types/yield/actions/join/validate.d.ts +0 -18
- package/types/yield/actions/join/validate.js +0 -10
- package/types/yield/actions/others.d.ts +0 -85
- package/types/yield/actions/others.js +0 -1
- package/types/yield/index.d.ts +0 -2
- package/types/yield/index.js +0 -5
- package/types/yield/info/account/index.d.ts +0 -4
- package/types/yield/info/account/index.js +0 -7
- package/types/yield/info/account/info.d.ts +0 -92
- package/types/yield/info/account/info.js +0 -1
- package/types/yield/info/account/reward.d.ts +0 -47
- package/types/yield/info/account/reward.js +0 -1
- package/types/yield/info/account/target.d.ts +0 -43
- package/types/yield/info/account/target.js +0 -27
- package/types/yield/info/account/unstake.d.ts +0 -31
- package/types/yield/info/account/unstake.js +0 -22
- package/types/yield/info/base.d.ts +0 -45
- package/types/yield/info/base.js +0 -36
- package/types/yield/info/chain/index.d.ts +0 -2
- package/types/yield/info/chain/index.js +0 -5
- package/types/yield/info/chain/info.d.ts +0 -252
- package/types/yield/info/chain/info.js +0 -1
- package/types/yield/info/chain/target.d.ts +0 -37
- package/types/yield/info/chain/target.js +0 -1
- package/types/yield/info/index.d.ts +0 -4
- package/types/yield/info/index.js +0 -7
- package/types/yield/info/pallet.d.ts +0 -143
- package/types/yield/info/pallet.js +0 -9
- package/utils/object.d.ts +0 -1
- package/utils/object.js +0 -6
|
@@ -1,219 +0,0 @@
|
|
|
1
|
-
// Copyright 2019-2022 @subwallet/extension-base
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
|
-
import { ChainType, ExtrinsicType } from '@subwallet/extension-base/background/KoniTypes';
|
|
5
|
-
import { _STAKING_ERA_LENGTH_MAP } from '@subwallet/extension-base/services/chain-service/constants';
|
|
6
|
-
import { _getTokenOnChainAssetId } from '@subwallet/extension-base/services/chain-service/utils';
|
|
7
|
-
import { fakeAddress } from '@subwallet/extension-base/services/earning-service/constants';
|
|
8
|
-
import { EarningStatus, UnstakingStatus, YieldStepType } from '@subwallet/extension-base/types';
|
|
9
|
-
import { BN, BN_TEN, BN_ZERO } from '@polkadot/util';
|
|
10
|
-
import BaseLiquidStakingPoolHandler from "./base.js";
|
|
11
|
-
export default class ParallelLiquidStakingPoolHandler extends BaseLiquidStakingPoolHandler {
|
|
12
|
-
altInputAsset = 'polkadot-NATIVE-DOT';
|
|
13
|
-
derivativeAssets = ['parallel-LOCAL-sDOT'];
|
|
14
|
-
inputAsset = 'parallel-LOCAL-DOT';
|
|
15
|
-
rewardAssets = ['parallel-LOCAL-DOT'];
|
|
16
|
-
feeAssets = ['parallel-NATIVE-PARA'];
|
|
17
|
-
minAmountPercent = 0.97;
|
|
18
|
-
rateDecimals = 18;
|
|
19
|
-
availableMethod = {
|
|
20
|
-
join: true,
|
|
21
|
-
defaultUnstake: true,
|
|
22
|
-
fastUnstake: true,
|
|
23
|
-
cancelUnstake: false,
|
|
24
|
-
withdraw: false,
|
|
25
|
-
claimReward: false
|
|
26
|
-
};
|
|
27
|
-
constructor(state, chain) {
|
|
28
|
-
super(state, chain);
|
|
29
|
-
const chainInfo = this.chainInfo;
|
|
30
|
-
this.slug = `DOT___liquid_staking___${chain}`;
|
|
31
|
-
this.name = `${chainInfo.name} Liquid Staking`;
|
|
32
|
-
this.shortName = chainInfo.name.replaceAll(' Relay Chain', '');
|
|
33
|
-
}
|
|
34
|
-
getDescription() {
|
|
35
|
-
return 'Stake DOT to earn yield on sDOT';
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
/* Subscribe pool info */
|
|
39
|
-
|
|
40
|
-
async getPoolStat() {
|
|
41
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
42
|
-
const [_exchangeRate, _currentBlockHeader, _currentTimestamp, _stakingLedgers] = await Promise.all([substrateApi.api.query.liquidStaking.exchangeRate(), substrateApi.api.rpc.chain.getHeader(), substrateApi.api.query.timestamp.now(), substrateApi.api.query.liquidStaking.stakingLedgers.entries()]);
|
|
43
|
-
let tvl = BN_ZERO;
|
|
44
|
-
for (const _stakingLedger of _stakingLedgers) {
|
|
45
|
-
const _ledger = _stakingLedger[1];
|
|
46
|
-
const ledger = _ledger.toPrimitive();
|
|
47
|
-
tvl = tvl.add(new BN(ledger.total.toString()));
|
|
48
|
-
}
|
|
49
|
-
const exchangeRate = _exchangeRate.toPrimitive();
|
|
50
|
-
const currentBlockHeader = _currentBlockHeader.toPrimitive();
|
|
51
|
-
const currentTimestamp = _currentTimestamp.toPrimitive();
|
|
52
|
-
const beginBlock = currentBlockHeader.number - 24 * 60 * 60 / 6 * 14;
|
|
53
|
-
const _beginBlockHash = await substrateApi.api.rpc.chain.getBlockHash(beginBlock);
|
|
54
|
-
const beginBlockHash = _beginBlockHash.toString();
|
|
55
|
-
const [_beginTimestamp, _beginExchangeRate] = await Promise.all([substrateApi.api.query.timestamp.now.at(beginBlockHash), substrateApi.api.query.liquidStaking.exchangeRate.at(beginBlockHash)]);
|
|
56
|
-
const beginTimestamp = _beginTimestamp.toPrimitive();
|
|
57
|
-
const beginExchangeRate = _beginExchangeRate.toPrimitive();
|
|
58
|
-
const decimals = 10 ** this.rateDecimals;
|
|
59
|
-
const apy = (exchangeRate / beginExchangeRate) ** (365 * 24 * 60 * 60000 / (currentTimestamp - beginTimestamp)) - 1;
|
|
60
|
-
const minStake = substrateApi.api.consts.liquidStaking.minStake.toString();
|
|
61
|
-
const minUnstake = substrateApi.api.consts.liquidStaking.minUnstake.toString();
|
|
62
|
-
this.updateExchangeRate(exchangeRate);
|
|
63
|
-
return {
|
|
64
|
-
...this.baseInfo,
|
|
65
|
-
type: this.type,
|
|
66
|
-
metadata: {
|
|
67
|
-
...this.metadataInfo,
|
|
68
|
-
description: this.getDescription()
|
|
69
|
-
},
|
|
70
|
-
statistic: {
|
|
71
|
-
assetEarning: [{
|
|
72
|
-
slug: this.rewardAssets[0],
|
|
73
|
-
apy: apy * 100,
|
|
74
|
-
exchangeRate: exchangeRate / decimals
|
|
75
|
-
}],
|
|
76
|
-
unstakingPeriod: 24 * 28,
|
|
77
|
-
maxCandidatePerFarmer: 1,
|
|
78
|
-
maxWithdrawalRequestPerFarmer: 1,
|
|
79
|
-
earningThreshold: {
|
|
80
|
-
join: minStake,
|
|
81
|
-
defaultUnstake: minUnstake,
|
|
82
|
-
fastUnstake: '0'
|
|
83
|
-
},
|
|
84
|
-
totalApy: apy * 100,
|
|
85
|
-
tvl: tvl.toString()
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
/* Subscribe pool info */
|
|
91
|
-
|
|
92
|
-
/* Subscribe pool position */
|
|
93
|
-
|
|
94
|
-
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
95
|
-
let cancel = false;
|
|
96
|
-
const substrateApi = this.substrateApi;
|
|
97
|
-
await substrateApi.isReady;
|
|
98
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
99
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
100
|
-
const unsub = await substrateApi.api.query.assets.account.multi(useAddresses.map(address => [_getTokenOnChainAssetId(derivativeTokenInfo), address]), async balances => {
|
|
101
|
-
if (cancel) {
|
|
102
|
-
unsub();
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
const [unlockingChunks, _currentEra, exchangeRate] = await Promise.all([substrateApi.api.query.liquidStaking.unlockings.multi(useAddresses), substrateApi.api.query.liquidStaking.currentEra(), this.getExchangeRate()]);
|
|
106
|
-
const currentEra = _currentEra.toPrimitive();
|
|
107
|
-
const decimals = BN_TEN.pow(new BN(this.rateDecimals));
|
|
108
|
-
for (let i = 0; i < balances.length; i++) {
|
|
109
|
-
const b = balances[i];
|
|
110
|
-
const address = useAddresses[i];
|
|
111
|
-
// @ts-ignore
|
|
112
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-assignment
|
|
113
|
-
const bdata = b === null || b === void 0 ? void 0 : b.toHuman();
|
|
114
|
-
const chunks = unlockingChunks[i].toPrimitive();
|
|
115
|
-
|
|
116
|
-
// @ts-ignore
|
|
117
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-argument
|
|
118
|
-
const activeBalance = bdata && bdata.balance ? new BN(String(bdata === null || bdata === void 0 ? void 0 : bdata.balance).replaceAll(',', '') || '0') : BN_ZERO;
|
|
119
|
-
let totalBalance = activeBalance.mul(new BN(exchangeRate)).div(decimals);
|
|
120
|
-
let unlockingBalance = BN_ZERO;
|
|
121
|
-
const unstakings = [];
|
|
122
|
-
if (chunks) {
|
|
123
|
-
for (const chunk of chunks) {
|
|
124
|
-
const amount = new BN(chunk.value);
|
|
125
|
-
const isClaimable = chunk.era - currentEra < 0;
|
|
126
|
-
const remainingEra = chunk.era - currentEra;
|
|
127
|
-
const eraTime = _STAKING_ERA_LENGTH_MAP[this.chain] || _STAKING_ERA_LENGTH_MAP.default;
|
|
128
|
-
const waitingTime = remainingEra * eraTime;
|
|
129
|
-
totalBalance = totalBalance.add(amount);
|
|
130
|
-
unlockingBalance = unlockingBalance.add(amount);
|
|
131
|
-
unstakings.push({
|
|
132
|
-
chain: this.chain,
|
|
133
|
-
status: isClaimable ? UnstakingStatus.CLAIMABLE : UnstakingStatus.UNLOCKING,
|
|
134
|
-
claimable: amount.toString(),
|
|
135
|
-
waitingTime: waitingTime
|
|
136
|
-
});
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
const result = {
|
|
140
|
-
...this.baseInfo,
|
|
141
|
-
type: this.type,
|
|
142
|
-
address,
|
|
143
|
-
balanceToken: this.inputAsset,
|
|
144
|
-
totalStake: totalBalance.toString(),
|
|
145
|
-
activeStake: activeBalance.toString(),
|
|
146
|
-
unstakeBalance: unlockingBalance.toString(),
|
|
147
|
-
status: activeBalance.gt(BN_ZERO) ? EarningStatus.EARNING_REWARD : EarningStatus.NOT_EARNING,
|
|
148
|
-
derivativeToken: derivativeTokenSlug,
|
|
149
|
-
isBondedBefore: totalBalance.gt(BN_ZERO),
|
|
150
|
-
nominations: [],
|
|
151
|
-
unstakings: unstakings
|
|
152
|
-
};
|
|
153
|
-
resultCallback(result);
|
|
154
|
-
}
|
|
155
|
-
});
|
|
156
|
-
return () => {
|
|
157
|
-
cancel = true;
|
|
158
|
-
unsub();
|
|
159
|
-
};
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
/* Subscribe pool position */
|
|
163
|
-
|
|
164
|
-
/* Join pool action */
|
|
165
|
-
|
|
166
|
-
get submitJoinStepInfo() {
|
|
167
|
-
return {
|
|
168
|
-
name: 'Mint sDOT',
|
|
169
|
-
type: YieldStepType.MINT_SDOT
|
|
170
|
-
};
|
|
171
|
-
}
|
|
172
|
-
async getSubmitStepFee(params) {
|
|
173
|
-
const poolOriginSubstrateApi = await this.substrateApi.isReady;
|
|
174
|
-
const defaultFeeTokenSlug = this.feeAssets[0];
|
|
175
|
-
if (new BN(params.amount).gt(BN_ZERO)) {
|
|
176
|
-
const _mintFeeInfo = await poolOriginSubstrateApi.api.tx.liquidStaking.stake(params.amount).paymentInfo(fakeAddress);
|
|
177
|
-
const mintFeeInfo = _mintFeeInfo.toPrimitive();
|
|
178
|
-
return {
|
|
179
|
-
amount: mintFeeInfo.partialFee.toString(),
|
|
180
|
-
slug: defaultFeeTokenSlug
|
|
181
|
-
};
|
|
182
|
-
} else {
|
|
183
|
-
return {
|
|
184
|
-
amount: '0',
|
|
185
|
-
slug: defaultFeeTokenSlug
|
|
186
|
-
};
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
async handleSubmitStep(data, path) {
|
|
190
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
191
|
-
const extrinsic = substrateApi.api.tx.liquidStaking.stake(data.amount);
|
|
192
|
-
return {
|
|
193
|
-
txChain: this.chain,
|
|
194
|
-
extrinsicType: ExtrinsicType.MINT_SDOT,
|
|
195
|
-
extrinsic,
|
|
196
|
-
txData: data,
|
|
197
|
-
transferNativeAmount: '0',
|
|
198
|
-
chainType: ChainType.SUBSTRATE
|
|
199
|
-
};
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
/* Join pool action */
|
|
203
|
-
|
|
204
|
-
/* Leave pool action */
|
|
205
|
-
|
|
206
|
-
async handleYieldRedeem(amount, address, selectedTarget) {
|
|
207
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
208
|
-
const weightedMinAmount = await this.createParamToRedeem(amount, address);
|
|
209
|
-
const extrinsic = substrateApi.api.tx.ammRoute.swapExactTokensForTokens(['1001', '101'], amount, weightedMinAmount);
|
|
210
|
-
return [ExtrinsicType.REDEEM_SDOT, extrinsic];
|
|
211
|
-
}
|
|
212
|
-
async handleYieldUnstake(amount, address, selectedTarget) {
|
|
213
|
-
const chainApi = await this.substrateApi.isReady;
|
|
214
|
-
const extrinsic = chainApi.api.tx.liquidStaking.unstake(amount, 'RelayChain');
|
|
215
|
-
return [ExtrinsicType.UNSTAKE_SDOT, extrinsic];
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
/* Leave pool action */
|
|
219
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { TransactionError } from '@subwallet/extension-base/background/errors/TransactionError';
|
|
2
|
-
import { ChainType, ExtrinsicType } from '@subwallet/extension-base/background/KoniTypes';
|
|
3
|
-
import KoniState from '@subwallet/extension-base/koni/background/handlers/State';
|
|
4
|
-
import { _EvmApi } from '@subwallet/extension-base/services/chain-service/types';
|
|
5
|
-
import { BaseYieldStepDetail, HandleYieldStepData, LiquidYieldPoolInfo, OptimalYieldPath, OptimalYieldPathParams, SubmitYieldJoinData, TransactionData, UnstakingInfo, YieldPoolMethodInfo, YieldPositionInfo, YieldTokenBaseInfo } from '@subwallet/extension-base/types';
|
|
6
|
-
import { Contract } from 'web3-eth-contract';
|
|
7
|
-
import BaseLiquidStakingPoolHandler from './base';
|
|
8
|
-
export declare const getStellaswapLiquidStakingContract: (networkKey: string, assetAddress: string, evmApi: _EvmApi, options?: {}) => Contract;
|
|
9
|
-
export default class StellaSwapLiquidStakingPoolHandler extends BaseLiquidStakingPoolHandler {
|
|
10
|
-
slug: string;
|
|
11
|
-
protected readonly name: string;
|
|
12
|
-
protected readonly shortName: string;
|
|
13
|
-
protected readonly inputAsset: string;
|
|
14
|
-
protected readonly altInputAsset: string;
|
|
15
|
-
protected readonly derivativeAssets: string[];
|
|
16
|
-
protected readonly rewardAssets: string[];
|
|
17
|
-
protected readonly feeAssets: string[];
|
|
18
|
-
transactionChainType: ChainType;
|
|
19
|
-
protected readonly rateDecimals = 10;
|
|
20
|
-
protected readonly availableMethod: YieldPoolMethodInfo;
|
|
21
|
-
constructor(state: KoniState, chain: string);
|
|
22
|
-
protected getDescription(): string;
|
|
23
|
-
getPoolStat(): Promise<LiquidYieldPoolInfo>;
|
|
24
|
-
subscribePoolPosition(useAddresses: string[], resultCallback: (rs: YieldPositionInfo) => void): Promise<VoidFunction>;
|
|
25
|
-
get submitJoinStepInfo(): BaseYieldStepDetail;
|
|
26
|
-
getTokenApproveStep(params: OptimalYieldPathParams): Promise<[BaseYieldStepDetail, YieldTokenBaseInfo] | undefined>;
|
|
27
|
-
getSubmitStepFee(params: OptimalYieldPathParams): Promise<YieldTokenBaseInfo>;
|
|
28
|
-
protected validateTokenApproveStep(params: OptimalYieldPathParams, path: OptimalYieldPath): Promise<TransactionError[]>;
|
|
29
|
-
protected handleTokenApproveStep(data: SubmitYieldJoinData, path: OptimalYieldPath): Promise<HandleYieldStepData>;
|
|
30
|
-
handleSubmitStep(data: SubmitYieldJoinData, path: OptimalYieldPath): Promise<HandleYieldStepData>;
|
|
31
|
-
handleYieldRedeem(amount: string, address: string, selectedTarget?: string): Promise<[ExtrinsicType, TransactionData]>;
|
|
32
|
-
handleYieldUnstake(amount: string, address: string, selectedTarget?: string): Promise<[ExtrinsicType, TransactionData]>;
|
|
33
|
-
handleYieldWithdraw(address: string, unstakingInfo: UnstakingInfo): Promise<TransactionData>;
|
|
34
|
-
}
|
|
@@ -1,394 +0,0 @@
|
|
|
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 { BasicTxErrorType, ChainType, ExtrinsicType } from '@subwallet/extension-base/background/KoniTypes';
|
|
6
|
-
import { getERC20Contract } from '@subwallet/extension-base/koni/api/tokens/evm/web3';
|
|
7
|
-
import { _getAssetDecimals, _getContractAddressOfToken } from '@subwallet/extension-base/services/chain-service/utils';
|
|
8
|
-
import { EarningStatus, UnstakingStatus, YieldStepType } from '@subwallet/extension-base/types';
|
|
9
|
-
import { recalculateGasPrice } from '@subwallet/extension-base/utils/eth';
|
|
10
|
-
import fetch from 'cross-fetch';
|
|
11
|
-
import { BN, BN_TEN, BN_ZERO } from '@polkadot/util';
|
|
12
|
-
import { ST_LIQUID_TOKEN_ABI } from "../../constants/index.js";
|
|
13
|
-
import BaseLiquidStakingPoolHandler from "./base.js";
|
|
14
|
-
export const getStellaswapLiquidStakingContract = (networkKey, assetAddress, evmApi, options = {}) => {
|
|
15
|
-
// @ts-ignore
|
|
16
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-member-access
|
|
17
|
-
return new evmApi.api.eth.Contract(ST_LIQUID_TOKEN_ABI, assetAddress, options);
|
|
18
|
-
};
|
|
19
|
-
const APR_STATS_URL = 'https://apr-api.stellaswap.com/api/v1/stdot';
|
|
20
|
-
const SUBWALLET_REFERRAL = '0x7e6815f45E624768548d085231f2d453f16FD7DD';
|
|
21
|
-
const MAX_INT = '115792089237316195423570985008687907853269984665640564039457584007913129639935';
|
|
22
|
-
export default class StellaSwapLiquidStakingPoolHandler extends BaseLiquidStakingPoolHandler {
|
|
23
|
-
inputAsset = 'moonbeam-LOCAL-xcDOT';
|
|
24
|
-
altInputAsset = '';
|
|
25
|
-
derivativeAssets = ['moonbeam-ERC20-stDOT-0xbc7E02c4178a7dF7d3E564323a5c359dc96C4db4'];
|
|
26
|
-
rewardAssets = ['moonbeam-LOCAL-xcDOT'];
|
|
27
|
-
feeAssets = ['moonbeam-NATIVE-GLMR'];
|
|
28
|
-
transactionChainType = ChainType.EVM;
|
|
29
|
-
rateDecimals = 10; // Derivative asset decimals
|
|
30
|
-
availableMethod = {
|
|
31
|
-
join: true,
|
|
32
|
-
defaultUnstake: true,
|
|
33
|
-
fastUnstake: false,
|
|
34
|
-
cancelUnstake: false,
|
|
35
|
-
withdraw: true,
|
|
36
|
-
claimReward: false
|
|
37
|
-
};
|
|
38
|
-
constructor(state, chain) {
|
|
39
|
-
super(state, chain);
|
|
40
|
-
this.slug = 'xcDOT___liquid_staking___stellaswap';
|
|
41
|
-
this.name = 'Stellaswap Liquid Staking';
|
|
42
|
-
this._logo = 'stellaswap';
|
|
43
|
-
this.shortName = 'Stellaswap';
|
|
44
|
-
}
|
|
45
|
-
getDescription() {
|
|
46
|
-
return 'Earn rewards by staking xcDOT for stDOT';
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
/* Subscribe pool info */
|
|
50
|
-
|
|
51
|
-
async getPoolStat() {
|
|
52
|
-
const evmApi = this.evmApi;
|
|
53
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
54
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
55
|
-
const stakingContract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
56
|
-
const aprPromise = new Promise(function (resolve) {
|
|
57
|
-
fetch(APR_STATS_URL, {
|
|
58
|
-
method: 'GET'
|
|
59
|
-
}).then(res => {
|
|
60
|
-
resolve(res.json());
|
|
61
|
-
}).catch(console.error);
|
|
62
|
-
});
|
|
63
|
-
const sampleTokenShare = 10 ** _getAssetDecimals(derivativeTokenInfo);
|
|
64
|
-
|
|
65
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
66
|
-
const tvlCall = stakingContract.methods.fundRaisedBalance();
|
|
67
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
68
|
-
const exchangeRateCall = stakingContract.methods.getPooledTokenByShares(sampleTokenShare);
|
|
69
|
-
|
|
70
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
71
|
-
const [aprObject, tvl, equivalentTokenShare] = await Promise.all([aprPromise,
|
|
72
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
73
|
-
tvlCall.call(),
|
|
74
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
75
|
-
exchangeRateCall.call()]);
|
|
76
|
-
const rate = equivalentTokenShare;
|
|
77
|
-
const exchangeRate = rate / 10 ** _getAssetDecimals(derivativeTokenInfo);
|
|
78
|
-
this.updateExchangeRate(rate);
|
|
79
|
-
return {
|
|
80
|
-
...this.baseInfo,
|
|
81
|
-
type: this.type,
|
|
82
|
-
metadata: {
|
|
83
|
-
...this.metadataInfo,
|
|
84
|
-
description: this.getDescription()
|
|
85
|
-
},
|
|
86
|
-
statistic: {
|
|
87
|
-
assetEarning: [{
|
|
88
|
-
slug: this.rewardAssets[0],
|
|
89
|
-
apr: aprObject.result,
|
|
90
|
-
exchangeRate: exchangeRate
|
|
91
|
-
}],
|
|
92
|
-
unstakingPeriod: 24 * 28,
|
|
93
|
-
maxCandidatePerFarmer: 1,
|
|
94
|
-
maxWithdrawalRequestPerFarmer: 1,
|
|
95
|
-
earningThreshold: {
|
|
96
|
-
join: '0',
|
|
97
|
-
defaultUnstake: '0',
|
|
98
|
-
fastUnstake: '0'
|
|
99
|
-
},
|
|
100
|
-
totalApr: aprObject.result,
|
|
101
|
-
tvl: tvl.toString()
|
|
102
|
-
}
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/* Subscribe pool info */
|
|
107
|
-
|
|
108
|
-
/* Subscribe pool position */
|
|
109
|
-
|
|
110
|
-
// eslint-disable-next-line @typescript-eslint/require-await
|
|
111
|
-
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
112
|
-
var _this$derivativeAsset;
|
|
113
|
-
let cancel = false;
|
|
114
|
-
const evmApi = this.evmApi;
|
|
115
|
-
const derivativeTokenSlug = ((_this$derivativeAsset = this.derivativeAssets) === null || _this$derivativeAsset === void 0 ? void 0 : _this$derivativeAsset[0]) || '';
|
|
116
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
117
|
-
const contract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
118
|
-
const getTokenBalance = () => {
|
|
119
|
-
if (!cancel) {
|
|
120
|
-
useAddresses.map(async address => {
|
|
121
|
-
if (cancel) {
|
|
122
|
-
return;
|
|
123
|
-
}
|
|
124
|
-
const rate = await this.getExchangeRate();
|
|
125
|
-
const exchangeRate = new BN(rate);
|
|
126
|
-
const decimals = BN_TEN.pow(new BN(this.rateDecimals));
|
|
127
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
128
|
-
const balance = await contract.methods.balanceOf(address).call();
|
|
129
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
130
|
-
const unbondedObject = await contract.methods.getUnbonded(address).call();
|
|
131
|
-
const unstakings = [];
|
|
132
|
-
let unlockBalance = BN_ZERO;
|
|
133
|
-
if (parseInt(unbondedObject.unbonded) > 0) {
|
|
134
|
-
unlockBalance = unlockBalance.add(new BN(unbondedObject.unbonded));
|
|
135
|
-
unstakings.push({
|
|
136
|
-
chain: this.chain,
|
|
137
|
-
claimable: unbondedObject.unbonded,
|
|
138
|
-
status: UnstakingStatus.CLAIMABLE,
|
|
139
|
-
waitingTime: 0
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
if (parseInt(unbondedObject.waiting) > 0) {
|
|
143
|
-
unlockBalance = unlockBalance.add(new BN(unbondedObject.waiting));
|
|
144
|
-
unstakings.push({
|
|
145
|
-
chain: this.chain,
|
|
146
|
-
claimable: unbondedObject.waiting,
|
|
147
|
-
status: UnstakingStatus.UNLOCKING
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
const activeBalance = new BN(balance);
|
|
151
|
-
const acviteToTotal = activeBalance.mul(exchangeRate).div(decimals);
|
|
152
|
-
const totalBalance = acviteToTotal.add(unlockBalance);
|
|
153
|
-
const result = {
|
|
154
|
-
...this.baseInfo,
|
|
155
|
-
type: this.type,
|
|
156
|
-
address,
|
|
157
|
-
balanceToken: this.inputAsset,
|
|
158
|
-
totalStake: totalBalance.toString(),
|
|
159
|
-
activeStake: balance.toString(),
|
|
160
|
-
unstakeBalance: unlockBalance.toString(),
|
|
161
|
-
isBondedBefore: totalBalance.gt(BN_ZERO),
|
|
162
|
-
derivativeToken: derivativeTokenSlug,
|
|
163
|
-
status: activeBalance.gt(BN_ZERO) ? EarningStatus.EARNING_REWARD : EarningStatus.NOT_EARNING,
|
|
164
|
-
nominations: [],
|
|
165
|
-
unstakings
|
|
166
|
-
};
|
|
167
|
-
resultCallback(result);
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
};
|
|
171
|
-
getTokenBalance();
|
|
172
|
-
const interval = setInterval(getTokenBalance, 30000);
|
|
173
|
-
return () => {
|
|
174
|
-
cancel = true;
|
|
175
|
-
clearInterval(interval);
|
|
176
|
-
};
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
/* Subscribe pool position */
|
|
180
|
-
|
|
181
|
-
/* Join pool action */
|
|
182
|
-
|
|
183
|
-
get submitJoinStepInfo() {
|
|
184
|
-
return {
|
|
185
|
-
name: 'Mint stDOT',
|
|
186
|
-
type: YieldStepType.MINT_STDOT
|
|
187
|
-
};
|
|
188
|
-
}
|
|
189
|
-
async getTokenApproveStep(params) {
|
|
190
|
-
const evmApi = this.evmApi;
|
|
191
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
192
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
193
|
-
const inputTokenSlug = this.inputAsset;
|
|
194
|
-
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
195
|
-
const inputTokenContract = getERC20Contract(this.chain, _getContractAddressOfToken(inputTokenInfo), this.state.getEvmApiMap());
|
|
196
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
197
|
-
const allowanceCall = inputTokenContract.methods.allowance(params.address, _getContractAddressOfToken(derivativeTokenInfo));
|
|
198
|
-
const [allowance, gasPrice] = await Promise.all([
|
|
199
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
200
|
-
await allowanceCall.call(), evmApi.api.eth.getGasPrice()]);
|
|
201
|
-
if (!allowance || parseInt(allowance) <= 0) {
|
|
202
|
-
const step = {
|
|
203
|
-
name: 'Authorize token approval',
|
|
204
|
-
type: YieldStepType.TOKEN_APPROVAL
|
|
205
|
-
};
|
|
206
|
-
|
|
207
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
208
|
-
const estimatedGas = await allowanceCall.estimateGas();
|
|
209
|
-
const fee = {
|
|
210
|
-
slug: this.feeAssets[0],
|
|
211
|
-
amount: (estimatedGas * parseInt(gasPrice)).toString()
|
|
212
|
-
};
|
|
213
|
-
return [step, fee];
|
|
214
|
-
}
|
|
215
|
-
return undefined;
|
|
216
|
-
}
|
|
217
|
-
async getSubmitStepFee(params) {
|
|
218
|
-
const evmApi = this.evmApi;
|
|
219
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
220
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
221
|
-
if (new BN(params.amount).gt(BN_ZERO)) {
|
|
222
|
-
const stakingContract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
223
|
-
|
|
224
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
225
|
-
const depositCall = stakingContract.methods.deposit(params.amount);
|
|
226
|
-
let estimatedDepositGas = 0;
|
|
227
|
-
try {
|
|
228
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
229
|
-
estimatedDepositGas = await depositCall.estimateGas({
|
|
230
|
-
from: params.address
|
|
231
|
-
});
|
|
232
|
-
} catch (e) {
|
|
233
|
-
console.error(e);
|
|
234
|
-
}
|
|
235
|
-
const gasPrice = await evmApi.api.eth.getGasPrice();
|
|
236
|
-
return {
|
|
237
|
-
slug: this.feeAssets[0],
|
|
238
|
-
amount: (estimatedDepositGas * parseInt(gasPrice)).toString()
|
|
239
|
-
};
|
|
240
|
-
} else {
|
|
241
|
-
return {
|
|
242
|
-
slug: this.feeAssets[0],
|
|
243
|
-
amount: '0'
|
|
244
|
-
};
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
async validateTokenApproveStep(params, path) {
|
|
248
|
-
return Promise.resolve([]);
|
|
249
|
-
}
|
|
250
|
-
async handleTokenApproveStep(data, path) {
|
|
251
|
-
const {
|
|
252
|
-
address
|
|
253
|
-
} = data;
|
|
254
|
-
const inputTokenSlug = this.inputAsset;
|
|
255
|
-
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
256
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(this.derivativeAssets[0]);
|
|
257
|
-
const derivativeTokenContractAddress = _getContractAddressOfToken(derivativeTokenInfo);
|
|
258
|
-
const evmApi = this.evmApi;
|
|
259
|
-
const inputTokenContract = getERC20Contract(this.chain, _getContractAddressOfToken(inputTokenInfo), this.state.getEvmApiMap());
|
|
260
|
-
|
|
261
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
262
|
-
const approveCall = inputTokenContract.methods.approve(derivativeTokenContractAddress, MAX_INT); // TODO: need test
|
|
263
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
264
|
-
const approveEncodedCall = approveCall.encodeABI();
|
|
265
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
266
|
-
const gasLimit = await approveCall.estimateGas({
|
|
267
|
-
from: address
|
|
268
|
-
});
|
|
269
|
-
const _price = await evmApi.api.eth.getGasPrice();
|
|
270
|
-
const gasPrice = recalculateGasPrice(_price, this.chain);
|
|
271
|
-
const transactionObject = {
|
|
272
|
-
from: address,
|
|
273
|
-
to: _getContractAddressOfToken(inputTokenInfo),
|
|
274
|
-
data: approveEncodedCall,
|
|
275
|
-
gasPrice: gasPrice,
|
|
276
|
-
gas: gasLimit
|
|
277
|
-
};
|
|
278
|
-
const _data = {
|
|
279
|
-
inputTokenSlug: inputTokenSlug,
|
|
280
|
-
spenderTokenSlug: this.derivativeAssets[0]
|
|
281
|
-
};
|
|
282
|
-
return Promise.resolve({
|
|
283
|
-
txChain: this.chain,
|
|
284
|
-
extrinsicType: ExtrinsicType.TOKEN_APPROVE,
|
|
285
|
-
extrinsic: transactionObject,
|
|
286
|
-
txData: _data,
|
|
287
|
-
transferNativeAmount: '0',
|
|
288
|
-
chainType: ChainType.EVM
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
async handleSubmitStep(data, path) {
|
|
292
|
-
const {
|
|
293
|
-
address,
|
|
294
|
-
amount
|
|
295
|
-
} = data;
|
|
296
|
-
const evmApi = this.evmApi;
|
|
297
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
298
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
299
|
-
const stakingContract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
300
|
-
|
|
301
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
302
|
-
const depositCall = stakingContract.methods.deposit(amount, SUBWALLET_REFERRAL); // TODO: need test
|
|
303
|
-
|
|
304
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
305
|
-
const depositEncodedCall = depositCall.encodeABI();
|
|
306
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
307
|
-
const gasLimit = await depositCall.estimateGas({
|
|
308
|
-
from: address
|
|
309
|
-
});
|
|
310
|
-
const _price = await evmApi.api.eth.getGasPrice();
|
|
311
|
-
const gasPrice = recalculateGasPrice(_price, this.chain);
|
|
312
|
-
const transactionObject = {
|
|
313
|
-
from: address,
|
|
314
|
-
to: _getContractAddressOfToken(derivativeTokenInfo),
|
|
315
|
-
data: depositEncodedCall,
|
|
316
|
-
gasPrice: gasPrice,
|
|
317
|
-
gas: gasLimit
|
|
318
|
-
};
|
|
319
|
-
return {
|
|
320
|
-
txChain: this.chain,
|
|
321
|
-
extrinsicType: ExtrinsicType.MINT_STDOT,
|
|
322
|
-
extrinsic: transactionObject,
|
|
323
|
-
txData: data,
|
|
324
|
-
transferNativeAmount: '0',
|
|
325
|
-
chainType: ChainType.EVM
|
|
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(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, _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 = recalculateGasPrice(_price, this.chain);
|
|
353
|
-
const transaction = {
|
|
354
|
-
from: address,
|
|
355
|
-
to: _getContractAddressOfToken(derivativeTokenInfo),
|
|
356
|
-
data: redeemEncodedCall,
|
|
357
|
-
gasPrice: gasPrice,
|
|
358
|
-
gas: gasLimit
|
|
359
|
-
};
|
|
360
|
-
return [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, _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 = recalculateGasPrice(_price, this.chain);
|
|
384
|
-
return {
|
|
385
|
-
from: address,
|
|
386
|
-
to: _getContractAddressOfToken(derivativeTokenInfo),
|
|
387
|
-
data: withdrawEncodedCall,
|
|
388
|
-
gasPrice: gasPrice,
|
|
389
|
-
gas: gasLimit
|
|
390
|
-
}; // TODO: check tx history parsing
|
|
391
|
-
}
|
|
392
|
-
|
|
393
|
-
/* Other actions */
|
|
394
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { _ChainInfo } from '@subwallet/chain-list/types';
|
|
2
|
-
import { ExtrinsicType, UnstakingInfo } from '@subwallet/extension-base/background/KoniTypes';
|
|
3
|
-
import { _SubstrateApi } from '@subwallet/extension-base/services/chain-service/types';
|
|
4
|
-
import { BaseYieldPositionInfo, EarningRewardItem, ParachainStakingStakeOption, StakeCancelWithdrawalParams, SubmitJoinNativeStaking, TransactionData, ValidatorInfo, YieldPoolInfo, YieldPositionInfo, YieldStepBaseInfo, YieldTokenBaseInfo } from '@subwallet/extension-base/types';
|
|
5
|
-
import { SubmittableExtrinsic } from '@polkadot/api/types';
|
|
6
|
-
import BaseParaNativeStakingPoolHandler from './base-para';
|
|
7
|
-
export default class AmplitudeNativeStakingPoolHandler extends BaseParaNativeStakingPoolHandler {
|
|
8
|
-
subscribePoolInfo(callback: (data: YieldPoolInfo) => void): Promise<VoidFunction>;
|
|
9
|
-
parseNominatorMetadata(chainInfo: _ChainInfo, address: string, substrateApi: _SubstrateApi, delegatorState: ParachainStakingStakeOption[], unstakingInfo: Record<string, number>): Promise<Omit<YieldPositionInfo, keyof BaseYieldPositionInfo>>;
|
|
10
|
-
subscribePoolPosition(useAddresses: string[], resultCallback: (rs: YieldPositionInfo) => void): Promise<VoidFunction>;
|
|
11
|
-
getPoolReward(useAddresses: string[], callBack: (rs: EarningRewardItem) => void): Promise<VoidFunction>;
|
|
12
|
-
getPoolTargets(): Promise<ValidatorInfo[]>;
|
|
13
|
-
get defaultSubmitStep(): YieldStepBaseInfo;
|
|
14
|
-
createJoinExtrinsic(data: SubmitJoinNativeStaking, positionInfo?: YieldPositionInfo, bondDest?: string): Promise<[TransactionData, YieldTokenBaseInfo]>;
|
|
15
|
-
handleYieldUnstake(amount: string, address: string, selectedTarget?: string): Promise<[ExtrinsicType, TransactionData]>;
|
|
16
|
-
/**
|
|
17
|
-
* @todo Need recheck
|
|
18
|
-
* */
|
|
19
|
-
handleYieldCancelUnstake(params: StakeCancelWithdrawalParams): Promise<TransactionData>;
|
|
20
|
-
handleYieldWithdraw(address: string, unstakingInfo: UnstakingInfo): Promise<TransactionData>;
|
|
21
|
-
handleYieldClaimReward(address: string, bondReward?: boolean): Promise<SubmittableExtrinsic<"promise", import("@polkadot/types/types").ISubmittableResult>>;
|
|
22
|
-
}
|