Skip to main content

No project description provided

Project description

Charli3 Dendrite

Python SDK for interacting with Cardano DEXs

Python version License PRs welcome

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:

  1. Clone the repository
  2. Install dependencies: poetry install
  3. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

charli3_dendrite-1.0.0.dev0.tar.gz (51.7 kB view details)

Uploaded Source

Built Distribution

charli3_dendrite-1.0.0.dev0-py3-none-any.whl (65.7 kB view details)

Uploaded Python 3

File details

Details for the file charli3_dendrite-1.0.0.dev0.tar.gz.

File metadata

  • Download URL: charli3_dendrite-1.0.0.dev0.tar.gz
  • Upload date:
  • Size: 51.7 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

Hashes for charli3_dendrite-1.0.0.dev0.tar.gz
Algorithm Hash digest
SHA256 4cea040c5ccdbd5f0ff501618ff590de8fcf46b2da1603f1627d643d96ed5d26
MD5 7b297b4daf4a9e993ff7db7c8ad2ff8b
BLAKE2b-256 1f4734a9c53c255952f066e3300902d828ada7dfbe77e43650a46d54c9b06b2a

See more details on using hashes here.

File details

Details for the file charli3_dendrite-1.0.0.dev0-py3-none-any.whl.

File metadata

File hashes

Hashes for charli3_dendrite-1.0.0.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 2b0735cc75d99e886dcf6566a9d991bf4c258ca78574acdbcacd1bf77ff8a425
MD5 5486b3495cd6e6399bd907d7a27dfbf0
BLAKE2b-256 ff7fe286d20e2d06595c0ac447a718cfe71a3171aad12c9b4faf9126a9ae9645

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page