darwinia.js.testdontuse
v0.0.14
Published
A library to help fetch darwinia storages and dispatch calls
Downloads
23
Readme
darwinia.js
Version >= ^3.0.2 for Darwinia 2.0. Version < 3.0.0 is for Darwinia 1.0.
A library to help
- fetch internal substrate storages, and
- dispatch calls
- Easy-to-use derived functions(Derived API List) which are build from 1 and 2.
Nodejs
npm install darwinia.js@^3.0.2
Browser
Collators Amount: <span id="result"></span>
<script type="module">
import { ethers } from "https://esm.sh/[email protected]";
import { clientBuilder } from "https://esm.sh/[email protected]";
const provider = new ethers.providers.Web3Provider(window.ethereum);
const client = clientBuilder.buildPangolinClient(provider);
// storage
const result = await client.storages.darwiniaStaking.collatorCount();
const resultEl = document.getElementById("result");
resultEl.innerHTML = result;
// call
await window.ethereum.request({ method: "eth_requestAccounts" });
const signer = provider.getSigner();
const from = await signer.getAddress();
await client.calls.system.remarkWithEvent(signer, "0x12345678");
</script>
Try it in jsfiddle:
https://jsfiddle.net/wuminzhe/gwp4ovz1/4/
Browser - viem
Collators Amount: <span id="result"></span>
<script type="module">
import {
ethers
} from "https://esm.sh/[email protected]";
import {
custom,
createPublicClient,
createWalletClient
} from "https://esm.sh/[email protected]"
import {
clientBuilder,
publicClientToProvider,
walletClientToSigner
} from "https://esm.sh/[email protected]";
///////////////////////
// storage
///////////////////////
// convert viem public client to ethers provider
const publicClient = createPublicClient({
transport: custom(window.ethereum)
})
const provider = await publicClientToProvider(publicClient);
//
const client = clientBuilder.buildPangolinClient(provider);
const result = await client.storages.darwiniaStaking.collatorCount();
const resultEl = document.getElementById("result");
resultEl.innerHTML = result;
///////////////////////
// call
///////////////////////
// convert viem wallet client to ethers provider & signer
const walletClient = createWalletClient({
transport: custom(window.ethereum)
})
const [provider2, signer] = walletClientToSigner(walletClient)
//
const pangolin = clientBuilder.buildPangolinClient(provider2);
await pangolin.calls.session.setKeys(
signer, {
aura: "0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d",
}, // keys
"0x" // proof
);
</script>
https://jsfiddle.net/wuminzhe/amwL4jpk/1/
Usage
fetch storage
The returns of this lib's functions are all json string or null.
import { ethers } from "ethers";
import { clientBuilder } from "darwinia.js";
async function main(): Promise<void> {
const provider = new ethers.providers.JsonRpcProvider(
"https://pangolin-rpc.darwinia.network"
);
// or
// const provider = new ethers.providers.Web3Provider(window.ethereum);
const pangolin = clientBuilder.buildPangolinClient(provider);
let result = await pangolin.storages.system.account(
"0x794BF0B66926D84CB735283D849f454A2A8d9a44"
);
console.log(`${result}\n`);
}
main();
dispatch call
import { ethers } from "ethers";
import { clientBuilder } from "darwinia.js";
async function main(): Promise<void> {
const provider = new ethers.providers.Web3Provider(window.ethereum);
const signer = provider.getSigner();
const pangolin = clientBuilder.buildPangolinClient(provider);
await pangolin.calls.session.setKeys(
signer,
{
aura: "0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d",
}, // keys
"0x" // proof
);
}
main();
dispatch multiple calls in a single transaction
import { ethers } from "ethers";
import { clientBuilder } from "darwinia.js";
async function main(): Promise<void> {
const provider = new ethers.providers.Web3Provider(window.ethereum);
const signer = provider.getSigner();
const pangolin = clientBuilder.buildPangolinClient(provider);
// prepare calls
const setKeysCall = pangolin.calls.session.buildSetKeysCall(
// keys
{
aura: "0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d",
},
// proof
"px"
);
const collectCall = pangolin.calls.staking.buildCollectCall(120000000);
// dispatch
await pangolin.calls.utility.batchAll(signer, [setKeysCall, collectCall]);
}
main();
dispatch call with encoded input
import { ethers } from "ethers";
import { clientBuilder } from "darwinia.js";
async function main(): Promise<void> {
const provider = new ethers.providers.Web3Provider(window.ethereum);
const signer = provider.getSigner();
const pangolin = clientBuilder.buildPangolinClient(provider);
// call ended with `D` is the version that accept params encoded in scale codec
await pangolin.calls.session.setKeysH(
signer,
"0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d00" // encoded (keys, proof)
);
}
main();
More examples in examples
Derived API List
nominateAndStake
Nominate a collator and stake tokens to the collator.
setSessionKeysAndCommission
Set session keys and commission percetage. Example
trackSystemEvents
Track specified events. Example
getSystemEvents
Get the latest events. You can use this function with provider.on('block', callback)
to implement the tracking functionality like trackSystemEvents
. Example
See src/derived.ts.
Update Chains Metadata
npm run gen