package controllers import ( "encoding/json" "eta/eta_index_lib/logic" "eta/eta_index_lib/models" "eta/eta_index_lib/services" "eta/eta_index_lib/utils" "strconv" "strings" "time" ) // PbFinanceController 彭博财务 type PbFinanceController struct { BaseAuthController } // @Title 新增彭博指标接口 // @Description 新增彭博指标接口 // @Success 200 {object} models.AddEdbInfoReq // @router /add [post] func (this *PbFinanceController) Add() { br := new(models.BaseResponse).Init() var cacheKey string defer func() { this.Data["json"] = br this.ServeJSON() }() source := utils.DATA_SOURCE_PB_FINANCE var req models.AddEdbInfoReq err := json.Unmarshal(this.Ctx.Input.RequestBody, &req) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.EdbCode == "" { br.Msg = "请输入指标编码!" br.ErrMsg = "请输入指标编码,指标编码为空" return } cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode if !utils.Rc.IsExist(cacheKey) { utils.Rc.SetNX(cacheKey, 1, 1*time.Minute) defer func() { utils.Rc.Delete(cacheKey) }() //指标编码处理,将指标编码拆分成 company_code和edb_code edbCode := req.EdbCode edbCodeArr := strings.Split(edbCode, "&&") if len(edbCodeArr) != 2 { br.Msg = "指标编码异常,请传入客户编码!" br.ErrMsg = "指标编码异常,请传入客户编码" return } dataItem, err := services.GetEdbDataFromPbFinance(edbCodeArr[0], edbCodeArr[1], utils.BASE_START_DATE_UnSpace, utils.BASE_END_DATE_UnSpace, "") if err != nil { br.Msg = "获取指标信息失败!" br.ErrMsg = "获取指标信息失败 GetEdbDataFromPb,Err:" + err.Error() return } err = models.AddEdbDataFromPbFinance(req.EdbCode, dataItem) if err != nil { br.Msg = "获取指标信息失败!" br.ErrMsg = "获取指标信息失败 AddEdbDataFromPb,Err:" + err.Error() return } br.Ret = 200 br.Success = true br.Msg = "获取成功" } else { br.Ret = 501 br.Success = true br.Msg = "系统处理中,请稍后重试" } } // @Title 刷新彭博指标接口 // @Description 刷新彭博指标接口 // @Success 200 {object} models.RefreshEdbInfoReq // @router /refresh [post] func (this *PbFinanceController) Refresh() { br := new(models.BaseResponse).Init() var cacheKey string defer func() { this.Data["json"] = br this.ServeJSON() }() source := utils.DATA_SOURCE_PB_FINANCE var req models.RefreshEdbInfoReq err := json.Unmarshal(this.Ctx.Input.RequestBody, &req) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.EdbCode == "" { br.Msg = "请输入指标编码!" br.ErrMsg = "请输入指标编码,指标编码为空" return } if req.EdbInfoId <= 0 { br.Msg = "请输入指标ID!" br.ErrMsg = "请输入指标ID" return } // 获取指标详情 edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode) if err != nil { br.Msg = "指标不存在!" br.ErrMsg = "指标不存在" return } cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode if utils.Rc.IsExist(cacheKey) { br.Ret = 501 br.Success = true br.Msg = "系统处理中,请稍后重试" return } utils.Rc.SetNX(cacheKey, 1, 1*time.Minute) defer func() { utils.Rc.Delete(cacheKey) }() //开始日期格式化 startDateTime, _ := time.ParseInLocation(utils.FormatDate, req.StartDate, time.Local) //指标编码处理,将指标编码拆分成 company_code和edb_code edbCode := req.EdbCode edbCodeArr := strings.Split(edbCode, "&&") if len(edbCodeArr) != 2 { br.Msg = "指标编码异常,请传入客户编码!" br.ErrMsg = "指标编码异常,请传入客户编码" return } dataItem, err := services.GetEdbDataFromPbFinance(edbCodeArr[0], edbCodeArr[1], startDateTime.Format(utils.FormatDateUnSpace), utils.BASE_END_DATE_UnSpace, edbInfo.TerminalCode) if err != nil { br.Msg = "获取指标信息失败!" br.ErrMsg = "获取指标信息失败 GetEdbDataFromPb,Err:" + err.Error() return } err = models.RefreshEdbDataFromPbFinance(req.EdbInfoId, req.EdbCode, req.StartDate, dataItem) if err != nil && err.Error() != utils.ErrNoRow() { br.Msg = "刷新指标信息失败!" br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromPb,Err:" + err.Error() return } // 更新指标最大最小值 err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo) if err != nil { br.Msg = errMsg br.ErrMsg = err.Error() return } // 更新ES go logic.UpdateEs(edbInfo.EdbInfoId) br.Ret = 200 br.Success = true br.Msg = "获取成功" }