Bot was created originally for IASA Student Council to handle suggestions, questions and requests. However, you can freely fork this repository and create your own bot.
- User sends a message to the bot
- Bot forwards the message to the chat
- Chat participant replies to the forwarded message
- Bot copies the answer and sends it to user
- Text, Photos, Videos, Documents, GIFs, Voice Messages and Geolocation are supported
- Customisable messages for bot to answer
- Ban/unban users using reply
- Messages editing. Changes would be displayed in private/group chat
❗ Note: changing pictures/videos is not possible, only their captions
To ban spamming/unfriendly users, you should reply on forwarded from user message like this: /ban
or like this: /ban <reason>
,
where the reason will be displayed to user if he would try to send something again. Then, bot will reply to you whether
it was successful or not.
In contrast, to unban users, you should reply on user's message with /unban
and bot will notify on command success
or failure.
Message editing is implemented using SQL table. When a message is being sent - bot inserts original message id and
forwarded message id into SQL table. For storage optimisation purposes in the table a script was written, which deletes
row after some time passes, which can be found in create_bot.py
To configure time interval after which added entry is to be deleted (1 day by default), edit .env
variable
ROW_REMOVAL_INTERVAL
according to time standards in SQL.
To setup a bot for your own usage, you should specify those variables in
.env
.
COMPOSE_FILE=docker-compose.yml
# Bot Data
TELEGRAM_TOKEN="<YOUR BOT TOKEN>" # your bot's token
CHAT_ID=0 # chat id where the bot will forward users' messages
# Database Data
POSTGRES_HOST="<YOUR HOST>" # host of sql database
POSTGRES_PASSWORD="<YOUR PASSWORD>" # password to access database
POSTGRES_DB="<YOUR DATABASE NAME>" # database name
POSTGRES_USER="<USER>" # username to log in
POSTGRES_PORT=5432 # port to connect to database
PGDATA=/var/lib/postgresql/data
ROW_REMOVAL_INTERVAL="1 days" # interval after which an entry is removed from the message table
To change default text to your custom, redefine values of the dictionary for each phrase in
config.py
.
# Predefined text to send
TEXT_MESSAGES = {
'start': 'Welcome to Suggestions Bot 👋 \n\n Please, send your message and we will process your request.',
'message_template': '<i>Message from: <b>@{0}</b>.</i>\n\n{1}<b>id: {2}</b>',
'is_banned': '❌ User is banned!', 'has_banned': '✅ User has been successfully banned!',
'already_banned': '❌ User is already banned!', 'has_unbanned': '✅ User has been successfully un-banned!',
'not_banned': '❌ There is no such user in the ban list!',
'user_banned': '🚫 You cannot send messages to this bot!',
'user_unbanned': '🥳 You have proven your innocence, and now you can write to this bot again!',
'user_reason_banned': '🚫 You cannot send messages to this bot due to the reason: <i>{}</i>.',
'pending': 'Thank you for your request! We are already into processing it.',
'unsupported_format': '❌ Format of your message is not supported and it will not be forwarded.',
'message_not_found': '❌ It looks like your message was sent more that a day ago. Message to edit was not found!',
'message_was_not_edited': '❌ Unfortunately you cannot edit images/videos themselves.'
'Please, send a new message.',
'reply_error': '❌ Please, reply with /ban or /unban only on forwarded from user messages!'
}
- Clone this repository using terminal or tools in your IDE:
git clone /~https://github.com/dimaplel/telegram-suggestions-bot.git
- Change directory in terminal
cd $repository-direcory
- Download requirements
pip install -r requirements.txt
- Edit and update
.env
and/orconfig.py
- Launch Docker
- Run the bot with
docker compose up --build
or with GNU Make:make up
Початково, бот був створений для СтудРади ІПСА для обробки пропозицій, питань та запитів. Однак ви легко можете форкати даний репозиторій і кастомізувати його під свої потреби.
- Користувач надсилає повідомлення боту
- Бот пересилає повідомлення в чат
- Учасник чату відповідає на переслане повідомлення
- Бот копіює відповідь і надсилає її користувачеві
- Підтримуються Текст, Зображення, Відео, Документи, Гіфки, Голосові Повідомлення та Геолокація
- Кастомізація стандартних відповідей бота на трігери або команди
- Бан/розбан користувачів за допомогою відповіді на повідомлення
- Редагування повідомлень. Зміни відображатимуться в приватному/груповому чаті
❗ Примітка: змінити зображення/відео неможливо, лише підпис
Для того, щоб забанити користувачів, що спамлять або поводять себе непривітно, ви маєте відповісти на повідомлення
користувача так: /ban
або так: /ban <причина>
, де причина відобразиться, якщо цей користувач знову спробує щось
надіслати. Потім, бот відповість статусом виконання операції.
На противагу, щоб розбанити користувача, потрібно відповісти на повідомлення користувача /unban
, і бот відповість, що
команда виконалась успішно чи невдало.
Редагування повідомлень реалізовано за допомогою SQL таблиці. Коли присилається повідомлення - бот вставляє
в таблицю id оригінального повідомлення та id пересланого повідомлення. Задля оптимізації місця у таблиці було
написано тригер, який видаляє рядок через деякий час (перевірка на час здійснюється, коли новий елемент додається
до таблиці). Тригер встановлюється у create_bot.py
.
Для зміни часу до видалення запису (1 день за замовчуванням) налаштуйте змінну оточення ROW_REMOVAL_INTERVAL
згідно
з форматом часу SQL.
Для того, щоб налаштувати бота для власного використання, потрібно вказати наступні змінні в
.env
COMPOSE_FILE=docker-compose.yml
# Bot Data
TELEGRAM_TOKEN="<YOUR BOT TOKEN>" # токен вашого бота
CHAT_ID=0 # id чату, куди бот пересилатиме повідомлення від користувачів
# Database Data
POSTGRES_HOST="<YOUR HOST>" # хост бази даних sql
POSTGRES_PASSWORD="<YOUR PASSWORD>" # пароль для бази даних
POSTGRES_DB="<YOUR DATABASE NAME>" # ім'я бази данних
POSTGRES_USER="<USER>" # username для входу в базу даних
POSTGRES_PORT=5432 # порт для з'єднання з базою даних
PGDATA=/var/lib/postgresql/data
ROW_REMOVAL_INTERVAL="1 days" # інтервал після якого запис про повідомлення видаляється з таблиці
Для того, щоб змінити стандартний текст відповідей бота на ваш власний, змініть значення в словнику для кожної фрази в
config.py
# Predefined text to send
TEXT_MESSAGES = {
'start': 'Ласкаво просимо 👋\n\nНапишіть своє запитання / пропозицію, і ми відповімо Вам найближчим часом.',
'message_template': '<i>Повідомлення від: <b>@{0}</b>.</i>\n\n{1}<b>id: {2}</b>',
'is_banned': '❌ Користувач забанений!', 'has_banned': '✅ Користувач був успішно забанений!',
'already_banned': '❌ Користувач уже забанений!', 'has_unbanned': '✅ Користувач був успішно розбанений!',
'not_banned': '❌ Такого користувача немає в бан-лісті!',
'user_banned': '🚫 Ви більше не можете писати в бот пропозицій!',
'user_reason_banned': '🚫 Ви більше не можете писати в бот пропозицій через причину: <i>{}</i>.',
'user_unbanned': '🥳 Сама благодать зійшла з небес, і тепер ви знову можете писати до боту пропозицій!',
'pending': 'Дякуємо за ваше звернення. Ми вже оброблюємо Ваш запит!',
'unsupported_format': '❌ Формат вашого повідомлення не підтримується, воно не буде переслане.',
'message_not_found': '❌ Схоже, що ви відправляли повідомлення більше трьох діб тому, повідомлення не було знайдено!'
, 'message_was_not_edited': '❌ На жаль не можна редагувати зображення в повідомленнях. '
'Будь ласка, надішліть нове зображення',
'reply_error': '❌ Будь-ласка, давайте відповідь /ban або /unban лише на переслані від користувачів повідомлення!'
}
- Зклонуйте репозиторій за допомогою терміналу або інструментів у вашій IDE:
git clone /~https://github.com/dimaplel/telegram-suggestions-bot.git
- Змініть папку в терміналі
cd $repository-directory
- Встановіть вимоги
pip install -r requirements.txt
- Відредагуйте та оновіть
.env
та/абоconfig.py
- Запустіть Docker
- Запустіть бота у терміналі
docker compose up --build
або з GNU Make:make up