This project runs trades automatically and send notifications. Basically you run the container and let the bot working for you.
Simple like:
Buy when it's cheap! And sell when it's expensive.
The intelligence of this bot use Relative Strength Index (RSI) to buy and sell automatically.
Fist, you need a binance api credentials.
If you don't have a binance api read How to create binance api.
To run the bot on your computer you need to have docker and compose installed.
Make sure you created the config.yaml
files:
cp config-example.yaml config.yaml
The bot configuration is provided by yaml file that
has the following trade parameters config.yaml
.
In this file, put the symbol price you want to buy and sell.
name: "go-binance-bot"
binance:
api_key: "xXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxX"
api_secret: "xXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxXxX"
notify:
webhook_url: "https://hooks.slack.com/services/ABABABABA/BABABABABAB/BLABLABLABLABLABLABLABLA"
trades:
- symbol: "BTC/USDT"
interval: "10s"
amount: 0.0004
rsi_buy: 30
rsi_sell: 70
rsi_limit: 14
rsi_interval: "15m"
- symbol: "BNB/USDT"
interval: "10s"
amount: 0.05
rsi_buy: 30
rsi_sell: 70
rsi_limit: 14
rsi_interval: "15m"
- symbol: "LOKA/USDT"
interval: "10s"
amount: 20
rsi_buy: 30
rsi_sell: 70
rsi_limit: 14
rsi_interval: "15m"
- symbol: "ETH/USDT"
interval: "10s"
amount: 0 # set zero to test the logic.
rsi_buy: 30
rsi_sell: 70
rsi_limit: 14
rsi_interval: "15m"
- symbol: Symbol name to trade -
string
- interval: Interval to the next trade -
time.Duration
- rsiBuy: When the rsi is below -
float64
- rsiSell: When the rsi is high -
float64
- rsiLimit: Quantity of registers to analize -
int
- rsi_interval: Interval of time to group of registers -
time.Duration
- limit: Limit of USDT that will negotiate -
float64
Finally start the containers to monitor the coins and open buy or sell order:
make up logs
...
app_1 | {"level":"info","time":"2022-03-28T13:19:31Z","message":"bot is running"}
app_1 | {"level":"debug","time":"2022-03-28T13:19:31Z","message":"monitor {BTC/USDT 1m0s 44630 44640}"}
app_1 | {"level":"debug","time":"2022-03-28T13:19:31Z","message":"monitor {LOKA/USDT 1m0s 2.295 2.34}"}
app_1 | {"level":"debug","time":"2022-03-28T13:19:35Z","message":"current price of BTC/USDT is 47282"}
app_1 | {"level":"debug","time":"2022-03-28T13:19:35Z","message":"time to SELL price 47282"}
...
To stop the bot and remove container, execute:
make clean
To contribute to the project, follow these steps:
- Clone the repository:
git clone git@github.com:rafaelbmateus/go-binance-bot.git
- Create a feature branch:
git switch -c feature-a
- Make changes and confirm (try using conventional commits):
git commit -m 'feat: new bot feature'
- Push the feature branch:
git push origin feature-a
- Create a pull request
- Get reviews from other users
- Merge to
main
branch (we encourage using commit squash) - Remove the branch merged.