2018-01-02 02:17:10 +00:00
# Configure the bot
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
This page explains how to configure your `config.json` file.
## Table of Contents
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
- [Bot commands ](#bot-commands )
- [Backtesting commands ](#backtesting-commands )
- [Hyperopt commands ](#hyperopt-commands )
## Setup config.json
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
We recommend to copy and use the `config.json.example` as a template
for your bot configuration.
The table below will list all configuration parameters.
| Command | Default | Mandatory | Description |
|----------|---------|----------|-------------|
| `max_open_trades` | 3 | Yes | Number of trades open your bot will have.
| `stake_currency` | BTC | Yes | Crypto-currency used for trading.
2018-05-25 14:04:08 +00:00
| `stake_amount` | 0.05 | Yes | Amount of crypto-currency your bot will use for each trade. Per default, the bot will use (0.05 BTC x 3) = 0.15 BTC in total will be always engaged. Set it to 'unlimited' to allow the bot to use all avaliable balance.
2018-03-24 09:21:59 +00:00
| `ticker_interval` | [1m, 5m, 30m, 1h, 1d] | No | The ticker interval to use (1min, 5 min, 30 min, 1 hour or 1 day). Default is 5 minutes
2018-01-02 02:17:10 +00:00
| `fiat_display_currency` | USD | Yes | Fiat currency used to show your profits. More information below.
2018-08-09 11:12:12 +00:00
| `dry_run` | true | Yes | Define if the bot must be in Dry-run or production mode.
| `ta_on_candle` | false | No | If set to true indicators are processed only once a new candle arrives. If false each loop populates the indicators, this will mean the same candle is processed many times creating system load but can be useful of your strategy depends on tick data not only candle. Can be set either in Configuration or in the strategy.
2018-01-18 07:06:37 +00:00
| `minimal_roi` | See below | No | Set the threshold in percent the bot will use to sell a trade. More information below. If set, this parameter will override `minimal_roi` from your strategy file.
| `stoploss` | -0.10 | No | Value of the stoploss in percent used by the bot. More information below. If set, this parameter will override `stoploss` from your strategy file.
2018-06-26 21:14:12 +00:00
| `trailing_stoploss` | false | No | Enables trailing stop-loss (based on `stoploss` in either configuration or strategy file).
| `trailing_stoploss_positve` | 0 | No | Changes stop-loss once profit has been reached.
2018-07-16 19:23:45 +00:00
| `trailing_stoploss_positve_offset` | 0 | No | Offset on when to apply `trailing_stoploss_positive` . Percentage value which should be positive.
2018-06-14 10:49:43 +00:00
| `unfilledtimeout.buy` | 10 | Yes | How long (in minutes) the bot will wait for an unfilled buy order to complete, after which the order will be cancelled.
| `unfilledtimeout.sell` | 10 | Yes | How long (in minutes) the bot will wait for an unfilled sell order to complete, after which the order will be cancelled.
2018-01-02 02:17:10 +00:00
| `bid_strategy.ask_last_balance` | 0.0 | Yes | Set the bidding price. More information below.
2018-05-30 05:21:29 +00:00
| `exchange.name` | bittrex | Yes | Name of the exchange class to use. [List below ](#user-content-what-values-for-exchangename ).
2018-01-02 02:17:10 +00:00
| `exchange.key` | key | No | API key to use for the exchange. Only required when you are in production mode.
| `exchange.secret` | secret | No | API secret to use for the exchange. Only required when you are in production mode.
| `exchange.pair_whitelist` | [] | No | List of currency to use by the bot. Can be overrided with `--dynamic-whitelist` param.
| `exchange.pair_blacklist` | [] | No | List of currency the bot must avoid. Useful when using `--dynamic-whitelist` param.
| `experimental.use_sell_signal` | false | No | Use your sell strategy in addition of the `minimal_roi` .
2018-01-17 10:31:26 +00:00
| `experimental.sell_profit_only` | false | No | waits until you have made a positive profit before taking a sell decision.
2018-06-22 18:10:05 +00:00
| `experimental.ignore_roi_if_buy_signal` | false | No | Does not sell if the buy-signal is still active. Takes preference over `minimal_roi` and `use_sell_signal`
2018-01-02 02:17:10 +00:00
| `telegram.enabled` | true | Yes | Enable or not the usage of Telegram.
2018-01-25 17:26:01 +00:00
| `telegram.token` | token | No | Your Telegram bot token. Only required if `telegram.enabled` is `true` .
| `telegram.chat_id` | chat_id | No | Your personal Telegram account id. Only required if `telegram.enabled` is `true` .
2018-07-07 12:10:15 +00:00
| `webhook.enabled` | false | No | Enable useage of Webhook notifications
| `webhook.url` | false | No | URL for the webhook. Only required if `webhook.enabled` is `true` . See the [webhook documentation ](webhook-config.md ) for more details.
| `webhook.webhookbuy` | false | No | Payload to send on buy. Only required if `webhook.enabled` is `true` . See the [webhook documentationV ](webhook-config.md ) for more details.
| `webhook.webhooksell` | false | No | Payload to send on sell. Only required if `webhook.enabled` is `true` . See the [webhook documentationV ](webhook-config.md ) for more details.
| `webhook.webhookstatus` | false | No | Payload to send on status calls. Only required if `webhook.enabled` is `true` . See the [webhook documentationV ](webhook-config.md ) for more details.
2018-06-07 03:36:39 +00:00
| `db_url` | `sqlite:///tradesv3.sqlite` | No | Declares database URL to use. NOTE: This defaults to `sqlite://` if `dry_run` is `True` .
2018-01-02 02:17:10 +00:00
| `initial_state` | running | No | Defines the initial application state. More information below.
2018-03-27 16:38:43 +00:00
| `strategy` | DefaultStrategy | No | Defines Strategy class to use.
| `strategy_path` | null | No | Adds an additional strategy lookup path (must be a folder).
2018-01-02 02:17:10 +00:00
| `internals.process_throttle_secs` | 5 | Yes | Set the process throttle. Value in second.
2018-06-26 21:14:12 +00:00
The definition of each config parameters is in [misc.py ](https://github.com/freqtrade/freqtrade/blob/develop/freqtrade/misc.py#L205 ).
2018-01-02 02:17:10 +00:00
2018-06-03 22:48:26 +00:00
### Understand stake_amount
2018-06-26 21:14:12 +00:00
2018-06-03 22:48:26 +00:00
`stake_amount` is an amount of crypto-currency your bot will use for each trade.
The minimal value is 0.0005. If there is not enough crypto-currency in
the account an exception is generated.
To allow the bot to trade all the avaliable `stake_currency` in your account set `stake_amount` = `unlimited` .
In this case a trade amount is calclulated as `currency_balanse / (max_open_trades - current_open_trades)` .
2018-01-02 02:17:10 +00:00
### Understand minimal_roi
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
`minimal_roi` is a JSON object where the key is a duration
in minutes and the value is the minimum ROI in percent.
See the example below:
2018-06-26 21:14:12 +00:00
2018-06-27 04:54:29 +00:00
```
2018-01-02 02:17:10 +00:00
"minimal_roi": {
"40": 0.0, # Sell after 40 minutes if the profit is not negative
"30": 0.01, # Sell after 30 minutes if there is at least 1% profit
"20": 0.02, # Sell after 20 minutes if there is at least 2% profit
"0": 0.04 # Sell immediately if there is at least 4% profit
},
```
2018-01-18 07:06:37 +00:00
Most of the strategy files already include the optimal `minimal_roi`
value. This parameter is optional. If you use it, it will take over the
`minimal_roi` value from the strategy file.
2018-01-02 02:17:10 +00:00
### Understand stoploss
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
`stoploss` is loss in percentage that should trigger a sale.
For example value `-0.10` will cause immediate sell if the
profit dips below -10% for a given trade. This parameter is optional.
2018-01-18 07:06:37 +00:00
Most of the strategy files already include the optimal `stoploss`
value. This parameter is optional. If you use it, it will take over the
`stoploss` value from the strategy file.
2018-06-26 21:14:12 +00:00
### Understand trailing stoploss
Go to the [trailing stoploss Documentation ](stoploss.md ) for details on trailing stoploss.
2018-01-02 02:17:10 +00:00
### Understand initial_state
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
`initial_state` is an optional field that defines the initial application state.
Possible values are `running` or `stopped` . (default=`running`)
If the value is `stopped` the bot has to be started with `/start` first.
2018-06-05 11:49:59 +00:00
### Understand process_throttle_secs
2018-06-26 21:14:12 +00:00
2018-06-05 11:51:30 +00:00
`process_throttle_secs` is an optional field that defines in seconds how long the bot should wait
before asking the strategy if we should buy or a sell an asset. After each wait period, the strategy is asked again for
every opened trade wether or not we should sell, and for all the remaining pairs (either the dynamic list of pairs or
2018-06-05 11:49:59 +00:00
the static list of pairs) if we should buy.
2018-01-02 02:17:10 +00:00
### Understand ask_last_balance
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
`ask_last_balance` sets the bidding price. Value `0.0` will use `ask` price, `1.0` will
use the `last` price and values between those interpolate between ask and last
price. Using `ask` price will guarantee quick success in bid, but bot will also
end up paying more then would probably have been necessary.
2018-05-30 05:21:29 +00:00
### What values for exchange.name?
2018-06-26 21:14:12 +00:00
2018-05-30 05:21:29 +00:00
Freqtrade is based on [CCXT library ](https://github.com/ccxt/ccxt ) that supports 115 cryptocurrency
exchange markets and trading APIs. The complete up-to-date list can be found in the
[CCXT repo homepage ](https://github.com/ccxt/ccxt/tree/master/python ). However, the bot was tested
with only Bittrex and Binance.
The bot was tested with the following exchanges:
2018-06-26 21:14:12 +00:00
2018-05-30 05:21:29 +00:00
- [Bittrex ](https://bittrex.com/ ): "bittrex"
- [Binance ](https://www.binance.com/ ): "binance"
Feel free to test other exchanges and submit your PR to improve the bot.
2018-01-02 02:17:10 +00:00
### What values for fiat_display_currency?
2018-06-26 21:14:12 +00:00
2018-06-04 19:19:25 +00:00
`fiat_display_currency` set the base currency to use for the conversion from coin to fiat in Telegram.
2018-06-04 19:17:10 +00:00
The valid values are: "AUD", "BRL", "CAD", "CHF", "CLP", "CNY", "CZK", "DKK", "EUR", "GBP", "HKD", "HUF", "IDR", "ILS", "INR", "JPY", "KRW", "MXN", "MYR", "NOK", "NZD", "PHP", "PKR", "PLN", "RUB", "SEK", "SGD", "THB", "TRY", "TWD", "ZAR", "USD".
In addition to central bank currencies, a range of cryto currencies are supported.
The valid values are: "BTC", "ETH", "XRP", "LTC", "BCH", "USDT".
2018-01-02 02:17:10 +00:00
## Switch to dry-run mode
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
We recommend starting the bot in dry-run mode to see how your bot will
behave and how is the performance of your strategy. In Dry-run mode the
bot does not engage your money. It only runs a live simulation without
creating trades.
### To switch your bot in Dry-run mode:
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
1. Edit your `config.json` file
2018-06-07 03:36:39 +00:00
2. Switch dry-run to true and specify db_url for a persistent db
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
```json
"dry_run": true,
2018-06-07 03:36:39 +00:00
"db_url": "sqlite///tradesv3.dryrun.sqlite",
2018-01-02 02:17:10 +00:00
```
2018-05-30 05:21:29 +00:00
3. Remove your Exchange API key (change them by fake api credentials)
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
```json
"exchange": {
"name": "bittrex",
"key": "key",
"secret": "secret",
...
2018-06-26 21:14:12 +00:00
}
2018-01-02 02:17:10 +00:00
```
Once you will be happy with your bot performance, you can switch it to
production mode.
## Switch to production mode
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
In production mode, the bot will engage your money. Be careful a wrong
strategy can lose all your money. Be aware of what you are doing when
you run it in production mode.
### To switch your bot in production mode:
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
1. Edit your `config.json` file
2018-06-07 03:47:14 +00:00
2. Switch dry-run to false and don't forget to adapt your database URL if set
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
```json
"dry_run": false,
```
2018-05-30 05:21:29 +00:00
3. Insert your Exchange API key (change them by fake api keys)
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
```json
"exchange": {
"name": "bittrex",
"key": "af8ddd35195e9dc500b9a6f799f6f5c93d89193b",
"secret": "08a9dc6db3d7b53e1acebd9275677f4b0a04f1a5",
...
2018-06-03 21:07:00 +00:00
}
2018-06-26 21:14:12 +00:00
2018-01-02 02:17:10 +00:00
```
2018-06-26 21:14:12 +00:00
If you have not your Bittrex API key yet, [see our tutorial ](https://github.com/freqtrade/freqtrade/blob/develop/docs/pre-requisite.md ).
2018-01-02 02:17:10 +00:00
2018-07-29 04:31:20 +00:00
### Embedding Strategies
FreqTrade provides you with with an easy way to embed the strategy into your configuration file.
This is done by utilizing BASE64 encoding and providing this string at the strategy configuration field,
in your chosen config file.
##### Encoding a string as BASE64
This is a quick example, how to generate the BASE64 string in python
```python
from base64 import urlsafe_b64encode
with open(file, 'r') as f:
content = f.read()
content = urlsafe_b64encode(content.encode('utf-8'))
```
The variable 'content', will contain the strategy file in a BASE64 encoded form. Which can now be set in your configurations file as following
```json
"strategy": "NameOfStrategy:BASE64String"
```
Please ensure that 'NameOfStrategy' is identical to the strategy name!
2018-01-02 02:17:10 +00:00
## Next step
2018-06-26 21:14:12 +00:00
Now you have configured your config.json, the next step is to [start your bot ](https://github.com/freqtrade/freqtrade/blob/develop/docs/bot-usage.md ).