SkillAgentSearch skills...

1c Formsserver

MCP server for 1C:Enterprise managed form generation, validation, conversion and search. Supports three formats: Configurator (logform), Managed, EDT (form:Form). 18 tools for Claude Code / AI agents.

Install / Use

/learn @Desko77/1c Formsserver

README

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:

| | Конфигуратор (logform) | Managed (managed) | EDT (edt) | |---|---|---|---| | Файл | Form.xml | Form.xml | Form.form | | Root | <Form xmlns="...xcf/logform"> | <ManagedForm xmlns="...xcf/managed"> | <form:Form xmlns:form="...dt/form"> | | Элементы | <InputField name="X" id="1"> | <InputField><Name>X</Name><Id>1</Id> | <items xsi:type="form:FormField"><name>X</name><id>1</id><type>InputField</type> | | DataPath | <DataPath>Объект.Поле</DataPath> | <DataPath>Объект.Поле</DataPath> | <dataPath xsi:type="form:DataPath"><segments>Объект.Поле</segments></dataPath> | | Типы | <v8:Type>cfg:CatalogObject.X</v8:Type> | <Type>CatalogObject.X</Type> | <valueType><types>CatalogObject.X</types></valueType> | | Companion | <ContextMenu> + <ExtendedTooltip> | нет | <contextMenu> + <extendedTooltip> | | ExtInfo | нет | нет | <extInfo xsi:type="form:InputFieldExtInfo"> |

Формат определяется автоматически по 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 файл:

| Переменная | По умолчанию | Описание | |-----------|-------------|----------| | PORT | 8011 | Порт сервера | | TRANSPORT | streamable-http | Транспорт MCP (streamable-http, sse) | | DATABASES_PATH | ./databases | Путь к базам данных поиска | | DATA_PATH | ./data | Путь к данным (схемы, промпт) | | EDT_ENABLED | false | Включить интеграцию с EDT MCP | | EDT_MCP_URL | http://localhost:9999/sse | URL EDT MCP сервера | | EDT_TIMEOUT | 10 | Таймаут запросов к 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/ -v

91 тест: валидация (logform, managed, edt), конвертация (roundtrip между всеми форматами), генерация, шаблоны, поиск, EDT интеграция.

Лицензия

MIT

View on GitHub
GitHub Stars3
CategoryDevelopment
Updated7h ago
Forks0

Languages

Python

Security Score

90/100

Audited on Mar 23, 2026

No findings