Локальная разработка — Development Setup

Требования

Инструмент Версия Назначение
Bun 1.x+ Backend runtime (Master Bot, Child Bot, MCP)
Node.js 22+ Frontend build (npm)
Docker Latest Опционально — для контейнеризации
Git Latest Репозиторий

Быстрый старт

git clone [email protected]:SerhiiInUa/citadel-v2.git
cd citadel-v2
cp .env.example .env
# Редагуй .env — додай токени ботів

# One-time: активувати pre-push doc-coverage hook (Phase 49.1)
bash scripts/setup-hooks.sh

Зачем hook: блокирует git push, если ты изменяешь код без обновления docs. Bypass: git push --no-verify. Детали — секция "Documentation Law" в CLAUDE.md.

Frontend

cd frontend
npm install
npm run dev          # → http://localhost:5173

Vite автоматически проксирует:

Команды сборки

Backend

Master Bot (CRM API)

cd master-bot
bun install
bun run bot.ts       # → http://localhost:19210

Это главный API-сервер с 68+ endpoints. Нужен MASTER_BOT_TOKEN в .env.

Child Bot (AI Proxy)

cd child-bot
bun install
bun run bot.ts       # → http://localhost:19211

Per-project Telegram ↔ Claude CLI прокси. Нужен CITADEL_BOT_TOKEN в .env.

MCP State Bridge

cd mcp-server
bun install
bun run server.ts    # → http://localhost:19200

Стейт-менеджер, SSE, WebSocket.

Порты

Порт Сервис Описание
5173 Vite Dev Server Frontend + API proxy
19200 MCP State Bridge State, SSE, WebSocket
19210 Master Bot CRM API (68+ endpoints)
19211 Child Bot Health check
18888 Nginx (VPS) Production only
18889 Nginx (Docker) Docker frontend

Переменные окружения (.env)

Обязательные

MASTER_BOT_TOKEN=...           # Telegram @BotFather
CRM_ALLOWED_ORIGINS=http://localhost:5173

Для полного функционала

CITADEL_BOT_TOKEN=...          # Child bot token
GITHUB_CLIENT_ID=...           # GitHub OAuth
GITHUB_CLIENT_SECRET=...
GOOGLE_CLIENT_ID=...           # Google OAuth
GOOGLE_CLIENT_SECRET=...

Опциональные

HEALTH_PORT=19210
CITADEL_DIR=/path/to/citadel-v2
EMAIL_PROVIDER=console          # 'console' для dev (печатает в терминал)
[email protected]

Docker (опционально)

# Полный стек
docker compose -f docker/docker-compose.yml up -d --build

# Только frontend
docker compose -f docker/docker-compose.yml up -d frontend

Структура проекта

citadel-v2/
├── master-bot/          # Telegram оркестратор + CRM API (:19210)
├── child-bot/           # Per-project AI proxy (:19211)
├── mcp-server/          # State bridge (:19200)
├── shared/              # Спільний код (db, auth, routes, migrations)
├── frontend/            # React CRM + Phaser (Vite)
├── clients/             # ARC CLI
├── services/            # NotebookLM Bridge (Python)
├── config/              # Registry, vault, workers
├── skills/              # Skill definitions + evals
├── docker/              # Compose + Dockerfiles + Nginx
├── infra/nginx/         # VPS Nginx config
├── scripts/             # Deploy, build scripts
├── docs/                # Documentation
└── data/                # SQLite DB (auto-created)

Типичный workflow разработки

  1. Запусти frontend: cd frontend && npm run dev
  2. Запусти Master Bot: cd master-bot && bun run bot.ts
  3. Открой http://localhost:5173
  4. Зарегистрируйся через email (email_provider=console → код в терминале)
  5. Создай проект через UI
  6. Работай с воркерами через Workspace

Быстрая проверка типов

cd master-bot && bun build --no-bundle bot.ts    # Type-check backend
cd frontend && npx vite build                     # Type-check + build frontend

Troubleshooting

Проблема Решение
Port already in use lsof -i :19210kill <PID>
CORS ошибка Проверь CRM_ALLOWED_ORIGINS в .env
Frontend не видит API Проверь, что Master Bot запущен на :19210
Bun не находит модули bun install в соответствующей директории
i18n ошибки cd frontend && npm run i18n:compile