Validator Management Contract
endrmng.sat
Actions
Add evm proxy account
Delete evm proxy account
Add whitelist (
proxyregorevmcaller)Delete whitelist (
proxyregorevmcaller)Staking, unstaking, changing staking, and claiming rewards on native chains and EVM
Validator claiming rewards
Batch allocation of validator rewards from rwddist.xsat
Quickstart
# setdonateacc @endrmng.xsat
$ cleos push action endrmng.xsat setdonateacc '{"donation_account": "alice", "min_donate_rate": 2000}' -p endrmng.xsat
# setdonate @validator
$ cleos push action endrmng.xsat setdonate '{"validator": "alice", "donate_rate": 100}' -p alice
# addevmproxy @endrmng.xsat
$ cleos push action endrmng.xsat addevmproxy '{"caller": "caller1", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5"}' -p endrmng.xsat
# delevmproxy @endrmng.xsat
$ cleos push action endrmng.xsat delevmproxy '{"caller": "caller1", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5"}' -p endrmng.xsat
# addcrdtproxy @endrmng.xsat
$ cleos push action endrmng.xsat addcrdtproxy '{"proxy": "e4d68a77714d9d388d8233bee18d578559950cf5"}' -p endrmng.xsat
# delcrdtproxy @endrmng.xsat
$ cleos push action endrmng.xsat delcrdtproxy '{"proxy": "e4d68a77714d9d388d8233bee18d578559950cf5"}' -p endrmng.xsat
# addwhitelist @endrmng.xsat type = ["proxyreg", "evmcaller"]
$ cleos push action endrmng.xsat addwhitelist '{"type": "proxyreg", "account": "alice"}' -p endrmng.xsat
# delwhitelist @endrmng.xsat type = ["proxyreg", "evmcaller"]
$ cleos push action endrmng.xsat delwhitelist '{"type": "proxyreg", "account": "alice"}' -p endrmng.xsat
# setstatus @endrmng.xsat
$ cleos push action endrmng.xsat setstatus '{"validator": "alice", "disabled_staking": true}' -p endrmng.xsat
# regvalidator @validator
$ cleos push action endrmng.xsat regvalidator '{"validator": "alice", "financial_account": "alice"}' -p alice
# proxyreg @proxy
$ cleos push action endrmng.xsat proxyreg '{"proxy": "alice", "validator": "alice", "financial_account": "alice"}' -p alice
# config @validator decimal = 10000
$ cleos push action endrmng.xsat config '{"validator": "alice", "commission_rate": 2000, "financial_account": "alice"}' -p alice
# stake @staking.xsat
$ cleos push action endrmng.xsat stake '{"staker": "alice", "validator": "alice", "quantity": "0.00000020 BTC"}' -p staking.xsat
# unstake @staking.xsat
$ cleos push action endrmng.xsat unstake '{"staker": "alice", "validator": "alice", "quantity": "0.00000020 BTC"}' -p staking.xsat
# newstake @staker
$ cleos push action endrmng.xsat newstake '{"staker": "alice", "old_validator": "alice", "new_validator": "bob", "quantity": "0.00000020 BTC"}' -p alice
# claim @staker
$ cleos push action endrmng.xsat claim '{"staker": "alice", "validator": "alice"}' -p alice
# evmstake @auth scope is `evmcaller` evmproxies account
$ cleos push action endrmng.xsat evmstake '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "validator": "alice", "quantity": "0.00000020 BTC"}' -p alice
# evmunstake @auth scope is `evmcaller` evmproxies account
$ cleos push action endrmng.xsat evmunstake '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "validator": "alice", "quantity": "0.00000020 BTC"}' -p evmutil.xsat
# evmnewstake @auth scope is `evmcaller` evmproxies account
$ cleos push action endrmng.xsat evmnewstake '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "old_validator": "alice", "new_validator": "bob", "quantity": "0.00000020 BTC"}' -p evmutil.xsat
# evmclaim @caller whitelist["evmcaller"]
$ cleos push action endrmng.xsat evmclaim '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "validator": "alice"}' -p evmutil.xsat
# evmclaim2 @caller whitelist["evmcaller"]
$ cleos push action endrmng.xsat evmclaim2 '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "validator": "alice", "donate_rate": 100}' -p evmutil.xsat
# vdrclaim @validator
$ cleos push action endrmng.xsat vdrclaim '{"validator": "alice"}' -p alice
# distribute @rwddist.xsat
$ cleos push action endrmng.xsat distribute '{"height": 840000, [{"validator": "alice", "staking_rewards": "0.00000020 XSAT", "consensus_rewards": "0.00000020 XSAT"}]}' -p rwddist.xsat
# stakexsat
$ cleos push action endrmng.xsat stakexsat '{"staker": "alice", "validator": "alice", "quantity": "0.00000020 XSAT"}' -p xsatstk.xsat
# unstakexsat
$ cleos push action endrmng.xsat unstakexsat '{"staker": "alice", "validator": "alice", "quantity": "0.00000020 XSAT"}' -p xsatstk.xsat
# restakexsat
$ cleos push action endrmng.xsat restakexsat '{"staker": "alice", "old_validator": "alice", "new_validator": "bob", "quantity": "0.00000020 XSAT"}' -p alice
# evmstakexsat @auth scope is `evmcaller` evmproxies account
$ cleos push action endrmng.xsat evmstakexsat '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "validator": "alice", "quantity": "0.00000020 XSAT"}' -p evmutil.xsat
# evmunstkxsat @auth scope is `evmcaller` evmproxies account
$ cleos push action endrmng.xsat evmunstkxsat '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "validator": "alice", "quantity": "0.00000020 XSAT"}' -p evmutil.xsat
# evmrestkxsat @auth scope is `evmcaller` evmproxies account
$ cleos push action endrmng.xsat evmrestkxsat '{"caller": "evmutil.xsat", "proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "old_validator": "alice", "new_validator": "bob", "quantity": "0.00000020 XSAT"}' -p evmutil.xsat
# creditstake @auth custody.xsat
$ cleos push action endrmng.xsat creditstake '{"proxy": "e4d68a77714d9d388d8233bee18d578559950cf5", "staker": "bbbbbbbbbbbbbbbbbbbbbbbb5530ea015b900000", "validator": "alice", "quantity": "0.00000020 XSAT"}' -p custody.xsat
# newregvalidator @auth validator
$ cleos push action endrmng.xsat newregvldtor '{"validator": "alice", "role": 0, "stake_addr": "e4d68a77714d9d388d8233bee18d578559950cf5", "reward_addr": "e4d68a77714d9d388d8233bee18d578559950cf5", "commission_rate": 2000}' -p alice
# evmconfigvald @auth validator
$ cleos push action endrmng.xsat evmconfigvald '{"validator": "alice", "commission_rate": 2000, "donate_rate": 100}' -p alice
# evmsetstaker @auth validator
$ cleos push action endrmng.xsat evmsetstaker '{"validator": "alice", "stake_addr": "e4d68a77714d9d388d8233bee18d578559950cf5"}' -p alice
# setrwdaddr @auth validator
$ cleos push action endrmng.xsat setrwdaddr '{"validator": "alice", "reward_addr": "e4d68a77714d9d388d8233bee18d578559950cf5"}' -p alice
# setstakebase @auth get_self()
$ cleos push action endrmng.xsat setstakebase '{"xsat_base_stake": "2100 XSAT", "btc_base_stake": "100 BTC"}' -p endrmng.xsat
# updcreditstk @auth get_self()
$ cleos push action endrmng.xsat updcreditstk '{"is_close": true}' -p endrmng.xsat
# endorse @auth BLOCK_ENDORSE_CONTRACT
$ cleos push action endrmng.xsat endorse '{"validator": "alice", "height": 840000}' -p block_endorse.xsatTable Information
TABLE globalid
globalidscope
endrmng.sat
params
{uint64_t} staking_id- the latest staking id
example
TABLE config
configscope
endrmng.sat
params
{string} donation_account- the account designated for receiving donations{binary_extension<uint16_t>} min_donate_rate- minimum donation rate
example
TABLE whitelist
whitelistscope proxyreg or evmcaller
proxyreg or evmcallerparams
{name} account- whitelist account
example
TABLE evmproxies
evmproxiesscope
whitelist of type evmcaller
params
{uint64_t} id- evm proxy id{checksum160} proxy- evm proxy account
example
TABLE creditproxy
creditproxyscope
the account whose scope is evmcaller in the whitelist table
params
{uint64_t} id- evm proxy id{checksum160} proxy- evm proxy account
example
TABLE evmstakers
evmstakersscope
endrmng.sat
params
{uint64_t} id- evm staker id{checksum160} proxy- proxy account{checksum160} staker- staker account{name} validator- validator account{asset} quantity- total number of staking{asset} xsat_quantity- the amount of XSAT tokens staked{asset} total_donated- the total amount of XSAT that has been donated{uint64_t} stake_debt- amount of requested stake debt{asset} staking_reward_unclaimed- amount of stake unclaimed rewards{asset} staking_reward_claimed- amount of stake claimed rewards{uint64_t} consensus_debt- amount of requested consensus debt{asset} consensus_reward_unclaimed- amount of consensus unclaimed rewards{asset} consensus_reward_claimed- amount of consensus claimed rewards
example
TABLE stakers
stakersscope
endrmng.sat
params
{uint64_t} id- staker id{name} staker- staker account{name} validator- validator account{asset} quantity- total number of staking{asset} xsat_quantity- the amount of XSAT tokens staked{asset} total_donated- the total amount of XSAT that has been donated{uint64_t} stake_debt- amount of requested stake debt{asset} staking_reward_unclaimed- amount of stake unclaimed rewards{asset} staking_reward_claimed- amount of stake claimed rewards{uint64_t} consensus_debt- amount of requested consensus debt{asset} consensus_reward_unclaimed- amount of consensus unclaimed rewards{asset} consensus_reward_claimed- amount of consensus claimed rewards
example
TABLE validators
validatorsscope
endrmng.sat
params
{name} owner- staker id{name} reward_recipient- receiving account for receiving rewards{string} memo- memo when receiving reward transfer{uint16_t} commission_rate- commission ratio, decimal is 10^4{asset} quantity- the amount of BTC staked by the validator{asset} qualification- the qualification of the validator{asset} xsat_quantity- the amount of XSAT tokens staked by the validator{uint16_t} donate_rate- the donation rate, represented as a percentage, ex: 500 means 5.00%{asset} total_donated- the total amount of XSAT that has been donated{uint128_t} stake_acc_per_share- staking rewards earnings per share{uint128_t} consensus_acc_per_share- consensus reward earnings per share{asset} staking_reward_unclaimed- unclaimed staking rewards{asset} staking_reward_claimed- amount of stake claimed rewards{asset} consensus_reward_unclaimed- amount of consensus unclaimed rewards{asset} consensus_reward_claimed- amount of consensus claimed rewards{asset} total_consensus_reward- total consensus rewards{asset} consensus_reward_balance- consensus reward balance{asset} total_staking_reward- total staking rewards{asset} staking_reward_balance- staking reward balance{time_point_sec} latest_staking_time- latest staking or unstaking time{uint64_t} latest_reward_block- latest reward block{time_point_sec} latest_reward_time- latest reward time{bool} disabled_staking- whether to disable staking{checksum160} stake_address- stake address{checksum160} reward_address- reward address{uint64_t} consecutive_vote_count- consecutive vote count{uint64_t} latest_consensus_block- latest consensus block{uint8_t} active_flag- active flag{uint8_t} role- role
example
TABLE stat
statscope
endrmng.sat
params
{asset} total_staking- btc total staking amount{asset} xsat_total_staking- the total amount of XSAT staked{asset} xsat_total_donated- the cumulative amount of XSAT donated
example
ACTION setdonateacc
setdonateaccauthority: endrmng.sat
Update donation account.
params
{string} donation_account- account to receive donations{uint16_t} min_donate_rate- minimum donation rate
example
ACTION addwhitelist
addwhitelistauthority: endrmng.sat
Add whitelist account
params
{name} type- whitelist type @seeWHITELIST_TYPES{name} account- whitelist account
example
ACTION delwhitelist
delwhitelistauthority: endrmng.sat
Delete whitelist account
params
{name} type- whitelist type @seeWHITELIST_TYPES{name} account- whitelist account
example
ACTION addevmproxy
addevmproxyauthority: endrmng.sat
Add evm proxy account
params
{name} caller- caller account{checksum160} proxy- proxy account
example
ACTION delevmproxy
delevmproxyauthority: endrmng.sat
Delete evm proxy account
params
{name} caller- caller account{checksum160} proxy- proxy account
example
ACTION addcrdtproxy
addcrdtproxyauthority: endrmng.sat
Add credit proxy account
params
{checksum160} proxy- proxy account
example
ACTION delcrdtproxy
delcrdtproxyauthority: endrmng.sat
Delete credit proxy account
params
{checksum160} proxy- proxy account
example
ACTION setstatus
setstatusauthority: endrmng.sat
Set validator staking status
params
{name} validator- validator account{bool} disabled_staking- whether to disable staking
example
ACTION regvalidator
regvalidatorauthority:
validator
Registering a validator
params
{name} validator- validator account{name} financial_account- financial accounts{uint16_t} commission_rate- commission ratio, decimal is 10^4
example
ACTION proxyreg
proxyregauthority:
proxy
Proxy account registration validator
params
{name} proxy- proxy account{name} validator- validator account{string} financial_account- financial accounts{uint16_t} commission_rate- commission ratio, decimal is 10^4
example
ACTION config
configauthority:
validator
Validator sets commission ratio and financial account
params
{name} validator- validator account{optional<uint16_t>} commission_rate- commission ratio, decimal is 10^4{optional<string>} financial_account- financial accounts
example
ACTION setdonate
setdonateauthority:
validator
Configure donate rate.
params
{name} validator- synchronizer account{uint16_t} donate_rate- the donation rate, represented as a percentage, ex: 500 means 5.00%
example
ACTION stake
stakeauthority:
staking.xsat
Staking BTC to validator
params
{name} staker- staker account{name} validator- validator account{asset} quantity- staking amount
example
ACTION unstake
unstakeauthority:
staking.xsat
Unstaking BTC from a validator
params
{name} staker- staker account{name} validator- validator account{asset} quantity- cancel staking amount
example
ACTION newstake
newstakeauthority:
staker
Staking BTC to a new validator
params
{name} staker- staker account{name} old_validator- old validator account{name} new_validator- new validator account{asset} quantity- the amount of stake transferred to the new validator
example
ACTION claim
claimauthority:
staker
Claim staking rewards
params
{name} staker- staker account{name} validator- validator account
example
ACTION evmstake
evmstakeauthority:
caller
Staking BTC to validator via evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} validator- validator account{asset} quantity- staking amount
example
ACTION evmunstake
evmunstakeauthority:
caller
Unstake BTC from validator via evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} validator- validator account{asset} quantity- staking amount
example
ACTION evmnewstake
evmnewstakeauthority:
caller
Staking BTC to a new validator via evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} old_validator- old validator account{name} new_validator- new validator account{asset} quantity- staking amount
example
ACTION evmclaim
evmclaimauthority:
caller
Claim staking rewards through evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} validator- validator account
example
ACTION evmclaim2
evmclaim2authority:
caller
Claim staking rewards through evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} validator- validator account{uint16_t} donate_rate- the donation rate, represented as a percentage, ex: 500 means 5.00%
example
ACTION vdrclaim
vdrclaimauthority:
validator->reward_recipientorevmutil.xsat
Validator Receive Rewards
params
{name} validator- validator account
example
STRUCT reward_details_row
reward_details_rowparams
{name} validator- validator account{asset} staking_rewards- staking rewards{asset} consensus_rewards- consensus rewards
example
ACTION distribute
distributeauthority:
rwddist.xsat
Distributing validator rewards
params
{uint64_t} height- validator account{vector<reward_details_row>} rewards- validator account
example
ACTION stakexsat
stakexsatauthority:
xsatstk.xsat
Staking XSAT to validator
params
{name} staker- staker account{name} validator- validator account{asset} quantity- staking amount
example
ACTION unstakexsat
unstakexsatauthority:
xsatstk.xsat
Unstaking XSAT from a validator
params
{name} staker- staker account{name} validator- validator account{asset} quantity- cancel staking amount
example
ACTION restakexsat
restakexsatauthority:
staker
Staking XSAT to a new validator
params
{name} staker- staker account{name} old_validator- old validator account{name} new_validator- new validator account{asset} quantity- the amount of stake transferred to the new validator
example
ACTION evmstakexsat
evmstakexsatauthority:
caller
Staking XSAT to validator via evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} validator- validator account{asset} quantity- staking amount
example
ACTION evmunstkxsat
evmunstkxsatauthority:
caller
Unstake XSAT from validator via evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} validator- validator account{asset} quantity- staking amount
example
ACTION evmrestkxsat
evmrestkxsatauthority:
caller
Staking XSAT to a new validator via evm
params
{name} caller- caller account{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} old_validator- old validator account{name} new_validator- new validator account{asset} quantity- staking amount
example
ACTION creditstake
creditstakeauthority:
custody.xsat
Unstake BTC from validator via credit
params
{checksum160} proxy- evm proxy account{checksum160} staker- evm staker account{name} validator- validator account{asset} quantity- staking amount{checksum160} stake_address- stake address{checksum160} reward_address- reward address{uint64_t} consecutive_vote_count- consecutive vote count{uint64_t} latest_consensus_block- latest consensus block{uint8_t} active_flag- active flag (0: inactive, 1: active, 2: credit staking validator){uint32_t} role- role (0: BTC, 1: XSAT)
example
ACTION newregvldtor
newregvldtorauthority:
validator
Register a new validator with additional parameters
params
{name} validator- validator account{uint32_t} role- role (0: BTC, 1: XSAT){checksum160} stake_addr- stake address{optional<checksum160>} reward_addr- reward address{optional<uint16_t>} commission_rate- commission ratio, decimal is 10^4
example
ACTION evmconfigvald
evmconfigvaldauthority:
validator
Configure validator commission and donate rates
params
{name} validator- validator account{optional<uint16_t>} commission_rate- commission ratio, decimal is 10^4{optional<uint16_t>} donate_rate- the donation rate, represented as a percentage
example
ACTION evmsetstaker
evmsetstakerauthority:
validator
Set validator stake address
params
{name} validator- validator account{checksum160} stake_addr- stake address
example
ACTION setrwdaddr
setrwdaddrauthority:
validator
Set validator reward address
params
{name} validator- validator account{checksum160} reward_addr- reward address
example
ACTION setstakebase
setstakebaseauthority: endrmng.sat
Set base stake amounts for validators
params
{asset} xsat_base_stake- XSAT base stake amount{asset} btc_base_stake- BTC base stake amount
example
ACTION updcreditstk
updcreditstkauthority: endrmng.sat
Update credit staking settings
params
{bool} is_close- whether to close credit staking
example
ACTION endorse
endorseauthority:
BLOCK_ENDORSE_CONTRACT
Endorse a validator for a specific block height
params
{name} validator- validator account{uint64_t} height- block height
example
ACTION setdepproxy
setdepproxyauthority: endrmng.sat
Set deposit proxy accounts
params
{checksum160} btc_deposit_proxy- BTC deposit proxy{checksum160} xsat_deposit_proxy- XSAT deposit proxy
example
Last updated