You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
143 lines
7.2 KiB
143 lines
7.2 KiB
# -*- 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]
|
|
|