1c-formsserver
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@1c-formsservergenerate catalog element form for Номенклатура"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
1c-formsserver
MCP-сервер для генерации, валидации, конвертации и поиска управляемых форм 1С:Предприятие.
Поддерживает три формата: Конфигуратор (logform), Managed (managed) и EDT (edt).
Быстрый старт
Docker (рекомендуется)
docker compose up -dСервер доступен на http://localhost:8011/mcp.
Локально
pip install -e .
python -m mcp_formsПодключение к Claude Code
В settings.json:
{
"mcpServers": {
"1c-forms": {
"url": "http://localhost:8011/mcp"
}
}
}Форматы форм
Сервер работает с тремя форматами Form.xml / Form.form:
Конфигуратор ( | Managed ( | EDT ( | |
Файл |
|
|
|
Root |
|
|
|
Элементы |
|
|
|
DataPath |
|
|
|
Типы |
|
|
|
Companion |
| нет |
|
ExtInfo | нет | нет |
|
Формат определяется автоматически по namespace корневого элемента. Конвертация между всеми тремя форматами с сохранением семантики.
MCP-инструменты (18)
Генерация форм
generate_form_template — быстрая генерация типовой формы по шаблону. Лучший выбор для начала.
Параметры:
template: "catalog_element" | "document" | "data_processor"
object_name: имя объекта ("Номенклатура", "ЗаказКлиента")
fields: список полей (["Наименование", "Артикул"])
format: "logform" (по умолчанию) | "managed" | "edt"
Для document:
header_fields: поля шапки (["Дата", "Номер", "Контрагент"])
table_name: имя ТЧ ("Товары")
table_columns: колонки ТЧ (["Номенклатура", "Количество", "Сумма"])generate_form — генерация по произвольной JSON-спецификации. Для нестандартных форм.
Параметры:
spec: {
format: "logform" | "managed" | "edt",
object_type: "Catalog" | "Document" | "DataProcessor",
object_name: "Номенклатура",
title: "Заголовок формы",
attributes: [
{name: "Объект", type_name: "CatalogObject.Номенклатура", is_main: true, save_data: true}
],
elements: [
{name: "Поле", data_path: "Объект.Поле", field_type: "InputField"},
{name: "Группа", group_type: "UsualGroup", title: "Заголовок", direction: "Vertical",
children: [{name: "Поле2", data_path: "Объект.Поле2"}]},
{name: "Таблица", data_path: "Объект.Товары",
columns: [{name: "Номенклатура", data_path: "Объект.Товары.Номенклатура"}]}
]
}generate_form_from_metadata — автогенерация на основе метаданных из EDT. Самый быстрый способ при наличии EDT.
Параметры:
object_type: "Catalog" | "Document" | "DataProcessor"
object_name: имя объекта
format: "logform" | "managed" | "edt"
include_table_parts: true | false (включать ТЧ, по умолчанию true)list_form_templates — список доступных шаблонов с описанием параметров.
Валидация
validate_form — проверка Form.xml / Form.form на ошибки. Вызывать после каждой генерации.
Параметры:
xml_content: содержимое файла формы
Проверки:
- logform: уникальность id, companion-элементы (ContextMenu, ExtendedTooltip),
имена атрибутов, привязка DataPath → Attribute
- edt: xsi:type у items, уникальность id (раздельно для items/attributes/commands),
dataPath/segments, структура attributes
- managed: базовая проверка структурыget_form_info — быстрый обзор формы: формат, количество элементов, атрибутов, структура.
validate_form_edt — расширенная валидация: встроенные проверки + проверки EDT (если EDT доступен).
Параметры:
xml_content: содержимое формы
form_fqn: FQN формы в EDT (напр. "Catalog.Номенклатура.Form.ФормаЭлемента"), опциональноКонвертация
convert_form — конвертация между форматами.
Параметры:
xml_content: исходный XML
target_format: "logform" | "managed" | "edt"
Маршруты:
logform ↔ managed — напрямую
logform ↔ edt — напрямую
managed ↔ edt — через промежуточный logformПри конвертации:
Companion-элементы добавляются/преобразуются автоматически
DataPath конвертируется между форматами (точечная нотация ↔ segments)
Типы:
cfg:prefix добавляется/удаляется автоматическиСтруктура элементов: теги ↔ items/xsi:type
Схема и справка
get_form_prompt — полная база знаний по Form.xml: теги, атрибуты, допустимые значения. Обязательно вызвать перед первой генерацией в сессии — без этого LLM не знает допустимые теги.
get_form_schema — JSON-справочник элементов формы с описанием свойств.
get_xcore_model_info — метамодель EDT из Xcore: классы (FormField, FormGroup, Table, Button, Decoration), перечисления, свойства.
Поиск примеров
search_form_examples — поиск форм в базе знаний по тексту (FTS) или вектору (embeddings).
Параметры:
query: поисковый запрос ("форма справочника с таблицей")
object_type: фильтр по типу ("Catalog", "Document")
limit: количество результатов (по умолчанию 5)index_forms — индексация Form.xml из директории конфигурации в базу поиска.
Параметры:
directory: путь к конфигурации (напр. "/path/to/src")
pattern: глоб-паттерн (по умолчанию "**/Form.xml")get_form_example — загрузить полный XML примера по id из результатов поиска.
EDT интеграция
Требует запущенный EDT MCP сервер (EDT_ENABLED=true).
edt_status — проверить доступность EDT. Вызвать перед другими EDT-инструментами.
get_object_metadata — получить реквизиты и табличные части объекта из проекта EDT.
Параметры:
object_type: "Catalog" | "Document" | "DataProcessor" и др.
object_name: "Номенклатура"form_screenshot — PNG-скриншот формы из WYSIWYG-редактора EDT.
Параметры:
form_fqn: "Catalog.Номенклатура.Form.ФормаЭлемента"Информация
get_server_info — версия сервера, список инструментов, поддерживаемые форматы.
Типовые сценарии
Создать форму для EDT-проекта
1. get_form_prompt → загрузить базу знаний
2. generate_form_template → template="catalog_element", object_name="Товары",
fields=["Наименование","Артикул","Цена"], format="edt"
3. validate_form → проверить результат
4. Сохранить как Form.form в EDT-проектСоздать форму из метаданных EDT
1. edt_status → проверить доступность
2. get_object_metadata → object_type="Document", object_name="ЗаказКлиента"
3. generate_form_from_metadata → format="edt", include_table_parts=true
4. validate_form_edt → расширенная валидацияКонвертировать форму Конфигуратора в EDT
1. convert_form → xml_content=<Form...>, target_format="edt"
2. validate_form → проверить результат
3. Сохранить как Form.formНайти пример и создать похожую форму
1. search_form_examples → query="документ с табличной частью товары"
2. get_form_example → form_id из результатов
3. Использовать пример как образец для generate_formКонфигурация
Через переменные окружения или .env файл:
Переменная | По умолчанию | Описание |
|
| Порт сервера |
|
| Транспорт MCP (streamable-http, sse) |
|
| Путь к базам данных поиска |
|
| Путь к данным (схемы, промпт) |
|
| Включить интеграцию с EDT MCP |
|
| URL EDT MCP сервера |
|
| Таймаут запросов к EDT (сек) |
Полный список — в .env.example.
Структура проекта
src/mcp_forms/
├── server.py # FastMCP сервер (18 инструментов)
├── config.py # Конфигурация из env vars
├── edt_client.py # Клиент EDT MCP (https://github.com/DitriXNew/EDT-MCP)
├── schema/ # Парсер Xcore, Pydantic-модель, валидатор
├── forms/ # Загрузчик, генератор, конвертер, шаблоны
│ ├── loader.py # Автоопределение формата, загрузка XML
│ ├── generator.py # Генерация logform / managed / edt
│ ├── converter.py # Конвертация между форматами
│ └── templates.py # Шаблоны (catalog, document, data_processor)
├── search/ # Индексатор, эмбеддинги, FTS + vector поиск
└── tools/ # MCP-инструменты (validate, generate, convert, search, edt)Зависимости
Core: fastmcp, lxml, pydantic, python-dotenv, uvicorn
Search (опционально):
pip install -e ".[search]"Добавляет sentence-transformers для векторного поиска примеров форм.
Тесты
pip install -e ".[dev]"
pytest tests/ -v91 тест: валидация (logform, managed, edt), конвертация (roundtrip между всеми форматами), генерация, шаблоны, поиск, EDT интеграция.
Лицензия
MIT
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/Desko77/1c-formsserver'
If you have feedback or need assistance with the MCP directory API, please join our Discord server