Skip to content

rafaelbmateus/go-binance-bot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Go Binance Bot

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.

Logic

The intelligence of this bot use Relative Strength Index (RSI) to buy and sell automatically.

Binance API

Fist, you need a binance api credentials.

If you don't have a binance api read How to create binance api.

How to run?

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

Config file

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

Running the bot

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

📫 Contributing

To contribute to the project, follow these steps:

  1. Clone the repository: git clone git@github.com:rafaelbmateus/go-binance-bot.git
  2. Create a feature branch: git switch -c feature-a
  3. Make changes and confirm (try using conventional commits): git commit -m 'feat: new bot feature'
  4. Push the feature branch: git push origin feature-a
  5. Create a pull request
  6. Get reviews from other users
  7. Merge to main branch (we encourage using commit squash)
  8. Remove the branch merged.