4ea7c531ef | ||
---|---|---|
.. | ||
src | ||
.env.example | ||
.gitignore | ||
Cargo.toml | ||
Dockerfile.liquidator | ||
README.md |
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.
-
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.
-
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.
-
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.
-
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.
-
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.
-
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 programmain
: stable, currently running on themainnet-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 accountLIQOR_OWNER
- private key of the owner of the mango accountRPC_URL
- RPC cluster urlMIN_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.