Simple Dapp Example
We have created a dapp demo, you can find it at https://demo-app.reiwallet.io.
And the source code of this demo is here.
In this demo, you will see different methods to interact with Rei Wallet.
Prepareβ
Please install REI Wallet first.
Download from https://chromewebstore.google.com/detail/rei-wallet/jacbgghlojlggfgljfhhlcddicacmbek.
Or follow this guide to build it from scratch.
Buildβ
Run the following command to clone the source code from github repo.π
git clone https://github.com/TeamTaoist/reiwallet-dapp-demo.git
Run the following command to install the packages needed.π
npm install
To start the demo locally, you can run below commandπ
npm run dev
And you will see the page http://localhost:5173/
. Open this webpage in your Chrome, then you can play it!
Interface Examplesβ
1. Get wallet addressβ
await window.rei.ckb.request({method:"ckb_requestAccounts"})
2. Get Public Keyβ
await window.rei.ckb.request({method:"ckb_getPublicKey"})
3. Get Capacityβ
await window.rei.ckb.request({method:"ckb_getCapacity",data:[address:"ckb....."]})
address: Your ckb address
4. Sign Messageβ
await window.rei.ckb.request({method:"ckb_signMessage",data:{message:"Hello REI Wallet"}})
message: This is message that wants to sign with rei wallet,default add prefix "Nervos Message:".
5. Send CKBβ
await window.rei.ckb.request({method:"ckb_sendCKB",data:{
amount:1000,
to:"ckb....."
}})
amount: This is amount that wants to send to: This is address that wants to send
6. Get Networkβ
Get REI wallet's current network
await window.rei.ckb.request({method:"ckb_getNetwork"})
7. Switch Networkβ
await window.rei.ckb.request({method:"ckb_switchNetwork",data:"testnet"})
data: Two networks are supported here: "mainnet","testnet"
8. Get Fee Rateβ
await window.rei.ckb.request({method:"ckb_getFeeRate"})
9. Get Connected Statusβ
await window.rei.ckb.isConnected()
10. Off/Onβ
Disable/Enable listening state
window.rei.ckb.on('chainChanged', chainChangesFunction)
window.rei.ckb.off('accountsChanged', accountChangesFunction)
11. Send DOBβ
await window.rei.ckb.request({method:"ckb_sendDOB",data:{
outPoint:{
index:"0x..",
txHash:"0x..."
},
to:"ckb....."
}})
index: DOB's out_point index(RPC)
txHash: DOB's out_point tx_hash(RPC)
to: This is address that wants to send
12. Send Clusterβ
await window.rei.ckb.request({method:"ckb_sendCluster",data:{
outPoint:{
index:"0x..",
txHash:"0x..."
},
to:"ckb....."
}})
index: Cluster's out_point index
txHash: Cluster's out_point tx_hash
to: This is address that wants to send
13. Send SUDTβ
await window.rei.ckb.request({method:"ckb_sendSUDT",data:{
amount:1000,
to:"ckb....."
token:"0x..."
}})
amount: This is amount that wants to send to: This is address that wants to send token: SUDT's args(RPC)
14. Send XUDT/RGB++β
await window.rei.ckb.request({method:"ckb_sendXUDT",data:{
amount:1000,
to:"ckb....."
typeScript:{
args:"0x...",
code_hash:"0x...",
hash_type:"type"
}
}})
amount: This is amount that wants to send to: This is address that wants to send. Two format is supported here: "BTC","CKB" args: XUDT's args(RPC) code_hash: XUDT's code_hash(RPC) hash_type: XUDT's hash_type(RPC)
15. Sign Raw Transactionβ
await window.rei.ckb.request({method:"ckb_signTransaction",data:{
txSkeleton:{...}
}})
TxSkeleton format is the same with RPC transaction:
{
"version": "0x0",
"cell_deps": [{
"out_point": {
"tx_hash": "0x...",
"index": "0x0"
},
"dep_type": "dep_group"
}],
"inputs": [{
"previous_output": {
"tx_hash": "0x...",
"index": "0x0"
},
"since": "0x0"
}, {
"previous_output": {
"tx_hash": "0x...",
"index": "0x1"
},
"since": "0x0"
}],
"outputs": [{
"capacity": "0x2540be400",
"lock": {
"code_hash": "0x...",
"hash_type": "type",
"args": "0x..."
}
}, {
"capacity": "0x47387e42959",
"lock": {
"code_hash": "0x...",
"hash_type": "type",
"args": "0x..."
}
}],
"outputs_data": ["0x", "0x"],
"header_deps": [],
"witnesses": [ "0x...", "0x"]
}
16. Send Raw Transactionβ
await window.rei.ckb.request({method:"ckb_sendTransaction",data:{
txSkeleton:{...}
}})
TxSkeleton format is the same as above
17. Sign Raw Transaction(deprecated)β
await window.rei.ckb.request({method:"ckb_signRawTransaction",data:{
txSkeleton:{...}
}})
TxSkeleton format is the same with txSkeleton that generated from ckb lumos:
{
"cellProvider":{
"medianTimeEmitters":[],
"emitters":[],
"isSubscribeRunning":false,
"ckbIndexerUrl":"https://....ckb.dev/indexer",
"ckbRpcUrl":"https://....ckb.dev/rpc",
"uri":"https://....ckb.dev/rpc",
"ckbIndexerUri":"https://....ckb.dev/indexer"
},
"cellDeps":[
{
"outPoint":{
"txHash":"0x...",
"index":"0x..."
},
"depType":"depGroup"
}
],
"headerDeps":[...],
"inputs":[
{
"cellOutput":{
"capacity":"0x...",
"lock":{
"args":"0x....",
"codeHash":"0x...",
"hashType":"..."
},
"type":null
},
"data":"0x",
"outPoint":{
"index":"0x...",
"txHash":"0x..."
},
"blockNumber":"0x..."
}
],
"outputs":[
{
"cellOutput":{
"capacity":"0x...",
"lock":{
"codeHash":"0x...",
"hashType":"type",
"args":"0x..."
}
},
"data":"0x"
},
{
"cellOutput":{
"capacity":"0x...",
"lock":{
"codeHash":"0x...",
"hashType":"type",
"args":"0x..."
}
},
"data":"0x"
}
],
"witnesses":["0x..."],
"fixedEntries":[],
"signingEntries":[],
"inputSinces":{}
}
18. Send Raw Transaction(deprecated)β
await window.rei.ckb.request({method:"ckb_sendRawTransaction",data:{
txSkeleton:{...}
}})
TxSkeleton format is the same as above
Need help?β
If you have any questions with REI Wallet, please join the tg group https://t.me/reiwallet