-
Notifications
You must be signed in to change notification settings - Fork 5
How to_Setup Bytz 2.0 GVT with Ubuntu remote and local QT wallet
This guide contains instructions to set up a single BYTZ mainnet masternode manually using a combination of a local desktop wallet (BYTZ QT) and a remote wallet (BYTZ daemon) on a virtual private server (VPS).
For moderate to advanced users
Setting up an BTYZ masternode this way requires some basic understanding of command line operations and careful inputting of commands in a console or terminal window. Masternodes require some ongoing maintenance, including installing services updates and upgrades for network improvements. Masternode operators must also carefully consider the security of their funds, particularly their masternode collateral by securely backing up crucial information and encrypting wallets.
To operate a masternode, you will need:
- 10,000,000.01 BYTZ coin (10,000,000 for collateral/.01 for transaction fees).
- 1 GVT.credit token (Issued by the BYTZ team)
- A local QT wallet available from https://bytz.gg for the BYTZ collateral.
- A local LINUX computer instance or remote Virtual Private Server (VPS) to run the BYTZ masternode daemon wallet and access the collateral coins remotely.
The VPS or remote server should have at least 4B of free memory. Ubuntu 18.04 x64 is a stable platform for running masternodes. A VPS normally has a static IPs and an always-on internet connection with stable uptime which provides the constant network connection that the masternode needs.
There are many providers of VPS services:
- Vultr
- Hetzner
- Digital Ocean
- Amazon EC2
- OVH
The VPS provider you choose should offer good hardware and guarantee high uptime. Continuous connectivity is important because if the masternode loses connection with the BYTZ network, it can take time to be registered for rewards again. Read reviews of services to determine which is best for you.
Once you have installed Ubuntu 18.04, you’ll connect to the server through Secure Shell (SSH).
Mac and Linux
On Mac and Linux it is possible to SSH directly from the Terminal.app window by typing:
ssh root@<server IP address>
The formatted command should look something like this:
Since this is the first time your computer is connecting to the server, you’ll be prompted with a warning:
<The authenticity of host 'xxx.xxx.xxx.xxx (xxx.xxx.xxx.xxx)' can't be established.
ECDSA key fingerprint is SHA256:3SDF4LKfhsJOWhsIrEUTruynMNjdCXjLdKJOTH.
Are you sure you want to continue connecting (yes/no)?>.” If prompted, reply “Yes.
Enter your password at the prompt.
Windows
To connect to the new VPS via SSH on Windows, download the PuTTy app:
https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html
Open PuTTy. Under “Host Name (or IP address),” replace the default text, “111.222.333.444,” with your new VPS IP. Click “Open.”
There may be a certificate warning because this is the first time you are connecting to this server.
When you see the prompt “Login as,” enter:
root
Follow prompts to enter the password assigned by your provider and press “Return.”
If your provider does not require a password change upon initial login, it is the best security practice to set a root password yourself. A strong password should be randomly generated and should contain both upper and lowercase characters as well as numbers and special characters.
To change root password, enter:
passwd root
After you press return, confirm the password.
For security, it is best practice not to run the system as the root user and so a new user should be added. Enter:
adduser --gecos "" <username>
Example adding user “MN1”:
adduser --gecos "" mn1
Press return, then add the new user to the sudo users file:
usermod -aG sudo <username>
The new user has now been added with sudo permissions.
Save the new username and password in a secure place. If you lose these details, you will also lose access to the user account.
Switch user from the root user to the newly created user:
su <username>
For example:
su mn1
Run the following two commands.
sudo apt update
sudo apt upgrade
Install build dependencies
Enter the following commands to install and setup the BYTZ masternode remote wallet on your VPS. These compile instructions have been tested on Ubuntu 18.04. They will also work on other compatible Linux flavors.
sudo apt-get install curl build-essential libtool autotools-dev automake pkg-config python3 bsdmainutils cmake git
Change the directory to your masternode user’s home folder so you can download and compile the BYTZ daemon wallet.
cd ~
NOTE This step (Compiling the wallet) is optional, you may also elect to download prebuilt binaries. The latest BYTZ releases can be found at: https://github.com/bytzcurrency/BYTZ/releases.
“Cloning” copies the wallet software from the Github developer repository to your VPS.
git clone https://github.com/bytzcurrency/BYTZ.git
Build additional dependencies
“Runtime dependencies” are tools or packages required to install, compile, or run software.
cd bytz/depends
make HOST=x86_64-linux-gnu
Return to the BYTZ directory
cd
cd bytz
./autogen.sh
./configure --prefix=`pwd`/depends/x86_64-linux-gnu
or
./configure --prefix=`pwd`/depends/x86_64-linux-gnu --without-miniupnpc --without-gui --disable-tests
NOTE: If these commands return an error message, replace with full path, eg:
/home/Username/bytz/depends/x86_64-linux-gnu
make
NOTE: Compiling will take some time. Make some tea.
After compiling (or downloading) binaries, move the newly created/extracted binaries to the /usr/bin/ folder. This allows you to run and interact with the BYTZ daemon (bytzd) and the command line interface (bytz-cli) from anywhere on the system:
cp ~/bytz/src/bytzd ~/bytz/src/bytz-cli /usr/local/bin
Next, you’ll configure the local “controller” wallet (on desktop). You will complete the remote wallet setup (on VPS) later.
First, configure your preferences on the BYTZ QT for easy masternode management.
Windows: Under Settings > Options choose Preferences Mac: BYTZ > Preferences
Select the Wallet tab and check “Show Masternodes tab” from the File menu > Settings > Options > Wallet tab then ‘✔’ the box.
The BYTZ local desktop wallet will hold the masternode collateral. The wallet must be fully synced and must hold a single 10,000,000 BYTZ unspent transaction which serves as the masternode collateral required to operate on the BYTZ network. Ideally this is held on a newly created and backed up address.
If you don’t yet have 10,000,000 BYTZ in a single transaction, here’s how to create a new address so you can get the 10,000,000 BYTZ.
After the wallet has synced, click on Tools, then click Debug Console and type the following commands.
getnewaddress mn1
Paste this newly created address into a text editor then label it “mn1” or “masternode collateral.” Adding a recognizable label (like mn1) will make it easy to recognize it when you need it later.
Security note: Backup your private key securely!
It is best practice to back up the private keys for this address before filling it with the required masternode collateral. To backup the private key enter the following:
dumpprivkey <newaddress>
Where is the output from getnewaddress command. NOTE: do not add the brackets.
Now, SEND EXACTLY 10,000,000 BTYZ to the new address in a single transaction. Once the network has confirmed this transaction, open the debug window and enter:
masternode outputs
Example of resulting output (may be multiple strings):
{
"37124f4da7ffe26b509263e70ac417fe5d862e8905c5abc9cdbf827f2658a6c3": "0"
}
Generate the masternode key pair
To run a BYTZ masternode, you must generate a public/private key pair.
By the end of this document, you will register your public key on the network through an initial registration transaction. Then, once the public key is registered, you can add the “secret” or private key to the remote VPS server, and register it on the network so that your masternode gets included in the masternode list.
On BYTZ's new masternode system, the masternode list is derived entirely from information found on-chain. New masternodes are added by new special transactions called “Provider Registration Transactions” (abbreviated as ProRegTx). Masternodes are only removed by spending the collateral. A ProRegTx includes either a 10,000,000 BYTZ collateral payment in a single transaction AND 1 GVT.credit token which is burned on creation.
To generate the masternode key pair, go to the debug console and enter:
bls generate
[Note: BLS stands for Boneh-Lynn-Sacham and refers to a type of cryptographic signature.]
Sample output:
{
"secret": "395555d67d884364f9e37e7e1b29536519b74af2e5ff7b62122e62c2fffab35e",
"public": "99f20ed1538e28259ff80044982372519a2e6e4cdedb01c96f8f22e755b2b3124fbeebdf6de3587189cf44b3c6e7670e"
}
The keys generated by this command are NOT stored by the wallet, so you must securely back them up in case you need them later. The bls generate
is similar to the masternode genkey
or createmasternode
commands used in previous versions of BYTZ.
Back on the VPS, you’ll add the BLS public/private key pair to the masternode’s bytz.conf file. This allows the masternode to actively listen on the blockchain for relevant ProRegTx transactions. When the ProRegTx transaction is broadcast by the operator’s wallet and confirmed by the wider network of miners, the node will start serving as a masternode on the BYTZ network.
NOTE: In order to run commands on the remote server (on VPS), you must specify the application that will run the commands. To issue commands for the BYTZ daemon, you must use the bytz-cli (CLI stands for command line interface). So you will type “bytz-cli” before each command for the BYTZ daemon.
Example:
bytz-cli help
Note: You will replace help with the relevant commands.
On the remote masternode server that you setup in the first step, edit the bytz.conf file with the command as follows:
Make a new directory called “.bytzcoin”
mkdir ~/.bytzcoin
Configure the daemon by writing a preferences file called “bytz.conf”
nano ~/.bytzcoin/bytz.conf
The editor will open a blank document called, “bytz.conf”. Copy the text below and paste it into the editor:
# If you want to run testnet, uncomment the line below for testnet by removing the hashtag.
# testnet=1
rpcuser=<REPLACE ME>
rpcpassword=<REPLACE ME>
rpcallowip=127.0.0.1
listen=1
server=1
daemon=1
externalip=XXX.XXX.XXX.XXX:37415
# **NOTE:** Replace “XXX.XXX.XXX.XXX” with the VPS IP address
# **NOTE:** testnet port 47415
masternodeblsprivkey=<“secret”>
# NOTE: Replace <”secret”> with the “secret” output from the `bls generate` command
masternode=1
Sample bytz.conf with all comments removed and including output from BLS generate:
rpcuser=STRONG_USERNAME
rpcpassword=STRONG_PASSWORD
rpcallowip=127.0.0.1
listen=1
server=1
daemon=1
externalip=123.456.78.90
masternodeblsprivkey=395555d67d884364f9e37e7e1b29536519b74af2e5ff7b62122e62c2fffab35e
Once you confirm the details, press ctrl+X to exit the editor, then Y to confirm the new edits, then the Return key to save the file under the same name.
Adding the masternodeblsprivkey
enables masternode mode. When the daemon wallet next starts, the “bytz.conf” file now forces the following settings needed to provide the masternode service:
txindex=1
peerbloomfilters=1
prune=0
bytzd &
You will see a message reading BYTZ Core server starting. Press Enter again to get back to the command prompt.
We will now install Sentinel, a piece of software which operates as a watchdog to communicate to the network that your node is working properly
Install the Sentinel Python Prerequisites
sudo apt-get -y install python-virtualenv
Install Sentinel
cd ~/.bytzcoin
git clone https://github.com/bytzcurrency/sentinel.git
cd sentinel
virtualenv venv
venv/bin/pip install -r requirements.txt
venv/bin/python bin/sentinel.py
The final command will return a string stating: bytzd not synced with network! Awaiting full sync before running Sentinel.
We'll now add a line to crontab to ensure sentinel runs every minute to update and check on the masternode
crontab -e
Choose nano as your editor and enter the following lines at the end of the file:
* * * * * cd ~/.bytzcoin/sentinel && ./venv/bin/python bin/sentinel.py 2>&1 >> sentinel-cron.log
* * * * * pidof bytzd || ~/.bytzcoin/bytzd
ctrl+x
to exit s
to save when prompted
Return to your local desktop wallet’s Debug Console.
With the keys that were generated above by the bls generate
command, we must prepare a transaction that registers the masternode on the network. This is called the “ProRegTx” transaction.
The private key was already entered on the bytz.conf configuration file. Now, the public key is used in this transaction as the operatorPubKey
.
You’ll need an “OwnerKeyAddr
” for voting (later) and for masternode registration (now). This needs to be a new and unused address. Generate it with the following command:
getnewaddress OwnerKeyAddr
A new address will be generated within the wallet and will be displayed on screen in the console window.
Example output:
sLQ72uinxF95yxiTrpq9QM4uh1GgBGPSoa
Paste the address generated on your screen into your text editor and label it as “OwnerKeyAddr
”.
Generate payout address (PayoutAddress)
Next, you’ll be generating a payoutAddress
that receives the masternode rewards. By default, the PayoutAddress
will also be the FeeSourceAddress
, but you may choose to separate them. You may even choose a payout address that is not on your local wallet. If you do so, however, note that in order to submit the transaction to the network successfully, the FeeSourceAddress
must exist in the wallet that is submitting the transaction to the network. The payoutaddress
or the FeeSourceAddress
must have enough balance AND 1 GVT.credit to cover the transaction and registration fee. If there is insufficient balances of BYTZ or GVT.credit, the final register_submit
transaction will fail.
To generate a new PayoutAddress:
getnewaddress PayoutAddress
Example output:
sT5k3AZPvQ7Ky13LfVP6E8bjfurk2AtHre
Generate and fund another address as the “transaction fee source” (labelled as FeeSourceAddress
):
getnewaddress FeeSourceAddress
Example output:
sN71Hrp2Qtjn6tR39omdDnfDUMs1jYnmtw
Fund the FeeSourceAddress with at least .01 BYTZ and 1 GVT.credit to cover the registration and transaction fees
If the wallet is encrypted and locked, it must now be unlocked to perform the next commands:
walletpassphrase y0urSecretP455w0rd 600
Replace y0urSecretP455w0rd
with your own password (the one that you used to encrypt the wallet).
Note: “600
” in the command example is the amount of time in seconds that the wallet remains unlocked.
“ProRegTx” is a special transaction that must now be prepared with the command:
protx register_prepare
The command has the following syntax:
protx register_prepare collateralHash collateralIndex ipAndPort ownerKeyAddr operatorPubKey votingKeyAddr operatorReward payoutAddress feeSourceAddress
Open a text editor to prepare this command, replacing each syntax argument as follows:
collateralHash
: The txid of the 10,000,000 BYTZ collateral funding transaction
collateralIndex
: The output index of the 10,000,000 BYTZ funding transaction
ipAndPort
: Masternode IP address and port, in the format x.x.x.x:yyyy, where the IP address is the IP address of your remote masternode server (VPS), and the standard BYTZ Mainnet port is 37415. The standard BYTZ Testnet port is 47415.
ownerKeyAddr
: The new BYTZ address generated above for the owner/voting address.
If you own the private key connected to the ownerKeyAddr
(which is a public key), you can change the masternode's configuration, e.g. through the protx update_registrar command.
operatorPubKey
: The BLS public key generated above (or provided by your hosting service).
The operatorPrivKey
is added to the configuration file of the remote masternode node, and is used to demonstrate to the network that the remote masternode node acts on behalf of you, the owner of the operatorPubKey
.
votingKeyAddr
: The new BYTZ address generated above for owner/voting, or the address of a delegate, used for proposal voting and other functions.
The person owning the private key belonging to the votingKeyAddr
can vote on behalf of the masternode that is registered with this votingKeyAddr
.
operatorReward
: The percentage of the block reward allocated to the operator as payment. [Most users will choose 0, indicating that 100% of the reward will go to the payoutAddress
.]
payoutAddress
: A new or existing normal BYTZ address to receive the owner’s masternode rewards. Payouts are sent to the payoutAddress
. (If there is an operator reward, these payouts are deducted from the amount sent here, and sent to the operator instead.)
feeSourceAddress
: An (optional) address used to fund ProTx fee. When a feeSource Address is specified, the payoutAddress
will not be used for fees.
When sending this registration transaction to the BYTZ network (which you will do a bit later), you must pay a fee. If feeSourceAddress
is specified, the fee will be paid from this address.
Notes about the above keys and addresses:
ownerKeyAddr
must be unique (cannot be used for another masternode)
operatorPubKey
must be unique (cannot be used for another masternode)
ipAndPort
must be unique (cannot be used for another masternode)
Initially, the ownerKeyAddr
and votingKeyAddr
must be the same. Masternodes that are created later can specify a votingKeyAddr
that is different from the ownerKeyAddr
.
NOTE: This “protx register_prepare
” transaction, does not allow you to specify an operatorReward
payout address. If you enter a non-zero operatorReward
, you’ll need to follow up with another separate transaction called the “update_service transaction” that specifies a different operator payment address.
ProTx Register example:
protx register_prepare f292da56253b983d89c377460d46cacdffc2fa95b6c085463c99e6d19c12d851 1 72.80.492.390:27170 sLQ72uinxF95yxiTrpq9QM4uh1GgBGPSoa 99f20ed1538e28259ff80044982372519a2e6e4cdedb01c96f8f22e755b2b3124fbeebdf6de3587189cf44b3c6e7670e sLQ72uinxF95yxiTrpq9QM4uh1GgBGPSoa 0 sT5k3AZPvQ7Ky13LfVP6E8bjfurk2AtHre sN71Hrp2Qtjn6tR39omdDnfDUMs1jYnmtw
Example of transaction ID output from the protx register_prepare command
above:
{
"tx": "030001000175c9d23c2710798ef0788e6a4d609460586a20e91a15f2097f56fc6e007c4f8e0000000000feffffff01a1949800000000001976a91434b09363474b14d02739a327fe76e6ea12deecad88ac00000000d1010000000000e379580dcfea3eb6944bfbe1de5fa2317932e260acce4d9ff3ede5f4287a34160100000000000000000000000000ffff2d4ce6ef4e1fd47babdb9092489c82426623299dde76b9c72d9799f20ed1538e28259ff80044982372519a2e6e4cdedb01c96f8f22e755b2b3124fbeebdf6de3587189cf44b3c6e7670ed1935246865dce1accce6c8691c8466bd67ebf1200001976a914fef33f56f709ba6b08d073932f925afedaa3700488acfdb281e134504145b5f8c7bd7b47fd241f3b7ea1f97ebf382249f601a0187f5300",
"collateralAddress": "sXSjWXvRVPXcM9BavLAtJ3nYyviTrzHM8B",
"signMessage": "sXSjWXvRVPXcM9BavLAtJ3nYyviTrzHM8B|1|i84AChqrdED2FHEFBCV7dWgt0fEaaGAEao|cd58d7bc662d3667696e331f08308a29c45eb112d5eefff87b7866d1f5b387"
}
Next, to complete the composition of the transaction so that you can submit it, you will sign the transaction using the collateralAddress
and signMessage
fields with the output of the tx field.
Sign the ProRegTx transaction
The contents of the ProRegTx operation must now be signed to authorize the masternode instance with the signMessage
field for the collateral address detailed in the collateralAddress
entry.
The BYTZ wallet or another daemon instance is usually used to sign the transaction but signing can also be carried out from a hardware wallet. To sign from a hardware wallet, use the following command syntax:
signmessage collateralAddress signMessage
Or
“signmessage "collateralAddress" "signMessage"”
Note: In the syntax above, the first “signmessage
” is a command. “collateralAddress
” and the second instance of “signmessage
“ are both placeholders that you’ll need to replace with the collateral address and the output from the ProRegTx above.
Example:
signmessage sXSjWXvRVPXcM9BavLAtJ3nYyviTrzHM8B sXSjWXvRVPXcM9BavLAtJ3nYyviTrzHM8B|0|i0nFXhqrdDG1GZWKJAN6dQba6dZdgBGAip|ad5f82257bd00a5a1cb5da1a44a6eb8899cf096d3748d68b8ea6d6b10046a28e
Sample console output:
II8JvEBMj6I3Ws8wqxh0bXVds6Ny+7h5HAQhqmd5r/0lWBCpsxMJHJT3KBcZ23oUZtsa6gjgISf+a8GzJg1BfEg=
Submit the transaction:
The special masternode transaction we created now needs to be submitted to the BYTZ blockchain to register the masternode on the network. The command needs to be sent from an BYTZ wallet that holds the balance on either the feeSourceAddress
or payoutAddress
entries. A standard transaction fee is required (.0001 BYTZ).
This command uses the following syntax:
protx register_submit tx sig
Where:
tx
: The serialized transaction previously returned in the tx output field from the protx register_prepare command
sig
: The message signed with the collateral key from the signmessage command
Input example:
protx register_submit 030001000175c9d23c2710798ef0788e6a4d609460586a20e91a15f2097f56fc6e007c4f8e0000000000feffffff01a1949800000000001976a91434b09363474b14d02739a327fe76e6ea12deecad88ac00000000d1010000000000e379580dcfea3eb6944bfbe1de5fa2317932e260acce4d9ff3ede5f4287a3416010000000000000000000001100ffeef2d4ce6ef4e1fd47babdb9092489c82426623299dde76b9c72d9799f20ed1538e28259ff80044982372519a2e6e4cdedb01c96f8f22e755b2b3124fbeebdf6de3587189cf44b3c6e7670ed1935246865dce1accce6c8691c8466bd67ebf1200001976a914fef33f56f709ba6b08dd073932f925afedaa3700488acfdb281e134504145b5f8c7bd7b47fd241f3b7ea1f97ebf382249f601a0187f5300 II8JvEBMj6I3Ws8wqxh0bXVds6Ny+7h5HAQhqmd5r/0lWBCpsxMJHJT3KBcZ23oUZtsa6gjgISf+a8GzJg1BfEg=
Output example:
The following output example is the transaction ID for the command protx register_submit tx sig
dba8c22f8992d78fd4ff0c94cb19a5c30e62e7587ee43d5285296a4e6e5af062
After this operation has been performed, your masternode will be successfully registered on the network after the transaction has been mined and confirmed in a block.
You can view the list of masternodes in the command console using the command
protx list valid
The final transaction ID details will be your newly registered masternode.
You can check the status of the masternode with the following command:
masternode status
This command returns the status of your masternode. If your masternode is correctly configured and actively serving the BYTZ network, Congratulations!
BYTZ Masternode Components Worksheet
Copy this form to a text editor. Paste the content you will need as you generate it.
New masternodes are added by new special transactions called Provider Registration Transactions (abbreviated as ProRegTx). This guide gives you step-by-step instructions to create the ProRegTx, constructing the command in the following format.
protx register_prepare collateralHash collateralIndex ipAndPort ownerKeyAddr operatorPubKey votingKeyAddr operatorReward payoutAddress (feeSourceAddress)
This worksheet will help you gather the data you need to construct the ProRegTx.
IPandPort: Write down the IP address of your remote masternode server (VPS). The standard BYTZ port is 37415.
Collateral address: This is the address that holds exactly 10,000,000 BYTZ in a single unspent transaction.
Collateral address private key:
XXXXXXXXXXXXXXX
Do NOT paste the private key in the document editor.
Store it somewhere that no one else can access.
XXXXXXXXXXXXXXX
"transaction hash" for 10,000,000 BYTZ collateral (output from masternode outputs
command)
"output index" for the collateral transaction above
"secret" output from bls generate
command
operatorPubKey: This is the "public" output from bls generate
command.
ownerKeyAddr: This is the output from getnewaddress ownerKeyAddr
votingKeyAddr: This is the same as the ownerKeyAddress
as above)
feeSourceAddress: This is the output from feeSourceAddress
. This address must have BYTZ in it for the fee as well as the 1 GVT.credit token to be burned during the Masternode registration.
Builds
HOW TO: Compile the Bytz daemon from source
Bytz Guardian Validator Nodes
HOWTO: Bytz 2.0 GVT Quickstart Guide
HOWTO: Setup Bytz 2.0 remote Masternode with Ubuntu remote and local QT wallet
Bytz Currency Token System - ATP
Atomic Token Protocol (ATP) Overview
Bytz Token system Basic Operations
Create new token
Send tokens
Use Cases - Create new NFT
Token balance
View token information
Testing Bytz tokens on regtest
Start regtest
Access Token Management Key
Bytz Token group management
Key rotation with token authorities
Create and distribute the GVT token for starting a GVN
Create Management Tokens
Drop token mint capability
Find token authorities
General FAQ
HOWTO: Backup my wallet and its data
HOWTO: Backup Bytz coin blockchain database
HOWTO: Export private Keys from Bytz Qt
HOWTO: Import private key to Bytz 2.0 Wallet
User-Documentation
Accounts-Explained
Bytz currency data directory
Raw transactions
Running Bytz
Gitian
Gitian Building
Create Debian - VirtualBox
Create Debian - VMWare
Create Debian - Google Console
Setup Gitian - Debian - VirtualBox
Setup Gitian - Ubuntu - VirtualBox
Setup Gitian - Debian - Google Console
Bytz
Developer-Documentation
API-Calls-List
API-Reference-JSON-RPC