The Sovryn node reads all open positions from the Sovryn marginTrade contracts and continuously monitors for changes. The app has three main functions: Liquidation of expired positions, rollover of open positions and taking advantage of arbitrage opportunities on the amm.
If margin < maintenance, it initiates liquidation on the contract.
If it fails, it checks if the liquidation criteria are still met.
If not, it keeps observing.
If yes, it sends an error notification to a telegram group for manual processing.
If the tx was not confirmed after 10 minutes, it resends the transaction with a higher gas fee.
The liquidator needs considerable funds in all currencies provided to be able to liquidate a position. He needs to allow the protocol contract to access his tokens in advance (Approve token transfers of all involved Erc20 tokens) and have enough RBTC to cover transaction costs.
When the maximum loan duration has been exceeded, the position will need to be rolled over. The function "rollover" on the protocol contract extends the loan duration by the maximum term (28 days for margin trades at the moment of writing) and pays the interest to the lender. The callers reward is 0.1% of the position size and receives 2 * the gas cost using the fast gas price as base for the calculation as well as 0.1% .
Earn $ through arbitrage: if the expected price from the amm deviates more than 2 % from the oracle price buy the side which is off and exchange the money back on money onchain.
NodeJs > 12.1
pm2
Webpack
1. npm install
2. npm install -g mocha pm2
3. To build the client create an empty directory "public/dist" and run "npm run build-client"
4. Create empty directories "logs" and "db" in the project root
5. Create directory "secrets" and within a file accounts.js with the credentials of the liquidator/rollover/arbitrage wallets
ks = encrypted keystore file in v3 standard.
(alternatively, you can specify pKey instead of ks to just use the private key)
export default {
"liquidator": [{
adr: "",
ks: ""
}],
"rollover": [{
adr: "",
ks: ""
}],
"arbitrage": [{
adr: "",
ks: ""
}],
}
To receive notifications on telegram about new transactions and errors create a telegram bot-token-id and write in in a file /secrets/telegram.js
export default "[telegram-bot-token]";
export default ""; for no notifications
6. Charge the Sovryn node wallets with all relevant tokens and enough Rbtc to cover tx cost.
7. Execute node -r esm util/approval.js to approve the Sovryn smart contract to spend Doc on behalf of the Sovryn node wallets as well as the swap network contract to spend tokens on behalf of the arbitrage wallet.
npm run dev:[main || test] [wallet-password]
npm run start:[main || test] [wallet-password]
Check
http://your-ip:3000/ to see some liquidation processing info
Please add the files to secret folder before runnning the docker-compose
To run the app via docker
docker-compose up -d --build
The Sovryn node uses pm2 for log handling. To enable Log-rotation do "pm2 install pm2-logrotate" and afterwards "pm2 set pm2-logrotate:max_size 1000K"
To develop the frontend with Hot Reload run npm run dev
Sovryn-Node includes tests created with Hardhat. To run them, first npm install
this package,
then follow the instructions in integration-tests/README.md
.
MIT Free Software, Hell Yeah!