user.go 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. package admin
  2. import (
  3. "github.com/gin-gonic/gin"
  4. "github.com/lejianwen/rustdesk-api/global"
  5. "github.com/lejianwen/rustdesk-api/http/request/admin"
  6. "github.com/lejianwen/rustdesk-api/http/response"
  7. adResp "github.com/lejianwen/rustdesk-api/http/response/admin"
  8. "github.com/lejianwen/rustdesk-api/model"
  9. "github.com/lejianwen/rustdesk-api/service"
  10. "gorm.io/gorm"
  11. "strconv"
  12. )
  13. type User struct {
  14. }
  15. // Detail 管理员
  16. // @Tags 用户
  17. // @Summary 管理员详情
  18. // @Description 管理员详情
  19. // @Accept json
  20. // @Produce json
  21. // @Param id path int true "ID"
  22. // @Success 200 {object} response.Response{data=model.User}
  23. // @Failure 500 {object} response.Response
  24. // @Router /admin/user/detail/{id} [get]
  25. // @Security token
  26. func (ct *User) Detail(c *gin.Context) {
  27. id := c.Param("id")
  28. iid, _ := strconv.Atoi(id)
  29. u := service.AllService.UserService.InfoById(uint(iid))
  30. if u.Id > 0 {
  31. response.Success(c, u)
  32. return
  33. }
  34. response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
  35. return
  36. }
  37. // Create 管理员
  38. // @Tags 用户
  39. // @Summary 创建管理员
  40. // @Description 创建管理员
  41. // @Accept json
  42. // @Produce json
  43. // @Param body body admin.UserForm true "管理员信息"
  44. // @Success 200 {object} response.Response{data=model.User}
  45. // @Failure 500 {object} response.Response
  46. // @Router /admin/user/create [post]
  47. // @Security token
  48. func (ct *User) Create(c *gin.Context) {
  49. f := &admin.UserForm{}
  50. if err := c.ShouldBindJSON(f); err != nil {
  51. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  52. return
  53. }
  54. errList := global.Validator.ValidStruct(c, f)
  55. if len(errList) > 0 {
  56. response.Fail(c, 101, errList[0])
  57. return
  58. }
  59. u := f.ToUser()
  60. err := service.AllService.UserService.Create(u)
  61. if err != nil {
  62. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  63. return
  64. }
  65. response.Success(c, nil)
  66. }
  67. // List 列表
  68. // @Tags 用户
  69. // @Summary 管理员列表
  70. // @Description 管理员列表
  71. // @Accept json
  72. // @Produce json
  73. // @Param page query int false "页码"
  74. // @Param page_size query int false "页大小"
  75. // @Param username query int false "账户"
  76. // @Success 200 {object} response.Response{data=model.UserList}
  77. // @Failure 500 {object} response.Response
  78. // @Router /admin/user/list [get]
  79. // @Security token
  80. func (ct *User) List(c *gin.Context) {
  81. query := &admin.UserQuery{}
  82. if err := c.ShouldBindQuery(query); err != nil {
  83. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  84. return
  85. }
  86. res := service.AllService.UserService.List(query.Page, query.PageSize, func(tx *gorm.DB) {
  87. if query.Username != "" {
  88. tx.Where("username like ?", "%"+query.Username+"%")
  89. }
  90. })
  91. response.Success(c, res)
  92. }
  93. // Update 编辑
  94. // @Tags 用户
  95. // @Summary 管理员编辑
  96. // @Description 管理员编辑
  97. // @Accept json
  98. // @Produce json
  99. // @Param body body admin.UserForm true "用户信息"
  100. // @Success 200 {object} response.Response{data=model.User}
  101. // @Failure 500 {object} response.Response
  102. // @Router /admin/user/update [post]
  103. // @Security token
  104. func (ct *User) Update(c *gin.Context) {
  105. f := &admin.UserForm{}
  106. if err := c.ShouldBindJSON(f); err != nil {
  107. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  108. return
  109. }
  110. if f.Id == 0 {
  111. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError"))
  112. return
  113. }
  114. errList := global.Validator.ValidStruct(c, f)
  115. if len(errList) > 0 {
  116. response.Fail(c, 101, errList[0])
  117. return
  118. }
  119. u := f.ToUser()
  120. err := service.AllService.UserService.Update(u)
  121. if err != nil {
  122. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  123. return
  124. }
  125. response.Success(c, nil)
  126. }
  127. // Delete 删除
  128. // @Tags 用户
  129. // @Summary 管理员删除
  130. // @Description 管理员编删除
  131. // @Accept json
  132. // @Produce json
  133. // @Param body body admin.UserForm true "用户信息"
  134. // @Success 200 {object} response.Response
  135. // @Failure 500 {object} response.Response
  136. // @Router /admin/user/delete [post]
  137. // @Security token
  138. func (ct *User) Delete(c *gin.Context) {
  139. f := &admin.UserForm{}
  140. if err := c.ShouldBindJSON(f); err != nil {
  141. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  142. return
  143. }
  144. id := f.Id
  145. errList := global.Validator.ValidVar(c, id, "required,gt=0")
  146. if len(errList) > 0 {
  147. response.Fail(c, 101, errList[0])
  148. return
  149. }
  150. u := service.AllService.UserService.InfoById(f.Id)
  151. if u.Id > 0 {
  152. err := service.AllService.UserService.Delete(u)
  153. if err == nil {
  154. response.Success(c, nil)
  155. return
  156. }
  157. response.Fail(c, 101, err.Error())
  158. return
  159. }
  160. response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
  161. }
  162. // UpdatePassword 修改密码
  163. // @Tags 用户
  164. // @Summary 修改密码
  165. // @Description 修改密码
  166. // @Accept json
  167. // @Produce json
  168. // @Param body body admin.UserPasswordForm true "用户信息"
  169. // @Success 200 {object} response.Response
  170. // @Failure 500 {object} response.Response
  171. // @Router /admin/user/updatePassword [post]
  172. // @Security token
  173. func (ct *User) UpdatePassword(c *gin.Context) {
  174. f := &admin.UserPasswordForm{}
  175. if err := c.ShouldBindJSON(f); err != nil {
  176. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  177. return
  178. }
  179. errList := global.Validator.ValidStruct(c, f)
  180. if len(errList) > 0 {
  181. response.Fail(c, 101, errList[0])
  182. return
  183. }
  184. u := service.AllService.UserService.InfoById(f.Id)
  185. if u.Id == 0 {
  186. response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
  187. return
  188. }
  189. err := service.AllService.UserService.UpdatePassword(u, f.Password)
  190. if err != nil {
  191. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  192. return
  193. }
  194. response.Success(c, nil)
  195. }
  196. // Current 当前用户
  197. // @Tags 用户
  198. // @Summary 当前用户
  199. // @Description 当前用户
  200. // @Accept json
  201. // @Produce json
  202. // @Success 200 {object} response.Response{data=adResp.LoginPayload}
  203. // @Failure 500 {object} response.Response
  204. // @Router /admin/user/current [get]
  205. // @Security token
  206. func (ct *User) Current(c *gin.Context) {
  207. u := service.AllService.UserService.CurUser(c)
  208. token, _ := c.Get("token")
  209. t := token.(string)
  210. responseLoginSuccess(c, u, t)
  211. }
  212. // ChangeCurPwd 修改当前用户密码
  213. // @Tags 用户
  214. // @Summary 修改当前用户密码
  215. // @Description 修改当前用户密码
  216. // @Accept json
  217. // @Produce json
  218. // @Param body body admin.ChangeCurPasswordForm true "用户信息"
  219. // @Success 200 {object} response.Response
  220. // @Failure 500 {object} response.Response
  221. // @Router /admin/user/changeCurPwd [post]
  222. // @Security token
  223. func (ct *User) ChangeCurPwd(c *gin.Context) {
  224. f := &admin.ChangeCurPasswordForm{}
  225. if err := c.ShouldBindJSON(f); err != nil {
  226. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  227. return
  228. }
  229. errList := global.Validator.ValidStruct(c, f)
  230. if len(errList) > 0 {
  231. response.Fail(c, 101, errList[0])
  232. return
  233. }
  234. u := service.AllService.UserService.CurUser(c)
  235. // If the password is not empty, the old password is verified
  236. // otherwise, the old password is not verified
  237. if !service.AllService.UserService.IsPasswordEmptyByUser(u) {
  238. oldPwd := service.AllService.UserService.EncryptPassword(f.OldPassword)
  239. if u.Password != oldPwd {
  240. response.Fail(c, 101, response.TranslateMsg(c, "OldPasswordError"))
  241. return
  242. }
  243. }
  244. err := service.AllService.UserService.UpdatePassword(u, f.NewPassword)
  245. if err != nil {
  246. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
  247. return
  248. }
  249. response.Success(c, nil)
  250. }
  251. // MyOauth
  252. // @Tags 用户
  253. // @Summary 我的授权
  254. // @Description 我的授权
  255. // @Accept json
  256. // @Produce json
  257. // @Success 200 {object} response.Response{data=[]adResp.UserOauthItem}
  258. // @Failure 500 {object} response.Response
  259. // @Router /admin/user/myOauth [get]
  260. // @Security token
  261. func (ct *User) MyOauth(c *gin.Context) {
  262. u := service.AllService.UserService.CurUser(c)
  263. oal := service.AllService.OauthService.List(1, 100, nil)
  264. ops := make([]string, 0)
  265. for _, oa := range oal.Oauths {
  266. ops = append(ops, oa.Op)
  267. }
  268. uts := service.AllService.UserService.UserThirdsByUserId(u.Id)
  269. var res []*adResp.UserOauthItem
  270. for _, oa := range oal.Oauths {
  271. item := &adResp.UserOauthItem{
  272. Op: oa.Op,
  273. }
  274. for _, ut := range uts {
  275. if ut.Op == oa.Op {
  276. item.Status = 1
  277. break
  278. }
  279. }
  280. res = append(res, item)
  281. }
  282. response.Success(c, res)
  283. }
  284. // groupUsers
  285. func (ct *User) GroupUsers(c *gin.Context) {
  286. q := &admin.GroupUsersQuery{}
  287. if err := c.ShouldBindJSON(q); err != nil {
  288. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  289. return
  290. }
  291. u := service.AllService.UserService.CurUser(c)
  292. gid := u.GroupId
  293. uid := u.Id
  294. if service.AllService.UserService.IsAdmin(u) && q.UserId > 0 {
  295. nu := service.AllService.UserService.InfoById(q.UserId)
  296. gid = nu.GroupId
  297. uid = q.UserId
  298. }
  299. res := service.AllService.UserService.List(1, 999, func(tx *gorm.DB) {
  300. tx.Where("group_id = ?", gid)
  301. })
  302. var data []*adResp.GroupUsersPayload
  303. for _, _u := range res.Users {
  304. gup := &adResp.GroupUsersPayload{}
  305. gup.FromUser(_u)
  306. if _u.Id == uid {
  307. gup.Status = 0
  308. }
  309. data = append(data, gup)
  310. }
  311. response.Success(c, data)
  312. }
  313. // Register
  314. func (ct *User) Register(c *gin.Context) {
  315. if !global.Config.App.Register {
  316. response.Fail(c, 101, response.TranslateMsg(c, "RegisterClosed"))
  317. return
  318. }
  319. f := &admin.RegisterForm{}
  320. if err := c.ShouldBindJSON(f); err != nil {
  321. response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
  322. return
  323. }
  324. errList := global.Validator.ValidStruct(c, f)
  325. if len(errList) > 0 {
  326. response.Fail(c, 101, errList[0])
  327. return
  328. }
  329. u := service.AllService.UserService.Register(f.Username, f.Email, f.Password)
  330. if u == nil || u.Id == 0 {
  331. response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed"))
  332. return
  333. }
  334. // 注册成功后自动登录
  335. ut := service.AllService.UserService.Login(u, &model.LoginLog{
  336. UserId: u.Id,
  337. Client: model.LoginLogClientWebAdmin,
  338. Uuid: "",
  339. Ip: c.ClientIP(),
  340. Type: model.LoginLogTypeAccount,
  341. })
  342. responseLoginSuccess(c, u, ut.Token)
  343. }