Version: 0.7.1.dev.260320

🧠 agent智能编排:删除了落库相关逻辑。再次重申:agent智能编排旨在为用户预览排程结果,实际的落库由用户决定,并通过按钮触发常规接口进行落库。目前仅保留 ReAct 精排循环链路(待改进)。
📄 修改了 ReAct 智能精排决策文档相关内容。
🔄 undo:当前 agent 智能排程逻辑待改进。
This commit is contained in:
LoveLosita
2026-03-20 19:40:11 +08:00
parent d3cec2a5b9
commit 059b25872a
12 changed files with 115 additions and 661 deletions

View File

@@ -18,22 +18,10 @@ type SchedulePlanToolDeps struct {
// SmartPlanningRaw 调用粗排算法,同时返回展示结构和已分配的任务项。
// 返回值:
// - []UserWeekSchedule展示型结构供 SSE 阶段推送给前端预览;
// - []TaskClassItem已分配的任务项EmbeddedTime 已回填),供 materialize 直接转换
// - []TaskClassItem已分配的任务项EmbeddedTime 已回填),供 ReAct 精排使用
SmartPlanningRaw func(ctx context.Context, userID, taskClassID int) ([]model.UserWeekSchedule, []model.TaskClassItem, error)
// BatchApplyPlans 将排程方案批量落库。
// 输入taskClassID、userID、落库请求体。
// 输出errornil 表示全部成功)。
BatchApplyPlans func(ctx context.Context, taskClassID, userID int, plans *model.UserInsertTaskClassItemToScheduleRequestBatch) error
// GetTaskClassByID 获取任务类详情(含关联的 Items
// 用于:
// 1) 校验 task_class_id 合法性;
// 2) 获取 Items 列表,为连续对话微调提供上下文。
GetTaskClassByID func(ctx context.Context, taskClassID, userID int) (*model.TaskClass, error)
// HybridScheduleWithPlan 构建混合日程(既有日程 + 粗排建议),供 ReAct 精排使用。
// 可选依赖:未注入时 ReAct 精排阶段不可用,走原有 materialize 路径。
HybridScheduleWithPlan func(ctx context.Context, userID, taskClassID int) ([]model.HybridScheduleEntry, []model.TaskClassItem, error)
}
@@ -42,11 +30,8 @@ func (d SchedulePlanToolDeps) validate() error {
if d.SmartPlanningRaw == nil {
return errors.New("schedule plan tool deps: SmartPlanningRaw is nil")
}
if d.BatchApplyPlans == nil {
return errors.New("schedule plan tool deps: BatchApplyPlans is nil")
}
if d.GetTaskClassByID == nil {
return errors.New("schedule plan tool deps: GetTaskClassByID is nil")
if d.HybridScheduleWithPlan == nil {
return errors.New("schedule plan tool deps: HybridScheduleWithPlan is nil")
}
return nil
}