@subwallet/extension-base 1.1.29-0 → 1.1.29-beta.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 +94 -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/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 +347 -69
- package/cjs/koni/background/handlers/State.js +51 -3
- package/cjs/koni/background/handlers/index.js +4 -2
- package/cjs/koni/background/subscription.js +88 -18
- 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 +230 -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 +176 -0
- package/cjs/services/earning-service/handlers/liquid-staking/acala.js +206 -0
- package/cjs/services/earning-service/handlers/liquid-staking/base.js +43 -0
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost.js +267 -0
- package/cjs/services/earning-service/handlers/liquid-staking/index.js +34 -0
- package/cjs/services/earning-service/handlers/liquid-staking/parallel.js +190 -0
- package/cjs/services/earning-service/handlers/liquid-staking/stella-swap.js +382 -0
- package/cjs/services/earning-service/handlers/native-staking/amplitude.js +380 -0
- package/cjs/services/earning-service/handlers/native-staking/astar.js +454 -0
- package/cjs/services/earning-service/handlers/native-staking/base-para.js +137 -0
- package/cjs/services/earning-service/handlers/native-staking/base.js +119 -0
- package/cjs/services/earning-service/handlers/native-staking/index.js +34 -0
- package/cjs/services/earning-service/handlers/native-staking/para-chain.js +381 -0
- package/cjs/services/earning-service/handlers/native-staking/relay-chain.js +540 -0
- package/cjs/services/earning-service/handlers/nomination-pool/index.js +528 -0
- package/cjs/services/earning-service/handlers/special.js +412 -0
- package/cjs/services/earning-service/service.js +351 -0
- package/cjs/services/earning-service/utils/index.js +128 -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/MigrateLedgerAccount.js +1 -1
- package/cjs/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
- package/cjs/services/migration-service/scripts/databases/MigrateEarningHistory.js +21 -0
- package/cjs/services/migration-service/scripts/databases/MigrateEarningVersion.js +21 -0
- package/cjs/services/migration-service/scripts/index.js +7 -1
- 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 +51 -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/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 +185 -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 +47 -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 +41 -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/utils/fetchStaticData.js +2 -1
- package/cjs/utils/index.js +89 -1
- package/cjs/utils/object.js +12 -0
- package/cjs/utils/yield/index.js +3 -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 +16 -1
- package/koni/background/handlers/Extension.js +306 -30
- package/koni/background/handlers/State.d.ts +18 -2
- package/koni/background/handlers/State.js +50 -3
- package/koni/background/handlers/index.js +4 -2
- package/koni/background/subscription.d.ts +5 -1
- package/koni/background/subscription.js +90 -20
- package/package.json +316 -3
- 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 +108 -0
- package/services/earning-service/handlers/base.js +224 -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 +168 -0
- package/services/earning-service/handlers/liquid-staking/acala.d.ts +27 -0
- package/services/earning-service/handlers/liquid-staking/acala.js +198 -0
- package/services/earning-service/handlers/liquid-staking/base.d.ts +9 -0
- package/services/earning-service/handlers/liquid-staking/base.js +35 -0
- package/services/earning-service/handlers/liquid-staking/bifrost.d.ts +44 -0
- package/services/earning-service/handlers/liquid-staking/bifrost.js +256 -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 +182 -0
- package/services/earning-service/handlers/liquid-staking/stella-swap.d.ts +36 -0
- package/services/earning-service/handlers/liquid-staking/stella-swap.js +372 -0
- package/services/earning-service/handlers/native-staking/amplitude.d.ts +22 -0
- package/services/earning-service/handlers/native-staking/amplitude.js +371 -0
- package/services/earning-service/handlers/native-staking/astar.d.ts +19 -0
- package/services/earning-service/handlers/native-staking/astar.js +444 -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 +20 -0
- package/services/earning-service/handlers/native-staking/base.js +110 -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 +373 -0
- package/services/earning-service/handlers/native-staking/relay-chain.d.ts +21 -0
- package/services/earning-service/handlers/native-staking/relay-chain.js +531 -0
- package/services/earning-service/handlers/nomination-pool/index.d.ts +33 -0
- package/services/earning-service/handlers/nomination-pool/index.js +518 -0
- package/services/earning-service/handlers/special.d.ts +59 -0
- package/services/earning-service/handlers/special.js +404 -0
- package/services/earning-service/service.d.ts +40 -0
- package/services/earning-service/service.js +343 -0
- package/services/earning-service/utils/index.d.ts +18 -0
- package/services/earning-service/utils/index.js +112 -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/databases/MigrateEarningHistory.d.ts +4 -0
- package/services/migration-service/scripts/databases/MigrateEarningHistory.js +13 -0
- package/services/migration-service/scripts/databases/MigrateEarningVersion.d.ts +4 -0
- package/services/migration-service/scripts/databases/MigrateEarningVersion.js +13 -0
- package/services/migration-service/scripts/index.js +7 -1
- 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 +18 -1
- package/services/storage-service/DatabaseService.js +51 -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 +183 -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 +94 -0
- package/types/yield/actions/join/step.js +46 -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 +63 -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 +101 -0
- package/types/yield/info/account/info.js +1 -0
- package/types/yield/info/account/reward.d.ts +30 -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 +45 -0
- package/types/yield/info/base.js +36 -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 +217 -0
- package/types/yield/info/chain/info.js +1 -0
- package/types/yield/info/chain/target.d.ts +37 -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,182 @@
|
|
|
1
|
+
// Copyright 2019-2022 @subwallet/extension-base
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { ExtrinsicType } from '@subwallet/extension-base/background/KoniTypes';
|
|
5
|
+
import { _getTokenOnChainAssetId } from '@subwallet/extension-base/services/chain-service/utils';
|
|
6
|
+
import { fakeAddress } from '@subwallet/extension-base/services/earning-service/constants';
|
|
7
|
+
import { EarningStatus, YieldStepType } from '@subwallet/extension-base/types';
|
|
8
|
+
import { BN, BN_ZERO } from '@polkadot/util';
|
|
9
|
+
import BaseLiquidStakingPoolHandler from "./base.js";
|
|
10
|
+
export default class ParallelLiquidStakingPoolHandler extends BaseLiquidStakingPoolHandler {
|
|
11
|
+
altInputAsset = 'polkadot-NATIVE-DOT';
|
|
12
|
+
derivativeAssets = ['parallel-LOCAL-sDOT'];
|
|
13
|
+
inputAsset = 'parallel-LOCAL-DOT';
|
|
14
|
+
rewardAssets = ['parallel-LOCAL-DOT'];
|
|
15
|
+
feeAssets = ['parallel-NATIVE-PARA'];
|
|
16
|
+
/** @inner */
|
|
17
|
+
minAmountPercent = 0.97;
|
|
18
|
+
/** @inner */
|
|
19
|
+
allowDefaultUnstake = true;
|
|
20
|
+
constructor(state, chain) {
|
|
21
|
+
super(state, chain);
|
|
22
|
+
const chainInfo = this.chainInfo;
|
|
23
|
+
this.slug = `DOT___liquid_staking___${chain}`;
|
|
24
|
+
this.name = `${chainInfo.name} Liquid Staking`;
|
|
25
|
+
this.shortName = chainInfo.name.replaceAll(' Relay Chain', '');
|
|
26
|
+
}
|
|
27
|
+
getDescription() {
|
|
28
|
+
return 'Stake DOT to earn yield on sDOT';
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
/* Subscribe pool info */
|
|
32
|
+
|
|
33
|
+
async getPoolStat() {
|
|
34
|
+
const substrateApi = await this.substrateApi.isReady;
|
|
35
|
+
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()]);
|
|
36
|
+
let tvl = BN_ZERO;
|
|
37
|
+
for (const _stakingLedger of _stakingLedgers) {
|
|
38
|
+
const _ledger = _stakingLedger[1];
|
|
39
|
+
const ledger = _ledger.toPrimitive();
|
|
40
|
+
tvl = tvl.add(new BN(ledger.total.toString()));
|
|
41
|
+
}
|
|
42
|
+
const exchangeRate = _exchangeRate.toPrimitive();
|
|
43
|
+
const currentBlockHeader = _currentBlockHeader.toPrimitive();
|
|
44
|
+
const currentTimestamp = _currentTimestamp.toPrimitive();
|
|
45
|
+
const beginBlock = currentBlockHeader.number - 24 * 60 * 60 / 6 * 14;
|
|
46
|
+
const _beginBlockHash = await substrateApi.api.rpc.chain.getBlockHash(beginBlock);
|
|
47
|
+
const beginBlockHash = _beginBlockHash.toString();
|
|
48
|
+
const [_beginTimestamp, _beginExchangeRate] = await Promise.all([substrateApi.api.query.timestamp.now.at(beginBlockHash), substrateApi.api.query.liquidStaking.exchangeRate.at(beginBlockHash)]);
|
|
49
|
+
const beginTimestamp = _beginTimestamp.toPrimitive();
|
|
50
|
+
const beginExchangeRate = _beginExchangeRate.toPrimitive();
|
|
51
|
+
const decimals = 10 ** 18;
|
|
52
|
+
const apy = (exchangeRate / beginExchangeRate) ** (365 * 24 * 60 * 60000 / (currentTimestamp - beginTimestamp)) - 1;
|
|
53
|
+
return {
|
|
54
|
+
...this.baseInfo,
|
|
55
|
+
type: this.type,
|
|
56
|
+
metadata: {
|
|
57
|
+
...this.metadataInfo,
|
|
58
|
+
description: this.getDescription()
|
|
59
|
+
},
|
|
60
|
+
statistic: {
|
|
61
|
+
assetEarning: [{
|
|
62
|
+
slug: this.rewardAssets[0],
|
|
63
|
+
apy: apy * 100,
|
|
64
|
+
exchangeRate: exchangeRate / decimals
|
|
65
|
+
}],
|
|
66
|
+
unstakingPeriod: 24 * 28,
|
|
67
|
+
maxCandidatePerFarmer: 1,
|
|
68
|
+
maxWithdrawalRequestPerFarmer: 1,
|
|
69
|
+
minJoinPool: '10000000000',
|
|
70
|
+
minWithdrawal: '5000000000',
|
|
71
|
+
totalApy: apy * 100,
|
|
72
|
+
tvl: tvl.toString()
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
/* Subscribe pool info */
|
|
78
|
+
|
|
79
|
+
/* Subscribe pool position */
|
|
80
|
+
|
|
81
|
+
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
82
|
+
let cancel = false;
|
|
83
|
+
const substrateApi = this.substrateApi;
|
|
84
|
+
await substrateApi.isReady;
|
|
85
|
+
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
86
|
+
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
87
|
+
const unsub = await substrateApi.api.query.assets.account.multi(useAddresses.map(address => [_getTokenOnChainAssetId(derivativeTokenInfo), address]), balances => {
|
|
88
|
+
if (cancel) {
|
|
89
|
+
unsub();
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
for (let i = 0; i < balances.length; i++) {
|
|
93
|
+
const b = balances[i];
|
|
94
|
+
const address = useAddresses[i];
|
|
95
|
+
// @ts-ignore
|
|
96
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-assignment
|
|
97
|
+
const bdata = b === null || b === void 0 ? void 0 : b.toHuman();
|
|
98
|
+
|
|
99
|
+
// @ts-ignore
|
|
100
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-argument
|
|
101
|
+
const bnTotalBalance = bdata && bdata.balance ? new BN(String(bdata === null || bdata === void 0 ? void 0 : bdata.balance).replaceAll(',', '') || '0') : BN_ZERO;
|
|
102
|
+
const totalBalance = bnTotalBalance.toString();
|
|
103
|
+
const result = {
|
|
104
|
+
...this.baseInfo,
|
|
105
|
+
type: this.type,
|
|
106
|
+
address,
|
|
107
|
+
balanceToken: this.inputAsset,
|
|
108
|
+
totalStake: totalBalance,
|
|
109
|
+
activeStake: totalBalance,
|
|
110
|
+
unstakeBalance: '0',
|
|
111
|
+
status: EarningStatus.EARNING_REWARD,
|
|
112
|
+
derivativeToken: derivativeTokenSlug,
|
|
113
|
+
isBondedBefore: bnTotalBalance.gt(BN_ZERO),
|
|
114
|
+
nominations: [],
|
|
115
|
+
unstakings: []
|
|
116
|
+
};
|
|
117
|
+
resultCallback(result);
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
return () => {
|
|
121
|
+
cancel = true;
|
|
122
|
+
unsub();
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
/* Subscribe pool position */
|
|
127
|
+
|
|
128
|
+
/* Join pool action */
|
|
129
|
+
|
|
130
|
+
get submitJoinStepInfo() {
|
|
131
|
+
return {
|
|
132
|
+
name: 'Mint sDOT',
|
|
133
|
+
type: YieldStepType.MINT_SDOT
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
async getSubmitStepFee(params) {
|
|
137
|
+
const poolOriginSubstrateApi = await this.substrateApi.isReady;
|
|
138
|
+
const defaultFeeTokenSlug = this.feeAssets[0];
|
|
139
|
+
if (new BN(params.amount).gt(BN_ZERO)) {
|
|
140
|
+
const _mintFeeInfo = await poolOriginSubstrateApi.api.tx.liquidStaking.stake(params.amount).paymentInfo(fakeAddress);
|
|
141
|
+
const mintFeeInfo = _mintFeeInfo.toPrimitive();
|
|
142
|
+
return {
|
|
143
|
+
amount: mintFeeInfo.partialFee.toString(),
|
|
144
|
+
slug: defaultFeeTokenSlug
|
|
145
|
+
};
|
|
146
|
+
} else {
|
|
147
|
+
return {
|
|
148
|
+
amount: '0',
|
|
149
|
+
slug: defaultFeeTokenSlug
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
async handleSubmitStep(data, path) {
|
|
154
|
+
const substrateApi = await this.substrateApi.isReady;
|
|
155
|
+
const extrinsic = substrateApi.api.tx.liquidStaking.stake(data.amount);
|
|
156
|
+
return {
|
|
157
|
+
txChain: this.chain,
|
|
158
|
+
extrinsicType: ExtrinsicType.MINT_SDOT,
|
|
159
|
+
extrinsic,
|
|
160
|
+
txData: data,
|
|
161
|
+
transferNativeAmount: '0'
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
/* Join pool action */
|
|
166
|
+
|
|
167
|
+
/* Leave pool action */
|
|
168
|
+
|
|
169
|
+
async handleYieldRedeem(amount, address, selectedTarget) {
|
|
170
|
+
const substrateApi = await this.substrateApi.isReady;
|
|
171
|
+
const weightedMinAmount = await this.createParamToRedeem(amount, address);
|
|
172
|
+
const extrinsic = substrateApi.api.tx.ammRoute.swapExactTokensForTokens(['1001', '101'], amount, weightedMinAmount);
|
|
173
|
+
return [ExtrinsicType.REDEEM_SDOT, extrinsic];
|
|
174
|
+
}
|
|
175
|
+
async handleYieldUnstake(amount, address, selectedTarget) {
|
|
176
|
+
const chainApi = await this.substrateApi.isReady;
|
|
177
|
+
const extrinsic = chainApi.api.tx.liquidStaking.unstake(amount, 'RelayChain');
|
|
178
|
+
return [ExtrinsicType.UNSTAKE_SDOT, extrinsic];
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
/* Leave pool action */
|
|
182
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
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, 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
|
+
protected readonly name: string;
|
|
11
|
+
protected readonly shortName: string;
|
|
12
|
+
protected readonly inputAsset: string;
|
|
13
|
+
protected readonly altInputAsset: string;
|
|
14
|
+
protected readonly derivativeAssets: string[];
|
|
15
|
+
protected readonly rewardAssets: string[];
|
|
16
|
+
protected readonly feeAssets: string[];
|
|
17
|
+
/** @inner */
|
|
18
|
+
protected readonly allowDefaultUnstake = true;
|
|
19
|
+
/** @inner */
|
|
20
|
+
protected readonly allowFastUnstake = false;
|
|
21
|
+
slug: string;
|
|
22
|
+
transactionChainType: ChainType;
|
|
23
|
+
constructor(state: KoniState, chain: string);
|
|
24
|
+
protected getDescription(): string;
|
|
25
|
+
getPoolStat(): Promise<LiquidYieldPoolInfo>;
|
|
26
|
+
subscribePoolPosition(useAddresses: string[], resultCallback: (rs: YieldPositionInfo) => void): Promise<VoidFunction>;
|
|
27
|
+
get submitJoinStepInfo(): BaseYieldStepDetail;
|
|
28
|
+
getTokenApproveStep(params: OptimalYieldPathParams): Promise<[BaseYieldStepDetail, YieldTokenBaseInfo] | undefined>;
|
|
29
|
+
getSubmitStepFee(params: OptimalYieldPathParams): Promise<YieldTokenBaseInfo>;
|
|
30
|
+
generateOptimalPath(params: OptimalYieldPathParams): Promise<OptimalYieldPath>;
|
|
31
|
+
protected validateTokenApproveStep(params: OptimalYieldPathParams, path: OptimalYieldPath): Promise<TransactionError[]>;
|
|
32
|
+
protected handleTokenApproveStep(data: SubmitYieldJoinData, path: OptimalYieldPath): Promise<HandleYieldStepData>;
|
|
33
|
+
handleSubmitStep(data: SubmitYieldJoinData, path: OptimalYieldPath): Promise<HandleYieldStepData>;
|
|
34
|
+
handleYieldRedeem(amount: string, address: string, selectedTarget?: string): Promise<[ExtrinsicType, TransactionData]>;
|
|
35
|
+
handleYieldUnstake(amount: string, address: string, selectedTarget?: string): Promise<[ExtrinsicType, TransactionData]>;
|
|
36
|
+
}
|
|
@@ -0,0 +1,372 @@
|
|
|
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 fetch from 'cross-fetch';
|
|
10
|
+
import { BN, BN_ZERO } from '@polkadot/util';
|
|
11
|
+
import { DEFAULT_YIELD_FIRST_STEP, ST_LIQUID_TOKEN_ABI } from "../../constants/index.js";
|
|
12
|
+
import BaseLiquidStakingPoolHandler from "./base.js";
|
|
13
|
+
export const getStellaswapLiquidStakingContract = (networkKey, assetAddress, evmApi, options = {}) => {
|
|
14
|
+
// @ts-ignore
|
|
15
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-member-access
|
|
16
|
+
return new evmApi.api.eth.Contract(ST_LIQUID_TOKEN_ABI, assetAddress, options);
|
|
17
|
+
};
|
|
18
|
+
const APR_STATS_URL = 'https://apr-api.stellaswap.com/api/v1/stdot';
|
|
19
|
+
const MAX_INT = '115792089237316195423570985008687907853269984665640564039457584007913129639935';
|
|
20
|
+
export default class StellaSwapLiquidStakingPoolHandler extends BaseLiquidStakingPoolHandler {
|
|
21
|
+
inputAsset = 'moonbeam-LOCAL-xcDOT';
|
|
22
|
+
altInputAsset = '';
|
|
23
|
+
derivativeAssets = ['moonbeam-ERC20-stDOT-0xbc7E02c4178a7dF7d3E564323a5c359dc96C4db4'];
|
|
24
|
+
rewardAssets = ['moonbeam-LOCAL-xcDOT'];
|
|
25
|
+
feeAssets = ['moonbeam-NATIVE-GLMR'];
|
|
26
|
+
/** @inner */
|
|
27
|
+
allowDefaultUnstake = true;
|
|
28
|
+
/** @inner */
|
|
29
|
+
allowFastUnstake = false;
|
|
30
|
+
transactionChainType = ChainType.EVM;
|
|
31
|
+
constructor(state, chain) {
|
|
32
|
+
super(state, chain);
|
|
33
|
+
this.slug = 'xcDOT___liquid_staking___stellaswap';
|
|
34
|
+
this.name = 'Stellaswap Liquid Staking';
|
|
35
|
+
this._logo = 'stellaswap';
|
|
36
|
+
this.shortName = 'Stellaswap';
|
|
37
|
+
}
|
|
38
|
+
getDescription() {
|
|
39
|
+
return 'Earn rewards by staking xcDOT for stDOT';
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/* Subscribe pool info */
|
|
43
|
+
|
|
44
|
+
async getPoolStat() {
|
|
45
|
+
const evmApi = this.evmApi;
|
|
46
|
+
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
47
|
+
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
48
|
+
const stakingContract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
49
|
+
const aprPromise = new Promise(function (resolve) {
|
|
50
|
+
fetch(APR_STATS_URL, {
|
|
51
|
+
method: 'GET'
|
|
52
|
+
}).then(res => {
|
|
53
|
+
resolve(res.json());
|
|
54
|
+
}).catch(console.error);
|
|
55
|
+
});
|
|
56
|
+
const sampleTokenShare = 10 ** _getAssetDecimals(derivativeTokenInfo);
|
|
57
|
+
|
|
58
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
59
|
+
const tvlCall = stakingContract.methods.fundRaisedBalance();
|
|
60
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
61
|
+
const exchangeRateCall = stakingContract.methods.getPooledTokenByShares(sampleTokenShare);
|
|
62
|
+
|
|
63
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
64
|
+
const [aprObject, tvl, equivalentTokenShare] = await Promise.all([aprPromise,
|
|
65
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
66
|
+
tvlCall.call(),
|
|
67
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
68
|
+
exchangeRateCall.call()]);
|
|
69
|
+
const exchangeRate = equivalentTokenShare / 10 ** _getAssetDecimals(derivativeTokenInfo);
|
|
70
|
+
return {
|
|
71
|
+
...this.baseInfo,
|
|
72
|
+
type: this.type,
|
|
73
|
+
metadata: {
|
|
74
|
+
...this.metadataInfo,
|
|
75
|
+
description: this.getDescription()
|
|
76
|
+
},
|
|
77
|
+
statistic: {
|
|
78
|
+
assetEarning: [{
|
|
79
|
+
slug: this.rewardAssets[0],
|
|
80
|
+
apr: aprObject.result,
|
|
81
|
+
exchangeRate: exchangeRate
|
|
82
|
+
}],
|
|
83
|
+
unstakingPeriod: 24 * 28,
|
|
84
|
+
maxCandidatePerFarmer: 1,
|
|
85
|
+
maxWithdrawalRequestPerFarmer: 1,
|
|
86
|
+
minJoinPool: '0',
|
|
87
|
+
minWithdrawal: '0',
|
|
88
|
+
totalApr: aprObject.result,
|
|
89
|
+
tvl: tvl.toString()
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/* Subscribe pool info */
|
|
95
|
+
|
|
96
|
+
/* Subscribe pool position */
|
|
97
|
+
|
|
98
|
+
// eslint-disable-next-line @typescript-eslint/require-await
|
|
99
|
+
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
100
|
+
var _this$derivativeAsset;
|
|
101
|
+
let cancel = false;
|
|
102
|
+
const evmApi = this.evmApi;
|
|
103
|
+
const derivativeTokenSlug = ((_this$derivativeAsset = this.derivativeAssets) === null || _this$derivativeAsset === void 0 ? void 0 : _this$derivativeAsset[0]) || '';
|
|
104
|
+
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
105
|
+
const contract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
106
|
+
const getTokenBalance = () => {
|
|
107
|
+
if (!cancel) {
|
|
108
|
+
useAddresses.map(async address => {
|
|
109
|
+
if (!cancel) {
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
114
|
+
const balance = await contract.methods.balanceOf(address).call();
|
|
115
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
116
|
+
const unbondedObject = await contract.methods.getUnbonded(address).call();
|
|
117
|
+
const unstakings = [];
|
|
118
|
+
let unlockBalance = BN_ZERO;
|
|
119
|
+
if (parseInt(unbondedObject.unbonded) > 0) {
|
|
120
|
+
unlockBalance = unlockBalance.add(new BN(unbondedObject.unbonded));
|
|
121
|
+
unstakings.push({
|
|
122
|
+
chain: this.chain,
|
|
123
|
+
claimable: unbondedObject.unbonded,
|
|
124
|
+
status: UnstakingStatus.CLAIMABLE,
|
|
125
|
+
waitingTime: 0
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
if (parseInt(unbondedObject.waiting) > 0) {
|
|
129
|
+
unlockBalance = unlockBalance.add(new BN(unbondedObject.waiting));
|
|
130
|
+
unstakings.push({
|
|
131
|
+
chain: this.chain,
|
|
132
|
+
claimable: unbondedObject.waiting,
|
|
133
|
+
status: UnstakingStatus.UNLOCKING,
|
|
134
|
+
waitingTime: 20 // TODO: Recheck
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const totalBalance = new BN(balance).add(unlockBalance);
|
|
139
|
+
const result = {
|
|
140
|
+
...this.baseInfo,
|
|
141
|
+
type: this.type,
|
|
142
|
+
address,
|
|
143
|
+
balanceToken: this.inputAsset,
|
|
144
|
+
totalStake: totalBalance.toString(),
|
|
145
|
+
activeStake: balance.toString(),
|
|
146
|
+
unstakeBalance: unlockBalance.toString(),
|
|
147
|
+
isBondedBefore: totalBalance.gt(BN_ZERO),
|
|
148
|
+
derivativeToken: derivativeTokenSlug,
|
|
149
|
+
status: EarningStatus.EARNING_REWARD,
|
|
150
|
+
nominations: [],
|
|
151
|
+
unstakings
|
|
152
|
+
};
|
|
153
|
+
resultCallback(result);
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
};
|
|
157
|
+
getTokenBalance();
|
|
158
|
+
const interval = setInterval(getTokenBalance, 30000);
|
|
159
|
+
return () => {
|
|
160
|
+
cancel = true;
|
|
161
|
+
clearInterval(interval);
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
/* Subscribe pool position */
|
|
166
|
+
|
|
167
|
+
/* Join pool action */
|
|
168
|
+
|
|
169
|
+
get submitJoinStepInfo() {
|
|
170
|
+
return {
|
|
171
|
+
name: 'Mint stDOT',
|
|
172
|
+
type: YieldStepType.MINT_STDOT
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
async getTokenApproveStep(params) {
|
|
176
|
+
const evmApi = this.evmApi;
|
|
177
|
+
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
178
|
+
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
179
|
+
const inputTokenSlug = this.inputAsset;
|
|
180
|
+
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
181
|
+
const inputTokenContract = getERC20Contract(this.chain, _getContractAddressOfToken(inputTokenInfo), this.state.getEvmApiMap());
|
|
182
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
183
|
+
const allowanceCall = inputTokenContract.methods.allowance(params.address, _getContractAddressOfToken(derivativeTokenInfo)); // TODO
|
|
184
|
+
|
|
185
|
+
const [allowance, gasPrice] = await Promise.all([
|
|
186
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
187
|
+
await allowanceCall.call(), evmApi.api.eth.getGasPrice()]);
|
|
188
|
+
if (!allowance || parseInt(allowance) <= 0) {
|
|
189
|
+
const step = {
|
|
190
|
+
name: 'Authorize token approval',
|
|
191
|
+
type: YieldStepType.TOKEN_APPROVAL
|
|
192
|
+
};
|
|
193
|
+
|
|
194
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
195
|
+
const estimatedGas = await allowanceCall.estimateGas();
|
|
196
|
+
const fee = {
|
|
197
|
+
slug: this.feeAssets[0],
|
|
198
|
+
amount: (estimatedGas * parseInt(gasPrice)).toString()
|
|
199
|
+
};
|
|
200
|
+
return [step, fee];
|
|
201
|
+
}
|
|
202
|
+
return undefined;
|
|
203
|
+
}
|
|
204
|
+
async getSubmitStepFee(params) {
|
|
205
|
+
const evmApi = this.evmApi;
|
|
206
|
+
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
207
|
+
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
208
|
+
if (new BN(params.amount).gt(BN_ZERO)) {
|
|
209
|
+
const stakingContract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
210
|
+
|
|
211
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
212
|
+
const depositCall = stakingContract.methods.deposit(params.amount);
|
|
213
|
+
|
|
214
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
215
|
+
const estimatedDepositGas = await depositCall.estimateGas();
|
|
216
|
+
const gasPrice = await evmApi.api.eth.getGasPrice();
|
|
217
|
+
return {
|
|
218
|
+
slug: this.feeAssets[0],
|
|
219
|
+
amount: (estimatedDepositGas * parseInt(gasPrice)).toString()
|
|
220
|
+
};
|
|
221
|
+
} else {
|
|
222
|
+
return {
|
|
223
|
+
slug: this.feeAssets[0],
|
|
224
|
+
amount: '0'
|
|
225
|
+
};
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
async generateOptimalPath(params) {
|
|
229
|
+
const result = {
|
|
230
|
+
totalFee: [{
|
|
231
|
+
slug: ''
|
|
232
|
+
}],
|
|
233
|
+
steps: [DEFAULT_YIELD_FIRST_STEP]
|
|
234
|
+
};
|
|
235
|
+
try {
|
|
236
|
+
/* Token approve step */
|
|
237
|
+
|
|
238
|
+
const approveStep = await this.getTokenApproveStep(params);
|
|
239
|
+
if (approveStep) {
|
|
240
|
+
const [step, fee] = approveStep;
|
|
241
|
+
result.steps.push({
|
|
242
|
+
id: result.steps.length,
|
|
243
|
+
...step
|
|
244
|
+
});
|
|
245
|
+
result.totalFee.push(fee);
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
/* Token approve step */
|
|
249
|
+
|
|
250
|
+
/* Submit step */
|
|
251
|
+
|
|
252
|
+
const submitFee = await this.getSubmitStepFee(params);
|
|
253
|
+
result.steps.push({
|
|
254
|
+
id: result.steps.length,
|
|
255
|
+
...this.submitJoinStepInfo
|
|
256
|
+
});
|
|
257
|
+
result.totalFee.push(submitFee);
|
|
258
|
+
|
|
259
|
+
/* Submit step */
|
|
260
|
+
|
|
261
|
+
return result;
|
|
262
|
+
} catch (e) {
|
|
263
|
+
const errorMessage = e.message;
|
|
264
|
+
if (errorMessage.includes('network')) {
|
|
265
|
+
result.connectionError = errorMessage.split(' ')[0];
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
/* Submit step */
|
|
269
|
+
|
|
270
|
+
result.steps.push({
|
|
271
|
+
id: result.steps.length,
|
|
272
|
+
...this.submitJoinStepInfo
|
|
273
|
+
});
|
|
274
|
+
result.totalFee.push({
|
|
275
|
+
slug: this.feeAssets[0],
|
|
276
|
+
amount: '0'
|
|
277
|
+
});
|
|
278
|
+
|
|
279
|
+
/* Submit step */
|
|
280
|
+
|
|
281
|
+
return result;
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
async validateTokenApproveStep(params, path) {
|
|
285
|
+
return Promise.resolve([]);
|
|
286
|
+
}
|
|
287
|
+
async handleTokenApproveStep(data, path) {
|
|
288
|
+
const {
|
|
289
|
+
address
|
|
290
|
+
} = data;
|
|
291
|
+
const inputTokenSlug = this.inputAsset;
|
|
292
|
+
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
293
|
+
const inputTokenContract = getERC20Contract(this.chain, _getContractAddressOfToken(inputTokenInfo), this.state.getEvmApiMap());
|
|
294
|
+
|
|
295
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
296
|
+
const approveCall = inputTokenContract.methods.approve(address, MAX_INT);
|
|
297
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
298
|
+
const approveEncodedCall = approveCall.encodeABI();
|
|
299
|
+
const transactionObject = {
|
|
300
|
+
from: address,
|
|
301
|
+
to: _getContractAddressOfToken(inputTokenInfo),
|
|
302
|
+
data: approveEncodedCall
|
|
303
|
+
};
|
|
304
|
+
return Promise.resolve({
|
|
305
|
+
txChain: this.chain,
|
|
306
|
+
extrinsicType: ExtrinsicType.EVM_EXECUTE,
|
|
307
|
+
extrinsic: transactionObject,
|
|
308
|
+
txData: transactionObject,
|
|
309
|
+
transferNativeAmount: '0'
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
// eslint-disable-next-line @typescript-eslint/require-await
|
|
314
|
+
async handleSubmitStep(data, path) {
|
|
315
|
+
const {
|
|
316
|
+
address,
|
|
317
|
+
amount
|
|
318
|
+
} = data;
|
|
319
|
+
const evmApi = this.evmApi;
|
|
320
|
+
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
321
|
+
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
322
|
+
const stakingContract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
323
|
+
|
|
324
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
325
|
+
const depositCall = stakingContract.methods.deposit(amount); // TODO: referral
|
|
326
|
+
|
|
327
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
328
|
+
const depositEncodedCall = depositCall.encodeABI();
|
|
329
|
+
const transactionObject = {
|
|
330
|
+
from: address,
|
|
331
|
+
to: _getContractAddressOfToken(derivativeTokenInfo),
|
|
332
|
+
data: depositEncodedCall
|
|
333
|
+
};
|
|
334
|
+
return {
|
|
335
|
+
txChain: this.chain,
|
|
336
|
+
extrinsicType: ExtrinsicType.MINT_STDOT,
|
|
337
|
+
extrinsic: transactionObject,
|
|
338
|
+
txData: data,
|
|
339
|
+
transferNativeAmount: '0'
|
|
340
|
+
};
|
|
341
|
+
}
|
|
342
|
+
|
|
343
|
+
/* Join pool action */
|
|
344
|
+
|
|
345
|
+
/* Leave pool action */
|
|
346
|
+
|
|
347
|
+
async handleYieldRedeem(amount, address, selectedTarget) {
|
|
348
|
+
return Promise.reject(new TransactionError(BasicTxErrorType.UNSUPPORTED));
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
// eslint-disable-next-line @typescript-eslint/require-await
|
|
352
|
+
async handleYieldUnstake(amount, address, selectedTarget) {
|
|
353
|
+
const evmApi = this.evmApi;
|
|
354
|
+
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
355
|
+
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
356
|
+
const stakingContract = getStellaswapLiquidStakingContract(this.chain, _getContractAddressOfToken(derivativeTokenInfo), evmApi);
|
|
357
|
+
|
|
358
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
359
|
+
const redeemCall = stakingContract.methods.redeem(amount);
|
|
360
|
+
|
|
361
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
362
|
+
const redeemEncodedCall = redeemCall.encodeABI();
|
|
363
|
+
const transaction = {
|
|
364
|
+
from: address,
|
|
365
|
+
to: _getContractAddressOfToken(derivativeTokenInfo),
|
|
366
|
+
data: redeemEncodedCall
|
|
367
|
+
};
|
|
368
|
+
return [ExtrinsicType.STAKING_UNBOND, transaction];
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
/* Leave pool action */
|
|
372
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
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
|
+
}
|