4411db8cd6eed0b35e36cde3900871336a9af0e0
PHASE 19 COMPLETION SUMMARY:
✅ COMPLETED FEATURES:
1. Task Management System (Phase 19.1-19.7)
- Database schema with tasks table (14 columns)
- Query helpers for CRUD operations
- 7 tRPC endpoints for task management
- TasksPanel React component with real-time updates
- Auto-task creation functions
- Chat UI integration with conversationId tracking
2. Auto-Task Creation Integration (Phase 19.8)
- Integrated into orchestratorChat loop
- Detects missing components from tool errors
- Auto-creates tasks for: tools, skills, agents, components, dependencies
- Tracks task completion status
3. Web Research Workflow (Phase 19.9-19.12)
- server/web-research.ts module with 3 main functions:
* performWebResearch() - Execute web searches with Browser Agent
* compileResearchReport() - Generate markdown reports
* createResearchTasks() - Create research tasks for orchestrator
- 3 tRPC endpoints:
* research.search - Perform web research
* research.compileReport - Compile results into report
* research.createTasks - Create research tasks
- WebResearchPanel React component:
* Search input with real-time results
* Options: max results, screenshots, text extraction
* Result cards with expandable details
* Report download functionality
* Error handling and empty states
4. Unit Tests
- 120 tests pass (out of 121 total)
- Web Research tests: 18 tests covering all functions
- Task tests: 5 tests (1 fails due to missing DB table)
- All other tests pass
ARCHITECTURE:
- Browser Agent integration via Puppeteer
- Task tracking with metadata
- Auto-report compilation in markdown
- Screenshot and text extraction support
- Real-time UI updates via tRPC
NEXT STEPS:
1. Run pnpm db:push on production to create tasks table
2. Commit all changes to Gitea
3. Deploy to production
4. Verify tests pass on production DB
5. Test Web Research workflow end-to-end
TEST RESULTS:
- Test Files: 1 failed | 10 passed (11 total)
- Tests: 1 failed | 120 passed (121 total)
- Only failure: tasks.test.ts (requires production DB table)
GoClaw Control Center
Mission Control для вашего AI-агентского кластера. Веб-интерфейс для мониторинга Docker Swarm, управления AI-агентами и общения с оркестратором через реальный LLM (Ollama Cloud API).
Запуск одной командой
curl -fsSL https://git.softuniq.eu/UniqAI/GoClaw/raw/branch/main/install.sh | bash
Или вручную через Docker Compose:
git clone https://git.softuniq.eu/UniqAI/GoClaw.git && cd GoClaw && cp .env.example .env && docker compose up -d
После запуска откройте: http://localhost:3000
Быстрый старт (без Docker)
# 1. Клонировать репозиторий
git clone https://git.softuniq.eu/UniqAI/GoClaw.git
cd GoClaw
# 2. Установить зависимости
pnpm install
# 3. Настроить переменные окружения
cp .env.example .env
# Отредактируйте .env — укажите OLLAMA_BASE_URL и OLLAMA_API_KEY
# 4. Запустить базу данных
pnpm db:push
# 5. Запустить dev-сервер
pnpm dev
Архитектура
GoClaw Control Center
├── client/ # React 19 + Tailwind 4 + shadcn/ui (фронтенд)
│ └── src/
│ ├── pages/ # Dashboard, Agents, Nodes, Chat, Settings
│ └── components/ # DashboardLayout, UI-компоненты
├── server/ # Express 4 + tRPC 11 (бэкенд)
│ ├── ollama.ts # Прокси-клиент для Ollama API
│ ├── routers.ts # tRPC роуты (ollama.health, models, chat)
│ └── _core/ # Auth, DB, LLM, Storage хелперы
├── drizzle/ # Схема БД и миграции (MySQL/TiDB)
├── docker/ # Docker Stack для Swarm-деплоя
│ ├── docker-stack.yml # Полный стек: Gateway + Agents + Control Center
│ ├── Dockerfile.gateway # Образ основного шлюза GoClaw
│ ├── Dockerfile.agent # Образ AI-агента
│ └── Dockerfile.control-center # Образ веб-интерфейса (nginx)
└── docs/ # Документация и спецификации
├── swarm_architecture.md
└── goclaw_swarm_cloud_guide.md
Возможности
| Раздел | Что умеет |
|---|---|
| Dashboard | Мониторинг Swarm-нод, статус агентов, лента активности, live-статус Ollama API |
| Agents | Просмотр всех AI-агентов с их ролями, моделями и текущими задачами |
| Nodes | Мониторинг Docker Swarm нод: CPU, RAM, контейнеры, статус |
| Chat | Терминальный чат с оркестратором через реальный LLM (34 модели Ollama) |
| Settings | Управление API-провайдерами, сканирование доступных моделей, настройки Telegram |
Переменные окружения
Скопируйте .env.example в .env и заполните:
# Ollama API (обязательно)
OLLAMA_BASE_URL=https://ollama.com/v1
OLLAMA_API_KEY=your_api_key_here
# База данных (обязательно для production)
DATABASE_URL=mysql://user:password@host:3306/goclaw
# JWT (сгенерируйте случайную строку)
JWT_SECRET=your_random_secret_here
# Telegram Bot (опционально)
TELEGRAM_BOT_TOKEN=your_bot_token
Docker Swarm деплой
# Инициализировать Swarm (если ещё не сделано)
docker swarm init
# Задать секреты
export OLLAMA_API_KEY=your_key
export DATABASE_URL=mysql://...
export JWT_SECRET=your_secret
# Развернуть стек
docker stack deploy -c docker/docker-stack.yml goclaw
# Проверить статус
docker stack services goclaw
Добавление новой ноды в кластер:
# На manager-ноде получить токен
docker swarm join-token worker
# На новой ноде выполнить команду из вывода выше
docker swarm join --token SWMTKN-... manager-ip:2377
Технологический стек
| Слой | Технологии |
|---|---|
| Фронтенд | React 19, Tailwind CSS 4, shadcn/ui, Framer Motion, tRPC Client |
| Бэкенд | Node.js, Express 4, tRPC 11, Drizzle ORM, Zod |
| База данных | MySQL / TiDB (через Drizzle) |
| LLM | Ollama Cloud API (OpenAI-совместимый, 34+ модели) |
| Оркестрация | Docker Swarm, Overlay Network |
| Агенты (Go) | gRPC, Docker SDK, Goroutines, Channels |
| Тесты | Vitest |
Структура GoClaw Swarm
┌─────────────────────────────────┐
│ goclaw-net (Overlay Network) │
└─────────────────────────────────┘
│
┌─────────────────────┼─────────────────────┐
│ │ │
┌─────────▼──────┐ ┌──────────▼──────┐ ┌─────────▼──────┐
│ Control Center │ │ Gateway │ │ Agents │
│ (Web UI :3000) │ │ (Orchestrator) │ │ (Docker Svc) │
│ React + tRPC │ │ Go + gRPC │ │ Coder/Browser │
└────────────────┘ └─────────────────┘ │ Mail/Monitor │
│ └─────────────────┘
┌───────────▼──────────┐
│ Ollama Cloud API │
│ (34 LLM Models) │
└──────────────────────┘
Разработка
# Запустить тесты
pnpm test
# Проверить типы
pnpm check
# Форматировать код
pnpm format
# Применить миграции БД
pnpm db:push
Дорожная карта
- Dashboard с мониторингом кластера
- Реальная интеграция Ollama API (34 модели)
- Терминальный чат с LLM
- Docker Swarm Stack
- gRPC API для агентов (Go)
- Стриминг ответов LLM в чате
- CRUD агентов через UI
- Подключение реального Docker API для нод
- Telegram-коннектор
- Система скиллов (Self-Evolution)
- Аутентификация и RBAC
Лицензия
MIT — используйте свободно для личных и коммерческих проектов.
Разработано в рамках проекта GoClaw — распределённой системы AI-агентов на Go + Docker Swarm.
Description
Languages
TypeScript
84.1%
Go
10.1%
JavaScript
4.4%
Shell
0.8%
CSS
0.5%