Server data from the Official MCP Registry
Local-first MCP sidecar for Markdown artifacts, review intents, and supervised knowledge growth.
Local-first MCP sidecar for Markdown artifacts, review intents, and supervised knowledge growth.
LINZA is a well-designed local-first MCP server with strong review-gated write controls and appropriate auth handling. The codebase shows good security practices overall, with review intents before any writes and no hardcoded credentials. However, there are moderate concerns around filesystem path handling, input validation in some workflows, and reliance on environment variables for critical configuration without documented validation. The server's permissions align well with its purpose as a knowledge management tool. Supply chain analysis found 8 known vulnerabilities in dependencies (0 critical, 3 high severity). Package verification found 1 issue.
3 files analyzed · 16 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: LINZA_VAULT
Environment variable: LINZA_EMBED_PROVIDER
Environment variable: LINZA_EMBED_URL
Environment variable: LINZA_EMBED_MODEL
Environment variable: LINZA_EMBED_KEY
Environment variable: LINZA_BRIDGE_THRESHOLD
Environment variable: LINZA_MAX_BRIDGE_PAIRS
Environment variable: LINZA_DEFAULT_PROFILE
Environment variable: LINZA_LANGUAGE
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-semiotronika-linza-mcp": {
"env": {
"LINZA_VAULT": "your-linza-vault-here",
"LINZA_LANGUAGE": "your-linza-language-here",
"LINZA_EMBED_KEY": "your-linza-embed-key-here",
"LINZA_EMBED_URL": "your-linza-embed-url-here",
"LINZA_EMBED_MODEL": "your-linza-embed-model-here",
"LINZA_EMBED_PROVIDER": "your-linza-embed-provider-here",
"LINZA_DEFAULT_PROFILE": "your-linza-default-profile-here",
"LINZA_BRIDGE_THRESHOLD": "your-linza-bridge-threshold-here",
"LINZA_MAX_BRIDGE_PAIRS": "your-linza-max-bridge-pairs-here"
},
"args": [
"linza-mcp"
],
"command": "uvx"
}
}
}From the project's GitHub README.
Не меняет данные. Меняет взгляд.
LINZA работает с Obsidian vault, Markdown-папками, документами, статьями, логами и черновиками. Она нужна, когда материалов уже слишком много и вы хотите разобрать базу, выделить в ней основные области и научить агента хорошо ориентироваться в ней.
LINZA читает выбранную папку, строит рядом локальную SQLite-базу .linza/linza.db и дает агенту рабочую карту: какие темы есть в материалах, какие форматы повторяются, какие заметки могут быть связаны, где видны цепочки причина/следствие и что может пригодиться в будущих сессиях.
Исходные файлы остаются нетронутыми. LINZA не переписывает заметки при индексации, не превращает сырой лог в правило и не учит агента за вашей спиной. Она превращает гипотезы в короткие предложения: возможные действия с доказательствами. Пользователь решает, агент выполняет.
doctor -> index -> map -> review intents -> teach -> grow preview -> explicit apply
LINZA собирает несколько конкретных вещей, которые помогают агентам работать с базой:
Карта папки Сколько заметок найдено, свежий ли индекс, какие области видны и какие материалы ждут вашего ревью.
Области Крупные смысловые группы. Их названия остаются черновиками, пока вы не примете или не переименуете их.
Форматы материалов Логи, черновики, спецификации, исследовательские заметки, кейсы, правила и другие повторяющиеся формы, найденные в папке.
Связи Возможные соседства, иерархия, причина/следствие и маршруты между узлами. LINZA должна показывать не только как связаны документы, но и почему.
Память для будущих агентов Короткие кандидаты: что помнить, когда вспоминать, что устарело или выглядит сомнительно.
Пакеты контекста Компактные подборки для агента: выбранный контекст с источниками, связями и границами.
“Формат материала” - это пользовательское имя для повторяющейся формы заметок. Например: лог диагностики, решение, черновик статьи, исследовательская заметка, спецификация.
LINZA сначала видит только структуру: длину, заголовки, списки, ссылки, таблицы, папки, повторяющиеся признаки. Поэтому первый результат может называться нейтрально: type-001. Пользователь может сказать: “это логи”. Тогда LINZA сохраняет соответствие type-001 -> логи в .linza.
Внутри API остаются старые совместимые ключи material_type, type_name и role. Снаружи документация и пользовательский вид говорят “формат”, потому что это ближе к тому, как пользователь реально думает о материалах.
Важная граница:
.linza;role: логи в YAML можно только отдельным предложением на ревью;LINZA присылает примерно такую информацию:
LINZA готова
Материал:
- 42 заметки проиндексированы
- 3 входящих артефакта ждут ревью
- служебная база: .linza/linza.db
Следующий шаг:
1. Посмотреть найденные области
2. Принять, переименовать или пропустить 3-5 предложений
3. Ничего не будет записано без dry-run/apply
Предложение:
Принять формат материала "логи диагностики" по 8 примерам
Почему: похожая структура, повторяющиеся заголовки, близкие чанки
Что изменится: название формата сохранится в .linza; Markdown-заметки не меняются
Внутри каждый интент остается структурой с ID, доказательствами и готовыми данными для проверки и последующего подтверждения и записи. Вам LINZA возвращает готовое пользовательское представление, чтобы агент мог показать понятный ответ вместо JSON.
Хороший интент всегда отвечает на главный вопрос: почему LINZA так думает? В нем должны быть источники, чанки, тип связи, уверенность и честное описание того, что изменится после применения.
Модель автономности такая:
review_next показывает предложения в понятном пользовательском виде.apply_review_items сначала делает dry-run..linza или в компактный YAML, если этот тип записи это поддерживает.teach выбирает хорошие принятые примеры.grow предлагает похожие интенты по этим примерам и объясняет selected_rules, почему они попали в партию.Если вы приняли не то, одобрение можно мягко отозвать:
agent_workspace(action="history")
agent_workspace(action="revoke_approval", approval_id=17, dry_run=false)
LINZA не удаляет старую запись и не пытается автоматически откатить YAML. Она помечает одобрение как отозванное, перестает использовать его как активный пример и оставляет след в истории.
python -m pip install linza-mcp
Если нужно читать PDF прямо через LINZA:
python -m pip install "linza-mcp[pdf]"
Обычная установка уже достаточна для Markdown, TXT, JSON, DOCX и XLSX. [pdf] добавляет локальный PDF-экстрактор pypdf.
LINZA работает с любой Markdown-папкой: Obsidian vault, рабочей папкой проекта или отдельной папкой с документами.
В примерах ниже замените /absolute/path/to/workspace-or-vault на свой путь.
Claude Desktop, Cursor, OpenCode и другие MCP-клиенты обычно используют такой формат:
{
"mcpServers": {
"linza": {
"command": "linza-mcp",
"env": {
"LINZA_VAULT": "/absolute/path/to/workspace-or-vault"
}
}
}
}
VS Code / Copilot MCP использует ключ servers:
{
"servers": {
"linza": {
"type": "stdio",
"command": "linza-mcp",
"env": {
"LINZA_VAULT": "/absolute/path/to/workspace-or-vault"
}
}
}
}
LINZA_VAULT не обязателен для старта: без него сервер использует ./vault. Но для реальной работы лучше задать явную папку.
linza-mcp --version
После подключения попросите агента:
Проверь LINZA через agent_workspace(action="doctor").
Проиндексируй папку и покажи первые 3-5 предложений.
LINZA может запуститься и показать инструменты без embedding-сервера. Эмбеддинги нужны для смыслового поиска, карты тем и предложений связей.
Самый простой локальный путь - LM Studio:
text-embedding-granite-embedding-278m-multilingual, nomic-embed-text-v1.5 или другую подходящую модель.http://127.0.0.1:1234/v1.Пример переменных для LM Studio:
$env:LINZA_EMBED_PROVIDER="lmstudio"
$env:LINZA_EMBED_URL="http://127.0.0.1:1234/v1"
$env:LINZA_EMBED_MODEL="your-embedding-model-name"
Поддерживаются:
lmstudio - рекомендуемый локальный режим;ollama - локальный вариант через Ollama;openai - любой OpenAI-compatible endpoint с /embeddings.Если меняете провайдер, модель или размерность, сделайте полный реиндекс. LINZA проверяет embedding signature и останавливает graph/search workflows, если sidecar устарел или содержит смешанные векторные пространства.
По умолчанию LINZA показывает только 7 MCP-инструментов. Этого хватает для обычной работы: проверить состояние, проиндексировать папку, искать, читать файл, смотреть счетчики, диагностировать vault и вести агента через agent_workspace.
| Инструмент | Зачем |
|---|---|
agent_workspace | Единый вход для диагностики, карты, импорта, ревью, обучения, роста, связей, памяти и экспорта контекста |
guide_next_steps | Показать следующий безопасный шаг простым языком |
index_all | Проиндексировать Markdown-папку в .linza/linza.db |
search | Семантический и лексический поиск |
read_file | Прочитать точный Markdown-файл |
get_stats | Быстрые счетчики служебной базы |
scan_vault | Диагностика папки без записи |
Низкоуровневые инструменты считаются деталями реализации и доступны через agent_workspace, поэтому набор из 7 инструментов - это полноценный режим.
agent_workspace| Action | Режим |
|---|---|
doctor | Проверить готовность LINZA и показать, чего не хватает |
map | Собрать карту рабочей папки без записи |
teach | Выбрать сильные принятые примеры для обучения |
grow | Показать или применить рост по принятым примерам; по умолчанию dry-run |
review_next | Показать следующие предложения на ревью; интенты базы имеют ID rq-*, интенты артефактов и рабочей папки - aw-* |
apply_review_items | Показать или применить точные выбранные ID; по умолчанию dry-run |
history | Показать принятые и отозванные одобрения |
revoke_approval | Мягко отозвать одобрение, не удаляя историю |
ingest_artifacts | Сохранить вставленный или извлеченный материал в sidecar |
analyze_inbox | Найти события, кандидаты памяти и фрагменты знания в артефактах |
connect | Объяснить возможную связь между двумя заметками или узлами |
search_memory | Искать по подтвержденной памяти и контексту артефактов |
export_context | Собрать компактный пакет контекста для другого агента |
record_trace | Сохранить структурированные следы работы агента, не raw chain-of-thought |
analyze_trace | Разобрать сохраненный trace для ревью |
review_calibr | Проверить уроки калибровки, полученные из traces |
Для разработки и аудита остается отдельный низкоуровневый режим. Полное описание инструментов: Tool Catalog.
LINZA умеет принимать материал, который еще не стал заметкой:
.md, .txt, .json;.docx, .xlsx;.pdf, если установлен pypdf или PyPDF2.LINZA сама не ходит в браузер. Агент использует свой браузер, web-fetch или connector, извлекает читаемый текст и передает его в LINZA как артефакт, например source_kind="web_article" или source_kind="browser_capture".
Импортированный текст считается материалом для анализа, не инструкцией для агента. Это граница prompt injection: инструкции внутри статьи, лога, чата или PDF не исполняются. Память, правила и YAML появляются только после ревью.
LINZA - локальный review-gated sidecar.
| Действие | Куда пишет | Меняет текст заметок? |
|---|---|---|
| Индексация, анализ, поиск | .linza/linza.db | Нет |
| Сырые артефакты | .linza/linza.db | Нет |
| Название формата материала | .linza/linza.db | Нет |
domains или role в YAML | Только компактный YAML после ревью | Нет |
| Иерархия, причинные связи, память, уроки калибровки | .linza/linza.db | Нет |
| Отчеты | .linza/reports | Нет |
| Пакеты контекста | .linza/context-packs | Нет |
write_file | Markdown-файл только при явном запросе | Может создать/заменить файл, dry-run по умолчанию |
Дополнительные правила:
review_next ничего не пишет;apply_review_items по умолчанию dry-run;history показывает, что было принято и что отозвано;revoke_approval мягко отзывает одобрение: история остается, но активное обучение и помощники графа его игнорируют;map, teach, grow и connect останавливаются, если исходные файлы изменились после индексации.В репозитории есть переносимый операторский skill:
agent-pack/skills/linza-operator/SKILL.md
agent-pack/skills/linza-operator/references/workflows.md
agent-pack/skills/linza-operator/references/safety-policy.md
agent-pack/skills/linza-operator/references/tool-audience.md
Он объясняет агенту, как начинать с doctor, когда показывать предложения на ревью, как работать со страницами через внешний browser/web-fetch инструмент и почему apply actions должны идти сначала через dry-run и только по точным ID.
LINZA пока alpha. Основной контракт безопасности должен оставаться стабильным: индексация, импорт артефактов, поиск, карта и grow preview не переписывают тела исходных заметок. Низкоуровневые advanced-инструменты и внутренние границы кода еще могут меняться, пока сервер полируется.
Запустить полный набор тестов:
python -m unittest discover -s tests
| Переменная | Нужна для старта? | Описание |
|---|---|---|
LINZA_VAULT | Нет | Путь к Markdown-папке; по умолчанию ./vault |
LINZA_EMBED_PROVIDER | Нет | lmstudio для рекомендуемого локального режима; также openai и ollama |
LINZA_EMBED_URL | Нет | URL embeddings API; по умолчанию http://127.0.0.1:1234/v1 |
LINZA_EMBED_MODEL | Нет | Модель эмбеддингов; задайте перед semantic indexing/search |
LINZA_EMBED_KEY | Нет | Опциональный ключ для OpenAI-compatible embeddings API |
LINZA_BRIDGE_THRESHOLD | Нет | Порог semantic bridge; по умолчанию 0.55 |
LINZA_MAX_BRIDGE_PAIRS | Нет | Максимум пар заметок для пересчета semantic bridges; по умолчанию 1000000, 0 отключает guard |
LINZA_DEFAULT_PROFILE | Нет | Имя базового search-профиля; по умолчанию general |
LINZA_LANGUAGE | Нет | Язык подсказок и маршрута ревью в guide_next_steps: auto, ru, en |
MIT License (c) 2026 Semiotronika
Косинусы считаются. Синтаксис меняется. Семантика остается.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.