MCP proxy server for 1C:Enterprise - bridge between AI agents and 1C database
Project description
1C_MCP_SERVER_OWN
Доработка и адаптация MCP 1С под текущие задачи при работе с Агентами
Источник разработки: https://github.com/vladimir-kharin/1c_mcp
MCP-прокси сервер для 1С:Предприятие - мост между AI-агентами (Claude, Cursor) и вашей базой 1С. Получайте метаданные, анализируйте структуру конфигурации и генерируйте код через естественный язык!
✨ Что это такое
Представьте, что у вас есть мощный ИИ-помощник, который может "разговаривать" с вашей базой 1С. Этот прокси-сервер как переводчик: он берет запросы от ИИ на понятном ему языке (MCP-протокол) и переводит их в команды, которые понимает 1С.
Простыми словами:
- 🤖 ИИ спрашивает: "Какие справочники есть в конфигурации?"
- 🔄 Прокси переводит это в JSON-RPC запрос к 1С
- 📊 1С отвечает списком справочников
- ✅ Прокси переводит ответ обратно для ИИ
🎯 Ключевые возможности
- 🔄 Два режима работы: stdio (для локальных программ) и HTTP (для веб-приложений)
- 🔐 Безопасность: OAuth2 авторизация - каждый пользователь работает под своими учетными данными
- ⚡ Быстродействие: асинхронная обработка, поддержка множества одновременных пользователей
- 🔧 Универсальность: работает со всеми типами MCP-клиентов
- 📊 Аналитика: получение метаданных, структуры объектов, предопределенных данных
📦 Быстрый старт
⚡ Установка (2 минуты)
# 1. Клонируйте репозиторий
git clone https://github.com/your-repo/1c-mcp-server.git
cd 1c-mcp-server
# 2. Создайте виртуальное окружение
python -m venv venv
# 3. Активируйте окружение
venv\Scripts\activate # Windows
source venv/bin/activate # Linux/Mac
# 4. Установите зависимости
pip install -r requirements.txt
🚀 Первый запуск
Вариант A: Stdio режим (для локальных клиентов)
# Настройте переменные окружения
set MCP_ONEC_URL=http://localhost/base
set MCP_ONEC_USERNAME=admin
set MCP_ONEC_PASSWORD=password
# Запустите сервер
python -m src.py_server stdio
Вариант B: HTTP режим (для веб-клиентов)
# Создайте файл конфигурации
copy env.example .env
# Отредактируйте .env (минимум):
# MCP_ONEC_URL=http://localhost/base
# MCP_ONEC_USERNAME=admin
# MCP_ONEC_PASSWORD=password
# Запустите сервер
python -m src.py_server http --port 8000
✅ Проверка работы
# Проверьте здоровье сервера
curl http://localhost:8000/health
# Ожидаемый ответ:
{
"status": "healthy",
"onec_connection": "ok",
"auth": {"mode": "none"}
}
📋 API Методы
🔍 list_metadata_objects
Получить список объектов метаданных указанного типа.
{
"name": "list_metadata_objects",
"arguments": {
"metaType": "Catalogs",
"nameMask": "Номенклатура",
"maxItems": 10
}
}
Результат: Список найденных объектов с именами и описаниями.
📋 get_metadata_structure
Получить подробную структуру объекта (реквизиты, табличные части).
{
"name": "get_metadata_structure",
"arguments": {
"metaType": "Catalogs",
"name": "Номенклатура"
}
}
Результат: Полная структура объекта с типами данных.
🎯 list_predefined_data
Получить список предопределенных элементов.
{
"name": "list_predefined_data",
"arguments": {
"metaType": "Catalogs",
"name": "Номенклатура",
"predefinedMask": "Услуга"
}
}
📄 get_predefined_data
Получить детальную информацию о предопределенном элементе.
{
"name": "get_predefined_data",
"arguments": {
"metaType": "Catalogs",
"name": "Номенклатура",
"predefinedName": "Услуга"
}
}
⚙️ Конфигурация
Основные параметры
| Параметр | Описание | По умолчанию | Обязательный |
|---|---|---|---|
MCP_ONEC_URL |
URL базы 1С | - | ✅ |
MCP_ONEC_USERNAME |
Имя пользователя | - | ✅ (без OAuth2) |
MCP_ONEC_PASSWORD |
Пароль | - | ✅ (без OAuth2) |
MCP_HOST |
Хост сервера | 127.0.0.1 |
❌ |
MCP_PORT |
Порт сервера | 8000 |
❌ |
MCP_AUTH_MODE |
Режим авторизации | none |
❌ |
OAuth2 настройки
# Включить OAuth2
MCP_AUTH_MODE=oauth2
MCP_PUBLIC_URL=http://your-server:8000
# Таймауты токенов
MCP_OAUTH2_CODE_TTL=120 # authorization code (сек)
MCP_OAUTH2_ACCESS_TTL=3600 # access token (сек)
MCP_OAUTH2_REFRESH_TTL=1209600 # refresh token (14 дней)
🔧 Режимы работы
Stdio режим
- 💻 Для локальных MCP-клиентов (Claude Desktop, Cursor)
- 📡 Общение через stdin/stdout
- 🔒 Логи идут в stderr
HTTP режим
- 🌐 Для веб-приложений и множественных клиентов
- 📊 Endpoints:
/mcp/,/sse,/health,/info - 🔐 Поддержка OAuth2 авторизации
🔐 Авторизация
Без OAuth2 (по умолчанию)
Все запросы выполняются от одного пользователя из конфигурации.
С OAuth2
Каждый клиент авторизуется своими креденшилами 1С.
Поддерживаемые flows:
- 🔑 Password Grant - прямая передача username/password
- 🔄 Authorization Code + PKCE - стандартный flow с формой авторизации
🏗️ Архитектура
┌─────────────────┐
│ MCP Client │ 🤖 Claude Desktop, Cursor
│ (stdio/HTTP) │
└────────┬────────┘
│ MCP Protocol
▼
┌────────────────────┐
│ Python Proxy │ 🔄 Проксирование MCP → JSON-RPC
│ - mcp_server │
│ - http_server │
│ - stdio_server │
│ - onec_client │
└────────┬───────────┘
│ JSON-RPC over HTTP
│ 🔐 Basic Auth (username:password)
▼
┌────────────────────┐
│ 1C HTTP Service │ 📡 /hs/mcp/rpc
│ (расширение) │
└────────────────────┘
🧪 Тестирование
# Запуск автоматических тестов
python testMCP_grok_plus_2.py
# Результаты сохраняются в testMCP.md
❓ Устранение неполадок
🔌 "Не удается подключиться к 1С"
- Проверьте
MCP_ONEC_URL - Убедитесь, что HTTP-сервис 1С опубликован
- Проверьте учетные данные
- Включите DEBUG логи:
--log-level DEBUG
🔐 "OAuth2 авторизация не работает"
- Установите
MCP_AUTH_MODE=oauth2 - Проверьте
MCP_PUBLIC_URL - Для Password Grant: проверьте креденшилы
- Для Authorization Code: проверьте PKCE параметры
🛠️ "MCP-клиент не видит инструменты"
- Проверьте конфигурацию клиента
- Убедитесь, что сервер запущен
- Проверьте логи на ошибки
- Для stdio: проверьте переменные окружения
📚 Документация
- 📖 agents.md - полная техническая документация
- ⚙️ env.example - пример конфигурации
- 🧪 testMCP.md - результаты тестирования
🤝 Contributing
Мы приветствуем вклад в развитие проекта!
- 🍴 Fork репозиторий
- 🌿 Создайте feature branch:
git checkout -b feature/amazing-feature - 💾 Commit изменения:
git commit -m 'Add amazing feature' - 📤 Push в branch:
git push origin feature/amazing-feature - 🔄 Создайте Pull Request
📄 Лицензия
MIT License - свободно используйте в коммерческих и личных проектах.
📞 Контакты
- 🐛 Issues: GitHub Issues
- 💬 Discussions: GitHub Discussions
- 📧 Email: AlexMiaWat@gmail.com
Источник разработки: https://github.com/vladimir-kharin/1c_mcp
⭐ Если проект оказался полезным, поставьте звезду на GitHub!
Разработано с ❤️ для сообщества 1С разработчиков
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file iflow_mcp_1c_alexmiawat_server-1.0.1.tar.gz.
File metadata
- Download URL: iflow_mcp_1c_alexmiawat_server-1.0.1.tar.gz
- Upload date:
- Size: 26.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2007cc7ba4e3f8a277e003a867245a858596ee23a1c3ba24d4c9eb23525e8e2a
|
|
| MD5 |
1e41264836f0cdf93b0c7bdca02b0aaa
|
|
| BLAKE2b-256 |
8d65549bf5efddb9f38862431df7ae2c66847646b5d2ebc22af328aeadbbe9c3
|
File details
Details for the file iflow_mcp_1c_alexmiawat_server-1.0.1-py3-none-any.whl.
File metadata
- Download URL: iflow_mcp_1c_alexmiawat_server-1.0.1-py3-none-any.whl
- Upload date:
- Size: 33.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
01632789cfb0a15021834c06ae5cfd462e05e7457dd87d103bb2a7f958726ecd
|
|
| MD5 |
6714d4dc66632be380b1eced9e1f8d17
|
|
| BLAKE2b-256 |
e6b74857639f96861403d6d234208912993e4e0209c67aafeeef4cd47f4816ad
|