@polkadot/types/interfaces#Multisig TypeScript Examples
The following examples show how to use
@polkadot/types/interfaces#Multisig.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: Address.tsx From crust-apps with Apache License 2.0 | 6 votes |
async function queryForMultisig (api: ApiPromise, requestAddress: string, proxyAddress: string | null, tx: SubmittableExtrinsic<'promise'>): Promise<MultiState | null> {
const multiModule = api.tx.multisig ? 'multisig' : 'utility';
if (isFunction(api.query[multiModule]?.multisigs)) {
const address = proxyAddress || requestAddress;
const { threshold, who } = extractExternal(address);
const hash = (proxyAddress ? api.tx.proxy.proxy(requestAddress, null, tx) : tx).method.hash;
const optMulti = await api.query[multiModule].multisigs<Option<Multisig>>(address, hash);
const multi = optMulti.unwrapOr(null);
return multi
? {
address,
isMultiCall: ((multi.approvals.length + 1) >= threshold),
who,
whoFilter: who.filter((w) => !multi.approvals.some((a) => a.eq(w)))
}
: {
address,
isMultiCall: false,
who,
whoFilter: who
};
}
return null;
}
Example #2
Source File: TxSigned.tsx From crust-apps with Apache License 2.0 | 6 votes |
async function wrapTx (api: ApiPromise, currentItem: QueueTx, { isMultiCall, multiRoot, proxyRoot, signAddress }: AddressProxy): Promise<SubmittableExtrinsic<'promise'>> {
let tx = currentItem.extrinsic as SubmittableExtrinsic<'promise'>;
if (proxyRoot) {
tx = api.tx.proxy.proxy(proxyRoot, null, tx);
}
if (multiRoot) {
const multiModule = api.tx.multisig ? 'multisig' : 'utility';
const info = await api.query[multiModule].multisigs<Option<Multisig>>(multiRoot, tx.method.hash);
const { weight } = await tx.paymentInfo(multiRoot);
const { threshold, who } = extractExternal(multiRoot);
const others = who.filter((w) => w !== signAddress);
let timepoint: Timepoint | null = null;
if (info.isSome) {
timepoint = info.unwrap().when;
}
tx = isMultiCall
? api.tx[multiModule].asMulti.meta.args.length === 6
// We are doing toHex here since we have a Vec<u8> input
? api.tx[multiModule].asMulti(threshold, others, timepoint, tx.method.toHex(), false, weight)
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
: api.tx[multiModule].asMulti(threshold, others, timepoint, tx.method)
: api.tx[multiModule].approveAsMulti.meta.args.length === 5
? api.tx[multiModule].approveAsMulti(threshold, others, timepoint, tx.method.hash, weight)
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
: api.tx[multiModule].approveAsMulti(threshold, others, timepoint, tx.method.hash);
}
return tx;
}
Example #3
Source File: Address.tsx From subscan-multisig-react with Apache License 2.0 | 6 votes |
async function queryForMultisig(
api: ApiPromise,
requestAddress: string,
proxyAddress: string | null,
tx: SubmittableExtrinsic<'promise'>
): Promise<MultiState | null> {
const multiModule = api.tx.multisig ? 'multisig' : 'utility';
if (isFunction(api.query[multiModule]?.multisigs)) {
const address = proxyAddress || requestAddress;
const { threshold, who } = extractExternal(address);
const hash = (proxyAddress ? api.tx.proxy.proxy(requestAddress, null, tx) : tx).method.hash;
const optMulti = await api.query[multiModule].multisigs<Option<Multisig>>(address, hash);
const multi = optMulti.unwrapOr(null);
return multi
? {
address,
isMultiCall: multi.approvals.length + 1 >= threshold,
who,
whoFilter: who.filter((w) => !multi.approvals.some((a) => a.eq(w))),
}
: {
address,
isMultiCall: false,
who,
whoFilter: who,
};
}
return null;
}
Example #4
Source File: TxSigned.tsx From subscan-multisig-react with Apache License 2.0 | 6 votes |
async function wrapTx(
api: ApiPromise,
currentItem: QueueTx,
{ isMultiCall, multiRoot, proxyRoot, signAddress }: AddressProxy
): Promise<SubmittableExtrinsic<'promise'>> {
let tx = currentItem.extrinsic as SubmittableExtrinsic<'promise'>;
if (proxyRoot) {
tx = api.tx.proxy.proxy(proxyRoot, null, tx);
}
if (multiRoot) {
const multiModule = api.tx.multisig ? 'multisig' : 'utility';
const info = await api.query[multiModule].multisigs<Option<Multisig>>(multiRoot, tx.method.hash);
const { weight } = await tx.paymentInfo(multiRoot);
const { threshold, who } = extractExternal(multiRoot);
const others = who.filter((w) => w !== signAddress);
let timepoint: Timepoint | null = null;
if (info.isSome) {
timepoint = info.unwrap().when;
}
tx = isMultiCall
? api.tx[multiModule].asMulti.meta.args.length === 6
? // We are doing toHex here since we have a Vec<u8> input
api.tx[multiModule].asMulti(threshold, others, timepoint, tx.method.toHex(), false, weight)
: // eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
api.tx[multiModule].asMulti(threshold, others, timepoint, tx.method)
: api.tx[multiModule].approveAsMulti.meta.args.length === 5
? api.tx[multiModule].approveAsMulti(threshold, others, timepoint, tx.method.hash, weight)
: // eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
api.tx[multiModule].approveAsMulti(threshold, others, timepoint, tx.method.hash);
}
return tx;
}
Example #5
Source File: useMultisigApprovals.ts From crust-apps with Apache License 2.0 | 5 votes |
export default function useMultisigApprovals (address: string): [H256, Multisig][] {
const events = useContext(EventsContext);
const { api } = useApi();
const [multiInfos, setMultiInfos] = useState<[H256, Multisig][]>([]);
const [trigger, incTrigger] = useIncrement();
const mountedRef = useIsMountedRef();
// increment the trigger by looking at all events
// - filter the by multisig module (old utility is not supported)
// - find anything data item where the type is AccountId
// - increment the trigger when at least one matches our address
useEffect((): void => {
events
.filter(({ record: { event: { section } } }) => section === 'multisig')
.reduce((hasMultisig: boolean, { record: { event: { data } } }) =>
data.reduce((hasMultisig: boolean, item) =>
hasMultisig || (item.toRawType() === 'AccountId' && item.eq(address)),
hasMultisig),
false) && incTrigger();
}, [address, events, incTrigger]);
// query all the entries for the multisig, extracting approvals with their hash
useEffect((): void => {
const multiModule = api.query.multisig || api.query.utility;
multiModule && multiModule.multisigs &&
multiModule.multisigs
.entries(address)
.then((infos: [StorageKey, Option<Multisig>][]): void => {
mountedRef.current && setMultiInfos(
infos
.filter(([, opt]) => opt.isSome)
.map(([key, opt]) => [key.args[1] as H256, opt.unwrap()])
);
})
.catch(console.error);
}, [address, api, mountedRef, trigger]);
return multiInfos;
}