73b1696b0a
为节点新增 auto_online 字段与后台同步任务, 仅对开启托管的节点按在线状态自动同步前台显示。 管理端补齐单节点与批量开关、列表标识与统计, 并在自动上线启用时禁用手动显隐切换。 后端新增定时命令、保存校验、批量更新支持、 数据库迁移与单元测试,保证托管逻辑可落地。
5.4 KiB
5.4 KiB
任务清单: admin-frontend-node-auto-online
@status: completed | 2026-04-27 23:56
@feature: admin-frontend-node-auto-online
@created: 2026-04-27
@status: completed
@mode: R2
@workflow: INTERACTIVE
@complexity: complex
LIVE_STATUS
{"status":"completed","completed":9,"failed":0,"pending":0,"total":9,"percent":100,"current":"节点自动上线功能已实现,前端构建通过,PHP 验证待具备 PHP 的环境补跑","updated_at":"2026-04-27 23:52:00"}
进度概览
| 完成 | 失败 | 跳过 | 总数 |
|---|---|---|---|
| 9 | 0 | 0 | 9 |
任务列表
1. 后端数据与同步机制
-
[√] 1.1 新增
database/migrations/*_add_auto_online_to_v2_server_table.php- 预期变更: 为
v2_server增加auto_online布尔字段,默认false,down 可回滚字段。 - 完成标准: 迁移文件存在,字段名、默认值和回滚逻辑明确。
- 验证方式:
php -l database/migrations/*_add_auto_online_to_v2_server_table.php - depends_on: []
- 预期变更: 为
-
[√] 1.2 修改
app/Models/Server.php- 预期变更: 增加
auto_online属性注释和 boolean cast,保持现有在线状态访问器与墙状态关系不变。 - 完成标准:
ServerJSON/API 输出包含auto_online,现有gfwChecks()不被移除。 - 验证方式:
php -l app/Models/Server.php - depends_on: [1.1]
- 预期变更: 增加
-
[√] 1.3 新增
app/Services/ServerAutoOnlineService.php- 预期变更: 封装自动上线同步逻辑,只处理
auto_online=true的节点,在线/待同步写show=true,离线写show=false。 - 完成标准: 服务返回同步统计,跳过未托管节点,不引入生产外部副作用。
- 验证方式:
php -l app/Services/ServerAutoOnlineService.php - depends_on: [1.2]
- 预期变更: 封装自动上线同步逻辑,只处理
-
[√] 1.4 新增命令并接入调度
app/Console/Commands/SyncServerAutoOnline.php,app/Console/Kernel.php- 预期变更: 新增
sync:server-auto-online命令,每 5 分钟调度,使用onOneServer()与withoutOverlapping()。 - 完成标准: 命令可调用服务并输出统计,调度不影响现有任务。
- 验证方式:
php -l app/Console/Commands/SyncServerAutoOnline.php;php -l app/Console/Kernel.php - depends_on: [1.3]
- 预期变更: 新增
2. 后端 API 契约
- [√] 2.1 修改
app/Http/Requests/Admin/ServerSave.php与app/Http/Controllers/V2/Admin/Server/ManageController.php- 预期变更:
save、update、batchUpdate支持auto_online,批量更新保持字段显式传入才更新。 - 完成标准: 手动显隐字段
show和自动上线字段auto_online可独立保存。 - 验证方式:
php -l app/Http/Requests/Admin/ServerSave.php;php -l app/Http/Controllers/V2/Admin/Server/ManageController.php - depends_on: [1.2]
- 预期变更:
3. 管理端前端
-
[√] 3.1 修改
admin-frontend/src/types/api.d.ts,admin-frontend/src/utils/nodeEditorOptions.ts,admin-frontend/src/utils/nodeEditorMapper.ts- 预期变更: 类型、表单模型、默认值、编辑回填和保存 payload 支持
auto_online。 - 完成标准: 新建默认关闭,编辑能正确回填,保存能提交布尔值。
- 验证方式:
npm run build - depends_on: [2.1]
- 预期变更: 类型、表单模型、默认值、编辑回填和保存 payload 支持
-
[√] 3.2 修改
admin-frontend/src/views/nodes/NodeEditorDialog.vue,NodeBatchEditDialog.vue,NodesView.vue,admin-frontend/src/utils/nodes.ts- 预期变更: 编辑弹窗和批量修改弹窗增加自动上线开关;节点表格展示自动托管状态;现有墙状态检测 UI 保持可用。
- 完成标准: 管理员可单节点和批量设置
auto_online;未开启批量字段时不覆盖。 - 验证方式:
npm run build - depends_on: [3.1]
4. 知识库与验收
-
[√] 4.1 新增
tests/Unit/ServerAutoOnlineServiceTest.php- 预期变更: 覆盖自动上线服务只同步托管节点、在线显示、离线隐藏、手动节点不受影响。
- 完成标准: 测试用例能表达核心业务边界。
- 验证方式:
php artisan test --filter=ServerAutoOnlineServiceTest - depends_on: [1.3]
-
[√] 4.2 更新
.helloagents/context.md,.helloagents/modules/*,.helloagents/CHANGELOG.md- 预期变更: 同步记录节点自动上线能力、后端命令和管理端节点页行为。
- 完成标准: 知识库反映代码事实,CHANGELOG 包含方案链接和决策 ID。
- 验证方式: 人工检查文档条目与本次改动一致。
- depends_on: [1.4, 2.1, 3.2, 4.1]
执行日志
| 时间 | 任务 | 状态 | 备注 |
|---|---|---|---|
| 2026-04-27 23:38 | DESIGN | in_progress | 用户选择方案 A,方案包创建并进入开发实施 |
| 2026-04-27 23:45 | DEVELOP | in_progress | 完成后端 auto_online 字段、服务、命令和 API 扩展 |
| 2026-04-27 23:48 | DEVELOP | in_progress | 完成管理端节点表格、编辑弹窗与批量修改自动上线开关 |
| 2026-04-27 23:50 | VERIFY | warning | npm run build 通过;当前环境缺少 php,PHP 语法检查和 PHPUnit 未执行 |
| 2026-04-27 23:52 | KB | completed | context、admin-frontend 模块索引和 CHANGELOG 已同步 |
执行备注
- 当前工作树已有节点墙状态检测相关未提交改动,本任务必须保留并兼容这些改动。
- 按上级工具约束,本轮不调度子代理,复杂任务由主代理直接实施并在验收中说明。
- PHP 命令在当前环境不可用,需在具备 PHP/Composer 的环境补跑
php -l与php artisan test --filter=ServerAutoOnlineServiceTest。