Commit Graph

183 Commits

Author SHA1 Message Date
Lauren ten Hoor
e0b374ce46 chore: bump version to 1.2.0 2026-02-13 21:13:48 +08:00
Lauren ten Hoor
64138b04bf docs: remove outdated scheduler tick references from AGENTS.md template (#177) (#178) 2026-02-13 21:04:16 +08:00
Lauren ten Hoor
be3095bbe9 docs: remove outdated auto-tick references from README.md (#174) (#176) 2026-02-13 20:57:28 +08:00
Lauren ten Hoor
cfd7ea9237 fix: update heartbeat.ts type signatures to accept SessionLookup | null (#169) (#175) 2026-02-13 20:49:20 +08:00
Lauren ten Hoor
abbf05777c fix: refactor queue.ts to use workflow config instead of hardcoded labels (#162) (#173)
## Problem

lib/services/queue.ts was not updated during workflow refactor (#147) and still
used hardcoded queue labels: QueueLabel type, QUEUE_PRIORITY constant.

## Solution

- Add getQueueLabelsWithPriority() to derive queue labels from workflow config
- Add getQueuePriority() to get priority for any label
- Update getTaskPriority() and getRoleForLabel() to accept workflow config
- Update fetchProjectQueues() to use workflow-derived labels
- Add getTotalQueuedCount() helper

## Files Changed

- lib/services/queue.ts — use workflow config for all queue operations
- lib/tools/status.ts — handle dynamic queue labels, include queueLabels in response

## Backward Compatibility

- QueueLabel type kept as deprecated alias
- QUEUE_PRIORITY kept as deprecated constant
- All functions accept optional workflow parameter, default to DEFAULT_WORKFLOW
2026-02-13 20:46:25 +08:00
Lauren ten Hoor
f6ea35324c Merge pull request #172 from laurentenhoor/docs/159-work-finish-auto-tick
docs: remove outdated auto-tick references from work_finish (#159)
2026-02-13 20:43:47 +08:00
Lauren ten Hoor
74db08abc5 docs: remove outdated auto-tick references from work_finish (#159) 2026-02-13 20:43:06 +08:00
Lauren ten Hoor
bdcc1b13de Merge pull request #171 from laurentenhoor/feat/170-orphaned-label-scan
feat: health check scans for orphaned Doing/Testing labels (#170)
2026-02-13 20:31:13 +08:00
Lauren ten Hoor
bf75db88c0 feat: health check scans for orphaned Doing/Testing labels (#170) 2026-02-13 20:30:28 +08:00
Lauren ten Hoor
70714388e8 fix: strip non-JSON prefix from gateway status output (#165) 2026-02-13 20:14:55 +08:00
Lauren ten Hoor
3440a3c187 fix: null safety for sessions in health tool (#165) 2026-02-13 19:51:52 +08:00
Lauren ten Hoor
8778f54f9a Merge pull request #168 from laurentenhoor/chore/167-remove-test-comment
chore: remove test comment from README.md (#167)
2026-02-13 19:45:30 +08:00
Lauren ten Hoor
45fd983c44 chore: remove test comment from README.md (#167) 2026-02-13 19:45:09 +08:00
Lauren ten Hoor
0606c9d970 Merge pull request #166 from laurentenhoor/fix/165-health-check-gateway-timeout
fix: health check skips session liveness checks when gateway unavailable (#165)
2026-02-13 19:41:22 +08:00
Lauren ten Hoor
8b5cfedb01 fix: health check skips session liveness checks when gateway unavailable (#165) 2026-02-13 19:40:43 +08:00
Lauren ten Hoor
19a2cb3bfc Merge pull request #164 from laurentenhoor/test/163-readme-comment
test: add comment to README.md (#163)
2026-02-13 19:30:15 +08:00
Lauren ten Hoor
c61060aff5 test: add comment to README.md (#163) 2026-02-13 19:29:50 +08:00
Lauren ten Hoor
dfeadf742a feat: make workflow states dynamic with XState-style statechart config (#147) (#160)
## Summary

Introduces a configurable workflow state machine that replaces all hardcoded
state labels. The default workflow matches current behavior exactly, ensuring
backward compatibility.

## Architecture

### lib/workflow.ts — Core workflow engine

XState-style statechart configuration:

```typescript
type StateConfig = {
  type: 'queue' | 'active' | 'hold' | 'terminal';
  role?: 'dev' | 'qa';
  label: string;
  color: string;
  priority?: number;
  on?: Record<string, TransitionTarget>;
};
```

All behavior is derived from the config:
- Queue states: `type: 'queue'`, grouped by role, ordered by priority
- Active states: `type: 'active'` — worker occupied
- Transitions: defined with optional actions (gitPull, detectPr, closeIssue, reopenIssue)
- Labels and colors: derived from state.label and state.color

### Derivation functions

- `getStateLabels()` — all labels for issue tracker sync
- `getLabelColors()` — label → color mapping
- `getQueueLabels(role)` — queue labels for a role, ordered by priority
- `getActiveLabel(role)` — the active/in-progress label for a role
- `getRevertLabel(role)` — queue label to revert to on failure
- `detectRoleFromLabel()` — detect role from a queue label
- `getCompletionRule(role, result)` — derive transition rule from config

## Files Changed

- **lib/workflow.ts** — NEW: workflow engine and default config
- **lib/providers/provider.ts** — deprecate STATE_LABELS, LABEL_COLORS; derive from workflow
- **lib/providers/github.ts** — use workflow config for label operations
- **lib/providers/gitlab.ts** — use workflow config for label operations
- **lib/services/pipeline.ts** — use getCompletionRule() from workflow
- **lib/services/tick.ts** — use workflow for queue/active labels
- **lib/services/health.ts** — use workflow for active/revert labels
- **lib/tools/work-start.ts** — use workflow for target label

## Backward Compatibility

- DEFAULT_WORKFLOW matches current hardcoded behavior exactly
- Deprecated exports kept for any external consumers
- No breaking changes to tool interfaces or project state

## Future Work

- Load per-project workflow overrides from projects.json
- User-facing config in projects/workflow.json
- Tool schema generation from workflow states
2026-02-13 18:50:09 +08:00
Lauren ten Hoor
24235cdbf7 Merge pull request #157 from laurentenhoor/fix/156-remove-chained-dispatch
fix: remove chained dispatch from work_finish - heartbeat only pickup path (#156)
2026-02-13 17:51:32 +08:00
Lauren ten Hoor
9dc5c66ce9 fix: remove chained dispatch from work_finish - heartbeat only pickup path (#156) 2026-02-13 17:50:50 +08:00
Lauren ten Hoor
c5c5e29e8f Merge pull request #155 from laurentenhoor/fix/138-orchestrator-issue-urls
fix: strengthen AGENTS.md to always include issue URLs in responses (#138)
2026-02-13 17:39:07 +08:00
Lauren ten Hoor
f2ccbe8bc8 fix: strengthen AGENTS.md to always include issue URLs in responses (#138) 2026-02-13 17:38:42 +08:00
Lauren ten Hoor
84d948ee68 fix: dispatch timeout causing missed Telegram notifications (#153) (#154)
## Problem

`dispatchTask()` shells out to `openclaw gateway call sessions.patch` which
times out when the gateway is busy, causing:
1. Notifications never fire (they're at the end of dispatchTask)
2. Worker state may not be recorded
3. Workers run silently

## Solution (3 changes)

### 1. Make `ensureSession` fire-and-forget
Session key is deterministic, so we don't need to wait for confirmation.
Health check catches orphaned state later.

### 2. Use runtime API for notifications instead of CLI
Pass `runtime` through opts and use direct API calls:
- `runtime.channel.telegram.sendMessageTelegram()`
- `runtime.channel.whatsapp.sendMessageWhatsApp()`
- etc.

### 3. Move notification before session dispatch
Fire workerStart/workerComplete notifications early (after label transition)
before the session calls that can timeout.

## Files Changed

- lib/dispatch.ts — fire-and-forget ensureSession, early notification, accept runtime
- lib/notify.ts — use runtime API for direct channel sends
- lib/services/pipeline.ts — early notification, accept runtime
- lib/services/tick.ts — pass runtime through to dispatchTask
- lib/tool-helpers.ts — accept runtime in tickAndNotify
- lib/tools/work-start.ts — pass api.runtime to dispatchTask
- lib/tools/work-finish.ts — pass api.runtime to executeCompletion/tickAndNotify
2026-02-13 17:29:32 +08:00
Lauren ten Hoor
24b35b3a3e fix: dispatch timeout causing missed Telegram notifications (#153) (#154)
## Problem

`dispatchTask()` shells out to `openclaw gateway call sessions.patch` which
times out when the gateway is busy, causing:
1. Notifications never fire (they're at the end of dispatchTask)
2. Worker state may not be recorded
3. Workers run silently

## Solution (3 changes)

### 1. Make `ensureSession` fire-and-forget
Session key is deterministic, so we don't need to wait for confirmation.
Health check catches orphaned state later.

### 2. Use runtime API for notifications instead of CLI
Pass `runtime` through opts and use direct API calls:
- `runtime.channel.telegram.sendMessageTelegram()`
- `runtime.channel.whatsapp.sendMessageWhatsApp()`
- etc.

### 3. Move notification before session dispatch
Fire workerStart/workerComplete notifications early (after label transition)
before the session calls that can timeout.

## Files Changed

- lib/dispatch.ts — fire-and-forget ensureSession, early notification, accept runtime
- lib/notify.ts — use runtime API for direct channel sends
- lib/services/pipeline.ts — early notification, accept runtime
- lib/services/tick.ts — pass runtime through to dispatchTask
- lib/tool-helpers.ts — accept runtime in tickAndNotify
- lib/tools/work-start.ts — pass api.runtime to dispatchTask
- lib/tools/work-finish.ts — pass api.runtime to executeCompletion/tickAndNotify
2026-02-13 17:29:25 +08:00
Lauren ten Hoor
d1106fc0bb Merge pull request #152 from laurentenhoor/fix/142-blocked-dispatch-loop
fix: blocked issues now go to Refining to prevent infinite dispatch loop (#142)
2026-02-13 17:12:57 +08:00
Lauren ten Hoor
130c38a314 fix: blocked issues now go to Refining to prevent infinite dispatch loop (#142) 2026-02-13 17:12:29 +08:00
Lauren ten Hoor
506f07bdb0 Merge pull request #151 from laurentenhoor/feature/150-centralize-notifications
refactor: centralize notifications in core dispatch/completion functions (#150)
2026-02-13 17:01:07 +08:00
Lauren ten Hoor
265f82f3a9 refactor: centralize notifications in core dispatch/completion functions (#150) 2026-02-13 17:00:42 +08:00
Lauren ten Hoor
80587412ee Merge pull request #149 from laurentenhoor/feature/148-include-issue-comments
feat: include issue comments in worker task context (#148)
2026-02-13 16:49:39 +08:00
Lauren ten Hoor
c0b3e15581 feat: include issue comments in worker task context (#148) 2026-02-13 16:49:15 +08:00
Lauren ten Hoor
54fabe1197 fix: change Planning label colour from blue to grey (#144) (#146)
Change Planning label from #6699cc (blue) to #95a5a6 (grey/slate) to distinguish it from To Do (#428bca).

Note: Only affects newly created labels. Existing repos need manual update.
2026-02-13 16:22:04 +08:00
Lauren ten Hoor
825c5e6f50 feat: redesign health check to triangulate projects.json, issue label, and session state (#143) (#145)
## Changes

- Remove `activeSessions` parameter from health check (was never populated)
- Add gateway session lookup via `openclaw gateway call status`
- Add issue label lookup via `provider.getIssue(issueId)`
- Implement detection matrix with 6 issue types:
  - session_dead: active worker but session missing in gateway
  - label_mismatch: active worker but issue not in Doing/Testing
  - stale_worker: active for >2h
  - stuck_label: inactive but issue has Doing/Testing label
  - orphan_issue_id: inactive but issueId set
  - issue_gone: active but issue deleted/closed

## Files

- lib/services/health.ts — complete rewrite with three-source triangulation
- lib/tools/health.ts — remove activeSessions param, fetch sessions from gateway
- lib/services/heartbeat.ts — remove empty activeSessions calls, pass sessions map
2026-02-13 16:20:21 +08:00
Lauren ten Hoor
4a029c1b3b Release v1.1.0 — Security hardening, session resilience, heartbeat fixes
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-13 10:57:21 +08:00
Lauren ten Hoor
83f1f1adf0 feat: implement runCommand wrapper and refactor command executions across modules 2026-02-13 10:50:35 +08:00
Lauren ten Hoor
e55b7fa555 Merge pull request #140 from laurentenhoor/feature/139-heartbeat-notifications
fix: send Telegram notifications for heartbeat pickups (#139)
2026-02-13 10:36:51 +08:00
Lauren ten Hoor
b1961fd362 fix: send Telegram notifications for heartbeat pickups (#139) 2026-02-13 10:36:32 +08:00
Lauren ten Hoor
412cddfb84 chore: remove TEST.md file (#136) 2026-02-13 09:35:40 +08:00
Lauren ten Hoor
5a960a1e1e docs: add TypeScript config fix to CHANGELOG
Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-12 20:48:38 +08:00
Lauren ten Hoor
9739a14910 fix: update TypeScript config for proper openclaw plugin-sdk type resolution
Changed module resolution from Node16 to Bundler (with ESNext module) to
properly resolve openclaw/plugin-sdk type exports. This fixes build errors
where OpenClawPluginApi and jsonResult types were not being found.

The Node16 module resolution was not following the re-exports in openclaw's
plugin-sdk index.d.ts correctly. Bundler resolution is more compatible with
modern package.json exports.

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-12 20:47:25 +08:00
Lauren ten Hoor
942fe9fd5d Release v1.0.0 - First Official Launch 🎉
First stable release of DevClaw, transforming OpenClaw into a
complete dev team management system.

Key features:
- Autonomous multi-project development pipeline
- Intelligent tier-based model selection (Junior/Medior/Senior)
- Token-free scheduling with work_heartbeat
- 60-80% token savings through tier selection and session reuse
- GitHub/GitLab integration with atomic operations
- Comprehensive tooling and documentation

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-12 20:40:20 +08:00
Lauren ten Hoor
b2fc94db9e feat: LLM-powered model auto-configuration and improved onboarding
Major changes:
- Add autoconfigure_models tool for intelligent model assignment
- Implement LLM-based model selection using openclaw agent
- Improve onboarding flow with better model access checks
- Update README with clearer installation and onboarding instructions

Technical improvements:
- Add model-fetcher utility to query authenticated models
- Add smart-model-selector for LLM-driven model assignment
- Use session context for LLM calls during onboarding
- Suppress logging from openclaw models list calls

Documentation:
- Add prerequisites section to README
- Add conversational onboarding example
- Improve quick start flow

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-12 20:37:15 +08:00
Lauren ten Hoor
84483176f4 docs: enforce orchestrator as planner-only, no direct coding (#133) (#135)
## Changes

### lib/templates.ts (AGENTS.md template)
- Added 'Critical: You Do NOT Write Code' section to orchestrator instructions
- Listed what orchestrator CAN do (planning, analysis, status checks)
- Listed what MUST go through workers (code, git ops, tests)
- Added 'Never write code yourself' to Safety section

### README.md
- Added 'The orchestrator's role' section explaining the workflow boundary
- Table showing what goes through workers vs orchestrator
- Explained why: audit trail, tier selection, parallelization, QA pipeline

### docs/ARCHITECTURE.md
- Updated scope boundaries diagram to show 'planning only' for orchestrator
- Added key boundary note about planner/dispatcher role

Addresses issue #133
2026-02-12 12:36:12 +08:00
Lauren ten Hoor
7dd9aa7a15 Merge pull request #134 from laurentenhoor/feat/132-improve-onboarding
feat: improve onboarding with model access check and Telegram group guidance
2026-02-12 12:32:57 +08:00
Lauren ten Hoor
93d616b0dc feat: improve onboarding with model access check and Telegram group guidance
Enhanced the DevClaw onboarding flow to address real-world usability issues
discovered during testing.

Changes:

1. Model Selection Improvements (Step 2):
   - Added explicit prompt to check user's available models first
   - Changed 'Default Model' table to 'Suggested default' to emphasize flexibility
   - Added model selection guidance with class descriptions:
     * junior/tester: Fast, cheap (Haiku-class, GPT-4-mini)
     * medior/reviewer: Balanced (Sonnet-class, GPT-4)
     * senior: Most capable (Opus-class, o1)
   - Emphasized guiding users to configure finer-grained mappings
   - Added warning that defaults are suggestions, not requirements

2. Telegram Group Setup Guidance (New Step 4):
   - Added comprehensive section on project isolation best practices
   - Explains the one-group-per-project model clearly
   - Provides rationale:
     * Clean issue backlogs per project
     * Isolated worker state
     * Clear audit trails
     * Team-specific access control
   - Documents mention requirement (@botname command)
   - Includes single-project mode option with strong warning
   - Provides tip for getting group ID from bot

3. Improved Flow:
   - Renumbered steps (Project Registration is now Step 5)
   - Added group ID discovery tip
   - Maintained conversational tone while being more explicit

Impact:
- Prevents configuration failures from using unavailable models
- Guides users toward sustainable multi-project setup
- Reduces support burden by proactively explaining best practices
- Still allows single-project mode for solo developers

Addresses issue #132
2026-02-12 12:31:50 +08:00
Lauren ten Hoor
3b508ca293 0.1.1 2026-02-12 11:48:09 +08:00
Lauren ten Hoor
fe3486b647 fix: correct npm package entry point and include manifest file 2026-02-12 11:48:05 +08:00
Lauren ten Hoor
3d3d1cc2e4 fix: update installation commands to reflect new package name 2026-02-12 00:42:15 +08:00
Lauren ten Hoor
a4312c886a fix: update package name and URLs to reflect new ownership 2026-02-12 00:32:35 +08:00
Lauren ten Hoor
e4b54646da refactor: remove context awareness documentation and related code; streamline tool registration and context detection 2026-02-12 00:25:34 +08:00
Lauren ten Hoor
dc3a7fcf9e Merge pull request #131 from laurentenhoor/feat/130-npm-publish
feat: set up npm publishing infrastructure
2026-02-12 00:14:33 +08:00