-
Notifications
You must be signed in to change notification settings - Fork 205
WASM wallet client
WASM wallet client is a thin wrapper around Beam client library built into WASM using Emscripten toolchain. This wrapper allows to run BEAM wallet inside any browser supporting WebAssembly and it provides the regular BEAM wallet API to communicate with it from external(javascript) code.
Starting from version 7.3.13702 all network types are handled by a single npm package.
Older versions are available via npm
for different network types:
WASM wallet client module exports the following classes:
-
WasmWalletClient - the main object provides a set of static and member methods to control the wallet. It could be used to implement BEAM wallet as a browser extension
Method Description Constructors Creates new regular wallet object Headless constructors Creates new headless wallet object startWallet Starts the wallet in the background thread stopWallet Asynchronously stops the wallet running in the background isRunning Checks if the wallet is running isHeadless Checks if the wallet is headless
, i.e. without master and owner keyssendRequest Sends API request to the wallet subscribe Subscribes for API responses unsubscribe Unsubscribes from response notifications setSyncHandler Sets synchronization handler, allows tracking sync progress setApproveSendHandler Sets handler which allows to approve or reject any send operation initiated by DAPPs setApproveContractInfoHandler Sets handler which allows to approve or reject any operation which requires user's attention from application shader createAppAPI Asynchronously creates new application wallet API for given application importRecovery Asynchronously imports recovery data GeneratePhrase Generates new seed phrase IsAllowedWord Checks if given word is in the dictionary of the words allowed to be used in seed phrases IsValidPhrase Validates given seed phrase ConvertTokenToJson Converts given BEAM address to json ConvertJsonToToken Packs transaction parameters presented as JSON object into BEAM address MountFS Asynchronously mounts WASM filesystem to the roor of IndexDB CreateWallet Creates new wallet database DeleteWallet Deletes given wallet database from IndexDB IsInitialized Ensures that database was created CheckPassword Tests if given password fits to the database -
AppAPI - a proxy API object, it gives limited wallet API for external web applications, which want to work with BEAM wallet
Method Description callWalletApi Allows to call wallet API methods from the application setHandler Sets handler to receive a response for API request -
AppAPICallback - a callback object for applications, it allows the wallet to control the action which the application wants to perform.
Method Description sendApproved Approves send request from application sendRejected Rejects send request from application contractInfoApproved Approves contract call contractInfoRejected Rejects contract call
WasmWalletClient.GeneratePhrase()
Generates new seed phrase
- seed phrase, a string of 12 words from the dictionary separated by
var phrase = Module.WasmWalletClient.GeneratePhrase()
console.log('seed phrase is: ', phrase);
// OUTPUT: seed phrase is: legend hurdle erode ribbon pass exit basket doll sorry version muscle brain
WasmWalletClient.IsAllowedWord(word : String)
Checks if given word is in the dictionary of the words allowed to be used in seed phrases
-
word
: the word to be checked
-
true
ifword
is in the dictionary otherwisefalse
if (Module.WasmWalletClient.IsAllowedWord('hurdle')) {
console.log("Word is allowed");
}
WasmWalletClient.IsValidPhrase(phrase : String)
Validates given seed phrase
-
phrase
: a string of words separated by
-
true
if seedphrase
is valid otherwisefalse
WasmWalletClient.ConvertTokenToJson(token : String)
Converts given BEAM address to json
-
token
: address to to unpack data
- json object with address parameters unpacked from given string
- in beam address(token) is binary packed set the key-value parameters presented as
base58
string
WasmWalletClient.ConvertJsonToToken(json : String)
Packs transaction parameters presented as JSON object into BEAM address
-
json
: parameters of the transaction
-
base58
encoded string of packed parameters
WasmWalletClient.MountFS(callback : function)
Asynchronously mounts WASM filesystem to the roor of IndexDB
-
callback
: mounting completion handler, if an error occurred, it will be provided as a parameter to this function.
- none
- This method should be called before any action which implies work with filesystem
Module.WasmWalletClient.MountFS(function(error) {
if (error != null) {
console.log("mounted");
var walletClient = new Module.WasmWalletClient("/beam_wallet/wallet.db",
"123",
"eu-node01.masternet.beam.mw:8200");
}
}
WasmWalletClient.CreateWallet(seedPhrase : String, database : String, password : String)
Creates new wallet database
-
seedPhrase
: seed pharse for the wallet -
database
: path to the database in IndexedDB -
password
: password to the new wallet database
- none
- Ensure that
MountFS()
has been called before
let phrase = Module.WasmWalletClient.GeneratePhrase();
Module.WasmWalletClient.CreateWallet(phrase, "/beam_wallet/wallet.db", "123");
WasmWalletClient.DeleteWallet(database : String)
Deletes given wallet database from IndexDB
-
database
: path to the database file
- none
- Ensure that
MountFS()
has been called before
WasmWalletClient.IsInitialized(database : String)
Ensures that database was created
-
database
: the path to the database
-
true
if database is created and initialized, otherwisefalse
- Ensure that
MountFS()
has been called before
WasmWalletClient.CheckPassword(database : String, password : String, callback : function)
Tests asynchronously if given password fits to the database
-
database
: path to the database -
password
: password to test -
callback
: asynchronously returns the result of the test
- none
- Ensure that
MountFS()
has been called before
Module.WasmWalletClient.CheckPassword("/beam_wallet/wallet.db", "13", (res) => {
if (res)
console.log("Password is correct")
else
console.log("Password is not correct")
})
WasmWalletClient(database : String, password : String, nodeURL : String);
WasmWalletClient(database : String, password : String, nodeURL : String, network : Network);
Creates new wallet client object
-
database
: path to encrypted database in browser's IndexDB -
password
: password to the database -
nodeURL
: URL to BEAM node to communicate with -
network
: network type, acceptable values are, available from version 7.3.13702
Module.Network.mainnet;
Module.Network.masternet;
Module.Network.testnet;
Module.Network.dappnet;
- object of the wallet client
- wallet client can communicate with node over Web Sockets only, ensure that node located by
nodeURL
has WebSocket proxy enabled - ensure that
MountFS()
has been called before - if no
network
param is passedmainnet
client is created
var mainnetWalletClient = new Module.WasmWalletClient("/beam_wallet/wallet.db",
"123",
"eu-node01.mainnet.beam.mw:8200");
var dappnetWalletClient = new Module.WasmWalletClient("/beam_wallet/wallet.db",
"123",
"eu-node01.dappnet.beam.mw:8200",
Module.Network.dappnet);
WasmWalletClient(nodeURL : String);
WasmWalletClient(nodeURL : String, network : Network); // available from version 7.3.13702
Creates new headless wallet client object. It doesn't have a master key. The wallet with such a database can communicate with the node, but cannot make transactions or detect any UTXO event. It can generate public keys, but they all are temporary and provided only for the reason to have viewer access to dapps
-
nodeURL
: URL to BEAM node to communicate with -
network
: network type, acceptable values are
Module.Network.mainnet;
Module.Network.masternet;
Module.Network.testnet;
Module.Network.dappnet;
- object of the wallet client
- wallet client can communicate with node over Web Sockets only, ensure that node located by
nodeURL
has WebSocket proxy enabled - headless wallet doesn't require
MountFS()
to be called before
var mainnetWalletClient = new Module.WasmWalletClient("eu-node01.mainnet.beam.mw:8200");
var walletClient = new Module.WasmWalletClient("eu-node01.masternet.beam.mw:8200", Module::Network::masternet);
function startWallet()
Starts the wallet in the background thread
- wallet client can communicate with node over Web Sockets only, ensure that node located by
nodeURL
has WebSocket proxy enabled
function stopWallet(callback : function)
Asynchronously stops the wallet running in the background
-
callback
: calls when wallet has stopped. In this callback it is safe to delete the wallet database
- none
wc.stopWallet(()=> {
console.log("is running: " + wc.isRunning()) // false
}
function isRunning()
Checks if the wallet is running
- none
-
true
if the wallet is running,false
otherwise
function isHeadless()
Checks if the wallet is headless
, i.e. without master and owner keys
- none
-
true
if the wallet is headless,false
otherwise
function sendRequest(jsonRequest : String)
Sends API request to the wallet
-
jsonRequest
: API request
- none
- to get response you have to subscribe before
walletClient.sendRequest(JSON.stringify({
jsonrpc: '2.0',
id: 5,
method: 'wallet_status'
}));
function subscribe(callback : function)
Subscribes for API responses
-
callback
: function which is called when response arrived
- index of the subscription
var i = walletClient.subscribe((r)=> {
console.log("response: " + r)
});
function unsubscribe(index : Number)
Unsubscribes from response notifications
-
index
: index of the subscription
- none
function setSyncHandler(handler : function)
Sets synchronization handler, allows to track sync progress
-
handler
: called each time wallet notifies about sync progress
- none
walletClient.setSyncHandler((done, total) => {
console.log("sync [" + done + "/" + total + "]");
});
function setApproveSendHandler(handler : function)
Sets handler which allows to approve or reject any send operation initiated by DAPPs
-
handler
: function called each time application wants to send assets from the wallet
- none
walletClient.setApproveSendHandler((request, info, cb)=>{
console.log("Request: " + request);
console.log("Info: " + info);
cb.sendApproved(request);
//cb.sendRejected(request);
})
function setApproveContractInfoHandler(handler : function)
Sets handler which allows to approve or reject any operation which requires user's attention from application shader
handler
- none
walletClient.setApproveContractInfoHandler((request, info, amounts, cb)=>{
console.log("Request: " + request);
console.log("Info: " + info);
cb.contractInfoApproved(request);
//cb.contractInfoRejected(request);
})
function createAppAPI(appid : String, appname : String, callback : function);
function createAppAPI(apiver: String, minapiver : String, appid : String, appname : String, callback : function);
function createAppAPI(apiver: String, minapiver : String, appid : String, appname : String, callback : function, privilegeLevel : Integer);
Asynchronously creates new application wallet API for given application
-
apiver
: desired version of API, acceptable values are strings like: "6.0", "7.3" or "current" if you want to use the latest version -
minapiver
: a fallback version of API in case if desired API version is inaccessible -
appid
: ID of the application -
appname
: the name of the app -
callback
: the callback with API object in the case of success -
privilegeLevel
: level of privilege for app shader running via requested API, possible values are0
,1
,2
, the higher value the higher privilege, available from version 7.3.13702
console.log("calling API...");
wc.createAppAPI("appid", "appname", (api)=>{
api.setHandler((r)=> {
console.log("API response: " + r)
})
api.callWalletApi(JSON.stringify({
jsonrpc: '2.0',
id: 5,
method: 'wallet_status'
}));
});
function importRecovery(recoveryData: Uint8Array, callback: function(error, done, total))
Asynchronously imports recovery data
-
recoveryData
: downloaded recovery data -
callback
: callback function, which allows to handle errors viaerror
parameter and to report progress usingdone
andtotal
// download function should be defined by user
download("recovery.bin", function(error, data) {
if (error == null) {
console.log("downloaded recovery")
walletClient.importRecovery(data, function(error, done, total) {
if (error == null) {
console.log(`Restoring ${done}/${total}`)
} else {
console.log(`Failed to recover: ${error}`)
}
});
} else {
console.log("failed to download recovery")
}
});