package dto import ( "gitea.com/red-future/common/beans" "github.com/gogf/gf/v2/frame/g" ) // CreateModelReq 添加模型配置 type CreateModelReq struct { g.Meta `path:"/createModel" method:"post" tags:"模型管理" summary:"创建模型配置" dc:"添加新的模型配置"` ModelName string `p:"modelName" json:"modelName" v:"required#modelName不能为空" dc:"模型名称(唯一标识)"` ModelsType string `p:"modelsType" json:"modelsType" dc:"模型类型ID列表(逗号分隔),示例:1,2,3(关联 asynch_models_type.type_id,可选)"` BaseURL string `p:"baseUrl" json:"baseUrl" v:"required#baseUrl不能为空" dc:"模型服务基础地址(如 http(s)://host:port)"` Route string `p:"route" json:"route" dc:"路由/路径(拼接到 BaseURL 之后的可选路径)"` HttpMethod string `p:"httpMethod" json:"httpMethod" dc:"请求方式:GET/POST(默认POST)"` HeadMsg string `p:"headMsg" json:"headMsg" dc:"请求头绑定(支持多个,逗号分隔),示例:X-API-Key:xxx,operation:true"` Form any `p:"form" json:"form" dc:"动态表单配置(JSON),用于前端渲染配置项,示例:[{field,label,type,required},...]"` Enabled int `p:"enabled" json:"enabled" dc:"是否启用:0-禁用,1-启用"` MaxConcurrency int `p:"maxConcurrency" json:"maxConcurrency" dc:"最大并发数"` QueueLimit int `p:"queueLimit" json:"queueLimit" dc:"排队队列上限(超过则拒绝/限流)"` TimeoutSeconds int `p:"timeoutSeconds" json:"timeoutSeconds" dc:"请求超时时间(秒)"` ExpectedSeconds int `p:"expectedSeconds" json:"expectedSeconds" dc:"模型预计执行时间(秒,用于超时判定/排队策略等)"` RetryTimes int `p:"retryTimes" json:"retryTimes" dc:"失败重试次数"` RetryQueueMaxSeconds int `p:"retryQueueMaxSeconds" json:"retryQueueMaxSeconds" dc:"失败重试最大排队时间(秒);0表示失败重试插队到队首;>0表示排队超过该时间后插队,否则仍到队尾"` AutoCleanSeconds int `p:"autoCleanSeconds" json:"autoCleanSeconds" dc:"自动清理间隔(秒)(如清理超时任务/队列)"` Remark string `p:"remark" json:"remark" dc:"备注说明"` } type CreateModelRes struct { ID int64 `json:"id,string" dc:"配置ID"` } // UpdateModelReq 更新模型配置 type UpdateModelReq struct { g.Meta `path:"/updateModel" method:"put" tags:"模型管理" summary:"更新模型配置" dc:"更新指定ID的模型配置"` ID int64 `p:"id" json:"id,string" v:"required#id不能为空" dc:"配置ID"` ModelsType *string `p:"modelsType" json:"modelsType" dc:"模型类型ID列表(逗号分隔)(可选更新)"` BaseURL string `p:"baseUrl" json:"baseUrl" dc:"模型服务基础地址"` Route string `p:"route" json:"route" dc:"路由/路径"` HttpMethod *string `p:"httpMethod" json:"httpMethod" dc:"请求方式:GET/POST(可选更新)"` HeadMsg *string `p:"headMsg" json:"headMsg" dc:"请求头绑定(可选更新)"` Form any `p:"form" json:"form" dc:"动态表单配置(JSON)(可选更新)"` Enabled *int `p:"enabled" json:"enabled" dc:"是否启用:0-禁用,1-启用(可选更新)"` MaxConcurrency *int `p:"maxConcurrency" json:"maxConcurrency" dc:"最大并发数(可选更新)"` QueueLimit *int `p:"queueLimit" json:"queueLimit" dc:"排队队列上限(可选更新)"` TimeoutSeconds *int `p:"timeoutSeconds" json:"timeoutSeconds" dc:"请求超时时间(秒)(可选更新)"` ExpectedSeconds *int `p:"expectedSeconds" json:"expectedSeconds" dc:"模型预计执行时间(秒)(可选更新)"` RetryTimes *int `p:"retryTimes" json:"retryTimes" dc:"失败重试次数(可选更新)"` RetryQueueMaxSeconds *int `p:"retryQueueMaxSeconds" json:"retryQueueMaxSeconds" dc:"失败重试最大排队时间(秒)(可选更新)"` AutoCleanSeconds *int `p:"autoCleanSeconds" json:"autoCleanSeconds" dc:"自动清理间隔(秒)(可选更新)"` Remark *string `p:"remark" json:"remark" dc:"备注说明(可选更新)"` } // DeleteModelReq 删除模型配置 type DeleteModelReq struct { g.Meta `path:"/deleteModel" method:"delete" tags:"模型管理" summary:"删除模型配置" dc:"删除指定ID的模型配置"` ID int64 `p:"id" json:"id,string" v:"required#id不能为空" dc:"配置ID"` } // GetModelReq 获取模型配置详情 type GetModelReq struct { g.Meta `path:"/getModel" method:"get" tags:"模型管理" summary:"获取模型配置" dc:"根据模型名称获取配置详情"` ID int64 `p:"id" json:"id,string" v:"required#id不能为空" dc:"配置ID"` } type GetModelRes struct { Model any `json:"model" dc:"模型配置详情"` } // ListModelReq 配置列表 type ListModelReq struct { g.Meta `path:"/listModel" method:"post" tags:"模型管理" summary:"模型配置列表" dc:"分页获取模型配置列表"` Page *beans.Page `p:"page" json:"page" dc:"分页参数"` ModelName string `p:"modelName" json:"modelName" dc:"模型名称(模糊查询,可选)"` } type ListModelRes struct { List any `json:"list" dc:"列表数据"` Total int64 `json:"total" dc:"总数"` } // AutoTuneReq 动态调参(由上层定时任务每小时触发一次) type AutoTuneReq struct { g.Meta `path:"/autoTune" method:"post" tags:"模型管理" summary:"动态调参" dc:"按 model_name 维度统计指定时间窗口内执行耗时(P90),动态生成运行时 max_concurrency/queue_limit(不超过配置上限),写入 Redis 供 Worker/CreateTask 使用;windowSeconds 不传默认 3600"` WindowSeconds int `p:"windowSeconds" json:"windowSeconds" dc:"统计窗口秒数;不传/<=0 默认 3600(1小时)"` } type AutoTuneRes struct { List any `json:"list" dc:"调参结果列表"` }