123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460 |
- 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
- }
|