edb_permission.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497
  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, dataIdList, noDataIdList []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 noDataIdList {
  30. noDataIdMap[v] = v
  31. }
  32. // 需要转义的指标/图表ID列表
  33. dataIdList = 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. dataIdList = append(dataIdList, 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. edbInfoType := 0
  60. if source == 4 {
  61. edbInfoType = 1
  62. }
  63. err = data_manage_permission.SetPermissionEdbChartByEdbIdList(dataIdList, userList, edbInfoType)
  64. //case 5: //图库
  65. // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
  66. // if tmpErr != nil {
  67. // err = tmpErr
  68. // return
  69. // }
  70. // if len(tmpList) > 0 {
  71. // for _, v := range tmpList {
  72. // if v.SysUserId == newUserId {
  73. // errMsg = "新创建人不可和原创建人一致"
  74. // err = errors.New(errMsg)
  75. // return
  76. // }
  77. // }
  78. // // 修改创建人
  79. // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  80. // }
  81. //case 6: // ETA表格
  82. // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
  83. // if tmpErr != nil {
  84. // err = tmpErr
  85. // return
  86. // }
  87. // if len(tmpList) > 0 {
  88. // for _, v := range tmpList {
  89. // if v.SysUserId == newUserId {
  90. // errMsg = "新创建人不可和原创建人一致"
  91. // err = errors.New(errMsg)
  92. // return
  93. // }
  94. // }
  95. // // 修改创建人
  96. // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  97. // }
  98. default:
  99. return
  100. }
  101. return
  102. }
  103. // SetDataIsPermission
  104. // @Description: 设置资产(指标、图表、ETA表格)分类是否涉密
  105. // @author: Roc
  106. // @datetime 2024-03-27 10:52:32
  107. // @param source int
  108. // @param subSource int
  109. // @param dataId []string
  110. // @return err error
  111. // @return errMsg string
  112. func SetDataIsPermission(source, subSource int, classifyIdList []int) (err error, errMsg string) {
  113. // TODO 消息通知
  114. switch source {
  115. case 3, 4: //ETA指标库、ETA预测指标
  116. //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
  117. //if tmpErr != nil {
  118. // err = tmpErr
  119. // return
  120. //}
  121. //if len(tmpList) > 0 {
  122. //}
  123. // 重新设置权限
  124. classifyType := 0
  125. if source == 4 {
  126. classifyType = 1
  127. }
  128. err = data_manage_permission.SetIsPermissionEdbChartByEdbClassifyIdList(classifyIdList, classifyType)
  129. //case 5: //图库
  130. //case 6: // ETA表格
  131. default:
  132. return
  133. }
  134. return
  135. }
  136. // SetEdbChartClassifyPermission
  137. // @Description: 给用户设置涉密分类的权限
  138. // @author: Roc
  139. // @datetime 2024-03-28 14:22:30
  140. // @param source int
  141. // @param subSource int
  142. // @param userList []int
  143. // @param classifyIdList []int
  144. // @return err error
  145. // @return errMsg string
  146. func SetEdbChartClassifyPermission(source, subSource int, userList []int, classifyIdList []int) (err error, errMsg string) {
  147. // TODO 消息通知
  148. if len(classifyIdList) <= 0 {
  149. // 说明是取消权限管控
  150. }
  151. switch source {
  152. case 3, 4: //ETA指标库、ETA预测指标
  153. //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
  154. //if tmpErr != nil {
  155. // err = tmpErr
  156. // return
  157. //}
  158. //if len(tmpList) > 0 {
  159. //}
  160. // 重新设置权限
  161. classifyType := 0
  162. if source == 4 {
  163. classifyType = 1
  164. }
  165. err = data_manage_permission.SetPermissionEdbChartClassifyIdByClassifyIdList(classifyIdList, userList, classifyType)
  166. //case 5: //图库
  167. // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
  168. // if tmpErr != nil {
  169. // err = tmpErr
  170. // return
  171. // }
  172. // if len(tmpList) > 0 {
  173. // for _, v := range tmpList {
  174. // if v.SysUserId == newUserId {
  175. // errMsg = "新创建人不可和原创建人一致"
  176. // err = errors.New(errMsg)
  177. // return
  178. // }
  179. // }
  180. // // 修改创建人
  181. // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  182. // }
  183. //case 6: // ETA表格
  184. // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
  185. // if tmpErr != nil {
  186. // err = tmpErr
  187. // return
  188. // }
  189. // if len(tmpList) > 0 {
  190. // for _, v := range tmpList {
  191. // if v.SysUserId == newUserId {
  192. // errMsg = "新创建人不可和原创建人一致"
  193. // err = errors.New(errMsg)
  194. // return
  195. // }
  196. // }
  197. // // 修改创建人
  198. // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  199. // }
  200. default:
  201. return
  202. }
  203. return
  204. }
  205. // CheckEdbPermissionByPermissionIdList
  206. // @Description: 检查EDB指标(含预测指标)权限
  207. // @author: Roc
  208. // @datetime 2024-03-28 16:12:08
  209. // @param edbIsJoinPermission int
  210. // @param edbClassifyIsJoinPermission int
  211. // @param edbInfoId int
  212. // @param edbClassifyId int
  213. // @param permissionEdbInfoIdList []int
  214. // @param permissionEdbClassifyIdList []int
  215. // @return hasAuth bool
  216. func CheckEdbPermissionByPermissionIdList(edbIsJoinPermission, edbClassifyIsJoinPermission, edbInfoId, edbClassifyId int, permissionEdbInfoIdList, permissionEdbClassifyIdList []int) (hasAuth bool) {
  217. //hasAuth = true
  218. // 判断 分类是否纳入权限管控
  219. if edbClassifyIsJoinPermission == 1 {
  220. // 不属于已授权的分类,那么就无权限
  221. if !utils.InArrayByInt(permissionEdbClassifyIdList, edbClassifyId) {
  222. return false
  223. }
  224. }
  225. // 判断 指标是否纳入权限管控
  226. if edbIsJoinPermission == 1 {
  227. // 不属于已授权的指标,那么就无权限
  228. if !utils.InArrayByInt(permissionEdbInfoIdList, edbInfoId) {
  229. return false
  230. }
  231. }
  232. hasAuth = true
  233. return
  234. }
  235. // CheckEdbClassifyPermissionByPermissionIdList
  236. // @Description: 检查EDB分类权限
  237. // @author: Roc
  238. // @datetime 2024-03-29 14:35:19
  239. // @param edbClassifyIsJoinPermission int
  240. // @param edbClassifyId int
  241. // @param permissionEdbClassifyIdList []int
  242. // @return hasAuth bool
  243. func CheckEdbClassifyPermissionByPermissionIdList(edbClassifyIsJoinPermission, edbClassifyId int, permissionEdbClassifyIdList []int) (hasAuth bool) {
  244. // 判断 分类是否纳入权限管控
  245. if edbClassifyIsJoinPermission == 1 {
  246. // 不属于已授权的分类,那么就无权限
  247. if !utils.InArrayByInt(permissionEdbClassifyIdList, edbClassifyId) {
  248. return
  249. }
  250. }
  251. hasAuth = true
  252. return
  253. }
  254. // GetUserEdbAndClassifyPermissionList
  255. // @Description: 根据用户获取已经授权指标ID列表和指标分类ID列表
  256. // @author: Roc
  257. // @datetime 2024-03-28 17:20:36
  258. // @param userId int
  259. // @param edbInfoId int 如果传递了edbInfoId,则只返回该edbInfoId的权限列表(其实也就是为了判断是否存在该指标权限了,目的是为了少获取数据)
  260. // @param classifyId int classifyId,则只返回该classifyId的权限列表(其实也就是为了判断是否存在该指标分类权限了,目的是为了少获取数据)
  261. // @return edbIdList []int
  262. // @return classifyIdList []int
  263. // @return err error
  264. func GetUserEdbAndClassifyPermissionList(userId, edbInfoId, classifyId int) (edbIdList, classifyIdList []int, err error) {
  265. // 获取有权限的指标ID列表
  266. edbIdList, err = data_manage_permission.GetPermissionEdbIdList(userId, edbInfoId)
  267. if err != nil {
  268. fmt.Println("获取授权指标列表失败, err:", err)
  269. return
  270. }
  271. // 获取有权限的指标分类ID列表
  272. classifyIdList, err = data_manage_permission.GetPermissionEdbClassifyIdList(userId, classifyId)
  273. if err != nil {
  274. fmt.Println("获取授权指标分类列表失败, err:", err)
  275. return
  276. }
  277. return
  278. }
  279. // GetUserEdbClassifyPermissionList
  280. // @Description: 根据用户获取已经授权指标分类ID列表
  281. // @author: Roc
  282. // @datetime 2024-03-28 17:20:36
  283. // @param userId int
  284. // @param classifyId int classifyId,则只返回该classifyId的权限列表(其实也就是为了判断是否存在该指标分类权限了,目的是为了少获取数据)
  285. // @return classifyIdList []int
  286. // @return err error
  287. func GetUserEdbClassifyPermissionList(userId, classifyId int) (classifyIdList []int, err error) {
  288. // 获取有权限的指标分类ID列表
  289. classifyIdList, err = data_manage_permission.GetPermissionEdbClassifyIdList(userId, classifyId)
  290. if err != nil {
  291. fmt.Println("获取授权指标分类列表失败, err:", err)
  292. return
  293. }
  294. return
  295. }
  296. // CheckEdbPermissionByEdbInfoId
  297. // @Description: 根据指标id和指标分类id,检查EDB指标(含预测指标)权限(方法内部自己获取所有的指标和指标分类权限,不用额外传递)
  298. // @author: Roc
  299. // @datetime 2024-03-29 13:28:06
  300. // @param edbInfoId int
  301. // @param edbClassifyId int
  302. // @param edbIsJoinPermission int
  303. // @param userId int
  304. // @return hasAuth bool
  305. // @return err error
  306. func CheckEdbPermissionByEdbInfoId(edbInfoId, edbClassifyId, edbIsJoinPermission, userId int) (hasAuth bool, err error) {
  307. currClassify, err := data_manage.GetEdbClassifyById(edbClassifyId)
  308. if err != nil {
  309. return
  310. }
  311. if currClassify != nil {
  312. return CheckEdbPermission(edbIsJoinPermission, currClassify.IsJoinPermission, userId, edbInfoId, edbClassifyId)
  313. }
  314. return
  315. }
  316. // CheckEdbPermission
  317. // @Description: 检查EDB指标(含预测指标)权限(方法内部自己获取所有的指标和指标分类权限,不用额外传递)
  318. // @author: Roc
  319. // @datetime 2024-03-28 16:12:08
  320. // @param edbIsJoinPermission int
  321. // @param edbClassifyIsJoinPermission int
  322. // @param edbInfoId int
  323. // @param edbClassifyId int
  324. // @return hasAuth bool
  325. func CheckEdbPermission(edbIsJoinPermission, edbClassifyIsJoinPermission, userId, edbInfoId, edbClassifyId int) (hasAuth bool, err error) {
  326. edbIdList, classifyIdList, err := GetUserEdbAndClassifyPermissionList(userId, edbInfoId, edbClassifyId)
  327. if err != nil {
  328. fmt.Println("GetUserEdbAndClassifyPermissionList err:", err)
  329. return
  330. }
  331. hasAuth = CheckEdbPermissionByPermissionIdList(edbIsJoinPermission, edbClassifyIsJoinPermission, edbInfoId, edbClassifyId, edbIdList, classifyIdList)
  332. return
  333. }
  334. // GetEdbChartClassifyIdListPermissionByUserId
  335. // @Description: 根据用户id获取已经配置的分类id列表
  336. // @author: Roc
  337. // @datetime 2024-03-29 16:26:10
  338. // @param source int
  339. // @param subSource int
  340. // @param userId int
  341. // @return idList []int
  342. // @return err error
  343. func GetEdbChartClassifyIdListPermissionByUserId(source, subSource, userId int) (idList []int, err error) {
  344. switch source {
  345. case 3, 4: //ETA指标库、ETA预测指标
  346. //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
  347. //if tmpErr != nil {
  348. // err = tmpErr
  349. // return
  350. //}
  351. //if len(tmpList) > 0 {
  352. //}
  353. // 重新设置权限
  354. classifyType := 0
  355. if source == 4 {
  356. classifyType = 1
  357. }
  358. idList, err = data_manage_permission.GetPermissionEdbClassifyIdListByUserId(userId, classifyType)
  359. //case 5: //图库
  360. // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
  361. // if tmpErr != nil {
  362. // err = tmpErr
  363. // return
  364. // }
  365. // if len(tmpList) > 0 {
  366. // for _, v := range tmpList {
  367. // if v.SysUserId == newUserId {
  368. // errMsg = "新创建人不可和原创建人一致"
  369. // err = errors.New(errMsg)
  370. // return
  371. // }
  372. // }
  373. // // 修改创建人
  374. // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  375. // }
  376. //case 6: // ETA表格
  377. // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
  378. // if tmpErr != nil {
  379. // err = tmpErr
  380. // return
  381. // }
  382. // if len(tmpList) > 0 {
  383. // for _, v := range tmpList {
  384. // if v.SysUserId == newUserId {
  385. // errMsg = "新创建人不可和原创建人一致"
  386. // err = errors.New(errMsg)
  387. // return
  388. // }
  389. // }
  390. // // 修改创建人
  391. // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  392. // }
  393. default:
  394. return
  395. }
  396. return
  397. }
  398. // GetEdbChartIdListPermissionByDataId
  399. // @Description: 根据用户id获取已经配置的资产(指标、图表、表格)id列表
  400. // @author: Roc
  401. // @datetime 2024-03-29 16:26:10
  402. // @param source int
  403. // @param subSource int
  404. // @param dataId int
  405. // @return idList []int
  406. // @return err error
  407. func GetEdbChartIdListPermissionByDataId(source, subSource, dataId int) (idList []int, err error) {
  408. switch source {
  409. case 3, 4: //ETA指标库、ETA预测指标
  410. //tmpList, tmpErr := data_manage.GetEdbInfoListGroupByUserId(dataId)
  411. //if tmpErr != nil {
  412. // err = tmpErr
  413. // return
  414. //}
  415. //if len(tmpList) > 0 {
  416. //}
  417. // 重新设置权限
  418. edbInfoType := 0
  419. if source == 4 {
  420. edbInfoType = 1
  421. }
  422. idList, err = data_manage_permission.GetPermissionEdbIdListByDataId(dataId, edbInfoType)
  423. //case 5: //图库
  424. // tmpList, tmpErr := data_manage.GetChartInfoListGroupByUserId(dataId)
  425. // if tmpErr != nil {
  426. // err = tmpErr
  427. // return
  428. // }
  429. // if len(tmpList) > 0 {
  430. // for _, v := range tmpList {
  431. // if v.SysUserId == newUserId {
  432. // errMsg = "新创建人不可和原创建人一致"
  433. // err = errors.New(errMsg)
  434. // return
  435. // }
  436. // }
  437. // // 修改创建人
  438. // err = data_manage.ModifyChartInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  439. // }
  440. //case 6: // ETA表格
  441. // tmpList, tmpErr := excel.GetNoContentExcelListGroupByUserId(dataId)
  442. // if tmpErr != nil {
  443. // err = tmpErr
  444. // return
  445. // }
  446. // if len(tmpList) > 0 {
  447. // for _, v := range tmpList {
  448. // if v.SysUserId == newUserId {
  449. // errMsg = "新创建人不可和原创建人一致"
  450. // err = errors.New(errMsg)
  451. // return
  452. // }
  453. // }
  454. // // 修改创建人
  455. // err = excel.ModifyExcelInfoUserIdByCodeList(dataId, adminInfo.AdminId, adminInfo.RealName)
  456. // }
  457. default:
  458. return
  459. }
  460. return
  461. }