package data_stat import ( "encoding/json" "eta/eta_api/controllers" "eta/eta_api/models" "eta/eta_api/models/data_manage" "eta/eta_api/services/data_stat" "eta/eta_api/utils" "fmt" "strconv" "github.com/rdlucklib/rdluck_tools/paging" ) // EdbTerminalController 数据源终端管理 type EdbTerminalController struct { controllers.BaseAuthController } // Save // @Title 保存数据源终端 // @Description 保存数据源终端接口 // @Param request body true data_manage.AddEdbTerminalListReq "type json string" // @Success 200 string "操作成功" // @router /terminal/save [post] func (this *EdbTerminalController) Save() { br := new(models.BaseResponse).Init() br.IsSendEmail = false defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } var req *data_manage.AddEdbTerminalListReq if err := json.Unmarshal(this.Ctx.Input.RequestBody, &req); err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.Name == "" { br.Msg = "请输入终端名称" return } /*if req.ServerUrl == "" && req.Value == "" { br.Msg = "请输入终端地址或者token" return }*/ if req.Num <= 0 { br.Msg = "请输入指标数据量" return } if req.Source == 0 { br.Msg = "请输入终端类型" return } // todo 校验终端数据 errMsg, err := data_stat.SaveEdbTerminal(req) if err != nil { br.Msg = errMsg br.ErrMsg = "SaveEnglishVideoCover ErrMsg:" + err.Error() return } br.Ret = 200 br.Success = true br.Msg = "操作成功" return } // SetStatus // @Title 启用/禁用数据源终端 // @Description 启用/禁用数据源终端 // @Param request body true data_manage.SetEdbTerminalStatusReq "type json string" // @Success 200 string "操作成功" // @router /terminal/status/set [post] func (this *EdbTerminalController) SetStatus() { br := new(models.BaseResponse).Init() br.IsSendEmail = false defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } var req *data_manage.SetEdbTerminalStatusReq if err := json.Unmarshal(this.Ctx.Input.RequestBody, &req); err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.TerminalId <= 0 { br.Msg = "请选择要操作的终端" return } if req.Status != 1 && req.Status != 2 { br.Msg = "请选择正确的终端状态" return } errMsg, err := data_stat.SetEdbTerminalStatus(req.TerminalId, req.Status) if err != nil { br.Msg = errMsg br.ErrMsg = "SetEdbTerminalStatus ErrMsg:" + err.Error() return } br.Ret = 200 br.Success = true br.Msg = "操作成功" return } // List // @Title 数据源终端列表 // @Description 数据源终端列表接口 // @Success 200 {object} data_manage.EdbTerminalLisResp // @router /terminal/list [get] func (this *EdbTerminalController) List() { br := new(models.BaseResponse).Init() br.IsSendEmail = false defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } source, _ := this.GetInt("Source") list, err := data_manage.GetEdbTerminalList(source) if err != nil { br.Msg = "获取终端列表失败" br.ErrMsg = "获取终端列表失败 ErrMsg:" + err.Error() return } // 计算已使用额度 // 根据source查找对应的终端信息,比如source为34,则查询对应的数据源里的指标 // 获取数据源详细信息 for _, v := range list { num, subNumList, err := data_manage.GetIndexNumBySource(v.Source, v.TerminalCode) if err != nil { br.Msg = "获取终端列表失败" br.ErrMsg = "获取终端列表失败 ErrMsg:" + err.Error() return } v.UsedQuota = strconv.Itoa(num) if v.Source == utils.DATA_SOURCE_THS { edbNum := 0 dateNum := 0 hfNum := 0 for _, subNum := range subNumList { if subNum.SubSource == utils.DATA_SUB_SOURCE_HIGH_FREQUENCY { hfNum = subNum.Num } else if subNum.SubSource == utils.DATA_SUB_SOURCE_EDB { edbNum = subNum.Num } else if subNum.SubSource == utils.DATA_SUB_SOURCE_DATE { dateNum = subNum.Num } } v.UsedQuota = fmt.Sprintf("EDB:%d\n日期序列:%d\n高频序列:%d", edbNum, dateNum, hfNum) }else if v.Source == utils.DATA_SOURCE_WIND { edbNum := 0 dateNum := 0 for _, subNum := range subNumList { if subNum.SubSource == utils.DATA_SUB_SOURCE_EDB { edbNum = subNum.Num } else if subNum.SubSource == utils.DATA_SUB_SOURCE_DATE { dateNum = subNum.Num } } v.UsedQuota = fmt.Sprintf("EDB:%d\n日期序列:%d", edbNum, dateNum) }else if len(subNumList) == 1 { v.UsedQuota = strconv.Itoa(subNumList[0].Num) } } resp := &data_manage.EdbTerminalListResp{ List: list, } br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // TerminalCodeList // @Title 数据源终端列表 // @Description 数据源终端列表接口 // @Success 200 {object} data_manage.EdbTerminalCodeResp // @router /terminal/code [get] func (this *EdbTerminalController) TerminalCodeList() { br := new(models.BaseResponse).Init() br.IsSendEmail = false defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } source, _ := this.GetInt("Source", utils.DATA_SOURCE_MYSTEEL_CHEMICAL) list, err := data_manage.GetEdbTerminalBySource(source) if err != nil { br.Msg = "获取终端列表失败" br.ErrMsg = "获取终端列表失败 ErrMsg:" + err.Error() return } codeList := make([]*data_manage.EdbTerminalCode, 0) if len(list) > 0 { for _, v := range list { tmp := new(data_manage.EdbTerminalCode) tmp.TerminalCode = v.TerminalCode tmp.Source = v.Source tmp.Name = v.Name codeList = append(codeList, tmp) } } resp := &data_manage.EdbTerminalCodeResp{ List: codeList, } br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // TerminalIndexDirInfo // @Title 获取指标终端文件夹信息 // @Description 获取指标终端文件夹信息 // @Success 200 {object} data_manage.EdbTerminalDirInfo // @router /terminal/index_dir [get] func (this *EdbTerminalController) TerminalIndexDirInfo() { br := new(models.BaseResponse).Init() br.IsSendEmail = false defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } source, _ := this.GetInt("Source") indexId, _ := this.GetInt("IndexId") if source <= 0 || indexId <= 0 { br.Msg = "请选择数据源和指标ID" return } info := new(data_manage.EdbTerminalDirInfo) var err error info, err = data_stat.GetEdbTerminalDirInfo(indexId, source) if err != nil { utils.FileLog.Info(fmt.Sprintf("获取终端文件夹信息失败indexId:%d,source:%d,Err:%s", indexId, source, err.Error())) //br.Msg = "获取终端文件夹信息失败" //br.ErrMsg = "获取终端文件夹信息失败 ErrMsg:" + err.Error() //return } br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = info } // 查询指标列表 // @Title 查询指标列表接口 // @Description 查询指标列表接口 // @Success Ret=200 获取成功 // @router /terminal/edb_info/list [get] func (c *EdbTerminalController) GetEdbInfoList() { br := new(models.BaseResponse).Init() defer func() { c.Data["json"] = br c.ServeJSON() }() source, _ := c.GetInt("Source") terminalCode := c.GetString("TerminalCode") keyword := c.GetString("Keyword") pageSize, _ := c.GetInt("PageSize") currentIndex, _ := c.GetInt("CurrentIndex") if pageSize <= 0 { pageSize = utils.PageSize20 } if currentIndex <= 0 { currentIndex = 1 } if source <= 0 { br.Msg = "来源不能为空" br.ErrMsg = "来源不能为空" br.IsSendEmail = false return } condition := `` var pars []interface{} condition += " AND e.source = ?" pars = append(pars, source) if terminalCode != "" { condition += " AND e.terminal_code = ?" pars = append(pars, terminalCode) } if keyword != "" { condition += " AND (e.edb_name like ? or e.edb_code like ?)" pars = append(pars, "%"+keyword+"%") pars = append(pars, "%"+keyword+"%") } list, err := data_manage.GetSimpleEdbListPageByCondition(condition, pars, currentIndex, pageSize) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } count, err := data_manage.GetSimpleEdbListCountByCondition(condition, pars) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } page := paging.GetPaging(currentIndex, pageSize, int(count)) br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = map[string]interface{}{ "List": list, "Paging": page, } return } // 设置指标终端 // @Title 设置指标终端 // @Description 设置指标终端 // @Success 200 string "操作成功" // @router /terminal/edb_info/set [post] func (c *EdbTerminalController) SetEdbInfoTerminal() { br := new(models.BaseResponse).Init() br.IsSendEmail = false defer func() { c.Data["json"] = br c.ServeJSON() }() sysUser := c.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } var req *data_manage.SetEdbInfoTerminalReq if err := json.Unmarshal(c.Ctx.Input.RequestBody, &req); err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.Source <= 0 { br.Msg = "来源不能为空" br.ErrMsg = "来源不能为空" return } if req.TerminalCode == "" { br.Msg = "终端编码不能为空" br.ErrMsg = "终端编码不能为空" return } if len(req.EdbInfoIds) <= 0 { br.Msg = "指标ID不能为空" br.ErrMsg = "指标ID不能为空" return } // 校验终端编码是否存在 terminal, err := data_manage.GetEdbTerminalByTerminalCode(req.TerminalCode) if err != nil { br.Msg = "终端编码不存在" br.ErrMsg = "终端编码不存在" return } if req.Source != terminal.Source { br.Msg = "终端来源不匹配" br.ErrMsg = "终端来源不匹配" return } // 更新指标的终端编码 condition := " and e.edb_info_id in (?) and e.source = ?" pars := []interface{}{req.EdbInfoIds, req.Source} count, err := data_manage.GetSimpleEdbListCountByCondition(condition, pars) if err != nil { br.Msg = "设置失败" br.ErrMsg = "设置失败,Err:" + err.Error() return } if count <= 0 { br.Msg = "指标ID不存在" br.ErrMsg = "指标ID不存在" return } if len(req.EdbInfoIds) != int(count) { br.Msg = "指标和数据源不匹配" br.ErrMsg = "指标和数据源不匹配" return } // 更新指标的终端编码 err = data_manage.UpdateEdbInfoTerminal(req.EdbInfoIds, req.TerminalCode, req.Source) if err != nil { br.Msg = "设置失败" br.ErrMsg = "设置失败,Err:" + err.Error() return } br.Ret = 200 br.Success = true br.Msg = "设置成功" return }