chore: organize documentation structure for monorepo

- Create /docs structure (microdao, daarion, agents)
- Organize 61 cursor technical docs
- Add README files for each category
- Copy key documents to public categories
- Add GitHub setup instructions and scripts
This commit is contained in:
Apple
2025-11-15 04:08:35 -08:00
parent 5520665600
commit c552199eed
138 changed files with 39624 additions and 40 deletions

View File

@@ -0,0 +1,654 @@
# 21 — Agent-Only Interface (MicroDAO)
Агентська операційна система замість класичного застосунку
Цей документ описує цільовий інтерфейс MicroDAO, де:
- немає класичного "меню функцій";
- все представлено як **учасники**: Люди, Агенти, Роботи;
- чати, проєкти, бази знань і доступи — це **ресурси**, якими керують агенти;
- інвайти, шеринги, права і токени виконуються через агентські дії (з web3-фіксацією, де потрібно).
Це візійний, але достатньо конкретний документ для Cursor:
- UX-специфікація;
- структура layout;
- сценарії;
- задачі для реалізації перших версій.
---
# 1. Мета
Перетворити MicroDAO на **агентську ОС спільнот**, де:
- користувач взаємодіє насамперед з агентами, а не з "екранами";
- кожен контекст (канал, проєкт, база даних, DAO-голосування) — це простір, де присутні:
- Люди,
- Агенти,
- (у майбутньому) Роботи;
- запрошення, шеринги, доступи — це:
- діалог з агентом,
- + технічні дії (RBAC, entitlements, web3-транзакції).
---
# 2. Загальний layout агентської ОС
## 2.1. Лівий сайдбар — Простори та Учасники
Структура:
1. **Мої простори (microDAO)**
- `[DAARION Core]`
- `[GreenFood DAO]`
- `[Personal Lab]`
2. **Учасники**
- **Люди**
- **Агенти**
- **Роботи** (поки пусто, плейсхолдер)
3. **Активний контекст**
Підсвічений простір + "поточний стіл":
- Канал: `#dev-mvp`
- Проєкт: `MicroDAO MVP`
- Простір знань: `Tokenomics`
Сайдбар показує **структуру світу**, але основні дії йдуть через агентів.
## 2.2. Центр — Діалоговий простір
Центральна колонка завжди є **чатом**:
- Це може бути:
- канал (`#dev-mvp`),
- група (мультичат),
- DM з людиною,
- або "Agent Hub" (чат з головним агентом).
У заголовку:
- Назва контексту (наприклад, `#dev-mvp`).
- Список учасників (аватари):
- Люди: 25
- Агенти: Team Assistant, Messenger Agent, Projects Agent, Governance Agent
- (Роботи, якщо є)
Звідси:
- пишуть люди,
- відповідають агенти,
- запускаються операції над ресурсами (проєктами, БД, токенами).
## 2.3. Правий сайдбар — Контекст і Ресурси
Праворуч:
1. **Контекст**:
- Активний простір (microDAO)
- Поточний канал/проєкт
- Які агенти мають доступ
2. **Ресурси**:
- Проєкти
- Бази даних / таблиці
- Простори знань (Co-Memory)
- Повʼязані гаманці / токени
3. **Права та ключі**:
- Список людей та агентів з доступами (read/write/admin/use-in-prompts)
- Кнопка "Керувати доступами"
- Інформація про web3-стан (якщо є on-chain записи)
---
# 3. Панель "Люди / Агенти / Роботи"
## 3.1. Люди
Елементи списку:
- Аватар
- Імʼя
- Статус (online/offline/busy)
- Ролі в microDAO (Member, Guardian, Investor…)
Клік по людині:
- відкриває:
- DM-чат з цією людиною,
- або розширений профіль (у майбутньому):
- в яких проєктах,
- з якими агентами працює.
## 3.2. Агенти
Групи:
- **Системні агенти**:
- Team Assistant
- Messenger Agent
- Projects Agent
- Memory/Knowledge Agent
- Governance/Tokenomics Agent
- Bridge/Integrations Agent
- **Користувацькі агенти**:
- спеціалізовані боти, створені командою.
- **Зовнішні агенти (маркетплейс)**:
- агенти з інших microDAO або від сторонніх розробників.
Клік по агенту:
- відкриває **сторінку агента**:
- вкладка "Чат",
- вкладка "Памʼять",
- вкладка "Самонавчання/Еволюція",
- вкладка "Доступи та ресурси" (які проєкти/БД він бачить).
## 3.3. Роботи
Поки може бути просто секція "Роботи (скоро)".
Модель на майбутнє:
- Привʼязані до фізичних пристроїв (робот, сенсор, енергоблок).
- Участь у чатах як окремі "учасники".
- Окремі права на дії у фізичному світі.
---
# 4. Запрошення агентів до каналів/чатів
## 4.1. UX-флоу
У будь-якому чаті/каналі:
- кнопка **"Додати учасника"**.
При натисканні:
1. Модалка:
- таби: `Люди | Агенти | Роботи`
- поле пошуку
2. Вибір Агента:
- список агентів,
- короткий опис (роль, профіль, що вміє).
3. Налаштування прав:
- чекбокси / селект:
- `Читати цей канал`
- `Писати в цей канал`
- `Створювати задачі / follow-ups`
- `Доступ до проєктів цього контексту`
- `Доступ до баз знань цього контексту`
4. Підтвердження:
- кнопка **"Запросити агента"**
Після цього:
- у header чату зʼявляється новий агент;
- агент отримує повідомлення (system DM):
> "Тебе додали до каналу #dev-mvp з правами: читати, писати, створювати задачі."
## 4.2. Backend/протоколно
Під капотом:
- створюється entitlement для `agent_id` з:
- `resource_kind`: `channel` / `project` / `knowledge_space`,
- `resource_id`,
- `scopes`: `[read, write, tasks, knowledge]`.
- (optionally) запускається web3-транзакція:
- видача capability-токена / NFT-доступу,
- запис в on-chain реєстр (аудит, DAO-гарантія).
---
# 5. Обмін проєктами / базами даних між людьми та агентами
## 5.1. Поняття "Ресурсу"
Ресурс — це будь-що, до чого можна дати/забрати доступ:
- Проєкт (`project_id`)
- Таблиця / БД (`dataset_id`, `table_id`)
- Простір знань (`knowledge_space_id`)
- Набір подій (`events_stream_id`)
- Гаманець / смарт-контракт (`wallet_id`, `contract_id`)
У правому сайдбарі поточного контексту:
- "Ресурси цього контексту"
- Кожен ресурс має меню:
- "Поділитися…"
- "Показати, хто має доступ"
## 5.2. UX шерингу
У правій панелі користувач:
1. Обирає ресурс → "Поділитися".
2. Відкривається модалка:
- таби: `Люди | Агенти | MicroDAO`
3. Вибирає:
- одного або кількох адресатів.
4. Вказує права:
- `read` / `write` / `admin` / `use_in_prompts_only`.
5. Підтверджує.
Після цього:
- Governance/Tokenomics Agent:
- оформлює web3-операцію (за потреби),
- оновлює entitlements,
- лог у audit/journal.
- Memory/Knowledge Agent:
- оновлює карту знань (хто/що бачить),
- може пропонувати нові рекомендації (наприклад, Projects Agent тепер бачить дані продажів).
---
# 6. "Agent Hub" — стартовий екран без меню
Замість класичного "Home":
- при вході в MicroDAO користувач потрапляє в чат з головним агентом (**Team Assistant / OS Agent**).
Верхня частина:
- "Привіт, це твоя microDAO: [Назва]"
- Короткі блоки:
- "Учасники" (скільки людей, скільки агентів)
- "Проєкти" (активні)
- "Сигнали" (важливі нотифікації)
Основний елемент — чат, де користувач може написати будь-що:
Приклади:
- "Покажи, хто зараз працює над MVP."
- "Створи новий проєкт для інтеграції DAGI."
- "Запроси Projects Agent і Governance Agent в цей проєкт."
- "Поділись базою `sales_events` з Projects Agent тільки для читання."
Агент:
- ставить уточнюючі питання (якщо потрібно),
- викликає внутрішні агенти:
- Messenger Agent → створити/налаштувати канал
- Projects Agent → створити проєкт/таски
- Governance Agent → оформити доступи й web3-запис
- Knowledge Agent → підключити Co-Memory
Усе це відображається як:
- ланцюжок дій у чаті,
- результати в структурі UI (нові канали / проєкти / ресурси).
---
# 7. Мінімальний MVP цієї парадигми
Для першої реалізації (без надроздуття):
1. **Лівий сайдбар:**
- блок "Учасники": `Люди`, `Агенти` (Роботи — плейсхолдер).
- кліки відкривають DM / сторінку агента.
2. **Agent Hub як Home:**
- `/t/:teamId/home` → чат з Team Assistant.
- кнопка "Домашня" у сайдбарі → туди.
3. **Модалка "Додати учасника" для каналів:**
- можливість додати агента,
- налаштувати права (на поки що хоча б `read/write`).
4. **Модалка "Поділитися ресурсом":**
- для проєктів (Projects Agent вже буде з 15-го документа),
- базові права `read/write`.
5. **Без web3 на першому етапі:**
- тільки модель прав у БД (RBAC + entitlements),
- web3-интеграція — stub/плейсхолдер (логіка в Governance Agent).
---
# 8. Компоненти та структура
## 8.1. Layout Components
```
src/layouts/
AgentOSLayout.tsx # Головний layout з 3 колонками
LeftSidebar.tsx # Простори + Учасники
ParticipantsPanel.tsx # Панель Люди/Агенти/Роботи
RightSidebar.tsx # Контекст + Ресурси
ContextPanel.tsx # Панель контексту
ResourcesPanel.tsx # Панель ресурсів
```
## 8.2. Pages
```
src/pages/
AgentHubPage.tsx # /t/:teamId/home - стартовий екран
ParticipantPage.tsx # Сторінка учасника (людина/агент)
```
## 8.3. Modals
```
src/components/modals/
AddParticipantModal.tsx # Додати учасника до каналу/чату
ShareResourceModal.tsx # Поділитися ресурсом
ManageAccessModal.tsx # Керування доступами
```
## 8.4. Types
```ts
interface Participant {
id: string;
type: "human" | "agent" | "robot";
name: string;
avatar?: string;
status?: "online" | "offline" | "busy";
roles?: string[];
}
interface Resource {
id: string;
type: "project" | "dataset" | "knowledge_space" | "wallet" | "contract";
name: string;
description?: string;
accessLevel?: "read" | "write" | "admin" | "use_in_prompts_only";
}
interface Entitlement {
participantId: string;
resourceKind: string;
resourceId: string;
scopes: string[];
}
```
---
# 9. API Endpoints
## 9.1. Participants
```ts
GET /teams/{teamId}/participants
// Повертає список учасників (люди + агенти)
GET /teams/{teamId}/participants/{id}
// Деталі учасника
POST /channels/{channelId}/participants
// Додати учасника до каналу
{
participantId: string;
participantType: "human" | "agent";
scopes: string[];
}
```
## 9.2. Resources
```ts
GET /teams/{teamId}/resources
// Список ресурсів у контексті
POST /resources/{resourceId}/share
// Поділитися ресурсом
{
participantIds: string[];
scopes: string[];
}
```
## 9.3. Entitlements
```ts
GET /entitlements
// Список прав поточного користувача/агента
POST /entitlements
// Створити entitlement
{
participantId: string;
resourceKind: string;
resourceId: string;
scopes: string[];
}
```
---
# 10. Інтеграція з існуючими модулями
## 10.1. Messenger Agent (14)
Messenger Agent може:
- показувати список каналів з учасниками
- фільтрувати канали за наявністю агентів
- пропонувати додати агента до каналу
## 10.2. Projects Agent (15)
Projects Agent може:
- показувати проєкти як ресурси
- керувати доступами до проєктів
- пропонувати поділитися проєктом з іншими агентами
## 10.3. Governance Agent (18)
Governance Agent:
- оформлює web3-транзакції для доступу
- веде audit log всіх змін прав
- керує токеномікою доступів
---
# 11. Завдання для Cursor
Приклад промта:
```
You are a senior React/TS engineer.
Implement the Agent-Only Interface shell using:
- 21_agent_only_interface.md
- 10_agent_ui_system.md
- 14_messenger_agent_module.md
- 03_api_core_snapshot.md
- 05_coding_standards.md
Tasks:
1) Update the main layout:
- Left sidebar: Spaces + Participants (People, Agents, Robots placeholder).
- Center: Dialog area (chat for current context).
- Right sidebar: Context & Resources panel (stub data).
2) Create "Agent Hub" route `/t/:teamId/home`:
- Chat with Team Assistant as the main entry point.
3) Add "Add participant" flow for channels:
- Modal with tabs: People / Agents.
- For Agents: basic permissions (read / write) stored in entitlements (stub).
4) Add "Share resource" flow in the right sidebar:
- For now: projects only (resource type stub).
- Modal to grant read/write access to People or Agents (no web3 yet).
5) Ensure navigation:
- Clicking on a Person/Agent in the sidebar opens the appropriate chat/page.
Output:
- list of modified files
- diff
- summary
```
---
# 12. Результат
Після впровадження цього модуля:
* MicroDAO отримує "агентський" каркас інтерфейсу:
* вхід через Agent Hub,
* центральна роль агентів,
* простий механізм запрошення агентів,
* базові flows шерингу ресурсів;
* класичний месенджер (документ 14) стає лише однією з "здібностей" всередині агентської ОС, а не центром продукту.
---
**Готово.**
Це **повна специфікація Agent-Only Interface**, готова до використання в Cursor.