NapCat MCP Server
NapCat MCP Server
MCP-сервер, инкапсулирующий все HTTP API NapCat, поддерживает оба режима: HTTP и WebSocket.
Основан на расширении napcat-group-info-mcp, добавлены все API для отправки сообщений, управления группами, управления друзьями, системного управления и т. д.
Функциональные особенности
📋 Получение информации о групповых чатах (только чтение)
👥 Получение информации об участниках группы (только чтение)
📁 Управление файлами группы (чтение/запись)
💬 Отправка и управление сообщениями
📢 Управление объявлениями группы
⭐ Управление важными сообщениями группы
👤 Управление друзьями/пользователями
🔧 Операции управления группой (исключение, бан, администраторы и т. д.)
🖥️ Системное управление (информация о входе, статус и т. д.)
🎨 Расширенные функции Napcat (OCR, изображения, голосовые сообщения и т. д.)
🔒 Поддержка ограничения доступа по номерам групп
🔐 Поддержка режима «только чтение»
🌐 Поддержка обоих режимов: HTTP и WebSocket
Установка
git clone https://github.com/1021143806/napcat_mcp.git
cd napcat_mcp
pip install -e .Конфигурация
Добавьте в файл конфигурации MCP-клиента:
{
"mcpServers": {
"napcat-mcp": {
"command": "python",
"args": ["path/to/run_direct.py"],
"env": {
"NAPCAT_HOST": "http://localhost:3000",
"NAPCAT_TOKEN": "your_token_here",
"ALLOWED_GROUPS": "",
"READONLY_MODE": "false"
}
}
}
}Переменные окружения
Переменная | Описание | Значение по умолчанию |
| Адрес сервера NapCat |
|
| Токен доступа NapCat | Пусто |
| Разрешенные номера групп (через запятую), пусто = все | Пусто |
| Режим «только чтение» (true/false) |
|
Режимы подключения
Автоматически выбирается на основе префикса NAPCAT_HOST:
http://илиhttps://→ режим HTTPws://илиwss://→ режим WebSocket
Функции безопасности
Ограничение доступа по номерам групп
ALLOWED_GROUPS= # 允许所有群
ALLOWED_GROUPS=628101497 # 只允许单个群
ALLOWED_GROUPS=628101497,123456789 # 允许多个群Режим «только чтение»
READONLY_MODE=true # 禁用所有写入操作Доступные инструменты (55)
Информация о групповых чатах (16)
get_group_info get_group_info_ex get_group_list get_group_honor_info get_group_at_all_remain get_group_member_list get_group_member_info get_group_root_files get_group_files_by_folder get_group_file_system_info get_group_file_url get_group_msg_history get_group_announcement_list get_essence_msg_list get_group_system_msg get_group_ignore_add_request
Отправка и управление сообщениями (8)
send_msg send_group_msg send_private_msg delete_msg get_msg get_forward_msg send_group_forward_msg mark_msg_as_read
Управление группами (13)
set_group_kick set_group_ban set_group_whole_ban set_group_admin set_group_card set_group_name set_group_leave set_group_special_title set_group_add_request upload_group_file delete_group_file send_group_notice set_essence_msg delete_essence_msg
Друзья/Пользователи (5)
get_friend_list get_stranger_info get_friend_msg_history send_like set_friend_add_request
Системное управление (6)
get_login_info get_status get_version_info get_cookies get_csrf_token get_credentials
Расширения Napcat (7)
ocr_image get_image get_record can_send_image can_send_record get_online_client set_qq_profile
Конфигурация NapCat
Убедитесь, что в конфигурации OneBot11 для NapCat включен HTTP-сервер:
{
"network": {
"httpServers": [{
"enable": true,
"name": "napcat mcp",
"host": "127.0.0.1",
"port": 3000,
"enableCors": true,
"enableWebsocket": true,
"messagePostFormat": "array",
"token": "your_token_here",
"debug": false
}]
}
}Технические детали
Основано на стандарте OneBot11
Совместимо с NapCat 4.9.91+
В режиме HTTP используется асинхронный клиент
httpxВ режиме WebSocket используется библиотека
websocketsИспользуется Pydantic для проверки параметров
Лицензия
AGPL-3.0
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/1021143806/napcat_mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server