Skip to main content

MCP proxy server for 1C:Enterprise - bridge between AI agents and 1C database

Project description

1C_MCP_SERVER_OWN

Доработка и адаптация MCP 1С под текущие задачи при работе с Агентами

Python 1C MCP License: MIT

Источник разработки: 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С"

  1. Проверьте MCP_ONEC_URL
  2. Убедитесь, что HTTP-сервис 1С опубликован
  3. Проверьте учетные данные
  4. Включите DEBUG логи: --log-level DEBUG

🔐 "OAuth2 авторизация не работает"

  1. Установите MCP_AUTH_MODE=oauth2
  2. Проверьте MCP_PUBLIC_URL
  3. Для Password Grant: проверьте креденшилы
  4. Для Authorization Code: проверьте PKCE параметры

🛠️ "MCP-клиент не видит инструменты"

  1. Проверьте конфигурацию клиента
  2. Убедитесь, что сервер запущен
  3. Проверьте логи на ошибки
  4. Для stdio: проверьте переменные окружения

📚 Документация

  • 📖 agents.md - полная техническая документация
  • ⚙️ env.example - пример конфигурации
  • 🧪 testMCP.md - результаты тестирования

🤝 Contributing

Мы приветствуем вклад в развитие проекта!

  1. 🍴 Fork репозиторий
  2. 🌿 Создайте feature branch: git checkout -b feature/amazing-feature
  3. 💾 Commit изменения: git commit -m 'Add amazing feature'
  4. 📤 Push в branch: git push origin feature/amazing-feature
  5. 🔄 Создайте Pull Request

📄 Лицензия

MIT License - свободно используйте в коммерческих и личных проектах.

📞 Контакты


Источник разработки: https://github.com/vladimir-kharin/1c_mcp

Если проект оказался полезным, поставьте звезду на GitHub!

Разработано с ❤️ для сообщества 1С разработчиков

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

iflow_mcp_1c_alexmiawat_server-1.0.1.tar.gz (26.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

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

Hashes for iflow_mcp_1c_alexmiawat_server-1.0.1.tar.gz
Algorithm Hash digest
SHA256 2007cc7ba4e3f8a277e003a867245a858596ee23a1c3ba24d4c9eb23525e8e2a
MD5 1e41264836f0cdf93b0c7bdca02b0aaa
BLAKE2b-256 8d65549bf5efddb9f38862431df7ae2c66847646b5d2ebc22af328aeadbbe9c3

See more details on using hashes here.

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

Hashes for iflow_mcp_1c_alexmiawat_server-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 01632789cfb0a15021834c06ae5cfd462e05e7457dd87d103bb2a7f958726ecd
MD5 6714d4dc66632be380b1eced9e1f8d17
BLAKE2b-256 e6b74857639f96861403d6d234208912993e4e0209c67aafeeef4cd47f4816ad

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