В последнее время я сделал насколько много ботов для телеграмма, что крайне преисполнился в том, как их писать, как хостить, да и в принципе выработал красивый шаблон для быстрого их создания.
Сразу могу предложить посмотреть на то, что получиться в конце этого туториала. Для этого я запустил бота с идентичном шаблону кодом.
Также стоит отметить, что хостинг в этом примере бесплатный, но его хватает для разумной нагрузки.
А еще сразу скажу, что далее будет все на питоне… Вот… Сказал. Не буду больше ходить вокруг да около, у нас всего 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://habr.com/ru/post/549178/
Добавить комментарий