Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/multiversx/mx-exchange-sc
Smart contracts for a decentralized exchange written in Rust
https://github.com/multiversx/mx-exchange-sc
Last synced: 3 months ago
JSON representation
Smart contracts for a decentralized exchange written in Rust
- Host: GitHub
- URL: https://github.com/multiversx/mx-exchange-sc
- Owner: multiversx
- License: gpl-3.0
- Created: 2021-02-26T14:57:25.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-04-13T15:39:11.000Z (9 months ago)
- Last Synced: 2024-04-14T05:11:46.787Z (9 months ago)
- Language: Rust
- Size: 8.63 MB
- Stars: 91
- Watchers: 14
- Forks: 42
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-multiversx-dev-resources - Exchange - These are the core Smart Contracts and the foundation exchange. (MultiversX official / Smart contracts)
README
# xExchange Smart Contracts
This repository contains the principal Smart Contract components of xExchange.
This document is a brief description of the Smart Contracts. It covers the basic workflows that a user may do in order to succesfully interact with each contract. For those interested about more in-depth technical details, each contract will have its separate README in its own root directory.
- [xExchange Smart Contracts](#xexchange-smart-contracts)
- [DEX Contracts](#dex-contracts)
- [Pair Contract](#pair-contract)
- [Router Contract](#router-contract)
- [Farm Contract](#farm-contract)
- [Farm with Lock Contract](#farm-with-lock-contract)
- [Price discovery](#price-discovery)
- [Farm Staking Contracts](#farm-staking-contracts)
- [Farm Staking](#farm-staking)
- [Farm Staking Proxy](#farm-staking-proxy)
- [Metabonding Staking](#metabonding-staking)
- [Locked Asset Contracts](#locked-asset-contracts)
- [Distribution Contract](#distribution-contract)
- [DEX Proxy Contract](#dex-proxy-contract)
- [Locked MEX Factory Contract](#locked-mex-factory-contract)Other Smart Contracts that are part of xExchange, but are not part of this repository:
- [Egld wrapping](https://github.com/multiversx/mx-sdk-rs/tree/master/contracts/core/wegld-swap) used for swapping EGLD to an ESDT and reversed with an exchange rate of 1:1.
## DEX Contracts
Core SCs of xExchange. They usually handle a few tokens and are used as primitives by the other contracts as they are built on top of them.
### Pair Contract
The core of any DEX is the swap feature. This contract acts as a constant product AMM and offers swap functionality as well as adding & removing liquidity. The fees for swapping are configurable by the Router SC and its owner, although most of the contracts use a total fee percent of 0.3%, from which 0.25% goes to liquidity providers and the rest of 0.05% is used to help the ecosystem by Buying & Burning MEX tokens.
### Router Contract
The owner of all the Pair SCs is the Router SC. It is used for deploying, upgrading and configuring the Pair SCs. It also holds the mapping between (the pair of the two tokens) and the Contract Address, so when a user wants to swap two assets, he needs to know the Pair SC address for the particular contract. This is the place where this info can be queried.
### Farm Contract
In order to gain users trust, the liquidity inside the DEX must be somewhat stable. To achieve that, Farm contracts come in place to incentivise liquidity providers to lock their LP tokens in exchange for MEX rewards. Rewards are generated per block and their rate is configurable in sync with the MEX tokenomics.
### Farm with Lock Contract
Works the same as the regular Farm with the exception that it does not generate MEX as rewards. Instead, it generates Locked MEX, with the help of the Factory SC. The reason one would choose to go with the locked rewards (LKMEX) instead of the regular rewards (MEX) is that the reward emission rate (reward per block rate) is bigger, meaning the APR is higher.
### Price discovery
In order to improve the experience of the user, and decrease the impact of trade bots at launches of new tokens on the DEX, the Price discovery mechanism was created. As its name states, this contract aims to find the Market Price of a token even before allowing swaps. This contract is supposed to be used before the creation of a Pair SC that needs this protection. The SC gathers both types of tokens and gives each user the corresponding tokens, assets that are locked for a small period of time, in order to further alleviate any unnatural price fluctuations that may appear at launch time.
## Farm Staking Contracts
Staking contracts that are heavily inspired by the farm contracts.
### Farm Staking
Uses the same base implementation and concepts as the Farm contracts, but is designed to work with any fungible tokens instead of very specific ones, like LP tokens. Also, rewards are not minted, but are instead deposited from time to time by the owner.
### Farm Staking Proxy
Used in conjunction with the Farm Staking contract, it lets users stake their LP FARM tokens, i.e. the farm tokens they received when they put their LP tokens in the normal farm. The user then receives a so-called dual yield token, which can be used to claim rewards from both the normal farm and the staking farm.
### Metabonding Staking
A simple staking contract where users lock their tokens in order to receive rewards from other contracts.
## Locked Asset Contracts
### Distribution Contract
This smart contract is used for distributing Locked MEX to the community. It receives information from the owner and offers the users the possibility to claim the configured amount of tokens. It was used only once and might not be used in the future since we think there are better ways to achieve same functionality and results.
### DEX Proxy Contract
This smart contract allows users to interact with the DEX using Locked MEX as fungible MEX for certain operations, such as adding liquidity and entering Farm contracts.
### Locked MEX Factory Contract
Locked MEX is a Meta ESDT. Since there can be only one address (per shard) that can hold the role of creating a Meta ESDT, this contract was created so the multiple other contracts that need to create Locked MEX can just request them from only one place.