@pezkuwi/api-derive 16.5.5 → 16.5.6
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/LICENSE +201 -0
- package/README.md +2 -2
- package/accounts/accountId.js +29 -0
- package/{build/accounts → accounts}/flags.d.ts +2 -2
- package/accounts/flags.js +55 -0
- package/accounts/idAndIndex.js +34 -0
- package/accounts/idToIndex.js +17 -0
- package/{build/accounts → accounts}/identity.d.ts +3 -3
- package/accounts/identity.js +153 -0
- package/{src/accounts/index.ts → accounts/index.js} +0 -3
- package/accounts/indexToId.js +18 -0
- package/accounts/indexes.js +34 -0
- package/accounts/info.js +33 -0
- package/{src/alliance/index.ts → alliance/index.js} +0 -5
- package/augment.js +1 -0
- package/bagsList/get.js +42 -0
- package/bagsList/getExpanded.js +19 -0
- package/bagsList/index.js +3 -0
- package/bagsList/listNodes.d.ts +9 -0
- package/bagsList/listNodes.js +26 -0
- package/{build/bagsList → bagsList}/types.d.ts +3 -3
- package/bagsList/types.js +1 -0
- package/bagsList/util.js +8 -0
- package/balances/account.js +149 -0
- package/balances/all.js +167 -0
- package/{src/balances/index.ts → balances/index.js} +0 -6
- package/{build/balances → balances}/types.d.ts +7 -7
- package/balances/types.js +1 -0
- package/balances/votingBalances.js +18 -0
- package/bounties/bounties.js +50 -0
- package/bounties/helpers/filterBountyProposals.js +5 -0
- package/bounties/index.js +1 -0
- package/bundle.js +107 -0
- package/{src/chain/bestNumber.ts → chain/bestNumber.js} +1 -10
- package/{src/chain/bestNumberFinalized.ts → chain/bestNumberFinalized.js} +1 -10
- package/chain/bestNumberLag.js +19 -0
- package/chain/getBlock.js +25 -0
- package/chain/getBlockByNumber.js +16 -0
- package/chain/getHeader.js +19 -0
- package/{src/chain/index.ts → chain/index.js} +0 -3
- package/chain/subscribeFinalizedBlocks.js +15 -0
- package/chain/subscribeFinalizedHeads.js +37 -0
- package/chain/subscribeNewBlocks.js +15 -0
- package/chain/subscribeNewHeads.js +21 -0
- package/chain/util.js +57 -0
- package/cjs/accounts/accountId.d.ts +17 -0
- package/cjs/accounts/accountId.js +32 -0
- package/cjs/accounts/flags.d.ts +29 -0
- package/cjs/accounts/flags.js +59 -0
- package/cjs/accounts/idAndIndex.d.ts +15 -0
- package/cjs/accounts/idAndIndex.js +37 -0
- package/cjs/accounts/idToIndex.d.ts +16 -0
- package/cjs/accounts/idToIndex.js +20 -0
- package/cjs/accounts/identity.d.ts +48 -0
- package/cjs/accounts/identity.js +159 -0
- package/cjs/accounts/index.d.ts +8 -0
- package/cjs/accounts/index.js +11 -0
- package/cjs/accounts/indexToId.d.ts +15 -0
- package/cjs/accounts/indexToId.js +21 -0
- package/cjs/accounts/indexes.d.ts +16 -0
- package/cjs/accounts/indexes.js +37 -0
- package/cjs/accounts/info.d.ts +18 -0
- package/cjs/accounts/info.js +36 -0
- package/cjs/accounts/types.d.ts +39 -0
- package/cjs/accounts/types.js +2 -0
- package/cjs/alliance/index.d.ts +70 -0
- package/cjs/alliance/index.js +74 -0
- package/cjs/augment.d.ts +1 -0
- package/cjs/augment.js +3 -0
- package/cjs/bagsList/get.d.ts +12 -0
- package/cjs/bagsList/get.js +47 -0
- package/cjs/bagsList/getExpanded.d.ts +16 -0
- package/cjs/bagsList/getExpanded.js +23 -0
- package/cjs/bagsList/index.d.ts +3 -0
- package/cjs/bagsList/index.js +6 -0
- package/cjs/bagsList/listNodes.d.ts +9 -0
- package/cjs/bagsList/listNodes.js +29 -0
- package/cjs/bagsList/types.d.ts +13 -0
- package/cjs/bagsList/types.js +2 -0
- package/cjs/bagsList/util.d.ts +2 -0
- package/cjs/bagsList/util.js +11 -0
- package/cjs/balances/account.d.ts +17 -0
- package/cjs/balances/account.js +152 -0
- package/cjs/balances/all.d.ts +20 -0
- package/cjs/balances/all.js +170 -0
- package/cjs/balances/index.d.ts +20 -0
- package/cjs/balances/index.js +25 -0
- package/cjs/balances/types.d.ts +69 -0
- package/cjs/balances/types.js +2 -0
- package/cjs/balances/votingBalances.d.ts +15 -0
- package/cjs/balances/votingBalances.js +21 -0
- package/cjs/bounties/bounties.d.ts +12 -0
- package/cjs/bounties/bounties.js +53 -0
- package/cjs/bounties/helpers/filterBountyProposals.d.ts +2 -0
- package/cjs/bounties/helpers/filterBountyProposals.js +8 -0
- package/cjs/bounties/index.d.ts +1 -0
- package/cjs/bounties/index.js +4 -0
- package/cjs/bundle.d.ts +9 -0
- package/cjs/bundle.js +112 -0
- package/cjs/chain/bestNumber.d.ts +11 -0
- package/cjs/chain/bestNumber.js +15 -0
- package/cjs/chain/bestNumberFinalized.d.ts +12 -0
- package/cjs/chain/bestNumberFinalized.js +16 -0
- package/cjs/chain/bestNumberLag.d.ts +15 -0
- package/cjs/chain/bestNumberLag.js +22 -0
- package/cjs/chain/getBlock.d.ts +15 -0
- package/cjs/chain/getBlock.js +28 -0
- package/{src/chain/getBlockByNumber.ts → cjs/chain/getBlockByNumber.d.ts} +1 -15
- package/cjs/chain/getBlockByNumber.js +19 -0
- package/cjs/chain/getHeader.d.ts +16 -0
- package/cjs/chain/getHeader.js +22 -0
- package/cjs/chain/index.d.ts +10 -0
- package/cjs/chain/index.js +13 -0
- package/cjs/chain/subscribeFinalizedBlocks.d.ts +14 -0
- package/cjs/chain/subscribeFinalizedBlocks.js +18 -0
- package/cjs/chain/subscribeFinalizedHeads.d.ts +22 -0
- package/cjs/chain/subscribeFinalizedHeads.js +41 -0
- package/cjs/chain/subscribeNewBlocks.d.ts +14 -0
- package/cjs/chain/subscribeNewBlocks.js +18 -0
- package/cjs/chain/subscribeNewHeads.d.ts +15 -0
- package/cjs/chain/subscribeNewHeads.js +24 -0
- package/cjs/chain/util.d.ts +9 -0
- package/cjs/chain/util.js +61 -0
- package/cjs/collective/helpers.js +23 -0
- package/cjs/collective/index.js +6 -0
- package/cjs/collective/members.js +5 -0
- package/cjs/collective/prime.js +11 -0
- package/cjs/collective/proposals.js +44 -0
- package/cjs/collective/types.js +2 -0
- package/{build → cjs}/contracts/fees.d.ts +1 -1
- package/cjs/contracts/fees.js +48 -0
- package/cjs/contracts/index.js +4 -0
- package/cjs/council/index.js +77 -0
- package/cjs/council/types.js +2 -0
- package/cjs/council/votes.js +59 -0
- package/cjs/council/votesOf.js +21 -0
- package/{build → cjs}/crowdloan/childKey.d.ts +2 -2
- package/cjs/crowdloan/childKey.js +26 -0
- package/{build → cjs}/crowdloan/contributions.d.ts +2 -2
- package/cjs/crowdloan/contributions.js +83 -0
- package/cjs/crowdloan/index.js +6 -0
- package/{build → cjs}/crowdloan/ownContributions.d.ts +2 -2
- package/cjs/crowdloan/ownContributions.js +48 -0
- package/cjs/crowdloan/types.js +2 -0
- package/{build → cjs}/crowdloan/util.d.ts +2 -2
- package/cjs/crowdloan/util.js +20 -0
- package/cjs/democracy/dispatchQueue.js +90 -0
- package/cjs/democracy/index.js +14 -0
- package/cjs/democracy/locks.js +65 -0
- package/cjs/democracy/nextExternal.js +31 -0
- package/{build → cjs}/democracy/preimages.d.ts +5 -5
- package/cjs/democracy/preimages.js +117 -0
- package/cjs/democracy/proposals.js +46 -0
- package/cjs/democracy/referendumIds.js +24 -0
- package/cjs/democracy/referendums.js +22 -0
- package/cjs/democracy/referendumsActive.js +19 -0
- package/{build → cjs}/democracy/referendumsFinished.d.ts +2 -2
- package/cjs/democracy/referendumsFinished.js +20 -0
- package/{build → cjs}/democracy/referendumsInfo.d.ts +2 -2
- package/cjs/democracy/referendumsInfo.js +114 -0
- package/cjs/democracy/sqrtElectorate.js +18 -0
- package/{build → cjs}/democracy/types.d.ts +3 -3
- package/cjs/democracy/types.js +2 -0
- package/{build → cjs}/democracy/util.d.ts +5 -5
- package/cjs/democracy/util.js +137 -0
- package/{build → cjs}/derive.d.ts +2 -2
- package/cjs/derive.js +25 -0
- package/cjs/elections/index.js +4 -0
- package/cjs/elections/info.js +93 -0
- package/cjs/elections/types.js +2 -0
- package/cjs/imOnline/index.js +4 -0
- package/cjs/imOnline/receivedHeartbeats.js +42 -0
- package/cjs/index.js +5 -0
- package/cjs/membership/index.js +74 -0
- package/cjs/package.json +3 -0
- package/cjs/packageDetect.d.ts +1 -0
- package/cjs/packageDetect.js +5 -0
- package/cjs/packageInfo.js +4 -0
- package/cjs/session/index.js +6 -0
- package/cjs/session/indexes.js +68 -0
- package/cjs/session/info.js +28 -0
- package/cjs/session/progress.js +93 -0
- package/cjs/session/types.js +2 -0
- package/cjs/society/candidates.js +42 -0
- package/cjs/society/index.js +7 -0
- package/cjs/society/info.js +36 -0
- package/cjs/society/member.js +18 -0
- package/cjs/society/members.js +70 -0
- package/{build → cjs}/society/types.d.ts +5 -5
- package/cjs/society/types.js +2 -0
- package/{build → cjs}/staking/account.d.ts +1 -1
- package/cjs/staking/account.js +80 -0
- package/cjs/staking/cache.js +39 -0
- package/{build → cjs}/staking/currentPoints.d.ts +2 -2
- package/cjs/staking/currentPoints.js +17 -0
- package/cjs/staking/electedInfo.js +37 -0
- package/cjs/staking/erasExposure.js +76 -0
- package/cjs/staking/erasHistoric.js +31 -0
- package/cjs/staking/erasPoints.js +51 -0
- package/cjs/staking/erasPrefs.js +47 -0
- package/cjs/staking/erasRewards.js +38 -0
- package/cjs/staking/erasSlashes.js +53 -0
- package/cjs/staking/index.js +25 -0
- package/{build → cjs}/staking/keys.d.ts +1 -1
- package/cjs/staking/keys.js +61 -0
- package/cjs/staking/overview.js +31 -0
- package/{build → cjs}/staking/ownExposure.d.ts +1 -1
- package/cjs/staking/ownExposure.js +64 -0
- package/{build → cjs}/staking/ownSlashes.d.ts +1 -1
- package/cjs/staking/ownSlashes.js +51 -0
- package/{build → cjs}/staking/query.d.ts +1 -1
- package/cjs/staking/query.js +176 -0
- package/{build → cjs}/staking/stakerExposure.d.ts +1 -1
- package/cjs/staking/stakerExposure.js +56 -0
- package/cjs/staking/stakerPoints.js +35 -0
- package/cjs/staking/stakerPrefs.js +33 -0
- package/{build → cjs}/staking/stakerRewards.d.ts +1 -1
- package/cjs/staking/stakerRewards.js +222 -0
- package/cjs/staking/stakerSlashes.js +34 -0
- package/cjs/staking/stashes.js +38 -0
- package/{build → cjs}/staking/types.d.ts +15 -15
- package/cjs/staking/types.js +2 -0
- package/cjs/staking/util.js +53 -0
- package/cjs/staking/validators.js +71 -0
- package/cjs/staking/waitingInfo.js +32 -0
- package/cjs/technicalCommittee/index.js +74 -0
- package/cjs/teyrchains/index.js +5 -0
- package/{build/parachains → cjs/teyrchains}/info.d.ts +7 -7
- package/cjs/teyrchains/info.js +75 -0
- package/cjs/teyrchains/overview.d.ts +15 -0
- package/cjs/teyrchains/overview.js +39 -0
- package/{build/parachains → cjs/teyrchains}/types.d.ts +6 -6
- package/cjs/teyrchains/types.js +2 -0
- package/cjs/teyrchains/util.js +8 -0
- package/cjs/treasury/index.js +4 -0
- package/cjs/treasury/proposals.js +71 -0
- package/cjs/tx/constants.js +8 -0
- package/cjs/tx/events.js +24 -0
- package/cjs/tx/extrinsicInfo.js +87 -0
- package/cjs/tx/index.js +6 -0
- package/cjs/tx/signingInfo.js +81 -0
- package/cjs/type/HeaderExtended.js +23 -0
- package/cjs/type/SignedBlockExtended.js +60 -0
- package/cjs/type/index.js +7 -0
- package/cjs/type/types.js +2 -0
- package/cjs/type/util.js +36 -0
- package/{build → cjs}/types.d.ts +4 -4
- package/cjs/types.js +15 -0
- package/cjs/util/approvalFlagsToBools.js +19 -0
- package/cjs/util/blockNumber.js +9 -0
- package/cjs/util/cache.js +45 -0
- package/cjs/util/cacheImpl.js +26 -0
- package/cjs/util/first.js +12 -0
- package/cjs/util/index.js +13 -0
- package/cjs/util/lazy.js +7 -0
- package/cjs/util/types.js +2 -0
- package/collective/helpers.d.ts +6 -0
- package/collective/helpers.js +18 -0
- package/collective/index.d.ts +3 -0
- package/collective/index.js +3 -0
- package/collective/members.d.ts +2 -0
- package/collective/members.js +2 -0
- package/collective/prime.d.ts +2 -0
- package/collective/prime.js +8 -0
- package/collective/proposals.d.ts +6 -0
- package/collective/proposals.js +38 -0
- package/{src/collective/types.ts → collective/types.d.ts} +0 -11
- package/collective/types.js +1 -0
- package/contracts/fees.d.ts +14 -0
- package/contracts/fees.js +45 -0
- package/contracts/index.d.ts +1 -0
- package/contracts/index.js +1 -0
- package/council/index.d.ts +72 -0
- package/{src/council/index.ts → council/index.js} +0 -6
- package/{src/council/types.ts → council/types.d.ts} +2 -7
- package/council/types.js +1 -0
- package/council/votes.d.ts +11 -0
- package/council/votes.js +56 -0
- package/council/votesOf.d.ts +16 -0
- package/council/votesOf.js +18 -0
- package/crowdloan/childKey.d.ts +15 -0
- package/crowdloan/childKey.js +23 -0
- package/crowdloan/contributions.d.ts +14 -0
- package/crowdloan/contributions.js +80 -0
- package/crowdloan/index.d.ts +3 -0
- package/crowdloan/index.js +3 -0
- package/crowdloan/ownContributions.d.ts +15 -0
- package/crowdloan/ownContributions.js +45 -0
- package/{src/crowdloan/types.ts → crowdloan/types.d.ts} +2 -7
- package/crowdloan/types.js +1 -0
- package/crowdloan/util.d.ts +10 -0
- package/crowdloan/util.js +17 -0
- package/democracy/dispatchQueue.d.ts +12 -0
- package/democracy/dispatchQueue.js +87 -0
- package/{src/democracy/index.ts → democracy/index.d.ts} +0 -3
- package/democracy/index.js +11 -0
- package/democracy/locks.d.ts +14 -0
- package/democracy/locks.js +62 -0
- package/democracy/nextExternal.d.ts +12 -0
- package/democracy/nextExternal.js +28 -0
- package/democracy/preimages.d.ts +24 -0
- package/democracy/preimages.js +113 -0
- package/democracy/proposals.d.ts +12 -0
- package/democracy/proposals.js +43 -0
- package/democracy/referendumIds.d.ts +12 -0
- package/democracy/referendumIds.js +21 -0
- package/democracy/referendums.d.ts +11 -0
- package/democracy/referendums.js +19 -0
- package/democracy/referendumsActive.d.ts +12 -0
- package/democracy/referendumsActive.js +16 -0
- package/democracy/referendumsFinished.d.ts +15 -0
- package/democracy/referendumsFinished.js +17 -0
- package/democracy/referendumsInfo.d.ts +23 -0
- package/democracy/referendumsInfo.js +108 -0
- package/democracy/sqrtElectorate.d.ts +13 -0
- package/democracy/sqrtElectorate.js +15 -0
- package/democracy/types.d.ts +70 -0
- package/democracy/types.js +1 -0
- package/democracy/util.d.ts +18 -0
- package/democracy/util.js +129 -0
- package/derive.d.ts +52 -0
- package/{src/derive.ts → derive.js} +2 -22
- package/elections/index.d.ts +1 -0
- package/elections/index.js +1 -0
- package/elections/info.d.ts +14 -0
- package/elections/info.js +90 -0
- package/elections/types.d.ts +18 -0
- package/elections/types.js +1 -0
- package/imOnline/index.d.ts +1 -0
- package/imOnline/index.js +1 -0
- package/imOnline/receivedHeartbeats.d.ts +13 -0
- package/imOnline/receivedHeartbeats.js +39 -0
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/membership/index.d.ts +70 -0
- package/{src/membership/index.ts → membership/index.js} +0 -5
- package/package.json +2066 -19
- package/packageDetect.d.ts +1 -0
- package/packageDetect.js +3 -0
- package/packageInfo.d.ts +6 -0
- package/packageInfo.js +1 -0
- package/session/index.d.ts +3 -0
- package/session/index.js +3 -0
- package/session/indexes.d.ts +15 -0
- package/session/indexes.js +65 -0
- package/session/info.d.ts +13 -0
- package/{src/session/info.ts → session/info.js} +7 -21
- package/session/progress.d.ts +47 -0
- package/session/progress.js +89 -0
- package/session/types.d.ts +19 -0
- package/session/types.js +1 -0
- package/society/candidates.d.ts +12 -0
- package/society/candidates.js +39 -0
- package/{src/society/index.ts → society/index.d.ts} +0 -3
- package/society/index.js +4 -0
- package/society/info.d.ts +12 -0
- package/society/info.js +33 -0
- package/society/member.d.ts +14 -0
- package/society/member.js +15 -0
- package/society/members.d.ts +14 -0
- package/society/members.js +66 -0
- package/society/types.d.ts +27 -0
- package/society/types.js +1 -0
- package/staking/account.d.ts +31 -0
- package/staking/account.js +76 -0
- package/staking/cache.d.ts +12 -0
- package/staking/cache.js +32 -0
- package/staking/currentPoints.d.ts +13 -0
- package/staking/currentPoints.js +14 -0
- package/staking/electedInfo.d.ts +23 -0
- package/staking/electedInfo.js +34 -0
- package/staking/erasExposure.d.ts +30 -0
- package/staking/erasExposure.js +72 -0
- package/staking/erasHistoric.d.ts +8 -0
- package/staking/erasHistoric.js +28 -0
- package/staking/erasPoints.d.ts +18 -0
- package/staking/erasPoints.js +47 -0
- package/staking/erasPrefs.d.ts +27 -0
- package/staking/erasPrefs.js +43 -0
- package/staking/erasRewards.d.ts +14 -0
- package/staking/erasRewards.js +34 -0
- package/staking/erasSlashes.d.ts +26 -0
- package/staking/erasSlashes.js +49 -0
- package/{src/staking/index.ts → staking/index.d.ts} +0 -3
- package/staking/index.js +22 -0
- package/staking/keys.d.ts +35 -0
- package/staking/keys.js +57 -0
- package/staking/overview.d.ts +19 -0
- package/staking/overview.js +28 -0
- package/staking/ownExposure.d.ts +37 -0
- package/staking/ownExposure.js +60 -0
- package/staking/ownSlashes.d.ts +35 -0
- package/staking/ownSlashes.js +47 -0
- package/staking/query.d.ts +31 -0
- package/staking/query.js +172 -0
- package/staking/stakerExposure.d.ts +33 -0
- package/staking/stakerExposure.js +51 -0
- package/staking/stakerPoints.d.ts +22 -0
- package/staking/stakerPoints.js +31 -0
- package/staking/stakerPrefs.d.ts +24 -0
- package/staking/stakerPrefs.js +29 -0
- package/staking/stakerRewards.d.ts +49 -0
- package/staking/stakerRewards.js +215 -0
- package/staking/stakerSlashes.d.ts +22 -0
- package/staking/stakerSlashes.js +30 -0
- package/staking/stashes.d.ts +16 -0
- package/staking/stashes.js +35 -0
- package/staking/types.d.ts +139 -0
- package/staking/types.js +1 -0
- package/staking/util.d.ts +14 -0
- package/staking/util.js +46 -0
- package/staking/validators.d.ts +33 -0
- package/{src/staking/validators.ts → staking/validators.js} +25 -40
- package/staking/waitingInfo.d.ts +16 -0
- package/{src/staking/waitingInfo.ts → staking/waitingInfo.js} +8 -24
- package/technicalCommittee/index.d.ts +70 -0
- package/{src/technicalCommittee/index.ts → technicalCommittee/index.js} +0 -5
- package/teyrchains/index.d.ts +2 -0
- package/teyrchains/index.js +2 -0
- package/teyrchains/info.d.ts +19 -0
- package/teyrchains/info.js +72 -0
- package/teyrchains/overview.d.ts +15 -0
- package/teyrchains/overview.js +36 -0
- package/teyrchains/types.d.ts +38 -0
- package/teyrchains/types.js +1 -0
- package/teyrchains/util.d.ts +3 -0
- package/teyrchains/util.js +5 -0
- package/treasury/index.d.ts +1 -0
- package/treasury/index.js +1 -0
- package/treasury/proposals.d.ts +12 -0
- package/treasury/proposals.js +68 -0
- package/tx/constants.d.ts +5 -0
- package/{src/tx/constants.ts → tx/constants.js} +0 -8
- package/tx/events.d.ts +22 -0
- package/tx/events.js +21 -0
- package/tx/extrinsicInfo.d.ts +61 -0
- package/tx/extrinsicInfo.js +83 -0
- package/tx/index.d.ts +3 -0
- package/tx/index.js +3 -0
- package/tx/signingInfo.d.ts +25 -0
- package/tx/signingInfo.js +78 -0
- package/type/HeaderExtended.d.ts +4 -0
- package/type/HeaderExtended.js +20 -0
- package/type/SignedBlockExtended.d.ts +4 -0
- package/type/SignedBlockExtended.js +57 -0
- package/{src/type/index.ts → type/index.d.ts} +0 -3
- package/type/index.js +2 -0
- package/type/types.d.ts +15 -0
- package/type/types.js +1 -0
- package/type/util.d.ts +2 -0
- package/type/util.js +33 -0
- package/{src/types.ts → types.d.ts} +39 -57
- package/types.js +12 -0
- package/util/approvalFlagsToBools.d.ts +4 -0
- package/util/approvalFlagsToBools.js +16 -0
- package/util/blockNumber.d.ts +7 -0
- package/util/blockNumber.js +6 -0
- package/util/cache.d.ts +4 -0
- package/util/cache.js +42 -0
- package/util/cacheImpl.d.ts +3 -0
- package/util/cacheImpl.js +23 -0
- package/util/first.d.ts +4 -0
- package/util/first.js +8 -0
- package/{src/util/index.ts → util/index.d.ts} +0 -6
- package/util/index.js +7 -0
- package/util/lazy.d.ts +4 -0
- package/util/lazy.js +4 -0
- package/util/types.d.ts +6 -0
- package/util/types.js +1 -0
- package/build/bagsList/listNodes.d.ts +0 -9
- package/build/parachains/overview.d.ts +0 -15
- package/src/accounts/accountId.ts +0 -44
- package/src/accounts/flags.ts +0 -90
- package/src/accounts/idAndIndex.ts +0 -51
- package/src/accounts/idToIndex.ts +0 -31
- package/src/accounts/identity.ts +0 -235
- package/src/accounts/indexToId.ts +0 -33
- package/src/accounts/indexes.ts +0 -56
- package/src/accounts/info.ts +0 -58
- package/src/accounts/types.ts +0 -48
- package/src/augment.ts +0 -4
- package/src/bagsList/get.ts +0 -79
- package/src/bagsList/getExpanded.ts +0 -41
- package/src/bagsList/index.ts +0 -6
- package/src/bagsList/listNodes.ts +0 -50
- package/src/bagsList/types.ts +0 -18
- package/src/bagsList/util.ts +0 -14
- package/src/balances/account.ts +0 -210
- package/src/balances/all.ts +0 -246
- package/src/balances/types.ts +0 -79
- package/src/balances/votingBalances.ts +0 -33
- package/src/bounties/bounties.spec.ts +0 -162
- package/src/bounties/bounties.ts +0 -76
- package/src/bounties/helpers/filterBountyProposals.ts +0 -13
- package/src/bounties/index.ts +0 -4
- package/src/bundle.ts +0 -140
- package/src/chain/bestNumberLag.ts +0 -33
- package/src/chain/getBlock.ts +0 -43
- package/src/chain/getHeader.ts +0 -37
- package/src/chain/subscribeFinalizedBlocks.ts +0 -30
- package/src/chain/subscribeFinalizedHeads.ts +0 -62
- package/src/chain/subscribeNewBlocks.ts +0 -30
- package/src/chain/subscribeNewHeads.ts +0 -38
- package/src/chain/util.ts +0 -112
- package/src/checkTypes.manual.ts +0 -8
- package/src/collective/helpers.ts +0 -36
- package/src/collective/index.ts +0 -6
- package/src/collective/members.ts +0 -8
- package/src/collective/prime.ts +0 -25
- package/src/collective/proposals.ts +0 -73
- package/src/contracts/fees.ts +0 -61
- package/src/contracts/index.ts +0 -4
- package/src/council/votes.ts +0 -97
- package/src/council/votesOf.ts +0 -35
- package/src/crowdloan/childKey.ts +0 -57
- package/src/crowdloan/contributions.ts +0 -142
- package/src/crowdloan/index.ts +0 -6
- package/src/crowdloan/ownContributions.ts +0 -81
- package/src/crowdloan/util.ts +0 -33
- package/src/democracy/dispatchQueue.ts +0 -158
- package/src/democracy/locks.ts +0 -114
- package/src/democracy/nextExternal.ts +0 -49
- package/src/democracy/preimages.ts +0 -171
- package/src/democracy/proposals.ts +0 -81
- package/src/democracy/referendumIds.ts +0 -37
- package/src/democracy/referendums.ts +0 -39
- package/src/democracy/referendumsActive.ts +0 -30
- package/src/democracy/referendumsFinished.ts +0 -37
- package/src/democracy/referendumsInfo.ts +0 -181
- package/src/democracy/sqrtElectorate.ts +0 -29
- package/src/democracy/types.ts +0 -84
- package/src/democracy/util.ts +0 -166
- package/src/elections/index.ts +0 -4
- package/src/elections/info.ts +0 -126
- package/src/elections/types.ts +0 -22
- package/src/imOnline/index.ts +0 -4
- package/src/imOnline/receivedHeartbeats.ts +0 -65
- package/src/index.spec.ts +0 -103
- package/src/index.ts +0 -6
- package/src/mod.ts +0 -4
- package/src/packageDetect.ts +0 -11
- package/src/packageInfo.ts +0 -6
- package/src/parachains/index.ts +0 -5
- package/src/parachains/info.ts +0 -111
- package/src/parachains/overview.ts +0 -63
- package/src/parachains/types.ts +0 -46
- package/src/parachains/util.ts +0 -11
- package/src/session/index.ts +0 -6
- package/src/session/indexes.ts +0 -90
- package/src/session/progress.ts +0 -130
- package/src/session/types.ts +0 -25
- package/src/society/candidates.ts +0 -71
- package/src/society/info.ts +0 -50
- package/src/society/member.ts +0 -28
- package/src/society/members.ts +0 -107
- package/src/society/types.ts +0 -33
- package/src/staking/account.ts +0 -112
- package/src/staking/cache.ts +0 -48
- package/src/staking/currentPoints.ts +0 -28
- package/src/staking/electedInfo.ts +0 -54
- package/src/staking/erasExposure.ts +0 -105
- package/src/staking/erasHistoric.ts +0 -47
- package/src/staking/erasPoints.ts +0 -67
- package/src/staking/erasPrefs.ts +0 -63
- package/src/staking/erasRewards.ts +0 -52
- package/src/staking/erasSlashes.ts +0 -69
- package/src/staking/keys.ts +0 -86
- package/src/staking/overview.ts +0 -42
- package/src/staking/ownExposure.ts +0 -83
- package/src/staking/ownSlashes.ts +0 -68
- package/src/staking/query.ts +0 -230
- package/src/staking/stakerExposure.ts +0 -78
- package/src/staking/stakerPoints.ts +0 -46
- package/src/staking/stakerPrefs.ts +0 -45
- package/src/staking/stakerRewards.ts +0 -298
- package/src/staking/stakerSlashes.ts +0 -45
- package/src/staking/stashes.ts +0 -55
- package/src/staking/types.ts +0 -174
- package/src/staking/util.ts +0 -94
- package/src/test/bountyFactory.ts +0 -39
- package/src/test/bytesFactory.ts +0 -15
- package/src/test/helpers.ts +0 -23
- package/src/test/proposalFactory.ts +0 -25
- package/src/treasury/index.ts +0 -4
- package/src/treasury/proposals.ts +0 -109
- package/src/tx/events.ts +0 -43
- package/src/tx/extrinsicInfo.ts +0 -123
- package/src/tx/index.ts +0 -6
- package/src/tx/signingInfo.ts +0 -129
- package/src/type/HeaderExtended.ts +0 -33
- package/src/type/SignedBlockExtended.ts +0 -75
- package/src/type/types.ts +0 -21
- package/src/type/util.ts +0 -45
- package/src/util/approvalFlagToBools.spec.ts +0 -37
- package/src/util/approvalFlagsToBools.ts +0 -26
- package/src/util/blockNumber.ts +0 -15
- package/src/util/cache.ts +0 -65
- package/src/util/cacheImpl.ts +0 -30
- package/src/util/first.ts +0 -20
- package/src/util/lazy.ts +0 -16
- package/src/util/types.ts +0 -9
- package/tsconfig.build.json +0 -21
- package/tsconfig.build.tsbuildinfo +0 -1
- package/tsconfig.spec.json +0 -27
- /package/{build/accounts → accounts}/accountId.d.ts +0 -0
- /package/{build/accounts → accounts}/idAndIndex.d.ts +0 -0
- /package/{build/accounts → accounts}/idToIndex.d.ts +0 -0
- /package/{build/accounts → accounts}/index.d.ts +0 -0
- /package/{build/accounts → accounts}/indexToId.d.ts +0 -0
- /package/{build/accounts → accounts}/indexes.d.ts +0 -0
- /package/{build/accounts → accounts}/info.d.ts +0 -0
- /package/{build/accounts → accounts}/types.d.ts +0 -0
- /package/{build/packageDetect.d.ts → accounts/types.js} +0 -0
- /package/{build/alliance → alliance}/index.d.ts +0 -0
- /package/{build/augment.d.ts → augment.d.ts} +0 -0
- /package/{build/bagsList → bagsList}/get.d.ts +0 -0
- /package/{build/bagsList → bagsList}/getExpanded.d.ts +0 -0
- /package/{build/bagsList → bagsList}/index.d.ts +0 -0
- /package/{build/bagsList → bagsList}/util.d.ts +0 -0
- /package/{build/balances → balances}/account.d.ts +0 -0
- /package/{build/balances → balances}/all.d.ts +0 -0
- /package/{build/balances → balances}/index.d.ts +0 -0
- /package/{build/balances → balances}/votingBalances.d.ts +0 -0
- /package/{build/bounties → bounties}/bounties.d.ts +0 -0
- /package/{build/bounties → bounties}/helpers/filterBountyProposals.d.ts +0 -0
- /package/{build/bounties → bounties}/index.d.ts +0 -0
- /package/{build/bundle.d.ts → bundle.d.ts} +0 -0
- /package/{build/chain → chain}/bestNumber.d.ts +0 -0
- /package/{build/chain → chain}/bestNumberFinalized.d.ts +0 -0
- /package/{build/chain → chain}/bestNumberLag.d.ts +0 -0
- /package/{build/chain → chain}/getBlock.d.ts +0 -0
- /package/{build/chain → chain}/getBlockByNumber.d.ts +0 -0
- /package/{build/chain → chain}/getHeader.d.ts +0 -0
- /package/{build/chain → chain}/index.d.ts +0 -0
- /package/{build/chain → chain}/subscribeFinalizedBlocks.d.ts +0 -0
- /package/{build/chain → chain}/subscribeFinalizedHeads.d.ts +0 -0
- /package/{build/chain → chain}/subscribeNewBlocks.d.ts +0 -0
- /package/{build/chain → chain}/subscribeNewHeads.d.ts +0 -0
- /package/{build/chain → chain}/util.d.ts +0 -0
- /package/{build → cjs}/collective/helpers.d.ts +0 -0
- /package/{build → cjs}/collective/index.d.ts +0 -0
- /package/{build → cjs}/collective/members.d.ts +0 -0
- /package/{build → cjs}/collective/prime.d.ts +0 -0
- /package/{build → cjs}/collective/proposals.d.ts +0 -0
- /package/{build → cjs}/collective/types.d.ts +0 -0
- /package/{build → cjs}/contracts/index.d.ts +0 -0
- /package/{build → cjs}/council/index.d.ts +0 -0
- /package/{build → cjs}/council/types.d.ts +0 -0
- /package/{build → cjs}/council/votes.d.ts +0 -0
- /package/{build → cjs}/council/votesOf.d.ts +0 -0
- /package/{build → cjs}/crowdloan/index.d.ts +0 -0
- /package/{build → cjs}/crowdloan/types.d.ts +0 -0
- /package/{build → cjs}/democracy/dispatchQueue.d.ts +0 -0
- /package/{build → cjs}/democracy/index.d.ts +0 -0
- /package/{build → cjs}/democracy/locks.d.ts +0 -0
- /package/{build → cjs}/democracy/nextExternal.d.ts +0 -0
- /package/{build → cjs}/democracy/proposals.d.ts +0 -0
- /package/{build → cjs}/democracy/referendumIds.d.ts +0 -0
- /package/{build → cjs}/democracy/referendums.d.ts +0 -0
- /package/{build → cjs}/democracy/referendumsActive.d.ts +0 -0
- /package/{build → cjs}/democracy/sqrtElectorate.d.ts +0 -0
- /package/{build → cjs}/elections/index.d.ts +0 -0
- /package/{build → cjs}/elections/info.d.ts +0 -0
- /package/{build → cjs}/elections/types.d.ts +0 -0
- /package/{build → cjs}/imOnline/index.d.ts +0 -0
- /package/{build → cjs}/imOnline/receivedHeartbeats.d.ts +0 -0
- /package/{build → cjs}/index.d.ts +0 -0
- /package/{build → cjs}/membership/index.d.ts +0 -0
- /package/{build → cjs}/packageInfo.d.ts +0 -0
- /package/{build → cjs}/session/index.d.ts +0 -0
- /package/{build → cjs}/session/indexes.d.ts +0 -0
- /package/{build → cjs}/session/info.d.ts +0 -0
- /package/{build → cjs}/session/progress.d.ts +0 -0
- /package/{build → cjs}/session/types.d.ts +0 -0
- /package/{build → cjs}/society/candidates.d.ts +0 -0
- /package/{build → cjs}/society/index.d.ts +0 -0
- /package/{build → cjs}/society/info.d.ts +0 -0
- /package/{build → cjs}/society/member.d.ts +0 -0
- /package/{build → cjs}/society/members.d.ts +0 -0
- /package/{build → cjs}/staking/cache.d.ts +0 -0
- /package/{build → cjs}/staking/electedInfo.d.ts +0 -0
- /package/{build → cjs}/staking/erasExposure.d.ts +0 -0
- /package/{build → cjs}/staking/erasHistoric.d.ts +0 -0
- /package/{build → cjs}/staking/erasPoints.d.ts +0 -0
- /package/{build → cjs}/staking/erasPrefs.d.ts +0 -0
- /package/{build → cjs}/staking/erasRewards.d.ts +0 -0
- /package/{build → cjs}/staking/erasSlashes.d.ts +0 -0
- /package/{build → cjs}/staking/index.d.ts +0 -0
- /package/{build → cjs}/staking/overview.d.ts +0 -0
- /package/{build → cjs}/staking/stakerPoints.d.ts +0 -0
- /package/{build → cjs}/staking/stakerPrefs.d.ts +0 -0
- /package/{build → cjs}/staking/stakerSlashes.d.ts +0 -0
- /package/{build → cjs}/staking/stashes.d.ts +0 -0
- /package/{build → cjs}/staking/util.d.ts +0 -0
- /package/{build → cjs}/staking/validators.d.ts +0 -0
- /package/{build → cjs}/staking/waitingInfo.d.ts +0 -0
- /package/{build → cjs}/technicalCommittee/index.d.ts +0 -0
- /package/{build/parachains → cjs/teyrchains}/index.d.ts +0 -0
- /package/{build/parachains → cjs/teyrchains}/util.d.ts +0 -0
- /package/{build → cjs}/treasury/index.d.ts +0 -0
- /package/{build → cjs}/treasury/proposals.d.ts +0 -0
- /package/{build → cjs}/tx/constants.d.ts +0 -0
- /package/{build → cjs}/tx/events.d.ts +0 -0
- /package/{build → cjs}/tx/extrinsicInfo.d.ts +0 -0
- /package/{build → cjs}/tx/index.d.ts +0 -0
- /package/{build → cjs}/tx/signingInfo.d.ts +0 -0
- /package/{build → cjs}/type/HeaderExtended.d.ts +0 -0
- /package/{build → cjs}/type/SignedBlockExtended.d.ts +0 -0
- /package/{build → cjs}/type/index.d.ts +0 -0
- /package/{build → cjs}/type/types.d.ts +0 -0
- /package/{build → cjs}/type/util.d.ts +0 -0
- /package/{build → cjs}/util/approvalFlagsToBools.d.ts +0 -0
- /package/{build → cjs}/util/blockNumber.d.ts +0 -0
- /package/{build → cjs}/util/cache.d.ts +0 -0
- /package/{build → cjs}/util/cacheImpl.d.ts +0 -0
- /package/{build → cjs}/util/first.d.ts +0 -0
- /package/{build → cjs}/util/index.d.ts +0 -0
- /package/{build → cjs}/util/lazy.d.ts +0 -0
- /package/{build → cjs}/util/types.d.ts +0 -0
|
@@ -1,298 +0,0 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
|
-
import type { Observable } from 'rxjs';
|
|
5
|
-
import type { u32, Vec } from '@pezkuwi/types';
|
|
6
|
-
import type { AccountId, EraIndex } from '@pezkuwi/types/interfaces';
|
|
7
|
-
import type { PalletStakingStakingLedger, SpStakingExposure, SpStakingExposurePage } from '@pezkuwi/types/lookup';
|
|
8
|
-
import type { BN } from '@pezkuwi/util';
|
|
9
|
-
import type { DeriveApi, DeriveEraPoints, DeriveEraPrefs, DeriveEraRewards, DeriveEraValPoints, DeriveEraValPrefs, DeriveStakerExposure, DeriveStakerReward, DeriveStakerRewardValidator } from '../types.js';
|
|
10
|
-
import type { DeriveStakingQuery } from './types.js';
|
|
11
|
-
|
|
12
|
-
import { combineLatest, map, of, switchMap } from 'rxjs';
|
|
13
|
-
|
|
14
|
-
import { BN_BILLION, BN_ZERO, objectSpread } from '@pezkuwi/util';
|
|
15
|
-
|
|
16
|
-
import { firstMemo, memo } from '../util/index.js';
|
|
17
|
-
|
|
18
|
-
type ErasResult = [DeriveEraPoints[], DeriveEraPrefs[], DeriveEraRewards[]];
|
|
19
|
-
|
|
20
|
-
// handle compatibility between generations of structures
|
|
21
|
-
function extractCompatRewards (claimedRewardsEras: Vec<u32>, ledger?: PalletStakingStakingLedger): u32[] {
|
|
22
|
-
const l = ledger
|
|
23
|
-
? (
|
|
24
|
-
ledger.legacyClaimedRewards ||
|
|
25
|
-
(ledger as PalletStakingStakingLedger & { claimedRewards: Vec<u32> }).claimedRewards
|
|
26
|
-
)?.toArray()
|
|
27
|
-
: [] as unknown as Vec<u32>;
|
|
28
|
-
|
|
29
|
-
return (claimedRewardsEras.toArray() || []).concat(l);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
function parseRewards (api: DeriveApi, stashId: AccountId, [erasPoints, erasPrefs, erasRewards]: ErasResult, exposures: DeriveStakerExposure[], claimedRewardsEras: Vec<u32>): DeriveStakerReward[] {
|
|
33
|
-
return exposures.map(({ era, isEmpty, isValidator, nominating, validators: eraValidators }): DeriveStakerReward => {
|
|
34
|
-
const { eraPoints, validators: allValPoints } = erasPoints.find((p) => p.era.eq(era)) || { eraPoints: BN_ZERO, validators: {} as DeriveEraValPoints };
|
|
35
|
-
const { eraReward } = erasRewards.find((r) => r.era.eq(era)) || { eraReward: api.registry.createType('Balance') };
|
|
36
|
-
const { validators: allValPrefs } = erasPrefs.find((p) => p.era.eq(era)) || { validators: {} as DeriveEraValPrefs };
|
|
37
|
-
const validators: Record<string, DeriveStakerRewardValidator> = {};
|
|
38
|
-
const stakerId = stashId.toString();
|
|
39
|
-
|
|
40
|
-
Object.entries(eraValidators).forEach(([validatorId, exposure]): void => {
|
|
41
|
-
const valPoints = allValPoints[validatorId] || BN_ZERO;
|
|
42
|
-
const valComm = allValPrefs[validatorId]?.commission.unwrap() || BN_ZERO;
|
|
43
|
-
const expTotal = (exposure as SpStakingExposure).total
|
|
44
|
-
? (exposure as SpStakingExposure).total?.unwrap()
|
|
45
|
-
: (exposure as SpStakingExposurePage).pageTotal
|
|
46
|
-
? (exposure as SpStakingExposurePage).pageTotal?.unwrap()
|
|
47
|
-
: BN_ZERO;
|
|
48
|
-
let avail = BN_ZERO;
|
|
49
|
-
let value: BN | undefined;
|
|
50
|
-
|
|
51
|
-
if (!(expTotal.isZero() || valPoints.isZero() || eraPoints.isZero())) {
|
|
52
|
-
avail = eraReward.mul(valPoints).div(eraPoints);
|
|
53
|
-
|
|
54
|
-
const valCut = valComm.mul(avail).div(BN_BILLION);
|
|
55
|
-
let staked: BN;
|
|
56
|
-
|
|
57
|
-
if (validatorId === stakerId) {
|
|
58
|
-
if ((exposure as SpStakingExposure).own) {
|
|
59
|
-
staked = (exposure as SpStakingExposure).own.unwrap();
|
|
60
|
-
} else {
|
|
61
|
-
const expAccount = exposure.others.find(({ who }) => who.eq(validatorId));
|
|
62
|
-
|
|
63
|
-
staked = expAccount
|
|
64
|
-
? expAccount.value.unwrap()
|
|
65
|
-
: BN_ZERO;
|
|
66
|
-
}
|
|
67
|
-
} else {
|
|
68
|
-
const stakerExp = exposure.others.find(({ who }) => who.eq(stakerId));
|
|
69
|
-
|
|
70
|
-
staked = stakerExp
|
|
71
|
-
? stakerExp.value.unwrap()
|
|
72
|
-
: BN_ZERO;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
value = avail.sub(valCut).imul(staked).div(expTotal).iadd(validatorId === stakerId ? valCut : BN_ZERO);
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
validators[validatorId] = {
|
|
79
|
-
total: api.registry.createType('Balance', avail),
|
|
80
|
-
value: api.registry.createType('Balance', value)
|
|
81
|
-
};
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
return {
|
|
85
|
-
era,
|
|
86
|
-
eraReward,
|
|
87
|
-
// This might not always be accurate as you need validator account information in order to see if the rewards have been claimed.
|
|
88
|
-
// This is possibly adjusted in `filterRewards` when need be.
|
|
89
|
-
isClaimed: claimedRewardsEras.some((c) => c.eq(era)),
|
|
90
|
-
isEmpty,
|
|
91
|
-
isValidator,
|
|
92
|
-
nominating,
|
|
93
|
-
validators
|
|
94
|
-
};
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
function allUniqValidators (rewards: DeriveStakerReward[][]): [string[], string[][]] {
|
|
99
|
-
return rewards.reduce(([all, perStash]: [string[], string[][]], rewards) => {
|
|
100
|
-
const uniq: string[] = [];
|
|
101
|
-
|
|
102
|
-
perStash.push(uniq);
|
|
103
|
-
rewards.forEach(({ validators }) =>
|
|
104
|
-
Object.keys(validators).forEach((validatorId): void => {
|
|
105
|
-
if (!uniq.includes(validatorId)) {
|
|
106
|
-
uniq.push(validatorId);
|
|
107
|
-
|
|
108
|
-
if (!all.includes(validatorId)) {
|
|
109
|
-
all.push(validatorId);
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
})
|
|
113
|
-
);
|
|
114
|
-
|
|
115
|
-
return [all, perStash];
|
|
116
|
-
}, [[], []]);
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
function removeClaimed (validators: string[], queryValidators: DeriveStakingQuery[], reward: DeriveStakerReward, claimedRewardsEras: Vec<u32>): void {
|
|
120
|
-
const rm: string[] = [];
|
|
121
|
-
|
|
122
|
-
Object.keys(reward.validators).forEach((validatorId): void => {
|
|
123
|
-
const index = validators.indexOf(validatorId);
|
|
124
|
-
|
|
125
|
-
if (index !== -1) {
|
|
126
|
-
const valLedger = queryValidators[index].stakingLedger;
|
|
127
|
-
|
|
128
|
-
if (extractCompatRewards(claimedRewardsEras, valLedger).some((e) => reward.era?.eq(e))) {
|
|
129
|
-
rm.push(validatorId);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
rm.forEach((validatorId): void => {
|
|
135
|
-
delete reward.validators[validatorId];
|
|
136
|
-
});
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
function filterRewards (eras: EraIndex[], valInfo: [string, DeriveStakingQuery][], { claimedRewardsEras, rewards, stakingLedger }: { rewards: DeriveStakerReward[]; stakingLedger: PalletStakingStakingLedger, claimedRewardsEras: Vec<u32> }): DeriveStakerReward[] {
|
|
140
|
-
const filter = eras.filter((e) => !extractCompatRewards(claimedRewardsEras, stakingLedger).some((s) => s?.eq(e)));
|
|
141
|
-
const validators = valInfo.map(([v]) => v);
|
|
142
|
-
const queryValidators = valInfo.map(([, q]) => q);
|
|
143
|
-
|
|
144
|
-
return rewards
|
|
145
|
-
.filter(({ isEmpty }) => !isEmpty)
|
|
146
|
-
.filter((reward): boolean => {
|
|
147
|
-
if (!filter.some((e) => reward.era.eq(e))) {
|
|
148
|
-
return false;
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
removeClaimed(validators, queryValidators, reward, claimedRewardsEras);
|
|
152
|
-
|
|
153
|
-
return true;
|
|
154
|
-
})
|
|
155
|
-
.filter(({ validators }) => Object.keys(validators).length !== 0)
|
|
156
|
-
.map((reward) => {
|
|
157
|
-
let isClaimed = reward.isClaimed;
|
|
158
|
-
const valKeys = Object.keys(reward.validators);
|
|
159
|
-
|
|
160
|
-
if (!reward.isClaimed && valKeys.length) {
|
|
161
|
-
for (const key of valKeys) {
|
|
162
|
-
const info = queryValidators.find((i) => i.accountId.toString() === key);
|
|
163
|
-
|
|
164
|
-
if (info) {
|
|
165
|
-
isClaimed = info.claimedRewardsEras?.toArray().some((era) => era.eq(reward.era));
|
|
166
|
-
break;
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
return objectSpread({}, reward, {
|
|
172
|
-
isClaimed,
|
|
173
|
-
nominators: reward.nominating.filter((n) => reward.validators[n.validatorId])
|
|
174
|
-
});
|
|
175
|
-
});
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
export function _stakerRewardsEras (instanceId: string, api: DeriveApi): (eras: EraIndex[], withActive?: boolean) => Observable<ErasResult> {
|
|
179
|
-
return memo(instanceId, (eras: EraIndex[], withActive = false): Observable<ErasResult> =>
|
|
180
|
-
combineLatest([
|
|
181
|
-
api.derive.staking._erasPoints(eras, withActive),
|
|
182
|
-
api.derive.staking._erasPrefs(eras, withActive),
|
|
183
|
-
api.derive.staking._erasRewards(eras, withActive)
|
|
184
|
-
])
|
|
185
|
-
);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
export function _stakerRewards (instanceId: string, api: DeriveApi): (accountIds: (Uint8Array | string)[], eras: EraIndex[], withActive?: boolean) => Observable<DeriveStakerReward[][]> {
|
|
189
|
-
return memo(instanceId, (accountIds: (Uint8Array | string)[], eras: EraIndex[], withActive = false): Observable<DeriveStakerReward[][]> => {
|
|
190
|
-
// Ensures that when number or string types are passed in they are sanitized
|
|
191
|
-
// Ref: https://github.com/polkadot-js/api/issues/5910
|
|
192
|
-
const sanitizedEras: EraIndex[] = eras.map((e) => typeof e === 'number' || typeof e === 'string' ? api.registry.createType('u32', e) : e);
|
|
193
|
-
|
|
194
|
-
return combineLatest([
|
|
195
|
-
api.derive.staking.queryMulti(accountIds, { withClaimedRewardsEras: true, withLedger: true }),
|
|
196
|
-
api.derive.staking._stakerExposures(accountIds, sanitizedEras, withActive),
|
|
197
|
-
api.derive.staking._stakerRewardsEras(sanitizedEras, withActive)
|
|
198
|
-
]).pipe(
|
|
199
|
-
switchMap(([queries, exposures, erasResult]): Observable<DeriveStakerReward[][]> => {
|
|
200
|
-
const allRewards = queries.map(({ claimedRewardsEras, stakingLedger, stashId }, index): DeriveStakerReward[] =>
|
|
201
|
-
(!stashId || (!stakingLedger && !claimedRewardsEras))
|
|
202
|
-
? []
|
|
203
|
-
: parseRewards(api, stashId, erasResult, exposures[index], claimedRewardsEras)
|
|
204
|
-
);
|
|
205
|
-
|
|
206
|
-
if (withActive) {
|
|
207
|
-
return of(allRewards);
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
const [allValidators, stashValidators] = allUniqValidators(allRewards);
|
|
211
|
-
|
|
212
|
-
return api.derive.staking.queryMulti(allValidators, { withClaimedRewardsEras: true, withLedger: true }).pipe(
|
|
213
|
-
map((queriedVals): DeriveStakerReward[][] =>
|
|
214
|
-
queries.map(({ claimedRewardsEras, stakingLedger }, index): DeriveStakerReward[] =>
|
|
215
|
-
filterRewards(
|
|
216
|
-
eras,
|
|
217
|
-
stashValidators[index]
|
|
218
|
-
.map((validatorId): [string, DeriveStakingQuery | undefined] => [
|
|
219
|
-
validatorId,
|
|
220
|
-
queriedVals.find((q) => q.accountId.eq(validatorId))
|
|
221
|
-
])
|
|
222
|
-
.filter((v): v is [string, DeriveStakingQuery] => !!v[1]),
|
|
223
|
-
{
|
|
224
|
-
claimedRewardsEras,
|
|
225
|
-
rewards: allRewards[index],
|
|
226
|
-
stakingLedger
|
|
227
|
-
}
|
|
228
|
-
)
|
|
229
|
-
)
|
|
230
|
-
)
|
|
231
|
-
);
|
|
232
|
-
})
|
|
233
|
-
);
|
|
234
|
-
}
|
|
235
|
-
);
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
/**
|
|
239
|
-
* @name stakerRewards
|
|
240
|
-
* @description Staking rewards history for a given staker.
|
|
241
|
-
* @param { Uint8Array | string } accountId The stakers AccountId.
|
|
242
|
-
* @param { boolean } withActive Whether to include the active era.
|
|
243
|
-
* @example
|
|
244
|
-
* ```javascript
|
|
245
|
-
* const rewards = await api.derive.staking.stakerRewards(
|
|
246
|
-
* ALICE, //Alice accountId
|
|
247
|
-
* false
|
|
248
|
-
* );
|
|
249
|
-
* ```
|
|
250
|
-
*/
|
|
251
|
-
export const stakerRewards = /*#__PURE__*/ firstMemo(
|
|
252
|
-
(api: DeriveApi, accountId: Uint8Array | string, withActive?: boolean) =>
|
|
253
|
-
api.derive.staking.erasHistoric(withActive).pipe(
|
|
254
|
-
switchMap((eras) => api.derive.staking._stakerRewards([accountId], eras, withActive))
|
|
255
|
-
)
|
|
256
|
-
);
|
|
257
|
-
|
|
258
|
-
/**
|
|
259
|
-
* @name stakerRewardsMultiEras
|
|
260
|
-
* @description Staking rewards for multiple stakers over specific eras.
|
|
261
|
-
* @param { Uint8Array | string } accountIds List of stakers identified by their AccountId.
|
|
262
|
-
* @param { EraIndex[] } eras Eras for which to retrieve the data.
|
|
263
|
-
* @example
|
|
264
|
-
* ```javascript
|
|
265
|
-
* const rewards = await api.derive.staking.stakerRewardsMultiEras(
|
|
266
|
-
* [ALICE, BOB, CHARLIER], //accountIds
|
|
267
|
-
* [100,101] //eras
|
|
268
|
-
* );
|
|
269
|
-
* ```
|
|
270
|
-
*/
|
|
271
|
-
export function stakerRewardsMultiEras (instanceId: string, api: DeriveApi): (accountIds: (Uint8Array | string)[], eras: EraIndex[]) => Observable<DeriveStakerReward[][]> {
|
|
272
|
-
return memo(instanceId, (accountIds: (Uint8Array | string)[], eras: EraIndex[]): Observable<DeriveStakerReward[][]> =>
|
|
273
|
-
accountIds.length && eras.length
|
|
274
|
-
? api.derive.staking._stakerRewards(accountIds, eras, false)
|
|
275
|
-
: of([])
|
|
276
|
-
);
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
/**
|
|
280
|
-
* @name stakerRewardsMulti
|
|
281
|
-
* @description Staking rewards for multiple stakers.
|
|
282
|
-
* @param { Uint8Array | string } accountIds List of stakers identified by their AccountId.
|
|
283
|
-
* @param { boolean } withActive Whether to include the active era.
|
|
284
|
-
* @example
|
|
285
|
-
* ```javascript
|
|
286
|
-
* const rewards = await api.derive.staking.stakerRewardsMulti(
|
|
287
|
-
* [ALICE, BOB, CHARLIER], //accountIds
|
|
288
|
-
* true
|
|
289
|
-
* );
|
|
290
|
-
* ```
|
|
291
|
-
*/
|
|
292
|
-
export function stakerRewardsMulti (instanceId: string, api: DeriveApi): (accountIds: (Uint8Array | string)[], withActive?: boolean) => Observable<DeriveStakerReward[][]> {
|
|
293
|
-
return memo(instanceId, (accountIds: (Uint8Array | string)[], withActive = false): Observable<DeriveStakerReward[][]> =>
|
|
294
|
-
api.derive.staking.erasHistoric(withActive).pipe(
|
|
295
|
-
switchMap((eras) => api.derive.staking.stakerRewardsMultiEras(accountIds, eras))
|
|
296
|
-
)
|
|
297
|
-
);
|
|
298
|
-
}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
|
-
import type { Observable } from 'rxjs';
|
|
5
|
-
import type { EraIndex } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type { DeriveApi, DeriveStakerSlashes } from '../types.js';
|
|
7
|
-
|
|
8
|
-
import { map } from 'rxjs';
|
|
9
|
-
|
|
10
|
-
import { memo } from '../util/index.js';
|
|
11
|
-
import { erasHistoricApplyAccount } from './util.js';
|
|
12
|
-
|
|
13
|
-
export function _stakerSlashes (instanceId: string, api: DeriveApi): (accountId: Uint8Array | string, eras: EraIndex[], withActive: boolean) => Observable<DeriveStakerSlashes[]> {
|
|
14
|
-
return memo(instanceId, (accountId: Uint8Array | string, eras: EraIndex[], withActive: boolean): Observable<DeriveStakerSlashes[]> => {
|
|
15
|
-
const stakerId = api.registry.createType('AccountId', accountId).toString();
|
|
16
|
-
|
|
17
|
-
return api.derive.staking._erasSlashes(eras, withActive).pipe(
|
|
18
|
-
map((slashes): DeriveStakerSlashes[] =>
|
|
19
|
-
slashes.map(({ era, nominators, validators }): DeriveStakerSlashes => ({
|
|
20
|
-
era,
|
|
21
|
-
total: nominators[stakerId] || validators[stakerId] || api.registry.createType('Balance')
|
|
22
|
-
}))
|
|
23
|
-
)
|
|
24
|
-
);
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
/**
|
|
29
|
-
* @name stakerSlashes
|
|
30
|
-
* @param { Uint8Array | string } accountId The stakers AccountId.
|
|
31
|
-
* @param { boolean } withActive Whether to include the active era.
|
|
32
|
-
* @description Retrieve the historical slashes (penalties) for a given staker.
|
|
33
|
-
* @example
|
|
34
|
-
* ```javascript
|
|
35
|
-
* const stakerSlashes = await api.derive.staking.stakerSlashes(
|
|
36
|
-
* ALICE, //Alice accountId
|
|
37
|
-
* true
|
|
38
|
-
* );
|
|
39
|
-
* console.log(
|
|
40
|
-
* 'Staker Slashes:',
|
|
41
|
-
* stakerSlashes.map(({ era, total }) => `Era ${era}: Slashed ${total.toString()}`)
|
|
42
|
-
* );
|
|
43
|
-
* ```
|
|
44
|
-
*/
|
|
45
|
-
export const stakerSlashes = /*#__PURE__*/ erasHistoricApplyAccount('_stakerSlashes');
|
package/src/staking/stashes.ts
DELETED
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
|
-
import type { Observable } from 'rxjs';
|
|
5
|
-
import type { AccountId } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type { DeriveApi } from '../types.js';
|
|
7
|
-
|
|
8
|
-
import { map, startWith, switchMap } from 'rxjs';
|
|
9
|
-
|
|
10
|
-
import { drr, memo } from '../util/index.js';
|
|
11
|
-
|
|
12
|
-
function onBondedEvent (api: DeriveApi): Observable<number> {
|
|
13
|
-
let current = Date.now();
|
|
14
|
-
|
|
15
|
-
return api.query.system.events().pipe(
|
|
16
|
-
map((events): number => {
|
|
17
|
-
current = events.filter(({ event, phase }): boolean => {
|
|
18
|
-
try {
|
|
19
|
-
return phase.isApplyExtrinsic &&
|
|
20
|
-
event.section === 'staking' &&
|
|
21
|
-
event.method === 'Bonded';
|
|
22
|
-
} catch {
|
|
23
|
-
return false;
|
|
24
|
-
}
|
|
25
|
-
})
|
|
26
|
-
? Date.now()
|
|
27
|
-
: current;
|
|
28
|
-
|
|
29
|
-
return current;
|
|
30
|
-
}),
|
|
31
|
-
startWith(current),
|
|
32
|
-
drr({ skipTimeout: true })
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* @name stashes
|
|
38
|
-
* @description Retrieve the list of all validator stashes.
|
|
39
|
-
* @example
|
|
40
|
-
* ```javascript
|
|
41
|
-
* const stashes = await api.derive.staking.stashes();
|
|
42
|
-
* console.log(
|
|
43
|
-
* "Validator Stashes:",
|
|
44
|
-
* stashes.map((s) => s.toString())
|
|
45
|
-
* );
|
|
46
|
-
* ```
|
|
47
|
-
*/
|
|
48
|
-
export function stashes (instanceId: string, api: DeriveApi): () => Observable<AccountId[]> {
|
|
49
|
-
return memo(instanceId, (): Observable<AccountId[]> =>
|
|
50
|
-
onBondedEvent(api).pipe(
|
|
51
|
-
switchMap(() => api.query.staking.validators.keys()),
|
|
52
|
-
map((keys) => keys.map(({ args: [v] }) => v).filter((a) => a))
|
|
53
|
-
)
|
|
54
|
-
);
|
|
55
|
-
}
|
package/src/staking/types.ts
DELETED
|
@@ -1,174 +0,0 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
|
-
import type { Option, u32, Vec } from '@pezkuwi/types';
|
|
5
|
-
import type { AccountId, Balance, EraIndex, RewardPoint } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type { PalletStakingRewardDestination, PalletStakingStakingLedger, PalletStakingValidatorPrefs, SpStakingExposure, SpStakingExposurePage, SpStakingPagedExposureMetadata } from '@pezkuwi/types/lookup';
|
|
7
|
-
import type { BN } from '@pezkuwi/util';
|
|
8
|
-
import type { DeriveSessionIndexes } from '../session/types.js';
|
|
9
|
-
|
|
10
|
-
export type DeriveEraValPoints = Record<string, RewardPoint>;
|
|
11
|
-
|
|
12
|
-
export type DeriveEraValPrefs = Record<string, PalletStakingValidatorPrefs>;
|
|
13
|
-
|
|
14
|
-
export type DeriveEraValSlash = Record<string, Balance>;
|
|
15
|
-
|
|
16
|
-
export interface DeriveEraPoints {
|
|
17
|
-
era: EraIndex;
|
|
18
|
-
eraPoints: RewardPoint;
|
|
19
|
-
validators: DeriveEraValPoints;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export interface DeriveEraPrefs {
|
|
23
|
-
era: EraIndex;
|
|
24
|
-
validators: DeriveEraValPrefs;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
export interface DeriveEraRewards {
|
|
28
|
-
era: EraIndex;
|
|
29
|
-
eraReward: Balance;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export interface DeriveEraSlashes {
|
|
33
|
-
era: EraIndex;
|
|
34
|
-
nominators: DeriveEraValSlash;
|
|
35
|
-
validators: DeriveEraValSlash;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
export interface DeriveStakerPoints {
|
|
39
|
-
era: EraIndex;
|
|
40
|
-
eraPoints: RewardPoint;
|
|
41
|
-
points: RewardPoint;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
export interface DeriveOwnExposure {
|
|
45
|
-
clipped: SpStakingExposure;
|
|
46
|
-
exposurePaged: Option<SpStakingExposurePage>;
|
|
47
|
-
era: EraIndex;
|
|
48
|
-
exposure: SpStakingExposure;
|
|
49
|
-
exposureMeta: Option<SpStakingPagedExposureMetadata>;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
export interface DeriveEraExposureNominating {
|
|
53
|
-
validatorId: string;
|
|
54
|
-
validatorIndex: number;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export type DeriveEraNominatorExposure = Record<string, DeriveEraExposureNominating[]>;
|
|
58
|
-
|
|
59
|
-
export type DeriveEraValidatorExposure = Record<string, SpStakingExposure>;
|
|
60
|
-
|
|
61
|
-
export type DeriveEraValidatorExposurePaged = Record<string, SpStakingExposurePage | SpStakingExposure>;
|
|
62
|
-
|
|
63
|
-
export interface DeriveEraExposure {
|
|
64
|
-
era: EraIndex;
|
|
65
|
-
nominators: DeriveEraNominatorExposure;
|
|
66
|
-
validators: DeriveEraValidatorExposure;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
export interface DeriveEraExposurePaged {
|
|
70
|
-
era: EraIndex;
|
|
71
|
-
nominators: DeriveEraNominatorExposure;
|
|
72
|
-
validators: DeriveEraValidatorExposurePaged;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
export interface DeriveStakerExposure {
|
|
76
|
-
era: EraIndex;
|
|
77
|
-
isEmpty: boolean;
|
|
78
|
-
isValidator: boolean;
|
|
79
|
-
nominating: DeriveEraExposureNominating[];
|
|
80
|
-
validators: DeriveEraValidatorExposurePaged;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
export interface DeriveStakerPrefs {
|
|
84
|
-
era: EraIndex;
|
|
85
|
-
validatorPrefs: PalletStakingValidatorPrefs;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
export interface DeriveStakerRewardValidator {
|
|
89
|
-
total: Balance;
|
|
90
|
-
value: Balance;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
export interface DeriveStakerReward {
|
|
94
|
-
era: EraIndex;
|
|
95
|
-
eraReward: Balance;
|
|
96
|
-
isClaimed: boolean;
|
|
97
|
-
isEmpty: boolean;
|
|
98
|
-
isValidator: boolean;
|
|
99
|
-
nominating: DeriveEraExposureNominating[];
|
|
100
|
-
validators: Record<string, DeriveStakerRewardValidator>;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
export interface DeriveStakerSlashes {
|
|
104
|
-
era: EraIndex;
|
|
105
|
-
total: Balance;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
export type DeriveOwnSlashes = DeriveStakerSlashes;
|
|
109
|
-
|
|
110
|
-
export interface DeriveStakingKeys {
|
|
111
|
-
nextSessionIds: AccountId[];
|
|
112
|
-
sessionIds: AccountId[];
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
export interface DeriveStakingValidators {
|
|
116
|
-
nextElected: AccountId[];
|
|
117
|
-
validators: AccountId[];
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
export interface DeriveStakingStash {
|
|
121
|
-
controllerId: AccountId | null;
|
|
122
|
-
// Legacy Support for erasStakers
|
|
123
|
-
exposureEraStakers: SpStakingExposure;
|
|
124
|
-
exposurePaged: Option<SpStakingExposurePage>;
|
|
125
|
-
exposureMeta: Option<SpStakingPagedExposureMetadata>;
|
|
126
|
-
nominators: AccountId[];
|
|
127
|
-
rewardDestination: PalletStakingRewardDestination | null;
|
|
128
|
-
stashId: AccountId;
|
|
129
|
-
validatorPrefs: PalletStakingValidatorPrefs;
|
|
130
|
-
claimedRewardsEras: Vec<u32>
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
export interface DeriveStakingQuery extends DeriveStakingStash {
|
|
134
|
-
accountId: AccountId;
|
|
135
|
-
stakingLedger: PalletStakingStakingLedger;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
export interface DeriveStakingElected {
|
|
139
|
-
info: DeriveStakingQuery[];
|
|
140
|
-
nextElected: AccountId[];
|
|
141
|
-
validators: AccountId[];
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
export interface DeriveStakingWaiting {
|
|
145
|
-
info: DeriveStakingQuery[];
|
|
146
|
-
waiting: AccountId[];
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
export interface DeriveUnlocking {
|
|
150
|
-
remainingEras: BN;
|
|
151
|
-
value: Balance;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
export interface DeriveStakingAccount extends DeriveStakingQuery, DeriveStakingKeys {
|
|
155
|
-
redeemable?: Balance;
|
|
156
|
-
unlocking?: DeriveUnlocking[];
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
export interface DeriveStakingOverview extends DeriveSessionIndexes {
|
|
160
|
-
nextElected: AccountId[];
|
|
161
|
-
validators: AccountId[];
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
export interface StakingQueryFlags {
|
|
165
|
-
withController?: boolean;
|
|
166
|
-
withDestination?: boolean;
|
|
167
|
-
withExposure?: boolean;
|
|
168
|
-
withExposureErasStakersLegacy?: boolean,
|
|
169
|
-
withLedger?: boolean;
|
|
170
|
-
withNominations?: boolean;
|
|
171
|
-
withPrefs?: boolean;
|
|
172
|
-
withExposureMeta?: boolean;
|
|
173
|
-
withClaimedRewardsEras?: boolean;
|
|
174
|
-
}
|
package/src/staking/util.ts
DELETED
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
|
-
import type { Observable } from 'rxjs';
|
|
5
|
-
import type { ObsInnerType } from '@pezkuwi/api-base/types';
|
|
6
|
-
import type { u32 } from '@pezkuwi/types';
|
|
7
|
-
import type { EraIndex } from '@pezkuwi/types/interfaces';
|
|
8
|
-
import type { AnyNumber } from '@pezkuwi/types-codec/types';
|
|
9
|
-
import type { ExactDerive } from '../derive.js';
|
|
10
|
-
import type { DeriveApi } from '../types.js';
|
|
11
|
-
|
|
12
|
-
import { BehaviorSubject, combineLatest, map, of, switchMap, tap, toArray } from 'rxjs';
|
|
13
|
-
|
|
14
|
-
import { arrayChunk, arrayFlatten, nextTick } from '@pezkuwi/util';
|
|
15
|
-
|
|
16
|
-
import { memo } from '../util/index.js';
|
|
17
|
-
|
|
18
|
-
type ApplyReturn<T extends keyof ExactDerive['staking']> = ReturnType<ExactDerive['staking'][T]>;
|
|
19
|
-
|
|
20
|
-
// only retrieve a maximum of 14 eras (84 / 6) at a time
|
|
21
|
-
// (This is not empirically calculated. Rather smaller sizes take longer
|
|
22
|
-
// time due to the serial nature, large sizes may tie up the RPCs)
|
|
23
|
-
const ERA_CHUNK_SIZE = 14;
|
|
24
|
-
|
|
25
|
-
function chunkEras <T> (eras: EraIndex[], fn: (eras: EraIndex[]) => Observable<T[]>): Observable<T[]> {
|
|
26
|
-
const chunked = arrayChunk(eras, ERA_CHUNK_SIZE);
|
|
27
|
-
let index = 0;
|
|
28
|
-
const subject = new BehaviorSubject<EraIndex[]>(chunked[index]);
|
|
29
|
-
|
|
30
|
-
return subject.pipe(
|
|
31
|
-
switchMap(fn),
|
|
32
|
-
tap((): void => {
|
|
33
|
-
nextTick((): void => {
|
|
34
|
-
index++;
|
|
35
|
-
|
|
36
|
-
index === chunked.length
|
|
37
|
-
? subject.complete()
|
|
38
|
-
: subject.next(chunked[index]);
|
|
39
|
-
});
|
|
40
|
-
}),
|
|
41
|
-
toArray(),
|
|
42
|
-
map(arrayFlatten)
|
|
43
|
-
);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
export function filterEras <T extends { era: EraIndex }> (eras: EraIndex[], list: T[]): EraIndex[] {
|
|
47
|
-
return eras.filter((e) => !list.some(({ era }) => e.eq(era)));
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
export function erasHistoricApply <F extends '_erasExposure' | '_erasPoints' | '_erasPrefs' | '_erasRewards' | '_erasSlashes'> (fn: F): (instanceId: string, api: DeriveApi) => (withActive?: boolean) => ApplyReturn<F> {
|
|
51
|
-
return (instanceId: string, api: DeriveApi) =>
|
|
52
|
-
// Cannot quite get the typing right, but it is right in the code
|
|
53
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
54
|
-
memo(instanceId, (withActive = false) =>
|
|
55
|
-
api.derive.staking.erasHistoric(withActive).pipe(
|
|
56
|
-
switchMap((e) => api.derive.staking[fn](e, withActive))
|
|
57
|
-
)
|
|
58
|
-
) as any;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
export function erasHistoricApplyAccount <F extends '_ownExposures' | '_ownSlashes' | '_stakerPoints' | '_stakerPrefs' | '_stakerSlashes'> (fn: F): (instanceId: string, api: DeriveApi) => (accountId: string | Uint8Array, withActive?: boolean) => ApplyReturn<F> {
|
|
62
|
-
return (instanceId: string, api: DeriveApi) =>
|
|
63
|
-
// Cannot quite get the typing right, but it is right in the code
|
|
64
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
65
|
-
memo(instanceId, (accountId: string | Uint8Array, withActive = false, page?: u32 | AnyNumber) =>
|
|
66
|
-
api.derive.staking.erasHistoric(withActive).pipe(
|
|
67
|
-
switchMap((e) => api.derive.staking[fn](accountId, e, withActive, page || 0))
|
|
68
|
-
)
|
|
69
|
-
) as any;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
export function singleEra <F extends '_eraExposure' | '_eraPrefs' | '_eraSlashes'> (fn: F): (instanceId: string, api: DeriveApi) => (era: EraIndex) => ApplyReturn<F> {
|
|
73
|
-
return (instanceId: string, api: DeriveApi) =>
|
|
74
|
-
// Cannot quite get the typing right, but it is right in the code
|
|
75
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
76
|
-
memo(instanceId, (era: EraIndex) =>
|
|
77
|
-
api.derive.staking[fn](era, true)
|
|
78
|
-
) as any;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
export function combineEras <F extends '_eraExposure' | '_eraPrefs' | '_eraSlashes'> (fn: F): (instanceId: string, api: DeriveApi) => (eras: EraIndex[], withActive: boolean) => Observable<ObsInnerType<ApplyReturn<F>>[]> {
|
|
82
|
-
return (instanceId: string, api: DeriveApi) =>
|
|
83
|
-
// Cannot quite get the typing right, but it is right in the code
|
|
84
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
85
|
-
memo(instanceId, (eras: EraIndex[], withActive: boolean) =>
|
|
86
|
-
!eras.length
|
|
87
|
-
? of([])
|
|
88
|
-
: chunkEras(eras, (eras) =>
|
|
89
|
-
combineLatest(
|
|
90
|
-
eras.map((e) => api.derive.staking[fn](e, withActive))
|
|
91
|
-
)
|
|
92
|
-
)
|
|
93
|
-
) as any;
|
|
94
|
-
}
|