some fix with emoji function
This commit is contained in:
@@ -1,68 +1,68 @@
|
||||
import time
|
||||
from datetime import datetime
|
||||
from pathlib import Path
|
||||
|
||||
from aiogram import Router, F
|
||||
from aiogram.types import CallbackQuery
|
||||
|
||||
from helper_bot.utils.base_dependency_factory import BaseDependencyFactory
|
||||
|
||||
callback_router = Router()
|
||||
|
||||
bdf = BaseDependencyFactory()
|
||||
|
||||
GROUP_FOR_LOGS = bdf.settings['Telegram']['group_for_logs']
|
||||
GROUP_FOR_POST = bdf.settings['Telegram']['group_for_posts']
|
||||
IMPORTANT_LOGS = bdf.settings['Telegram']['important_logs']
|
||||
PREVIEW_LINK = bdf.settings['Telegram']['preview_link']
|
||||
LOGS = bdf.settings['Settings']['logs']
|
||||
TEST = bdf.settings['Settings']['test']
|
||||
|
||||
BotDB = bdf.get_db()
|
||||
|
||||
|
||||
@callback_router.callback_query(
|
||||
F.data == "save"
|
||||
)
|
||||
async def save_voice_message(call: CallbackQuery):
|
||||
file_name = ''
|
||||
file_id = 1
|
||||
user_id = BotDB.get_user_id_by_message_id_for_voice_bot(call.message.message_id)
|
||||
# Проверяем что запись о файле есть в базе данных
|
||||
is_having_audio_from_user = BotDB.get_last_user_audio_record(user_id=user_id)
|
||||
if is_having_audio_from_user is False:
|
||||
# Если нет, то генерируем имя файла
|
||||
file_name = f'message_from_{user_id}_number_{file_id}'
|
||||
else:
|
||||
# Иначе берем последнюю запись из БД, добавляем к ней 1, и создаем новую запись
|
||||
file_name = BotDB.get_path_for_audio_record(user_id=user_id)
|
||||
file_id = BotDB.get_id_for_audio_record(user_id) + 1
|
||||
path = Path(f'voice_users/{file_name}.ogg')
|
||||
if path.exists():
|
||||
file_name = f'message_from_{user_id}_number_{file_id}'
|
||||
else:
|
||||
pass
|
||||
# Собираем инфо о сообщении
|
||||
time_UTC = int(time.time())
|
||||
date_added = datetime.fromtimestamp(time_UTC)
|
||||
|
||||
# Сохраняем в базку
|
||||
BotDB.add_audio_record(file_name, user_id, date_added, 0, file_id)
|
||||
|
||||
file_info = await call.message.bot.get_file(file_id=call.message.voice.file_id)
|
||||
downloaded_file = await call.message.bot.download_file(file_path=file_info.file_path)
|
||||
with open(f'voice_users/{file_name}.ogg', 'wb') as new_file:
|
||||
new_file.write(downloaded_file.read())
|
||||
|
||||
await call.bot.delete_message(chat_id=GROUP_FOR_POST, message_id=call.message.message_id)
|
||||
await call.answer(text='Сохранено!', cache_time=3)
|
||||
|
||||
|
||||
@callback_router.callback_query(
|
||||
F.data == "delete"
|
||||
)
|
||||
async def delete_voice_message(call: CallbackQuery):
|
||||
# Получаем из базы автора + отправляем сообщение + удаляем сообщение из предложки
|
||||
|
||||
await call.bot.delete_message(chat_id=GROUP_FOR_POST, message_id=call.message.message_id)
|
||||
await call.answer(text='Удалено!', cache_time=3)
|
||||
import time
|
||||
from datetime import datetime
|
||||
from pathlib import Path
|
||||
|
||||
from aiogram import Router, F
|
||||
from aiogram.types import CallbackQuery
|
||||
|
||||
from helper_bot.utils.base_dependency_factory import BaseDependencyFactory
|
||||
|
||||
callback_router = Router()
|
||||
|
||||
bdf = BaseDependencyFactory()
|
||||
|
||||
GROUP_FOR_LOGS = bdf.settings['Telegram']['group_for_logs']
|
||||
GROUP_FOR_POST = bdf.settings['Telegram']['group_for_posts']
|
||||
IMPORTANT_LOGS = bdf.settings['Telegram']['important_logs']
|
||||
PREVIEW_LINK = bdf.settings['Telegram']['preview_link']
|
||||
LOGS = bdf.settings['Settings']['logs']
|
||||
TEST = bdf.settings['Settings']['test']
|
||||
|
||||
BotDB = bdf.get_db()
|
||||
|
||||
|
||||
@callback_router.callback_query(
|
||||
F.data == "save"
|
||||
)
|
||||
async def save_voice_message(call: CallbackQuery):
|
||||
file_name = ''
|
||||
file_id = 1
|
||||
user_id = BotDB.get_user_id_by_message_id_for_voice_bot(call.message.message_id)
|
||||
# Проверяем что запись о файле есть в базе данных
|
||||
is_having_audio_from_user = BotDB.get_last_user_audio_record(user_id=user_id)
|
||||
if is_having_audio_from_user is False:
|
||||
# Если нет, то генерируем имя файла
|
||||
file_name = f'message_from_{user_id}_number_{file_id}'
|
||||
else:
|
||||
# Иначе берем последнюю запись из БД, добавляем к ней 1, и создаем новую запись
|
||||
file_name = BotDB.get_path_for_audio_record(user_id=user_id)
|
||||
file_id = BotDB.get_id_for_audio_record(user_id) + 1
|
||||
path = Path(f'voice_users/{file_name}.ogg')
|
||||
if path.exists():
|
||||
file_name = f'message_from_{user_id}_number_{file_id}'
|
||||
else:
|
||||
pass
|
||||
# Собираем инфо о сообщении
|
||||
time_UTC = int(time.time())
|
||||
date_added = datetime.fromtimestamp(time_UTC)
|
||||
|
||||
# Сохраняем в базку
|
||||
BotDB.add_audio_record(file_name, user_id, date_added, 0, file_id)
|
||||
|
||||
file_info = await call.message.bot.get_file(file_id=call.message.voice.file_id)
|
||||
downloaded_file = await call.message.bot.download_file(file_path=file_info.file_path)
|
||||
with open(f'voice_users/{file_name}.ogg', 'wb') as new_file:
|
||||
new_file.write(downloaded_file.read())
|
||||
|
||||
await call.bot.delete_message(chat_id=GROUP_FOR_POST, message_id=call.message.message_id)
|
||||
await call.answer(text='Сохранено!', cache_time=3)
|
||||
|
||||
|
||||
@callback_router.callback_query(
|
||||
F.data == "delete"
|
||||
)
|
||||
async def delete_voice_message(call: CallbackQuery):
|
||||
# Получаем из базы автора + отправляем сообщение + удаляем сообщение из предложки
|
||||
|
||||
await call.bot.delete_message(chat_id=GROUP_FOR_POST, message_id=call.message.message_id)
|
||||
await call.answer(text='Удалено!', cache_time=3)
|
||||
|
||||
@@ -37,13 +37,24 @@ voice_router.message.middleware(BlacklistMiddleware())
|
||||
async def restart_function(message: types.Message, state: FSMContext):
|
||||
await message.forward(chat_id=GROUP_FOR_LOGS)
|
||||
await update_user_info('voice', message)
|
||||
check_user_emoji(message.from_user.id)
|
||||
check_user_emoji(message)
|
||||
markup = get_main_keyboard()
|
||||
await message.answer(text='Я перезапущен!',
|
||||
reply_markup=markup)
|
||||
await state.set_state('START')
|
||||
|
||||
|
||||
@voice_router.message(
|
||||
ChatTypeFilter(chat_type=["private"]),
|
||||
Command("emoji")
|
||||
)
|
||||
async def handle_emoji_message(message: types.Message, state: FSMContext):
|
||||
user_emoji = check_user_emoji(message)
|
||||
await state.set_state("START")
|
||||
if user_emoji is not None:
|
||||
await message.answer(f'Твоя эмодзя - {user_emoji}', parse_mode='HTML')
|
||||
|
||||
|
||||
@voice_router.message(
|
||||
ChatTypeFilter(chat_type=["private"]),
|
||||
Command("help")
|
||||
@@ -51,7 +62,6 @@ async def restart_function(message: types.Message, state: FSMContext):
|
||||
async def help_function(message: types.Message, state: FSMContext):
|
||||
await message.forward(chat_id=GROUP_FOR_LOGS)
|
||||
await update_user_info('voice', message)
|
||||
check_user_emoji(message.from_user.id)
|
||||
await message.answer(
|
||||
text='Скорее всего ответы на твои вопросы есть здесь, ознакомься: https://telegra.ph/Instrukciya-k-botu-Golosa-Bijsk-10-11-2'
|
||||
'\nЕсли это не поможет, пиши в личку: @Kerrad1', disable_web_page_preview=not PREVIEW_LINK)
|
||||
@@ -66,7 +76,7 @@ async def start(message: types.Message, state: FSMContext):
|
||||
await state.set_state("START")
|
||||
await message.forward(chat_id=GROUP_FOR_LOGS)
|
||||
await update_user_info('voice', message)
|
||||
check_user_emoji(message.from_user.id)
|
||||
user_emoji = check_user_emoji(message)
|
||||
try:
|
||||
name_stick_hello = list(Path('Stick').rglob('Hello_*'))
|
||||
random_stick_hello = random.choice(name_stick_hello)
|
||||
@@ -107,11 +117,17 @@ async def start(message: types.Message, state: FSMContext):
|
||||
parse_mode='html', reply_markup=markup,
|
||||
disable_web_page_preview=not PREVIEW_LINK)
|
||||
time.sleep(0.8)
|
||||
await message.answer(text=f"Любые войсы будут помечены эмоджи. <b>Твой эмоджи - </b>{user_emoji}"
|
||||
f"Таким эмоджи будут помечены твои сообщения для других "
|
||||
f"Но другие люди не узнают кто за каким эмоджи скрывается:)",
|
||||
parse_mode='html', reply_markup=markup,
|
||||
disable_web_page_preview=not PREVIEW_LINK)
|
||||
time.sleep(0.8)
|
||||
await message.answer(text="Так же можешь ознакомиться с инструкцией к боту по команде /help",
|
||||
parse_mode='html', reply_markup=markup,
|
||||
disable_web_page_preview=not PREVIEW_LINK)
|
||||
time.sleep(0.8)
|
||||
await message.answer(text="<b>ну всё, достаточно инструкций. записывайся! Микрофон твой - </b> 🎤",
|
||||
await message.answer(text="<b>Ну всё, достаточно инструкций. записывайся! Микрофон твой - </b> 🎤",
|
||||
parse_mode='html', reply_markup=markup,
|
||||
disable_web_page_preview=not PREVIEW_LINK)
|
||||
|
||||
@@ -124,7 +140,6 @@ async def refresh_listen_function(message: types.Message, state: FSMContext):
|
||||
await message.forward(chat_id=GROUP_FOR_LOGS)
|
||||
await update_user_info('voice', message)
|
||||
markup = get_main_keyboard()
|
||||
check_user_emoji(message.from_user.id)
|
||||
BotDB.delete_listen_count_for_user(message.from_user.id)
|
||||
await message.answer(
|
||||
text='Прослушивания очищены. Можешь начать слушать заново🤗', disable_web_page_preview=not PREVIEW_LINK,
|
||||
@@ -195,20 +210,27 @@ async def standup_listen_audio(message: types.Message):
|
||||
except Exception as e:
|
||||
logger.error(f'Не удалось получить последнюю дату {e}')
|
||||
else:
|
||||
# Получаем эмоджи пользователя
|
||||
# Получаем ссылку на аудио сообщение пользователя
|
||||
number_element = random.randint(0, len(list_audio) - 1)
|
||||
audio_for_user = check_audio[number_element]
|
||||
|
||||
# Получаем автора записи + эмодзи по нему
|
||||
user_id = BotDB.get_user_id_by_file_name(audio_for_user)
|
||||
date_added = BotDB.get_date_by_file_name(audio_for_user)
|
||||
# TODO: Мейби не напрямую ходить?
|
||||
# user_emoji = BotDB.check_emoji_for_user(user_id)
|
||||
user_emoji = BotDB.check_emoji_for_user(user_id)
|
||||
|
||||
path = Path(f'voice_users/{audio_for_user}.ogg')
|
||||
# voice = open(path, 'rb')
|
||||
voice = FSInputFile(path)
|
||||
|
||||
# Маркируем сообщение как прослушанное
|
||||
BotDB.mark_listened_audio(audio_for_user, user_id=message.from_user.id)
|
||||
|
||||
# Формируем подпись
|
||||
if user_emoji:
|
||||
await message.bot.send_voice(chat_id=message.chat.id, voice=voice, caption=user_emoji, reply_markup=markup)
|
||||
caption = f'{user_emoji}\nДата записи: {date_added}'
|
||||
else:
|
||||
await message.bot.send_voice(chat_id=message.chat.id, voice=voice, reply_markup=markup)
|
||||
caption = f'Дата записи: {date_added}'
|
||||
await message.bot.send_voice(chat_id=message.chat.id, voice=voice, caption=caption, reply_markup=markup)
|
||||
await message.answer(text=f'Осталось непрослушанных: <b>{len(check_audio) - 1}</b>', reply_markup=markup)
|
||||
|
||||
Reference in New Issue
Block a user