Newer
Older
import Decorated from '@polkadot/metadata/Decorated';
import { Metadata, TypeRegistry } from '@polkadot/types';
import { getSpecTypes } from '@polkadot/types-known';
import memoizee from 'memoizee';
import {
KUSAMA_SS58_FORMAT,
POLKADOT_SS58_FORMAT,
WESTEND_SS58_FORMAT,
} from './constants';
/**
* JSON object of ChainProperties codec from `@polkadot/api`.
*/
export interface ChainProperties {
ss58Format: number;
tokenDecimals: number;
tokenSymbol: string;
}
* Hardcode some chain properties of known chains. These are normally returned
* by `system_properties` call, but since they don't change much, it's pretty
* safe to hardcode them.
*
* @ignore
* @todo Should we expose this publicly?
*/
const defaultChainProperties: Record<string, ChainProperties> = {
Kusama: {
ss58Format: KUSAMA_SS58_FORMAT,
tokenDecimals: 12,
tokenSymbol: 'KSM',
},
Polkadot: {
ss58Format: POLKADOT_SS58_FORMAT,
tokenDecimals: 12,
tokenSymbol: 'DOT',
},
'Polkadot CC1': {
ss58Format: POLKADOT_SS58_FORMAT,
tokenDecimals: 12,
tokenSymbol: 'DOT',
},
Westend: {
ss58Format: WESTEND_SS58_FORMAT,
tokenDecimals: 12,
tokenSymbol: 'WND',
},
};
/**
* From a metadata hex string (for example returned by RPC), create a Metadata
* class instance. Metadata decoding is expensive, so this function is
* memoized.
* @param registry - The registry of the metadata.
* @param metadata - The metadata as hex string.
*/
function createMetadataUnmemoized(
registry: TypeRegistry,
metadataRpc: string
return new Metadata(registry, metadataRpc);
export const createMetadata = memoizee(createMetadataUnmemoized, {
length: 2,
});
/**
* From a metadata hex string (for example returned by RPC), create a Decorated
* object.
*
* @param registry - The registry of the metadata.
* @param metadata - The metadata as hex string.
*/
export function createDecorated(
registry: TypeRegistry,
metadataRpc: string
return new Decorated(registry, createMetadata(registry, metadataRpc));
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
/**
* Given a chain name, a spec name, and a spec version, return the
* corresponding type registry. This function only returns the correct type
* registry for the following chains:
* - Kusama,
* - Polkadot (incl. when running a dev node),
* - Westend.
* For other chains, please use `@polkadot/api`s `TypeRegistry` directly:
* `const registry = new TypeRegistry()`. If needed, you should also register
* your chain's custom types using `registry.register()`.
*
* @see https://github.com/polkadot-js/api/tree/master/packages/types-known
* @param chainName - The chain to create the type registry for. Returned by
* RPC `system_chain`.
* @param specName - The name of the runtime spec. Returned by RPC
* `state_getRuntimeVersion`.
* @param specVersion - The spec version of that chain for which we want to
* create a type registry. Returned by RPC `state_getRuntimeVersion`.
* @param metadataRpc - If you pass the optional `metadataRpc` argument, then
* this function will run `registry.setMetadata()`. **Important!** If you don't
* pass this argument, make sure to call `registry.setMetadata()` yourself!
*/
export function getRegistry(
chainName: 'Kusama' | 'Polkadot' | 'Polkadot CC1' | 'Westend',
specName: 'kusama' | 'polkadot' | 'westend',
specVersion: number,
metadataRpc?: string
): TypeRegistry {
const registry = new TypeRegistry();
// Register types specific to chain/runtimeVersion
registry.register(getSpecTypes(registry, chainName, specName, specVersion));
// Register the chain properties for this registry
registry.setChainProperties(
registry.createType('ChainProperties', defaultChainProperties[chainName])
);
if (metadataRpc) {
registry.setMetadata(createMetadata(registry, metadataRpc));
}
return registry;
}