mcp-max-messenger
mcp-max-messenger
mcp-max-messenger
The first MCP server for MAX Messenger โ Russia's national messenger by VK (75M+ users).
Connect AI clients (Claude Desktop, Cursor, n8n, and any MCP-compatible app) to MAX: send and read messages, manage chats and members, send media, handle button presses, format with HTML/Markdown โ all through the open Model Context Protocol standard.
21 tools with full coverage of MAX Bot API.
Why MAX?
- ๐ท๐บ National messenger mandated for pre-installation on all smartphones in Russia (September 2025)
- ๐ฑ 75M+ registered users
- ๐ข Recommended by the Ministry of Digital Development for government agencies and large enterprises
- ๐ค Full Bot API with official SDKs: TypeScript, Python, Go, Java, PHP
Quick Start
Prerequisites
- Node.js 18+
- A MAX bot token (create a bot at max.ru)
Claude Desktop / Cursor (stdio mode)
Add to your Claude Desktop config:
Mac: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"max-messenger": {
"command": "npx",
"args": ["-y", "@woyax/mcp-max-messenger"],
"env": {
"MAX_TOKEN": "YOUR_BOT_TOKEN"
}
}
}
}
Restart Claude Desktop. The MAX tools will appear automatically.
Remote / Hosted mode (HTTP)
MAX_TOKEN=YOUR_BOT_TOKEN MCP_TRANSPORT=http MCP_PORT=3000 npx @woyax/mcp-max-messenger
Connect any MCP client to http://your-server:3000/mcp.
Available Tools (21)
Messages
| Tool | Description |
|---|---|
get_messages | Read messages from a chat (by chat_id or message_ids) |
send_message | Send a message with text, HTML/Markdown, inline keyboard, media attachments |
edit_message | Edit message text and attachments |
delete_message | Delete a message |
pin_message | Pin a message in a chat |
unpin_message | Unpin the currently pinned message |
Media
| Tool | Description |
|---|---|
send_media | Upload and send photo, video, audio, or file by URL |
send_action | Show typing indicator, "sending photo/video/audio/file", mark as read |
Chats
| Tool | Description |
|---|---|
get_bot_info | Bot info: name, ID, username, description |
get_chats | List all group chats the bot participates in |
get_chat | Full chat details: participants, pinned message, owner |
edit_chat | Rename chat, change description or icon |
Members
| Tool | Description |
|---|---|
get_chat_members | List chat members with roles |
get_admins | List chat administrators with permissions |
set_admin | Grant admin rights to a member |
remove_admin | Revoke admin rights |
add_members | Add users to a group chat |
remove_member | Remove a user from a group chat |
Events
| Tool | Description |
|---|---|
get_updates | Incoming events: messages, button presses, new dialogs (long polling) |
answer_callback | Respond to inline button press: show notification or update message |
Buttons (via send_message attachments)
5 button types supported: callback, link, message, request_contact, request_geo_location.
Usage Examples
Once connected to Claude Desktop, use natural language:
"Send a message to chat 123456789: 'The meeting starts in 10 minutes'"
"Send an approval request with Approve/Reject buttons to the team chat"
"Show me the last 10 messages from the announcements chat"
"Send this photo to the chat: https://example.com/image.jpg"
"Who are the members of the sales group? Make Alex an admin."
"Check for new incoming messages and button presses"
Configuration
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
MAX_TOKEN | โ | โ | Your MAX bot token |
MCP_TRANSPORT | โ | stdio | Transport: stdio or http |
MCP_PORT | โ | 3000 | Port for HTTP mode |
Command-line Flags
# Local stdio mode (default)
npx @woyax/mcp-max-messenger
# Remote HTTP mode
npx @woyax/mcp-max-messenger --transport http --port 3000
Architecture
Two independent layers โ tools work identically in both modes:
src/
โโโ core/ # Business logic โ shared between modes
โ โโโ max-client.ts # MAX API HTTP client
โ โโโ types.ts # TypeScript types for MAX API
โ โโโ tools/
โ โโโ bot.ts # get_bot_info
โ โโโ chats.ts # get_chats, get_chat, edit_chat, send_action
โ โโโ messages.ts # send/get/edit/delete/pin/unpin, send_media
โ โโโ members.ts # get_chat_members, get_admins, set/remove_admin, add/remove_members
โ โโโ updates.ts # get_updates, answer_callback
โโโ transports/ # Transport layer โ selected at runtime
โ โโโ stdio.ts # Local mode (Claude Desktop, Cursor)
โ โโโ http.ts # Remote mode (Streamable HTTP)
โโโ index.ts # Entry point: transport selection
MAX API Notes
- Authorization: Token passed as
Authorization: <token>โ noBearerprefix - Base URL:
https://platform-api.max.ru - Rate limit: 30 requests/second
- Group chats:
GET /chatsreturns group chats only - Personal dialogs: Accessible via
get_updatesโ use the returnedchat_idwith all standard tools - Media upload: Two-step process (upload โ send). Audio/video tokens come from the upload step, not the file transfer
- HTTP transport: Uses Streamable HTTP (SSE deprecated since MCP SDK 1.10.0)
Known MAX API Issues
remove_adminmay returnsuccess: truewithout actually revoking rights โ confirmed bug on MAX sideopen_appbutton type returns "Field 'webApp' cannot be null" โ MAX API bugadd_membersmay fail withadd.participant.privacyif the user has privacy mode enabled
Roadmap
- HTTP mode testing on VPS with n8n integration
- Hosted MCP service (connect by URL, no local install)
- Webhook support for real-time event handling
-
answer_callbacktesting via n8n webhook workflow
Links
Author & Support
Built by Oleg Alekseev โ ERP/AI integration architect.
- ๐ง [email protected] ยท [email protected]
- ๐ฌ Telegram: @ale_oleg ยท Channel: @woyax_ai
- ๐ฌ MAX: max.ru/id503610654564_biz
Need help integrating AI agents with your ERP, CRM, or MAX? Custom MCP servers, n8n workflows, AI automation โ contact me.
License
MIT + Commons Clause ยฉ Oleg Alekseev
Free to use for personal and corporate purposes. Selling as a hosted service requires author's permission. See LICENSE for details.
Server Terkait
Damien Email Wrestler
An AI-powered email intelligence platform that integrates with Gmail and OpenAI. It can be run as a CLI tool or deployed on AWS Lambda for enhanced capabilities.
API Docs MCP
MCP server for API documentation, supporting GraphQL, OpenAPI/Swagger, and gRPC from local files or remote URLs
Reddit
Interact with Reddit by posting comments and searching for posts.
Webhooks MCP
Send HTTP requests to webhooks with dynamic parameters.
MCP Server Whisper
Advanced audio transcription and processing using OpenAI's Whisper and GPT-4o models.
LLM Chat Assistant
A chat assistant that integrates an MCP client with an LLM and other external MCP servers.
shippost-mcp
Twitter/X tools for AI agents โ read timelines, post tweets, search, and engage
ClickSend MCP Server
Send SMS messages and make Text-to-Speech (TTS) calls using the ClickSend API.
VirtualSMS
SMS verification with real physical SIM phone numbers across 145+ countries and 2000+ services for AI agents.
MCP LinkedIn
Interact with LinkedIn using an unofficial API, requiring email and password for authentication.