|
|
|
# -*- coding: utf8 -*-
|
|
|
|
# Общественное достояние, 2023, Алексей Безбородов (Alexei Bezborodov) <AlexeiBv+mirocod_platform_bot@narod.ru>
|
|
|
|
|
|
|
|
# Сообщения пользователю
|
|
|
|
|
|
|
|
from bot_sys import bot_bd, keyboard, user_access, bd_table, bot_subscribes, bot_messages, interfaces
|
|
|
|
from bot_modules import mod_table_operate, mod_simple_message, users
|
|
|
|
|
|
|
|
# ---------------------------------------------------------
|
|
|
|
# БД
|
|
|
|
module_name = 'user_messge'
|
|
|
|
|
|
|
|
table_name = module_name
|
|
|
|
key_name = 'userMessageID'
|
|
|
|
desc_field = 'messageText'
|
|
|
|
access_field = 'catAccess'
|
|
|
|
create_datetime_field = 'catCreateDateTime'
|
|
|
|
parent_id_field = users.key_name
|
|
|
|
|
|
|
|
table = bd_table.Table(table_name, [
|
|
|
|
bd_table.TableField(key_name, bd_table.TableFieldDestiny.KEY, bd_table.TableFieldType.INT),
|
|
|
|
bd_table.TableField(desc_field, bd_table.TableFieldDestiny.DESC, bd_table.TableFieldType.STR),
|
|
|
|
bd_table.TableField(access_field, bd_table.TableFieldDestiny.ACCESS, bd_table.TableFieldType.STR),
|
|
|
|
bd_table.TableField(create_datetime_field, bd_table.TableFieldDestiny.CREATE_DATE, bd_table.TableFieldType.STR),
|
|
|
|
bd_table.TableField(parent_id_field, bd_table.TableFieldDestiny.PARENT_ID, bd_table.TableFieldType.INT),
|
|
|
|
])
|
|
|
|
|
|
|
|
init_access = f'{user_access.user_access_group_new}=-'
|
|
|
|
|
|
|
|
# ---------------------------------------------------------
|
|
|
|
# Сообщения и кнопки
|
|
|
|
|
|
|
|
button_names = {
|
|
|
|
mod_simple_message.ButtonNames.START: "📩 Сообщения для польователей",
|
|
|
|
mod_table_operate.ButtonNames.LIST: "📃 Список отправленных сообщений",
|
|
|
|
mod_table_operate.ButtonNames.ADD: "📨 Отправить сообщение",
|
|
|
|
mod_table_operate.ButtonNames.EDIT: "🛠 Редактировать сообщение",
|
|
|
|
mod_table_operate.EditButton(bd_table.TableFieldDestiny.DESC): "𝌴 Изменить описание у сообщения",
|
|
|
|
mod_table_operate.EditButton(bd_table.TableFieldDestiny.ACCESS): "✋ Изменить доступ к сообщению",
|
|
|
|
mod_table_operate.ButtonNames.DEL: "❌ Удалить отправленное сообщение",
|
|
|
|
}
|
|
|
|
|
|
|
|
messages = {
|
|
|
|
mod_simple_message.Messages.START: f'''
|
|
|
|
<b>{button_names[mod_simple_message.ButtonNames.START]}</b>
|
|
|
|
|
|
|
|
''',
|
|
|
|
mod_table_operate.Messages.SELECT: '''
|
|
|
|
Пожалуйста, выберите сообщение:
|
|
|
|
''',
|
|
|
|
mod_table_operate.Messages.ERROR_FIND: '''
|
|
|
|
❌ Ошибка, сообщение не найдено
|
|
|
|
''',
|
|
|
|
mod_table_operate.Messages.OPEN: f'''
|
|
|
|
<b>Категория: </b>
|
|
|
|
|
|
|
|
Пользоватеель: #{parent_id_field}
|
|
|
|
|
|
|
|
Текст сообщения: #{desc_field}
|
|
|
|
|
|
|
|
Время создания: #{create_datetime_field}
|
|
|
|
''',
|
|
|
|
mod_table_operate.CreateMessage(bd_table.TableFieldDestiny.DESC): '''
|
|
|
|
Отправка сообщения
|
|
|
|
|
|
|
|
Введите текст сообщения:
|
|
|
|
''',
|
|
|
|
mod_table_operate.Messages.SUCCESS_CREATE: f'''✅ Сообщение успешно отправлено пользователю!''',
|
|
|
|
mod_table_operate.Messages.START_EDIT: '''
|
|
|
|
Пожалуйста, выберите действие:
|
|
|
|
''',
|
|
|
|
mod_table_operate.Messages.SELECT_TO_EDIT: '''
|
|
|
|
Выберите проект, который вы хотите отредактировать.
|
|
|
|
''',
|
|
|
|
mod_table_operate.EditMessage(bd_table.TableFieldDestiny.DESC): f'''
|
|
|
|
Текущий текст сообщения:
|
|
|
|
#{desc_field}
|
|
|
|
|
|
|
|
Введите новый текст:
|
|
|
|
''',
|
|
|
|
mod_table_operate.EditMessage(bd_table.TableFieldDestiny.ACCESS): f'''
|
|
|
|
Текущий доступ к сообщению:
|
|
|
|
#{access_field}
|
|
|
|
|
|
|
|
{user_access.user_access_readme}
|
|
|
|
|
|
|
|
Введите новую строку доступа:
|
|
|
|
''',
|
|
|
|
mod_table_operate.Messages.SUCCESS_EDIT: '''✅ Сообщение успешно отредактировано!''',
|
|
|
|
mod_table_operate.Messages.SELECT_TO_DELETE: '''
|
|
|
|
Выберите категорию, которую вы хотите удалить.
|
|
|
|
''',
|
|
|
|
mod_table_operate.Messages.SUCCESS_DELETE: '''✅ Сообщение успешно удалёно!''',
|
|
|
|
}
|
|
|
|
|
|
|
|
messages_subscribes = {
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_ADD):f'''Сообщение создано''',
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_EDIT):f'''Сообщение отредактировано''',
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_DEL):f'''Сообщение удалено''',
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ITEM_EDIT):f'''Сообщение отредактировано #item_id''',
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ITEM_DEL):f'''Сообщение удалено #item_id''',
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_ADD_WITH_PARENT):f'''Сообщение создано''',
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_EDIT_WITH_PARENT):f'''Сообщение отредактировано''',
|
|
|
|
mod_table_operate.SubscribeMessage(bot_subscribes.SubscribeType.ANY_ITEM_DEL_WITH_PARENT):f'''Сообщение удалено''',
|
|
|
|
}
|
|
|
|
|
|
|
|
messages.update(messages_subscribes)
|
|
|
|
|
|
|
|
class ModuleUserMessage(mod_table_operate.TableOperateModule):
|
|
|
|
def __init__(self, a_ParentModName, a_ChildModName, a_ChildModuleNameList, a_EditModuleNameList, a_Bot, a_ModuleAgregator, a_BotMessages, a_BotButtons, a_BotSubscribes, a_Log):
|
|
|
|
super().__init__(table, messages, button_names, a_ParentModName, a_ChildModName, init_access, init_access, a_ChildModuleNameList, a_EditModuleNameList, a_Bot, a_ModuleAgregator, a_BotMessages, a_BotButtons, a_BotSubscribes, a_Log)
|
|
|
|
|
|
|
|
def GetName(self):
|
|
|
|
return module_name
|
|
|
|
|
|
|
|
async def AddBDItemFunc(self, a_ItemData, a_UserID):
|
|
|
|
res, error = await super().AddBDItemFunc(a_ItemData, a_UserID)
|
|
|
|
desc_field = self.m_Table.GetFieldNameByDestiny(bd_table.TableFieldDestiny.DESC)
|
|
|
|
user_id_field = self.m_Table.GetFieldNameByDestiny(bd_table.TableFieldDestiny.PARENT_ID)
|
|
|
|
|
|
|
|
if not await self.SendMessageToUser(bot_messages.MakeBotMessage(a_ItemData[desc_field]), a_ItemData[user_id_field], parse_mode=interfaces.ParseMode.HTML.value):
|
|
|
|
return None, '❌ Ошибка отправки сообщения'
|
|
|
|
return res, error
|
|
|
|
|
|
|
|
def GetStartButtons(self, a_Message, a_UserGroups):
|
|
|
|
return [
|
|
|
|
[mod_table_operate.ButtonNames.ADD, user_access.AccessMode.ADD],
|
|
|
|
[mod_table_operate.ButtonNames.LIST, user_access.AccessMode.VIEW],
|
|
|
|
[mod_table_operate.ButtonNames.EDIT, user_access.AccessMode.EDIT],
|
|
|
|
[mod_table_operate.ButtonNames.DEL, user_access.AccessMode.DELETE],
|
|
|
|
]
|
|
|
|
|
|
|
|
def GetButtonNameAndKeyValueAndAccess(self, a_Item):
|
|
|
|
key_name_id = self.GetKeyFieldID()
|
|
|
|
date_field_id = self.m_Table.GetFieldIDByDestiny(bd_table.TableFieldDestiny.CREATE_DATE)
|
|
|
|
access_field_id = self.m_Table.GetFieldIDByDestiny(bd_table.TableFieldDestiny.ACCESS)
|
|
|
|
assert key_name_id != None
|
|
|
|
assert date_field_id != None
|
|
|
|
assert access_field_id != None
|
|
|
|
return \
|
|
|
|
a_Item[date_field_id],\
|
|
|
|
a_Item[key_name_id],\
|
|
|
|
a_Item[access_field_id]
|