| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404 |
- package admin
- import (
- "Gwen/global"
- "Gwen/http/request/admin"
- "Gwen/http/response"
- adResp "Gwen/http/response/admin"
- "Gwen/model"
- "Gwen/service"
- "github.com/gin-gonic/gin"
- "gorm.io/gorm"
- "strconv"
- "time"
- )
- type User struct {
- }
- // Detail 管理员
- // @Tags 用户
- // @Summary 管理员详情
- // @Description 管理员详情
- // @Accept json
- // @Produce json
- // @Param id path int true "ID"
- // @Success 200 {object} response.Response{data=model.User}
- // @Failure 500 {object} response.Response
- // @Router /admin/user/detail/{id} [get]
- // @Security token
- func (ct *User) Detail(c *gin.Context) {
- id := c.Param("id")
- iid, _ := strconv.Atoi(id)
- u := service.AllService.UserService.InfoById(uint(iid))
- if u.Id > 0 {
- response.Success(c, u)
- return
- }
- response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
- return
- }
- // Create 管理员
- // @Tags 用户
- // @Summary 创建管理员
- // @Description 创建管理员
- // @Accept json
- // @Produce json
- // @Param body body admin.UserForm true "管理员信息"
- // @Success 200 {object} response.Response{data=model.User}
- // @Failure 500 {object} response.Response
- // @Router /admin/user/create [post]
- // @Security token
- func (ct *User) Create(c *gin.Context) {
- f := &admin.UserForm{}
- if err := c.ShouldBindJSON(f); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- errList := global.Validator.ValidStruct(c, f)
- if len(errList) > 0 {
- response.Fail(c, 101, errList[0])
- return
- }
- u := f.ToUser()
- err := service.AllService.UserService.Create(u)
- if err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
- return
- }
- response.Success(c, nil)
- }
- // List 列表
- // @Tags 用户
- // @Summary 管理员列表
- // @Description 管理员列表
- // @Accept json
- // @Produce json
- // @Param page query int false "页码"
- // @Param page_size query int false "页大小"
- // @Param username query int false "账户"
- // @Success 200 {object} response.Response{data=model.UserList}
- // @Failure 500 {object} response.Response
- // @Router /admin/user/list [get]
- // @Security token
- func (ct *User) List(c *gin.Context) {
- query := &admin.UserQuery{}
- if err := c.ShouldBindQuery(query); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- res := service.AllService.UserService.List(query.Page, query.PageSize, func(tx *gorm.DB) {
- if query.Username != "" {
- tx.Where("username like ?", "%"+query.Username+"%")
- }
- })
- response.Success(c, res)
- }
- // Update 编辑
- // @Tags 用户
- // @Summary 管理员编辑
- // @Description 管理员编辑
- // @Accept json
- // @Produce json
- // @Param body body admin.UserForm true "用户信息"
- // @Success 200 {object} response.Response{data=model.User}
- // @Failure 500 {object} response.Response
- // @Router /admin/user/update [post]
- // @Security token
- func (ct *User) Update(c *gin.Context) {
- f := &admin.UserForm{}
- if err := c.ShouldBindJSON(f); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- if f.Id == 0 {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError"))
- return
- }
- errList := global.Validator.ValidStruct(c, f)
- if len(errList) > 0 {
- response.Fail(c, 101, errList[0])
- return
- }
- u := f.ToUser()
- err := service.AllService.UserService.Update(u)
- if err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
- return
- }
- response.Success(c, nil)
- }
- // Delete 删除
- // @Tags 用户
- // @Summary 管理员删除
- // @Description 管理员编删除
- // @Accept json
- // @Produce json
- // @Param body body admin.UserForm true "用户信息"
- // @Success 200 {object} response.Response
- // @Failure 500 {object} response.Response
- // @Router /admin/user/delete [post]
- // @Security token
- func (ct *User) Delete(c *gin.Context) {
- f := &admin.UserForm{}
- if err := c.ShouldBindJSON(f); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- id := f.Id
- errList := global.Validator.ValidVar(c, id, "required,gt=0")
- if len(errList) > 0 {
- response.Fail(c, 101, errList[0])
- return
- }
- u := service.AllService.UserService.InfoById(f.Id)
- if u.Id > 0 {
- err := service.AllService.UserService.Delete(u)
- if err == nil {
- response.Success(c, nil)
- return
- }
- response.Fail(c, 101, err.Error())
- return
- }
- response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
- }
- // UpdatePassword 修改密码
- // @Tags 用户
- // @Summary 修改密码
- // @Description 修改密码
- // @Accept json
- // @Produce json
- // @Param body body admin.UserPasswordForm true "用户信息"
- // @Success 200 {object} response.Response
- // @Failure 500 {object} response.Response
- // @Router /admin/user/updatePassword [post]
- // @Security token
- func (ct *User) UpdatePassword(c *gin.Context) {
- f := &admin.UserPasswordForm{}
- if err := c.ShouldBindJSON(f); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- errList := global.Validator.ValidStruct(c, f)
- if len(errList) > 0 {
- response.Fail(c, 101, errList[0])
- return
- }
- u := service.AllService.UserService.InfoById(f.Id)
- if u.Id == 0 {
- response.Fail(c, 101, response.TranslateMsg(c, "ItemNotFound"))
- return
- }
- err := service.AllService.UserService.UpdatePassword(u, f.Password)
- if err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
- return
- }
- response.Success(c, nil)
- }
- // Current 当前用户
- // @Tags 用户
- // @Summary 当前用户
- // @Description 当前用户
- // @Accept json
- // @Produce json
- // @Success 200 {object} response.Response{data=adResp.LoginPayload}
- // @Failure 500 {object} response.Response
- // @Router /admin/user/current [get]
- // @Security token
- func (ct *User) Current(c *gin.Context) {
- u := service.AllService.UserService.CurUser(c)
- token, _ := c.Get("token")
- t := token.(string)
- responseLoginSuccess(c, u, t)
- }
- // ChangeCurPwd 修改当前用户密码
- // @Tags 用户
- // @Summary 修改当前用户密码
- // @Description 修改当前用户密码
- // @Accept json
- // @Produce json
- // @Param body body admin.ChangeCurPasswordForm true "用户信息"
- // @Success 200 {object} response.Response
- // @Failure 500 {object} response.Response
- // @Router /admin/user/changeCurPwd [post]
- // @Security token
- func (ct *User) ChangeCurPwd(c *gin.Context) {
- f := &admin.ChangeCurPasswordForm{}
- if err := c.ShouldBindJSON(f); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- errList := global.Validator.ValidStruct(c, f)
- if len(errList) > 0 {
- response.Fail(c, 101, errList[0])
- return
- }
- u := service.AllService.UserService.CurUser(c)
- // If the password is not empty, the old password is verified
- // otherwise, the old password is not verified
- if !service.AllService.UserService.IsPasswordEmptyByUser(u) {
- oldPwd := service.AllService.UserService.EncryptPassword(f.OldPassword)
- if u.Password != oldPwd {
- response.Fail(c, 101, response.TranslateMsg(c, "OldPasswordError"))
- return
- }
- }
- err := service.AllService.UserService.UpdatePassword(u, f.NewPassword)
- if err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed")+err.Error())
- return
- }
- response.Success(c, nil)
- }
- // MyOauth
- // @Tags 用户
- // @Summary 我的授权
- // @Description 我的授权
- // @Accept json
- // @Produce json
- // @Success 200 {object} response.Response{data=[]adResp.UserOauthItem}
- // @Failure 500 {object} response.Response
- // @Router /admin/user/myOauth [get]
- // @Security token
- func (ct *User) MyOauth(c *gin.Context) {
- u := service.AllService.UserService.CurUser(c)
- oal := service.AllService.OauthService.List(1, 100, nil)
- ops := make([]string, 0)
- for _, oa := range oal.Oauths {
- ops = append(ops, oa.Op)
- }
- uts := service.AllService.UserService.UserThirdsByUserId(u.Id)
- var res []*adResp.UserOauthItem
- for _, oa := range oal.Oauths {
- item := &adResp.UserOauthItem{
- Op: oa.Op,
- }
- for _, ut := range uts {
- if ut.Op == oa.Op {
- item.Status = 1
- break
- }
- }
- res = append(res, item)
- }
- response.Success(c, res)
- }
- // MyPeer 列表
- // @Tags 设备
- // @Summary 我的设备列表
- // @Description 我的设备列表
- // @Accept json
- // @Produce json
- // @Param page query int false "页码"
- // @Param page_size query int false "页大小"
- // @Param time_ago query int false "时间"
- // @Param id query string false "ID"
- // @Param hostname query string false "主机名"
- // @Param uuids query string false "uuids 用逗号分隔"
- // @Success 200 {object} response.Response{data=model.PeerList}
- // @Failure 500 {object} response.Response
- // @Router /admin/user/myPeer [get]
- // @Security token
- func (ct *User) MyPeer(c *gin.Context) {
- query := &admin.PeerQuery{}
- if err := c.ShouldBindQuery(query); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- u := service.AllService.UserService.CurUser(c)
- res := service.AllService.PeerService.ListFilterByUserId(query.Page, query.PageSize, func(tx *gorm.DB) {
- if query.TimeAgo > 0 {
- lt := time.Now().Unix() - int64(query.TimeAgo)
- tx.Where("last_online_time < ?", lt)
- }
- if query.TimeAgo < 0 {
- lt := time.Now().Unix() + int64(query.TimeAgo)
- tx.Where("last_online_time > ?", lt)
- }
- if query.Id != "" {
- tx.Where("id like ?", "%"+query.Id+"%")
- }
- if query.Hostname != "" {
- tx.Where("hostname like ?", "%"+query.Hostname+"%")
- }
- if query.Uuids != "" {
- tx.Where("uuid in (?)", query.Uuids)
- }
- }, u.Id)
- response.Success(c, res)
- }
- // groupUsers
- func (ct *User) GroupUsers(c *gin.Context) {
- q := &admin.GroupUsersQuery{}
- if err := c.ShouldBindJSON(q); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- u := service.AllService.UserService.CurUser(c)
- gid := u.GroupId
- uid := u.Id
- if service.AllService.UserService.IsAdmin(u) && q.UserId > 0 {
- nu := service.AllService.UserService.InfoById(q.UserId)
- gid = nu.GroupId
- uid = q.UserId
- }
- res := service.AllService.UserService.List(1, 999, func(tx *gorm.DB) {
- tx.Where("group_id = ?", gid)
- })
- var data []*adResp.GroupUsersPayload
- for _, _u := range res.Users {
- gup := &adResp.GroupUsersPayload{}
- gup.FromUser(_u)
- if _u.Id == uid {
- gup.Status = 0
- }
- data = append(data, gup)
- }
- response.Success(c, data)
- }
- // Register
- func (ct *User) Register(c *gin.Context) {
- if !global.Config.App.Register {
- response.Fail(c, 101, response.TranslateMsg(c, "RegisterClosed"))
- return
- }
- f := &admin.RegisterForm{}
- if err := c.ShouldBindJSON(f); err != nil {
- response.Fail(c, 101, response.TranslateMsg(c, "ParamsError")+err.Error())
- return
- }
- errList := global.Validator.ValidStruct(c, f)
- if len(errList) > 0 {
- response.Fail(c, 101, errList[0])
- return
- }
- u := service.AllService.UserService.Register(f.Username, f.Email, f.Password)
- if u == nil || u.Id == 0 {
- response.Fail(c, 101, response.TranslateMsg(c, "OperationFailed"))
- return
- }
- // 注册成功后自动登录
- ut := service.AllService.UserService.Login(u, &model.LoginLog{
- UserId: u.Id,
- Client: model.LoginLogClientWebAdmin,
- Uuid: "",
- Ip: c.ClientIP(),
- Type: model.LoginLogTypeAccount,
- })
- responseLoginSuccess(c, u, ut.Token)
- }
|