mirror of
https://github.com/civsocit/olgram.git
synced 2025-05-24 09:03:25 +00:00
tag first iteration
This commit is contained in:
parent
214824db14
commit
1b1fe239f8
|
@ -12,6 +12,9 @@ Bitcoin:
|
||||||
Litecoin:
|
Litecoin:
|
||||||
``ltc1qxajsvz0lw44aa5nytuch8cp2g8x7a4cdase4y7``
|
``ltc1qxajsvz0lw44aa5nytuch8cp2g8x7a4cdase4y7``
|
||||||
|
|
||||||
|
Monero:
|
||||||
|
``84ymMfpw3vxFxsgmYbFURMiZLgQCmhKsZNiZiqZRbpH2WRka2UDjyDVZpX8XH1cZ9d5EghvPXrF5hEuzvK5NvHGE8za4Gmk``
|
||||||
|
|
||||||
Как убрать "Этот бот создан с помощью ..."
|
Как убрать "Этот бот создан с помощью ..."
|
||||||
----------------
|
----------------
|
||||||
Напишите нам на `@civsocit_feedback_bot <https://t.me/civsocit_feedback_bot>`_.
|
Напишите нам на `@civsocit_feedback_bot <https://t.me/civsocit_feedback_bot>`_.
|
||||||
|
@ -20,6 +23,7 @@ Litecoin:
|
||||||
История изменений
|
История изменений
|
||||||
----------------
|
----------------
|
||||||
|
|
||||||
|
- `2024-03-15` Тэги
|
||||||
- `2024-03-02` Рассылки
|
- `2024-03-02` Рассылки
|
||||||
- `2024-03-01` Непрерывные потоки сообщений (опция)
|
- `2024-03-01` Непрерывные потоки сообщений (опция)
|
||||||
- `2024-02-17` Опция смены режима работы автоответчика: автоответчик отвечает на КАЖДОЕ сообщение
|
- `2024-02-17` Опция смены режима работы автоответчика: автоответчик отвечает на КАЖДОЕ сообщение
|
||||||
|
|
|
@ -115,3 +115,14 @@ BotFather - это официальный бот Telegram, создающий д
|
||||||
|
|
||||||
Если у вас возникли вопросы по использованию бота, или вы нашли ошибку - напишите
|
Если у вас возникли вопросы по использованию бота, или вы нашли ошибку - напишите
|
||||||
нам `@civsocit_feedback_bot <https://t.me/civsocit_feedback_bot>`_.
|
нам `@civsocit_feedback_bot <https://t.me/civsocit_feedback_bot>`_.
|
||||||
|
|
||||||
|
Тэги пользователей
|
||||||
|
------------------
|
||||||
|
|
||||||
|
Пользователям можно проставлять теги. Например, в ответ на сообщение пользователя написать:
|
||||||
|
|
||||||
|
```
|
||||||
|
/tag #important
|
||||||
|
```
|
||||||
|
|
||||||
|
Тогда в user info (см. раздел опции) помимо информации о пользователе будет тег #important
|
||||||
|
|
|
@ -40,6 +40,10 @@ def _message_unique_id(bot_id: int, message_id: int) -> str:
|
||||||
return f"{bot_id}_{message_id}"
|
return f"{bot_id}_{message_id}"
|
||||||
|
|
||||||
|
|
||||||
|
def _tag_uid(bot_id: int, user_id: int) -> str:
|
||||||
|
return f"tag_{bot_id}_{user_id}"
|
||||||
|
|
||||||
|
|
||||||
def _thread_unique_id(bot_id: int, chat_id: int) -> str:
|
def _thread_unique_id(bot_id: int, chat_id: int) -> str:
|
||||||
return f"thread_{bot_id}_{chat_id}"
|
return f"thread_{bot_id}_{chat_id}"
|
||||||
|
|
||||||
|
@ -89,6 +93,9 @@ async def send_user_message(message: types.Message, super_chat_id: int, bot):
|
||||||
user_info += f" | lang: {message.from_user.locale}"
|
user_info += f" | lang: {message.from_user.locale}"
|
||||||
if message.forward_sender_name:
|
if message.forward_sender_name:
|
||||||
user_info += f" | fwd: {message.forward_sender_name}"
|
user_info += f" | fwd: {message.forward_sender_name}"
|
||||||
|
tag = await _redis.get(_tag_uid(bot.pk, message.from_user.id), encoding="utf-8")
|
||||||
|
if tag:
|
||||||
|
user_info += f" | tag: {tag}"
|
||||||
|
|
||||||
# Добавлять информацию в конец текста
|
# Добавлять информацию в конец текста
|
||||||
if message.content_type == types.ContentType.TEXT \
|
if message.content_type == types.ContentType.TEXT \
|
||||||
|
@ -216,6 +223,14 @@ async def handle_operator_message(message: types.Message, super_chat_id: int, bo
|
||||||
else:
|
else:
|
||||||
await banned_user.delete()
|
await banned_user.delete()
|
||||||
return SendMessage(chat_id=message.chat.id, text=_("Пользователь разбанен"))
|
return SendMessage(chat_id=message.chat.id, text=_("Пользователь разбанен"))
|
||||||
|
if message.text.startswith("/tag "):
|
||||||
|
tag = message.text.replace("/tag ", "")[:20].strip()
|
||||||
|
if tag:
|
||||||
|
await _redis.set(_tag_uid(bot.pk, chat_id), tag, pexpire=ServerSettings.redis_timeout_ms())
|
||||||
|
return SendMessage(chat_id=message.chat.id, text=_("Тег выставлен"))
|
||||||
|
else:
|
||||||
|
await _redis.delete(_tag_uid(bot.pk, chat_id))
|
||||||
|
return SendMessage(chat_id=message.chat.id, text=_("Тег убран"))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
await message.copy_to(chat_id)
|
await message.copy_to(chat_id)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user