2021-04-09 11:17:38 +03:00
|
|
|
import base64
|
|
|
|
import binascii
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from izihawa_utils.exceptions import BaseError
|
|
|
|
from nexus.translations import t
|
|
|
|
from telethon import Button
|
|
|
|
|
|
|
|
|
|
|
|
class TooLongQueryError(BaseError):
|
|
|
|
code = 'too_long_query_error'
|
|
|
|
level = logging.WARNING
|
|
|
|
|
|
|
|
|
|
|
|
class DecodeDeepQueryError(BaseError):
|
|
|
|
code = 'decode_deep_query_error'
|
|
|
|
level = logging.WARNING
|
|
|
|
|
|
|
|
|
|
|
|
def close_button(session_id: str = None):
|
|
|
|
if session_id:
|
|
|
|
return Button.inline(
|
|
|
|
text='✖️',
|
|
|
|
data=f'/close_{session_id}',
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
return Button.inline(
|
|
|
|
text='✖️',
|
|
|
|
data='/close',
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2021-04-13 10:39:00 +03:00
|
|
|
def vote_button(language: str, session_id: str, schema: str, document_id: int, case: str):
|
2021-04-09 11:17:38 +03:00
|
|
|
label = f"REPORT_{case.upper()}_FILE"
|
|
|
|
case = {'broken': 'b', 'ok': 'o'}[case]
|
2021-04-13 10:39:00 +03:00
|
|
|
schema = {'scimag': 'a', 'scitech': 'b'}[schema]
|
2021-04-09 11:17:38 +03:00
|
|
|
return Button.inline(
|
|
|
|
text=t(label, language=language),
|
2021-04-13 10:39:00 +03:00
|
|
|
data=f'/vote{schema}_{session_id}_{document_id}_{case}',
|
2021-04-09 11:17:38 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def encode_query_to_deep_link(query, bot_name):
|
|
|
|
encoded_query = encode_deep_query(query)
|
|
|
|
if len(encoded_query) <= 64:
|
|
|
|
return f'https://t.me/{bot_name}?start={encoded_query}'
|
|
|
|
raise TooLongQueryError()
|
|
|
|
|
|
|
|
|
|
|
|
def encode_deep_query(query):
|
|
|
|
return base64.b64encode(query.encode(), altchars=b'-_').decode()
|
|
|
|
|
|
|
|
|
|
|
|
def decode_deep_query(query):
|
|
|
|
try:
|
|
|
|
# Padding fix
|
|
|
|
return base64.b64decode(query + "=" * ((4 - len(query) % 4) % 4), altchars=b'-_').decode()
|
|
|
|
except (binascii.Error, ValueError, UnicodeDecodeError) as e:
|
|
|
|
raise DecodeDeepQueryError(nested_error=e)
|
|
|
|
|
|
|
|
|
|
|
|
async def remove_button(event, mark, and_empty_too=False):
|
|
|
|
original_message = await event.get_message()
|
|
|
|
if original_message:
|
|
|
|
original_buttons = original_message.buttons
|
|
|
|
buttons = []
|
|
|
|
for original_line in original_buttons:
|
|
|
|
line = []
|
|
|
|
for original_button in original_line:
|
|
|
|
if mark in original_button.text or (and_empty_too and not original_button.text.strip()):
|
|
|
|
continue
|
|
|
|
line.append(original_button)
|
|
|
|
if line:
|
|
|
|
buttons.append(line)
|
|
|
|
await event.edit(original_message.text, buttons=buttons)
|