Skip to main content

MCP server that generates Russian GOST/ESKD technical documents (passport, manual, TU, mounting, form, label) in md/docx/pdf from product data

Project description

pocketcoder-gost

MCP-сервер для генерации технических документов по ГОСТ/ЕСКД. Шесть текстовых ЭД (паспорт, РЭ, ТУ, ИМ, ФО, этикетка) × три формата (md, docx, pdf) из одного product_data.

Подключается к Claude Code, Cursor или Claude Desktop по протоколу MCP. LLM-инференс — на стороне твоего агента, сервер делает «руки»: знает структуру ГОСТов, штамп ЕСКД, нумерацию, склонения, и собирает финальные файлы под нормоконтроль.

Зачем

Конструктор пишет ТУ или паспорт неделю — copy-paste из соседнего изделия, ручная сверка с ГОСТом, правка нумерации. С pocketcoder-gost весь скелет ЕСКД-документа собирается за секунды из одной структуры product_data, а агент дописывает только техническую конкретику.

Установка

pip install pocketcoder-gost

Опциональные toolchains для рендера в docx/pdf:

Формат Что нужно Установка
md ничего сверх пакета
docx pandoc brew install pandoc  |  apt install pandoc
pdf xelatex + класс eskdx brew install --cask mactex-no-gui  |  apt install texlive-xetex texlive-lang-cyrillic && tlmgr install eskdx

Если toolchain отсутствует — generate_document вернёт {error, hint} с per-OS подсказкой, не упадёт.

Подключение к MCP-клиенту

Добавь в конфиг клиента:

Claude Desktop~/Library/Application Support/Claude/claude_desktop_config.json (macOS) / %APPDATA%\Claude\claude_desktop_config.json (Windows):

{
  "mcpServers": {
    "pocketcoder-gost": {
      "command": "pocketcoder-gost",
      "args": ["mcp"]
    }
  }
}

Cursor~/.cursor/mcp.json (или .cursor/mcp.json в проекте):

{
  "mcpServers": {
    "pocketcoder-gost": {
      "command": "pocketcoder-gost",
      "args": ["mcp"]
    }
  }
}

Claude Code.mcp.json в корне проекта или ~/.claude.json:

{
  "mcpServers": {
    "pocketcoder-gost": {
      "command": "pocketcoder-gost",
      "args": ["mcp"]
    }
  }
}

После перезапуска клиента в чате доступны 5 tools (list_standards, get_standard_section, get_document_structure, generate_document, validate_normcontrol).

Доступные tools

Tool Назначение
list_standards() Список ГОСТов, входящих в MVP
get_standard_section(standard_id, section) Текст конкретного раздела ГОСТ. section = номер (4.2), toc, meta
get_document_structure(doc_type) Скелет разделов: passport | manual | tu | mounting | form | label
generate_document(doc_type, product_data, format, output_path?) Рендер документа. format = md | docx | pdf. Возвращает путь или {error, hint}
validate_normcontrol(text, standards) Заглушка под валидатор нормоконтроля (полноценный — в v0.2)

Пример: попросить агента сгенерировать паспорт

В чате клиента:

Сделай паспорт на изделие «Блок управления БУС-12», обозначение ЭПТ.421457.001 ПС, разработчик — ООО «Эпотос», в формате PDF.

Агент составит product_data (универсальная модель ProductBase + открытая таблица ТТХ через parameters[]), вызовет generate_document и сохранит passport.pdf в указанный каталог.

Что внутри

pocketcoder_gost/
├── models/           ProductBase, Person, Parameter (pydantic v2)
├── templates/        15 .j2 шаблонов: 6 doc-types × {md,tex} + штамп ЕСКД + таблица ТТХ
├── generators/       md + docx (pandoc) + pdf (xelatex) пайплайны
├── parsers/          парсеры ГОСТ-разделов
├── loaders/          загрузчики product_data
├── standards/        мета-данные стандартов
└── mcp/              FastMCP-сервер, 5 tools

Стандарты, по которым штампует:

  • ГОСТ 2.114-2016 (ТУ)
  • ГОСТ 2.610-2019 (паспорт, РЭ, ИМ, ФО, этикетка)
  • ГОСТ 2.104-2006 (штамп ЕСКД)
  • ГОСТ 2.601-2019 (ЭД на изделие)
  • ГОСТ 15150-69 (условия хранения)
  • ГОСТ 14254-2015 / IEC 60529 (степень защиты IP)
  • ГОСТ 8.417-2002 (единицы величин)

Открытая таблица ТТХ

ProductBase содержит универсальные поля (наименование, обозначение, питание, габариты и т.д.). Доменно-специфичные ТТХ (масса ОТВ, класс пожара, цвет огнетушащего вещества — что угодно) передаются через массив parameters[] с опциональными группами и сносками. Шаблоны автоматически рендерят группированную или плоскую таблицу.

{
  "parameters": [
    {"name": "Огнетушащее вещество", "value": "Аэрозоль", "group": "ТТХ"},
    {"name": "Масса заряда ОТВ", "value": "1,2 кг", "group": "ТТХ"},
    {"name": "Время работы", "value": "8 с", "group": "Эксплуатация", "note": "1"}
  ]
}

Разработка

git clone https://github.com/pocketcoder-ch/pocketcoder-gost.git
cd pocketcoder-gost
uv sync
pytest                       # 125 unit + e2e тестов
python tools/mcp_smoke.py    # 24 live MCP-вызова

Лицензия

MIT. Автор и единственный мейнтейнер — Dmitrii Chashchin (cdv.inbox@gmail.com).

Roadmap

  • v0.1 — MCP + 6 ЕСКД-шаблонов в md/docx/pdf, открытая таблица ТТХ ← текущий
  • v0.2 — валидатор нормоконтроля (ЕСПД 1986, коды 01–47): ёлочки, тире, единицы СИ, мёртвые ссылки на пункты/таблицы, обязательные разделы
  • v0.3+ — облако pocketcoder.tech: HTTP-backend через POCKETCODER_API_KEY, биллинг, коммерческие шаблоны (КП, ТКП, договор)

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

pocketcoder_gost-0.1.1.tar.gz (121.4 kB view details)

Uploaded Source

Built Distribution

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

pocketcoder_gost-0.1.1-py3-none-any.whl (151.3 kB view details)

Uploaded Python 3

File details

Details for the file pocketcoder_gost-0.1.1.tar.gz.

File metadata

  • Download URL: pocketcoder_gost-0.1.1.tar.gz
  • Upload date:
  • Size: 121.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.2

File hashes

Hashes for pocketcoder_gost-0.1.1.tar.gz
Algorithm Hash digest
SHA256 4101fb20a3036993fffa802af345f436f89e29635af695958b31061db71407d1
MD5 184ce1bd1567ebfc26629eb2dc5b6b9a
BLAKE2b-256 6c263152b38f33f701f5d68395e8af4bf950f9182778a2c59f6106618d94030d

See more details on using hashes here.

File details

Details for the file pocketcoder_gost-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pocketcoder_gost-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c7f1cd5d961879ae3d10fdac12426a27d3e8be77410f674c9e4ea7c9ded3f083
MD5 d651754f116ac532395d33c221a74da9
BLAKE2b-256 943d26beb5c9ea6b7d7bde8bbea5668841f5bd233b7f9ad2f312168415694627

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