Files
devclaw-gitea/docs/ONBOARDING.md

274 lines
11 KiB
Markdown

# DevClaw — Onboarding Guide
Step-by-step setup: install the plugin, configure an agent, register projects, and run your first task.
## Prerequisites
| Requirement | Why | How to check |
|---|---|---|
| [OpenClaw](https://openclaw.ai) installed | DevClaw is an OpenClaw plugin | `openclaw --version` |
| Node.js >= 20 | Runtime for plugin | `node --version` |
| [`gh`](https://cli.github.com) or [`glab`](https://gitlab.com/gitlab-org/cli) CLI | Issue tracker provider (auto-detected from git remote) | `gh --version` or `glab --version` |
| CLI authenticated | Plugin calls gh/glab for every label transition | `gh auth status` or `glab auth status` |
| A GitHub/GitLab repo with issues | The task backlog lives in the issue tracker | `gh issue list` or `glab issue list` from your repo |
## Step 1: Install the plugin
```bash
openclaw plugins install @laurentenhoor/devclaw
```
Or for local development:
```bash
openclaw plugins install -l ./devclaw
```
Verify:
```bash
openclaw plugins list
# Should show: DevClaw | devclaw | loaded
```
## Step 2: Run setup
There are three ways to set up DevClaw:
### Option A: Conversational onboarding (recommended)
Call the `onboard` tool from any agent that has the DevClaw plugin loaded. The agent walks you through configuration step by step — asking about:
- Agent selection (current or create new)
- Channel binding (telegram/whatsapp/none) — for new agents only
- Model levels (accept defaults or customize)
- Optional project registration
The tool returns instructions that guide the agent through the QA-style setup conversation.
### Option B: CLI wizard
```bash
openclaw devclaw setup
```
The setup wizard walks you through:
1. **Agent** — Create a new orchestrator agent or configure an existing one
2. **Developer team** — Choose which LLM model powers each level:
- **Developer junior** (fast, cheap tasks) — default: `anthropic/claude-haiku-4-5`
- **Developer medior** (standard tasks) — default: `anthropic/claude-sonnet-4-5`
- **Developer senior** (complex tasks) — default: `anthropic/claude-opus-4-6`
- **Tester junior** (quick checks) — default: `anthropic/claude-haiku-4-5`
- **Tester medior** (standard review) — default: `anthropic/claude-sonnet-4-5`
- **Tester senior** (thorough review) — default: `anthropic/claude-opus-4-6`
- **Architect junior** (standard design) — default: `anthropic/claude-sonnet-4-5`
- **Architect senior** (complex architecture) — default: `anthropic/claude-opus-4-6`
3. **Workspace** — Writes AGENTS.md, HEARTBEAT.md, workflow.yaml, role templates, and initializes state
Non-interactive mode:
```bash
# Create new agent with default models
openclaw devclaw setup --new-agent "My Dev Orchestrator"
# Configure existing agent with custom models
openclaw devclaw setup --agent my-orchestrator \
--junior "anthropic/claude-haiku-4-5" \
--senior "anthropic/claude-opus-4-6"
```
### Option C: Tool call (agent-driven)
**Conversational onboarding via tool:**
```json
onboard({ "mode": "first-run" })
```
The tool returns step-by-step instructions that guide the agent through the setup conversation.
**Direct setup (skip conversation):**
```json
setup({
"newAgentName": "My Dev Orchestrator",
"channelBinding": "telegram",
"models": {
"developer": {
"junior": "anthropic/claude-haiku-4-5",
"senior": "anthropic/claude-opus-4-6"
},
"tester": {
"medior": "anthropic/claude-sonnet-4-5"
}
}
})
```
## Step 3: Channel binding (optional, for new agents)
If you created a new agent during conversational onboarding and selected a channel binding (telegram/whatsapp), the agent is automatically bound. **Skip to step 4.**
**Smart Migration**: If an existing agent already has a channel-wide binding (e.g., the old orchestrator receives all telegram messages), the onboarding agent will:
1. Detect the conflict
2. Ask if you want to migrate the binding from the old agent to the new one
3. If you confirm, the binding is automatically moved — no manual config edit needed
If you didn't bind a channel during setup:
**Option A: Manually edit `openclaw.json`**
```json
{
"bindings": [
{
"agentId": "my-orchestrator",
"match": {
"channel": "telegram"
}
}
]
}
```
For group-specific bindings:
```json
{
"agentId": "my-orchestrator",
"match": {
"channel": "telegram",
"peer": {
"kind": "group",
"id": "-1234567890"
}
}
}
```
Restart OpenClaw after editing.
**Option B: Add bot to Telegram/WhatsApp group**
If using a channel-wide binding (no peer filter), the agent receives all messages from that channel. Add your orchestrator bot to the relevant Telegram group.
## Step 4: Register your project
Go to the Telegram/WhatsApp group for the project and tell the orchestrator agent:
> "Register project my-project at ~/git/my-project with base branch development"
The agent calls `project_register`, which atomically:
- Validates the repo and auto-detects GitHub/GitLab from remote
- Creates all 11 state labels (idempotent)
- Scaffolds role instruction files (`devclaw/projects/<project>/prompts/developer.md`, `tester.md`, `architect.md`)
- Adds the project entry to `projects.json`
- Logs the registration event
**Initial state in `projects.json`:**
```json
{
"projects": {
"-1234567890": {
"name": "my-project",
"repo": "~/git/my-project",
"groupName": "Project: my-project",
"baseBranch": "development",
"deployBranch": "development",
"channel": "telegram",
"provider": "github",
"roleExecution": "parallel",
"workers": {
"developer": {
"active": false,
"issueId": null,
"startTime": null,
"level": null,
"sessions": { "junior": null, "medior": null, "senior": null }
},
"tester": {
"active": false,
"issueId": null,
"startTime": null,
"level": null,
"sessions": { "junior": null, "medior": null, "senior": null }
},
"architect": {
"active": false,
"issueId": null,
"startTime": null,
"level": null,
"sessions": { "junior": null, "senior": null }
}
}
}
}
}
```
**Finding the Telegram group ID:** The group ID is the numeric ID of your Telegram supergroup (a negative number like `-1234567890`). When you call `project_register` from within the group, the ID is auto-detected from context.
## Step 5: Create your first issue
Issues can be created in multiple ways:
- **Via the agent** — Ask the orchestrator in the Telegram group: "Create an issue for adding a login page" (uses `task_create`)
- **Via workers** — DEVELOPER/TESTER workers can call `task_create` to file follow-up bugs they discover
- **Via CLI** — `cd ~/git/my-project && gh issue create --title "My first task" --label "To Do"` (or `glab issue create`)
- **Via web UI** — Create an issue and add the "To Do" label
Note: `task_create` defaults to the "Planning" label. Use "To Do" explicitly when the task is ready for immediate work.
## Step 6: Test the pipeline
Ask the agent in the Telegram group:
> "Check the queue status"
The agent should call `status` and report the "To Do" issue. Then:
> "Pick up issue #1 for developer"
The agent calls `work_start`, which assigns a level, transitions the label to "Doing", creates or reuses a worker session, and dispatches the task — all in one call. The agent posts the announcement.
## Adding more projects
Tell the agent to register a new project (step 4) from within the new project's Telegram group. That's it — `project_register` handles labels and state setup.
Each project is fully isolated — separate queue, separate workers, separate state.
## Developer levels
DevClaw assigns tasks to developer levels instead of raw model names. This makes the system intuitive — you're assigning a "junior" to fix a typo, not configuring model parameters. All roles use the same level scheme.
| Role | Level | Default Model | When to assign |
|------|-------|---------------|----------------|
| Developer | **junior** | `anthropic/claude-haiku-4-5` | Typos, single-file fixes, CSS changes |
| Developer | **medior** | `anthropic/claude-sonnet-4-5` | Features, bug fixes, multi-file changes |
| Developer | **senior** | `anthropic/claude-opus-4-6` | Architecture, migrations, system-wide refactoring |
| Tester | **junior** | `anthropic/claude-haiku-4-5` | Quick smoke tests, basic checks |
| Tester | **medior** | `anthropic/claude-sonnet-4-5` | Standard code review, test validation |
| Tester | **senior** | `anthropic/claude-opus-4-6` | Thorough security review, complex edge cases |
| Architect | **junior** | `anthropic/claude-sonnet-4-5` | Standard design investigation |
| Architect | **senior** | `anthropic/claude-opus-4-6` | Complex architecture decisions |
Change which model powers each level in `workflow.yaml` — see [Configuration](CONFIGURATION.md#role-configuration).
## What the plugin handles vs. what you handle
| Responsibility | Who | Details |
|---|---|---|
| Plugin installation | You (once) | `openclaw plugins install @laurentenhoor/devclaw` |
| Agent + workspace setup | Plugin (`setup`) | Creates agent, configures models, writes workspace files |
| Channel binding migration | Plugin (`setup` with `migrateFrom`) | Automatically moves channel-wide bindings between agents |
| Label setup | Plugin (`project_register`) | 11 labels, created idempotently via IssueProvider |
| Prompt file scaffolding | Plugin (`project_register`) | Creates `devclaw/projects/<project>/prompts/<role>.md` for each role |
| Project registration | Plugin (`project_register`) | Entry in `projects.json` with empty worker state |
| Telegram group setup | You (once per project) | Add bot to group |
| Issue creation | Plugin (`task_create`) | Orchestrator or workers create issues from chat |
| Label transitions | Plugin | Atomic transitions via issue tracker CLI |
| Developer assignment | Plugin | LLM-selected level by orchestrator, keyword heuristic fallback |
| State management | Plugin | Atomic read/write to `projects.json` with file locking |
| Session management | Plugin | Creates, reuses, and dispatches to sessions via CLI. Agent never touches session tools. |
| Task completion | Plugin (`work_finish`) | Workers self-report. Scheduler dispatches next role. |
| Role instructions | Plugin (bootstrap hook) | Injected into worker sessions via `agent:bootstrap` hook at session startup |
| Review polling | Plugin (heartbeat) | Auto-merges and advances "In Review" issues when PR is approved |
| Config validation | Plugin | Zod schemas validate `workflow.yaml` at load time |
| Audit logging | Plugin | Automatic NDJSON append per tool call |
| Zombie detection | Plugin | `health` checks active vs alive |
| Queue scanning | Plugin | `status` queries issue tracker per project |