106 lines
4.1 KiB
Markdown
106 lines
4.1 KiB
Markdown
# WORKFLOW_SCRIPTS — 工作流自动化
|
||
|
||
> Feature Flag: `FEATURE_WORKFLOW_SCRIPTS=1`
|
||
> 实现状态:全部 Stub(7 个文件),布线完整
|
||
> 引用数:10
|
||
|
||
## 一、功能概述
|
||
|
||
WORKFLOW_SCRIPTS 实现基于文件的多步自动化工作流。用户可以定义 YAML/JSON 格式的工作流描述文件,系统将其解析为可执行的多 agent 步骤序列。提供 `/workflows` 命令管理和触发工作流。
|
||
|
||
## 二、实现架构
|
||
|
||
### 2.1 模块状态
|
||
|
||
| 模块 | 文件 | 状态 |
|
||
|------|------|------|
|
||
| WorkflowTool | `src/tools/WorkflowTool/WorkflowTool.ts` | **Stub** — 空对象 |
|
||
| Workflow 权限 | `src/tools/WorkflowTool/WorkflowPermissionRequest.ts` | **Stub** — 返回 null |
|
||
| 常量 | `src/tools/WorkflowTool/constants.ts` | **Stub** — 空工具名 |
|
||
| 命令创建 | `src/tools/WorkflowTool/createWorkflowCommand.ts` | **Stub** — 空操作 |
|
||
| 捆绑工作流 | `src/tools/WorkflowTool/bundled/` | **缺失** — 目录不存在 |
|
||
| 本地工作流任务 | `src/tasks/LocalWorkflowTask/LocalWorkflowTask.ts` | **Stub** — 类型 + 空操作 |
|
||
| UI 任务组件 | `src/components/tasks/src/tasks/LocalWorkflowTask/` | **Stub** — 空导出 |
|
||
| 详情对话框 | `src/components/tasks/WorkflowDetailDialog.ts` | **Stub** — 返回 null |
|
||
| 任务注册 | `src/tasks.ts` | **布线** — 动态加载 |
|
||
| 工具注册 | `src/tools.ts` | **布线** — 包含 bundled 工作流初始化 |
|
||
| 命令注册 | `src/commands.ts` | **布线** — `/workflows` 命令 |
|
||
|
||
### 2.2 预期数据流
|
||
|
||
```
|
||
用户定义工作流(YAML/JSON 文件)
|
||
│
|
||
▼
|
||
/workflows 命令发现工作流文件
|
||
│
|
||
▼
|
||
createWorkflowCommand() 解析为 Command 对象 [需要实现]
|
||
│
|
||
▼
|
||
WorkflowTool 执行工作流 [需要实现]
|
||
│
|
||
├── 步骤 1: Agent({ task: "..." })
|
||
├── 步骤 2: Agent({ task: "..." })
|
||
└── 步骤 N: Agent({ task: "..." })
|
||
│
|
||
▼
|
||
LocalWorkflowTask 协调步骤执行 [需要实现]
|
||
│
|
||
▼
|
||
WorkflowDetailDialog 显示进度 [需要实现]
|
||
```
|
||
|
||
### 2.3 预期工作流 DSL
|
||
|
||
```
|
||
# workflow.yaml(预期格式,需要设计)
|
||
name: "代码审查工作流"
|
||
steps:
|
||
- name: "静态分析"
|
||
agent: { type: "general-purpose", prompt: "运行 lint 和类型检查" }
|
||
- name: "测试"
|
||
agent: { type: "general-purpose", prompt: "运行测试套件" }
|
||
- name: "综合报告"
|
||
agent: { type: "general-purpose", prompt: "综合分析结果写报告" }
|
||
```
|
||
|
||
## 三、需要补全的内容
|
||
|
||
| 优先级 | 模块 | 工作量 | 说明 |
|
||
|--------|------|--------|------|
|
||
| 1 | `WorkflowTool.ts` | 大 | Schema 定义 + 多步执行引擎 |
|
||
| 2 | `bundled/index.js` | 中 | 内置工作流定义(initBundledWorkflows) |
|
||
| 3 | `createWorkflowCommand.ts` | 中 | 从文件解析创建命令对象 |
|
||
| 4 | `LocalWorkflowTask.ts` | 大 | 步骤协调、kill/skip/retry |
|
||
| 5 | `WorkflowDetailDialog.ts` | 中 | 进度详情 UI |
|
||
| 6 | `WorkflowPermissionRequest.ts` | 小 | 权限对话框 |
|
||
| 7 | `constants.ts` | 小 | 工具名常量 |
|
||
|
||
## 四、关键设计决策
|
||
|
||
1. **基于文件的 DSL**:工作流定义为文件(YAML/JSON),版本控制友好
|
||
2. **多 Agent 步骤**:每个步骤是独立的 agent 任务,支持并行/串行
|
||
3. **内置工作流**:`bundled/` 目录提供开箱即用的常用工作流
|
||
4. **/workflows 命令**:统一的发现和触发入口
|
||
|
||
## 五、使用方式
|
||
|
||
```bash
|
||
# 启用 feature(需要补全后才能真正使用)
|
||
FEATURE_WORKFLOW_SCRIPTS=1 bun run dev
|
||
```
|
||
|
||
## 六、文件索引
|
||
|
||
| 文件 | 职责 |
|
||
|------|------|
|
||
| `src/tools/WorkflowTool/WorkflowTool.ts` | 工具定义(stub) |
|
||
| `src/tools/WorkflowTool/WorkflowPermissionRequest.ts` | 权限对话框(stub) |
|
||
| `src/tools/WorkflowTool/constants.ts` | 常量(stub) |
|
||
| `src/tools/WorkflowTool/createWorkflowCommand.ts` | 命令创建(stub) |
|
||
| `src/tasks/LocalWorkflowTask/LocalWorkflowTask.ts` | 任务协调(stub) |
|
||
| `src/components/tasks/WorkflowDetailDialog.ts` | 详情对话框(stub) |
|
||
| `src/tools.ts:127-132` | 工具注册 |
|
||
| `src/commands.ts:86-89` | 命令注册 |
|