Skip to content

๐Ÿงฉ Liquidator Bot for the Vesu protocol.

License

Notifications You must be signed in to change notification settings

astraly-labs/vesu-liquidator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

57 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Vesu Liquidator


Report a Bug - Request a Feature

About

Vesu Liquidator ๐Ÿค– is an automated bot that monitors positions on the Vesu Protocol and liquidates them.

Under the hood, the bot calls the vesu-liquidate contract made by the Vesu team.

Getting Started

Docker through published package

You can run the Vesu Liquidator using our pre-built Docker image. Here's how to use it:

  1. Pull the latest image:
docker pull ghcr.io/astraly-labs/vesu-liquidator:latest
  1. Run the container:
docker run --rm -it \
  -v /path/to/your/.env:/app/.env \
  ghcr.io/astraly-labs/vesu-liquidator:latest \
  --account-address <LIQUIDATOR_ACCOUNT_ADDRESS> \
  --network <NETWORK_NAME> \
  --rpc-url <RPC_URL> \
  --starting-block <BLOCK_NUMBER> \
  --pragma-api-base-url <PRAGMA_API_BASE_URL>
  --storage-path ./vesu.json

For more options, run:

docker run --rm ghcr.io/astraly-labs/vesu-liquidator:latest --help

Docker locally

If you want to build the Docker image locally:

  1. Build the Docker image:
docker build -t vesu-liquidator .
  1. Run the locally built image:
docker run --rm vesu-liquidator --help
#ย OR
docker run --rm -it \
  # Optional .env, can also be provided through CLI
  -v /path/to/your/.env:/app/.env \
  vesu-liquidator \
  --account-address <LIQUIDATOR_ACCOUNT_ADDRESS> \
  --network <NETWORK_NAME> \
  --rpc-url <RPC_URL> \
  --starting-block <BLOCK_NUMBER> \
  --pragma-api-base-url <PRAGMA_API_BASE_URL>
  --storage-path ./vesu.json # persistent indexer storage into a file

Prerequisites

Protobuf

In order to run the liquidator, you need the protoc Protocol Buffers compiler, along with Protocol Buffers resource files.

Ubuntu
sudo apt update && sudo apt upgrade -y
sudo apt install -y protobuf-compiler libprotobuf-dev
macOS

Assuming Homebrew is already installed.

brew install protobuf

Environment Variables

Create an .env file following the example file and fill the keys.

Usage

Build

cargo build --release

The executable can be found at ./target/release/vesu-liquidator.

Run

You can run vesu-liquidator --help - which will show how to use the bot:

Usage: vesu-liquidator [OPTIONS] --account-address <LIQUIDATOR ACCOUNT ADDRESS> --network <NETWORK NAME> --rpc-url <RPC URL> --starting-block <BLOCK NUMBER> --pragma-api-base-url <PRAGMA API BASE URL>

Options:
      --account-address <LIQUIDATOR ACCOUNT ADDRESS>
          Account address of the liquidator account

      --private-key <LIQUIDATOR PRIVATE KEY>
          Private key of the liquidator account

      --keystore-path <LIQUIDATOR KEYSTORE>
          Keystore path for the liquidator account

      --keystore-password <LIQUIDATOR KEYSTORE PASSWORD>
          Keystore password for the liquidator account

  -n, --network <NETWORK NAME>
          The network chain configuration [possible values: mainnet, sepolia]

      --rpc-url <RPC URL>
          The rpc endpoint url

      --config-path <VESU CONFIG PATH>
          Configuration file path [default: config.yaml]

  -s, --starting-block <BLOCK NUMBER>
          The block you want to start syncing from

      --pragma-api-base-url <PRAGMA API BASE URL>
          Pragma API Key for indexing

      --apibara-api-key <APIBARA API KEY>
          Apibara API Key for indexing

      --pragma-api-key <PRAGMA API KEY>
          Pragma API Key for indexing

  -h, --help
          Print help

Example: running the bot on Mainnet

./target/release/vesu-liquidator --network mainnet --rpc-url https://starknet-mainnet.public.blastapi.io --starting-block 668886 --pragma-api-base-url https://api.dev.pragma.build --account-address <YOUR_ACCOUNT> --private-key <YOUR_PRIVATE_KEY>

Should run the bot:

โ–ˆโ–ˆโ•—   โ–ˆโ–ˆโ•—โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—โ–ˆโ–ˆโ•—   โ–ˆโ–ˆโ•—    โ–ˆโ–ˆโ•—     โ–ˆโ–ˆโ•— โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•— โ–ˆโ–ˆโ•—   โ–ˆโ–ˆโ•—โ–ˆโ–ˆโ•—โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—  โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•— โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•— โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•— โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—
โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•”โ•โ•โ•โ•โ•โ–ˆโ–ˆโ•”โ•โ•โ•โ•โ•โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘    โ–ˆโ–ˆโ•‘     โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•”โ•โ•โ•โ–ˆโ–ˆโ•—โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•”โ•โ•โ–ˆโ–ˆโ•—โ–ˆโ–ˆโ•”โ•โ•โ–ˆโ–ˆโ•—โ•šโ•โ•โ–ˆโ–ˆโ•”โ•โ•โ•โ–ˆโ–ˆโ•”โ•โ•โ•โ–ˆโ–ˆโ•—โ–ˆโ–ˆโ•”โ•โ•โ–ˆโ–ˆโ•—
โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—  โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘    โ–ˆโ–ˆโ•‘     โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘  โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•”โ•
โ•šโ–ˆโ–ˆโ•— โ–ˆโ–ˆโ•”โ•โ–ˆโ–ˆโ•”โ•โ•โ•  โ•šโ•โ•โ•โ•โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘    โ–ˆโ–ˆโ•‘     โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘โ–„โ–„ โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•‘  โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•”โ•โ•โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ•”โ•โ•โ–ˆโ–ˆโ•—
 โ•šโ–ˆโ–ˆโ–ˆโ–ˆโ•”โ• โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•‘โ•šโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•”โ•    โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•—โ–ˆโ–ˆโ•‘โ•šโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•”โ•โ•šโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•”โ•โ–ˆโ–ˆโ•‘โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•”โ•โ–ˆโ–ˆโ•‘  โ–ˆโ–ˆโ•‘   โ–ˆโ–ˆโ•‘   โ•šโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ•”โ•โ–ˆโ–ˆโ•‘  โ–ˆโ–ˆโ•‘
  โ•šโ•โ•โ•โ•  โ•šโ•โ•โ•โ•โ•โ•โ•โ•šโ•โ•โ•โ•โ•โ•โ• โ•šโ•โ•โ•โ•โ•โ•     โ•šโ•โ•โ•โ•โ•โ•โ•โ•šโ•โ• โ•šโ•โ•โ–€โ–€โ•โ•  โ•šโ•โ•โ•โ•โ•โ• โ•šโ•โ•โ•šโ•โ•โ•โ•โ•โ• โ•šโ•โ•  โ•šโ•โ•   โ•šโ•โ•    โ•šโ•โ•โ•โ•โ•โ• โ•šโ•โ•  โ•šโ•โ•

  ๐Ÿค– Liquidator ๐Ÿ‘‰ 0x42...6c
  ๐ŸŽฏ On Mainnet
  ๐Ÿฅก Starting from block 668886


2024-08-23T05:29:06.808482Z  INFO ๐Ÿงฉ Starting the indexer service...
2024-08-23T05:29:06.808583Z  INFO โณ Waiting a few moment for the indexer to fetch positions...

2024-08-23T05:29:07.916084Z  INFO [๐Ÿ” Indexer] Found new position 0x156fa1e95830c415
2024-08-23T05:29:16.809509Z  INFO ๐Ÿงฉ Starting the oracle service...
2024-08-23T05:29:16.833518Z  INFO ๐Ÿงฉ Starting the monitoring service...

2024-08-23T05:29:16.833561Z  INFO [๐Ÿ”ฎ Oracle] Fetching latest prices...
2024-08-23T05:29:16.833667Z  INFO [๐Ÿ”ญ Monitoring] Checking if any position is liquidable...
2024-08-23T05:29:20.176390Z  INFO [๐Ÿ”ฎ Oracle] โœ… Fetched all new prices
2024-08-23T05:29:20.177651Z  INFO [๐Ÿ”ญ Monitoring] ๐Ÿคจ They're good.. for now...

#ย rest of the execution...

Project assistance

If you want to say thank you or/and support:

  • Add a GitHub Star to the project.
  • Tweet about it.
  • Write interesting articles about the project on Dev.to, Medium or your personal blog.

Contributing

First off, thanks for taking the time to contribute! Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make will benefit everybody else and are greatly appreciated.

Please read our contribution guidelines, and thank you for being involved!

Security

We follows good practices of security, but 100% security cannot be assured. The bot is provided "as is" without any warranty. Use at your own risk.

For more information and to report security issues, please refer to our security documentation.

License

This project is licensed under the MIT license.

See LICENSE for more information.