@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
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createSignedBlockExtended = exports.createHeaderExtended = void 0;
|
|
4
|
+
var HeaderExtended_js_1 = require("./HeaderExtended.js");
|
|
5
|
+
Object.defineProperty(exports, "createHeaderExtended", { enumerable: true, get: function () { return HeaderExtended_js_1.createHeaderExtended; } });
|
|
6
|
+
var SignedBlockExtended_js_1 = require("./SignedBlockExtended.js");
|
|
7
|
+
Object.defineProperty(exports, "createSignedBlockExtended", { enumerable: true, get: function () { return SignedBlockExtended_js_1.createSignedBlockExtended; } });
|
package/cjs/type/util.js
ADDED
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.extractAuthor = extractAuthor;
|
|
4
|
+
function extractAuthor(digest, sessionValidators) {
|
|
5
|
+
const [citem] = digest.logs.filter((e) => e.isConsensus);
|
|
6
|
+
const preRuntimeItems = digest.logs.filter((e) => e.isPreRuntime);
|
|
7
|
+
const [sitem] = digest.logs.filter((e) => e.isSeal);
|
|
8
|
+
let accountId;
|
|
9
|
+
try {
|
|
10
|
+
// This is critical to be first for BABE (before Consensus)
|
|
11
|
+
// If not first, we end up dropping the author at session-end
|
|
12
|
+
// Iterate through ALL preRuntime logs to find a recognized engine
|
|
13
|
+
// (teyrchains may have multiple preRuntime logs, e.g., CMLS + aura)
|
|
14
|
+
for (const pitem of preRuntimeItems) {
|
|
15
|
+
const [engine, data] = pitem.asPreRuntime;
|
|
16
|
+
accountId = engine.extractAuthor(data, sessionValidators);
|
|
17
|
+
// Stop at first recognized engine that returns an author
|
|
18
|
+
if (accountId) {
|
|
19
|
+
return accountId;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
if (!accountId && citem) {
|
|
23
|
+
const [engine, data] = citem.asConsensus;
|
|
24
|
+
accountId = engine.extractAuthor(data, sessionValidators);
|
|
25
|
+
}
|
|
26
|
+
// SEAL, still used in e.g. Kulupu for pow
|
|
27
|
+
if (!accountId && sitem) {
|
|
28
|
+
const [engine, data] = sitem.asSeal;
|
|
29
|
+
accountId = engine.extractAuthor(data, sessionValidators);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
// ignore
|
|
34
|
+
}
|
|
35
|
+
return accountId;
|
|
36
|
+
}
|
package/{build → cjs}/types.d.ts
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { ApiInterfaceRx } from '@pezkuwi/api-base/types';
|
|
2
2
|
import type { u32 } from '@pezkuwi/types';
|
|
3
3
|
import type { Balance, BlockNumber, BountyIndex, Hash, Proposal, ProposalIndex, SetIndex, Votes } from '@pezkuwi/types/interfaces';
|
|
4
|
-
import type {
|
|
4
|
+
import type { PezpalletBountiesBounty, PezpalletTreasuryProposal } from '@pezkuwi/types/lookup';
|
|
5
5
|
import type { BN } from '@pezkuwi/util';
|
|
6
6
|
import type { ExactDerive } from './derive.js';
|
|
7
7
|
export * from './accounts/types.js';
|
|
@@ -11,7 +11,7 @@ export * from './council/types.js';
|
|
|
11
11
|
export * from './crowdloan/types.js';
|
|
12
12
|
export * from './democracy/types.js';
|
|
13
13
|
export * from './elections/types.js';
|
|
14
|
-
export * from './
|
|
14
|
+
export * from './teyrchains/types.js';
|
|
15
15
|
export * from './session/types.js';
|
|
16
16
|
export * from './society/types.js';
|
|
17
17
|
export * from './staking/types.js';
|
|
@@ -57,7 +57,7 @@ export type DeriveRecentlyOffline = Record<string, RecentlyOffline[]>;
|
|
|
57
57
|
export interface DeriveTreasuryProposal {
|
|
58
58
|
council: DeriveCollectiveProposal[];
|
|
59
59
|
id: ProposalIndex;
|
|
60
|
-
proposal:
|
|
60
|
+
proposal: PezpalletTreasuryProposal;
|
|
61
61
|
}
|
|
62
62
|
export interface DeriveTreasuryProposals {
|
|
63
63
|
approvals: DeriveTreasuryProposal[];
|
|
@@ -71,7 +71,7 @@ export interface VoterPosition {
|
|
|
71
71
|
}
|
|
72
72
|
export type DeriveVoterPositions = Record<string, VoterPosition>;
|
|
73
73
|
export interface DeriveBounty {
|
|
74
|
-
bounty:
|
|
74
|
+
bounty: PezpalletBountiesBounty;
|
|
75
75
|
description: string;
|
|
76
76
|
index: BountyIndex;
|
|
77
77
|
proposals: DeriveCollectiveProposal[];
|
package/cjs/types.js
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
tslib_1.__exportStar(require("./accounts/types.js"), exports);
|
|
5
|
+
tslib_1.__exportStar(require("./bagsList/types.js"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./balances/types.js"), exports);
|
|
7
|
+
tslib_1.__exportStar(require("./council/types.js"), exports);
|
|
8
|
+
tslib_1.__exportStar(require("./crowdloan/types.js"), exports);
|
|
9
|
+
tslib_1.__exportStar(require("./democracy/types.js"), exports);
|
|
10
|
+
tslib_1.__exportStar(require("./elections/types.js"), exports);
|
|
11
|
+
tslib_1.__exportStar(require("./teyrchains/types.js"), exports);
|
|
12
|
+
tslib_1.__exportStar(require("./session/types.js"), exports);
|
|
13
|
+
tslib_1.__exportStar(require("./society/types.js"), exports);
|
|
14
|
+
tslib_1.__exportStar(require("./staking/types.js"), exports);
|
|
15
|
+
tslib_1.__exportStar(require("./type/types.js"), exports);
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.approvalFlagsToBools = approvalFlagsToBools;
|
|
4
|
+
/** @internal */
|
|
5
|
+
function approvalFlagsToBools(flags) {
|
|
6
|
+
const bools = [];
|
|
7
|
+
for (let i = 0, count = flags.length; i < count; i++) {
|
|
8
|
+
const str = flags[i].toString(2);
|
|
9
|
+
// read from lowest bit to highest
|
|
10
|
+
for (const bit of str.split('').reverse()) {
|
|
11
|
+
bools.push(!!parseInt(bit, 10));
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
// slice off trailing "false" values, as in bizinikiwi
|
|
15
|
+
const lastApproval = bools.lastIndexOf(true);
|
|
16
|
+
return lastApproval >= 0
|
|
17
|
+
? bools.slice(0, lastApproval + 1)
|
|
18
|
+
: [];
|
|
19
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.unwrapBlockNumber = unwrapBlockNumber;
|
|
4
|
+
const util_1 = require("@pezkuwi/util");
|
|
5
|
+
function unwrapBlockNumber(hdr) {
|
|
6
|
+
return (0, util_1.isCompact)(hdr.number)
|
|
7
|
+
? hdr.number.unwrap()
|
|
8
|
+
: hdr.number;
|
|
9
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.deriveCache = void 0;
|
|
4
|
+
exports.setDeriveCache = setDeriveCache;
|
|
5
|
+
const cacheImpl_js_1 = require("./cacheImpl.js");
|
|
6
|
+
const CACHE_EXPIRY = 7 * (24 * 60) * (60 * 1000);
|
|
7
|
+
let deriveCache;
|
|
8
|
+
function wrapCache(keyStart, cache) {
|
|
9
|
+
return {
|
|
10
|
+
del: (partial) => cache.del(`${keyStart}${partial}`),
|
|
11
|
+
forEach: cache.forEach,
|
|
12
|
+
get: (partial) => {
|
|
13
|
+
const key = `${keyStart}${partial}`;
|
|
14
|
+
const cached = cache.get(key);
|
|
15
|
+
if (cached) {
|
|
16
|
+
cached.x = Date.now();
|
|
17
|
+
cache.set(key, cached);
|
|
18
|
+
return cached.v;
|
|
19
|
+
}
|
|
20
|
+
return undefined;
|
|
21
|
+
},
|
|
22
|
+
set: (partial, v) => {
|
|
23
|
+
cache.set(`${keyStart}${partial}`, { v, x: Date.now() });
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
function clearCache(cache) {
|
|
28
|
+
// clear all expired values
|
|
29
|
+
const now = Date.now();
|
|
30
|
+
const all = [];
|
|
31
|
+
cache.forEach((key, { x }) => {
|
|
32
|
+
((now - x) > CACHE_EXPIRY) && all.push(key);
|
|
33
|
+
});
|
|
34
|
+
// don't do delete inside loop, just in-case
|
|
35
|
+
all.forEach((key) => cache.del(key));
|
|
36
|
+
}
|
|
37
|
+
function setDeriveCache(prefix = '', cache) {
|
|
38
|
+
exports.deriveCache = deriveCache = cache
|
|
39
|
+
? wrapCache(`derive:${prefix}:`, cache)
|
|
40
|
+
: cacheImpl_js_1.deriveNoopCache;
|
|
41
|
+
if (cache) {
|
|
42
|
+
clearCache(cache);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
setDeriveCache();
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.deriveNoopCache = exports.deriveMapCache = void 0;
|
|
4
|
+
const mapCache = new Map();
|
|
5
|
+
exports.deriveMapCache = {
|
|
6
|
+
del: (key) => {
|
|
7
|
+
mapCache.delete(key);
|
|
8
|
+
},
|
|
9
|
+
forEach: (cb) => {
|
|
10
|
+
for (const [k, v] of mapCache.entries()) {
|
|
11
|
+
cb(k, v);
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
get: (key) => {
|
|
15
|
+
return mapCache.get(key);
|
|
16
|
+
},
|
|
17
|
+
set: (key, value) => {
|
|
18
|
+
mapCache.set(key, value);
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
exports.deriveNoopCache = {
|
|
22
|
+
del: () => undefined,
|
|
23
|
+
forEach: () => undefined,
|
|
24
|
+
get: () => undefined,
|
|
25
|
+
set: (_, value) => value
|
|
26
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.firstObservable = firstObservable;
|
|
4
|
+
exports.firstMemo = firstMemo;
|
|
5
|
+
const rxjs_1 = require("rxjs");
|
|
6
|
+
const rpc_core_1 = require("@pezkuwi/rpc-core");
|
|
7
|
+
function firstObservable(obs) {
|
|
8
|
+
return obs.pipe((0, rxjs_1.map)(([a]) => a));
|
|
9
|
+
}
|
|
10
|
+
function firstMemo(fn) {
|
|
11
|
+
return (instanceId, api) => (0, rpc_core_1.memo)(instanceId, (...args) => firstObservable(fn(api, ...args)));
|
|
12
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.memo = exports.drr = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
var rpc_core_1 = require("@pezkuwi/rpc-core");
|
|
6
|
+
Object.defineProperty(exports, "drr", { enumerable: true, get: function () { return rpc_core_1.drr; } });
|
|
7
|
+
Object.defineProperty(exports, "memo", { enumerable: true, get: function () { return rpc_core_1.memo; } });
|
|
8
|
+
tslib_1.__exportStar(require("./approvalFlagsToBools.js"), exports);
|
|
9
|
+
tslib_1.__exportStar(require("./blockNumber.js"), exports);
|
|
10
|
+
tslib_1.__exportStar(require("./cache.js"), exports);
|
|
11
|
+
tslib_1.__exportStar(require("./cacheImpl.js"), exports);
|
|
12
|
+
tslib_1.__exportStar(require("./first.js"), exports);
|
|
13
|
+
tslib_1.__exportStar(require("./lazy.js"), exports);
|
package/cjs/util/lazy.js
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.lazyDeriveSection = lazyDeriveSection;
|
|
4
|
+
const util_1 = require("@pezkuwi/util");
|
|
5
|
+
function lazyDeriveSection(result, section, getKeys, creator) {
|
|
6
|
+
(0, util_1.lazyMethod)(result, section, () => (0, util_1.lazyMethods)({}, getKeys(section), (method) => creator(section, method)));
|
|
7
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Observable } from 'rxjs';
|
|
2
|
+
import type { DeriveApi } from '../types.js';
|
|
3
|
+
import type { Collective } from './types.js';
|
|
4
|
+
export declare function getInstance(api: DeriveApi, section: string): DeriveApi['query']['council'];
|
|
5
|
+
export declare function withSection<T, F extends (...args: any[]) => Observable<T>>(section: Collective, fn: (query: DeriveApi['query']['council'], api: DeriveApi, instanceId: string) => F): (instanceId: string, api: DeriveApi) => F;
|
|
6
|
+
export declare function callMethod<T>(method: 'members' | 'proposals' | 'proposalCount', empty: T): (section: Collective) => (instanceId: string, api: DeriveApi) => () => Observable<T>;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { of } from 'rxjs';
|
|
2
|
+
import { isFunction } from '@pezkuwi/util';
|
|
3
|
+
import { memo } from '../util/index.js';
|
|
4
|
+
export function getInstance(api, section) {
|
|
5
|
+
const instances = api.registry.getModuleInstances(api.runtimeVersion.specName, section);
|
|
6
|
+
const name = instances?.length
|
|
7
|
+
? instances[0]
|
|
8
|
+
: section;
|
|
9
|
+
return api.query[name];
|
|
10
|
+
}
|
|
11
|
+
export function withSection(section, fn) {
|
|
12
|
+
return (instanceId, api) => memo(instanceId, fn(getInstance(api, section), api, instanceId));
|
|
13
|
+
}
|
|
14
|
+
export function callMethod(method, empty) {
|
|
15
|
+
return (section) => withSection(section, (query) => () => isFunction(query?.[method])
|
|
16
|
+
? query[method]()
|
|
17
|
+
: of(empty));
|
|
18
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { map, of } from 'rxjs';
|
|
2
|
+
import { isFunction } from '@pezkuwi/util';
|
|
3
|
+
import { withSection } from './helpers.js';
|
|
4
|
+
export function prime(section) {
|
|
5
|
+
return withSection(section, (query) => () => isFunction(query?.prime)
|
|
6
|
+
? query.prime().pipe(map((o) => o.unwrapOr(null)))
|
|
7
|
+
: of(null));
|
|
8
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Collective, HasProposalsFnRet, ProposalCountFn, ProposalFnRet, ProposalHashesFn, ProposalsFnRet } from './types.js';
|
|
2
|
+
export declare function hasProposals(section: Collective): HasProposalsFnRet;
|
|
3
|
+
export declare function proposals(section: Collective): ProposalsFnRet;
|
|
4
|
+
export declare function proposal(section: Collective): ProposalFnRet;
|
|
5
|
+
export declare const proposalCount: ProposalCountFn;
|
|
6
|
+
export declare const proposalHashes: ProposalHashesFn;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { catchError, combineLatest, map, of, switchMap } from 'rxjs';
|
|
2
|
+
import { isFunction } from '@pezkuwi/util';
|
|
3
|
+
import { firstObservable } from '../util/index.js';
|
|
4
|
+
import { callMethod, withSection } from './helpers.js';
|
|
5
|
+
function parse(api, [hashes, proposals, votes]) {
|
|
6
|
+
return proposals.map((o, index) => ({
|
|
7
|
+
hash: api.registry.createType('Hash', hashes[index]),
|
|
8
|
+
proposal: o && o.isSome
|
|
9
|
+
? o.unwrap()
|
|
10
|
+
: null,
|
|
11
|
+
votes: votes[index].unwrapOr(null)
|
|
12
|
+
}));
|
|
13
|
+
}
|
|
14
|
+
function _proposalsFrom(api, query, hashes) {
|
|
15
|
+
return (isFunction(query?.proposals) && hashes.length
|
|
16
|
+
? combineLatest([
|
|
17
|
+
of(hashes),
|
|
18
|
+
// this should simply be api.query[section].proposalOf.multi<Option<Proposal>>(hashes),
|
|
19
|
+
// however we have had cases on Edgeware where the indices have moved around after an
|
|
20
|
+
// upgrade, which results in invalid on-chain data
|
|
21
|
+
query.proposalOf.multi(hashes).pipe(catchError(() => of(hashes.map(() => null)))),
|
|
22
|
+
query.voting.multi(hashes)
|
|
23
|
+
])
|
|
24
|
+
: of([[], [], []])).pipe(map((r) => parse(api, r)));
|
|
25
|
+
}
|
|
26
|
+
export function hasProposals(section) {
|
|
27
|
+
return withSection(section, (query) => () => of(isFunction(query?.proposals)));
|
|
28
|
+
}
|
|
29
|
+
export function proposals(section) {
|
|
30
|
+
return withSection(section, (query, api) => () => api.derive[section].proposalHashes().pipe(switchMap((all) => _proposalsFrom(api, query, all))));
|
|
31
|
+
}
|
|
32
|
+
export function proposal(section) {
|
|
33
|
+
return withSection(section, (query, api) => (hash) => isFunction(query?.proposals)
|
|
34
|
+
? firstObservable(_proposalsFrom(api, query, [hash]))
|
|
35
|
+
: of(null));
|
|
36
|
+
}
|
|
37
|
+
export const proposalCount = /*#__PURE__*/ callMethod('proposalCount', null);
|
|
38
|
+
export const proposalHashes = /*#__PURE__*/ callMethod('proposals', []);
|
|
@@ -1,30 +1,19 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
1
|
import type { Observable } from 'rxjs';
|
|
5
2
|
import type { u32 } from '@pezkuwi/types';
|
|
6
3
|
import type { AccountId, Hash } from '@pezkuwi/types/interfaces';
|
|
7
4
|
import type { DeriveApi, DeriveCollectiveProposal } from '../types.js';
|
|
8
|
-
|
|
9
5
|
export type Collective = 'allianceMotion' | 'council' | 'membership' | 'technicalCommittee';
|
|
10
|
-
|
|
11
6
|
export type HasProposalsFnRet = (instanceId: string, api: DeriveApi) => () => Observable<boolean>;
|
|
12
7
|
export type HasProposalsFn = (section: Collective) => HasProposalsFnRet;
|
|
13
|
-
|
|
14
8
|
export type MembersFnRet = (instanceId: string, api: DeriveApi) => () => Observable<AccountId[]>;
|
|
15
9
|
export type MembersFn = (section: Collective) => MembersFnRet;
|
|
16
|
-
|
|
17
10
|
export type PrimeFnRet = (instanceId: string, api: DeriveApi) => () => Observable<AccountId | null>;
|
|
18
11
|
export type PrimeFn = (section: Collective) => PrimeFnRet;
|
|
19
|
-
|
|
20
12
|
export type ProposalFnRet = (instanceId: string, api: DeriveApi) => (hash: Hash | Uint8Array | string) => Observable<DeriveCollectiveProposal | null>;
|
|
21
13
|
export type ProposalFn = (section: Collective) => ProposalFnRet;
|
|
22
|
-
|
|
23
14
|
export type ProposalsFnRet = (instanceId: string, api: DeriveApi) => () => Observable<DeriveCollectiveProposal[]>;
|
|
24
15
|
export type ProposalsFn = (section: Collective) => ProposalsFnRet;
|
|
25
|
-
|
|
26
16
|
export type ProposalCountFnRet = (instanceId: string, api: DeriveApi) => () => Observable<u32 | null>;
|
|
27
17
|
export type ProposalCountFn = (section: Collective) => ProposalCountFnRet;
|
|
28
|
-
|
|
29
18
|
export type ProposalHashesFnRet = (instanceId: string, api: DeriveApi) => () => Observable<Hash[]>;
|
|
30
19
|
export type ProposalHashesFn = (section: Collective) => ProposalHashesFnRet;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Observable } from 'rxjs';
|
|
2
|
+
import type { DeriveApi, DeriveContractFees } from '../types.js';
|
|
3
|
+
/**
|
|
4
|
+
* @name fees
|
|
5
|
+
* @returns An object containing the combined results of the queries for
|
|
6
|
+
* all relevant contract fees as declared in the bizinikiwi chain spec.
|
|
7
|
+
* @example
|
|
8
|
+
* ```javascript
|
|
9
|
+
* api.derive.contracts.fees(([creationFee, transferFee]) => {
|
|
10
|
+
* console.log(`The fee for creating a new contract on this chain is ${creationFee} units. The fee required to call this contract is ${transferFee} units.`);
|
|
11
|
+
* });
|
|
12
|
+
* ```
|
|
13
|
+
*/
|
|
14
|
+
export declare function fees(instanceId: string, api: DeriveApi): () => Observable<DeriveContractFees>;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { map, of } from 'rxjs';
|
|
2
|
+
import { memo } from '../util/index.js';
|
|
3
|
+
function queryConstants(api) {
|
|
4
|
+
return of([
|
|
5
|
+
// deprecated
|
|
6
|
+
api.consts.contracts['callBaseFee'] || api.registry.createType('Balance'),
|
|
7
|
+
api.consts.contracts['contractFee'] || api.registry.createType('Balance'),
|
|
8
|
+
api.consts.contracts['creationFee'] || api.registry.createType('Balance'),
|
|
9
|
+
api.consts.contracts['transactionBaseFee'] || api.registry.createType('Balance'),
|
|
10
|
+
api.consts.contracts['transactionByteFee'] || api.registry.createType('Balance'),
|
|
11
|
+
api.consts.contracts['transferFee'] || api.registry.createType('Balance'),
|
|
12
|
+
// current
|
|
13
|
+
api.consts.contracts['rentByteFee'] || api.registry.createType('Balance'),
|
|
14
|
+
api.consts.contracts['rentDepositOffset'] || api.registry.createType('Balance'),
|
|
15
|
+
api.consts.contracts['surchargeReward'] || api.registry.createType('Balance'),
|
|
16
|
+
api.consts.contracts['tombstoneDeposit'] || api.registry.createType('Balance')
|
|
17
|
+
]);
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* @name fees
|
|
21
|
+
* @returns An object containing the combined results of the queries for
|
|
22
|
+
* all relevant contract fees as declared in the bizinikiwi chain spec.
|
|
23
|
+
* @example
|
|
24
|
+
* ```javascript
|
|
25
|
+
* api.derive.contracts.fees(([creationFee, transferFee]) => {
|
|
26
|
+
* console.log(`The fee for creating a new contract on this chain is ${creationFee} units. The fee required to call this contract is ${transferFee} units.`);
|
|
27
|
+
* });
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export function fees(instanceId, api) {
|
|
31
|
+
return memo(instanceId, () => {
|
|
32
|
+
return queryConstants(api).pipe(map(([callBaseFee, contractFee, creationFee, transactionBaseFee, transactionByteFee, transferFee, rentByteFee, rentDepositOffset, surchargeReward, tombstoneDeposit]) => ({
|
|
33
|
+
callBaseFee,
|
|
34
|
+
contractFee,
|
|
35
|
+
creationFee,
|
|
36
|
+
rentByteFee,
|
|
37
|
+
rentDepositOffset,
|
|
38
|
+
surchargeReward,
|
|
39
|
+
tombstoneDeposit,
|
|
40
|
+
transactionBaseFee,
|
|
41
|
+
transactionByteFee,
|
|
42
|
+
transferFee
|
|
43
|
+
})));
|
|
44
|
+
});
|
|
45
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './fees.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './fees.js';
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
export * from './votes.js';
|
|
2
|
+
export * from './votesOf.js';
|
|
3
|
+
/**
|
|
4
|
+
* @name members
|
|
5
|
+
* @description Retrieves the list of members in the "council" collective.
|
|
6
|
+
* @example
|
|
7
|
+
* ```javascript
|
|
8
|
+
* const members = await api.derive.council.members();
|
|
9
|
+
* console.log(`Members: ${JSON.stringify(members)});
|
|
10
|
+
* ```
|
|
11
|
+
*/
|
|
12
|
+
export declare const members: import("../collective/types.js").MembersFnRet;
|
|
13
|
+
/**
|
|
14
|
+
* @name hasProposals
|
|
15
|
+
* @description Checks if there are any active proposals in the "council" collective.
|
|
16
|
+
* @example
|
|
17
|
+
* ```javascript
|
|
18
|
+
* const exists = await api.derive.council.hasProposals();
|
|
19
|
+
* console.log(exists);
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
export declare const hasProposals: import("../collective/types.js").HasProposalsFnRet;
|
|
23
|
+
/**
|
|
24
|
+
* @name proposal
|
|
25
|
+
* @description Retrieves details of a specific proposal in the "councilMotion" collective by its hash.
|
|
26
|
+
* @example
|
|
27
|
+
* ```javascript
|
|
28
|
+
* const proposalDetails = await api.derive.council.proposal(PROPOSAL_HASH);
|
|
29
|
+
* console.log(proposalDetails);
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export declare const proposal: import("../collective/types.js").ProposalFnRet;
|
|
33
|
+
/**
|
|
34
|
+
* @name proposalCount
|
|
35
|
+
* @description Retrieves the total number of proposals in the "council" collective.
|
|
36
|
+
* @example
|
|
37
|
+
* ```javascript
|
|
38
|
+
* const count = await api.derive.council.proposalCount();
|
|
39
|
+
* console.log(`Amount of proposals: ${count}`);
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
export declare const proposalCount: import("../collective/types.js").ProposalCountFnRet;
|
|
43
|
+
/**
|
|
44
|
+
* @name proposalHashes
|
|
45
|
+
* @description Retrieves an array of hashes for all active proposals in the "council" collective.
|
|
46
|
+
* @example
|
|
47
|
+
* ```javascript
|
|
48
|
+
* const hashes = await api.derive.council.proposalHashes();
|
|
49
|
+
* console.log(`Proposals ${JSON.stringify(hashes)}`);
|
|
50
|
+
* ```
|
|
51
|
+
*/
|
|
52
|
+
export declare const proposalHashes: import("../collective/types.js").ProposalHashesFnRet;
|
|
53
|
+
/**
|
|
54
|
+
* @name proposals
|
|
55
|
+
* @description Retrieves a list of all active proposals in the "council" collective.
|
|
56
|
+
* @example
|
|
57
|
+
* ```javascript
|
|
58
|
+
* const proposals = await api.derive.council.proposals();
|
|
59
|
+
* console.log(proposals);
|
|
60
|
+
* ```
|
|
61
|
+
*/
|
|
62
|
+
export declare const proposals: import("../collective/types.js").ProposalsFnRet;
|
|
63
|
+
/**
|
|
64
|
+
* @name prime
|
|
65
|
+
* @description Retrieves the prime member of the "council" collective, if one exists.
|
|
66
|
+
* @example
|
|
67
|
+
* ```javascript
|
|
68
|
+
* const primeMember = await api.derive.council.prime();
|
|
69
|
+
* console.log(primeMember);
|
|
70
|
+
* ```
|
|
71
|
+
*/
|
|
72
|
+
export declare const prime: import("../collective/types.js").PrimeFnRet;
|
|
@@ -1,11 +1,6 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
1
|
import { hasProposals as collectiveHasProposals, members as collectiveMembers, prime as collectivePrime, proposal as collectiveProposal, proposalCount as collectiveProposalCount, proposalHashes as collectiveProposalHashes, proposals as collectiveProposals } from '../collective/index.js';
|
|
5
|
-
|
|
6
2
|
export * from './votes.js';
|
|
7
3
|
export * from './votesOf.js';
|
|
8
|
-
|
|
9
4
|
/**
|
|
10
5
|
* @name members
|
|
11
6
|
* @description Retrieves the list of members in the "council" collective.
|
|
@@ -16,7 +11,6 @@ export * from './votesOf.js';
|
|
|
16
11
|
* ```
|
|
17
12
|
*/
|
|
18
13
|
export const members = /*#__PURE__*/ collectiveMembers('council');
|
|
19
|
-
|
|
20
14
|
/**
|
|
21
15
|
* @name hasProposals
|
|
22
16
|
* @description Checks if there are any active proposals in the "council" collective.
|
|
@@ -1,11 +1,6 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
1
|
import type { AccountId, Balance } from '@pezkuwi/types/interfaces';
|
|
5
|
-
|
|
6
2
|
export interface DeriveCouncilVote {
|
|
7
|
-
|
|
8
|
-
|
|
3
|
+
stake: Balance;
|
|
4
|
+
votes: AccountId[];
|
|
9
5
|
}
|
|
10
|
-
|
|
11
6
|
export type DeriveCouncilVotes = [AccountId, DeriveCouncilVote][];
|
package/council/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Observable } from 'rxjs';
|
|
2
|
+
import type { DeriveApi, DeriveCouncilVotes } from '../types.js';
|
|
3
|
+
/**
|
|
4
|
+
* @name votes
|
|
5
|
+
* @description Retrieves the council election votes for all participants.
|
|
6
|
+
* @example
|
|
7
|
+
* ```javascript
|
|
8
|
+
* const votes = await api.derive.council.votes();
|
|
9
|
+
* ```
|
|
10
|
+
*/
|
|
11
|
+
export declare function votes(instanceId: string, api: DeriveApi): () => Observable<DeriveCouncilVotes>;
|
package/council/votes.js
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { combineLatest, map, of } from 'rxjs';
|
|
2
|
+
import { memo } from '../util/index.js';
|
|
3
|
+
function isVoter(value) {
|
|
4
|
+
return !Array.isArray(value);
|
|
5
|
+
}
|
|
6
|
+
function retrieveStakeOf(elections) {
|
|
7
|
+
return elections['stakeOf'].entries().pipe(map((entries) => entries.map(([{ args: [accountId] }, stake]) => [accountId, stake])));
|
|
8
|
+
}
|
|
9
|
+
function retrieveVoteOf(elections) {
|
|
10
|
+
return elections['votesOf'].entries().pipe(map((entries) => entries.map(([{ args: [accountId] }, votes]) => [accountId, votes])));
|
|
11
|
+
}
|
|
12
|
+
function retrievePrev(api, elections) {
|
|
13
|
+
return combineLatest([
|
|
14
|
+
retrieveStakeOf(elections),
|
|
15
|
+
retrieveVoteOf(elections)
|
|
16
|
+
]).pipe(map(([stakes, votes]) => {
|
|
17
|
+
const result = [];
|
|
18
|
+
votes.forEach(([voter, votes]) => {
|
|
19
|
+
result.push([voter, { stake: api.registry.createType('Balance'), votes }]);
|
|
20
|
+
});
|
|
21
|
+
stakes.forEach(([staker, stake]) => {
|
|
22
|
+
const entry = result.find(([voter]) => voter.eq(staker));
|
|
23
|
+
if (entry) {
|
|
24
|
+
entry[1].stake = stake;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
result.push([staker, { stake, votes: [] }]);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
return result;
|
|
31
|
+
}));
|
|
32
|
+
}
|
|
33
|
+
function retrieveCurrent(elections) {
|
|
34
|
+
return elections.voting.entries().pipe(map((entries) => entries.map(([{ args: [accountId] }, value]) => [
|
|
35
|
+
accountId,
|
|
36
|
+
isVoter(value)
|
|
37
|
+
? { stake: value.stake, votes: value.votes }
|
|
38
|
+
: { stake: value[0], votes: value[1] }
|
|
39
|
+
])));
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* @name votes
|
|
43
|
+
* @description Retrieves the council election votes for all participants.
|
|
44
|
+
* @example
|
|
45
|
+
* ```javascript
|
|
46
|
+
* const votes = await api.derive.council.votes();
|
|
47
|
+
* ```
|
|
48
|
+
*/
|
|
49
|
+
export function votes(instanceId, api) {
|
|
50
|
+
const elections = api.query.elections || api.query['phragmenElection'] || api.query['electionsPhragmen'];
|
|
51
|
+
return memo(instanceId, () => elections
|
|
52
|
+
? elections['stakeOf']
|
|
53
|
+
? retrievePrev(api, elections)
|
|
54
|
+
: retrieveCurrent(elections)
|
|
55
|
+
: of([]));
|
|
56
|
+
}
|