Прежде чем перейти к статье, хочу вам представить, экономическую онлайн игру Brave Knights, в которой вы можете играть и зарабатывать. Регистируйтесь, играйте и зарабатывайте!
В последнее время я сделал насколько много ботов для телеграмма, что крайне преисполнился в том, как их писать, как хостить, да и в принципе выработал красивый шаблон для быстрого их создания.
Сразу могу предложить посмотреть на то, что получиться в конце этого туториала. Для этого я запустил бота с идентичном шаблону кодом.
Также стоит отметить, что хостинг в этом примере бесплатный, но его хватает для разумной нагрузки.
А еще сразу скажу, что далее будет все на питоне... Вот... Сказал. Не буду больше ходить вокруг да около, у нас всего 5 минут (помните, да?). Приступим!
Пошаговая инструкция
1) Создаем репозиторий на гитхабе из моего шаблона
2) Регистрируемся на Heroku
3) Создаем новое приложение
4) Привязываем наш репозиторий к проекту на Heroku
5) Настраиваем автоматический deployment
6) Смотрим на адрес, где будет висеть наш бот
7) Настраиваем переменные среды
KEY | VALUE |
BOT_TOKEN | Токен для бота |
WEBHOOK_TOKEN | Рандомная строка из букв для безопастности |
ADMIN_PASSWORD | Еще одна рандомная строка из букв для безопастности |
HOST | Адрес полученный в пункте 6 (например fancy-panda.herokuapp.com). Обратите внимание на формат! |
IS_PRODUCTION | True |
LOG_BOT_TOKEN | Токен для бота, куда будут отправляться логи |
ADMIN_ID | user_id, куда будут отправляться логи (получить в боте @userinfobot) |
8) Собираем наше приложение и ждем пока оно запустится
9) Заходим по адресу из пункта 6 и добавляем к ссылке пароль. Получиться что-то такое: fancy-panda.herokuapp.com/?password=<ADMIN_PASSWORD>
10) Устанавливаем webhook, переходя по ссылке на подобие fancy-panda.herokuapp.com/set_webhook?password=<ADMIN_PASSWORD>
Тестируем
Теперь, когда мы закончили все настраивать, пора посмотреть, что же мы "натворили".
Посмотреть в живую можно тут.
Добавляем функционал
Теперь, когда у вас есть рабочий бот, который сам разворачивается и запускается в облаке, пришло время добавить свои функции. Для примера такую:
@bot.message_handler(commands=["id"])
def get_id(message):
logger.info(f'</code>@{message.from_user.username}<code> used /id')
bot.send_message(message.chat.id, f"user_id = {message.chat.id}")
Думаю, дальше ограничивает вас только воображение... (ну почти)
Применение в проектах
Все любят, когда есть примеры работы. На основе этого шаблона я сделал бота wifi_qr_bot, который генерирует QR-коды для подключения к WiFi. Это упрощает жизнь, ведь пароль у вас длинный (безопасность, все дела), а вводить его на каждом новом устройстве вам лень.
Выводы
Вот мы и сделали нашего бота, который хоститься в облаке. Он уже многое умеет в плане логирования. Для логирования я написал отдельную библиотеку, tg-logger. Если интересно, как она работает, то потыкайте в демо бота. Если все еще интересно, прочитайте мою статью. Такие пироги с котятками...
Ссылки
Репозиторий шаблона: https://github.com/otter18/telegram-bot-template
Рабочий бот (запущенный шаблон): https://t.me/sjfsdjflsdkjlkgjdfg_bot
WiFi QR-code generator bot: https://t.me/wifi_qr_bot
Исходный код WiFi QR-code generator bot: https://github.com/otter18/wifi_qr_bot