mango-v4/bin/liquidator
Christian Kamm 4ea7c531ef
liquidator: make alternate routes configurable (#916)
2024-03-13 09:13:07 +01:00
..
src liquidator: make alternate routes configurable (#916) 2024-03-13 09:13:07 +01:00
.env.example liquidator: Add telemetry (#668) 2023-08-08 18:17:23 +02:00
.gitignore Organize paths, rename crates (#466) 2023-02-20 14:08:38 +01:00
Cargo.toml liquidator: avoid logging same oracle error (same token) in loop (#889) 2024-02-21 16:35:28 +01:00
Dockerfile.liquidator Use ghcr.io container registry (#549) 2023-04-17 16:57:51 +01:00
README.md client/liquidator: jupiter v6 (#684) 2023-08-24 16:45:01 +02:00

README.md

Disclaimer

The following open source code contains an an example that documents possible interaction with the smart contract for the purpose of performing liquidations. Please note that the use of this code is at your own risk and responsibility.

  1. No Warranty: The code is provided "as is," without any warranty or guarantee of any kind, express or implied. The developers and contributors of this code do not make any representations or warranties regarding its accuracy, reliability, or functionality. The use of this code is solely at your own risk.

  2. Limitation of Liability: In no event shall the developers and contributors of this code be liable for any direct, indirect, incidental, special, exemplary, or consequential damages (including, but not limited to, procurement of substitute goods or services, loss of use, data, or profits, or business interruption) arising in any way out of the use, inability to use, or the results of the use of this code, even if advised of the possibility of such damages.

  3. Compliance with Laws: It is your responsibility to ensure that the use of this code complies with all applicable laws, regulations, and policies. The developers and contributors of this code shall not be held responsible for any illegal or unauthorized use of the code.

  4. User Accountability: You are solely responsible for any actions performed using this code. The developers and contributors of this code shall not be held liable for any misuse, harm, or damages caused by the bot or its actions.

  5. Security Considerations: While efforts have been made to ensure the security of this code, the developers and contributors do not guarantee its absolute security. It is recommended that you take appropriate measures to secure the code and any associated systems from potential vulnerabilities or threats.

  6. Third-Party Dependencies: This code may rely on third-party libraries, frameworks, or APIs. The developers and contributors of this code are not responsible for the functionality, availability, or security of any third-party components.

By using this open source code, you acknowledge and agree to the above disclaimer. If you do not agree with any part of the disclaimer, refrain from using the code.

License

See https://github.com/blockworks-foundation/mango-v4/blob/dev/LICENSE


Two branches are relevant here:

  • dev: bleeding edge, may be unstable, could be incompatible with deployed program
  • main: stable, currently running on the mainnet-beta cluster

Setup Environment

.env Config file:

A .env file can be used to configure the liquidator setup. See .env.example for a example.

The environment variables required are

  • LIQOR_MANGO_ACCOUNT - public key of the mango account
  • LIQOR_OWNER - private key of the owner of the mango account
  • RPC_URL - RPC cluster url
  • MIN_HEALTH_RATIO - minimum health ratio the liquidator should retain (default 50%)

more advanced parameters

  • REBALANCE - if rebalancing should happen (default true)
  • REBALANCE_SLIPPAGE_BPS - slippage liquidator should tolerate when offloading tokens (default 100)
  • PRIORITIZATION_MICRO_LAMPORTS - how much priority fee to pay (default 0)
  • COMPUTE_LIMIT_FOR_LIQUIDATION - compute to request for liq instructions (default 250k)
  • COMPUTE_LIMIT_FOR_TCS - compute to request for token conditional swap trigger instructions (default 300k)
  • SNAPSHOT_INTERVAL_SECS - how frequently to request a full on-chain snapshot (default 5min)
  • PARALLEL_RPC_REQUESTS - number of allowed parallel rpc calls (default 10)
  • TELEMETRY - report the liquidator's existence and pubkey occasionally (default true)
  • JUPITER_VERSION - choose between v4 and v6 jupiter (or mock, for devnet testing only)
cargo run --bin liquidator

There is also a dockerfile Dockerfile.liquidator available in case one wants to run this in a containerized environment.