diff --git a/config.json.example b/config.json.example
index d37a6b336..ae87164d6 100644
--- a/config.json.example
+++ b/config.json.example
@@ -76,6 +76,15 @@
"token": "your_telegram_token",
"chat_id": "your_telegram_chat_id"
},
+ "api_server": {
+ "enabled": false,
+ "listen_ip_address": "127.0.0.1",
+ "listen_port": 8080,
+ "verbosity": "info",
+ "jwt_secret_key": "somethingrandom",
+ "username": "",
+ "password": ""
+ },
"initial_state": "running",
"forcebuy_enable": false,
"internals": {
diff --git a/config_binance.json.example b/config_binance.json.example
index 5d7b6b656..74207d565 100644
--- a/config_binance.json.example
+++ b/config_binance.json.example
@@ -81,6 +81,15 @@
"token": "your_telegram_token",
"chat_id": "your_telegram_chat_id"
},
+ "api_server": {
+ "enabled": false,
+ "listen_ip_address": "127.0.0.1",
+ "listen_port": 8080,
+ "verbosity": "info",
+ "jwt_secret_key": "somethingrandom",
+ "username": "",
+ "password": ""
+ },
"initial_state": "running",
"forcebuy_enable": false,
"internals": {
diff --git a/config_full.json.example b/config_full.json.example
index 481742817..57ebb22e6 100644
--- a/config_full.json.example
+++ b/config_full.json.example
@@ -121,6 +121,7 @@
"enabled": false,
"listen_ip_address": "127.0.0.1",
"listen_port": 8080,
+ "verbosity": "info",
"jwt_secret_key": "somethingrandom",
"username": "freqtrader",
"password": "SuperSecurePassword"
diff --git a/config_kraken.json.example b/config_kraken.json.example
index 54fbf4a00..f1e522da5 100644
--- a/config_kraken.json.example
+++ b/config_kraken.json.example
@@ -87,6 +87,15 @@
"token": "your_telegram_token",
"chat_id": "your_telegram_chat_id"
},
+ "api_server": {
+ "enabled": false,
+ "listen_ip_address": "127.0.0.1",
+ "listen_port": 8080,
+ "verbosity": "info",
+ "jwt_secret_key": "somethingrandom",
+ "username": "",
+ "password": ""
+ },
"initial_state": "running",
"forcebuy_enable": false,
"internals": {
diff --git a/docs/configuration.md b/docs/configuration.md
index 254c581fd..da0f015e8 100644
--- a/docs/configuration.md
+++ b/docs/configuration.md
@@ -103,6 +103,7 @@ Mandatory parameters are marked as **Required**, which means that they are requi
| `api_server.enabled` | Enable usage of API Server. See the [API Server documentation](rest-api.md) for more details.
**Datatype:** Boolean
| `api_server.listen_ip_address` | Bind IP address. See the [API Server documentation](rest-api.md) for more details.
**Datatype:** IPv4
| `api_server.listen_port` | Bind Port. See the [API Server documentation](rest-api.md) for more details.
**Datatype:** Integer between 1024 and 65535
+| `api_server.verbosity` | Logging verbosity. `info` will print all RPC Calls, while "error" will only display errors.
**Datatype:** Enum, either `info` or `error`. Defaults to `info`.
| `api_server.username` | Username for API server. See the [API Server documentation](rest-api.md) for more details.
**Keep it in secret, do not disclose publicly.**
**Datatype:** String
| `api_server.password` | Password for API server. See the [API Server documentation](rest-api.md) for more details.
**Keep it in secret, do not disclose publicly.**
**Datatype:** String
| `db_url` | Declares database URL to use. NOTE: This defaults to `sqlite:///tradesv3.dryrun.sqlite` if `dry_run` is `true`, and to `sqlite:///tradesv3.sqlite` for production instances.
**Datatype:** String, SQLAlchemy connect string
diff --git a/docs/rest-api.md b/docs/rest-api.md
index 7f1a95b12..ed5f355b4 100644
--- a/docs/rest-api.md
+++ b/docs/rest-api.md
@@ -11,6 +11,7 @@ Sample configuration:
"enabled": true,
"listen_ip_address": "127.0.0.1",
"listen_port": 8080,
+ "verbosity": "info",
"jwt_secret_key": "somethingrandom",
"username": "Freqtrader",
"password": "SuperSecret1!"
diff --git a/freqtrade/constants.py b/freqtrade/constants.py
index 0e08db91f..09ee54208 100644
--- a/freqtrade/constants.py
+++ b/freqtrade/constants.py
@@ -221,6 +221,7 @@ CONF_SCHEMA = {
},
'username': {'type': 'string'},
'password': {'type': 'string'},
+ 'verbosity': {'type': 'string', 'enum': ['error', 'info']},
},
'required': ['enabled', 'listen_ip_address', 'listen_port', 'username', 'password']
},
diff --git a/freqtrade/loggers.py b/freqtrade/loggers.py
index 153ce8c80..aa08ee8a7 100644
--- a/freqtrade/loggers.py
+++ b/freqtrade/loggers.py
@@ -11,7 +11,7 @@ from freqtrade.exceptions import OperationalException
logger = logging.getLogger(__name__)
-def _set_loggers(verbosity: int = 0) -> None:
+def _set_loggers(verbosity: int = 0, api_verbosity: str = 'info') -> None:
"""
Set the logging level for third party libraries
:return: None
@@ -28,6 +28,10 @@ def _set_loggers(verbosity: int = 0) -> None:
)
logging.getLogger('telegram').setLevel(logging.INFO)
+ logging.getLogger('werkzeug').setLevel(
+ logging.ERROR if api_verbosity == 'error' else logging.INFO
+ )
+
def setup_logging(config: Dict[str, Any]) -> None:
"""
@@ -77,5 +81,5 @@ def setup_logging(config: Dict[str, Any]) -> None:
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
handlers=log_handlers
)
- _set_loggers(verbosity)
+ _set_loggers(verbosity, config.get('api_server', {}).get('verbosity', 'info'))
logger.info('Verbosity set to %s', verbosity)
diff --git a/freqtrade/rpc/api_server.py b/freqtrade/rpc/api_server.py
index 23b6a85b0..9d0899ccd 100644
--- a/freqtrade/rpc/api_server.py
+++ b/freqtrade/rpc/api_server.py
@@ -360,7 +360,6 @@ class ApiServer(RPC):
Returns a cumulative profit statistics
:return: stats
"""
- logger.info("LocalRPC - Profit Command Called")
stats = self._rpc_trade_statistics(self._config['stake_currency'],
self._config.get('fiat_display_currency')
@@ -377,8 +376,6 @@ class ApiServer(RPC):
Returns a cumulative performance statistics
:return: stats
"""
- logger.info("LocalRPC - performance Command Called")
-
stats = self._rpc_performance()
return self.rest_dump(stats)
diff --git a/freqtrade/templates/base_config.json.j2 b/freqtrade/templates/base_config.json.j2
index 6d3174347..5339595e8 100644
--- a/freqtrade/templates/base_config.json.j2
+++ b/freqtrade/templates/base_config.json.j2
@@ -53,6 +53,15 @@
"token": "{{ telegram_token }}",
"chat_id": "{{ telegram_chat_id }}"
},
+ "api_server": {
+ "enabled": false,
+ "listen_ip_address": "127.0.0.1",
+ "listen_port": 8080,
+ "verbosity": "info",
+ "jwt_secret_key": "somethingrandom",
+ "username": "",
+ "password": ""
+ },
"initial_state": "running",
"forcebuy_enable": false,
"internals": {
diff --git a/tests/test_configuration.py b/tests/test_configuration.py
index 2af89bea7..dcb5e2ed0 100644
--- a/tests/test_configuration.py
+++ b/tests/test_configuration.py
@@ -654,12 +654,14 @@ def test_set_loggers() -> None:
assert logging.getLogger('requests').level is logging.DEBUG
assert logging.getLogger('ccxt.base.exchange').level is logging.INFO
assert logging.getLogger('telegram').level is logging.INFO
+ assert logging.getLogger('werkzeug').level is logging.INFO
- _set_loggers(verbosity=3)
+ _set_loggers(verbosity=3, api_verbosity='error')
assert logging.getLogger('requests').level is logging.DEBUG
assert logging.getLogger('ccxt.base.exchange').level is logging.DEBUG
assert logging.getLogger('telegram').level is logging.INFO
+ assert logging.getLogger('werkzeug').level is logging.ERROR
@pytest.mark.skipif(sys.platform == "win32", reason="does not run on windows")