123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789 |
- package data_manage
- import (
- "encoding/json"
- "eta_gn/eta_api/controllers"
- "eta_gn/eta_api/models"
- "eta_gn/eta_api/models/data_manage"
- "eta_gn/eta_api/models/data_manage/request"
- "eta_gn/eta_api/services/data"
- dataApproveSerice "eta_gn/eta_api/services/data/data_approve"
- "eta_gn/eta_api/services/elastic"
- "eta_gn/eta_api/utils"
- "github.com/rdlucklib/rdluck_tools/paging"
- "strconv"
- "strings"
- )
- // EdbPublicController 公共指标
- type EdbPublicController struct {
- controllers.BaseAuthController
- }
- // RemoveCheck
- // @Title 删除检测接口
- // @Description 删除检测接口
- // @Param request body data_manage.ClassifyDeleteCheckReq true "type json string"
- // @Success 200 Ret=200 检测成功
- // @router /edb_public/remove/check [post]
- func (c *EdbPublicController) RemoveCheck() {
- // TODO
- br := new(models.BaseResponse).Init()
- defer func() {
- c.Data["json"] = br
- c.ServeJSON()
- }()
- var req data_manage.ClassifyDeleteCheckReq
- err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if req.ClassifyId < 0 && req.EdbInfoId <= 0 {
- br.Msg = "参数错误"
- br.IsSendEmail = false
- return
- }
- deleteStatus, tipsMsg, tableList, err, errMsg := data.DeleteEdbPublicCheck(req.EdbInfoId, c.SysUser)
- if errMsg != `` {
- br.Msg = errMsg
- br.ErrMsg = errMsg
- if err != nil {
- br.ErrMsg = err.Error()
- } else {
- br.IsSendEmail = false
- }
- return
- }
- if c.Lang == "en" {
- if utils.ViperConfig.InConfig(tipsMsg) {
- tipsMsg = utils.ViperConfig.GetString(tipsMsg)
- }
- }
- //var deleteStatus int
- //var tipsMsg string
- ////删除公共分类
- //if req.ClassifyId > 0 && req.EdbInfoId == 0 {
- // //判断公共分类下,是否含有指标
- // count, err := data_manage.GetEdbInfoCountByClassifyId(req.ClassifyId)
- // if err != nil {
- // br.Msg = "删除失败"
- // br.ErrMsg = "公共分类下是否含有指标失败,Err:" + err.Error()
- // return
- // }
- //
- // if count > 0 {
- // deleteStatus = 1
- // tipsMsg = "若目录关联指标不可删除"
- // }
- //}
- //
- //if deleteStatus != 1 && req.EdbInfoId == 0 {
- // classifyCount, err := data_manage.GetClassifyCountByClassifyId(req.ClassifyId)
- // if err != nil && !utils.IsErrNoRow(err) {
- // br.Msg = "删除失败"
- // br.ErrMsg = "公共分类下是否含有指标失败,Err:" + err.Error()
- // return
- // }
- // if classifyCount > 0 {
- // deleteStatus = 2
- // tipsMsg = "确认删除当前目录及包含的子目录吗"
- // }
- //}
- //
- ////删除指标
- //if req.EdbInfoId > 0 {
- // //判断指标是否用于作图,如果用于作图,则不可删除
- // chartCount, err := data_manage.GetChartEdbMappingCount(req.EdbInfoId)
- // if err != nil && !utils.IsErrNoRow(err) {
- // br.Msg = "删除失败"
- // br.ErrMsg = "判断指标是否被用于作图失败,Err:" + err.Error()
- // return
- // }
- // if chartCount > 0 {
- // deleteStatus = 3
- // tipsMsg = "当前指标已用作画图,不可删除"
- // }
- // //判断指标是否用于计算
- // {
- // calculateCount, err := data_manage.GetEdbInfoCalculateMappingCount(req.EdbInfoId)
- // if err != nil && !utils.IsErrNoRow(err) {
- // br.Msg = "删除失败"
- // br.ErrMsg = "判断指标是否被用于计算失败,GetEdbInfoCalculateCount Err:" + err.Error()
- // return
- // }
- // if calculateCount > 0 {
- // deleteStatus = 4
- // tipsMsg = "当前指标已用作,指标运算,不可删除"
- // }
- // }
- //}
- resp := new(data_manage.ClassifyDeleteCheckResp)
- resp.DeleteStatus = deleteStatus
- resp.TipsMsg = tipsMsg
- resp.TableList = tableList
- br.Ret = 200
- br.Msg = "检测成功"
- br.Success = true
- br.Data = resp
- }
- // Remove
- // @Title 删除公共分类/指标
- // @Description 删除公共分类/指标接口
- // @Param request body data_manage.DeleteEdbClassifyReq true "type json string"
- // @Success 200 Ret=200 删除成功
- // @router /edb_public/remove [post]
- func (c *EdbPublicController) Remove() {
- // TODO
- br := new(models.BaseResponse).Init()
- 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.DeleteEdbClassifyReq
- err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if req.ClassifyId < 0 && req.EdbInfoId <= 0 {
- br.Msg = "参数错误"
- br.IsSendEmail = false
- return
- }
- nextItem, _, err, errMsg := data.Delete(req.ClassifyId, req.EdbInfoId, sysUser, string(c.Ctx.Input.RequestBody), c.Ctx.Input.URI())
- if errMsg != `` {
- br.Msg = errMsg
- br.ErrMsg = errMsg
- if err != nil {
- br.ErrMsg = err.Error()
- } else {
- br.IsSendEmail = false
- }
- return
- }
- resp := data_manage.AddEdbInfoResp{}
- if nextItem != nil {
- resp = data_manage.AddEdbInfoResp{
- EdbInfoId: nextItem.EdbInfoId,
- UniqueCode: nextItem.UniqueCode,
- }
- }
- br.Ret = 200
- br.Msg = "删除成功"
- br.Success = true
- br.IsAddLog = true
- br.Data = resp
- }
- // Save
- // @Title 单个指标设置公开
- // @Description 单个指标设置公开
- // @Param request body request.SetEdbInfoShareReq true "type json string"
- // @Success 200 {object} data_manage.EdbInfo
- // @router /edb_info/public/save [post]
- func (c *EdbPublicController) Save() {
- br := new(models.BaseResponse).Init()
- 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 request.SetEdbPublicReq
- err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if len(req.EdbInfoList) <= 0 {
- br.Msg = `请选择指标`
- br.IsSendEmail = false
- return
- }
- // 待处理的资产
- dataPublicItemList := make([]dataApproveSerice.SetDataPublicItem, 0)
- // 校验是否重复存在已公开、已提交的指标
- {
- edbInfoIdList := make([]int, 0)
- for _, item := range req.EdbInfoList {
- edbInfoIdList = append(edbInfoIdList, item.EdbInfoId)
- dataPublicItemList = append(dataPublicItemList, dataApproveSerice.SetDataPublicItem{
- DataId: item.EdbInfoId,
- ClassifyId: item.ClassifyId,
- })
- }
- list, err := data_manage.GetEdbInfoByIdList(edbInfoIdList)
- if err != nil {
- br.Msg = "保存失败!"
- br.ErrMsg = "获取指标数据失败,Err:" + err.Error()
- return
- }
- for _, v := range list {
- if v.PublicStatus != utils.DataPublicDefault {
- br.Msg = `选择指标中存在已经公开/提交审批的指标,请仅选择未公开指标!`
- br.IsSendEmail = false
- return
- }
- }
- }
- // 校验是否开启了审批流
- opening, e := dataApproveSerice.CheckOpenApprove(utils.DataApproveTypeEdb)
- if e != nil {
- br.Msg = "操作失败"
- br.ErrMsg = "校验指标公开是否开启审批流失败, Err: " + e.Error()
- return
- }
- // 是否忽略审批
- var isIgnoreApprove bool
- {
- businessConf, e := models.GetBusinessConfByKey(models.IgnoreEdbApproveUserId)
- if e != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取商家配置失败, Err: " + e.Error()
- return
- }
- ignoreEdbApproveUserIdList := strings.Split(businessConf.ConfVal, `,`)
- if utils.InArrayByStr(ignoreEdbApproveUserIdList, strconv.Itoa(c.SysUser.AdminId)) {
- isIgnoreApprove = true
- }
- }
- edbInfo, err := data_manage.GetEdbInfoById(req.EdbInfoList[0].EdbInfoId)
- if err != nil {
- br.Msg = "获取指标失败"
- br.ErrMsg = "获取指标失败:" + err.Error()
- return
- }
- title := edbInfo.EdbName
- if len(req.EdbInfoList) > 1 {
- title += `等指标`
- }
- title += `公开审批`
- // 没开启审批流、或者无需审批
- if !opening || isIgnoreApprove {
- err = dataApproveSerice.UpdatePublicByDataList(utils.DataApproveTypeEdb, dataApproveSerice.DataApproveStatePass, dataPublicItemList)
- } else {
- _, err = dataApproveSerice.SubmitDataApprove(utils.DataApproveTypeEdb, dataPublicItemList, title, strings.TrimSpace(req.Description), c.SysUser.AdminId, c.SysUser.RealName)
- if err != nil {
- br.Msg = "提交审批失败"
- br.ErrMsg = "提交审批失败, Err: " + err.Error()
- return
- }
- // 更新ES
- for _, dataPublicItem := range dataPublicItemList {
- data.AddOrEditEdbInfoToEs(dataPublicItem.DataId)
- }
- }
- if err != nil {
- br.Msg = "编辑失败"
- br.ErrMsg = "编辑失败,Err:" + err.Error()
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "保存成功"
- }
- // Cancel
- // @Title 撤销指标公开
- // @Description 撤销指标公开
- // @Param EdbInfoId query int true "指标id"
- // @Success 200 {object} data_manage.EdbInfo
- // @router /edb_info/public/cancel [post]
- func (c *EdbPublicController) Cancel() {
- br := new(models.BaseResponse).Init()
- defer func() {
- c.Data["json"] = br
- c.ServeJSON()
- }()
- // TODO 单个指标撤销的时候,需要校验状态,然后撤销
- sysUser := c.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- edbInfoId, _ := c.GetInt("EdbInfoId")
- if edbInfoId <= 0 {
- br.Msg = "参数错误"
- br.ErrMsg = "参数错误"
- return
- }
- var req request.SetEdbPublicReq
- err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if len(req.EdbInfoList) <= 0 {
- br.Msg = `请选择指标`
- br.IsSendEmail = false
- return
- }
- // 待处理的资产
- dataPublicItemList := make([]dataApproveSerice.SetDataPublicItem, 0)
- // 校验是否重复存在已公开、已提交的指标
- {
- edbInfoIdList := make([]int, 0)
- for _, item := range req.EdbInfoList {
- edbInfoIdList = append(edbInfoIdList, item.EdbInfoId)
- dataPublicItemList = append(dataPublicItemList, dataApproveSerice.SetDataPublicItem{
- DataId: item.EdbInfoId,
- ClassifyId: item.ClassifyId,
- })
- }
- list, err := data_manage.GetEdbInfoByIdList(edbInfoIdList)
- if err != nil {
- br.Msg = "保存失败!"
- br.ErrMsg = "获取指标数据失败,Err:" + err.Error()
- return
- }
- for _, v := range list {
- if v.PublicStatus != utils.DataPublicDefault {
- br.Msg = `选择指标中存在已经公开/提交审批的指标,请仅选择未公开指标!`
- br.IsSendEmail = false
- return
- }
- }
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "保存成功"
- }
- // ListByEs
- // @Title 指标筛选接口
- // @Description 指标筛选接口
- // @Success 200 {object} data_manage.EdbInfoList
- // @Param request body request.SearchPublicEdbReq true "type json string"
- // @Success 200 {object} data_manage.EdbInfoFilterDataResp
- // @router /edb_info/public/list/es [post]
- func (c *EdbPublicController) ListByEs() {
- br := new(models.BaseResponse).Init()
- defer func() {
- c.Data["json"] = br
- c.ServeJSON()
- }()
- var req request.SearchPublicEdbReq
- err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- pageSize := req.PageSize
- currentIndex := req.CurrentIndex
- var total int64
- var startSize int
- if pageSize <= 0 {
- pageSize = utils.PageSize20
- }
- if currentIndex <= 0 {
- currentIndex = 1
- }
- startSize = paging.StartIndex(currentIndex, pageSize)
- // 获取查询参数
- keyword, searchEdbPublicList, sourceList, edbClassifyIdList, publicClassifyIdList, edbTypeList, edbInfoType, edbAuth, sortMap := data.GetSearchPar(req)
- total, edbInfoList, err := elastic.SearchEdbInfoDataByPublic(keyword, startSize, pageSize, searchEdbPublicList, sourceList, edbClassifyIdList, publicClassifyIdList, edbTypeList, edbInfoType, edbAuth, c.SysUser.AdminId, sortMap)
- if err != nil {
- edbInfoList = make([]*data_manage.EdbInfoList, 0)
- }
- page := paging.GetPaging(currentIndex, pageSize, int(total))
- edbInfoListLen := len(edbInfoList)
- // 因为是ES查找的,所以需要重新查一下指标的信息,主要是为了把是否授权字段找出来
- if len(edbInfoList) > 0 {
- // 图表map
- edbInfoMap := make(map[int]*data_manage.EdbInfo)
- classifyMap := make(map[int]*data_manage.EdbClassify)
- publicClassifyMap := make(map[int]*data_manage.EdbPublicClassify)
- // 指标id,分类id,公共分类id
- edbInfoIdList := make([]int, 0)
- tmpClassifyIdList := make([]int, 0)
- tmpPublicClassifyIdList := make([]int, 0)
- for _, v := range edbInfoList {
- v.ConvertToResp()
- v.EdbNameAlias = v.EdbName
- v.HaveOperaAuth = true
- edbInfoIdList = append(edbInfoIdList, v.EdbInfoId)
- }
- // 查找指标
- {
- tmpEdbList, err := data_manage.GetEdbInfoByIdList(edbInfoIdList)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取所有有权限的指标失败,Err:" + err.Error()
- return
- }
- for _, v := range tmpEdbList {
- edbInfoMap[v.EdbInfoId] = v
- tmpClassifyIdList = append(tmpClassifyIdList, v.ClassifyId)
- tmpPublicClassifyIdList = append(tmpPublicClassifyIdList, v.EdbPublicClassifyId)
- }
- }
- // 指标分类
- {
- tmpList, err := data_manage.GetEdbClassifyByIdList(tmpClassifyIdList)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取所有有权限的图表分类失败,Err:" + err.Error()
- return
- }
- for _, v := range tmpList {
- classifyMap[v.ClassifyId] = v
- }
- }
- // 公共分类
- {
- obj := data_manage.EdbPublicClassify{}
- tmpList, err := obj.GetEdbClassifyByIdList(tmpPublicClassifyIdList)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取所有有权限的公共分类失败,Err:" + err.Error()
- return
- }
- for _, v := range tmpList {
- publicClassifyMap[v.EdbPublicClassifyId] = v
- }
- }
- // 数据重新赋值
- for _, v := range edbInfoList {
- if tmpEdbInfo, ok := edbInfoMap[v.EdbInfoId]; ok {
- v.IsJoinPermission = tmpEdbInfo.IsJoinPermission
- }
- // 普通分类
- if classifyItem, ok := classifyMap[v.ClassifyId]; ok {
- v.ClassifyNamePath = classifyItem.ClassifyNamePath
- }
- // 公共分类
- if classifyItem, ok := publicClassifyMap[v.EdbPublicClassifyId]; ok {
- v.PublicClassifyNamePath = classifyItem.EdbPublicClassifyNamePath
- }
- }
- }
- for i := 0; i < edbInfoListLen; i++ {
- for j := 0; j < edbInfoListLen; j++ {
- if (edbInfoList[i].EdbNameAlias == edbInfoList[j].EdbNameAlias) &&
- (edbInfoList[i].EdbInfoId != edbInfoList[j].EdbInfoId) &&
- !(strings.Contains(edbInfoList[i].EdbName, edbInfoList[i].SourceName)) {
- edbInfoList[i].EdbName = edbInfoList[i].EdbName + "(" + edbInfoList[i].SourceName + ")"
- }
- }
- }
- resp := data_manage.EdbInfoFilterDataResp{
- Paging: page,
- List: edbInfoList,
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // AllListByEs
- // @Title 指标筛选接口
- // @Description 指标筛选接口
- // @Success 200 {object} data_manage.EdbInfoList
- // @Param request body request.SearchEdbInfoShareReq true "type json string"
- // @Success 200 {object} data_manage.EdbInfoFilterDataResp
- // @router /edb_info/public/list/es/all [post]
- func (c *EdbPublicController) AllListByEs() {
- br := new(models.BaseResponse).Init()
- defer func() {
- c.Data["json"] = br
- c.ServeJSON()
- }()
- var req request.AllSearchPublicEdbReq
- err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- // 选择所有指标,所以需要通过es获取数据
- // 选中的指标id列表
- edbInfoList := make([]*data_manage.EdbInfoList, 0)
- // 选择所有指标,所以需要通过es获取数据
- if req.IsSelectAll {
- tmpEdbInfoList, err := data.GetAllEdbInfoListBySearchPublicEdbReq(req.SearchPublicEdbReq, c.SysUser.AdminId)
- if err != nil {
- br.Msg = "获取指标列表失败!"
- br.ErrMsg = "获取指标列表失败,Err:" + err.Error()
- return
- }
- // 如果有过滤指标,那么就过滤吧
- if len(req.NoEdbIdList) > 0 {
- noEdbIdMap := make(map[int]bool)
- for _, v := range req.NoEdbIdList {
- noEdbIdMap[v] = true
- }
- for _, v := range tmpEdbInfoList {
- if _, ok := noEdbIdMap[v.EdbInfoId]; !ok {
- // 如果不在未选中的指标id列表中,那么就加入到选中的指标id列表
- edbInfoList = append(edbInfoList, v)
- }
- }
- } else {
- edbInfoList = tmpEdbInfoList
- }
- // 因为是ES查找的,所以需要重新查一下指标的信息,主要是为了把是否授权字段找出来
- if len(edbInfoList) > 0 {
- edbInfoIdList := make([]int, 0)
- for _, v := range edbInfoList {
- v.ConvertToResp()
- v.EdbNameAlias = v.EdbName
- v.HaveOperaAuth = true
- edbInfoIdList = append(edbInfoIdList, v.EdbInfoId)
- }
- tmpEdbList, err := data_manage.GetEdbInfoByIdList(edbInfoIdList)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取所有有权限的指标失败,Err:" + err.Error()
- return
- }
- edbInfoMap := make(map[int]*data_manage.EdbInfo)
- for _, v := range tmpEdbList {
- edbInfoMap[v.EdbInfoId] = v
- }
- for _, v := range edbInfoList {
- tmpEdbInfo, ok := edbInfoMap[v.EdbInfoId]
- if !ok {
- continue
- }
- v.IsJoinPermission = tmpEdbInfo.IsJoinPermission
- }
- }
- } else {
- // 因为是ES查找的,所以需要重新查一下指标的信息,主要是为了把是否授权字段找出来
- if len(req.EdbIdList) > 0 {
- edbInfoList, err = data_manage.GetEdbInfoListByCond(` AND edb_info_id in (?) `, []interface{}{req.EdbIdList})
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取所有有权限的指标失败,Err:" + err.Error()
- return
- }
- }
- }
- edbInfoListLen := len(edbInfoList)
- for i := 0; i < edbInfoListLen; i++ {
- for j := 0; j < edbInfoListLen; j++ {
- if (edbInfoList[i].EdbNameAlias == edbInfoList[j].EdbNameAlias) &&
- (edbInfoList[i].EdbInfoId != edbInfoList[j].EdbInfoId) &&
- !(strings.Contains(edbInfoList[i].EdbName, edbInfoList[i].SourceName)) {
- edbInfoList[i].EdbName = edbInfoList[i].EdbName + "(" + edbInfoList[i].SourceName + ")"
- }
- }
- }
- resp := data_manage.EdbInfoFilterDataResp{
- List: edbInfoList,
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // BatchMoveEdb
- // @Title 指标批量移动接口
- // @Description 指标批量移动接口
- // @Param request body request.MoveEdbClassifyReq true "type json string"
- // @Success Ret=200 移动成功
- // @router /edb_info/public/batch_move [post]
- func (c *EdbPublicController) BatchMoveEdb() {
- br := new(models.BaseResponse).Init()
- defer func() {
- c.Data["json"] = br
- c.ServeJSON()
- }()
- var req request.MoveEdbClassifyReq
- err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if req.NewClassifyId <= 0 {
- br.Msg = `请选择要转移的新分类`
- br.IsSendEmail = false
- return
- }
- // 校验分类
- obj := data_manage.EdbPublicClassify{}
- publicClassifyItem, err := obj.GetEdbClassifyById(req.NewClassifyId)
- if err != nil {
- br.Msg = "获取公共分类失败!"
- br.ErrMsg = "获取公共分类失败!" + err.Error()
- return
- }
- if publicClassifyItem.EdbPublicClassifyId <= 0 {
- br.Msg = "公共分类不存在!"
- br.ErrMsg = "公共分类不存在!"
- return
- }
- // 只是取公开
- req.SearchPublicEdbReq.EdbPublicList = []int{3}
- edbInfoIdList := make([]int, 0)
- if req.IsSelectAll {
- // 获取指标
- edbInfoList, err := data.GetAllEdbInfoListBySearchPublicEdbReq(req.SearchPublicEdbReq, c.SysUser.AdminId)
- if err != nil {
- br.Msg = "获取指标列表失败!"
- br.ErrMsg = "获取指标列表失败,Err:" + err.Error()
- return
- }
- // 如果有过滤指标,那么就过滤吧
- if len(req.NoEdbIdList) > 0 {
- noEdbIdMap := make(map[int]bool)
- for _, v := range req.NoEdbIdList {
- noEdbIdMap[v] = true
- }
- for _, edbInfo := range edbInfoList {
- if _, ok := noEdbIdMap[edbInfo.EdbInfoId]; !ok {
- if edbInfo.PublicStatus != utils.DataPublicSuccess {
- br.Msg = `存在未公开的指标:` + edbInfo.EdbName
- br.IsSendEmail = false
- return
- }
- // 如果不在未选中的指标id列表中,那么就加入到选中的指标id列表
- edbInfoIdList = append(edbInfoIdList, edbInfo.EdbInfoId)
- }
- }
- } else {
- for _, edbInfo := range edbInfoList {
- if edbInfo.PublicStatus != utils.DataPublicSuccess {
- br.Msg = `存在未公开的指标:` + edbInfo.EdbName
- br.IsSendEmail = false
- return
- }
- edbInfoIdList = append(edbInfoIdList, edbInfo.EdbInfoId)
- }
- }
- } else {
- edbInfoList, err := data_manage.GetEdbInfoListByCond(` AND edb_info_id in (?) `, []interface{}{req.EdbIdList})
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取所有有权限的指标失败,Err:" + err.Error()
- return
- }
- for _, v := range edbInfoList {
- if v.PublicStatus != utils.DataPublicSuccess {
- br.Msg = `存在未公开的指标:` + v.EdbName
- br.IsSendEmail = false
- return
- }
- }
- edbInfoIdList = req.EdbIdList
- }
- num := len(edbInfoIdList)
- if num <= 0 {
- br.Msg = `请选择要移动的指标!`
- br.IsSendEmail = false
- return
- }
- if num > 100 {
- br.Msg = `最多只能选择100条指标!`
- br.IsSendEmail = false
- return
- }
- // 开始批量修改指标分类
- if len(edbInfoIdList) > 0 {
- err = data_manage.UpdatePublicClassifyIdByEdbInfoIdList(edbInfoIdList, req.NewClassifyId)
- if err != nil {
- br.Msg = `指标移动失败!`
- br.ErrMsg = `指标移动失败,ERR:` + err.Error()
- return
- }
- // 还得修改ES呢
- for _, v := range edbInfoIdList {
- data.AddOrEditEdbInfoToEs(v)
- }
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- }
|