Создаём бота для поиска дешёвых билетов

Специальный корреспондент
Собака

Собака

Пресс-служба
Команда форума
Private Club
Регистрация
13/10/15
Сообщения
55.276
Репутация
63.040
Реакции
277.675
RUB
0
Как обычно ищут дешёвые билеты (а может, и туры)?

  • Есть подписка на сервисах бронирований типа Aviasales. Но мне никогда не попадались с её помощью реально хорошие билеты.
  • Есть распродажи авиакомпаний. Чтобы словить выгодные билеты, надо подписаться на большое количество авиакомпаний. Будет приходить много писем, и придётся их просматривать на предмет реальной выгоды и интересных вам стран.
  • Регулярно смотреть самому интересующее направление. Но здесь подойдёт мем:
    Все так же ждали дешёвых билетов?

    Все так же ждали дешёвых билетов?
  • Подписаться на Telegram‑каналы, которые сами мониторят лучшие предложения, типа Samokatus (мне интересно, они руками это делают или как‑то автоматизировали?). О таких каналах и пойдёт дальше речь.

Что лично для меня не так с Telegram-каналами?​

  • В них очень много сообщений (до 50 в день). Глазами просматривать это практически невозможно.
  • Направления никак не отсортированы по странам. Возможно, это не для всех актуально, но лично я был в Турции уже 7 раз.
  • Реально хорошие предложения требую мгновенной реакции, так как улетают как горячие пирожки.
И тут мне пришла в голову идея — а что если как‑то в онлайне вычленять сообщения с конкретным направлением и пересылать его себе? Раньше я уже писал пару ботов для Telegram. Но тут другая история — чат публичный, и бота туда не добавить без разрешения админов.

Я начал исследовать, как можно автоматизировать. Нашёл информацию о том, что у Telegram есть один протокол для работы с ботами, а другой — для работы клиентов, он называется MTProto.

Оказывается, клиенты для десктопов и разных мобилок пишет не сам Telegram, а отдаёт это на откуп сторонним разработчикам. Именно поэтому есть много кастомных клиентов. Значит и мне нужно написать свой (ну как написать — использовать реализацию протокола через либу).

Самая популярная библиотека — это Telethon, написанная на Python. Именно им я пользовался 3 года назад, когда пересылал себе сообщения миниатюрным скриптом, который работал на домашнем компьютере.

Но тут-то я решил расшарить свой лайфхак на OpenSource — значит нужно что‑то серьёзное, разворачиваемое по кнопке и масштабируемое не на меня одного. Начал искать аналогичную либу на Java / Kotlin (мой основной стек), но ни одной готовой работающей библиотеки не нашёл.

Есть либа на C++ от Telegram, но во‑первых, это будет проблема с переносимостью, во‑вторых, она собиралась у меня 30 минут (а ноут улетал в облака) и упала в результате на стандартном MacBook. Значит будем делать минимально возможную версию на Python, а всё остальное на Java.

В итоге получилось две части приложения.

  1. SenderAPI — приложение на Python (аллилуйя СhatGPT), которое:
  • Получает подписки с бэк‑части.
  • Вступает в группы.
  • Читает сообщения группы.
  • Пересылает их в личку от аккаунта.
  1. BackendForwarder — приложение, с которым через бота можно подписаться на открытые группы.
Так это выглядит на схеме:

Схема работы модулей

Схема работы модулей
Я сразу подумал, что можно написать spring-boot-starter, в котором уже есть шедулер, работающий на шаблоне проектирования цепочки обязанностей. Достаточно реализовать свои сервисы обработчики сообщений.

Как это работает:

  • Вы реализуете свои UpdatesService.
  • Шедулер, который запускается в стартере, отдаёт вам сообщения.
Например, у меня сервис CreateSubscriptionService отвечает за создание подписки, а GetForDeleteSubscriptionsService — за просмотр и удаление. Каждый обрабатывает сообщения, предназначенные только для этого сервиса (ссылки в конце статьи).

А теперь самое интересное — демонстрация​

Задача: я хочу получать интересные предложения из канала Samokatus.
Идём в бот и подписываемся на публичные группы и сообщения с определёнными фразами.

Ищем крутые билеты

Ищем крутые билеты
Ждём сообщения в личку от аккаунта (нужно разрешить писать тебе не твоим контактам или добавить в контакт свой сервисный аккаунт).

Получаем интересующие сообщения

Получаем интересующие сообщения
При желании можно добавлять новые подписки / управлять старыми.

75bbc2f9ffac170f6792c8e634e9be7e.png

Мораль этой статьи — когда очень что-то надо, люди могут быть очень изобретательными. Теперь у вас есть инструмент для активных путешествий. Как говорится, путешествуйте, оно того стоит, касатики.

Полезные ссылки, чтобы сделать такого же бота​

  • (в нём ссылки на Git-модули частей проект).
  • — бот для подписки.
  • — мой Telegram, если возникнут вопросы.
P. S. Наверно, можно добавить бот не только в группу с путешествиями (или добавить функционал с сочетанием слов для поиска по датам или цене). Найти своё применение вы можете сами.







 
  • Теги
    бот
  • Назад
    Сверху Снизу