Patriot-solution
Max мессенджер появился недавно, и пока экосистема вокруг него только формируется. YandexGPT - мощная языковая модель с OpenAI-совместимым API. Казалось бы, собрать из этого бота - задача на вечер. На практике оказалось, что готового инструмента, который бы связал эти две вещи, просто нет.
Я написал max-yandexgpt - Python-фреймворк, который позволяет запустить AI-бота в Max мессенджере с YandexGPT за 5 строк кода. Со стримингом ответов, выбором модели и нормальной конфигурацией.
В этой статье расскажу, как он устроен и зачем.
Что получается на выходе
from max_yandexgpt import MaxYandexGPT bot = MaxYandexGPT( max_token="ВАШ_ТОКЕН_MAX", yandex_api_key="ВАШ_КЛЮЧ_YANDEXGPT", yandex_folder_id="ВАШ_FOLDER_ID", ) bot.run()
Это рабочий бот. Он принимает сообщения в Max, отправляет их в YandexGPT, и отдаёт ответ пользователю, со стримингом по умолчанию. То есть бот сначала отправляет placeholder, а потом обновляет сообщение по мере генерации текста. Выглядит как ChatGPT-интерфейс прямо в мессенджере.
Зачем это нужно
Max - новый мессенджер, и разработчики только начинают осваивать его API. YandexGPT - это Yandex Cloud Foundation Models с OpenAI-совместимым эндпоинтом. По отдельности документация есть, но связки между ними нет: нужно самому разбираться с авторизацией, форматом model URI, стримингом через SSE, редактированием сообщений в Max.
max-yandexgpt берёт это на себя. Под капотом - два компонента:
maxapi - клиент Max мессенджера (диспетчер, хэндлеры, polling)
openai SDK - для запросов к YandexGPT через OpenAI-совместимый API Yandex Cloud
Разработчику остаётся только указать токены и запустить.
Архитектура
Фреймворк состоит из трёх модулей:
config.py - конфигурация. Dataclass с валидацией: токены, модель, system prompt, температура, max_tokens, параметры стриминга. Поддерживает переменные окружения (MAX_TOKEN, YANDEX_API_KEY, YANDEX_FOLDER_ID), что бы не хардкодить секреты.
llm.py - клиент YandexGPT. Использует AsyncOpenAI из официального OpenAI SDK, но с кастомным base_url:
YANDEX_BASE_URL = "https://ai.api.cloud.yandex.net/v1" self._client = AsyncOpenAI( api_key=config.yandex_api_key, base_url=YANDEX_BASE_URL, )
Model URI формируется как gpt://{folder_id}/{model_name}- это специфика Yandex Cloud. Два режима: complete() для синхронных запросов и stream() асинхронный генератор, который yield’ит текстовые дельты.
bot.py - основной класс MaxYandexGPT. Связывает Max и YandexGPT: регистрирует хэндлеры через maxapi.Dispatcher, маршрутизирует входящие сообщения и управляет стримингом.
Стриминг работает так:
Бот получает сообщение от пользователя
Отправляет placeholder
"..."Запрашивает YandexGPT в streaming-режиме
По мере поступления дельт - редактирует сообщение в Max
Rate-limit на редактирование: не чаще чем раз в
stream_intervalсекунд (по умолчанию 1.0)Финальное сообщение - полный ответ без placeholder
Весь бот асинхронный asyncio от начала до конца.
Модели
Поддерживаются все актуальные модели YandexGPT:
Модель |
Описание |
|---|---|
|
Быстрая и дешёвая (по умолчанию) |
|
Стандартная |
|
Новейшая |
|
AliceAI |
Переключение — один параметр:
bot = MaxYandexGPT( max_token="...", yandex_api_key="...", yandex_folder_id="...", model="yandexgpt-5.1/latest", )
Настройка
Полный набор параметров:
bot = MaxYandexGPT( max_token="...", yandex_api_key="...", yandex_folder_id="...", system_prompt="Ты — полезный ассистент.", stream=True, # стриминг включён по умолчанию temperature=0.3, max_tokens=2000, )
Или через переменные окружения для продакшена:
bot = MaxYandexGPT() # читает из MAX_TOKEN, YANDEX_API_KEY, YANDEX_FOLDER_ID bot.run()
Установка и запуск
pip install max-yandexgpt
Что нужно:
Python 3.11+
Токен бота Max мессенджера, создаётся на max.ru
API-ключ YandexGPT + folder ID через Yandex Cloud Console
Исходный код
Проект открытый, MIT-лицензия:
Буду рад фидбеку, issues на GitHub открыты.
Комментарии (6)

K0Jlya9
10.04.2026 10:20Там уже есть алиса и гигачад. Какой смысл делать платный аналог у которого нет даже базовых тулзов типа гугл поиска и выполнения кода?
Зы стриминг только мешает читать, исключение - очень медленные модели которые ответ по 2 минуты пишут. Токен получить нельзя без юр лица, нет никакого смысла смотреть в эту сторону.

Triton5
10.04.2026 10:20Выполнение кода в чате, я думаю, обычному человеку не нужно, да и программисту наверное тоже:)
А поиск и суммаризация, это можно сделать даже бесплатно, на маленьких объёмах:) Тут же речь про примитивный прототип:)

K0Jlya9
10.04.2026 10:20Выполнение кода - банальный калькулятор, запросы типа сколько дней осталось до 11 небритебря. Даже у алисы с этим есть проблемы, это дорого стоит очень.

Triton5
10.04.2026 10:20Самое ненужное - это всякая маркетинговая чешуя про вопреки продаж и прочие способы впарить ненужные товары:)
А зачем нужно делать свои разговорные боты, когда есть Алиса и Гигачат - именно потому, что есть Алиса и Гигачат и они чем-то не устраивают. Да и просто прикольно иметь свою личную электронную версию собеседника.
Хобби это такое может быть. Айти как отдых и хобби от грубого реального мира. А айтишники наоборот, уходят в грубый материальный мир - вытачивают что-то на станке из дерева, делают машинки, собирают мебель, запускают дроны (не те, о которых вы подумали).
Triton5
Можно и без модного стриминга, просто отправлять сообщение целиком, ещё проще.
Только ведь вот этот пункт:
"Токен бота Max мессенджера, создаётся на max.ru" - он как бы не для простых смертных, образно говоря. Это чисто упёртость начальников Макса, в стиле "можно, а зачем". Да и во многих других моментах в Максе там этот подход прямо таки основополагающий.
За статью спасибо, конечно:)