VFX Integration Setup
Summary
This document is intended to be used by all third-party integrators including, but not limited to, exchanges, third-party APIs, explorers, web tools/web wallets, and any other integrable products that the core CLI can connect to.
This document will outline the core CLI functions and give recommended practices. Please note that you should always follow the highest levels of security based on your own environment. This document is merely a guide to get you up and running.
Wallet Information
Currently VFX has both a GUI and CLI wallet. These wallets will run in all environments (windows, linux, and mac). The VFX Core was built with .Net 6 and C#. The VFX GUI was built with Flutter/Dart
.Net 6 can be found here: https://dotnet.microsoft.com/en-us/download/dotnet/6.0
The recommended IDE for VFX is Visual Studio 2022, or Visual Code.
It is recommended for production level environments to run the CLI and communicate through the API. For personal use the GUI wallet is more than suitable.
You can find pre-compiled binaries here:
CLI - https://github.com/VerifiedXBlockchain/VerifiedX-Core/releases
GUI - https://github.com/VerifiedXBlockchain/VerifiedX-GUI/releases
If you are wanting to build from source, please choose the correct repo from here: https://github.com/ReserveBlockIO
VFX wallet generates addresses based on the ECDSA curve.
Mainnet addresses start with an R
.
Testnet addresses start with an x
.
For the VFX P2P Layer, the wallet is using SignalR. More information on SignalR can be found here: https://dotnet.microsoft.com/en-us/apps/aspnet/signalr
For Beacons and Asset transfer the wallet is using its own modified version of a TCP listener with a socket handler. This allows the two functions to work together but not interfere with each at the same time.
The wallet is a multi-threaded application. Normal performance has been consistent with 2 CPU Cores - 2GB of ram. Any less than the recommended could result in slowed performance. An ideal setup is 3+ CPU Cores and 4 GB of ram. Your operating system will also determine this. As an example, Windows needing more resources you might want more, however a Linux with no GUI will require less.
The wallet main connection port 3338 must be configured to at least allow outgoing. If you do not want people connecting to you simply do not open that port for any incoming connections.
Compile your own CLI
If you are wanting to compile your own CLI from source here is how to do this.
The instructions below can be found here: Build Instructions
Linux
inux Install For Ubuntu 22.04:
sudo apt-get update && sudo apt-get install -y dotnet-sdk-6.0
sudo apt-get update && sudo apt-get install -y aspnetcore-runtime-6.0
- run
dotnet --version
. You should see a version number of 6.0.xxx mkdir rbx
- Makes a direction for RBX- cd rbx
- Clone the repo with git.
git clone https://github.com/VerifiedXBlockchain/VerifiedX-Core.git
- Download the already packaged release https://github.com/VerifiedXBlockchain/VerifiedX-Core/releases/. If you do this please navigate to the folder you downloaded binaries from and skip to step 12.
- Clone the repo with git.
cd ReserveBlock-Core
dotnet build
- There should be 0 (zero) errors.dotnet publish -c Release -r linux-x64 --output ./rbxpublished
Please note the
linux-x64
can be changed if you are on a different architecture like arm or x86.cd rbxpublished
dotnet ReserveBlockCore.dll
From here you are done. The wallet will be running. To turn on the API simple type ‘10’ and press enter or you can pass it in as a command argument.
dotnet ReserveBlockCore.dll enableapi
You are done! You should now see a wallet running! Some common errors are usually related to file permissions. Please ensure you have given proper permission to the newly created RBX folder
Windows
Install the latest dotnet sdk from here: https://dotnet.microsoft.com/en-us/download/dotnet/6.0 Once that is installed follow steps below.
Create a directory for RBX and then open command prompt in admin and navigate to that directory.
Please ensure you have a working version of git installed.
- Clone the repo with git.
git clone https://github.com/VerifiedXBlockchain/VerifiedX-Core.git
- Download the already packaged release https://github.com/VerifiedXBlockchain/VerifiedX-Core/releases/. If you do this please navigate to the folder you downloaded binaries from and skip to step 8.
- Clone the repo with git.
cd ReserveBlock-Core
dotnet build
- There should be 0 (zero) errors.dotnet publish -c Release -r win-x64 --output ./rbxpublished
please note the
win-x64
can be changed if you are on a different architecturecd rbxpublished
dotnet ReserveBlockCore.exe
Mac OS X
- Install the latest dotnet sdk from here: https://dotnet.microsoft.com/en-us/download/dotnet/6.0 Once that is installed follow steps below.
- Create a directory for RBX and then open command prompt in admin and navigate to that directory.
- Please ensure you have a working version of git installed.
- Clone the repo with git.
git clone https://github.com/VerifiedXBlockchain/VerifiedX-Core.git
- Download the already packaged release https://github.com/VerifiedXBlockchain/VerifiedX-Core/releases/. If you do this please navigate to the folder you downloaded binaries from and skip to step 8.
- Clone the repo with git.
cd ReserveBlock-Core
dotnet build
- There should be 0 (zero) errors.dotnet publish -c Release -r osx-x64 --output ./rbxpublished
please note the 'osx-x64' can be changed if you are on a different architecture like arm.
cd rbxpublished
dotnet ReserveBlockCore
, sometimes dotnet ReserveBlockCore.dll. Just depends on the current environment setup.
Wallet Config Setup
Summary
The point of this paper is to outline the config file setup and features it has.
Port (default is 3338)
- Type
int
- Ex:
Port=3338.
- This is the port for all p2p functions. This should remain as 3338.
- Type
APIPort (default is 7292)
- Type
int
- Ex:
APIPort=7292
- This is the port to call the API. This may be changed to whatever you want.
- Type
WalletPassword (default is null)
- Type
string
- Ex:
WalletPassword=SomePassword1234!
- This is a password that will lock all functions in wallet and require you input a password to unlock wallet functions.
- Type
AlwaysRequireWalletPassword (default is false)
- Type
boolean
- Ex:
AlwaysRequireWalletPassword=true
- If set to true you will be required to input password before every function call.
- Type
APIPassword (default is null)
- Type
string
- Ex:
APIPassword=SomePassword1234!
- This is a password set to lock down control of the API. This password must be inputted to call any API function.
- You will need to call UnlockWallet to unlock the API with this password.
- Type
AlwaysRequireAPIPassword (default is false)
- Type
boolean
- Ex:
AlwaysRequireAPIPassword=true
- If set to true then you must include the password in all API request.
- Type
APICallURL (default is null)
- Type
string
- Ex:
APICallURL=https://mycallbackurl.com
- This URL is used to send incoming transactions to an outside URL. This is something used for like incoming deposits or other notification. services.
- Type
WalletUnlockTime (default is 15)
- Type
int
- Ex:
WalletUnlockTime=5
- This is the amount of time once a password has been entered the wallet will remain unlocked and not need password again. If any of the RequirePasswords above are set to true, then it will override this setting and require the password everytime.
- Type
ChainCheckPoint (default is false)
- Type
Boolean
- Ex: ChainCheckPoint=true
- This is a feature that will turn on chain check points. What this will do is create a FULL copy of the chains state and back it up and create a checkpoint you can revert back to in the event your current structure becomes corrupted.
- Type
ChainCheckPointInterval (default is 12)
- Type
int
- Ex:
ChainCheckPointInterval=4
- This interval is in hours and means it will run the checkpoint every X amount of hours with 1 being the smallest allowed.
- Type
ChainCheckPointRetain (default is 2)
- Type
int
- Ex:
ChainCheckPointRetain=4
- Retain is what will determine how many backups to keep before it will begin to remove the oldest backup to make room for new one.
- Type
ChainCheckPointLocation (default is default path)
- Type
string
- Ex:
ChainCheckPointLocation=C:\somelocation\otherthan\default\
- If the default path is not wanted you can setup a new location for them to go to.
- Type
APICallURLLogging (default is false)
- Type
Boolean
- Ex:
APICallURLLogging=true
- This will debug the API call URL in the event there is an issue with TX’s being sent to your URL. This is recommended to be turned on during the initial testing of your URL.
- Type
ValidatorAddress (default is null)
- Type
string
- Ex:
ValidatorAddress=RBcHyS2AF4Z4jgzTLZNBVLvtxQ6MtB2vUN
- You can input a default validator address to instantly start validating. Please note you must also import the wallet address through the launch commands. Ex: ReserveBlockCore.exe privKey=MyPrivateKey.
- Type
ValidatorName (default is new guid)
- Type
string
- Ex:
ValidatorName=MyValidatorRBX1
- This is the name for the above validator that will be used. Once validator has been imported once then these settings won’t do anything and can be removed or left there.
- Type
NFTTimeout (default is 15 secs)
- Type
int
- Ex:
NFTTimeout=5
- This will control the timeout for processing an incoming NFT
- Type
PasswordClearTime (default is 10 mins)
- Type
int
- Ex:
PasswordClearTime=5
- This will control the clear time for an ecrypted wallets password
- Type
AutoDownloadNFTAsset (default is true)
- Type
Boolean
- Ex:
AutoDownloadNFTAsset=false
- This will control whether or not an NFT's asset is automatically downloaded
- Type
IgnoreIncomingNFTs (default is false)
- Type
Boolean
- Ex:
IgnoreIncomingNFTs=false
- This will control whether or not incoming NFTs are processed or just added as a TX record
- Type
RejectAssetExtensionTypes (default is a List of rejected assets)
- Type
List of string
- Ex:
RejectAssetExtensionTypes=exe,zip,pdf...
(ensure there are no spaces between types) --This will add extension types to the already defined list and will reject any NFT assets with these known extension types
- Type
AllowedExtensionsTypes (default is null)
- Type
List of string
- Ex:
AllowedExtensionsTypes=pdf,doc,xls
- This will remove extension types to the already defined list and will allow any NFT assets with these known extension types to be downloaded
- Type
An example config setup could appear like this:
This information is updated whenever new features are added and can be found here: https://github.com/VerifiedXBlockchain/VerifiedX-Core/blob/main/ConfigSetup.md
RPC Interface Connection
Mainnet : http://localhost:7292/
TestNet: http://localhost:17292/
The ports above can be changed in the config document.
The config setting is APIPort=[Insert new Port number, no brackets]
Example: APIPort=1337
The default ports are:
Mainnet : 7292 Testnet : 17292
There are five total API endpoints in the core CLI. They are as follows:
- Beacons - /bcapi/BCV1
- Smart Contracts - /scapi/SCV1
- Transactions - /txapi/TXV1
- General - /api/V1
- Voting - /voapi/VOV1
RPC Interface Config
Before interfacing with RPC You will want to ensure you have the config settings you desire.
The main config options are the following:
- APIPort
- Changes default API port to something else
APIPort=1337
- APIPassword
- Creates an API password to access all endpoints. Password is stored for 15 minutes or whatever is specified in WalletUnlockTime
APIPassword=SomePassword123!
- AlwaysRequireAPIPassword
- This makes the password required for every call regardless of WalletUnlockTime
AlwaysRequireAPIPassword=true
- APICallURL
- This is a custom URL that whenever a transaction is received will be called to deliver this information
APICallURL=http://somecustomurl.com/api/
- WalletUnlockTime
- Sets the time a password will keep the wallet unlocked when entered in minutes
WaleltUnlockTime=5
RPC Interface
The RBX Core CLI uses a json based interface. You will want to create some type of Http client request and send “application/json” to the interface. From there you will want to await a result (post) from the client.
The best way to test the interface is to use Swagger.
The swagger location can be found here:
Mainnet: http://localhost:7292/swagger/index.html Testnet: http://localhost:17292/swagger/index.html Each API Endpoint has a list of methods with a description. Some of the most commonly used endpoints are as follows:
/api/V1/
CheckStatus
CheckPasswordNeeded
GetIsWalletEncrypted
GetIsEncryptedPasswordStored
GetEncryptWallet/{password}
GetDecryptWallet/{password}
GetEncryptLock
GetCLIVersion
GetWalletInfo
GetAllAddresses
GetValidatorAddresses
getgenesisblock
ImportPrivateKey
GetNewAddress
SendTransaction/{from}/{to}/{amount}
StartValidating/{address}/{username}
TurnOnValidator/{id}
TurnOffValidator/{id}
GetValidatorInfo/{address}
SendBlock/{height}
GetMasternodes
GetPeerInfo
GetDebugInfo
GetRollbackBlocks/{id}
SendExit
ClearRBXLog
ChangeValidatorName/{name}
===================
/voapi/VOV1/
GetAllTopics
GetActiveTopics
GetInactiveTopics
GetMyTopics
GetSearchTopics/{search}
GetTopicDetails/{topicUid}
GetMyVotes
GetTopicVotes/{topicUid}
CastTopicVote/{topicUid}/{vote}
===================
/scapi/scv1/
GetAllSmartContracts
GetAllSmartContracts/{page}/{search}
GetMintedSmartContracts/{page}/{search}
GetSingleSmartContract/{id}
ChangeNFTPublicState/{id}
GetSmartContractData/{id}
CreateSmartContract
MintSmartContract/{id}
TransferNFT/{id}/{address}
TransferNFT/{id}/{address}/{url}
EvolveSpecific/{id}/{address}/{stage}
Burn/{id}
AssociateNFTAsset/{id}/{path}
DownloadNftAssets/{id}
GetNFTAssetLocation/{id}/{filename}
===================
/bcapi/BCV1/
GetBeacons
AddBeacon/{name}/{port}/{ip}
CreateBeacon/{name}/{port}
DeleteBeacon/{id}
====
/txapi/txV1/
CreateAdnr/{address}/{name}
TransferAdnr/{from}/{to}/
DeleteAdnr/{address}
Example
A short example would be as followed (C#)
HttpClient client = new HttpClient();
string json = JsonConvert.SerializeObject(mainSc).Dump();
var httpContent = new StringContent(json, Encoding.UTF8, "application/json");
var httpResponse = await client.PostAsync("http://localhost:7292/api/V1/CheckStatus", httpContent);
var responseString = await httpResponse.Content.ReadAsStringAsync();
This results in the following: a response body of Online
The curl example is as follows:
curl -X 'GET' \
'http://localhost:7292/api/V1/CheckStatus' \
-H 'accept: text/plain'
Another basic example in Go is a follows:
package main
import (
"fmt"
"net/http"
"io/ioutil"
"os"
)
func main() {
response, err := http.Get("http://localhost:7292/api/v1/CheckStatus")
if err != nil {
fmt.Printf("%s", err)
os.Exit(1)
} else {
defer response.Body.Close()
contents, err := ioutil.ReadAll(response.Body)
if err != nil {
fmt.Printf("%s", err)
os.Exit(1)
}
fmt.Printf("%s\n", string(contents))
}
}
Testnet Information
Testnet Information Testnet can be activated two ways:
- Passing in testnet as an argument when starting a wallet.
- Ex:
reserveblockcore.exe testnet
- Ex:
- Enabling it in the config.
- Ex:
TestNet=true
- Ex:
Please be sure you are on testnet so as to not make any mistakes with your mainnet accounts.
VFX addresses on testnet will ALWAYS start with an x
. For Example:
xC1zNn7596TC4Bcyn1vE88pj12hfieqCoa
The primary testnet faucet will come from this address (subject to change): xMpa8DxDLdC9SQPcAFBc2vqwyPsoFtrWyC
There are three ways to get funds from the faucet:
- Message the discord channel titled
Testnet Faucet
with your VFX address and funds will be sent. - Reach out to your point of contact through your current chat tool (telegram, skype, email, etc.) and ask them to send funds to a request testnet address.
- Use the testnet faucet via the explorer (https://spyglass-testnet.verifiedx.io/faucet)
It is advised to begin with testnet to ensure all functions are working with your environment before moving over to mainnet.
The CLI
The VFX CLI is recommended for most enterprise or third-party integrators as it runs headless and the most efficiently.
The CLI is still rather robust and the main menu options are seen above, and more options can be discovered by typing /help and pressing enter.
For example: Once a CLI is started you may type commands at any point and time and interact with the wallet and not need to worry about stopping any of the background processes. Closing the wallet is the only thing to stop all functions.
The wallet must be left open for items to continue running. If using Linux and SSH it is recommended to use screen or other tool to keep it running.
Screen example: screen dotnet ReserveBlockCore.dll
ctrl A & ctrl D
to detach from the screen session.
when returning to return you type
screen -r
and press enter.
Third Party Interfacing for Exchanges and other Entities
Summary
This section will outline the best practices for setting up an VFX wallet in your environment. While many of these features are optional it is recommended to leverage as many, if not all, as you can.
The section will cover the config.txt setup, password setup, and how to use the API in some common and general scenarios that will fit most environments.
The VFX Architecture very closely follows the philosophies and principles of Bitcoin so integration will also very similarly mimic that. This was done by design to ease the burden of the solution and the fact it is a layer 1.
Build the Project
Depending on your environment you will find build instructions for Windows, Linux, and Mac here: https://github.com/VerifiedXBlockchain/VerifiedX-Core/blob/main/RBXBuildInstructions.md
Follow the instructions and you can either build the project from source to ensure you are receiving a clean version of the program, or you can build from a binary posted in the release section here: https://github.com/VerifiedXBlockchain/VerifiedX-Core/releases
Configuration File Setup (Config.txt)
A full list of configuration options can be seen here: https://github.com/VerifiedXBlockchain/VerifiedX-Core/blob/main/ConfigSetup.md
First you want to start up the wallet to generate a stock configuration file. Depending on your environment it will be located in the same folder the database folder is.
First thing is to change the APIPort and set an APIPassword. You can choose to require the API password always, or if you don’t the API is set to stay unlocked for 15 minutes by default. You can change that with the WalletUnlockTime command.
You can also configure a wallet password here as well if you plan to feed commands directly into the CLI. An example could look like this:
These are the most relevant config options:
Port (default is 3338)
- Type int
- Ex:
Port=3338.
- This is the port for all p2p functions. This should remain as 3338.
APIPort (default is 7292)
- Type int
- Ex:
APIPort=7292
- This is the port to call the API. This may be changed to whatever you want.
WalletPassword (default is null)
- Type string
- Ex:
WalletPassword=SomePassword1234!
- This is a password that will lock all functions in the wallet and require you input a password to unlock wallet functions.
AlwaysRequireWalletPassword (default is false)
- Type boolean
- Ex:
AlwaysRequireWalletPassword=true
- If set to true you will be required to input a password before every function call.
APIPassword (default is null)
- Type string
- Ex:
APIPassword=SomePassword1234!
- This is a password set to lock down control of the API. This password must be inputted to call any API function.
AlwaysRequireAPIPassword (default is false)
- Type boolean
- Ex:
AlwaysRequireAPIPassword=true
- If set to true then you must include the password in all API request.
APICallURL (default is null)
- Type string
- Ex:
APICallURL=https://mycallbackurl.com
- This URL is used to send incoming transactions to an outside URL. This is something used for incoming deposits or other notifications. services.
WalletUnlockTime (default is 15)
- Type int
- Ex:
WalletUnlockTime=5
- This is the amount of time once a password has been entered the wallet will remain unlocked and not need a password again. If any of the RequirePasswords above are set to true, then it will override this setting and require the password every time.
Optional APICallURL
You can also set up an APICallURL. This will be a URL you input that the VFX wallet upon receiving any new incoming transaction the wallet will call out to this URL sending a json response following the transaction model. This will allow you to easily get incoming transactions in real time and immediately.
Setting Up Wallet & Private Key Encryption
You can set up a wallet simply by opening the VFX wallet. From there you can generate an infinite number of addresses or set up a 24 word mnemonic to create an HD wallet.
Recommend you backup your phrase offline or create it in an air gapped environment. It is strongly recommended you encrypt your private keys. This will protect you if your database files are stolen they will not be able to access funds as the private keys will be encrypted. To encrypt your private keys simply call the /encrypt in the wallet and follow the instructions. It will have you type in a password twice, to ensure it is correct. 1000 addresses will be auto generated at the start. Should more be needed, that is fine.
The only time you need to type a password in is when you want to do something with a private key. The two main functions are sending a transaction or signing a message. This process is very similar to Bitcoin and if you are already doing this then you won’t feel any difference. When you type in your password it is stored as a SecureString for 10 minutes, unless specified otherwise. After 10 minutes Garbage collection is called and it is both cleared from the application as well as the system RAM.
General Use
rom here how you integrate to your application or systems is dependent on your current environment. The Swagger endpoint has all the APIs needed for integrating and all use cases. If you are an exchange one possible route is to do the following:
- Generate all your deposit addresses
- Store the addresses in memory in a list.
- Every 30-60 seconds perform a check
- Check each new block against the list stored in step 2 and see if any incoming transactions exist. If so then you have a new deposit
- Keep a list of all TX hashes and then run a scan against the last time checked with a timestamp and if any next hashes exist that you don’t have stored then you also know you have a new deposit.
- Credit the account associated with the deposit address.
- For withdrawals simply verify funds against your own DB and execute a SendTransaction/ API call.
The above example is a simple use case for processing incoming deposits. If your environment has any special needs they obviously would be added in, but the above model does work.
You can attempt to use the APICallURL which will send a new TX everytime one is detected, but only from a deposit perspective as a withdrawal would not make sense.
If you have any needs or specific questions it's recommended to reach out over discord or the current chat tool you are using like telegram, skype, email, etc.
Conclusion
This document will get most integrations started in the right direction, however, please don’t hesitate to reach out to the VFX community and devs through discord or if you are currently talking to anyone through other social channels please reach out to them there with any questions.