package handlers import ( "platform/web/auth" "platform/web/core" g "platform/web/globals" m "platform/web/models" q "platform/web/queries" s "platform/web/services" "github.com/gofiber/fiber/v2" "golang.org/x/crypto/bcrypt" ) // 分页获取用户 func PageUserByAdmin(c *fiber.Ctx) error { // 检查权限 _, err := auth.GetAuthCtx(c).PermitAdmin() if err != nil { return err } // 解析请求参数 req := new(core.PageReq) if err := g.Validator.ParseBody(c, req); err != nil { return err } // 查询用户列表 users, total, err := q.User. Preload(q.User.Admin). Omit(q.User.Password). FindByPage(req.GetOffset(), req.GetLimit()) if err != nil { return err } for _, user := range users { if user.Admin != nil { user.Admin = &m.Admin{ Name: user.Admin.Name, } } } // 返回结果 return c.JSON(core.PageResp{ Total: int(total), Page: req.GetPage(), Size: req.GetSize(), List: users, }) } // 绑定管理员 func BindAdmin(c *fiber.Ctx) error { // 检查权限 authCtx, err := auth.GetAuthCtx(c).PermitAdmin() if err != nil { return err } // 解析请求参数 req := new(struct { UserID int `json:"user_id" validate:"required"` }) if err := g.Validator.ParseBody(c, req); err != nil { return err } // 更新用户信息 result, err := q.User.Where( q.User.ID.Eq(int32(req.UserID)), q.User.AdminID.IsNull(), ).UpdateColumnSimple( q.User.AdminID.Value(authCtx.Admin.ID), ) if err != nil { return err } if result.RowsAffected == 0 { return core.NewBizErr("用户已绑定管理员") } // 返回结果 return c.SendStatus(fiber.StatusNoContent) } // 更新用户 func UpdateUser(c *fiber.Ctx) error { // 检查权限 authCtx, err := auth.GetAuthCtx(c).PermitUser() if err != nil { return err } // 解析请求参数 req := new(UpdateUserReq) if err := c.BodyParser(req); err != nil { return err } // 更新用户信息 _, err = q.User. Where(q.User.ID.Eq(authCtx.User.ID)). Updates(m.User{ Username: &req.Username, Email: &req.Email, ContactQQ: &req.ContactQQ, ContactWechat: &req.ContactWechat, }) if err != nil { return err } // 返回结果 return c.SendStatus(fiber.StatusNoContent) } type UpdateUserReq struct { Username string `json:"username" validate:"omitempty,min=3,max=20"` Email string `json:"email" validate:"omitempty,email"` ContactQQ string `json:"contact_qq" validate:"omitempty,qq"` ContactWechat string `json:"contact_wechat" validate:"omitempty,wechat"` } // 更新账号信息 func UpdateAccount(c *fiber.Ctx) error { // 检查权限 authCtx, err := auth.GetAuthCtx(c).PermitUser() if err != nil { return err } // 解析请求参数 req := new(UpdateAccountReq) if err := c.BodyParser(req); err != nil { return err } // 更新用户信息 _, err = q.User. Where(q.User.ID.Eq(authCtx.User.ID)). Updates(m.User{ Username: &req.Username, Password: &req.Password, }) if err != nil { return err } // 返回结果 return c.SendStatus(fiber.StatusNoContent) } type UpdateAccountReq struct { Username string `json:"username" validate:"omitempty,min=3,max=20"` Password string `json:"password" validate:"omitempty,min=6,max=20"` } // 更新账号密码 func UpdatePassword(c *fiber.Ctx) error { // 检查权限 authCtx, err := auth.GetAuthCtx(c).PermitUser() if err != nil { return err } // 解析请求参数 req := new(UpdatePasswordReq) if err := c.BodyParser(req); err != nil { return err } // 验证手机号 if req.Phone != authCtx.User.Phone { return fiber.NewError(fiber.StatusBadRequest, "手机号码不正确") } // 验证手机令牌 if req.Code == "" { return fiber.NewError(fiber.StatusBadRequest, "手机号码和验证码不能为空") } err = s.Verifier.VerifySms(c.Context(), req.Phone, req.Code) if err != nil { return err } // 更新密码 newHash, err := bcrypt.GenerateFromPassword([]byte(req.Password), bcrypt.DefaultCost) if err != nil { return err } _, err = q.User. Where(q.User.ID.Eq(authCtx.User.ID)). UpdateColumn(q.User.Password, newHash) if err != nil { return err } // 返回结果 return c.SendStatus(fiber.StatusNoContent) } type UpdatePasswordReq struct { Phone string `json:"phone"` Code string `json:"code"` Password string `json:"password"` }