郑伯涛
d2a91effef
fix(task): 修复使用 auto 分组时 Task Relay 不记录日志和不扣费的问题
问题描述:
- 使用 auto 分组的令牌调用 /v1/videos 等 Task 接口时,虽然任务能成功创建,
但使用日志不显示记录,且不会扣费
根本原因:
- Distribute 中间件在选择渠道后,会将实际选中的分组存储在 ContextKeyAutoGroup 中
- 但 RelayTaskSubmit 函数没有从 context 中读取这个值来更新 info.UsingGroup
- 导致 info.UsingGroup 始终是 "auto" 而不是实际选中的分组(如 "sora2逆")
- 当 auto 分组的倍率配置为 0 时,quota 计算结果为 0
- 日志记录条件 "if quota != 0" 不满足,导致日志不记录、不扣费
修复方案:
- 在 RelayTaskSubmit 函数中计算分组倍率之前,添加从 ContextKeyAutoGroup
获取实际分组的逻辑
- 使用安全的类型断言,避免潜在的 panic 风险
影响范围:
- 仅影响 Task Relay 流程(/v1/videos, /suno, /kling 等接口)
- 不影响使用具体分组令牌的调用
- 不影响其他 Relay 类型(chat/completions 等已有类似处理逻辑)
2026-01-06 00:16:50 +08:00
..
2026-01-05 17:56:24 +08:00
2026-01-03 10:27:16 +08:00
2025-12-02 21:34:39 +08:00
2025-08-16 18:26:26 +08:00
2025-12-13 13:29:21 +08:00
2025-12-29 23:00:17 +08:00
2025-11-22 18:27:17 +08:00
2025-12-31 21:29:10 +08:00
2025-12-29 23:00:17 +08:00
2025-12-29 23:00:17 +08:00
2025-12-29 23:00:17 +08:00
2025-10-13 22:25:39 +08:00
2025-11-14 11:55:43 +08:00
2026-01-06 00:16:50 +08:00
2025-12-29 23:00:17 +08:00
2025-12-29 23:00:17 +08:00
2025-10-11 15:30:09 +08:00