123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355 |
- package data_manage_permission
- import (
- "eta/eta_api/models/data_manage"
- "eta/eta_api/models/data_manage/data_manage_permission"
- "eta/eta_api/utils"
- "fmt"
- )
- // SetEdbChartPermission
- // @Description: 单独给资产(指标、图表、ETA表格)设置权限
- // @author: Roc
- // @datetime 2024-03-27 10:52:32
- // @param source int
- // @param subSource int
- // @param userId int
- // @param userList []int
- // @param isSelectAll bool
- // @param dataId []string
- // @param noDataId []string
- // @param keyword string
- // @param classify string
- // @return err error
- // @return errMsg string
- func SetEdbChartPermission(source, subSource, userId int, userList []int, isSelectAll bool, dataId, noDataId []string, keyword, classify string) (err error, errMsg string) {
- // TODO 消息通知
- // 如果勾选全部数据,那么
- if isSelectAll {
- // 找出不要的指标ID列表
- noDataIdMap := make(map[string]string, 0)
- for _, v := range noDataId {
- noDataIdMap[v] = v
- }
- // 需要转义的指标/图表ID列表
- dataId = make([]string, 0)
- // 获取所有指标/图表
- list, _, tmpErr := GetMoveEdbChartList(source, subSource, userId, keyword, classify, 0, 100000)
- if tmpErr != nil {
- err = tmpErr
- return
- }
- for _, v := range list {
- if _, ok := noDataIdMap[v.DataId]; !ok {
- dataId = append(dataId, v.DataId)
- }
- }
- }
- if len(userList) <= 0 {
- // 说明是取消权限管控
- }
- switch source {
- case 3, 4: //ETA指标库、ETA预测指标
- //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
- //if tmpErr != nil {
- // err = tmpErr
- // return
- //}
- //if len(tmpList) > 0 {
- //}
- // 重新设置权限
- err = data_manage_permission.SetPermissionEdbChartByEdbIdList(dataId, userList)
- //case 5: //图库
- // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
- // if tmpErr != nil {
- // err = tmpErr
- // return
- // }
- // if len(tmpList) > 0 {
- // for _, v := range tmpList {
- // if v.SysUserId == newUserId {
- // errMsg = "新创建人不可和原创建人一致"
- // err = errors.New(errMsg)
- // return
- // }
- // }
- // // 修改创建人
- // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
- // }
- //case 6: // ETA表格
- // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
- // if tmpErr != nil {
- // err = tmpErr
- // return
- // }
- // if len(tmpList) > 0 {
- // for _, v := range tmpList {
- // if v.SysUserId == newUserId {
- // errMsg = "新创建人不可和原创建人一致"
- // err = errors.New(errMsg)
- // return
- // }
- // }
- // // 修改创建人
- // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
- // }
- default:
- return
- }
- return
- }
- // SetDataIsPermission
- // @Description: 设置资产(指标、图表、ETA表格)分类是否涉密
- // @author: Roc
- // @datetime 2024-03-27 10:52:32
- // @param source int
- // @param subSource int
- // @param dataId []string
- // @return err error
- // @return errMsg string
- func SetDataIsPermission(source, subSource int, classifyIdList []int) (err error, errMsg string) {
- // TODO 消息通知
- switch source {
- case 3, 4: //ETA指标库、ETA预测指标
- //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
- //if tmpErr != nil {
- // err = tmpErr
- // return
- //}
- //if len(tmpList) > 0 {
- //}
- // 重新设置权限
- err = data_manage_permission.SetIsPermissionEdbChartByEdbClassifyIdList(classifyIdList)
- //case 5: //图库
- //case 6: // ETA表格
- default:
- return
- }
- return
- }
- // SetEdbChartClassifyPermission
- // @Description: 给用户设置涉密分类的权限
- // @author: Roc
- // @datetime 2024-03-28 14:22:30
- // @param source int
- // @param subSource int
- // @param userList []int
- // @param classifyIdList []int
- // @return err error
- // @return errMsg string
- func SetEdbChartClassifyPermission(source, subSource int, userList []int, classifyIdList []int) (err error, errMsg string) {
- // TODO 消息通知
- if len(classifyIdList) <= 0 {
- // 说明是取消权限管控
- }
- switch source {
- case 3, 4: //ETA指标库、ETA预测指标
- //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
- //if tmpErr != nil {
- // err = tmpErr
- // return
- //}
- //if len(tmpList) > 0 {
- //}
- // 重新设置权限
- err = data_manage_permission.SetPermissionEdbChartClassifyIdByClassifyIdList(classifyIdList, userList)
- //case 5: //图库
- // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
- // if tmpErr != nil {
- // err = tmpErr
- // return
- // }
- // if len(tmpList) > 0 {
- // for _, v := range tmpList {
- // if v.SysUserId == newUserId {
- // errMsg = "新创建人不可和原创建人一致"
- // err = errors.New(errMsg)
- // return
- // }
- // }
- // // 修改创建人
- // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
- // }
- //case 6: // ETA表格
- // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
- // if tmpErr != nil {
- // err = tmpErr
- // return
- // }
- // if len(tmpList) > 0 {
- // for _, v := range tmpList {
- // if v.SysUserId == newUserId {
- // errMsg = "新创建人不可和原创建人一致"
- // err = errors.New(errMsg)
- // return
- // }
- // }
- // // 修改创建人
- // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
- // }
- default:
- return
- }
- return
- }
- // CheckEdbPermissionByPermissionIdList
- // @Description: 检查EDB指标(含预测指标)权限
- // @author: Roc
- // @datetime 2024-03-28 16:12:08
- // @param edbIsJoinPermission int
- // @param edbClassifyIsJoinPermission int
- // @param edbInfoId int
- // @param edbClassifyId int
- // @param permissionEdbInfoIdList []int
- // @param permissionEdbClassifyIdList []int
- // @return hasAuth bool
- func CheckEdbPermissionByPermissionIdList(edbIsJoinPermission, edbClassifyIsJoinPermission, edbInfoId, edbClassifyId int, permissionEdbInfoIdList, permissionEdbClassifyIdList []int) (hasAuth bool) {
- //hasAuth = true
- // 判断 分类是否纳入权限管控
- if edbClassifyIsJoinPermission == 1 {
- // 不属于已授权的分类,那么就无权限
- if !utils.InArrayByInt(permissionEdbClassifyIdList, edbClassifyId) {
- return false
- }
- }
- // 判断 指标是否纳入权限管控
- if edbIsJoinPermission == 1 {
- // 不属于已授权的指标,那么就无权限
- if !utils.InArrayByInt(permissionEdbInfoIdList, edbInfoId) {
- return false
- }
- }
- hasAuth = true
- return
- }
- // CheckEdbClassifyPermissionByPermissionIdList
- // @Description: 检查EDB分类权限
- // @author: Roc
- // @datetime 2024-03-29 14:35:19
- // @param edbClassifyIsJoinPermission int
- // @param edbClassifyId int
- // @param permissionEdbClassifyIdList []int
- // @return hasAuth bool
- func CheckEdbClassifyPermissionByPermissionIdList(edbClassifyIsJoinPermission, edbClassifyId int, permissionEdbClassifyIdList []int) (hasAuth bool) {
- // 判断 分类是否纳入权限管控
- if edbClassifyIsJoinPermission == 1 {
- // 不属于已授权的分类,那么就无权限
- if !utils.InArrayByInt(permissionEdbClassifyIdList, edbClassifyId) {
- return
- }
- }
- hasAuth = true
- return
- }
- // GetUserEdbAndClassifyPermissionList
- // @Description: 根据用户获取已经授权指标ID列表和指标分类ID列表
- // @author: Roc
- // @datetime 2024-03-28 17:20:36
- // @param userId int
- // @param edbInfoId int 如果传递了edbInfoId,则只返回该edbInfoId的权限列表(其实也就是为了判断是否存在该指标权限了,目的是为了少获取数据)
- // @param classifyId int classifyId,则只返回该classifyId的权限列表(其实也就是为了判断是否存在该指标分类权限了,目的是为了少获取数据)
- // @return edbIdList []int
- // @return classifyIdList []int
- // @return err error
- func GetUserEdbAndClassifyPermissionList(userId, edbInfoId, classifyId int) (edbIdList, classifyIdList []int, err error) {
- // 获取有权限的指标ID列表
- edbIdList, err = data_manage_permission.GetPermissionEdbIdList(userId, edbInfoId)
- if err != nil {
- fmt.Println("获取授权指标列表失败, err:", err)
- return
- }
- // 获取有权限的指标分类ID列表
- classifyIdList, err = data_manage_permission.GetPermissionEdbClassifyIdList(userId, classifyId)
- if err != nil {
- fmt.Println("获取授权指标分类列表失败, err:", err)
- return
- }
- return
- }
- // GetUserEdbClassifyPermissionList
- // @Description: 根据用户获取已经授权指标分类ID列表
- // @author: Roc
- // @datetime 2024-03-28 17:20:36
- // @param userId int
- // @param classifyId int classifyId,则只返回该classifyId的权限列表(其实也就是为了判断是否存在该指标分类权限了,目的是为了少获取数据)
- // @return classifyIdList []int
- // @return err error
- func GetUserEdbClassifyPermissionList(userId, classifyId int) (classifyIdList []int, err error) {
- // 获取有权限的指标分类ID列表
- classifyIdList, err = data_manage_permission.GetPermissionEdbClassifyIdList(userId, classifyId)
- if err != nil {
- fmt.Println("获取授权指标分类列表失败, err:", err)
- return
- }
- return
- }
- // CheckEdbPermissionByEdbInfoId
- // @Description: 根据指标id和指标分类id,检查EDB指标(含预测指标)权限(方法内部自己获取所有的指标和指标分类权限,不用额外传递)
- // @author: Roc
- // @datetime 2024-03-29 13:28:06
- // @param edbInfoId int
- // @param edbClassifyId int
- // @param edbIsJoinPermission int
- // @param userId int
- // @return hasAuth bool
- // @return err error
- func CheckEdbPermissionByEdbInfoId(edbInfoId, edbClassifyId, edbIsJoinPermission, userId int) (hasAuth bool, err error) {
- currClassify, err := data_manage.GetEdbClassifyById(edbClassifyId)
- if err != nil {
- return
- }
- if currClassify != nil {
- return CheckEdbPermission(edbIsJoinPermission, currClassify.IsJoinPermission, userId, edbInfoId, edbClassifyId)
- }
- return
- }
- // CheckEdbPermission
- // @Description: 检查EDB指标(含预测指标)权限(方法内部自己获取所有的指标和指标分类权限,不用额外传递)
- // @author: Roc
- // @datetime 2024-03-28 16:12:08
- // @param edbIsJoinPermission int
- // @param edbClassifyIsJoinPermission int
- // @param edbInfoId int
- // @param edbClassifyId int
- // @return hasAuth bool
- func CheckEdbPermission(edbIsJoinPermission, edbClassifyIsJoinPermission, userId, edbInfoId, edbClassifyId int) (hasAuth bool, err error) {
- edbIdList, classifyIdList, err := GetUserEdbAndClassifyPermissionList(userId, edbInfoId, edbClassifyId)
- if err != nil {
- fmt.Println("GetUserEdbAndClassifyPermissionList err:", err)
- return
- }
- hasAuth = CheckEdbPermissionByPermissionIdList(edbIsJoinPermission, edbClassifyIsJoinPermission, edbInfoId, edbClassifyId, edbIdList, classifyIdList)
- return
- }
|