Simplify update logic by moving it to send_msg

This commit is contained in:
Matthias 2021-06-13 20:34:08 +02:00
parent 03eff69829
commit a95f760ff7

View File

@ -10,7 +10,7 @@ from datetime import date, datetime, timedelta
from html import escape from html import escape
from itertools import chain from itertools import chain
from math import isnan from math import isnan
from typing import Any, Callable, Dict, List, Union from typing import Any, Callable, Dict, List, Optional, Union
import arrow import arrow
from tabulate import tabulate from tabulate import tabulate
@ -421,14 +421,9 @@ class Telegram(RPCHandler):
# insert separators line between Total # insert separators line between Total
lines = message.split("\n") lines = message.split("\n")
message = "\n".join(lines[:-1] + [lines[1]] + [lines[-1]]) message = "\n".join(lines[:-1] + [lines[1]] + [lines[-1]])
if(messages_count == 1 and update.callback_query): self._send_msg(f"<pre>{message}</pre>", reload_able=True,
self._update_msg(query=update.callback_query, callback_path="update_status_table", parse_mode=ParseMode.HTML,
msg=f"<pre>{message}</pre>", query=update.callback_query)
parse_mode=ParseMode.HTML,
callback_path="update_status_table", reload_able=True)
else:
self._send_msg(f"<pre>{message}</pre>", reload_able=True,
callback_path="update_status_table", parse_mode=ParseMode.HTML)
except RPCException as e: except RPCException as e:
self._send_msg(str(e)) self._send_msg(str(e))
@ -466,13 +461,8 @@ class Telegram(RPCHandler):
], ],
tablefmt='simple') tablefmt='simple')
message = f'<b>Daily Profit over the last {timescale} days</b>:\n<pre>{stats_tab}</pre>' message = f'<b>Daily Profit over the last {timescale} days</b>:\n<pre>{stats_tab}</pre>'
if(update.callback_query): self._send_msg(message, parse_mode=ParseMode.HTML, callback_path="update_daily",
self._update_msg(query=update.callback_query, reload_able=True, query=update.callback_query)
msg=message, parse_mode=ParseMode.HTML,
callback_path="update_daily", reload_able=True)
else:
self._send_msg(msg=message, parse_mode=ParseMode.HTML, callback_path="update_daily",
reload_able=True)
except RPCException as e: except RPCException as e:
self._send_msg(str(e)) self._send_msg(str(e))
@ -544,11 +534,8 @@ class Telegram(RPCHandler):
if stats['closed_trade_count'] > 0: if stats['closed_trade_count'] > 0:
markdown_msg += (f"\n*Avg. Duration:* `{avg_duration}`\n" markdown_msg += (f"\n*Avg. Duration:* `{avg_duration}`\n"
f"*Best Performing:* `{best_pair}: {best_rate:.2f}%`") f"*Best Performing:* `{best_pair}: {best_rate:.2f}%`")
if(update.callback_query): self._send_msg(markdown_msg, callback_path="update_profit", reload_able=True,
self._update_msg(query=update.callback_query, query=update.callback_query)
msg=markdown_msg, callback_path="update_profit", reload_able=True)
else:
self._send_msg(msg=markdown_msg, callback_path="update_profit", reload_able=True)
@authorized_only @authorized_only
def _stats(self, update: Update, context: CallbackContext) -> None: def _stats(self, update: Update, context: CallbackContext) -> None:
@ -635,11 +622,8 @@ class Telegram(RPCHandler):
f"\t`{result['stake']}: {result['total']: .8f}`\n" f"\t`{result['stake']}: {result['total']: .8f}`\n"
f"\t`{result['symbol']}: " f"\t`{result['symbol']}: "
f"{round_coin_value(result['value'], result['symbol'], False)}`\n") f"{round_coin_value(result['value'], result['symbol'], False)}`\n")
if(update.callback_query): self._send_msg(output, callback_path="update_balance", reload_able=True,
self._update_msg(query=update.callback_query, query=update.callback_query)
msg=output, callback_path="update_balance", reload_able=True)
else:
self._send_msg(msg=output, callback_path="update_balance", reload_able=True)
except RPCException as e: except RPCException as e:
self._send_msg(str(e)) self._send_msg(str(e))
@ -820,7 +804,6 @@ class Telegram(RPCHandler):
try: try:
trades = self._rpc._rpc_performance() trades = self._rpc._rpc_performance()
output = "<b>Performance:</b>\n" output = "<b>Performance:</b>\n"
sent_messages = 0
for i, trade in enumerate(trades): for i, trade in enumerate(trades):
stat_line = ( stat_line = (
f"{i+1}.\t <code>{trade['pair']}\t" f"{i+1}.\t <code>{trade['pair']}\t"
@ -831,17 +814,12 @@ class Telegram(RPCHandler):
if len(output + stat_line) >= MAX_TELEGRAM_MESSAGE_LENGTH: if len(output + stat_line) >= MAX_TELEGRAM_MESSAGE_LENGTH:
self._send_msg(output, parse_mode=ParseMode.HTML) self._send_msg(output, parse_mode=ParseMode.HTML)
output = stat_line output = stat_line
sent_messages += 1
else: else:
output += stat_line output += stat_line
if(sent_messages == 0 and update.callback_query): self._send_msg(output, parse_mode=ParseMode.HTML,
self._update_msg(query=update.callback_query, callback_path="update_performance", reload_able=True,
msg=output, parse_mode=ParseMode.HTML, query=update.callback_query)
callback_path="update_performance", reload_able=True)
else:
self._send_msg(msg=output, parse_mode=ParseMode.HTML,
callback_path="update_performance", reload_able=True)
except RPCException as e: except RPCException as e:
self._send_msg(str(e)) self._send_msg(str(e))
@ -861,13 +839,9 @@ class Telegram(RPCHandler):
tablefmt='simple') tablefmt='simple')
message = "<pre>{}</pre>".format(message) message = "<pre>{}</pre>".format(message)
logger.debug(message) logger.debug(message)
if(update.callback_query): self._send_msg(message, parse_mode=ParseMode.HTML,
self._update_msg(query=update.callback_query, callback_path="update_count", reload_able=True,
msg=message, parse_mode=ParseMode.HTML, query=update.callback_query)
callback_path="update_count", reload_able=True)
else:
self._send_msg(msg=message, parse_mode=ParseMode.HTML,
callback_path="update_count", reload_able=True)
except RPCException as e: except RPCException as e:
self._send_msg(str(e)) self._send_msg(str(e))
@ -1140,7 +1114,8 @@ class Telegram(RPCHandler):
disable_notification: bool = False, disable_notification: bool = False,
keyboard: List[List[Union[str, KeyboardButton, InlineKeyboardButton]]] = None, keyboard: List[List[Union[str, KeyboardButton, InlineKeyboardButton]]] = None,
callback_path: str = "", callback_path: str = "",
reload_able: bool = False) -> None: reload_able: bool = False,
query: Optional[CallbackQuery] = None) -> None:
""" """
Send given markdown message Send given markdown message
:param msg: message :param msg: message
@ -1148,6 +1123,10 @@ class Telegram(RPCHandler):
:param parse_mode: telegram parse mode :param parse_mode: telegram parse mode
:return: None :return: None
""" """
if query:
self._update_msg(query=query, msg=msg, parse_mode=parse_mode,
callback_path=callback_path, reload_able=reload_able)
return
if reload_able and self._config['telegram'].get('reload', True): if reload_able and self._config['telegram'].get('reload', True):
reply_markup = InlineKeyboardMarkup([ reply_markup = InlineKeyboardMarkup([
[InlineKeyboardButton("Refresh", callback_data=callback_path)]]) [InlineKeyboardButton("Refresh", callback_data=callback_path)]])