Skip to content

Latest commit

 

History

History
82 lines (54 loc) · 5.6 KB

README.md

File metadata and controls

82 lines (54 loc) · 5.6 KB

Swapable: Automated Liquidity Pools

npm-badge size-badge dl-badge Build Status

This repository contains the source code for swapable, an open standard for peer-to-peer automated liquidity pools on top of Symbol from NEM, and compatible networks.

This library empowers the creation and operations of automated liquidity pools using Symbol from NEM and compatible networks.

Introduction

This library empowers the creation and operations of automated liquidity pools using Symbol from NEM and compatible networks.

Swapable assets consist in combining two cryptocurrencies in a liquidity pool to define an invariant k using a constant product formula of: x * y = k where x and y represent the cryptocurrencies that are paired in said liquidity pool. The shares of liquidity providers are determined with another asset that we call the pool shares mosaic and which is issued at the time of creation of a liquidity pool, i.e. each liquidity pool will have its own pool shares mosaic.

A swapable asset may be paired with any other cryptocurrency provided that they reside on the same blockchain network.

Liquidity providers add liquidity into pools and Traders can swap currencies. A fee is added to each trade at the rate of 0.30% which are then added to token reserves. Providers can withdraw their shares of the total reserve at any time.

When liquidity is added by a provider, they will be assigned some Pool Shares. Those shares can then be burned at any time by providers in order to take back their part of pooled assets.

An automated liquidity pool is represented by the following properties:

  • A target account: Consists of a public account which holds the funds of said pool. This account SHOULD be converted to a multi-signature account, i.e cosignatories can be the operators of a DAO (see @ubcdigital/governable).

  • A pool shares mosaic: Consists of a digital asset that is created only for the purpose of keeping track liquidity provider shares in pools. These assets can be burned for pooled assets at any time but are not exchangeable for other cryptocurrencies. Using Symbol from NEM, this asset is represented by a non-transferrable mosaic.

Contracts found here

Contract Name Description
CreatePool Contract for creating a new liquidity pool. This contract is typically executed by liquidity providers and require the input of two different cryptocurrencies marked x and y which form the liquidity pool, a.k.a the market pair.
AddLiquidity Contract for adding liquidity to an already existing liquidity pool. This contract is typically executed by liquidity providers and requires the input of two cryptocurrencies that have previously been paired in a liquidity pool with the CreatePool contract.
RemoveLiquidity Contract for removing liquidity from an already existing liquidity pool. This contract is typically executed by liquidity providers and requires the input of two cryptocurrencies that have previously been paired in a liquidity pool with the CreatePool contract.
Swap Contract for swapping currencies. This contract is typically executed by traders and requires the input of one cryptocurrency and one output denominator. Prior to the execution of swaps between x and y, a liquidity pool must exist that provides liquidity for the market pair x:y, i.e. using the CreatePool contract.

Installation

npm i -g @ubcdigital/swapable

Sponsor us

Platform Sponsor Link
Paypal https://paypal.me/usingblockchainltd
Patreon https://patreon.com/usingblockchainltd
Github https://github.com/sponsors/UsingBlockchain
☕ ☕ ☕ https://www.buymeacoffee.com/UBCDigital

This project is sponsored by UBC Digital Magazine.

Disclaimer

The author of this package cannot be held responsible for any loss of money or any malintentioned usage forms of this package. Please use this package with caution.

Our software contains links to the websites of third parties (“external links”). As the content of these websites is not under our control, we cannot assume any liability for such external content. In all cases, the provider of information of the linked websites is liable for the content and accuracy of the information provided. At the point in time when the links were placed, no infringements of the law were recognisable to us..

License

Copyright 2020-2021 Using Blockchain Ltd, Reg No.: 12658136, United Kingdom, All rights reserved.

Licensed under the LGPL v3.0