edb_permission.go 11 KB

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