Skip to main content

Python client (unofficial) for MAX API. Early version for Async version.

Project description

AIOMaxgram

v0.1.4 от 2.04.2025

https://pypi.org/project/aiomaxgram/

Python-клиент (неофициальный) для API MAX

Внимание! Разработка в ранней стадии. Сейчас поддерживаются: прием и отправка сообщений, инлайн-кнопки.

Обсудить в MAX DevChat - комьюнити разработчиков ботов и приложений MAX

maxgram

Быстрый старт

1. Установка

pip install aiomaxgram

если нужно обновление, то

pip install aiomaxgram --upgrade

2. Получение токена

Откройте диалог с MasterBot, следуйте инструкциям и создайте нового бота. После создания бота MasterBot отправит вам токен. Используйте его в коде ниже вместо YOUR_BOT_TOKEN

3. Пример эхо-бота

from aiomaxgram import Bot
import asyncio

# Инициализация бота (рекомендуется получать через .env)
bot = Bot("YOUR_BOT_TOKEN")

# Обработчик события запуска бота
@bot.on("bot_started")
async def on_start(context):
    await context.reply("Привет! Отправь мне ping, чтобы сыграть в пинг-понг или скажи /hello")

# Обработчик для сообщения с текстом 'ping'
@bot.hears("ping")
async def ping_handler(context):
    await context.reply("pong")

# Обработчик команды '/hello'
@bot.command("hello")
async def hello_handler(context):
    await context.reply("world")

# Обработчик для всех остальных входящих сообщений
@bot.on("message_created")
async def echo(context):
    # Проверяем, что есть сообщение и тело сообщения
    if context.message and context.message.get("body") and "text" in context.message["body"]:
        # Получаем текст сообщения
        text = context.message["body"]["text"]
        
        # Проверяем, что это не команда и не специальные сообщения с обработчиками
        if not text.startswith("/") and text != "ping" and text != "hello":
            await context.reply(text)

# Запуск бота
if __name__ == "__main__":
    try:
        asyncio.run(bot.start())
    except KeyboardInterrupt:
        asyncio.run(bot.stop())

4. Установка подсказок для команд бота

# Установка команд бота
import asyncio

asyncio.run(bot.set_my_commands({
    "help": "Получить помощь",
    "ping": "Проверка работы бота",
    "hello": "Приветствие"
}))

Примечание: функционал подсказок сейчас может не работать на десктопном клиенте

menu_example

Создание клавиатуры

  • Поддерживаются инлайн-кнопки, иимпортируйте InlineKeyboard из библиотеки
  • Для формирования клавиатуры передайте списки, где каждый список - это одна строка кнопок. Внутри строки кнопок располагаются словари с названием и уникальным тегом кнопки. Callback - обычная кнопка, url - кнопка ссылка
  • Количество кнопок в строке по количеству словарей. При этом ширина кнопок делится поровну
  • Для отправки клавиатуры в сообщении просто передайте параметр keyboard в reply c названием клавиатуры
from aiomaxgram.keyboards import InlineKeyboard

# Создание клавиатуры
main_keyboard = InlineKeyboard(
    [
        {"text": "Отправить новое сообщение", "callback": "button1"},
    ],
    [ 
        {"text": "Изменить сообщение", "callback": "button2"},
        {"text": "Показать Назад", "callback": "button3"}
    ],
    [
        {"text": "Открыть ссылку", "url": "https://pypi.org/project/aiomaxgram/"}
    ]
)

# Отправить клавиатуру по команде '/keyboard'
@bot.command("keyboard")
async def keyboard_command(context):
    await context.reply(
        "Вот клавиатура. Выбери одну из опций:",
        keyboard=main_keyboard
    )

Обработка нажатий на кнопки

  • Примите уникальные теги кнопок из .payload и отвечайте с помощью .reply_callback
  • Можно передавать новые клавиатуры в сообщениях
  • Укажите параметр is_current=True, чтобы изменить текущее сообщение, а не отправлять новое
# Обработчик нажатий на кнопки
@bot.on("message_callback")
async def handle_callback(context):
    
    button = context.payload
    
    if button == "button1":
        await context.reply_callback("Вы отправили новое сообщение")
    elif button == "button2":
        await context.reply_callback("Вы изменили текущее сообщение", is_current=True)
    elif button == "button3":
        await context.reply_callback("Вы изменили текущее сообщение с новой клавиатурой", 
                          keyboard=InlineKeyboard(
                              [{"text": "Вернуться к меню", "callback": "back_to_menu"}]
                          ),
                          is_current=True)
    elif button == "back_to_menu":
        await context.reply_callback(
            "Вернемся к основному меню", 
            keyboard=main_keyboard,
            is_current=True
        )

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aiomaxgram-0.1.5.1.tar.gz (15.6 kB view details)

Uploaded Source

File details

Details for the file aiomaxgram-0.1.5.1.tar.gz.

File metadata

  • Download URL: aiomaxgram-0.1.5.1.tar.gz
  • Upload date:
  • Size: 15.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for aiomaxgram-0.1.5.1.tar.gz
Algorithm Hash digest
SHA256 fa3d201d08c476f7334e5dd4f862312af986a3c72fc0ae309f2500ccb8b85b81
MD5 a8a5e1bd79f4181cd0271a756cb98c95
BLAKE2b-256 9e6ed3ff6f4b19ca724c7902f284736c61dc41d3a606f1ca8f2596a01f3fee2c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page