Login as root and do
mkdir -p ~/.ssh
echo "your ssh-rsa key" >> ~/.ssh/authorized_keys
chmod 600 ~/.ssh/authorized_keys
Install git, sudo and bash if it not installed (FreeBSD)
For FreeBSD make a link
ln -s /usr/local/bin/bash /bin/bash
Then add ordinary user with name as you wish (for example "svt") and do
# FOR LINUX :
echo "svt ALL=(ALL:ALL) NOPASSWD:ALL" >> /etc/sudoers
cp -r /root/.ssh /home/svt/
chown -R svt:svt /home/svt/.ssh
# =============================================
# For FreeBSD :
echo "svt ALL=(ALL:ALL) NOPASSWD:ALL" >> /usr/local/etc/sudoers
cp -r /root/.ssh /home/svt/
chown -R svt:svt /home/svt/.ssh
Setup your host name, timezone and firewall, update your system core and packs.
If you have separate disk for database, prepare it and mount to /var/ton-work (default). You can change it in env.sh
NB!! Double check if time sync is enabled.
First of all you have to set the follow environment variables for certain network at the beginning of $HOME/custler.uninode/scripts/env.sh:
export NETWORK_TYPE="fld.ton.dev" # can be main.* / net.* / fld.* / rustnet.*
export STAKE_MODE="depool" # can be 'msig' or 'depool'
export MAX_FACTOR=3
export MSIG_FIX_STAKE=45000 # fixed stake for 'msig' mode (tokens). if 0 - use whole stake
export VAL_ACC_INIT_BAL=95000 # Initial balance on validator account for full balance staking (if MSIG_FIX_STAKE=0)
export VAL_ACC_RESERVED=50 # Reserved amount staying on msig account in full staking mode
export TIK_REPLANISH_AMOUNT=5 # If Tik acc balance less 2 tokens, It will be auto topup with this amount
export LC_Send_MSG_Timeout=20 # time after Lite-Client send message to BC in seconds
To build node run ./Nodes_Build.sh from $HOME/custler.uninode/scripts/ folder. This script will build all binaries needed and has 3 options:
./Nodes_Build.sh # build both C++ and Rust nodes
./Nodes_Build.sh rust # build Rust node and tools
./Nodes_Build.sh cpp # build C++ node and tools
This script also build tonos-cli, tvm_linker, solc (Solidity compiler) from the respective repositories , from master branch. You can set commit number in "# GIT addresses & commits " section in 'env.sh'
After success build all executable files will be placed to $HOME/bin directory
All you needs to setup your node - run ./Setup.sh script from $HOME/custler.uninode/scripts/ folder. This script has no options and does the follow:
- remove old databases and logs if any
- create all needed dirs
- set proper url in tonos-cli config file
- setup logrotate service
- setup new keys for node
- setup service tonnode to run node as service
- generates 3 accounts and place files to $HOME/ton-keys
Setup.sh generates 3 accounts file sets:
- depool account files in
$HOME/DPKeys
- validator msig (SafeCode) account files in
$HOME/MSKeys_${HOSTNAME}
with 3 custodians - Tik (SafeCode) account files in
$HOME/MSKeys_Tik
- Safe msig with 1 custodian for tik-tok depool - finally, script place files to
$HOME/ton-keys/
` if it hasn't same files already
If you have not any accounts before, you can use just generated accounts. If you already has your accounts files in $HOME/ton-keys/
` it will NOT be replaced.
After Setup script successfully finished, you can start node by starting it service:
- service tonnode start for FreeBSD
- sudo service tonnode start for Linux (CentOS / Ubuntu)
Then you can check node syncronizanion with the blockchain:
./check_node_sync_status.sh
This script looped and will show you sync status every 1 min by default. It has 1 parameter - frequency of showing status in seconds:
./check_node_sync_status.sh 10 # show info every 10 secs
NB! On first start sync can start after some time, up to 30-60 mins
In FLD network where is free giver called "Marvin". You can ask him for test 100K tokens once for each account. For example, for you validator msig (${KEYS_DIR}/${DST_NAME}.addr
) you can use script Get_tokens_from_Marvin.sh
To deploy your validator main account, after receved tokens on it, use MS-Wallet_deploy.sh
script. By default, it has 3 custodians and 2 is enought to sign a transaction
MS-Wallet_deploy.sh $VALIDATOR_NAME Safe 3 2
First of all we to have set DePool parametrs at the beginnig of deploy script DP4_depool_deploy.sh
ValidatorAssuranceT=10000 # Assurance in tokens
MinStakeT=10 # Min DePool assepted stake in tokens
ParticipantRewardFraction=95 # In % participant share from reward
BalanceThresholdT=20
These parametrs cannot be changed after deploy the DePool.
All about Depool you can find in Run DePool v3
To send initial balance to DePool account use script transfer_amount.sh
./transfer_amount.sh $VALIDATOR_NAME depool 50 new
where:
$VALIDATOR_NAME
- file name of${VALIDATOR_NAME}.addr
file with address of your msigdepool
- file name ofdepool.addr
file with address of your DePool- 50 - initial balance for deploy depool
- new - set transaction flag
bounce
to false to tranfer tokens to undeployed address
next we have to sign the transaction by script Sign_Trans.sh
./Sign_Trans.sh
Now you can deploy the DePool contract by
./DP4_depool_deploy.sh
For tik-tok DePool action we use separate SafeCode msig account with 1 custodian and address in ${KEYS_DIR}/Tik.addr
file
To deploy Tik smartcontract use the same script as for msig
./transfer_amount.sh $VALIDATOR_NAME Tik 10 new
./Sign_Trans.sh
./MS-Wallet_deploy.sh Tik Safe 1 1
Simple way to send stake to the depool is ordinary stake to each round. Do follow before first elections for first round:
. ./env.sh
$CALL_TC depool --addr $(cat ${KEYS_DIR}/depool.addr) stake ordinary --wallet $(cat ${KEYS_DIR}/${VALIDATOR_NAME}.addr) --sign ${KEYS_DIR}/${VALIDATOR_NAME}.keys.json --value 30000
./Sign_Trans.sh
And do the same just after sent stake to the elector.
More complex is to set lock stake. It will be automatically divide halfly for two rounds. Before elections start do the follow:
. ./env.sh
$CALL_TC depool --addr $(cat ${KEYS_DIR}/depool.addr) stake ordinary --wallet $(cat ${KEYS_DIR}/${VALIDATOR_NAME}.addr) --sign ${KEYS_DIR}/${VALIDATOR_NAME}.keys.json --value 30000
./Sign_Trans.sh
Donor_Addr=$(cat ${KEYS_DIR}/Donor.addr) # should not be your validator address
$CALL_TC depool --addr $(cat ${KEYS_DIR}/depool.addr) donor vesting --wallet $(cat ${KEYS_DIR}/${VALIDATOR_NAME}.addr) --donor "$Donor_Addr" --sign ${KEYS_DIR}/${VALIDATOR_NAME}.keys.json
./Sign_Trans.sh
$CALL_TC depool --addr $(cat ${KEYS_DIR}/depool.addr) stake lock --wallet $(cat ${KEYS_DIR}/Donor.addr) --total 365 --withdrawal 365 --beneficiary $(cat ${KEYS_DIR}/${VALIDATOR_NAME}.addr) --sign ${KEYS_DIR}/Donor.keys.json --value 60000
./Sign_Trans.sh Donor
./prepare_elections.sh
# For remove your ordinary stake do
$CALL_TC depool --addr $(cat ${KEYS_DIR}/depool.addr) withdraw on --wallet $(cat ${KEYS_DIR}/${VALIDATOR_NAME}.addr) --sign ${KEYS_DIR}/${VALIDATOR_NAME}.keys.json
./Sign_Trans.sh
After a few minutes from elections start, we have to prepare the DePool by prepare_elections.sh
script
./prepare_elections.sh
In case of depool validation mode, this script checks balance of Tik account and topup it if it less 2 tokens. Then it send tik-tok transaction from Tik to DePool.
./take_part_in_elections.sh
This script prepare all nesessary steps to prepare bid transaction for election and call Sign_Trans.sh
to sign and send message to DePool with keys for validating
To check your participation status in currrent election use part_check.sh
During elections it will show your ADNL and stake amount. And between elections it will show your ADNL and % yours stake of total stake in the elector
To set all above scripts to run in time for further elections use script next_elect_set_time.sh
`
It has 2 main parametrs inside:
DELAY_TIME=0 # Delay time from the start of elections
TIME_SHIFT=600 # Time between sequential scripts
DELAY_TIME
- Time in seconds from a elections start and between scripts runDELAY_TIME
- additional timeshift in seconds from the elections start
NB! crontab has not seconds precision, only minutes, so for proper use these numbers MUST be divisible by 60
After run this script it set itself to crontab and will be run after all scripts in each elections
You can setup your Telegram chat to receive alerts and info in file TlgChat.json
like this:
{
"telegram_bot_token": "5xxxxxxx:Axxxxxxxxxxxxxxxxxxxxxx",
"telegram_chat_id": "-100xxxxxxxxxx"
}
For monitoring timediff of your node you can run script tg_check_node_sync_status.s
in tmux, for example:
cd $HOME/custler.uninode/scripts
tmux new -ds tg
tmux send -t tg.0 './tg_check_node_sync_status.sh &' ENTER
After that, if timediff will be more 100 secs or the node goes down you will receive message to you telegram channel.
part_check.sh
script called from crontab will notify you about elections result to the same channel.
prepare_elections.sh
and take_part_in_elections.sh
will notify you if they will have some problems
Not finished..
... to be continue