Hive Interface is a JavaScript library for interacting with the Hive blockchain. It is designed for high-availability applications that use the Hive platform.
To install via NPM use:
npm install @splinterlands/hive-interface
Then add the following in your NodeJS project:
const { Hive } = require('@splinterlands/hive-interface');
const hive = new Hive();
The Hive class constructor can optionally take a configuration object as a parameter with the following options:
- logging_level - The "level" of logs to output, with 1 being only errors to 4 being everything. Default is 3.
- rpc_error_limit - The number of errors an RPC node can have in a 10 minute period before it is disabled for an hour. Default is 10.
- rpc_nodes - Array of RPC node URLs that should be used. Default is:
["https://api.hive.blog", "https://anyx.io", "https://api.openhive.network", "https://hived.privex.io", "https://api.hivekings.com"]
The api
method will make an RPC API call to a Hive blockchain RPC node. It takes the following parameters:
method_name
- the name of the RPC API method to callparams
- parameters to send to the RPC API endpoint
Example:
let accounts = await hive.api('get_accounts', [['account1', 'account2', ...]]);
You can find more information about the available RPC API calls here: https://developers.hive.io/apidefinitions/#apidefinitions-condenser-api
The broadcast
method will sign and broadcast a transaction with a single operation to the blockchain. It takes the following parameters:
method_name
- the name of the operationparams
- the operation parameterskey
- the appropriate private key with which to sign the transaction
Example:
let transaction = await hive.broadcast('transfer', {
from: "account1",
to: "account2",
amount: "1.000 HIVE",
memo: "transfer memo"
}, "[private active key for @account1]");
You can find more information about the available operations and parameters here: https://developers.hive.io/apidefinitions/#apidefinitions-broadcast-ops
The customJson
method is a helper method to easily sign and broadcast a custom_json
operation. It takes the following parameters:
id
- the "id" parameter of the custom_json operationjson
- the JSON object data to include in the operationaccount
- the name of the blockchain account which will sign the transactionkey
- the appropriate private key for the specified accountuse_active
- custom_json operations can be signed with either the posting or active keys. The posting key will be used by default unlessuse_active
is set totrue
.
Example:
let transaction = await hive.customJson('my_id', { test: 123 }, 'account1', 'private posting key for @account1');
The transfer
method is a helper method to easily sign and broadcast a transfer
operation. It takes the following parameters:
from
- the account from which the transfer will be sentto
- the account to which the transfer will be sentamount
- the amount of the transfer. Note that the amount must be a string in the format:#.### [HIVE/HBD]
.memo
- a memo to include with the transfer operationkey
- the private acive key for thefrom
account
Example:
let transaction = await hive.transfer('account1', 'account2', '0.001 HIVE', 'test transfer', 'private active key for @account1');
The sendSignedTx
method will broadcast and already signed transaction to the blockchain. It takes the following parameters:
tx
- the complete, signed transaction to send
The stream
method will stream blocks and/or operations from the blockchain. It takes an options object which may contain the following properties:
- save_state - Function that should be called to save the current state of streaming. By default this will save the last block streamed to a state.json file in the root directory of the application. It takes as a parameter a JSON object like
{ "last_block": 12345 }
. - load_state - Function that will be called to load the last saved state of streaming when it starts. By default this will load the state from the state.json file in the root directory of the application. Returns the JSON object loaded from the state file.
- state_file - File name to use to save the state of the streaming process. Default is
state.json
. - on_block - Function that will be called each time a new block is streamed from the Hive blockchain. Parameters are
block_num
, andblock
. - on_op - Function that will be called each time a new operation is streamed from the Hive blockchain.
- on_behind_blocks - Function that will be called if the streaming process ever gets 20 or more blocks behind (~1 minute).
- on_virtual_op - Function that will be called each time a new virtual operation is streamed from the Hive blockchain.
- irreversible - If this is set to
true
, then thestream()
method will stream the last irreversible block instead of the head block. - blocks_behind_head - Set to stream from a certain number of blocks behind the head block.
Example:
hive.stream({
on_block: onBlock,
on_op: onOperation,
on_virtual_op: onVirtualOperation
});
function onBlock(block_num, block) {
console.log(`Received Hive block: ${block_num} - ${block.transactions.length}`);
}
function onOperation(op, block_num, block_id, previous, transaction_id, block_time) {
console.log(`Received operation [${op[0]}] in transaction [${transaction_id}], in block [${block_num}], at [${block_time}]`);
}
function onVirtualOperation(trx, block_num) {
console.log(`Received virtual operation [${trx.op[0]}] in block [${block_num}]`);
}
Hive Interface also allows streaming transactions from the Hive Engine second layer side-chain. This can be set up as follows:
const { HiveEngine } = require('./hive-interface');
let hive_engine = new HiveEngine();
The HiveEngine()
class constructor can optionally take an object with the following properties:
rpc_url
- the RPC URL of a Hive Engine node to connect tosave_state
- Function that should be called to save the current state of streaming. By default this will save the last block streamed to a state_he.json file in the root directory of the application. It takes as a parameter a JSON object like { "last_block": 12345 }.load_state
- Function that will be called to load the last saved state of streaming when it starts. By default this will load the state from the state_he.json file in the root directory of the application. Returns the JSON object loaded from the state file.state_file
- File name to use to save the state of the streaming process. Default is state_he.json.
You may then call the stream
method to start streaming which takes as a parameter the function to call whenever a Hive Engine operation is received.
Example:
hive_engine.stream(tx => console.log(`Hive Engine transaction: ${tx.transactionId}, Sender: ${tx.sender}, Action: ${tx.action}`));