data_manage_permission.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. package data_manage
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/data_manage"
  7. "eta/eta_api/services/data"
  8. "eta/eta_api/utils"
  9. )
  10. // DataMangePermissionController 数据权限管理
  11. type DataMangePermissionController struct {
  12. controllers.BaseAuthController
  13. }
  14. // SetEdbChartPermission
  15. // @Title 指标/图表/表格权限设置接口
  16. // @Description 指标/图表/表格权限设置接口
  17. // @Param request body data_manage.SetEdbChartPermissionReq true "type json string"
  18. // @Success 200 {object} data_manage.ChartListResp
  19. // @router /edb_chart/permission/set [post]
  20. func (c *DataMangePermissionController) SetEdbChartPermission() {
  21. br := new(models.BaseResponse).Init()
  22. defer func() {
  23. c.Data["json"] = br
  24. c.ServeJSON()
  25. }()
  26. sysUser := c.SysUser
  27. if sysUser == nil {
  28. br.Msg = "请登录"
  29. br.ErrMsg = "请登录,SysUser Is Empty"
  30. br.Ret = 408
  31. return
  32. }
  33. var req data_manage.SetEdbChartPermissionReq
  34. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  35. if err != nil {
  36. br.Msg = "参数解析异常!"
  37. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  38. return
  39. }
  40. if req.Source <= 0 || req.Source > 6 {
  41. br.Msg = "错误的来源"
  42. br.IsSendEmail = false
  43. return
  44. }
  45. // 子来源(目前作用于ETA表格,2024-3-26 14:12:09)
  46. if req.Source == 6 && (req.SubSource <= utils.EXCEL_DEFAULT || req.SubSource > utils.CUSTOM_ANALYSIS_TABLE) {
  47. br.Msg = "错误的子来源"
  48. br.IsSendEmail = false
  49. return
  50. }
  51. if !req.IsSelectAll && len(req.DataIdList) <= 0 {
  52. br.Msg = "请勾选数据项"
  53. br.IsSendEmail = false
  54. return
  55. }
  56. err, errMsg := data.SetEdbChartPermission(req.Source, req.SubSource, req.UserId, req.UserList, req.IsSelectAll, req.DataIdList, req.NoDataIdList, req.Keyword, req.ClassifyId)
  57. if err != nil {
  58. //br.Success = true
  59. br.Msg = "设置失败"
  60. if errMsg != `` {
  61. br.Msg = errMsg
  62. }
  63. br.ErrMsg = "设置失败,Err:" + err.Error()
  64. return
  65. }
  66. br.Ret = 200
  67. br.IsAddLog = true
  68. br.Success = true
  69. br.Msg = "设置成功"
  70. }
  71. // SetPermissionEdbChartClassifyIsPermission
  72. // @Title 指标/图表/表格分类是否涉密设置接口
  73. // @Description 指标/图表/表格分类是否涉密设置接口
  74. // @Param request body data_manage.MoveEdbChartReq true "type json string"
  75. // @Success 200 {object} data_manage.ChartListResp
  76. // @router /edb_chart/classify/permission/is_permission/set [post]
  77. func (c *DataMangePermissionController) SetPermissionEdbChartClassifyIsPermission() {
  78. br := new(models.BaseResponse).Init()
  79. defer func() {
  80. c.Data["json"] = br
  81. c.ServeJSON()
  82. }()
  83. sysUser := c.SysUser
  84. if sysUser == nil {
  85. br.Msg = "请登录"
  86. br.ErrMsg = "请登录,SysUser Is Empty"
  87. br.Ret = 408
  88. return
  89. }
  90. var req data_manage.SetDataIsPermissionReq
  91. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  92. if err != nil {
  93. br.Msg = "参数解析异常!"
  94. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  95. return
  96. }
  97. if req.Source <= 0 || req.Source > 6 {
  98. br.Msg = "错误的来源"
  99. br.IsSendEmail = false
  100. return
  101. }
  102. // 子来源(目前作用于ETA表格,2024-3-26 14:12:09)
  103. if req.Source == 6 && (req.SubSource <= utils.EXCEL_DEFAULT || req.SubSource > utils.CUSTOM_ANALYSIS_TABLE) {
  104. br.Msg = "错误的子来源"
  105. br.IsSendEmail = false
  106. return
  107. }
  108. err, errMsg := data.SetDataIsPermission(req.Source, req.SubSource, req.ClassifyIdList)
  109. if err != nil {
  110. //br.Success = true
  111. br.Msg = "设置失败"
  112. if errMsg != `` {
  113. br.Msg = errMsg
  114. }
  115. br.ErrMsg = "设置失败,Err:" + err.Error()
  116. return
  117. }
  118. br.Ret = 200
  119. br.IsAddLog = true
  120. br.Success = true
  121. br.Msg = "设置成功"
  122. }
  123. // SetEdbChartClassifyPermission
  124. // @Title 指标/图表/表格分类权限设置接口
  125. // @Description 指标/图表/表格分类权限设置接口
  126. // @Param request body data_manage.SetEdbChartClassifyPermissionReq true "type json string"
  127. // @Success 200 {object} data_manage.ChartListResp
  128. // @router /edb_chart/classify/permission/set [post]
  129. func (c *DataMangePermissionController) SetEdbChartClassifyPermission() {
  130. br := new(models.BaseResponse).Init()
  131. defer func() {
  132. c.Data["json"] = br
  133. c.ServeJSON()
  134. }()
  135. sysUser := c.SysUser
  136. if sysUser == nil {
  137. br.Msg = "请登录"
  138. br.ErrMsg = "请登录,SysUser Is Empty"
  139. br.Ret = 408
  140. return
  141. }
  142. var req data_manage.SetEdbChartClassifyPermissionReq
  143. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  144. if err != nil {
  145. br.Msg = "参数解析异常!"
  146. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  147. return
  148. }
  149. if req.Source <= 0 || req.Source > 6 {
  150. br.Msg = "错误的来源"
  151. br.IsSendEmail = false
  152. return
  153. }
  154. // 子来源(目前作用于ETA表格,2024-3-26 14:12:09)
  155. if req.Source == 6 && (req.SubSource <= utils.EXCEL_DEFAULT || req.SubSource > utils.CUSTOM_ANALYSIS_TABLE) {
  156. br.Msg = "错误的子来源"
  157. br.IsSendEmail = false
  158. return
  159. }
  160. if len(req.UserList) <= 0 {
  161. br.Msg = "请选择用户"
  162. br.IsSendEmail = false
  163. return
  164. }
  165. err, errMsg := data.SetEdbChartClassifyPermission(req.Source, req.SubSource, req.UserList, req.ClassifyIdList)
  166. if err != nil {
  167. //br.Success = true
  168. br.Msg = "设置失败"
  169. if errMsg != `` {
  170. br.Msg = errMsg
  171. }
  172. br.ErrMsg = "设置失败,Err:" + err.Error()
  173. return
  174. }
  175. br.Ret = 200
  176. br.IsAddLog = true
  177. br.Success = true
  178. br.Msg = "设置成功"
  179. }