Локальна розробка — 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 коли змінюєш code без оновлення docs. Bypass: git push --no-verify. Деталі — CLAUDE.md секція "Documentation Law".

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+ ендпоінтами. Потрібен 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+ ендпоінтів)
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/            # archived Phase 36 NotebookLM Bridge (decommissioned 2026-06-05; RAG moved into shared/rag.ts in Phase 71)
├── 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