@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,23 @@
|
|
|
1
|
+
const mapCache = new Map();
|
|
2
|
+
export const deriveMapCache = {
|
|
3
|
+
del: (key) => {
|
|
4
|
+
mapCache.delete(key);
|
|
5
|
+
},
|
|
6
|
+
forEach: (cb) => {
|
|
7
|
+
for (const [k, v] of mapCache.entries()) {
|
|
8
|
+
cb(k, v);
|
|
9
|
+
}
|
|
10
|
+
},
|
|
11
|
+
get: (key) => {
|
|
12
|
+
return mapCache.get(key);
|
|
13
|
+
},
|
|
14
|
+
set: (key, value) => {
|
|
15
|
+
mapCache.set(key, value);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
export const deriveNoopCache = {
|
|
19
|
+
del: () => undefined,
|
|
20
|
+
forEach: () => undefined,
|
|
21
|
+
get: () => undefined,
|
|
22
|
+
set: (_, value) => value
|
|
23
|
+
};
|
package/util/first.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Observable } from 'rxjs';
|
|
2
|
+
import type { DeriveApi } from '../types.js';
|
|
3
|
+
export declare function firstObservable<T>(obs: Observable<T[]>): Observable<T>;
|
|
4
|
+
export declare function firstMemo<T, A extends any[]>(fn: (api: DeriveApi, ...args: A) => Observable<T[]>): (instanceId: string, api: DeriveApi) => (...args: A) => Observable<T>;
|
package/util/first.js
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { map } from 'rxjs';
|
|
2
|
+
import { memo } from '@pezkuwi/rpc-core';
|
|
3
|
+
export function firstObservable(obs) {
|
|
4
|
+
return obs.pipe(map(([a]) => a));
|
|
5
|
+
}
|
|
6
|
+
export function firstMemo(fn) {
|
|
7
|
+
return (instanceId, api) => memo(instanceId, (...args) => firstObservable(fn(api, ...args)));
|
|
8
|
+
}
|
|
@@ -1,10 +1,4 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
|
-
// all named
|
|
5
1
|
export { drr, memo } from '@pezkuwi/rpc-core';
|
|
6
|
-
|
|
7
|
-
// all starred
|
|
8
2
|
export * from './approvalFlagsToBools.js';
|
|
9
3
|
export * from './blockNumber.js';
|
|
10
4
|
export * from './cache.js';
|
package/util/index.js
ADDED
package/util/lazy.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
type LazySection<T> = Record<string, T>;
|
|
2
|
+
type LazyRecord<T> = Record<string, LazySection<T>>;
|
|
3
|
+
export declare function lazyDeriveSection<T>(result: LazyRecord<T>, section: string, getKeys: (s: string) => string[], creator: (s: string, m: string) => T): void;
|
|
4
|
+
export {};
|
package/util/lazy.js
ADDED
package/util/types.d.ts
ADDED
package/util/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { Observable } from 'rxjs';
|
|
2
|
-
import type { PalletBagsListListBag, PalletBagsListListNode } from '@pezkuwi/types/lookup';
|
|
3
|
-
import type { DeriveApi } from '../types.js';
|
|
4
|
-
/**
|
|
5
|
-
* @name listNodes
|
|
6
|
-
* @param {(PalletBagsListListBag | null)} bag A reference to a specific bag in the BagsList pallet.
|
|
7
|
-
* @description Retrieves the list of nodes (accounts) contained in a specific bag within the BagsList pallet.
|
|
8
|
-
*/
|
|
9
|
-
export declare function listNodes(instanceId: string, api: DeriveApi): (bag: PalletBagsListListBag | null) => Observable<PalletBagsListListNode[]>;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import type { Observable } from 'rxjs';
|
|
2
|
-
import type { DeriveApi, DeriveParachain } from '../types.js';
|
|
3
|
-
/**
|
|
4
|
-
* @name overview
|
|
5
|
-
* @description Retrieves an overview of all registered parachains.
|
|
6
|
-
* @example
|
|
7
|
-
* ```javascript
|
|
8
|
-
* await api.derive.parachains.overview((overview) => {
|
|
9
|
-
* parachains.forEach(parachain => {
|
|
10
|
-
* console.log(`Parachain ${parachain.id.toString()} is registered.`);
|
|
11
|
-
* });
|
|
12
|
-
* });
|
|
13
|
-
* ```
|
|
14
|
-
*/
|
|
15
|
-
export declare function overview(instanceId: string, api: DeriveApi): () => Observable<DeriveParachain[]>;
|
|
@@ -1,44 +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, AccountIndex, Address } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type { DeriveApi } from '../types.js';
|
|
7
|
-
|
|
8
|
-
import { map, of } from 'rxjs';
|
|
9
|
-
|
|
10
|
-
import { assertReturn, isU8a } from '@pezkuwi/util';
|
|
11
|
-
import { decodeAddress } from '@pezkuwi/util-crypto';
|
|
12
|
-
|
|
13
|
-
import { memo } from '../util/index.js';
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* @name accountId
|
|
17
|
-
* @param {(Address | AccountId | AccountIndex | string | null)} address An accounts address in various formats.
|
|
18
|
-
* @description Resolves an address (in different formats) to its corresponding `AccountId`.
|
|
19
|
-
* @example
|
|
20
|
-
* ```javascript
|
|
21
|
-
* const ALICE = "F7Hs";
|
|
22
|
-
*
|
|
23
|
-
* api.derive.accounts.accountId(ALICE, (accountId) => {
|
|
24
|
-
* console.log(`Resolved AccountId: ${accountId}`);
|
|
25
|
-
* });
|
|
26
|
-
* ```
|
|
27
|
-
*/
|
|
28
|
-
export function accountId (instanceId: string, api: DeriveApi): (address?: Address | AccountId | AccountIndex | string | null) => Observable<AccountId> {
|
|
29
|
-
return memo(instanceId, (address?: Address | AccountId | AccountIndex | string | null): Observable<AccountId> => {
|
|
30
|
-
const decoded = isU8a(address)
|
|
31
|
-
? address
|
|
32
|
-
: decodeAddress((address || '').toString());
|
|
33
|
-
|
|
34
|
-
if (decoded.length > 8) {
|
|
35
|
-
return of(api.registry.createType(decoded.length === 20 ? 'AccountId20' : 'AccountId', decoded));
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const accountIndex = api.registry.createType('AccountIndex', decoded);
|
|
39
|
-
|
|
40
|
-
return api.derive.accounts.indexToId(accountIndex.toString()).pipe(
|
|
41
|
-
map((a) => assertReturn(a, 'Unable to retrieve accountId'))
|
|
42
|
-
);
|
|
43
|
-
});
|
|
44
|
-
}
|
package/src/accounts/flags.ts
DELETED
|
@@ -1,90 +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, Address, Balance } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type{ PalletElectionsPhragmenSeatHolder } from '@pezkuwi/types/lookup';
|
|
7
|
-
import type { Codec } from '@pezkuwi/types/types';
|
|
8
|
-
import type { Option } from '@pezkuwi/types-codec';
|
|
9
|
-
import type { DeriveAccountFlags, DeriveApi } from '../types.js';
|
|
10
|
-
|
|
11
|
-
import { map, of } from 'rxjs';
|
|
12
|
-
|
|
13
|
-
import { isFunction } from '@pezkuwi/util';
|
|
14
|
-
|
|
15
|
-
import { memo } from '../util/index.js';
|
|
16
|
-
|
|
17
|
-
type FlagsIntermediate = [
|
|
18
|
-
PalletElectionsPhragmenSeatHolder[] | [AccountId, Balance][] | undefined,
|
|
19
|
-
AccountId[],
|
|
20
|
-
AccountId[],
|
|
21
|
-
AccountId[],
|
|
22
|
-
Option<AccountId> | AccountId | undefined
|
|
23
|
-
];
|
|
24
|
-
|
|
25
|
-
function parseFlags (address: AccountId | Address | string | null | undefined, [electionsMembers, councilMembers, technicalCommitteeMembers, societyMembers, sudoKey]: FlagsIntermediate): DeriveAccountFlags {
|
|
26
|
-
const addrStr = address?.toString();
|
|
27
|
-
const isIncluded = (id: AccountId | Address | string) =>
|
|
28
|
-
id.toString() === addrStr;
|
|
29
|
-
|
|
30
|
-
return {
|
|
31
|
-
isCouncil: (electionsMembers?.map((r) => Array.isArray(r) ? r[0] : r.who) || councilMembers || []).some(isIncluded),
|
|
32
|
-
isSociety: (societyMembers || []).some(isIncluded),
|
|
33
|
-
isSudo: sudoKey?.toString() === addrStr,
|
|
34
|
-
isTechCommittee: (technicalCommitteeMembers || []).some(isIncluded)
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
export function _flags (instanceId: string, api: DeriveApi): () => Observable<FlagsIntermediate> {
|
|
39
|
-
return memo(instanceId, (): Observable<FlagsIntermediate> => {
|
|
40
|
-
const results: unknown[] = [undefined, [], [], [], undefined];
|
|
41
|
-
const calls = [
|
|
42
|
-
(api.query.elections || api.query['phragmenElection'] || api.query['electionsPhragmen'])?.members,
|
|
43
|
-
api.query.council?.members,
|
|
44
|
-
api.query.technicalCommittee?.members,
|
|
45
|
-
api.query.society?.members,
|
|
46
|
-
api.query.sudo?.key
|
|
47
|
-
];
|
|
48
|
-
const filtered = calls.filter((c) => c);
|
|
49
|
-
|
|
50
|
-
if (!filtered.length) {
|
|
51
|
-
return of(results as FlagsIntermediate);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
return api.queryMulti(filtered).pipe(
|
|
55
|
-
map((values: Codec[]): FlagsIntermediate => {
|
|
56
|
-
let resultIndex = -1;
|
|
57
|
-
|
|
58
|
-
for (let i = 0, count = calls.length; i < count; i++) {
|
|
59
|
-
if (isFunction(calls[i])) {
|
|
60
|
-
results[i] = values[++resultIndex];
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
return results as FlagsIntermediate;
|
|
65
|
-
})
|
|
66
|
-
);
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* @name flags
|
|
72
|
-
* @param {(AccountId | Address | string | null)} address The account identifier.
|
|
73
|
-
* @description Retrieves the membership flags for a given account.
|
|
74
|
-
* @example
|
|
75
|
-
* const ALICE = "F7Hs";
|
|
76
|
-
*
|
|
77
|
-
* api.derive.accounts.flags(ALICE, (flags) => {
|
|
78
|
-
* console.log(
|
|
79
|
-
* `Account Flags:`,
|
|
80
|
-
* Object.keys(flags).map((flag) => `${flag}: ${flags[flag]}`)
|
|
81
|
-
* );
|
|
82
|
-
* });
|
|
83
|
-
*/
|
|
84
|
-
export function flags (instanceId: string, api: DeriveApi): (address?: AccountId | Address | string | null) => Observable<DeriveAccountFlags> {
|
|
85
|
-
return memo(instanceId, (address?: AccountId | Address | string | null): Observable<DeriveAccountFlags> =>
|
|
86
|
-
api.derive.accounts._flags().pipe(
|
|
87
|
-
map((r) => parseFlags(address, r))
|
|
88
|
-
)
|
|
89
|
-
);
|
|
90
|
-
}
|
|
@@ -1,51 +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, AccountIndex, Address } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type { AccountIdAndIndex, DeriveApi } from '../types.js';
|
|
7
|
-
|
|
8
|
-
import { map, of } from 'rxjs';
|
|
9
|
-
|
|
10
|
-
import { isU8a } from '@pezkuwi/util';
|
|
11
|
-
import { decodeAddress } from '@pezkuwi/util-crypto';
|
|
12
|
-
|
|
13
|
-
import { memo } from '../util/index.js';
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* @name idAndIndex
|
|
17
|
-
* @param {(Address | AccountId | AccountIndex | Uint8Array | string | null)} address An accounts address in various formats.
|
|
18
|
-
* @description An array containing the [[AccountId]] and [[AccountIndex]] as optional values.
|
|
19
|
-
* @example
|
|
20
|
-
* ```javascript
|
|
21
|
-
* api.derive.accounts.idAndIndex('F7Hs', ([id, ix]) => {
|
|
22
|
-
* console.log(`AccountId #${id} with corresponding AccountIndex ${ix}`);
|
|
23
|
-
* });
|
|
24
|
-
* ```
|
|
25
|
-
*/
|
|
26
|
-
export function idAndIndex (instanceId: string, api: DeriveApi): (address?: Address | AccountId | AccountIndex | Uint8Array | string | null) => Observable<AccountIdAndIndex> {
|
|
27
|
-
return memo(instanceId, (address?: Address | AccountId | AccountIndex | Uint8Array | string | null): Observable<AccountIdAndIndex> => {
|
|
28
|
-
try {
|
|
29
|
-
// yes, this can fail, don't care too much, catch will catch it
|
|
30
|
-
const decoded = isU8a(address)
|
|
31
|
-
? address
|
|
32
|
-
: decodeAddress((address || '').toString());
|
|
33
|
-
|
|
34
|
-
if (decoded.length > 8) {
|
|
35
|
-
const accountId = api.registry.createType(decoded.length === 20 ? 'AccountId20' : 'AccountId', decoded);
|
|
36
|
-
|
|
37
|
-
return api.derive.accounts.idToIndex(accountId).pipe(
|
|
38
|
-
map((accountIndex): AccountIdAndIndex => [accountId, accountIndex])
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
const accountIndex = api.registry.createType('AccountIndex', decoded);
|
|
43
|
-
|
|
44
|
-
return api.derive.accounts.indexToId(accountIndex.toString()).pipe(
|
|
45
|
-
map((accountId): AccountIdAndIndex => [accountId, accountIndex])
|
|
46
|
-
);
|
|
47
|
-
} catch {
|
|
48
|
-
return of([undefined, undefined]);
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
}
|
|
@@ -1,31 +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, AccountIndex } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type { AccountIndexes, DeriveApi } from '../types.js';
|
|
7
|
-
|
|
8
|
-
import { map } from 'rxjs';
|
|
9
|
-
|
|
10
|
-
import { memo } from '../util/index.js';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* @name idToIndex
|
|
14
|
-
* @description Retrieves the corresponding AccountIndex.
|
|
15
|
-
* @param {( AccountId | string )} accountId An accounts Id in different formats.
|
|
16
|
-
* @example
|
|
17
|
-
* ```javascript
|
|
18
|
-
* const ALICE = '5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY';
|
|
19
|
-
* api.derive.accounts.idToIndex(ALICE, (accountIndex) => {
|
|
20
|
-
* console.log(`The AccountIndex of ${ALICE} is ${accountIndex}`);
|
|
21
|
-
* });
|
|
22
|
-
* ```
|
|
23
|
-
*/
|
|
24
|
-
export function idToIndex (instanceId: string, api: DeriveApi): (accountId: AccountId | string) => Observable<AccountIndex | undefined> {
|
|
25
|
-
return memo(instanceId, (accountId: AccountId | string): Observable<AccountIndex | undefined> =>
|
|
26
|
-
api.derive.accounts.indexes().pipe(
|
|
27
|
-
map((indexes: AccountIndexes): AccountIndex | undefined =>
|
|
28
|
-
indexes[accountId.toString()]
|
|
29
|
-
)
|
|
30
|
-
));
|
|
31
|
-
}
|
package/src/accounts/identity.ts
DELETED
|
@@ -1,235 +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 { Bytes, Data, Struct } from '@pezkuwi/types';
|
|
6
|
-
import type { AccountId, H160 } from '@pezkuwi/types/interfaces';
|
|
7
|
-
import type { PalletIdentityLegacyIdentityInfo, PalletIdentityRegistration } from '@pezkuwi/types/lookup';
|
|
8
|
-
import type { Option } from '@pezkuwi/types-codec';
|
|
9
|
-
import type { ITuple } from '@pezkuwi/types-codec/types';
|
|
10
|
-
import type { DeriveAccountRegistration, DeriveApi, DeriveHasIdentity } from '../types.js';
|
|
11
|
-
|
|
12
|
-
import { combineLatest, map, of, switchMap } from 'rxjs';
|
|
13
|
-
|
|
14
|
-
import { isHex, u8aToString } from '@pezkuwi/util';
|
|
15
|
-
|
|
16
|
-
import { firstMemo, memo } from '../util/index.js';
|
|
17
|
-
|
|
18
|
-
type IdentityInfoAdditional = PalletIdentityLegacyIdentityInfo['additional'][0];
|
|
19
|
-
|
|
20
|
-
interface PeopleIdentityInfo extends Struct {
|
|
21
|
-
display: Data;
|
|
22
|
-
legal: Data;
|
|
23
|
-
web: Data;
|
|
24
|
-
matrix: Data;
|
|
25
|
-
email: Data;
|
|
26
|
-
pgpFingerprint: Option<H160>;
|
|
27
|
-
image: Data;
|
|
28
|
-
twitter: Data;
|
|
29
|
-
github: Data;
|
|
30
|
-
discord: Data;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
const UNDEF_HEX = { toHex: () => undefined };
|
|
34
|
-
|
|
35
|
-
function dataAsString (data: Data): string | undefined {
|
|
36
|
-
if (!data) {
|
|
37
|
-
return data;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return data.isRaw
|
|
41
|
-
? u8aToString(data.asRaw.toU8a(true))
|
|
42
|
-
: data.isNone
|
|
43
|
-
? undefined
|
|
44
|
-
: data.toHex();
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
function extractOther (additional: IdentityInfoAdditional[]): Record<string, string> {
|
|
48
|
-
return additional.reduce((other: Record<string, string>, [_key, _value]): Record<string, string> => {
|
|
49
|
-
const key = dataAsString(_key);
|
|
50
|
-
const value = dataAsString(_value);
|
|
51
|
-
|
|
52
|
-
if (key && value) {
|
|
53
|
-
other[key] = value;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return other;
|
|
57
|
-
}, {});
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
// handle compatibility between generations of structures
|
|
61
|
-
function identityCompat (identityOfOpt: Option<ITuple<[PalletIdentityRegistration, Option<Bytes>]>> | Option<PalletIdentityRegistration>): PalletIdentityRegistration {
|
|
62
|
-
const identity = identityOfOpt.unwrap();
|
|
63
|
-
|
|
64
|
-
return Array.isArray(identity)
|
|
65
|
-
? identity[0]
|
|
66
|
-
: identity;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
function extractIdentity (identityOfOpt?: Option<ITuple<[PalletIdentityRegistration, Option<Bytes>]>> | Option<PalletIdentityRegistration>, superOf?: [AccountId, Data]): DeriveAccountRegistration {
|
|
70
|
-
if (!identityOfOpt?.isSome) {
|
|
71
|
-
return { judgements: [] };
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
const { info, judgements } = identityCompat(identityOfOpt);
|
|
75
|
-
const topDisplay = dataAsString(info.display);
|
|
76
|
-
|
|
77
|
-
return {
|
|
78
|
-
discord: dataAsString((info as unknown as PeopleIdentityInfo).discord),
|
|
79
|
-
display: (superOf && dataAsString(superOf[1])) || topDisplay,
|
|
80
|
-
displayParent: superOf && topDisplay,
|
|
81
|
-
email: dataAsString(info.email),
|
|
82
|
-
github: dataAsString((info as unknown as PeopleIdentityInfo).github),
|
|
83
|
-
image: dataAsString(info.image),
|
|
84
|
-
judgements,
|
|
85
|
-
legal: dataAsString(info.legal),
|
|
86
|
-
matrix: dataAsString((info as unknown as PeopleIdentityInfo).matrix),
|
|
87
|
-
other: info.additional ? extractOther(info.additional) : {},
|
|
88
|
-
parent: superOf?.[0],
|
|
89
|
-
pgp: info.pgpFingerprint.unwrapOr(UNDEF_HEX).toHex(),
|
|
90
|
-
riot: dataAsString(info.riot),
|
|
91
|
-
twitter: dataAsString(info.twitter),
|
|
92
|
-
web: dataAsString(info.web)
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
function getParent (api: DeriveApi, identityOfOpt: Option<ITuple<[PalletIdentityRegistration, Option<Bytes>]>> | Option<PalletIdentityRegistration> | undefined, superOfOpt: Option<ITuple<[AccountId, Data]>> | undefined): Observable<[Option<ITuple<[PalletIdentityRegistration, Option<Bytes>]>> | Option<PalletIdentityRegistration> | undefined, [AccountId, Data] | undefined]> {
|
|
97
|
-
if (identityOfOpt?.isSome) {
|
|
98
|
-
// this identity has something set
|
|
99
|
-
return of([identityOfOpt, undefined]);
|
|
100
|
-
} else if (superOfOpt?.isSome) {
|
|
101
|
-
const superOf = superOfOpt.unwrap();
|
|
102
|
-
|
|
103
|
-
return combineLatest([
|
|
104
|
-
api.derive.accounts._identity(superOf[0]).pipe(
|
|
105
|
-
map(([info]) => info)
|
|
106
|
-
),
|
|
107
|
-
of(superOf)
|
|
108
|
-
]);
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
// nothing of value returned
|
|
112
|
-
return of([undefined, undefined]);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
export function _identity (instanceId: string, api: DeriveApi): (accountId?: AccountId | Uint8Array | string) => Observable<[Option<ITuple<[PalletIdentityRegistration, Option<Bytes>]>> | Option<PalletIdentityRegistration> | undefined, Option<ITuple<[AccountId, Data]>> | undefined]> {
|
|
116
|
-
return memo(instanceId, (accountId?: AccountId | Uint8Array | string): Observable<[Option<ITuple<[PalletIdentityRegistration, Option<Bytes>]>> | Option<PalletIdentityRegistration> | undefined, Option<ITuple<[AccountId, Data]>> | undefined]> =>
|
|
117
|
-
accountId && api.query.identity?.identityOf
|
|
118
|
-
? combineLatest([
|
|
119
|
-
api.query.identity.identityOf(accountId),
|
|
120
|
-
api.query.identity.superOf(accountId)
|
|
121
|
-
])
|
|
122
|
-
: of([undefined, undefined])
|
|
123
|
-
);
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* @name identity
|
|
128
|
-
* @description Retrieves the on chain identity information for a given account.
|
|
129
|
-
* @param {(AccountId | Uint8Array | string)} accoutId The account identifier to query the identity for.
|
|
130
|
-
* @example
|
|
131
|
-
* ```javascript
|
|
132
|
-
* const ALICE = "13xAUH";
|
|
133
|
-
*
|
|
134
|
-
* api.derive.accounts.identity(ALICE, (identity) => {
|
|
135
|
-
* console.log(
|
|
136
|
-
* "Account Identity:",
|
|
137
|
-
* Object.keys(identity).map((key) => `${key}: ${identity[key]}`)
|
|
138
|
-
* );
|
|
139
|
-
* });
|
|
140
|
-
* ```
|
|
141
|
-
*/
|
|
142
|
-
export function identity (instanceId: string, api: DeriveApi): (accountId?: AccountId | Uint8Array | string) => Observable<DeriveAccountRegistration> {
|
|
143
|
-
return memo(instanceId, (accountId?: AccountId | Uint8Array | string): Observable<DeriveAccountRegistration> =>
|
|
144
|
-
api.derive.accounts._identity(accountId).pipe(
|
|
145
|
-
switchMap(([identityOfOpt, superOfOpt]) =>
|
|
146
|
-
getParent(api, identityOfOpt, superOfOpt)
|
|
147
|
-
),
|
|
148
|
-
map(([identityOfOpt, superOf]) =>
|
|
149
|
-
extractIdentity(identityOfOpt, superOf)
|
|
150
|
-
),
|
|
151
|
-
switchMap((identity) =>
|
|
152
|
-
getSubIdentities(identity, api, accountId)
|
|
153
|
-
)
|
|
154
|
-
)
|
|
155
|
-
);
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
// if an account has no parents it will extract its subidentities
|
|
159
|
-
// otherwise if the account is a subidentity, obtain all subidentities of its parent.
|
|
160
|
-
function getSubIdentities (identity: DeriveAccountRegistration, api: DeriveApi, accountId?: AccountId | Uint8Array | string): Observable<DeriveAccountRegistration> {
|
|
161
|
-
const targetAccount = identity.parent || accountId;
|
|
162
|
-
|
|
163
|
-
if (!targetAccount || !api.query.identity) {
|
|
164
|
-
// No valid accountId return the identity as-is
|
|
165
|
-
return of(identity);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
return api.query.identity.subsOf(targetAccount).pipe(
|
|
169
|
-
map((subsResponse) => {
|
|
170
|
-
const subs = subsResponse[1];
|
|
171
|
-
|
|
172
|
-
return {
|
|
173
|
-
...identity,
|
|
174
|
-
subs
|
|
175
|
-
};
|
|
176
|
-
})
|
|
177
|
-
);
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
/**
|
|
181
|
-
* @name hasIdentity
|
|
182
|
-
* @description Checks if a specific account has an identity registered on chain.
|
|
183
|
-
* @param {(AccountId | Uint8Array | string)} accoutId The account identifier to query.
|
|
184
|
-
* @example
|
|
185
|
-
* ```javascript
|
|
186
|
-
* const ALICE = "13AU";
|
|
187
|
-
* console.log(await api.derive.accounts.hasIdentity(ALICE));
|
|
188
|
-
* ```
|
|
189
|
-
*/
|
|
190
|
-
export const hasIdentity = /*#__PURE__*/ firstMemo(
|
|
191
|
-
(api: DeriveApi, accountId: AccountId | Uint8Array | string) =>
|
|
192
|
-
api.derive.accounts.hasIdentityMulti([accountId])
|
|
193
|
-
);
|
|
194
|
-
|
|
195
|
-
/**
|
|
196
|
-
* @name hasIdentityMulti
|
|
197
|
-
* @description Checks whether multiple accounts have on chain identities registered.
|
|
198
|
-
* @param {(AccountId | Uint8Array | string)[]} accountIds Array of account identifiers to query.
|
|
199
|
-
* @example
|
|
200
|
-
* ```javascript
|
|
201
|
-
* const ALICE = "13AU";
|
|
202
|
-
* const BOB = "16WW";
|
|
203
|
-
* console.log(await api.derive.accounts.hasIdentityMulti([ALICE, BOB]));
|
|
204
|
-
* ```
|
|
205
|
-
*/
|
|
206
|
-
export function hasIdentityMulti (instanceId: string, api: DeriveApi): (accountIds: (AccountId | Uint8Array | string)[]) => Observable<DeriveHasIdentity[]> {
|
|
207
|
-
return memo(instanceId, (accountIds: (AccountId | Uint8Array | string)[]): Observable<DeriveHasIdentity[]> =>
|
|
208
|
-
api.query.identity?.identityOf
|
|
209
|
-
? combineLatest([
|
|
210
|
-
api.query.identity.identityOf.multi(accountIds),
|
|
211
|
-
api.query.identity.superOf.multi(accountIds)
|
|
212
|
-
]).pipe(
|
|
213
|
-
map(([identities, supers]) =>
|
|
214
|
-
identities.map((identityOfOpt, index): DeriveHasIdentity => {
|
|
215
|
-
const superOfOpt = supers[index];
|
|
216
|
-
const parentId = superOfOpt && superOfOpt.isSome
|
|
217
|
-
? superOfOpt.unwrap()[0].toString()
|
|
218
|
-
: undefined;
|
|
219
|
-
let display: string | undefined;
|
|
220
|
-
|
|
221
|
-
if (identityOfOpt && identityOfOpt.isSome) {
|
|
222
|
-
const value = dataAsString(identityCompat(identityOfOpt).info.display);
|
|
223
|
-
|
|
224
|
-
if (value && !isHex(value)) {
|
|
225
|
-
display = value;
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
return { display, hasIdentity: !!(display || parentId), parentId };
|
|
230
|
-
})
|
|
231
|
-
)
|
|
232
|
-
)
|
|
233
|
-
: of(accountIds.map(() => ({ hasIdentity: false })))
|
|
234
|
-
);
|
|
235
|
-
}
|
|
@@ -1,33 +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, AccountIndex } from '@pezkuwi/types/interfaces';
|
|
6
|
-
import type { DeriveApi } from '../types.js';
|
|
7
|
-
|
|
8
|
-
import { map, of } from 'rxjs';
|
|
9
|
-
|
|
10
|
-
import { memo } from '../util/index.js';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* @name indexToId
|
|
14
|
-
* @description Resolves an AccountIndex (short address) to the full AccountId.
|
|
15
|
-
* @param {( AccountIndex | string )} accountIndex An accounts index in different formats.
|
|
16
|
-
* @example
|
|
17
|
-
* ```javascript
|
|
18
|
-
* const ALICE = "13AU";
|
|
19
|
-
* const id = await api.derive.accounts.indexToId(ALICE);
|
|
20
|
-
* console.log(id);
|
|
21
|
-
* ```
|
|
22
|
-
*/
|
|
23
|
-
export function indexToId (instanceId: string, api: DeriveApi): (accountIndex: AccountIndex | string) => Observable<AccountId | undefined> {
|
|
24
|
-
return memo(instanceId, (accountIndex: AccountIndex | string): Observable<AccountId | undefined> =>
|
|
25
|
-
api.query.indices
|
|
26
|
-
? api.query.indices.accounts(accountIndex).pipe(
|
|
27
|
-
map((optResult): AccountId | undefined =>
|
|
28
|
-
optResult.unwrapOr([])[0]
|
|
29
|
-
)
|
|
30
|
-
)
|
|
31
|
-
: of(undefined)
|
|
32
|
-
);
|
|
33
|
-
}
|
package/src/accounts/indexes.ts
DELETED
|
@@ -1,56 +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 { AccountIndexes, DeriveApi } from '../types.js';
|
|
6
|
-
|
|
7
|
-
import { map, of, startWith } from 'rxjs';
|
|
8
|
-
|
|
9
|
-
import { memo } from '../util/index.js';
|
|
10
|
-
|
|
11
|
-
let indicesCache: AccountIndexes | null = null;
|
|
12
|
-
|
|
13
|
-
function queryAccounts (api: DeriveApi): Observable<AccountIndexes> {
|
|
14
|
-
return api.query.indices.accounts.entries().pipe(
|
|
15
|
-
map((entries): AccountIndexes =>
|
|
16
|
-
entries.reduce((indexes: AccountIndexes, [key, idOpt]): AccountIndexes => {
|
|
17
|
-
if (idOpt.isSome) {
|
|
18
|
-
indexes[idOpt.unwrap()[0].toString()] = api.registry.createType('AccountIndex', key.args[0]);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
return indexes;
|
|
22
|
-
}, {})
|
|
23
|
-
)
|
|
24
|
-
);
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* @name indexes
|
|
29
|
-
* @returns Returns all the indexes on the system.
|
|
30
|
-
* @description This is an unwieldly query since it loops through
|
|
31
|
-
* all of the enumsets and returns all of the values found. This could be up to 32k depending
|
|
32
|
-
* on the number of active accounts in the system.
|
|
33
|
-
* @example
|
|
34
|
-
* ```javascript
|
|
35
|
-
* api.derive.accounts.indexes((indexes) => {
|
|
36
|
-
* console.log('All existing AccountIndexes', indexes);
|
|
37
|
-
* });
|
|
38
|
-
* ```
|
|
39
|
-
*/
|
|
40
|
-
export function indexes (instanceId: string, api: DeriveApi): () => Observable<AccountIndexes> {
|
|
41
|
-
return memo(instanceId, (): Observable<AccountIndexes> =>
|
|
42
|
-
indicesCache
|
|
43
|
-
? of(indicesCache)
|
|
44
|
-
: (
|
|
45
|
-
api.query.indices
|
|
46
|
-
? queryAccounts(api).pipe(startWith({}))
|
|
47
|
-
: of({} as AccountIndexes)
|
|
48
|
-
).pipe(
|
|
49
|
-
map((indices): AccountIndexes => {
|
|
50
|
-
indicesCache = indices;
|
|
51
|
-
|
|
52
|
-
return indices;
|
|
53
|
-
})
|
|
54
|
-
)
|
|
55
|
-
);
|
|
56
|
-
}
|