company.go 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. package controller
  2. import (
  3. "cold-delivery/app/admin/model"
  4. "cold-delivery/app/admin/service"
  5. "cold-delivery/app/admin/service/dto"
  6. "cold-delivery/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 CompanyController struct {
  14. api.Api
  15. }
  16. // GetPage 获取公司列表
  17. // @Summary 获取公司列表
  18. // @Description 获取公司列表(用户公司及子公司)
  19. // @Tags 公司
  20. // @Param name query string false "公司名称"
  21. // @Success 200 {object} response.Response{data=response.Page{list=[]model.SysDept}} "{"code": 200, "data": [...]}"
  22. // @Router /api/company [get]
  23. // @Security Bearer
  24. func (e CompanyController) GetPage(c *gin.Context) {
  25. s := service.Company{}
  26. req := dto.CompanyGetPageReq{}
  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. list := make([]model.SysDept, 0)
  41. var count int64
  42. err = s.GetPage(&req, &list, &count)
  43. list, err = s.SetDeptPage(&req, p)
  44. if err != nil {
  45. e.Error(500, err, err.Error())
  46. return
  47. }
  48. e.OK(list, "查询成功")
  49. }
  50. // GetUserPage 获取公司下面的用户列表
  51. // @Summary 获取公司下面的用户列表
  52. // @Description 获取公司下面的用户列表
  53. // @Tags 公司
  54. // @Param username query string false "用户名"
  55. // @Param status query string false "状态 1-停用 2-正常"
  56. // @Param pageSize query int false "页条数"
  57. // @Param page query int false "页码"
  58. // @Success 200 {object} response.Response{data=response.Page{list=[]model.SysUser}} "{"code": 200, "data": [...]}"
  59. // @Router /api/sys-user [get]
  60. // @Security Bearer
  61. func (e CompanyController) GetUserPage(c *gin.Context) {
  62. s := service.SysUser{}
  63. req := dto.SysUserGetPageByDeptIdReq{}
  64. err := e.MakeContext(c).
  65. MakeOrm().
  66. Bind(&req, binding.Query).
  67. MakeService(&s.Service).
  68. Errors
  69. if err != nil {
  70. e.Logger.Error(err)
  71. e.Error(500, err, err.Error())
  72. return
  73. }
  74. //数据权限检查
  75. p := actions.GetPermissionFromContext(c)
  76. list := make([]model.SysUser, 0)
  77. var count int64
  78. err = s.GetPageByDeptId(&req, p, &list, &count)
  79. if err != nil {
  80. e.Error(500, err, err.Error())
  81. return
  82. }
  83. e.PageOK(list, int(count), req.GetPageIndex(), req.GetPageSize(), "查询成功")
  84. }
  85. // GetAll 添加用户-获取公司列表
  86. // @Summary 添加用户-获取公司列表
  87. // @Description 添加用户-获取公司列表
  88. // @Tags 公司
  89. // @Param id path string true "公司id"
  90. // @Success 200 {object} response.Response{data=model.SysDept} "{"code": 200, "data": [...]}"
  91. // @Router /api/company/{id} [get]
  92. // @Security Bearer
  93. func (e CompanyController) GetAll(c *gin.Context) {
  94. s := service.Company{}
  95. req := dto.CompanyGetAllReq{}
  96. err := e.MakeContext(c).
  97. MakeOrm().
  98. Bind(&req, binding.Query).
  99. MakeService(&s.Service).
  100. Errors
  101. if err != nil {
  102. e.Logger.Error(err)
  103. e.Error(500, err, err.Error())
  104. return
  105. }
  106. //数据权限检查
  107. p := actions.GetPermissionFromContext(c)
  108. p.DeptId = user.GetDeptId(c)
  109. list := make([]model.SysDept, 0)
  110. var count int64
  111. err = s.GetAll(&req, &list, &count, p)
  112. if err != nil {
  113. e.Error(500, err, err.Error())
  114. return
  115. }
  116. e.PageOK(list, int(count), 0, 0, "查询成功")
  117. }
  118. // Get 通过id获取公司
  119. // @Summary 通过id获取公司
  120. // @Description 通过id获取公司
  121. // @Tags 公司
  122. // @Param id path string true "公司id"
  123. // @Success 200 {object} response.Response{data=model.SysDept} "{"code": 200, "data": [...]}"
  124. // @Router /api/company/{id} [get]
  125. // @Security Bearer
  126. func (e CompanyController) Get(c *gin.Context) {
  127. s := service.Company{}
  128. req := dto.CompanyGetReq{}
  129. err := e.MakeContext(c).
  130. MakeOrm().
  131. Bind(&req, nil).
  132. MakeService(&s.Service).
  133. Errors
  134. if err != nil {
  135. e.Logger.Error(err)
  136. e.Error(500, err, err.Error())
  137. return
  138. }
  139. var object model.SysDept
  140. //数据权限检查
  141. err = s.Get(&req, &object)
  142. if err != nil {
  143. e.Error(500, err, err.Error())
  144. return
  145. }
  146. e.OK(object, "查询成功")
  147. }
  148. // Insert 添加公司
  149. // @Summary 添加公司
  150. // @Description 添加公司
  151. // @Tags 公司
  152. // @Accept application/json
  153. // @Product application/json
  154. // @Param data body dto.CompanyInsertReq true "data"
  155. // @Success 200 {string} string "{"code": 200, "message": "添加成功"}"
  156. // @Success 200 {string} string "{"code": -1, "message": "添加失败"}"
  157. // @Router /api/company [post]
  158. // @Security Bearer
  159. func (e CompanyController) Insert(c *gin.Context) {
  160. s := service.Company{}
  161. req := dto.CompanyInsertReq{}
  162. err := e.MakeContext(c).
  163. MakeOrm().
  164. Bind(&req, binding.JSON).
  165. MakeService(&s.Service).
  166. Errors
  167. if err != nil {
  168. e.Logger.Error(err)
  169. e.Error(500, err, err.Error())
  170. return
  171. }
  172. // 设置创建人
  173. req.SetCreateBy(user.GetUserId(c))
  174. err = s.Insert(&req)
  175. if err != nil {
  176. e.Error(500, err, err.Error())
  177. return
  178. }
  179. e.OK(req.GetId(), "创建成功")
  180. }
  181. // Update 修改公司
  182. // @Summary 修改公司
  183. // @Description 修改公司
  184. // @Tags 公司
  185. // @Accept application/json
  186. // @Product application/json
  187. // @Param data body dto.CompanyUpdateReq true "body"
  188. // @Success 200 {string} string "{"code": 200, "message": "添加成功"}"
  189. // @Success 200 {string} string "{"code": -1, "message": "添加失败"}"
  190. // @Router /api/company [put]
  191. // @Security Bearer
  192. func (e CompanyController) Update(c *gin.Context) {
  193. s := service.Company{}
  194. req := dto.CompanyUpdateReq{}
  195. err := e.MakeContext(c).
  196. MakeOrm().
  197. Bind(&req).
  198. MakeService(&s.Service).
  199. Errors
  200. if err != nil {
  201. e.Logger.Error(err)
  202. e.Error(500, err, err.Error())
  203. return
  204. }
  205. req.SetUpdateBy(user.GetUserId(c))
  206. err = s.Update(&req)
  207. if err != nil {
  208. e.Error(500, err, err.Error())
  209. return
  210. }
  211. e.OK(req.GetId(), "更新成功")
  212. }
  213. // Delete 删除公司
  214. // @Summary 删除公司
  215. // @Description 删除公司
  216. // @Tags 公司
  217. // @Accept application/json
  218. // @Product application/json
  219. // @Param data body dto.CompanyDeleteReq true "body"
  220. // @Success 200 {string} string "{"code": 200, "message": "删除成功"}"
  221. // @Success 200 {string} string "{"code": -1, "message": "删除失败"}"
  222. // @Router /api/company [delete]
  223. // @Security Bearer
  224. func (e CompanyController) Delete(c *gin.Context) {
  225. s := service.Company{}
  226. req := dto.CompanyDeleteReq{}
  227. err := e.MakeContext(c).
  228. MakeOrm().
  229. Bind(&req, binding.JSON, nil).
  230. MakeService(&s.Service).
  231. Errors
  232. if err != nil {
  233. e.Logger.Error(err)
  234. e.Error(500, err, err.Error())
  235. return
  236. }
  237. //数据权限检查
  238. //p := actions.GetPermissionFromContext(c)
  239. err = s.Remove(&req, nil)
  240. if err != nil {
  241. e.Error(500, err, err.Error())
  242. return
  243. }
  244. e.OK(req.GetId(), "删除成功")
  245. }