Simplify update logic by moving it to send_msg
This commit is contained in:
parent
03eff69829
commit
a95f760ff7
@ -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)]])
|
||||||
|
Loading…
Reference in New Issue
Block a user