name: mm-init-project version: 0.5.2 description: Инициализирует или обновляет проект для mm-системы — создаёт passport.md в корне, копию в Obsidian, dashboard.md, handoff.md (скелет), project-instructions.md для claude.ai. Use when user says "оформи проект", "сделай паспорт", "init project", "/mm-init", "/mm-init-project", "обнови паспорт", "регистрирую проект". Работает на пустой папке (новый проект) и на существующем коде с любыми .md файлами (auto-discovery + dry-run preview перед записью). Включает auto-detect стека (~150 фреймворков), dual-detection GSD v1 (.planning/) и v2 (.gsd/), import scope/requirements из GSD-артефактов, secret-grep, детектор рассинхрона между копиями паспорта.
mm-init-project — Project Bootstrap & Refresh (safe edition)
Создаёт «паспорт» проекта — единый источник контекста для claude.ai Project Knowledge и для всех mm-* skills. Всегда показывает план перед записью, никогда не уничтожает чужие .md файлы.
Контракт безопасности (это важно — соблюдай дословно)
Skill ПИШЕТ только в эти файлы:
<project_root>/passport.md— создаёт или обновляет<project_root>/CLAUDE.md— только добавляет секции## Obsidian Knowledge Vaultи## mm-systemесли их нет; никогда не редактирует существующие секции<project_root>/.gitignore— добавляет правила для игнорирования локальных настроек Obsidian (.vault/.obsidian/)- Файлы Obsidian Vault (хранилище в
<project_root>/.vault/при локальном режиме или<obsidian_projects>/<name>/при глобальном режиме):00-home/index.md— карта всех заметок00-home/текущие приоритеты.md— текущие приоритеты00-home/project-instructions.md— инструкции для claude.aihandoff.md— создаёт скелет на старте (в корне хранилища)atlas/passport.md— копия паспорта проектаatlas/архитектура проекта.md— описание архитектурыatlas/база данных.md— схема БДatlas/деплой.md— информация о деплое- Создает папки
knowledge/integrations/,knowledge/decisions/,knowledge/debugging/,knowledge/patterns/,knowledge/business/,sessions/,inbox/if they don't exist.
Skill ТОЛЬКО ЧИТАЕТ (никогда не редактирует):
- README.md, ARCHITECTURE.md, NOTES.md, OVERVIEW.md, CONTEXT.md, DESIGN.md, ROADMAP.md, TODO.md, BUGS.md, DECISIONS.md, и любые другие *.md в проекте
- package.json, pyproject.toml, requirements.txt, go.mod, Cargo.toml, pom.xml
- .env.example (не .env!)
- Dockerfile, docker-compose.yml, railway.json, vercel.json
- .git/config, git log, git status
Skill НЕ ТРОГАЕТ ВООБЩЕ:
.env,*.key,*.pem,secrets/— даже не читает значения- node_modules/, .venv/, dist/, build/, target/
- Файлы вне
<project_root>за исключением Obsidian-папки из конфига
Перед любой записью — обязательная фаза Preview (см. ниже). Без подтверждения y — ничего не пишется.
Конфиг
Загрузи mm-config.json по алгоритму из <repo>/docs/CONFIG-LOADING.md. Поддержка mm-config.local.json overlay обязательна. <repo> берётся из _repo_root инжектированного loader'ом.
Понадобятся:
paths.obsidian_projects_repo_root(дляtemplates/passport.mdиtemplates/project-instructions.md)bot_defaults.*default_language
Фаза 0. Определи целевую папку (worktree-aware)
Целевая папка = «корень проекта», не «cwd как есть».
Алгоритм:
- Возьми
cwd. - Если в пути есть подстрока
\.claude\worktrees\или/.claude/worktrees/— это worktree. Найди корневой репо:- Прочитай
<cwd>/.git(это файл-указатель, не папка). Извлекиgitdir: <path>. Из него выведи main repo path. - Если не получилось — спроси:
Это git worktree. Какую папку считать корнем проекта? <предложи: ...>.
- Прочитай
- Иначе — поднимись от
cwdпока не найдёшь.git/(папку, не файл) илиpackage.json/pyproject.toml/ любой явный маркер корня. Если ничего нет —cwdи есть корень.
Имя проекта = basename целевой папки. Покажи: Имя проекта: <name> (целевая папка: <path>). Ок? (y/n или новое имя).
Фаза 1. Discovery (что уже есть в проекте)
Просканируй и выведи отчёт пользователю перед любыми действиями.
1a. Существующие паспорта (миграция)
Поищи (case-insensitive) в <project_root> и <project_root>/docs/:
passport.md,PASSPORT.md,Passport.md,passport.MD— варианты casePROJECT_PASSPORT.md,project_passport.md— старая louise-система (Claude Setup/)*_passport.md,passport_*.md
Любой найденный — кандидат на миграцию, не конфликт-блокер.
1b. Документы которые могут содержать контекст
Просканируй *.md в:
<project_root>/(корень)<project_root>/docs/,<project_root>/notes/,<project_root>/_docs/<project_root>/.planning/(GSD-документы)
Распознай семантически по имени (case-insensitive substring):
| В имени есть | Категория |
|---|---|
readme |
Описание / overview |
architecture, design, arch |
Архитектура |
overview, context, intro |
Контекст |
notes, ideas |
Заметки |
decisions, adr, rfc |
Решения |
roadmap, plan |
Планы |
todo, tasks, backlog |
Задачи |
bugs, issues, known-issues |
Проблемы |
changelog, history |
История |
claude (CLAUDE.md, claude-rules.md) |
Правила для AI |
Прочитай первые 50 строк каждого найденного файла — для понимания.
1c. Маркеры стека (auto-detection)
Manifest-файлы — прочитай если есть:
package.json,pyproject.toml,requirements.txt,go.mod,Cargo.toml,pom.xml,composer.json,Gemfile,mix.exs,pubspec.yamlDockerfile,docker-compose.yml,railway.json,vercel.json,fly.toml,Procfile.env.example,.env.template(не.env!)tsconfig.json,next.config.*,vite.config.*,astro.config.*,nuxt.config.*,svelte.config.*,remix.config.*.python-version,.nvmrc,.tool-versions,runtime.txt
Auto-detection: пакет → стек (по подстроке в зависимостях):
| Если в зависимостях | Тип | Фреймворк | Категория |
|---|---|---|---|
aiogram, python-telegram-bot, telethon, pyrogram, telegraf, grammy |
bot | по имени | tg-bot |
discord.py, discord.js, discordeno |
bot | по имени | discord-bot |
fastapi, flask, django, starlette, litestar, quart, sanic, bottle, pyramid |
web | по имени | python-web |
express, koa, hapi, fastify, nest, polka, hono, elysia |
web | по имени | node-web |
next, nuxt, astro, remix, sveltekit, gatsby, solid-start, qwik |
web | по имени | meta-framework |
react, vue, svelte, solid-js, preact, lit, htmx |
web | по имени | spa-frontend |
gin, echo, fiber, chi, gorilla/mux, huma |
web | по имени | go-web |
actix-web, axum, rocket, warp, tide, salvo |
web | по имени | rust-web |
rails, sinatra, hanami, roda |
web | по имени | ruby-web |
phoenix, plug |
web | по имени | elixir-web |
laravel, symfony, slim |
web | по имени | php-web |
sqlalchemy, sqlmodel, alembic, tortoise-orm, peewee, pydantic |
— | — | python-db |
prisma, drizzle, kysely, typeorm, sequelize, mongoose, mikro-orm |
— | — | node-db |
gorm, ent, sqlx, bun, pgx |
— | — | go-db |
diesel, sea-orm, sqlx (rust) |
— | — | rust-db |
pytest, unittest, nose2, tox |
— | тесты Python | testing |
vitest, jest, mocha, playwright, cypress, ava, tap |
— | тесты JS | testing |
cargo test (default), nextest |
— | тесты Rust | testing |
loguru, structlog, winston, pino, zap, tracing, slog |
— | логирование | observability |
pydantic, zod, joi, yup, ajv, valibot, arktype |
— | валидация | validation |
openai, anthropic, litellm, langchain, llama-index, instructor |
— | — | ai-llm |
huggingface, transformers, torch, tensorflow, jax, keras |
— | — | ai-ml |
pandas, polars, numpy, scipy, dask |
— | — | data |
dlt, airflow, prefect, dagster, kafka-python, aiokafka |
— | — | pipelines |
redis, aioredis, kombu, celery, rq, bullmq |
— | — | queue/cache |
scrapy, playwright, puppeteer, selenium, httpx, aiohttp |
— | — | scraping/http |
tauri, electron, wails |
— | — | desktop |
Файловые маркеры (если manifest неоднозначен):
*.tsx/*.jsx→ React*.vue→ Vue*.svelte→ Svelte*.astro→ Astroapp/page.tsx→ Next.js App Routerpages/*.tsx→ Next.js Pages Routerwrangler.toml→ Cloudflare Workersserverless.yml→ Serverless Frameworkterraform/,*.tf→ Terraformhelm/,Chart.yaml→ Kubernetes Helm
Combo-recognition (комплекты):
- React + TypeScript + Tailwind + shadcn → пометить «modern react stack»
- FastAPI + Pydantic + sqlmodel + pytest → пометить «modern python web»
- aiogram + sqlmodel + loguru → пометить «default bot stack» (из bot_defaults конфига)
- Наличие
telethonв зависимостях → установить внутренний флагtelethon_project: true - Наличие фреймворков категории
tg-bot(aiogram,python-telegram-bot,telegraf,grammyи др.) в зависимостях → установить внутренний флагtg_bot_project: true
Приоритет определения типа (когда несколько матчей):
- tg-bot / discord-bot (если есть бот-фреймворк) —
bot - meta-framework (Next/Nuxt/Astro/Remix) —
web - python-web / node-web / go-web / rust-web —
web - spa-frontend без backend —
web(frontend-only) - ai-ml / ai-llm + entry point —
scriptилиservice - data / pipelines —
script - desktop —
desktop - lib (если в
pyproject.toml[project]без entry point ИЛИ вpackage.jsonmainбезbin) —lib - иначе —
script
Версии:
- Питон: из
.python-versionилиpyproject.tomlrequires-python - Node: из
.nvmrc,engines.nodeв package.json - Go: из
go.modстрокаgo X.Y - Rust: из
rust-toolchain.tomlили edition вCargo.toml
1d. Git-контекст
git rev-parse --show-toplevel
git remote -v
git branch --show-current
git log --oneline -10
1e. Системы которые могут конфликтовать (dual-detection GSD)
GSD detection (определи версию):
<project_root>/.planning/существует:- Если
<project_root>/.planning/config.jsonсуществует → GSD Core. В passport frontmattergsd_version: core. - Иначе → GSD v1. В passport frontmatter
gsd_version: v1.
- Если
<project_root>/.gsd/существует → GSD v2. В passport frontmattergsd_version: v2.- Оба → смешанный (редкость, после миграции). Спроси: какой считать активным?
- Ни одного →
gsd_version: none.
Если GSD есть — попробуй импортировать scope/requirements (чтобы не дублировать):
GSD v1 (.planning/):
PROJECT.md→ vision, audience, goals → секция 1 (Назначение) + секция 3 (Архитектура краткая)REQUIREMENTS.md→ REQ-001..N → можно вытащить топ-5 в секцию 4 как «функциональные требования» (опционально)ROADMAP.md→ phases, статусы → секция 9 паспорта строкаТекущий milestone / phase: <M1 / phase 03 — <title>>STATE.md→ current phase / position → секция 10 «В работе сейчас»codebase/STACK.md,codebase/ARCHITECTURE.md,codebase/CONVENTIONS.md,codebase/CONCERNS.md→ если есть, переносим в секции 2, 3, 7, 10 паспорта (НЕ дублируя — кратко + ссылкасм. .planning/codebase/STACK.md)
GSD v2 (.gsd/):
gsd.db(SQLite) → если можешь прочитать через sqlite3 CLI/Python — извлеки текущий milestone/slice/task; иначе пропустиSTATE.md(rendered dashboard) → парсинг как у v1AGENTS.md→ preferences для агентов → ссылка в секции 7 паспорта
Важное правило про дубликацию:
- Если в
.planning/PROJECT.mdуже есть подробное описание проекта — в секции 1 паспорта пиши краткое summary + ссылку (см. .planning/PROJECT.md), не копируй целиком. - В секции 9 явно укажи source-of-truth:
Source-of-truth для scope/requirements: .planning/PROJECT.md. Это нужно чтобы будущий читатель не запутался какой документ актуальный.
Никогда не пиши в .planning/* или .gsd/* напрямую — там file-lock'и, hook'и-охранники GSD. Только читать.
CLAUDE.md → читай, оценивай размер: маленький (< 30 строк) — добавим секцию; большой — спросим перед добавлением.
passport.md (точное совпадение) → режим update, см. фазу 3.
1f. Sync-check между копиями паспорта
Если есть и <project_root>/passport.md И <obsidian>/Projects/<name>/passport.md:
- Сравни sha256 содержимого (или хотя бы mtime + size).
- Если расходятся — это значит юзер редактировал одну из копий (например в Obsidian app). Покажи в Discovery:
⚠️ Рассинхрон: passport.md в проекте и в Obsidian отличаются. Проект: updated <date>, sha <hex8> Obsidian: updated <date>, sha <hex8> Какую версию считать source-of-truth? [1] Проект (Obsidian перезапишется) — дефолт [2] Obsidian (проект перезапишется) [3] Show diff first [4] Cancel - Запомни выбор для фазы 4 (write).
1g. Вывод фазы Discovery (покажи пользователю)
🔍 Discovery: <project_name>
Целевая папка: <abs_path>
Git: <branch>, <N> коммитов, remote: <url или local>
Найдено существующих паспортов:
• PROJECT_PASSPORT.md ← старая louise-система, можно мигрировать
• passport.md ← текущий формат, режим update
(или: «не найдено»)
Найдено документов с контекстом:
• README.md (описание)
• docs/architecture.md (архитектура)
• NOTES.md (заметки)
(используются ТОЛЬКО для чтения — не будут изменены)
GSD detection:
• Версия: <none | v1 (.planning/) | v2 (.gsd/) | core (.planning/ config.json)>
• PROJECT.md: <есть, 240 строк — могу импортировать vision и audience в секции 1, 3>
• REQUIREMENTS.md: <есть, REQ-001..REQ-014 — топ-5 в секцию 4?>
• Текущий milestone: <M1 «MVP», phase 03/07 «add /stats command» (in-progress)>
• codebase/: <STACK.md, ARCHITECTURE.md, CONVENTIONS.md — могу подсосать в секции 2, 3, 7>
Стек определён (auto-detection):
• Язык: Python 3.12 (из .python-version)
• Фреймворк: aiogram 3.x (из pyproject.toml)
• DB: SQLite через sqlmodel
• Тесты: pytest
• Логирование: loguru
• Тип: bot (combo: «default bot stack»)
Существующий CLAUDE.md: <нет / <N> строк, добавлю секцию mm-system / большой — спрошу>
Фаза 2. Решения (если нужны)
Задай только реально неопределённые вопросы (максимум 3-4):
Расположение Obsidian Vault (КРИТИЧНО): Спроси пользователя, где хранить базу знаний (Obsidian Vault):
Выберите расположение Obsidian Vault для проекта: [1] Локально в папке проекта (рекомендуется: <project_root>/.vault/, версионируется в git, синхронизируется с claude.ai автоматически) — дефолт [2] Глобально в папке Obsidian (из конфига: <obsidian_projects>/<name>/)Если найден PROJECT_PASSPORT.md или другой кандидат миграции:
Найден старый паспорт <file>. Мигрировать его контент в новый passport.md? (y = мигрировать, переименую старый в .legacy / n = игнорировать)Если есть passport.md И он явно устарел (mtime старше 30 дней или git log показывает много коммитов после updated): Просто переходи в режим update без вопроса.
Если CLAUDE.md > 30 строк:
CLAUDE.md существует и непустой (<N> строк). Добавить правила базы знаний в конец? (y/n)Если папка пустая (новый проект):
- Тип: bot / web / lib / script?
- Язык / фреймворк? (для bot — дефолт
aiogramиз bot_defaults) - Назначение в одном предложении?
Если в выбранной директории Vault уже есть файлы:
В директории базы знаний уже есть файлы. Update (y) / Создать папку с суффиксом -2 (n) / Отмена (c)?Если есть GSD (
.planning/PROJECT.mdили.gsd/) и режим init:Найден <PROJECT.md / .gsd/>. Импортировать описание/scope в секции 1, 3 паспорта (y) / только сослаться, не дублировать (n) / отмена (c)? Дефолт n — паспорт ссылается, не дублирует.
Если пользователь говорит «решай сам» — выбирай разумный дефолт, отмечай в финальном отчёте <assumed: ...>.
Фаза 3. План записи (Preview / Dry-run)
Это обязательная фаза. Без подтверждения — НИЧЕГО не пишется.
Покажи пользователю полный план в формате:
📋 План записи
Расположение Obsidian Vault: <локальное (.vault/) | глобальное (<path>)>
СОЗДАМ:
+ <project>/passport.md (новый файл, <N> секций)
Источники: README.md, package.json, etc.
+ <vault_root>/00-home/index.md (карта всех заметок)
+ <vault_root>/00-home/текущие приоритеты.md (активные приоритеты)
+ <vault_root>/00-home/project-instructions.md (инструкции для claude.ai)
+ <vault_root>/handoff.md (скелет)
+ <vault_root>/atlas/passport.md (копия паспорта)
+ <vault_root>/atlas/архитектура проекта.md (архитектура)
+ <vault_root>/atlas/база данных.md (схемы БД)
+ <vault_root>/atlas/деплой.md (информация о деплое)
+ <vault_root>/knowledge/integrations/ (папка)
+ <vault_root>/knowledge/decisions/ (папка)
+ <vault_root>/knowledge/debugging/ (папка)
+ <vault_root>/knowledge/patterns/ (папка)
+ <vault_root>/knowledge/business/ (папка)
+ <vault_root>/sessions/ (папка для логов сессий)
+ <vault_root>/inbox/ (папка для входящего)
ИЗМЕНЮ:
~ <project>/CLAUDE.md (добавлю правила Obsidian Knowledge Vault, +18 строк)
<если локальный режим:>
~ <project>/.gitignore (добавлю .vault/.obsidian/ в конец, +2 строки)
ПЕРЕИМЕНУЮ:
→ PROJECT_PASSPORT.md → PROJECT_PASSPORT.md.legacy
НЕ ТРОНУ:
README.md, .planning/*, .env, src/
Continue? (y / n / edit)
edit → дай возможность изменить план: «Не переименовывай PROJECT_PASSPORT» / «Не трогай CLAUDE.md» / «Не создавай dashboard» — пользователь редактирует список через простой dialog, ты применяешь.
n → останови, ничего не пиши.
y → переходи к фазе 4.
Фаза 4. Запись (atomic: всё или ничего)
Делай в этом порядке. Если хоть один шаг падает — откати уже сделанное (удали созданные файлы, восстанови переименованный):
4.1. Сгенерируй текст passport.md в памяти
Возьми шаблон <skills_repo>/templates/passport.md. Заполни:
- Секции 1-7, 9 — из discovery (стек, архитектура, команды, конвенции из README, ENV из .env.example).
- Секция 8 «Контекст для промптов»:
- Если миграция из PROJECT_PASSPORT.md и там есть аналогичный раздел — перенеси.
- Иначе:
- Если
telethon_project == true, добавь следующие жесткие правила:При написании кода для Telethon-аккаунтов строго следуй правилам из [[telethon-sessions|инструкции по сессиям Telethon]].Запрещены параллельные запуски сессий с одним файлом .session (риск AuthKeyDuplicatedError).Все параметры устройства (fingerprint) бери строго из соответствующего .json файла.Используй SOCKS5-прокси с rdns=True для всех подключений.
- Если
tg_bot_project == true, добавь следующие жесткие правила:При проектировании интерфейса бота (текст, кнопки, эмодзи) строго следуй правилам из [[tg-bot-ui-ux|руководства по UI/UX ботов Telegram]].
- Иначе оставь шаблон +
<!-- TODO: заполни секцию 8 — критично, читается каждым промптом -->.
- Если
- Секция 10 «Текущее состояние»:
- Init: пустой шаблон.
- Update (есть passport.md): сохрани существующий текст 1:1.
- Migration: если в старом паспорте была секция «Текущее состояние / Status / Now» — перенеси.
- Секция 11 «История»:
- Init: одна строка «
Initial». - Update: добавь строку «
Refresh: <что обновилось>». - Migration: «
Migrated from PROJECT_PASSPORT.md».
- Init: одна строка «
Frontmatter: created из существующего файла или сегодня; updated = сегодня; mm_version = config.version из mm-config.json (подставь значение, не оставляй плейсхолдер <MM_VERSION>); telegram_ui_ux = true (если tg_bot_project == true), иначе false.
4.2. Сгенерируй файлы Obsidian Vault в памяти
Сгенерируй структуру и контент для файлов базы знаний:
00-home/index.md: Карта всех файлов в Vault. На старте содержит ссылки на[[текущие приоритеты]],[[project-instructions]],[[handoff]],[[atlas/passport|паспорт проекта]],[[atlas/архитектура проекта]],[[atlas/база данных]],[[atlas/деплой.md]]и заглушки для подразделов вknowledge/иsessions/. Еслиtelethon_project == true, добавь также ссылку на[[knowledge/integrations/telethon-sessions|инструкцию по сессиям Telethon]]. Еслиtg_bot_project == true, добавь также ссылку на[[knowledge/patterns/tg-bot-ui-ux|инструкцию по UI/UX ботов Telegram]].00-home/текущие приоритеты.md: Содержит текущий milestone и приоритетные задачи, извлеченные из GSD или Discovery (на старте).00-home/project-instructions.md: Возьми<skills_repo>/templates/project-instructions.md, подставь<PROJECT_NAME>, замени пути к файлам на новые пути в структуре базы (например,00-home/index.mdвместоdashboard.md), добавь топ-3 пункта из секции 8 паспорта.- Если
telethon_project == true, добавь в инструкции для ИИ блок:Этот проект использует Telethon. При написании кода по работе с сессиями/аккаунтами руководствуйся правилами из [[knowledge/integrations/telethon-sessions.md]].
- Если
tg_bot_project == true, добавь в инструкции для ИИ блок:При создании диалогов, кнопок, FSM-сценариев и форматировании сообщений следуй правилам из [[knowledge/patterns/tg-bot-ui-ux.md]].
- Если
handoff.md(в корне Vault): Скелет handoff (шаблон см. в Appendix). В режиме update не трогай, если файл уже существует.atlas/passport.md: Копия сгенерированногоpassport.md.atlas/архитектура проекта.md: Содержит описание архитектуры из секции 3 паспорта.atlas/база данных.md: Содержит модели данных из секции 6 паспорта.atlas/деплой.md: Содержит инструкции и команды деплоя из секции 5/2 паспорта.knowledge/integrations/telethon-sessions.md(только еслиtelethon_project == true): скопируй содержимое из<skills_repo>/templates/telethon-sessions.md.knowledge/patterns/tg-bot-ui-ux.md(только еслиtg_bot_project == true): скопируй содержимое из<skills_repo>/templates/tg-bot-ui-ux.md.
4.3. Сгенерируй патч для CLAUDE.md (если нужен)
Если CLAUDE.md существует и в нём нет секции ## Obsidian Knowledge Vault — добавь в конец:
## Obsidian Knowledge Vault
Хранилище знаний: <vault_path>
### При старте сессии
Прочитай 00-home/index.md и текущие приоритеты.md.
Если задача касается модуля — прочитай заметку из knowledge/.
### При завершении (пользователь: "сохрани сессию")
1. Создай заметку в sessions/ с датой
2. Обнови текущие приоритеты.md
3. Если решение — создай в knowledge/decisions/
4. Если баг — создай в knowledge/debugging/
5. Обнови index.md если новые заметки
## Режимы работы (IDE vs CLI)
1. **Если ты запущен в чат-окне Antigravity IDE (Gemini)**:
- Ты выступаешь **исключительно как Планировщик и Архитектор**.
- Тебе **категорически запрещено** самостоятельно изменять файлы проекта, записывать код в файлы или запускать изменяющие состояние команды (типа `git commit`, `git push`).
- Твоя задача — использовать инструменты чтения (файлы, логи) и поиска, анализировать код, планировать изменения и генерировать готовый промпт для CLI-агента.
2. **Если ты запущен в консоли/терминале как CLI-агент (Claude Code / CLI-клиент)**:
- Ты выступаешь как **Исполнитель**.
- Ты должен автоматически вносить изменения в файлы, запускать тестов, делать коммиты и пушить изменения без подтверждений (согласно Karpathy-style discipline) на основе промптов, полученных из IDE.
## mm-system
Этот проект подключён к mm-системе.
- Паспорт: `passport.md` (актуальный source-of-truth)
- База знаний: `<vault_path>`
- Skills: глобальные `mm-*` (см. `~/.claude/skills/`)
- Конец сессии: `/mm-save-session`
- Перед новым чатом claude.ai: `/mm-handoff`
### Интеграция с Antigravity (Gemini IDE)
- Агент Antigravity поддерживает те же команды mm-системы.
- При получении команды (например `/mm resume`, `/mm save`, `/mm setup`, `где мы`, `сохрани сессию`) агент должен найти соответствующий SKILL.md по пути `~/.claude/skills/mm-<name>/SKILL.md` или в каталоге репозитория `$MM_REPO_ROOT/skills/mm-<name>/SKILL.md`, прочесть его и выполнить указанные в нем инструкции.
Где <vault_path> — это .vault/ (если выбран локальный режим) или <obsidian_projects>/<name>/ (если глобальный).
4.4. Запиши всё
В строгом порядке (с откатом при падении):
- Создай директорию Vault (
<project_root>/.vault/или глобальную) и все подпапки:00-home/,atlas/,knowledge/integrations/,knowledge/decisions/,knowledge/debugging/,knowledge/patterns/,knowledge/business/,sessions/,inbox/. - Запиши
<project>/passport.md. - Запиши файлы в Vault:
<vault>/00-home/index.md<vault>/00-home/текущие приоритеты.md<vault>/00-home/project-instructions.md<vault>/handoff.md(только если не существует)<vault>/atlas/passport.md<vault>/atlas/архитектура проекта.md<vault>/atlas/база данных.md<vault>/atlas/деплой.md<vault>/knowledge/integrations/telethon-sessions.md(только еслиtelethon_project == true)<vault>/knowledge/patterns/tg-bot-ui-ux.md(только еслиtg_bot_project == true)
- Если выбран локальный режим, открой
<project>/.gitignore, и если в нём нет строки.vault/.obsidian/— добавь в конец:# Local Obsidian UI state .vault/.obsidian/ - Если есть PROJECT_PASSPORT.md и пользователь подтвердил миграцию — переименуй в
.legacy. - Примени патч к CLAUDE.md.
При ошибке на шагах 1-6: удали созданные файлы и папки, верни переименованный паспорт.
4.5. Проверка инвариантов + secret-grep
После записи проверь:
passport.mdсодержит все 11 секций.- Frontmatter валидный (parse YAML).
- В Obsidian нет файлов с похожими именами (
passport.mdvspassport_old.md) — если есть, предупреди.
Secret-grep (критично — passport едет в claude.ai):
Прогони passport.md через regex-поиск потенциальных секретов. Паттерны — в каноне <repo>/config/secret-patterns.json (Класс A — высокоточные, Класс B — широкие/warn-only; пояснение — <repo>/docs/SECRET-PATTERNS.md). Не дублируй их здесь — source of truth именно json.
Если что-то нашёл — не молчи, не удаляй сам. Покажи:
⚠️ В passport.md найдено что выглядит как секрет:
Строка 47: TELEGRAM_TOKEN=12345...
Строка 53: api_key: sk-abc123...
passport.md загружается в claude.ai Project Knowledge → попадёт во внешний сервис.
Действия:
[1] Удалю секреты сам, оставлю плейсхолдер `<REDACTED>` — рекомендуется
[2] Покажу строки, я отредактирую вручную, перезапусти /mm-init-project
[3] Игнорировать (например это пример из docs)
Только после ответа юзера продолжай.
Фаза 5. Финальный отчёт
✅ mm-init-project завершён
Режим: <init | update | migration>
Проект: <name>
Тип: <type> | Язык: <lang> | Стек: <главное>
Записано:
✓ <project>/passport.md
✓ <vault>/00-home/index.md (карта всех заметок)
✓ <vault>/00-home/текущие приоритеты.md (активные приоритеты)
✓ <vault>/00-home/project-instructions.md (инструкции для claude.ai)
✓ <vault>/handoff.md (скелет)
✓ <vault>/atlas/passport.md (копия паспорта)
✓ <vault>/atlas/архитектура проекта.md
✓ <vault>/atlas/база данных.md
✓ <vault>/atlas/деплой.md
✓ <vault>/knowledge/integrations/telethon-sessions.md (только если `telethon_project == true`)
✓ <vault>/knowledge/patterns/tg-bot-ui-ux.md (только если `tg_bot_project == true`)
✓ <project>/CLAUDE.md (добавлены правила Obsidian Knowledge Vault)
<если локальный режим:>
✓ <project>/.gitignore (добавлен игнор .vault/.obsidian/)
Перенесено из старого паспорта (если миграция):
✓ Секция «Контекст для промптов» (5 правил)
✓ Секция «Текущее состояние» (3 пункта)
Старый файл переименован: PROJECT_PASSPORT.md.legacy
Не тронуто:
README.md, docs/, NOTES.md, .planning/, .env
Следующие шаги:
1. Открой passport.md, проверь секции 1-7 (заполнены автоматически — могут быть неточны)
2. Заполни секцию 8 «Контекст для промптов» — это критично
3. claude.ai → New Project «<name>»
4. Knowledge → загрузи passport.md и dashboard.md из Obsidian
5. Instructions → скопируй из project-instructions.md
Edge cases
- Папка пустая, но git initialized без коммитов: спрашивай как новый проект.
- Имя папки с пробелами / кириллицей: используй для отображения как есть; для slug в Obsidian (имя папки) — транслит в kebab-case.
- Несколько языков (моно-репо): тип =
multi, перечисляй через запятую. - Symlinks / junctions в проекте: не следуй по ним (Get-Item Attributes & ReparsePoint).
- Скрытые .md (
.DS_Store.mdили подобное мусорное): игнорируй файлы начинающиеся с точки (кроме.planning/). - Очень большой проект (> 1000 .md файлов): сканируй только корень + 1 уровень глубже +
docs/. Не углубляйся. - Vault недоступен (путь из конфига не существует): останови, скажи
Obsidian vault не найден: <path>. Проверь mm-config.json или создай папку. - Существующий passport.md в Obsidian отличается от проекта (рассинхрон): предупреди — какую версию считать source-of-truth? Дефолт: проектная версия выигрывает.
Что НЕ делать
- Не делать
git init,git add,git commit,git push— никаких git-операций. - Не читать значения из
.env,*.key,*.pem,secrets/. - Не редактировать README.md, ARCHITECTURE.md и любые другие .md в корне проекта (только passport.md и CLAUDE.md). Файлы внутри Obsidian-папки проекта — passport.md/dashboard.md/project-instructions.md — это разрешённый scope (см. контракт безопасности в начале skill).
- Не удалять файлы (только переименование с суффиксом
.legacyпри миграции). - Не пропускать фазу Preview — даже если кажется «и так всё ясно».
- Не задавать больше 3-4 вопросов; для остального — разумные дефолты с пометкой
<assumed: ...>.
Appendix: шаблон dashboard.md
---
project: <name>
updated: <date>
---
# <name> — Dashboard
## Сейчас
<пусто на старте — обновляется через /mm-save-session>
## Последние сессии
- <будут появляться после /mm-save-session>
## Открытые вопросы
- [ ] см. passport.md секция 10
## Ссылки
- Код: `<абсолютный путь к проекту>`
- Паспорт: [[passport]]
- Sessions: [[sessions/]]
- Handoff (для нового чата claude.ai): [[handoff]]
Appendix: шаблон handoff.md (скелет на init)
На init кладётся именно этот скелет. Полноценный handoff (15-категорийный snapshot, выжимка сессий, GSD-контекст) генерирует /mm-handoff — он вызывается автоматически из /mm-save-session и заменяет скелет при первом же сохранении сессии.
---
project: <name>
generated: <date>
covers_period: <date> — <date>
sessions_summarized: 0
---
# Handoff: <name>
> Этот файл загружается в Project Knowledge чата claude.ai вместе с passport.md.
> Обновляется автоматически при `/mm-save-session` (или вручную через `/mm-handoff` / `/mm next`).
## Сейчас в работе
<свежий проект — наполнится после первой рабочей сессии>
## Что сделано за период
Свежий проект, истории сессий ещё нет — см. [[passport]].
## Открытые вопросы
- [ ] см. [[passport]] секция 10
## Следующий логичный шаг
<определится после первой сессии>
## Где смотреть подробности
- Паспорт: [[passport]]
- Dashboard: [[dashboard]]
- Sessions: [[sessions/]]
- Код: `<абсолютный путь к проекту>`