Skip to main content

A client for interacting with the Haveno daemon.

Project description

Python Haveno Client

The Haveno Client is a Python gRPC client that allows you to interact with the Haveno daemon, a decentralized cryptocurrency trading platform. This client enables you to connect to Haveno servers, access market data, manage accounts, and perform trades programmatically.

Features

  • Connect to multiple Haveno servers using gRPC.
  • Manage accounts, access market data, and make trades.
  • Supports SOCKS5 proxy for secure and private connections.
  • Modular design for different gRPC services (e.g., Accounts, Trades, Offers).

Requirements

  • Python 3.7+
  • grpcio and grpcio-tools
  • pysocks for SOCKS5 proxy support (optional)
  • Haveno server running and accessible

Installation

  1. Clone the repository:
   git clone https://github.com/KewbitXMR/python-haveno-client.git
   cd python-haveno-client
  1. Create a virtual environment (optional but recommended):
   python3 -m venv venv
   source venv/bin/activate
  1. Install dependencies:
   pip install -r requirements.txt

Usage

1. Initialize the Haveno Client

Here is an example of how to initialize the client and connect to a Haveno server:

   from haveno_client import HavenoClient

   # Create a Haveno client instance and connect to the server
   client = HavenoClient(host='localhost', port=3201, password='your_password', use_socks5=True, socks5_host='127.0.0.1', socks5_port=9050)

   # Perform operations using the client
   account_info = client.account_client.get_account_info('account_id')
   print(account_info)

   # Disconnect from the server
   client.disconnect()

2. Connect to Multiple Servers

You can create multiple instances of HavenoClient to connect to different Haveno servers:

   client1 = HavenoClient(host='localhost', port=50051, password='password1')
   client2 = HavenoClient(host='localhost', port=50052, password='password2', use_socks5=True)

   # Perform operations with each client...
   client1.disconnect()
   client2.disconnect()

3. Using Modular Service Stubs

The client provides modular stubs for each gRPC service, such as AccountClient, TradesClient, and OffersClient. Each stub can be accessed via the HavenoClient instance:

   # Example: Get account information
   account_info = client.account_client.get_account_info('account_id')

Development

Building the Package

To compile the package for distribution:

   python -m build

This will create the distribution files in the dist/ directory.

Running Tests

To run the test suite, use:

   python -m unittest discover tests/

Contributing

  1. Fork the repository.
  2. Create a new branch: git checkout -b my-feature-branch.
  3. Make your changes and commit them: git commit -m 'Add new feature'.
  4. Push to the branch: git push origin my-feature-branch.
  5. Submit a pull request.

License

This project is licensed under the MIT License. See the LICENSE file for more details.

Acknowledgments

  • The Haveno development team for building the Haveno decentralized exchange.
  • Contributors to the grpcio and pysocks libraries.
  • THIS PROJECT IS A WORK IN PROGRESS, ITS IS NOT YET SUITABLE FOR PRODUCTION ENVIRONMENTS

Contributors

The main contributor for this project is Kewbit for the purpose of making a funtional and effecient interface for the Django website on the original haveno.com but now used on haveno.app.

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

haveno_client-0.2.2.tar.gz (84.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

haveno_client-0.2.2-py3-none-any.whl (86.0 kB view details)

Uploaded Python 3

File details

Details for the file haveno_client-0.2.2.tar.gz.

File metadata

  • Download URL: haveno_client-0.2.2.tar.gz
  • Upload date:
  • Size: 84.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for haveno_client-0.2.2.tar.gz
Algorithm Hash digest
SHA256 2742dca457e281ffce7827fbf7b3d106d614d7609c0220fba788bac9ddf0e656
MD5 c2703114a70390c91a84fc83dd259d7c
BLAKE2b-256 d8d2153a85158437c87047f48716effa3b78ca2da2f84e4a7f125d9ff8df548c

See more details on using hashes here.

File details

Details for the file haveno_client-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: haveno_client-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 86.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for haveno_client-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7519dccb41b5448444c1724df200995154e3ff814d867370f7ac9fcdaba1cb23
MD5 8fc43665b2b88053e4596aa40602bb2c
BLAKE2b-256 c248bc2ad8435a28dbb42dc7abba8bea4e310569550c15af2fd764ad7ea8cfd4

See more details on using hashes here.

Supported by

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