No project description provided
Project description
Charli3 Dendrite
Python SDK for interacting with Cardano DEXs
Overview
Charli3 Dendrite is a powerful Python SDK designed for seamless interaction with multiple Decentralized Exchanges (DEXs) on the Cardano blockchain. It provides a unified interface for developers to access various DEX functionalities, simplifying the process of building applications in the Cardano ecosystem.
Key Features
- 🔄 Multi-DEX Support: Integrate with Minswap, MuesliSwap, Spectrum, SundaeSwap, VyFi, GeniusYield, Axo, and WingRiders
- 💧 Liquidity Pool Data: Fetch and analyze pool information across different DEXs
- 💱 Swap Operations: Execute token swaps with ease
- 🧩 Flexible Asset Handling: Manage various asset types and pool states efficiently
- 🔗 On-chain Data Integration: Connect with Blockfrost or custom data providers
- 🛠 Extensible Architecture: Easily add support for new DEXs and features
Quick Start
Installation
# Using pip
pip install charli3_dendrite
# Using Poetry
poetry add charli3_dendrite
Supported DEXs
Charli3 Dendrite currently supports the following Cardano DEXs:
- Minswap
- MuesliSwap
- Spectrum
- SundaeSwap
- VyFi
- WingRiders
- GeniusYield
- Axo
Upcoming DEXs
- CardanoSwaps
- Metadex
- CSwap
Not Supported
- TeddySwap
- Cerra
- SaturnSwap
- Splash
Each DEX is implemented as a separate module within the charli3 dendrite.dexs.amm
package.
Core Components
AbstractPoolState
The AbstractPoolState
class in amm_base.py
provides the base implementation for AMM (Automated Market Maker) pool states. It includes methods for:
- Extracting pool information
- Handling swap operations
- Calculating prices and TVL (Total Value Locked)
AbstractPairState
The AbstractPairState
class in base.py
defines the interface for all pair states (both AMM and orderbook-based). It includes abstract methods that must be implemented by specific DEX classes.
Assets
The Assets
class in models.py
represents a collection of assets (tokens) and their quantities. It provides utility methods for working with asset collections, including addition and subtraction operations.
Configuration
Charli3 Dendrite can be configured using environment variables or a .env
file. See sample.env
for an example of the configuration options.
Data Provider Configuration
Charli3 Dendrite supports multiple data providers to fetch on-chain data. Currently, it supports Blockfrost and DBSync, with plans to add Ogmios and Kupo in the future.
Blockfrost Configuration
Blockfrost is the default data provider for Charli3 Dendrite. To use Blockfrost, you need to set up your API key in the environment variables or .env
file:
PROJECT_ID="your-blockfrost-project-id"
NETWORK="mainnet" # or "testnet" for the Cardano testnet
DBSync Configuration
Charli3 Dendrite also supports using a DBSync instance as a data provider. To configure DBSync, set the following environment variables:
DBSYNC_HOST="your-dbsync-host"
DBSYNC_PORT="your-dbsync-port"
DBSYNC_DB_NAME="your-dbsync-database-name"
DBSYNC_USER="your-dbsync-username"
DBSYNC_PASS="your-dbsync-password"
Future Plans: Ogmios and Kupo
We are planning to add support for Ogmios and Kupo as additional data providers in future releases. These will offer alternative ways to interact with the Cardano blockchain and may provide performance improvements or additional features. Stay tuned for updates on the integration of these providers. Once implemented, they will be configurable in a similar manner to the existing providers.
Wallet Configuration
Charli3 Dendrite supports wallet integration for performing transactions. You can configure a wallet using a mnemonic phrase:
WALLET_MNEMONIC="your wallet mnemonic phrase"
Development
To set up the development environment:
- Clone the repository
- Install dependencies:
poetry install
- Set up pre-commit hooks:
pre-commit install
Running Tests
poetry run pytest --benchmark-disable -v --slow -n auto
For parallel test execution:
poetry run pytest -n auto
Contributing
Contributions to Charli3 Dendrite are welcome! Please refer to the CONTRIBUTING.md
file for guidelines on how to contribute to the project.
Project details
Release history Release notifications | RSS feed
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
File details
Details for the file charli3_dendrite-1.0.0.dev1.tar.gz
.
File metadata
- Download URL: charli3_dendrite-1.0.0.dev1.tar.gz
- Upload date:
- Size: 52.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.10.13 Linux/5.15.0-106-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 413e3962d05d218cc81b5cb91c0b1712b014c158086c17eb9b5754987d1d5404 |
|
MD5 | 67daafcee0c06ff0b4375592d8d8e10b |
|
BLAKE2b-256 | 3eeddb8fe163e97e99d21042820b7c55fda6b0743bd54e38d8a305691c024ea2 |
File details
Details for the file charli3_dendrite-1.0.0.dev1-py3-none-any.whl
.
File metadata
- Download URL: charli3_dendrite-1.0.0.dev1-py3-none-any.whl
- Upload date:
- Size: 65.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.10.13 Linux/5.15.0-106-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 078884cd872c7415dbf2e412f2fff50aaa6dc3b6c10edea080a45de27eb6524a |
|
MD5 | ece432053863743bfc24e9577bd54aca |
|
BLAKE2b-256 | ef5d02dd17157b4fead13989d37ee1f64073a1857da030c4df54e552cc877431 |