data_manage_permission.go 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. package data
  2. import (
  3. "eta/eta_api/models/data_manage"
  4. "eta/eta_api/utils"
  5. "fmt"
  6. )
  7. // SetEdbChartPermission
  8. // @Description: 单独给资产(指标、图表、ETA表格)设置权限
  9. // @author: Roc
  10. // @datetime 2024-03-27 10:52:32
  11. // @param source int
  12. // @param subSource int
  13. // @param userId int
  14. // @param userList []int
  15. // @param isSelectAll bool
  16. // @param dataId []string
  17. // @param noDataId []string
  18. // @param keyword string
  19. // @param classify string
  20. // @return err error
  21. // @return errMsg string
  22. func SetEdbChartPermission(source, subSource, userId int, userList []int, isSelectAll bool, dataId, noDataId []string, keyword, classify string) (err error, errMsg string) {
  23. // TODO 消息通知
  24. // 如果勾选全部数据,那么
  25. if isSelectAll {
  26. // 找出不要的指标ID列表
  27. noDataIdMap := make(map[string]string, 0)
  28. for _, v := range noDataId {
  29. noDataIdMap[v] = v
  30. }
  31. // 需要转义的指标/图表ID列表
  32. dataId = make([]string, 0)
  33. // 获取所有指标/图表
  34. list, _, tmpErr := GetMoveEdbChartList(source, subSource, userId, keyword, classify, 0, 100000)
  35. if tmpErr != nil {
  36. err = tmpErr
  37. return
  38. }
  39. for _, v := range list {
  40. if _, ok := noDataIdMap[v.DataId]; !ok {
  41. dataId = append(dataId, v.DataId)
  42. }
  43. }
  44. }
  45. if len(userList) <= 0 {
  46. // 说明是取消权限管控
  47. }
  48. switch source {
  49. case 3, 4: //ETA指标库、ETA预测指标
  50. //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
  51. //if tmpErr != nil {
  52. // err = tmpErr
  53. // return
  54. //}
  55. //if len(tmpList) > 0 {
  56. //}
  57. // 重新设置权限
  58. err = data_manage.SetPermissionEdbChartByEdbIdList(dataId, userList)
  59. //case 5: //图库
  60. // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
  61. // if tmpErr != nil {
  62. // err = tmpErr
  63. // return
  64. // }
  65. // if len(tmpList) > 0 {
  66. // for _, v := range tmpList {
  67. // if v.SysUserId == newUserId {
  68. // errMsg = "新创建人不可和原创建人一致"
  69. // err = errors.New(errMsg)
  70. // return
  71. // }
  72. // }
  73. // // 修改创建人
  74. // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  75. // }
  76. //case 6: // ETA表格
  77. // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
  78. // if tmpErr != nil {
  79. // err = tmpErr
  80. // return
  81. // }
  82. // if len(tmpList) > 0 {
  83. // for _, v := range tmpList {
  84. // if v.SysUserId == newUserId {
  85. // errMsg = "新创建人不可和原创建人一致"
  86. // err = errors.New(errMsg)
  87. // return
  88. // }
  89. // }
  90. // // 修改创建人
  91. // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  92. // }
  93. default:
  94. return
  95. }
  96. return
  97. }
  98. // SetDataIsPermission
  99. // @Description: 设置资产(指标、图表、ETA表格)分类是否涉密
  100. // @author: Roc
  101. // @datetime 2024-03-27 10:52:32
  102. // @param source int
  103. // @param subSource int
  104. // @param dataId []string
  105. // @return err error
  106. // @return errMsg string
  107. func SetDataIsPermission(source, subSource int, classifyIdList []int) (err error, errMsg string) {
  108. // TODO 消息通知
  109. switch source {
  110. case 3, 4: //ETA指标库、ETA预测指标
  111. //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
  112. //if tmpErr != nil {
  113. // err = tmpErr
  114. // return
  115. //}
  116. //if len(tmpList) > 0 {
  117. //}
  118. // 重新设置权限
  119. err = data_manage.SetIsPermissionEdbChartByEdbClassifyIdList(classifyIdList)
  120. //case 5: //图库
  121. //case 6: // ETA表格
  122. default:
  123. return
  124. }
  125. return
  126. }
  127. // SetEdbChartClassifyPermission
  128. // @Description: 给用户设置涉密分类的权限
  129. // @author: Roc
  130. // @datetime 2024-03-28 14:22:30
  131. // @param source int
  132. // @param subSource int
  133. // @param userList []int
  134. // @param classifyIdList []int
  135. // @return err error
  136. // @return errMsg string
  137. func SetEdbChartClassifyPermission(source, subSource int, userList []int, classifyIdList []int) (err error, errMsg string) {
  138. // TODO 消息通知
  139. if len(classifyIdList) <= 0 {
  140. // 说明是取消权限管控
  141. }
  142. switch source {
  143. case 3, 4: //ETA指标库、ETA预测指标
  144. //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
  145. //if tmpErr != nil {
  146. // err = tmpErr
  147. // return
  148. //}
  149. //if len(tmpList) > 0 {
  150. //}
  151. // 重新设置权限
  152. err = data_manage.SetPermissionEdbChartClassifyIdByClassifyIdList(classifyIdList, userList)
  153. //case 5: //图库
  154. // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
  155. // if tmpErr != nil {
  156. // err = tmpErr
  157. // return
  158. // }
  159. // if len(tmpList) > 0 {
  160. // for _, v := range tmpList {
  161. // if v.SysUserId == newUserId {
  162. // errMsg = "新创建人不可和原创建人一致"
  163. // err = errors.New(errMsg)
  164. // return
  165. // }
  166. // }
  167. // // 修改创建人
  168. // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  169. // }
  170. //case 6: // ETA表格
  171. // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
  172. // if tmpErr != nil {
  173. // err = tmpErr
  174. // return
  175. // }
  176. // if len(tmpList) > 0 {
  177. // for _, v := range tmpList {
  178. // if v.SysUserId == newUserId {
  179. // errMsg = "新创建人不可和原创建人一致"
  180. // err = errors.New(errMsg)
  181. // return
  182. // }
  183. // }
  184. // // 修改创建人
  185. // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  186. // }
  187. default:
  188. return
  189. }
  190. return
  191. }
  192. // GetUserEdbAndClassifyPermissionList
  193. // @Description: 根据用户获取已经授权指标ID列表和指标分类ID列表
  194. // @author: Roc
  195. // @datetime 2024-03-28 17:20:36
  196. // @param userId int
  197. // @param edbInfoId int 如果传递了edbInfoId,则只返回该edbInfoId的权限列表(其实也就是为了判断是否存在该指标权限了,目的是为了少获取数据)
  198. // @param classifyId int classifyId,则只返回该classifyId的权限列表(其实也就是为了判断是否存在该指标分类权限了,目的是为了少获取数据)
  199. // @return edbIdList []int
  200. // @return classifyIdList []int
  201. // @return err error
  202. func GetUserEdbAndClassifyPermissionList(userId, edbInfoId, classifyId int) (edbIdList, classifyIdList []int, err error) {
  203. edbIdList, err = data_manage.GetPermissionEdbIdList(userId, edbInfoId)
  204. if err != nil {
  205. fmt.Println("获取授权指标列表失败, err:", err)
  206. return
  207. }
  208. classifyIdList, err = data_manage.GetPermissionEdbClassifyIdList(userId, classifyId)
  209. if err != nil {
  210. fmt.Println("获取授权指标分类列表失败, err:", err)
  211. return
  212. }
  213. return
  214. }
  215. // CheckEdbPermission
  216. // @Description: 检查EDB指标(含预测指标)权限(方法内部自己获取所有的指标和指标分类权限,不用额外传递)
  217. // @author: Roc
  218. // @datetime 2024-03-28 16:12:08
  219. // @param edbIsJoinPermission int
  220. // @param edbClassifyIsJoinPermission int
  221. // @param edbInfoId int
  222. // @param edbClassifyId int
  223. // @return hasAuth bool
  224. func CheckEdbPermission(edbIsJoinPermission, edbClassifyIsJoinPermission, userId, edbInfoId, edbClassifyId int) (hasAuth bool, err error) {
  225. edbIdList, classifyIdList, err := GetUserEdbAndClassifyPermissionList(userId, edbInfoId, edbClassifyId)
  226. if err != nil {
  227. fmt.Println("GetUserEdbAndClassifyPermissionList err:", err)
  228. return
  229. }
  230. hasAuth = CheckEdbPermissionByPermissionIdList(edbIsJoinPermission, edbClassifyIsJoinPermission, edbInfoId, edbClassifyId, edbIdList, classifyIdList)
  231. return
  232. }
  233. // CheckEdbPermissionByPermissionIdList
  234. // @Description: 检查EDB指标(含预测指标)权限
  235. // @author: Roc
  236. // @datetime 2024-03-28 16:12:08
  237. // @param edbIsJoinPermission int
  238. // @param edbClassifyIsJoinPermission int
  239. // @param edbInfoId int
  240. // @param edbClassifyId int
  241. // @param permissionEdbInfoIdList []int
  242. // @param permissionEdbClassifyIdList []int
  243. // @return hasAuth bool
  244. func CheckEdbPermissionByPermissionIdList(edbIsJoinPermission, edbClassifyIsJoinPermission, edbInfoId, edbClassifyId int, permissionEdbInfoIdList, permissionEdbClassifyIdList []int) (hasAuth bool) {
  245. //hasAuth = true
  246. // 判断 分类是否纳入权限管控
  247. if edbClassifyIsJoinPermission == 1 {
  248. // 不属于已授权的分类,那么就无权限
  249. if !utils.InArrayByInt(permissionEdbClassifyIdList, edbClassifyId) {
  250. return false
  251. }
  252. }
  253. // 判断 指标是否纳入权限管控
  254. if edbIsJoinPermission == 1 {
  255. // 不属于已授权的指标,那么就无权限
  256. if !utils.InArrayByInt(permissionEdbInfoIdList, edbInfoId) {
  257. return false
  258. }
  259. }
  260. hasAuth = true
  261. return
  262. }