|
Professor Seleznov
|
 Не знаю как правильно спозиционировать статью, то ли это очередной рассказ про вайбкодинг, то ли про то что Kotlin Native на что-то годится и в целом может потягаться с Go, то ли пиар моего бота, то ли история неуспеха. Ну да ладно, будет всего понемногу. Началось всё с того что я купил себе новую бибику, нашел в телеге чаты-сообщества по моей модели, и в одном из их был раздел с перекличкой автовладельцев, так как модель машины ещё новая и совсем не распространённая у нас. Выглядит этот чат примерно так:
 Далее кто-то иногда делает усилие и постит статистику по городам, сколько машин в каком городе. И мне было интересно узнать что в моём городе уже ездит около 6 машин, потому что я за пол года ни одной не видел вживую. Собственно так и родилась идея для бота, я её долго вынашивал. Потом когда все вокруг начали упарываться вайбкодингом, я понял что настало время и сбацал MVP. Человек в чате даёт команду /checkin и дальше в диалоге с ботом указывает какая у него комплектация и из какого он города. Соответственно команда /stats отображает в чате статистику по городам и комплектациям. Ну и админ должен подключить бота в чат, настроить боту права, выбрать модель машины для чата. Для этого есть команды /setup и /admin в личке с ботом. Также человек может просмотреть и изменить регистрацию своей машины командой /me в личке с ботом. Вот видео, показывающее весь процесс: Ещё одна попутно возникшая прикольная идея - общая база между всеми чатами разных сообществ. То есть если человек регистрируется в каком-то одном чате, то он попадает в глобальную статистику и в других чатах люди видят реальную картину сколько в их городе таких машин, а не только сколько конкретно в их чате. Мне было интересно попробовать сделать бота на Kotlin Native, так как мне нравится Kotlin и не нравится JVM. Я завидую Go в том плане что как легко собирается легковесный бинарник, который работает везде и не завидую тем кто на нём пишет из за примитивности самого языка ) Также я был не уверен что эта идея вообще зайдет, но хотелось попробовать и заодно повайбкодить при помощи Claude Code и Sonnet 4.6. В целом я вместе с Claude Sonnet 4.6 справился с написанием этого бота менее чем за день. Я в очередной раз восхищен тем как он умеет реализовывать задачи, как чинит ошибки. Особенно это хорошо было видно на примере написания на Kotlin Native. Столько вылезло проблем с Gradle, нестыковкой версий библиотек, конфликтом забандленной OpenSSL и тем что у меня стояло в системе. Я не знаю сколько бы это всё разгребал самостоятельно. Sonnet находил такие решения проблем, что я просто снимаю шляпу. Он умеет лазить в байткод Kotlin и Java библиотек там выяснять реализацию, а также ковыряться в нативных бинарниках всеми возможными тулзами типа nm, objdump, strace и прочими. Получился такой стек:
Готовых годных библиотек на Kotlin/Native для написания TG-ботов вроде как нет, поэтому было решено просто использовать HTTPS клиент и API напрямую, это не сильно сложнее чем борьба с сырыми либами, а может даже и проще. Код получился довольно простой и понятный, практически без абстракций. Я конечно добавил бы туда DI, интерфейсы и прочие мне привычные штуки при разработке, но сдерживал себя что это MVP. Также была сделана сборка Docker образа на Github Actions и постинг его на Docker Hub (https://hub.docker.com/repository/docker/navrocky/car-survey-tg-bot) К сожалению компилятор Kotlin Native не умеет собирать нормальную статику, как, например, это умеет Rust или Go. Поэтому бинарь зависит от операционки на которой он собирался, от glibc и gcc рантайм библиотек. Пришлось сильно повозиться с тем чтобы собрать Docker образ на базе Alpine, путём установки сторонней сборки glibc под Alpine. В итоге сам бинарь получился 15Мб. Docker образ на базе Alpine получился 40Мб не сжатый и 16Мб в сжатом виде. При работе процесс потребляет 20-60Мб ОЗУ. Сам проект находится на Github - https://github.com/navrocky/car-survey-tg-bot. Если кому-то будет интересно сделать бота именно на Kotlin Native - это живой работающий проект. Запустить его можно командой:
docker run --name car-survey-bot \ -e SUPERADMIN_IDS=12345678 \ -e BOT_TOKEN=12345678:AAGassdasqweqwesdfsdfsdfsadfMech8AHM \ -e BOT_USERNAME=car_survey_bot \ -e DB_URL=sqlite:///data/bot.db \ -v ./data:/data \ navrocky/car-survey-tg-bot:latest
Где:
- SUPERADMIN_IDS - список ID пользователей телеграм, которые являются суперадминами бота, имеют права на администрирование списка городов, моделей машин.
- BOT_TOKEN - токен бота полученный при регистрации у BotFather
- BOT_USERNAME - имя бота при регистрации у BotFather
- DB_URL - путь к SQLite базе данных (также возможна настройка PostgreSQL, описано в README)
Ну а самое печальное, что я, такой радостный, начал писать во все свои автомобильные чаты и их админам, что вот теперь то заживём, гляньте какой классный бот. Но как-то никто моего энтузиазма, к сожалению, не разделил. Собственно, это история неуспеха как было интересно с этим ковыряться, но похоже что в стол. Хотелось бы услышать ваше мнение, идея норм или нет? И почему не зашло и что можно сделать чтобы админам зашло? Ссылки: https://t.me/car_club_survey_bot - бот https://github.com/navrocky/car-survey-tg-bot - исходники бота https://hub.docker.com/repository/docker/navrocky/car-survey-tg-bot - собранный докер образ бота PS. Сорян за Коди-осьминога, ChatGPT упорно не хотела нарисовать ему нормальные руки ноги )-Источник
|