sys_dept.go 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. package controller
  2. import (
  3. "Medical_OAuth/app/admin/model"
  4. "Medical_OAuth/app/admin/service"
  5. "Medical_OAuth/app/admin/service/dto"
  6. "Medical_OAuth/common/actions"
  7. "github.com/gin-gonic/gin"
  8. "github.com/gin-gonic/gin/binding"
  9. "gogs.baozhida.cn/zoie/OAuth-core/api"
  10. "gogs.baozhida.cn/zoie/OAuth-core/pkg/jwtauth/user"
  11. _ "gogs.baozhida.cn/zoie/OAuth-core/pkg/response"
  12. )
  13. type SysDeptController struct {
  14. api.Api
  15. }
  16. // GetPage 获取部门列表
  17. // @Summary 获取部门列表
  18. // @Description 获取部门列表
  19. // @Tags 部门
  20. // @Param deptName query string false "部门名称"
  21. // @Success 200 {object} response.Response{data=response.Page{list=[]model.SysDept}} "{"code": 200, "data": [...]}"
  22. // @Router /api/dept [get]
  23. // @Security Bearer
  24. func (e SysDeptController) GetPage(c *gin.Context) {
  25. s := service.SysDept{}
  26. req := dto.SysDeptGetPageReq{}
  27. err := e.MakeContext(c).
  28. MakeOrm().
  29. Bind(&req, binding.Query).
  30. MakeService(&s.Service).
  31. Errors
  32. if err != nil {
  33. e.Logger.Error(err)
  34. e.Error(500, err, err.Error())
  35. return
  36. }
  37. //数据权限检查
  38. p := actions.GetPermissionFromContext(c)
  39. p.DeptId = user.GetDeptId(c)
  40. req.DeptId = user.GetDeptId(c)
  41. list := make([]model.SysDept, 0)
  42. list, err = s.SetDeptPage(&req, p)
  43. if err != nil {
  44. e.Error(500, err, err.Error())
  45. return
  46. }
  47. e.OK(list, "查询成功")
  48. }
  49. // Get 通过id获取部门
  50. // @Summary 通过id获取部门
  51. // @Description 通过id获取部门
  52. // @Tags 部门
  53. // @Param id path string true "部门id"
  54. // @Success 200 {object} response.Response{data=model.SysDept} "{"code": 200, "data": [...]}"
  55. // @Router /api/dept/{id} [get]
  56. // @Security Bearer
  57. func (e SysDeptController) Get(c *gin.Context) {
  58. s := service.SysDept{}
  59. req := dto.SysDeptGetReq{}
  60. err := e.MakeContext(c).
  61. MakeOrm().
  62. Bind(&req, nil).
  63. MakeService(&s.Service).
  64. Errors
  65. if err != nil {
  66. e.Logger.Error(err)
  67. e.Error(500, err, err.Error())
  68. return
  69. }
  70. var object model.SysDept
  71. //数据权限检查
  72. err = s.Get(&req, &object)
  73. if err != nil {
  74. e.Error(500, err, err.Error())
  75. return
  76. }
  77. e.OK(object, "查询成功")
  78. }
  79. // Insert 添加部门
  80. // @Summary 添加部门
  81. // @Description 添加部门
  82. // @Tags 部门
  83. // @Accept application/json
  84. // @Product application/json
  85. // @Param data body dto.SysDeptInsertReq true "data"
  86. // @Success 200 {string} string "{"code": 200, "message": "添加成功"}"
  87. // @Success 200 {string} string "{"code": -1, "message": "添加失败"}"
  88. // @Router /api/dept [post]
  89. // @Security Bearer
  90. func (e SysDeptController) Insert(c *gin.Context) {
  91. s := service.SysDept{}
  92. req := dto.SysDeptInsertReq{}
  93. err := e.MakeContext(c).
  94. MakeOrm().
  95. Bind(&req, binding.JSON).
  96. MakeService(&s.Service).
  97. Errors
  98. if err != nil {
  99. e.Logger.Error(err)
  100. e.Error(500, err, err.Error())
  101. return
  102. }
  103. // 设置创建人
  104. req.SetCreateBy(user.GetUserId(c))
  105. deptId := user.GetDeptId(c)
  106. err = s.Insert(&req, deptId)
  107. if err != nil {
  108. e.Error(500, err, err.Error())
  109. return
  110. }
  111. e.OK(req.GetId(), "创建成功")
  112. }
  113. // Update 修改部门
  114. // @Summary 修改部门
  115. // @Description 修改部门
  116. // @Tags 部门
  117. // @Accept application/json
  118. // @Product application/json
  119. // @Param id path string true "部门id"
  120. // @Param data body dto.SysDeptUpdateReq true "body"
  121. // @Success 200 {string} string "{"code": 200, "message": "添加成功"}"
  122. // @Success 200 {string} string "{"code": -1, "message": "添加失败"}"
  123. // @Router /api/dept [put]
  124. // @Security Bearer
  125. func (e SysDeptController) Update(c *gin.Context) {
  126. s := service.SysDept{}
  127. req := dto.SysDeptUpdateReq{}
  128. err := e.MakeContext(c).
  129. MakeOrm().
  130. Bind(&req).
  131. MakeService(&s.Service).
  132. Errors
  133. if err != nil {
  134. e.Logger.Error(err)
  135. e.Error(500, err, err.Error())
  136. return
  137. }
  138. req.SetUpdateBy(user.GetUserId(c))
  139. err = s.Update(&req)
  140. if err != nil {
  141. e.Error(500, err, err.Error())
  142. return
  143. }
  144. e.OK(req.GetId(), "更新成功")
  145. }
  146. // Delete 删除部门
  147. // @Summary 删除部门
  148. // @Description 删除部门
  149. // @Tags 部门
  150. // @Accept application/json
  151. // @Product application/json
  152. // @Param data body dto.SysDeptDeleteReq true "body"
  153. // @Success 200 {string} string "{"code": 200, "message": "删除成功"}"
  154. // @Success 200 {string} string "{"code": -1, "message": "删除失败"}"
  155. // @Router /api/dept [delete]
  156. // @Security Bearer
  157. func (e SysDeptController) Delete(c *gin.Context) {
  158. s := service.SysDept{}
  159. req := dto.SysDeptDeleteReq{}
  160. userSvc := service.SysUser{}
  161. err := e.MakeContext(c).
  162. MakeOrm().
  163. Bind(&req, binding.JSON, nil).
  164. MakeService(&s.Service).
  165. MakeService(&userSvc.Service).
  166. Errors
  167. if err != nil {
  168. e.Logger.Error(err)
  169. e.Error(500, err, err.Error())
  170. return
  171. }
  172. var count int64
  173. err = userSvc.GetCount(&dto.SysUserGetCountReq{DeptIds: []int{req.Id}}, &count)
  174. if err != nil {
  175. e.Error(500, err, err.Error())
  176. return
  177. }
  178. if count > 0 {
  179. e.Error(500, err, "有用户关联,禁止删除!")
  180. return
  181. }
  182. //数据权限检查
  183. //p := actions.GetPermissionFromContext(c)
  184. err = s.Remove(&req, nil)
  185. if err != nil {
  186. e.Error(500, err, err.Error())
  187. return
  188. }
  189. e.OK(req.GetId(), "删除成功")
  190. }
  191. // Enter 进入部门
  192. // @Summary 删除部门
  193. // @Description 删除部门
  194. // @Tags 部门
  195. // @Accept application/json
  196. // @Product application/json
  197. // @Param data body dto.SysDeptEnterReq true "body"
  198. // @Success 200 {string} string "{"code": 200, "message": "删除成功"}"
  199. // @Success 200 {string} string "{"code": -1, "message": "删除失败"}"
  200. // @Router /api/dept/enter [post]
  201. // @Security Bearer
  202. func (e SysDeptController) Enter(c *gin.Context) {
  203. s := service.SysDept{}
  204. req := dto.SysDeptEnterReq{}
  205. err := e.MakeContext(c).
  206. MakeOrm().
  207. Bind(&req).
  208. MakeService(&s.Service).
  209. Errors
  210. if err != nil {
  211. e.Logger.Error(err)
  212. e.Error(500, err, err.Error())
  213. return
  214. }
  215. var object model.SysDept
  216. //数据权限检查
  217. err = s.Get(&dto.SysDeptGetReq{
  218. Id: req.Id,
  219. }, &object)
  220. if err != nil {
  221. e.Error(500, err, err.Error())
  222. return
  223. }
  224. err = e.Cache.Set(model.GetEnterDeptCacheKey(user.GetUserId(c)), req.GetId(), -1)
  225. err = e.Cache.Set(model.GetEnterDeptNameCacheKey(user.GetUserId(c)), object.DeptName, -1)
  226. if err != nil {
  227. e.Logger.Error(err)
  228. e.Error(500, err, "进入失败")
  229. return
  230. }
  231. e.OK(req.GetId(), "进入成功")
  232. }