Python SDK for MangroveMarkets — DEX aggregation, wallet management, and portfolio analytics for agents
Project description
mangrovemarkets
Python SDK for MangroveMarkets -- DEX aggregation, wallet management, and portfolio analytics for agents.
Installation
pip install mangrovemarkets
Quickstart
The MangroveMarkets MCP server requires an API key for authenticated endpoints. You can pass it explicitly via the api_key parameter or set the MANGROVE_API_KEY environment variable (the SDK reads it automatically as a fallback).
import os
from mangrovemarkets import MangroveMarkets
client = MangroveMarkets(
base_url="https://mangrovemarkets-pcqgpciucq-uc.a.run.app",
api_key="prod_...", # or rely on MANGROVE_API_KEY env var
)
# Chain info
info = client.wallet.chain_info(chain="evm")
print(f"Chain: {info.chain}, Native token: {info.native_token}")
# DEX venues
venues = client.dex.supported_venues()
for v in venues:
print(f" {v.id}: {v.name} ({v.chain}) - {v.supported_pairs_count} pairs")
# Portfolio value
value = client.portfolio.value(addresses="0xYOUR_WALLET_ADDRESS")
print(f"Total portfolio: ${value.total_value_usd:,.2f}")
client.close()
The client also works as a context manager (and picks up MANGROVE_API_KEY / MANGROVE_BASE_URL from the environment):
with MangroveMarkets() as client:
venues = client.dex.supported_venues()
For local development, point the client at a locally running MCP server:
client = MangroveMarkets(base_url="http://localhost:8080", api_key=os.getenv("MANGROVE_API_KEY"))
Getting an API key
-
Sign up at https://mangrovedeveloper.ai.
-
Go to Settings -> API Keys -> Create.
-
Copy the key -- it is shown only once.
-
Export it as
MANGROVE_API_KEYor pass it directly toMangroveMarkets(api_key=...):export MANGROVE_API_KEY="prod_..."
If you call the API without a valid key, the server returns HTTP 401 with this payload:
{"detail": "Missing or malformed Authorization header. Expected: Bearer <api_key>"}
Full swap flow
A DEX swap goes through six steps: quote, approve, prepare, sign locally, broadcast, and confirm.
import os
from mangrovemarkets import MangroveMarkets
client = MangroveMarkets(
base_url="https://mangrovemarkets-pcqgpciucq-uc.a.run.app",
api_key=os.getenv("MANGROVE_API_KEY"),
)
# 1. Get a quote
quote = client.dex.get_quote(
input_token="0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913", # USDC on Base
output_token="0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE", # ETH
amount=1_000_000, # 1 USDC (6 decimals)
chain_id=8453,
)
print(f"Quote: {quote.input_amount} -> {quote.output_amount} (rate: {quote.exchange_rate})")
# 2. Approve token spending (ERC-20 only, returns None if already approved)
approval = client.dex.approve_token(
token_address="0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913",
chain_id=8453,
wallet_address="0xYOUR_WALLET",
)
if approval:
# Sign the approval tx with your local signer, then broadcast
# signed_approval = your_signer.sign(approval.payload)
# client.dex.broadcast(signed_tx=signed_approval, chain_id=8453)
pass
# 3. Prepare the swap transaction
swap_tx = client.dex.prepare_swap(
quote_id=quote.quote_id,
wallet_address="0xYOUR_WALLET",
)
# 4. Sign locally (SDK never touches private keys)
# signed_swap = your_signer.sign(swap_tx.payload)
# 5. Broadcast
# result = client.dex.broadcast(signed_tx=signed_swap, chain_id=8453)
# 6. Confirm
# status = client.dex.tx_status(tx_hash=result.tx_hash, chain_id=8453)
client.close()
Configuration
| Parameter | Env var | Default | Description |
|---|---|---|---|
base_url |
MANGROVE_BASE_URL |
https://mangrovemarkets-pcqgpciucq-uc.a.run.app |
MCP server URL (use http://localhost:8080 for local dev) |
api_key |
MANGROVE_API_KEY |
None |
API key for authenticated endpoints |
timeout |
-- | 30.0 |
Request timeout in seconds |
max_retries |
-- | 3 |
Max retries on 429/5xx |
auto_retry |
-- | True |
Enable automatic retry with backoff |
Examples
See the examples/ directory for runnable scripts:
- quickstart.py -- chain info and DEX venues
- swap_flow.py -- full swap lifecycle
- portfolio_check.py -- portfolio value, P&L, and token holdings
- e2e_swap.py -- a real 0.1 USDC → ETH swap on Base mainnet (requires
web3and a funded wallet; install withpip install mangrovemarkets[e2e]orpip install web3)
Run the end-to-end swap with:
E2E_SWAP_PRIVATE_KEY=0x... MANGROVE_API_KEY=prod_... python examples/e2e_swap.py
Costs a few cents in gas per run. Never runs in CI.
Security
The SDK never stores or transmits private keys. All signing happens locally in your application. The prepare_swap and approve_token methods return unsigned transaction payloads that you sign with your own wallet/signer before broadcasting through broadcast.
API reference
This SDK wraps the MangroveMarkets MCP Server REST API. For full tool documentation, parameter details, and response schemas, see the MangroveMarkets-MCP-Server repository.
License
MIT
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mangrovemarkets-0.1.1.tar.gz.
File metadata
- Download URL: mangrovemarkets-0.1.1.tar.gz
- Upload date:
- Size: 19.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5862cb7fbe173cc97cb872419879e72197515c7b43018ada9378036ab0a627d6
|
|
| MD5 |
6dc5bdcb34ec05f9a7cd08f62b1b2194
|
|
| BLAKE2b-256 |
2a3bb6c48ef9bcb821d832e22af5cb8217f2be99ed7bb38561c757c224a677ec
|
File details
Details for the file mangrovemarkets-0.1.1-py3-none-any.whl.
File metadata
- Download URL: mangrovemarkets-0.1.1-py3-none-any.whl
- Upload date:
- Size: 19.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e8ac4715dfcf5e116bc89fe9ff23529e985a10e2f0293e179e10b87bd45d421e
|
|
| MD5 |
4f0953addeb4e5340cfc4762da9a8d75
|
|
| BLAKE2b-256 |
4f420bef8c65fafa574f1b721518627fbb336575e360afb48cc8c5186e7877d0
|