Skip to main content
POST
/
v1
/
uniswap
/
liquidity_provision
/
mint
Python (SDK)
from compass_api_sdk import CompassAPI, models


with CompassAPI(
    api_key_auth="<YOUR_API_KEY_HERE>",
) as compass_api:

    res = compass_api.uniswap_v3.uniswap_liquidity_provision_mint(token0="USDC", token1="USDT", fee=models.FeeEnum.ONE_DOT_0, tick_lower=1823, tick_upper=2623, amount0_desired="0.05", amount1_desired="0.00", amount0_min="0", amount1_min="0", chain=models.UniswapMintLiquidityProvisionRequestChain.BASE, sender="0x41096de529D54718a5600185F8C4460979ed75C9", recipient="0x41096de529D54718a5600185F8C4460979ed75C9", estimate_gas=True)

    # Handle response
    print(res)
{
  "transaction": {
    "chainId": "0x2105",
    "data": "0x1688f0b900000000000000000000000029fcb43b46531bca003ddc8fcb67ffe91900c762000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000675f4a3d",
    "from": "0x4A83b4413CF41C3244027e1590E35a0F48403F0c",
    "gas": "0x7a120",
    "maxFeePerGas": "0x59682f00",
    "maxPriorityFeePerGas": "0x3b9aca00",
    "nonce": "0x5",
    "to": "0x4e1DCf7AD4e460CfD30791CCC4F9c8a4f820ec67",
    "value": "0x0"
  }
}

Authorizations

x-api-key
string
header
required

Your Compass API Key. Get your key here.

Body

application/json

Request model for minting a new liquidity position.

token0
string
default:USDC
required

The symbol or address of the first token in the pair.

Example:

"WETH"

token1
string
default:USDT
required

The symbol or address of the second token in the pair.

Example:

"WETH"

fee
enum<string>
default:1.0
required

The swap fee of the pool

Available options:
0.01,
0.05,
0.3,
1.0
Example:

"0.3"

tick_lower
integer
default:1823
required

The lower tick of the range to mint the position in

Required range: -887272 <= x <= 887272
Example:

-1000

tick_upper
integer
default:2623
required

The upper tick of the range to mint the position in

Required range: -887272 <= x <= 887272
Example:

1000

amount0_desired
default:0.05
required

The desired amount of the first token to deposit

Required range: x >= 0
Example:

"1.5"

amount1_desired
default:0.00
required

The desired amount of the second token to deposit

Required range: x >= 0
Example:

"1.7"

amount0_min
default:0
required

The minimum amount of the first token to deposit

Required range: x >= 0
Example:

"1.4"

amount1_min
default:0
required

The minimum amount of the second token to deposit

Required range: x >= 0
Example:

"1.6"

chain
enum<string>
default:base
required
Available options:
arbitrum,
base,
ethereum
sender
string
default:0x41096de529D54718a5600185F8C4460979ed75C9
required

The address of the transaction sender.

Example:

"0x29F20a192328eF1aD35e1564aBFf4Be9C5ce5f7B"

action_type
string
default:UNISWAP_MINT_LIQUIDITY_PROVISION
Allowed value: "UNISWAP_MINT_LIQUIDITY_PROVISION"
recipient
string | null
default:0x41096de529D54718a5600185F8C4460979ed75C9

The address that will receive the LP tokens

Example:

"0x29F20a192328eF1aD35e1564aBFf4Be9C5ce5f7B"

estimate_gas
boolean
default:true

Determines whether to estimate gas costs for transactions, also verifying that the transaction can be successfully executed.

Response

Successful Response

transaction
UnsignedTransaction · object
required

The unsigned transaction data. User must sign and broadcast to network.

Example:
{
"chainId": "0x2105",
"data": "0x1688f0b900000000000000000000000029fcb43b46531bca003ddc8fcb67ffe91900c762000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000675f4a3d",
"from": "0x4A83b4413CF41C3244027e1590E35a0F48403F0c",
"gas": "0x7a120",
"maxFeePerGas": "0x59682f00",
"maxPriorityFeePerGas": "0x3b9aca00",
"nonce": "0x5",
"to": "0x4e1DCf7AD4e460CfD30791CCC4F9c8a4f820ec67",
"value": "0x0"
}