mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-30 07:26:46 +00:00
* gateio: Add multi asset websocket support WIP. * meow * Add tests and shenanigans * integrate flushing and for enabling/disabling pairs from rpc shenanigans * some changes * linter: fixes strikes again. * Change name ConnectionAssociation -> ConnectionCandidate for better clarity on purpose. Change connections map to point to candidate to track subscriptions for future dynamic connections holder and drop struct ConnectionDetails. * Add subscription tests (state functional) * glorious:nits + proxy handling * Spelling * linter: fixerino * instead of nil, dont do nil. * clean up nils * cya nils * don't need to set URL or check if its running * stream match update * update tests * linter: fix * glorious: nits + handle context cancellations * stop ping handler routine leak * * Fix bug where reader routine on error that is not a disconnection error but websocket frame error or anything really makes the reader routine return and then connection never cycles and the buffer gets filled. * Handle reconnection via an errors.Is check which is simpler and in that scope allow for quick disconnect reconnect without waiting for connection cycle. * Dial now uses code from DialContext but just calls context.Background() * Don't allow reader to return on parse binary response error. Just output error and return a non nil response * Allow rollback on connect on any error across all connections * fix shadow jutsu * glorious/gk: nitters - adds in ws mock server * linter: fix * fix deadlock on connection as the previous channel had no reader and would hang connection reader for eternity. * glorious: whooops * gk: nits * Leak issue and edge case * Websocket: Add SendMessageReturnResponses * whooooooopsie * gk: nitssssss * Update exchanges/stream/stream_match.go Co-authored-by: Gareth Kirwan <gbjkirwan@gmail.com> * Update exchanges/stream/stream_match_test.go Co-authored-by: Gareth Kirwan <gbjkirwan@gmail.com> * linter: appease the linter gods * gk: nits * gk: drain brain * started * more changes before merge match pr * gateio: still building out * gateio: finish spot * fix up tests in gateio * Add tests for stream package * rm unused field * glorious: nits * rn files, specifically set function names to asset and offload routing to websocket type. * linter: fix * Add futures websocket request support * gateio: integrate with IBOTExchange (cherry pick my nose) * linter: fix * glorious: nits * add counter and update gateio * fix collision issue * Update exchanges/stream/websocket.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * glorious: nits * add tests * linter: fix * After merge * Add error connection info * upgrade to upstream merge * Fix edge case where it does not reconnect made by an already closed connection * stream coverage * glorious: nits * glorious: nits removed asset error handling in stream package * linter: fix * rm block * Add basic readme * fix asset enabled flush cycle for multi connection * spella: fix * linter: fix * Add glorious suggestions, fix some race thing * reinstate name before any routine gets spawned * stop on error in mock tests * glorious: nits * Set correct price * glorious: nits found in CI build * Add test for drain, bumped wait times as there seems to be something happening on macos CI builds, used context.WithTimeout because its instant. * mutex across shutdown and connect for protection * lint: fix * test time withoffset, reinstate stop * fix whoops * const trafficCheckInterval; rm testmain * y * fix lint * bump time check window * stream: fix intermittant test failures while testing routines and remove code that is not needed. * spells * cant do what I did * protect race due to routine. * update testURL * use mock websocket connection instead of test URL's * linter: fix * remove url because its throwing errors on CI builds * connections drop all the time, don't need to worry about not being able to echo back ws data as it can be easily reviewed _test file side. * remove another superfluous url thats not really set up for this * spawn overwatch routine when there is no errors, inline checker instead of waiting for a time period, add sleep inline with echo handler as this is really quick and wanted to ensure that latency is handing correctly * linter: fixerino uperino * fix ID bug, why I do this, I don't know. * glorious: panix * linter: things * whoops * dont need to make consecutive Unix() calls * websocket: fix potential panic on error and no responses and adding waitForResponses * rm json parser and handle in json package instead * in favour of json package unmarshalling * linter: fix * linter: fix again * * change field name OutboundRequestSignature to WrapperDefinedConnectionSignature for agnostic inbound and outbound connections. * change method name GetOutboundConnection to GetConnection for agnostic inbound and outbound connections. * drop outbound field map for improved performance just using a range and field check (less complex as well) * change field name connections to connectionToWrapper for better clarity * spells and magic and wands * glorious: nits * comparable check for signature * mv err var * glorious: nits and stuff * attempt to fix race * glorious: nits * gk: nits; engine log cleanup * gk: nits; OCD * gk: nits; move function change file names * gk: nits; 🚀 * gk: nits; convert variadic function and message inspection to interface and include a specific function for that handling so as to not need nil on every call * gk: nits; continued * gk: engine nits; rm loaded exchange * gk: nits; drop WebsocketLoginResponse * stream: Add match method EnsureMatchWithData * gk: nits; rn Inspect to IsFinal * gk: nits; rn to MessageFilter * linter: fix * gateio: update rate limit definitions (cherry-pick) * Add test and missing * Shared REST rate limit definitions with Websocket service, set lookup item to nil for systems that do not require rate limiting; add glorious nit * integrate rate limits for websocket trading spot * conform to match upstream changes * standardise names to upstream style * fix wrapper standards test when sending a auth request through a websocket connection * whoops * Update exchanges/gateio/gateio_types.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * glorious: nits * linter: fix * linter: overload * whoops * spelling fixes on recent merge * glorious: nits * linter: fix? * glorious: nits * gk: assert errors touched * gk: unexport derive functions * gk: nitssssssss * fix test * gk: nitters v1 * gk: http status * gk/nits: Add getAssetFromFuturesPair * gk: nits single response when submitting * gk: new pair with delimiter in tests * gk: param update slice to slice of pointers * gk: add asset type in params, includes t.Context() for tests * linter: fix * linter: fix * fix merge whoopsie * glorious: nits * gk: nit * shift over to websocket package error * internal/exchange/websocket -> exchange/websocket * PEAK OCD! * appease the OCD gods * thrasher: nits --------- Co-authored-by: shazbert <ryan.oharareid@thrasher.io> Co-authored-by: Gareth Kirwan <gbjkirwan@gmail.com> Co-authored-by: Scott <gloriousCode@users.noreply.github.com>
216 lines
9.7 KiB
Markdown
216 lines
9.7 KiB
Markdown
<img src="/common/gctlogo.png?raw=true" width="350px" height="350px" hspace="70">
|
|
|
|
[](https://github.com/thrasher-corp/gocryptotrader/actions/workflows/tests.yml)
|
|
[](https://github.com/thrasher-corp/gocryptotrader/blob/master/LICENSE)
|
|
[](https://godoc.org/github.com/thrasher-corp/gocryptotrader)
|
|
[](https://codecov.io/gh/thrasher-corp/gocryptotrader)
|
|
[](https://goreportcard.com/report/github.com/thrasher-corp/gocryptotrader)
|
|
|
|
A cryptocurrency trading bot supporting multiple exchanges written in Golang.
|
|
|
|
**Please note that this bot is under development and is not ready for production!**
|
|
|
|
## Community
|
|
|
|
Join our slack to discuss all things related to GoCryptoTrader! [GoCryptoTrader Slack](https://join.slack.com/t/gocryptotrader/shared_invite/enQtNTQ5NDAxMjA2Mjc5LTc5ZDE1ZTNiOGM3ZGMyMmY1NTAxYWZhODE0MWM5N2JlZDk1NDU0YTViYzk4NTk3OTRiMDQzNGQ1YTc4YmRlMTk)
|
|
|
|
## Exchange Support Table
|
|
|
|
| Exchange | REST API | Streaming API | FIX API |
|
|
|----------|------|-----------|-----|
|
|
| Alphapoint | Yes | Yes | NA |
|
|
| Binance.US| Yes | Yes | NA |
|
|
| Binance| Yes | Yes | NA |
|
|
| Bitfinex | Yes | Yes | NA |
|
|
| Bitflyer | Yes | No | NA |
|
|
| Bithumb | Yes | Yes | NA |
|
|
| BitMEX | Yes | Yes | NA |
|
|
| Bitstamp | Yes | Yes | No |
|
|
| BTCMarkets | Yes | Yes | NA |
|
|
| BTSE | Yes | Yes | NA |
|
|
| Bybit | Yes | Yes | NA |
|
|
| CoinbasePro | Yes | Yes | No|
|
|
| COINUT | Yes | Yes | NA |
|
|
| Deribit | Yes | Yes | No |
|
|
| Exmo | Yes | NA | NA |
|
|
| GateIO | Yes | Yes | NA |
|
|
| Gemini | Yes | Yes | No |
|
|
| HitBTC | Yes | Yes | No |
|
|
| Huobi.Pro | Yes | Yes | NA |
|
|
| Kraken | Yes | Yes | NA |
|
|
| Kucoin | Yes | Yes | NA |
|
|
| Lbank | Yes | No | NA |
|
|
| Okx | Yes | Yes | NA |
|
|
| Poloniex | Yes | Yes | NA |
|
|
| Yobit | Yes | NA | NA |
|
|
|
|
We are aiming to support the top 30 exchanges sorted by average liquidity as [ranked by CoinMarketCap](https://coinmarketcap.com/rankings/exchanges/).
|
|
However, we welcome pull requests for any exchange which does not match this criterion. If you need help with this, please join us on [Slack](https://join.slack.com/t/gocryptotrader/shared_invite/enQtNTQ5NDAxMjA2Mjc5LTc5ZDE1ZTNiOGM3ZGMyMmY1NTAxYWZhODE0MWM5N2JlZDk1NDU0YTViYzk4NTk3OTRiMDQzNGQ1YTc4YmRlMTk).
|
|
|
|
** NA means not applicable as the exchange does not support the feature.
|
|
|
|
## Current Features
|
|
|
|
+ Support for all exchange fiat and digital currencies, with the ability to individually toggle them on/off.
|
|
+ AES256 encrypted config file.
|
|
+ REST API support for all exchanges.
|
|
+ Websocket support for applicable exchanges.
|
|
+ Ability to turn off/on certain exchanges.
|
|
+ Communication packages (Slack, SMS via SMSGlobal, Telegram and SMTP).
|
|
+ HTTP rate limiter package.
|
|
+ Unified API for exchange usage.
|
|
+ Customisation of HTTP client features including setting a proxy, user agent and adjusting transport settings.
|
|
+ NTP client package.
|
|
+ Database support (Postgres and SQLite3). See [database](/database/README.md).
|
|
+ OTP generation tool. See [gen otp](/cmd/gen_otp).
|
|
+ Connection monitor package.
|
|
+ gRPC service and JSON RPC proxy. See [gRPC service](/gctrpc/README.md).
|
|
+ gRPC client. See [gctcli](/cmd/gctcli/README.md).
|
|
+ Forex currency converter packages (CurrencyConverterAPI, CurrencyLayer, Exchange Rates, Fixer.io, OpenExchangeRates, Exchange Rate Host).
|
|
+ Packages for handling currency pairs, tickers and orderbooks.
|
|
+ Portfolio management tool; fetches balances from supported exchanges and allows for custom address tracking.
|
|
+ Basic event trigger system.
|
|
+ OHLCV/Candle retrieval support. See [OHLCV](/docs/OHLCV.md).
|
|
+ Scripting support. See [gctscript](/gctscript/README.md).
|
|
+ Recent and historic trade processing. See [trades](/exchanges/trade/README.md).
|
|
+ Backtesting application. An event-driven backtesting tool to test and iterate trading strategies using historical or custom data. See [backtester](/backtester/README.md).
|
|
+ WebGUI (discontinued).
|
|
+ Exchange HTTP mock testing. See [mock](/exchanges/mock/README.md).
|
|
+ Exchange multichain deposits and withdrawals for specific exchanges. See [multichain transfer support](/docs/MULTICHAIN_TRANSFER_SUPPORT.md).
|
|
|
|
## Development Tracking
|
|
|
|
Our [Kanban board](https://github.com/orgs/thrasher-corp/projects/3) provides updates on:
|
|
|
|
+ New feature development
|
|
+ Bug fixes in progress
|
|
+ Recently completed work
|
|
+ Contribution opportunities
|
|
|
|
Follow our progress as we continuously improve GoCryptoTrader.
|
|
|
|
## Contribution
|
|
|
|
Please feel free to submit any pull requests or suggest any desired features to be added.
|
|
|
|
When submitting a PR, please abide by our coding guidelines:
|
|
|
|
+ Code must adhere to the official Go [formatting](https://golang.org/doc/effective_go.html#formatting) guidelines (i.e. uses [gofmt](https://golang.org/cmd/gofmt/)).
|
|
+ Code must be documented adhering to the official Go [commentary](https://golang.org/doc/effective_go.html#commentary) guidelines.
|
|
+ Code must adhere to our [coding style](https://github.com/thrasher-corp/gocryptotrader/blob/master/.github/CONTRIBUTING.md).
|
|
+ Pull requests need to be based on and opened against the `master` branch.
|
|
|
|
## Compiling and Running instructions
|
|
|
|
Download and install Go from [Go Downloads](https://golang.org/dl/) for your platform.
|
|
|
|
### Linux/macOS
|
|
|
|
```bash
|
|
git clone https://github.com/thrasher-corp/gocryptotrader.git
|
|
cd gocryptotrader
|
|
go build
|
|
mkdir ~/.gocryptotrader
|
|
cp config_example.json ~/.gocryptotrader/config.json
|
|
```
|
|
|
|
### Windows
|
|
|
|
```bash
|
|
git clone https://github.com/thrasher-corp/gocryptotrader.git
|
|
cd gocryptotrader
|
|
go build
|
|
mkdir %AppData%\GoCryptoTrader
|
|
copy config_example.json %APPDATA%\GoCryptoTrader\config.json
|
|
```
|
|
|
|
+ Make any necessary changes to the `config.json` file.
|
|
+ Run the `gocryptotrader` binary file.
|
|
|
|
### Sonic JSON handling
|
|
|
|
GoCryptoTrader can optionally use the [Sonic](https://github.com/bytedance/sonic) JSON library for improved performance, as a drop in replacement for golang.org/encoding/json.
|
|
Please see sonic [Requirements](https://github.com/bytedance/sonic/#requirement) for supported platforms.
|
|
|
|
To enable sonic, build with the sonic_on tag:
|
|
|
|
```bash
|
|
go build -tags=sonic_on
|
|
```
|
|
|
|
## Donations
|
|
|
|
<img src="https://github.com/thrasher-corp/gocryptotrader/blob/master/web/src/assets/donate.png?raw=true" hspace="70">
|
|
|
|
If this framework helped you in any way, or you would like to support the developers working on it, please donate Bitcoin to:
|
|
|
|
***bc1qk0jareu4jytc0cfrhr5wgshsq8282awpavfahc***
|
|
|
|
## Binaries
|
|
|
|
Binaries will be published once the codebase reaches a stable condition.
|
|
|
|
## Contributor List
|
|
|
|
### A very special thank you to all who have contributed to this program:
|
|
|
|
|User|Contribution Amount|
|
|
|--|--|
|
|
| [thrasher-](https://github.com/thrasher-) | 711 |
|
|
| [dependabot[bot]](https://github.com/apps/dependabot) | 369 |
|
|
| [shazbert](https://github.com/shazbert) | 362 |
|
|
| [gloriousCode](https://github.com/gloriousCode) | 237 |
|
|
| [gbjk](https://github.com/gbjk) | 125 |
|
|
| [dependabot-preview[bot]](https://github.com/apps/dependabot-preview) | 88 |
|
|
| [xtda](https://github.com/xtda) | 47 |
|
|
| [lrascao](https://github.com/lrascao) | 27 |
|
|
| [Beadko](https://github.com/Beadko) | 24 |
|
|
| [ydm](https://github.com/ydm) | 15 |
|
|
| [vazha](https://github.com/vazha) | 15 |
|
|
| [Rots](https://github.com/Rots) | 15 |
|
|
| [ermalguni](https://github.com/ermalguni) | 14 |
|
|
| [MadCozBadd](https://github.com/MadCozBadd) | 13 |
|
|
| [samuael](https://github.com/samuael) | 11 |
|
|
| [vadimzhukck](https://github.com/vadimzhukck) | 10 |
|
|
| [geseq](https://github.com/geseq) | 8 |
|
|
| [marcofranssen](https://github.com/marcofranssen) | 8 |
|
|
| [140am](https://github.com/140am) | 8 |
|
|
| [junnplus](https://github.com/junnplus) | 8 |
|
|
| [TaltaM](https://github.com/TaltaM) | 6 |
|
|
| [cranktakular](https://github.com/cranktakular) | 6 |
|
|
| [dackroyd](https://github.com/dackroyd) | 5 |
|
|
| [khcchiu](https://github.com/khcchiu) | 5 |
|
|
| [yangrq1018](https://github.com/yangrq1018) | 4 |
|
|
| [woshidama323](https://github.com/woshidama323) | 3 |
|
|
| [crackcomm](https://github.com/crackcomm) | 3 |
|
|
| [mshogin](https://github.com/mshogin) | 2 |
|
|
| [herenow](https://github.com/herenow) | 2 |
|
|
| [tk42](https://github.com/tk42) | 2 |
|
|
| [andreygrehov](https://github.com/andreygrehov) | 2 |
|
|
| [azhang](https://github.com/azhang) | 2 |
|
|
| [bretep](https://github.com/bretep) | 2 |
|
|
| [Christian-Achilli](https://github.com/Christian-Achilli) | 2 |
|
|
| [cornelk](https://github.com/cornelk) | 2 |
|
|
| [gam-phon](https://github.com/gam-phon) | 2 |
|
|
| [if1live](https://github.com/if1live) | 2 |
|
|
| [lozdog245](https://github.com/lozdog245) | 2 |
|
|
| [MarkDzulko](https://github.com/MarkDzulko) | 2 |
|
|
| [soxipy](https://github.com/soxipy) | 2 |
|
|
| [blombard](https://github.com/blombard) | 1 |
|
|
| [cavapoo2](https://github.com/cavapoo2) | 1 |
|
|
| [CodeLingoTeam](https://github.com/CodeLingoTeam) | 1 |
|
|
| [CodeLingoBot](https://github.com/CodeLingoBot) | 1 |
|
|
| [Daanikus](https://github.com/Daanikus) | 1 |
|
|
| [daniel-cohen](https://github.com/daniel-cohen) | 1 |
|
|
| [DirectX](https://github.com/DirectX) | 1 |
|
|
| [frankzougc](https://github.com/frankzougc) | 1 |
|
|
| [idoall](https://github.com/idoall) | 1 |
|
|
| [Jimexist](https://github.com/Jimexist) | 1 |
|
|
| [lookfirst](https://github.com/lookfirst) | 1 |
|
|
| [m1kola](https://github.com/m1kola) | 1 |
|
|
| [mattkanwisher](https://github.com/mattkanwisher) | 1 |
|
|
| [merkeld](https://github.com/merkeld) | 1 |
|
|
| [mKurrels](https://github.com/mKurrels) | 1 |
|
|
| [starit](https://github.com/starit) | 1 |
|
|
| [zeldrinn](https://github.com/zeldrinn) | 1 |
|