Hive Developer Portal
Convert HBD To HIVE
How to convert HBD to HIVE for a specified account.
Full, runnable src of Convert HBD To HIVE can be downloaded as part of: tutorials/javascript (or download just this tutorial: devportal-master-tutorials-javascript-32_convert_hbd_to_hive.zip).
This tutorial will take you through the process of checking a specific users’ balances and then broadcasting the intended HBD conversion to the blockchain. Demo account information has been provided to assist with the tutorial. This tutorial has been set up for the testnet
but can be easily be changed for production
.
It should be noted that the converted HIVE will not be available instantly as it takes 3.5 days for the transaction to be processed. It is also not possible to stop a conversion once initialized. During the 3.5 days for it to be converted and as the conversion price fluctuates you could actually be receiving less HIVE than what you should. Because of this, the method in this tutorial is NOT the preferred or most efficient way of converting HBD to HIVE. This tutorial just illustrates that it can be done in this manner.
There is a marketplace on Hive that allows you to “sell” your HBD instantly. With this process you can get your HIVE immediately and at the exact price that you expect. The market place is the better way to convert your HBD. This article provides more information on using the market to exchange your HBD to HIVE
Hiveconnect offers an alternative to converting HBD with a “simple link” solution. Instead of running through a list of operations on your account, you can simply use a link similar to the one below substituting the three parameters for your own details. You will be prompted to enter your username and password before the transaction will be executed. https://hivesigner.com/sign/convert?owner=username&requestid=1234567&amount=0.000%20HBD This is similar to the Hive Connect links that have been covered in previous tutorials. For a list of signing operations that work in this manner you can go to https://v2.hivesigner.com/sign This article has more information on using Hive Connect
Intro
This tutorial uses the database API
to gather account information for the current HBD and HIVE balances of the specified user. This information is then used to assist the user in completing the conversion request. The values are then captured and the operation is transmitted via the broadcast
API. The parameters for this convert
function are:
- owner - The account for which the conversion is being done
- requestid - Integer identifier for tracking the conversion. This needs to be a unique number for a specified user
- amount - The amount of HBD to withdraw
The only other information required is the private active key of the user.
Also see:
Steps
- Configure connection Configuration of
dhive
to communicate with a Hive blockchain - User account User account is captured and balances displayed
- Input variables Collecting the required inputs via an HTML UI
- Broadcast operation Broadcasting the operation to the blockchain
1. Configure connection
As usual, we have a public/app.js
file which holds the Javascript segment of the tutorial. In the first few lines we define the configured library and packages:
import { Client, PrivateKey } from '@hiveio/dhive';
import { Testnet as NetConfig } from '../../configuration'; //A Hive Testnet. Replace 'Testnet' with 'Mainnet' to connect to the main Hive blockchain.
let opts = { ...NetConfig.net };
// //connect to a hive node, tesetnet in this case
const client = new Client(NetConfig.url, opts);
Above, we have dhive
pointing to the testnet with the proper chainId, addressPrefix, and endpoint by importing it from the configuration.js
file. Due to this tutorial altering the blockchain it is preferable to not work on production.
2. User account
The user account is input through the UI. Once entered, the user can select the search
button to display the HBD and HIVE balances for that account. During this step, a random number is also generated for the requestid
. This value can be changed to any integer value as long as it is unique for the specific account. If the requestid is duplicated an error to do with “uniqueness constraint” will be displayed in the console. For ease of use values for a demo account has already been entered in the relevant fields once the page loads.
window.onload = async () => {
const account = NetConfig.accounts[0];
document.getElementById('username').value = account.address;
document.getElementById('privateKey').value = account.privActive;
};
With the account search function as seen below.
window.submitAcc = async () => {
const accSearch = document.getElementById('username').value;
const _account = await client.database.call('get_accounts', [[accSearch]]);
console.log(`_account:`, _account);
const availHBD = _account[0].hbd_balance
const availHIVE = _account[0].balance
const balance = `Available balance: ${availHBD} and ${availHIVE} <br/>`;
document.getElementById('accBalance').innerHTML = balance;
//create random number for requestid paramter
var x = Math.floor(Math.random() * 10000000);
document.getElementById("requestID").value = x
}
3. Input variables
The parameters for the convert
function are input in the UI and assigned as seen below once the user presses the convert button.
//get all values from the UI
//get account name
const username = document.getElementById('username').value;
//get private active key
const privateKey = PrivateKey.fromString(
document.getElementById('privateKey').value
);
//get convert amount
const quantity = document.getElementById('quantity').value;
//create correct format
const convert = quantity.concat(' HBD');
//assign integer value of ID
const requestid = parseInt(document.getElementById('requestID').value);
4. Broadcast operation
With all the parameters assigned we create an array for the convert
function and transmit it to the blockchain via the sendOperation
function in the broadcast
API.
//create convert operation
const op = [
'convert',
{ owner: username, amount: convert, requestid: requestid },
];
//broadcast the conversion
client.broadcast.sendOperations([op], privateKey).then(
function(result) {
console.log(
'included in block: ' + result.block_num,
'expired: ' + result.expired
);
document.getElementById('convertResultContainer').style.display = 'flex';
document.getElementById('convertResult').className =
'form-control-plaintext alert alert-success';
document.getElementById('convertResult').innerHTML = 'Success';
},
function(error) {
console.error(error);
document.getElementById('convertResultContainer').style.display = 'flex';
document.getElementById('convertResult').className =
'form-control-plaintext alert alert-danger';
document.getElementById('convertResult').innerHTML = error.jse_shortmsg;
}
);
The results of the operation is displayed on the UI along with a block number in the console to confirm a successful operation.
Final code:
import { Client, PrivateKey } from '@hiveio/dhive';
import { Testnet as NetConfig } from '../../configuration'; //A Hive Testnet. Replace 'Testnet' with 'Mainnet' to connect to the main Hive blockchain.
let opts = { ...NetConfig.net };
//connect to a hive node, tesetnet in this case
const client = new Client(NetConfig.url, opts);
window.submitAcc = async () => {
const accSearch = document.getElementById('username').value;
const _account = await client.database.call('get_accounts', [[accSearch]]);
console.log(`_account:`, _account);
const availHBD = _account[0].hbd_balance
const availHIVE = _account[0].balance
const balance = `Available balance: ${availHBD} and ${availHIVE} <br/>`;
document.getElementById('accBalance').innerHTML = balance;
//create random number for requestid paramter
var x = Math.floor(Math.random() * 10000000);
document.getElementById("requestID").value = x
}
//submit convert function executes when you click "Convert" button
window.submitConvert = async () => {
//get all values from the UI
//get account name
const username = document.getElementById('username').value;
//get private active key
const privateKey = PrivateKey.fromString(
document.getElementById('privateKey').value
);
//get convert amount
const quantity = document.getElementById('quantity').value;
//create correct format
const convert = quantity.concat(' HBD');
//assign integer value of ID
const requestid = parseInt(document.getElementById('requestID').value);
//create convert operation
const op = [
'convert',
{ owner: username, amount: convert, requestid: requestid },
];
//broadcast the conversion
client.broadcast.sendOperations([op], privateKey).then(
function(result) {
console.log(
'included in block: ' + result.block_num,
'expired: ' + result.expired
);
document.getElementById('convertResultContainer').style.display =
'flex';
document.getElementById('convertResult').className =
'form-control-plaintext alert alert-success';
document.getElementById('convertResult').innerHTML = 'Success';
},
function(error) {
console.error(error);
document.getElementById('convertResultContainer').style.display =
'flex';
document.getElementById('convertResult').className =
'form-control-plaintext alert alert-danger';
document.getElementById('convertResult').innerHTML =
error.jse_shortmsg;
}
);
};
window.onload = async () => {
const account = NetConfig.accounts[0];
document.getElementById('username').value = account.address;
document.getElementById('privateKey').value = account.privActive;
};
To run this tutorial
git clone https://gitlab.syncad.com/hive/devportal.git
cd devportal/tutorials/javascript/32_convert_hbd_to_hive
npm i
npm run dev-server
ornpm run start
- After a few moments, the server should be running at http://localhost:3000/