REST API and WebSocket asyncio wrapper with grpc powered multiplexer server
Project description
Crypto exchanges API/WSS wrapper with grpc powered server
Binance, Bitfinex, Huobi, OKX,
For SPOT markets
From v1.3.6b4
, v1.3.6b7
must be updated exch_srv_cfg.toml
(see CHANGELOG for details)
exchanges-wrapper vs binance.py
The main difference is the development of the project for trading with many exchanges.
Next is adding a new module exchanges_wrapper/exch_srv.py
as a multiplexer layer, providing simultaneous async interaction for many accounts
and many trading pairs through one connection. It's powered by gRPC
Remote Procedure Call framework.
Warning. Coverage of overridden binance.py packages is significant but not complete.
Served methods describes into example/exch_client.py
Initial capabilities (inherited from binance.py)
- Covers general endpoints (test connectivity and get exchange information's)
- Covers market data endpoints
- Covers Account endpoints (create and manage orders)
- Covers user data stream (receive real time user updates)
- Covers web socket streams (receive real time market updates)
- Async support
- Auto reconnect after exchanges API or network failure
- Completely free and without limitations
Added Features
- Multi exchanges support
- Adaptive algorithm to ensure maximum performance and avoid exceeding the rates limits
- Passthrough logging
- WSS keepalive
- Reuse session for new client sessions
- Utilizing Websocket API (bidirectional) for the most commonly used methods (Binance ws-api/v3, )
Extra exchanges implementation features
- Binance REST API and WSS are accepted as basic, connection of other exchanges wrapped their API to Binance compatible
- For other, some data cannot be obtained by directly calling one method, it is generated by a synthetic or calculation method
- Some exchanges have not any testing or "paper trading" features, therefore, application development and testing is possible only at real bidding. First, run applications on the Binance Spot Test Network or (Bitfinex, OKX) test account.
Get started
Prepare exchange account
- Create account on Binance and get 10% discount on all trading fee
- Create account on Bitfinex and get 6% rebate fee
- Create account on HUOBI and get 10% cashback on all trading fee
- Create account on OKX and get Mystery Boxes worth up to $10,000
- For test purpose log in at Binance Spot Test Network
- Create API Key
- After install and create environment specify api_key and api_secret in
/home/ubuntu/.MartinBinance/config/exch_srv_cfg.toml
Install use PIP
To install just run the following command:
pip install exchanges-wrapper
After first install create environment by run exchanges-wrapper-init
in terminal window.
The structure of the working directory will be created and the necessary files will be copied:
For Ubuntu it will be here: home/user/.MartinBinance/
For upgrade to latest versions use:
pip install -U exchanges-wrapper
Start server
-
Run in terminal window
exchanges-wrapper-srv
-
Use an example to study
- Copy example/ms_cfg.toml
to
/home/ubuntu/.MartinBinance/config/
and select (uncomment) desired exchange. Don't change exchange name. - Run example/exch_client.py in other terminal window
- Copy example/ms_cfg.toml
to
Use Docker image
docker pull ghcr.io/dogstailfarmer/exchanges-wrapper:latest
First run
The structure of the working directory will be created and the necessary files will be copied:
For Ubuntu it will be here: home/user/.MartinBinance/
docker run --rm --entrypoint /bin/sh exchanges-wrapper -c "cat ./exchanges_wrapper/__init__.py" > init.py && \
docker run --rm --entrypoint /bin/sh exchanges-wrapper -c "cat ./exchanges_wrapper/exch_srv_cfg.toml.template" > exch_srv_cfg.toml.template &&\
python3 init.py && rm init.py && rm exch_srv_cfg.toml.template
Start server
docker run -itP \
--mount type=bind,source=/home/ubuntu/.MartinBinance,target=/home/appuser/.MartinBinance \
--network=host \
--restart=always \
--name=exchanges-wrapper \
exchanges-wrapper
Documentations
- For binance.py use original
- Served methods and examples of their use are described at
example/exch_client.py
- For Protocol Buffers serializing structured data
see
proto/exchanges_wrapper/api.proto
Donate
BNB, BUSD, USDT (BEP20) 0x5b52c6ba862b11318616ee6cef64388618318b92
USDT (TRC20) TP1Y43dpY7rrRyTSLaSKDZmFirqvRcpopC
Powered by exchanges-wrapper
Free trading system for crypto exchanges SPOT markets. Adaptive customizable reverse grid strategy based on martingale.
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 exchanges_wrapper-1.3.7.post3.tar.gz
.
File metadata
- Download URL: exchanges_wrapper-1.3.7.post3.tar.gz
- Upload date:
- Size: 55.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2efa75111ab8f58f05492c918c2c8b2b40504f5e464bd8c2a6a9f724b9695886 |
|
MD5 | 02d7b9f614a5ff349f40e03914a1f182 |
|
BLAKE2b-256 | 3a22a025d0980374e212ce44c82ce8132d0162d3d1280a885da77c0e73ac0a7c |
File details
Details for the file exchanges_wrapper-1.3.7.post3-py3-none-any.whl
.
File metadata
- Download URL: exchanges_wrapper-1.3.7.post3-py3-none-any.whl
- Upload date:
- Size: 60.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7be459ac2ccf216955d4035a3570c2a1e8820d1f0bf92cbaae70fd15c9fc32a3 |
|
MD5 | 0eca18ff64cf6bbf7aa91626f2702509 |
|
BLAKE2b-256 | fc4d0b7bef7537cdb5384fbc32d8e17bca692ac4776ead11496189b68c5ce034 |