Skip to content

Latest commit

 

History

History
803 lines (608 loc) · 24.8 KB

liquidity.md

File metadata and controls

803 lines (608 loc) · 24.8 KB
Title Description
Liquidity
A high-level overview of how the command-line interfaces (CLI) works for the liquidity module.

Liquidity Module

Synopsis

This document provides a high-level overview of how the command line (CLI) interface works for the liquidity module.

Note that jq is recommended to be installed as it is used to process JSON throughout the document.

Command Line Interfaces

Transaction

CreatePair

Create a pair (market) for trading.

A pair consists of a base coin and a quote coin and you can think of a pair in an order book. An orderer can request a limit or market order once a pair is created. Anyone can create a pair by paying a fee PairCreationFee (default is 1000000stake).

Usage

create-pair [base-coin-denom] [quote-coin-denom]
Argument Description
base-coin-denom denom of the base coin for the pair
quote-coin-denom denom of the quote coin for the pair

Example

# Create a pair ATOM/UST
crescentd tx liquidity create-pair uatom uusd \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query pairs using the following command
crescentd q liquidity pairs -o json | jq

CreatePool

Create a liquidity pool in existing pair.

Pool(s) belong to a pair. Therefore, a pair must exist in order to create a pool. Anyone can create a pool by paying a fee PoolCreationFee (default is 1000000stake).

Usage

create-pool [pair-id] [deposit-coins]
Argument Description
pair-id pair id
deposit-coins deposit amount of base and quote coins

Example

# Create a pool 1000ATOM/3000UST
crescentd tx liquidity create-pool 1 1000000000uatom,3000000000uusd \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query pools using the following command
crescentd q liquidity pools -o json | jq

CreateRangedPool

Create a ranged liquidity pool in existing pair.

Pool(s) belong to a pair. Therefore, a pair must exist in order to create a pool. Anyone can create a pool by paying a fee PoolCreationFee (default is 1000000stake).

Usage

create-ranged-pool [pair-id] [deposit-coins] [min-price] [max-price] [initial-price]
Argument Description
pair-id pair id
deposit-coins deposit amount of base and quote coins
min-price minimum price of the pool
max-price maximum price of the pool
initial-price initial pool price

Example

# Create a ranged pool with 1000ATOM/1000UST with price range of [2.5, 10.0],
# with initial price set to 3.0
crescentd tx liquidity create-ranged-pool 1 1000000000uatom,1000000000uusd 2.5 10.0 3.0 \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query pools using the following command
crescentd q liquidity pools -o json | jq

Deposit

Deposit coins to a liquidity pool.

Deposit uses a batch execution methodology. Deposit requests are accumulated in a batch for a pre-defined period (default is 1 block) and they are executed at the end of the batch. A minimum deposit amount is 1000000 for each denomination.

Note that in an order book system, a pool is considered as an orderer. A liquidity in the pool places orders conservatively. What that means is that it places buy orders lower than the pool price and places sell orders higher than the pool price.

Usage

deposit [pool-id] [deposit-coins]
Argument Description
pool-id pool id
deposit-coins deposit amount of base and quote coins

Example

# Deposit 10ATOM/30UST to the pool
crescentd tx liquidity deposit 1 10000000uatom,30000000uusd \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query deposit requests by using the following command
# You must query this right away to get the result
# Otherwise, it is removed as it is executed.
crescentd q liquidity deposit-requests 1 -o json | jq

Withdraw

Withdraw coins from the liquidity pool.

Withdraw uses a batch execution methodology. Withdraw requests are accumulated in a batch for a pre-defined period (default is 1 block) and they are executed at the end of the batch.

Usage

withdraw [pool-id] [pool-coin]
Argument Description
pool-id pool id
pool-coin amount of pool coin to withdraw

Example

# Withdraw pool coin from the pool
crescentd tx liquidity withdraw 1 500000000000pool1 \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query withdraw requests by using the following command
# You must query this right away to get the result
# Otherwise, it is removed as it is executed.
crescentd q liquidity withdraw-requests 1 -o json | jq

LimitOrder

Make a limit order.

Buy limit order will be matched at lower than or equal to the defined order price whereas sell limit order will be matched at higher than or equal to the defined order price.

Order uses a batch execution methodology. Order requests are accumulated in a batch for a pre-defined period (default is 1 block) and they are executed at the end of the batch.

Usage

limit-order [pair-id] [direction] [offer-coin] [demand-coin-denom] [price] [amount]
Argument Description
pair-id pair id
direction swap direction; buy or sell
offer-coin amount of coin that the orderer offers to swap for the demand coin denom; it varies depending on swap direction (buy or sell). Buy direction requires quote coin whereas sell direction requires base coin. For buy direction, quote coin amount must be greater than or equal to price * amount. For sell direction, base coin amount must be greater than or equal to the amount value.
demand-coin-denom demand coin denom that the orderer is willing to swap for
price order price; the exchange ratio is the amount of quote coin over the amount of base coin. It must be between 90% and 110% of the last price. This means the price change can only be between -10% and +10%.
amount amount of base coin that the orderer is willing to buy or sell
Optional Flag Description
order-lifespan duration that the order lives until it is expired; an order will be executed for at least one batch, even if the lifespan is 0; valid time units are ns|us|ms|s|m|h

An Example of Buying Direction

#
# Pair: ATOM / USDT where ATOM is `BaseCoinDenom` and USDT is `QuoteCoinDenom`
#
# Let’s say you want to buy ATOM with 50 USDT (50*10^6uusd)
#
# You first have to query the last price of the pair
# 
# Assuming the last price is 3.0, it is up to your discretion
# what order price you want to place an order with.
#
# [Case 1]
# If you want your order to be executed to buy ATOM right away,
# you must place an order with an order price above the last price.
# e.g) 3.1, 3.2, 3.3 (max limit)
#
# [Case 2]
# If you are willing to wait until your order is executed at certain price,
# then place an order with an order price that is less than or equal to the last price.
#
# It is important to note that the order price must be between 90% and 110% of the last price 
# for the price change to be between -10% and +10%. 
# Our DEX is designed in this way to minimize computational resources 
# and improve performance issue. 
#
# In regards of the `amount` field, it is how many ATOM you want to buy.
# It is important to note that OfferCoinAmount/OrderPrice is the maximum amount you can buy and
# the amount value multiply by order price cannot be more than the offer coin amount.
# 
# To describe the CLI below, 
# it means you want to buy 17241379 amount of uatom by offering 50000000uusd with an order price of 2.9, which is lower than
# the current last price of the pair.
# You are placing an order with an intention to wait until your order is matched and executed at 2.9.
#
# Place a limit order to buy
crescentd tx liquidity limit-order 1 buy 50000000uusd uatom 2.9 17241379 \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

# Place a limit order to buy with order-lifespan flag
crescentd tx liquidity limit-order 1 buy 50000000uusd uatom 2.9 17241379 \
--chain-id localnet \
--order-lifespan 30s \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query order requests by using the following command
# You must query this right away to get the result
# Otherwise, it is removed as it is executed.
crescentd q liquidity orders cre1zaavvzxez0elundtn32qnk9lkm8kmcszxclz6p -o json | jq

An Example of Selling Direction

#
# Pair: ATOM / USDT where ATOM is `BaseCoinDenom` and USDT is `QuoteCoinDenom`
#
# Let’s say you want to sell 50 ATOM (50*10^6uatom) for USDT
#
# You first have to query the last price of the pair
# 
# Assuming the last price is 3.0, it is up to your discretion
# what order price you want to place an order with.
#
# [Case 1]
# If you want your order to be executed to sell ATOM right away,
# you must place an order with an order price below the last price.
# e.g) 2.9, 2.8, 2.7 (max limit)
# 
# [Case 2]
# If you are willing to wait until your order is executed at certain price,
# then place an order with an order price that is more than or equal to the last price.
#
# It is important to note that the order price must be between 90% and 110% of the last price 
# for the price change to be between -10% and +10%. 
# Our DEX is designed in this way to minimize computational resources 
# and improve performance issue. 
#
# In regards of the `amount` field, it is a number of ATOMs you want to sell.
# 
# To describe the CLI below, 
# it means you want to sell 50000000 all amounts by offering 50000000uatom for uusd with an order price of 2.7.
# You are placing an order with an intention to sell it immediately with any amounts placed in the orderbook pair.
# OfferCoinAmount is the maximum amount you can sell.
#
# Place a limit order to sell
crescentd tx liquidity limit-order 1 sell 50000000uatom uusd 2.7 50000000 \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

# Place a limit order to sell with order-lifespan flag
crescentd tx liquidity limit-order 1 sell 50000000uatom uusd 2.7 50000000 \
--chain-id localnet \
--order-lifespan 30s \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query order requests by using the following command
# You must query this right away to get the result
# Otherwise, it is removed as it is executed.
crescentd q liquidity orders cre1zaavvzxez0elundtn32qnk9lkm8kmcszxclz6p -o json | jq

MarketOrder

Make a market order.

Unlike a limit order, there is no need to input order price.

Buy market order uses MaxPriceLimitRatio of the last price, which is LastPrice * (1+MaxPriceLimitRatio).

Sell market order uses negative MaxPriceLimitRatio of the last price, which is LastPrice * (1-MaxPriceLimitRatio).

Order uses a batch execution methodology. Order requests are accumulated in a batch for a pre-defined period (default is 1 block) and they are executed at the end of the batch.

Usage

market-order [pair-id] [direction] [offer-coin] [demand-coin-denom] [amount]
Argument Description
pair-id pair id
direction swap direction; buy or sell
offer-coin amount of coin that the orderer offers to swap with; buy direction requires quote coin whereas sell direction requires base coin. For buy direction, quote coin amount must be greater than or equal to price * amount. For sell direction, base coin amount must be greater than or equal to the amount value.
demand-coin-denom demand coin denom that the orderer is willing to swap for
amount amount of base coin that the orderer is willing to buy or sell
Optional Flag Description
order-lifespan duration that the order lives until it is expired; an order will be executed for at least one batch, even if the lifespan is 0; valid time units are ns|us|ms|s|m|h

Example

# Make a market order to swap 
crescentd tx liquidity market-order 1 sell 100000000uatom uusd 100000000 \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

# Make a limit order to swap with order-lifespan flag
crescentd tx liquidity market-order 1 sell 100000000uatom uusd 100000000 \
--chain-id localnet \
--order-lifespan 30s \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

#
# Tips
#
# You can query order requests by using the following command
# You must query this right away to get the result
# Otherwise, it is removed as it is executed.
crescentd q liquidity orders cre1zaavvzxez0elundtn32qnk9lkm8kmcszxclz6p -o json | jq

MMOrder

Make an MM(market making) order. An MM order is a group of multiple buy/sell limit orders which are distributed evenly based on its parameters.

Usage

mm-order [pair-id] [max-sell-price] [min-sell-price] [sell-amount] [max-buy-price] [min-buy-price] [buy-amount]
Argument Description
pair-id pair id
max-sell-price maximum price of sell orders
min-sell-price minimum price of sell orders
sell-amount total amount of sell orders
max-buy-price maximum price of buy orders
min-buy-price minimum price of buy orders
buy-amount total amount of buy orders
Optional Flag Description
order-lifespan duration that the order lives until it is expired; an order will be executed for at least one batch, even if the lifespan is 0; valid time units are ns|us|ms|s|m|h

Example

# Make a market making order in pair 1 with following parameters:
# Sell: total 1000000 with price range from 102 to 101
# Buy: total 1000000 with price range from 100 to 99
crescentd tx liquidity mm-order 1 102 101 1000000 100 99 1000000  \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

# Make the same order with order-lifespan flag
crescentd tx liquidity mm-order 1 102 101 1000000 100 99 1000000  \
--order-lifespan 30s \
--chain-id localnet \
--from alice \
--keyring-backend test \
--broadcast-mode block \
--yes \
--output json | jq

CancelOrder

Cancel an order.

Usage

cancel-order [pair-id] [order-id]
Argument Description
pair-id pair id
order-id order id

Example

crescentd tx liquidity cancel-order 1 1 \
--chain-id localnet \
--from alice \
--keyring-backend=test \
--broadcast-mode block \
--yes \
--output json | jq

CancelAllOrders

Cancel all orders.

This command provides a convenient way to cancel all orders.

Usage

cancel-all-orders [pair-ids]
Argument Description
pool-id pool id
pool-coin amount of pool coin to withdraw

Example

crescentd tx liquidity cancel-all-orders 1,2,3 \
--chain-id localnet \
--from alice \
--keyring-backend=test \
--broadcast-mode block \
--yes \
--output json | jq

CancelMMOrder

Cancel a market making order in a pair. This will cancel all limit orders in the pair made by the mm order.

Usage

cancel-mm-order [pair-id]
Argument Description
pair-id pair id

Example

crescentd tx liquidity cancel-mm-order 1 \
--chain-id localnet \
--from alice \
--keyring-backend=test \
--broadcast-mode block \
--yes \
--output json | jq

Query

Params

Query the current liquidity parameters information

Usage

params

Example

crescentd q liquidity params -o json | jq

Pairs

Query for all pairs

Usage

pairs

Example

# Query all pairs
crescentd q liquidity pairs -o json | jq

# Query all pairs that has the defined denom
crescentd q liquidity pairs --denoms=uatom -o json | jq

# Query all pairs that has the defined denoms
crescentd q liquidity pairs --denoms=uatom,uusd -o json | jq

Pair

Query details for the particular pair

Usage

pair [pair-id]

Example

crescentd q liquidity pair 1 -o json | jq

Pools

Query for all pools

Usage

pools

Example

# Query all pools
crescentd q liquidity pools -o json | jq

# Query all pools that has the pair id
crescentd q liquidity pools -o json --pair-id=1 | jq

# Query all pools with disabled flag
crescentd q liquidity pools -o json --disabled=false | jq

Pool

Query details for the particular pool

Usage

pool [pool-id]

Example

# Query the specific pool
crescentd q liquidity pool 1 -o json | jq

# Query the specific pool that has the defined pool coin denom
crescentd q liquidity pool --pool-coin-denom=pool1 -o json | jq

DepositRequests

Query for all deposit requests in the pool

Usage

deposit-requests [pool-id]

Example

crescentd q liquidity deposit-requests 1 -o json | jq

DepositRequest

Query details for the particular deposit request in the pool

Usage

deposit-request [pool-id] [id]

Example

crescentd q liquidity deposit-request 1 1 -o json | jq

WithdrawRequests

Query for all withdraw requests in the pool

Usage

withdraw-requests [pool-id]

Example

crescentd q liquidity withdraw-requests 1 -o json | jq

WithdrawRequest

Query details for the particular withdraw request in the pool

Usage

withdraw-request [pool-id] [id]

Example

crescentd q liquidity withdraw-request 1 1 -o json | jq

Orders

Query for all orders made by an orderer or in the pair.

Usage

orders

Example

crescentd q liquidity orders cre1zaavvzxez0elundtn32qnk9lkm8kmcszxclz6p \
-o json | jq

crescentd q liquidity orders cre1zaavvzxez0elundtn32qnk9lkm8kmcszxclz6p \
--pair-id=1 \
-o json | jq

crescentd q liquidity orders \
--pair-id=1 \
-o json | jq

Order

Query details for the particular order

Usage

order [pair-id] [id]

Example

crescentd q liquidity order 1 1

OrderBooks

Query order books for given pairs and tick precisions.

Usage

order-books [pair-ids] [tick-precisions]

Example

crescentd order-books 1 --num-ticks=10

crescentd order-books 1,2,3