From 1fadd77158c942ec45fc388ac94157a29a4e574a Mon Sep 17 00:00:00 2001 From: wucongxing8150 <815046773@qq.com> Date: Mon, 30 Sep 2024 11:40:35 +0800 Subject: [PATCH] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E5=90=8E=E5=8F=B0=E7=94=A8?= =?UTF-8?q?=E6=88=B7=E7=AE=A1=E7=90=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/controller/adminUser.go | 674 ++++++++++++++++++++++++++++++++++++ api/dao/AdminUser.go | 62 ++++ api/dto/AdminUser.go | 34 ++ api/model/AdminUser.go | 1 + api/requests/AdminUser.go | 72 +++- api/router/router.go | 32 ++ go.mod | 1 + go.sum | 2 + 8 files changed, 877 insertions(+), 1 deletion(-) diff --git a/api/controller/adminUser.go b/api/controller/adminUser.go index 852d62a..f18bc64 100644 --- a/api/controller/adminUser.go +++ b/api/controller/adminUser.go @@ -1,17 +1,28 @@ package controller import ( + "crypto/md5" + "encoding/hex" "github.com/gin-gonic/gin" + "github.com/google/uuid" + "knowledge/api/dao" + "knowledge/api/dto" + "knowledge/api/model" "knowledge/api/requests" "knowledge/api/responses" "knowledge/api/service" "knowledge/config" "knowledge/global" "knowledge/utils" + "regexp" + "strconv" + "strings" + "time" ) type AdminUser struct{} +// Login 登陆 func (r *AdminUser) Login(c *gin.Context) { adminUserRequest := requests.AdminUserRequest{} req := adminUserRequest.Login @@ -46,3 +57,666 @@ func (r *AdminUser) Login(c *gin.Context) { responses.OkWithData(token, c) } + +// GetAdminUserPage 获取列表-分页 +func (r *AdminUser) GetAdminUserPage(c *gin.Context) { + adminUserRequest := requests.AdminUserRequest{} + req := adminUserRequest.GetAdminUserPage + if err := c.ShouldBind(&req); err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 参数验证 + if err := global.Validate.Struct(req); err != nil { + responses.FailWithMessage(utils.Translate(err), c) + return + } + + if req.Page == 0 { + req.Page = 1 + } + + if req.PageSize == 0 { + req.PageSize = 20 + } + + adminUserDao := dao.AdminUserDao{} + adminUser, total, err := adminUserDao.GetAdminUserPageSearch(req, req.Page, req.PageSize) + if err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 处理返回值 + g := dto.GetAdminUserListDto(adminUser) + + result := make(map[string]interface{}) + result["page"] = req.Page + result["page_size"] = req.PageSize + result["total"] = total + result["data"] = g + responses.OkWithData(result, c) +} + +// AddAdminUser 新增 +func (r *AdminUser) AddAdminUser(c *gin.Context) { + adminUserRequest := requests.AdminUserRequest{} + req := adminUserRequest.AddAdminUser + if err := c.ShouldBindJSON(&req); err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 参数验证 + if err := global.Validate.Struct(req); err != nil { + responses.FailWithMessage(utils.Translate(err), c) + return + } + + // 获取当前登陆用户数据 + loginUserId := c.GetInt64("UserId") + if loginUserId == 0 { + responses.FailWithMessage("数据错误", c) + return + } + + adminUserDao := dao.AdminUserDao{} + loginAdminUser, err := adminUserDao.GetAdminUserFirstById(loginUserId) + if err != nil && loginAdminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if loginAdminUser.IsAdmin == 0 { + responses.FailWithMessage("非管理员用户不可添加", c) + return + } + + // 开始事务 + tx := global.Db.Begin() + defer func() { + if r := recover(); r != nil { + tx.Rollback() + } + }() + + // 检测账号名 + maps := make(map[string]interface{}) + maps["access"] = req.Access + maps["is_deleted"] = 0 + adminUser, _ := adminUserDao.GetAdminUser(maps) + if adminUser != nil { + tx.Rollback() + responses.FailWithMessage("账号名重复", c) + return + } + + // 检测手机号 + maps = make(map[string]interface{}) + maps["phone"] = req.Phone + maps["is_deleted"] = 0 + adminUser, _ = adminUserDao.GetAdminUser(maps) + if adminUser != nil { + tx.Rollback() + responses.FailWithMessage("手机号重复", c) + return + } + + // 处理密码 + salt := uuid.New().String() + password := md5.Sum([]byte(req.Password + salt)) + // 将哈希值转换为16进制字符串 + passwordString := hex.EncodeToString(password[:]) + + // 新增用户 + AdminUserModel := &model.AdminUser{ + Access: req.Access, + Password: passwordString, + Salt: salt, + NickName: req.NickName, + IsAdmin: req.IsAdmin, + Status: *req.Status, + IsDeleted: *req.IsDeleted, + IsDisabled: *req.IsDisabled, + Phone: req.Phone, + Avatar: utils.RemoveOssDomain(req.Avatar), + Sex: req.Sex, + Email: req.Email, + } + + adminUser, err = adminUserDao.AddAdminUser(tx, AdminUserModel) + if err != nil { + tx.Rollback() + responses.FailWithMessage("新增失败", c) + return + } + + tx.Commit() + responses.Ok(c) +} + +// PutAdminUser 修改用户 +func (r *AdminUser) PutAdminUser(c *gin.Context) { + adminUserRequest := requests.AdminUserRequest{} + req := adminUserRequest.PutAdminUser + if err := c.ShouldBind(&req); err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 参数验证 + if err := global.Validate.Struct(req); err != nil { + responses.FailWithMessage(utils.Translate(err), c) + return + } + + id := c.Param("user_id") + if id == "" { + responses.FailWithMessage("缺少参数", c) + return + } + + // 将 id 转换为 int64 类型 + userId, err := strconv.ParseInt(id, 10, 64) + if err != nil { + responses.Fail(c) + return + } + + // 获取当前登陆用户数据 + loginUserId := c.GetInt64("UserId") + if loginUserId == 0 { + responses.FailWithMessage("数据错误", c) + return + } + + adminUserDao := dao.AdminUserDao{} + loginAdminUser, err := adminUserDao.GetAdminUserFirstById(loginUserId) + if err != nil && loginAdminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if loginUserId == userId && req.IsDisabled == 1 { + responses.FailWithMessage("不可把自己置为禁用", c) + return + } + + if loginUserId == userId && req.IsDeleted == 1 { + responses.FailWithMessage("不可把自己置为删除", c) + return + } + + if loginUserId != userId && loginAdminUser.IsAdmin != 1 { + responses.FailWithMessage("非管理员用户只可修改自己数据", c) + return + } + + // 获取需修改用户数据 + adminUser, err := adminUserDao.GetAdminUserFirstById(userId) + if err != nil && adminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if req.Access != adminUser.Access { + // 检测账号名 + maps := make(map[string]interface{}) + maps["access"] = req.Access + maps["is_deleted"] = 0 + adminUser, _ = adminUserDao.GetAdminUser(maps) + if adminUser != nil { + responses.FailWithMessage("账号名重复", c) + return + } + + } + + if req.Phone != adminUser.Phone { + // 检测手机号 + maps := make(map[string]interface{}) + maps["phone"] = req.Phone + maps["is_deleted"] = 0 + adminUser, _ = adminUserDao.GetAdminUser(maps) + if adminUser != nil { + responses.FailWithMessage("手机号重复", c) + return + } + } + + // 开始事务 + tx := global.Db.Begin() + defer func() { + if r := recover(); r != nil { + tx.Rollback() + } + }() + + data := make(map[string]interface{}) + data["access"] = req.Access + data["is_deleted"] = req.IsDeleted + data["is_disabled"] = req.IsDisabled + data["nick_name"] = req.NickName + data["is_admin"] = req.IsAdmin + data["phone"] = req.Phone + data["avatar"] = req.Avatar + data["sex"] = req.Sex + data["email"] = req.Email + err = adminUserDao.EditAdminUserById(tx, userId, data) + if err != nil { + tx.Rollback() + responses.FailWithMessage("修改失败", c) + return + } + + tx.Commit() + + responses.Ok(c) +} + +// PutAdminUserStatus 修改状态 +func (r *AdminUser) PutAdminUserStatus(c *gin.Context) { + adminUserRequest := requests.AdminUserRequest{} + req := adminUserRequest.PutAdminUserStatus + if err := c.ShouldBind(&req); err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 参数验证 + if err := global.Validate.Struct(req); err != nil { + responses.FailWithMessage(utils.Translate(err), c) + return + } + + id := c.Param("user_id") + if id == "" { + responses.FailWithMessage("缺少参数", c) + return + } + + // 将 id 转换为 int64 类型 + userId, err := strconv.ParseInt(id, 10, 64) + if err != nil { + responses.Fail(c) + return + } + + // 获取当前登陆用户数据 + loginUserId := c.GetInt64("UserId") + if loginUserId == 0 { + responses.FailWithMessage("数据错误", c) + return + } + + if loginUserId == userId { + responses.FailWithMessage("非法操作,请勿修改自己", c) + return + } + + adminUserDao := dao.AdminUserDao{} + loginAdminUser, err := adminUserDao.GetAdminUserFirstById(loginUserId) + if err != nil && loginAdminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if loginAdminUser.IsAdmin != 1 { + responses.FailWithMessage("非管理员用户不可操作", c) + return + } + + // 获取需修改用户数据 + adminUser, err := adminUserDao.GetAdminUserFirstById(userId) + if err != nil && adminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if adminUser.Status == req.Status { + responses.Ok(c) + return + } + + // 开始事务 + tx := global.Db.Begin() + defer func() { + if r := recover(); r != nil { + tx.Rollback() + } + }() + + data := make(map[string]interface{}) + data["status"] = req.Status + err = adminUserDao.EditAdminUserById(tx, userId, data) + if err != nil { + tx.Rollback() + responses.FailWithMessage("修改失败", c) + return + } + + tx.Commit() + + responses.Ok(c) +} + +// PutUserDisabled 修改禁用状态 +func (r *AdminUser) PutAdminUserDisabled(c *gin.Context) { + adminUserRequest := requests.AdminUserRequest{} + req := adminUserRequest.PutAdminUserDisabled + if err := c.ShouldBind(&req); err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 参数验证 + if err := global.Validate.Struct(req); err != nil { + responses.FailWithMessage(utils.Translate(err), c) + return + } + + id := c.Param("user_id") + if id == "" { + responses.FailWithMessage("缺少参数", c) + return + } + + // 将 id 转换为 int64 类型 + userId, err := strconv.ParseInt(id, 10, 64) + if err != nil { + responses.Fail(c) + return + } + + // 获取当前登陆用户数据 + loginUserId := c.GetInt64("UserId") + if loginUserId == 0 { + responses.FailWithMessage("数据错误", c) + return + } + + if loginUserId == userId { + responses.FailWithMessage("非法操作,请勿修改自己", c) + return + } + + adminUserDao := dao.AdminUserDao{} + loginAdminUser, err := adminUserDao.GetAdminUserFirstById(loginUserId) + if err != nil && loginAdminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if loginAdminUser.IsAdmin != 1 { + responses.FailWithMessage("非管理员用户不可操作", c) + return + } + + // 获取需修改用户数据 + adminUser, err := adminUserDao.GetAdminUserFirstById(userId) + if err != nil && adminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if adminUser.IsDisabled == req.IsDisabled { + responses.Ok(c) + return + } + + // 开始事务 + tx := global.Db.Begin() + defer func() { + if r := recover(); r != nil { + tx.Rollback() + } + }() + + data := make(map[string]interface{}) + data["is_disabled"] = req.IsDisabled + err = adminUserDao.EditAdminUserById(tx, userId, data) + if err != nil { + tx.Rollback() + responses.FailWithMessage("修改失败", c) + return + } + + tx.Commit() + + responses.Ok(c) +} + +// PutAdminUserPassword 修改用户密码 +func (r *AdminUser) PutAdminUserPassword(c *gin.Context) { + adminUserRequest := requests.AdminUserRequest{} + req := adminUserRequest.PutAdminUserPassword + if err := c.ShouldBind(&req); err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 参数验证 + if err := global.Validate.Struct(req); err != nil { + responses.FailWithMessage(utils.Translate(err), c) + return + } + + // 获取当前登陆用户数据 + loginUserId := c.GetInt64("UserId") + if loginUserId == 0 { + responses.FailWithMessage("数据错误", c) + return + } + + adminUserDao := dao.AdminUserDao{} + loginAdminUser, err := adminUserDao.GetAdminUserFirstById(loginUserId) + if err != nil && loginAdminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if loginAdminUser.IsAdmin != 1 { + responses.FailWithMessage("非管理员用户只可修改自己数据", c) + return + } + + // 获取需修改用户数据 + userId, err := strconv.ParseInt(req.UserId, 10, 64) + if err != nil { + responses.Fail(c) + return + } + + adminUser, err := adminUserDao.GetAdminUserFirstById(userId) + if err != nil || adminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + // 加密旧密码 + newPassword := md5.Sum([]byte(req.NewPassword + adminUser.Salt)) + // 将哈希值转换为16进制字符串 + newPasswordString := hex.EncodeToString(newPassword[:]) + + // 检测密码是否相同 + if adminUser.Password == newPasswordString { + responses.FailWithMessage("新密码请不要和原密码相同", c) + return + } + + // 检测旧密码是否正确 + // 检测用户密码 + password := md5.Sum([]byte(req.Password + adminUser.Salt)) + // 将哈希值转换为16进制字符串 + passwordString := hex.EncodeToString(password[:]) + + if passwordString != adminUser.Password { + responses.FailWithMessage("原密码错误,请重新输入", c) + return + } + + // 密码校验 + if len(req.NewPassword) < 8 { + responses.FailWithMessage("密码小于8位数", c) + return + } + + num := `[0-9]{1}` + a_z := `[a-z]{1}` + A_Z := `[A-Z]{1}` + symbol := `[!@#.~$%^&*()+|_]{1}` + if b, err := regexp.MatchString(num, req.NewPassword); !b || err != nil { + responses.FailWithMessage("密码强度必须为字⺟⼤⼩写+数字+符号", c) + return + } + if b, err := regexp.MatchString(a_z, req.NewPassword); !b || err != nil { + responses.FailWithMessage("密码强度必须为字⺟⼤⼩写+数字+符号", c) + return + } + if b, err := regexp.MatchString(A_Z, req.NewPassword); !b || err != nil { + responses.FailWithMessage("密码强度必须为字⺟⼤⼩写+数字+符号", c) + return + } + if b, err := regexp.MatchString(symbol, req.NewPassword); !b || err != nil { + responses.FailWithMessage("密码强度必须为字⺟⼤⼩写+数字+符号", c) + return + } + + // 开始事务 + tx := global.Db.Begin() + defer func() { + if r := recover(); r != nil { + tx.Rollback() + } + }() + + data := make(map[string]interface{}) + data["password"] = newPasswordString + err = adminUserDao.EditAdminUserById(tx, userId, data) + if err != nil { + tx.Rollback() + responses.FailWithMessage("修改失败", c) + return + } + + tx.Commit() + + responses.Ok(c) +} + +// LoginOut 退出登陆 +func (b *AdminUser) LoginOut(c *gin.Context) { + userId := c.GetInt64("UserId") + if userId == 0 { + responses.FailWithMessage("用户错误", c) + return + } + + // 获取用户信息 + adminUserDao := dao.AdminUserDao{} + adminUser, err := adminUserDao.GetAdminUserFirstById(userId) + if err != nil || adminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + // token加入黑名单 + authorization := c.Request.Header.Get("Authorization") + if authorization == "" || !strings.HasPrefix(authorization, "Bearer ") { + responses.FailWithMessage("退出登陆失败", c) + return + } + + // 去除Bearer + authorization = authorization[7:] // 截取字符 + + // 增加缓存 + _, err = global.Redis.Set(c, "jwt_black_"+authorization, time.Now().Unix(), 60*time.Second).Result() + if err != nil { + responses.FailWithMessage("退出登陆失败", c) + return + } + + responses.Ok(c) +} + +// DeleteAdminUser 删除用户-批量 +func (r *AdminUser) DeleteAdminUser(c *gin.Context) { + adminUserRequest := requests.AdminUserRequest{} + req := adminUserRequest.DeleteAdminUser + if err := c.ShouldBindJSON(&req); err != nil { + responses.FailWithMessage(err.Error(), c) + return + } + + // 参数验证 + if err := global.Validate.Struct(req); err != nil { + responses.FailWithMessage(utils.Translate(err), c) + return + } + + // 获取当前登陆用户数据 + loginUserId := c.GetInt64("UserId") + if loginUserId == 0 { + responses.FailWithMessage("数据错误", c) + return + } + + adminUserDao := dao.AdminUserDao{} + loginAdminUser, err := adminUserDao.GetAdminUserFirstById(loginUserId) + if err != nil && loginAdminUser == nil { + responses.FailWithMessage("用户数据错误", c) + return + } + + if loginAdminUser.IsAdmin != 1 { + responses.FailWithMessage("非管理员用户不可操作", c) + return + } + + // 开始事务 + tx := global.Db.Begin() + defer func() { + if r := recover(); r != nil { + tx.Rollback() + } + }() + + for _, id := range req.UserIds { + userId, err := strconv.ParseInt(id, 10, 64) + if err != nil { + tx.Rollback() + responses.Fail(c) + return + } + + if userId == loginUserId { + tx.Rollback() + responses.FailWithMessage("不可把自己删除", c) + return + } + + // 检测删除用户 + adminUser, err := adminUserDao.GetAdminUserFirstById(userId) + if err != nil || adminUser == nil { + tx.Rollback() + responses.FailWithMessage("删除失败", c) + return + } + + // 删除用户 + data := make(map[string]interface{}) + data["is_deleted"] = 1 + err = adminUserDao.EditAdminUserById(tx, userId, data) + if err != nil { + tx.Rollback() + responses.FailWithMessage("修改失败", c) + return + } + } + + tx.Commit() + + responses.Ok(c) +} diff --git a/api/dao/AdminUser.go b/api/dao/AdminUser.go index 3563bc3..7a47701 100644 --- a/api/dao/AdminUser.go +++ b/api/dao/AdminUser.go @@ -3,6 +3,7 @@ package dao import ( "gorm.io/gorm" "knowledge/api/model" + "knowledge/api/requests" "knowledge/global" ) @@ -37,6 +38,15 @@ func (r *AdminUserDao) GetAdminUserFirstByPhone(phone string) (m *model.AdminUse return m, nil } +// GetAdminUser 获取 +func (r *AdminUserDao) GetAdminUser(maps interface{}) (m *model.AdminUser, err error) { + err = global.Db.Where(maps).First(&m).Error + if err != nil { + return nil, err + } + return m, nil +} + // DeleteAdminUser 删除用户 func (r *AdminUserDao) DeleteAdminUser(tx *gorm.DB, maps interface{}) error { err := tx.Where(maps).Delete(&model.AdminUser{}).Error @@ -88,3 +98,55 @@ func (r *AdminUserDao) AddAdminUser(tx *gorm.DB, model *model.AdminUser) (*model } return model, nil } + +// GetAdminUserPageSearch 获取列表-分页 +func (r *AdminUserDao) GetAdminUserPageSearch(req requests.GetAdminUserPage, page, pageSize int) (m []*model.AdminUser, total int64, err error) { + var totalRecords int64 + + // 构建查询条件 + query := global.Db.Model(&model.AdminUser{}) + + // 账号 + if req.Access != "" { + query = query.Where("access LIKE ?", "%"+req.Access+"%") + } + + // 昵称 + if req.NickName != "" { + query = query.Where("nick_name LIKE ?", "%"+req.NickName+"%") + } + + // 状态 + if req.Status != nil { + query = query.Where("status = ?", req.Status) + } + + // 是否被删除 + if req.IsDeleted != nil { + query = query.Where("is_deleted = ?", req.IsDeleted) + } + + // 是否被禁用 + if req.IsDisabled != nil { + query = query.Where("is_disabled = ?", req.IsDisabled) + } + + // 手机号 + if req.Phone != "" { + query = query.Where("phone LIKE ?", "%"+req.Phone+"%") + } + + // 排序 + query = query.Order("created_at desc") + + // 查询总数量 + if err := query.Count(&totalRecords).Error; err != nil { + return nil, 0, err + } + + err = query.Scopes(model.Paginate(page, pageSize)).Find(&m).Error + if err != nil { + return nil, 0, err + } + return m, totalRecords, nil +} diff --git a/api/dto/AdminUser.go b/api/dto/AdminUser.go index e5c8fe9..36045f3 100644 --- a/api/dto/AdminUser.go +++ b/api/dto/AdminUser.go @@ -13,6 +13,7 @@ type AdminUserDto struct { Password string `json:"password"` // 密码 Salt string `json:"salt"` // 密码掩码 NickName string `json:"nick_name"` // 昵称 + IsAdmin int `json:"is_admin"` // 是否管理员(0:否 1:是) Status int `json:"status"` // 状态(1:正常 2:审核中 3:审核失败) IsDeleted int `json:"is_deleted"` // 是否被删除(0:否 1:是) IsDisabled int `json:"is_disabled"` // 是否被禁用(0:否 1:是) @@ -25,12 +26,14 @@ type AdminUserDto struct { Token string `json:"token"` // token } +// LoginDto 登陆 func LoginDto(m *model.AdminUser) *AdminUserDto { return &AdminUserDto{ UserId: fmt.Sprintf("%d", m.UserId), Access: m.Access, Status: m.Status, NickName: m.NickName, + IsAdmin: m.IsAdmin, Avatar: utils.AddOssDomain(m.Avatar), Sex: m.Sex, Email: m.Email, @@ -39,6 +42,37 @@ func LoginDto(m *model.AdminUser) *AdminUserDto { } } +// GetAdminUserListDto 列表 +func GetAdminUserListDto(m []*model.AdminUser) []*AdminUserDto { + // 处理返回值 + responses := make([]*AdminUserDto, len(m)) + + if len(m) > 0 { + for i, v := range m { + response := &AdminUserDto{ + UserId: fmt.Sprintf("%d", v.UserId), + Access: v.Access, + NickName: v.NickName, + IsAdmin: v.IsAdmin, + Status: v.Status, + IsDeleted: v.IsDeleted, + IsDisabled: v.IsDisabled, + Phone: v.Phone, + Avatar: utils.AddOssDomain(v.Avatar), + Sex: v.Sex, + Email: v.Email, + CreatedAt: v.CreatedAt, + UpdatedAt: v.UpdatedAt, + } + + // 将转换后的结构体添加到新切片中 + responses[i] = response + } + } + + return responses +} + // LoadUserDoctor 加载token func (r *AdminUserDto) LoadUserDoctor(t string) *AdminUserDto { if t != "" { diff --git a/api/model/AdminUser.go b/api/model/AdminUser.go index b25a0fb..6af1ca8 100644 --- a/api/model/AdminUser.go +++ b/api/model/AdminUser.go @@ -13,6 +13,7 @@ type AdminUser struct { Password string `gorm:"column:password;type:varchar(128);comment:密码;NOT NULL" json:"password"` Salt string `gorm:"column:salt;type:varchar(255);comment:密码掩码;NOT NULL" json:"salt"` NickName string `gorm:"column:nick_name;type:varchar(255);comment:昵称" json:"nick_name"` + IsAdmin int `gorm:"column:is_admin;type:tinyint(1);default:0;comment:是否管理员(0:否 1:是)" json:"is_admin"` Status int `gorm:"column:status;type:tinyint(1);default:2;comment:状态(1:正常 2:审核中 3:审核失败)" json:"status"` IsDeleted int `gorm:"column:is_deleted;type:tinyint(1);default:0;comment:是否被删除(0:否 1:是)" json:"is_deleted"` IsDisabled int `gorm:"column:is_disabled;type:tinyint(1);default:0;comment:是否被禁用(0:否 1:是)" json:"is_disabled"` diff --git a/api/requests/AdminUser.go b/api/requests/AdminUser.go index 397c61f..70265fb 100644 --- a/api/requests/AdminUser.go +++ b/api/requests/AdminUser.go @@ -1,7 +1,14 @@ package requests type AdminUserRequest struct { - Login // 登陆 + Login // 登陆 + GetAdminUserPage // 获取列表-分页 + AddAdminUser // 新增 + PutAdminUser // 修改 + PutAdminUserStatus // 修改状态 + PutAdminUserDisabled // 修改禁用状态 + PutAdminUserPassword // 修改用户密码 + DeleteAdminUser // 删除用户-批量 } // Login 登陆 @@ -11,3 +18,66 @@ type Login struct { Captcha string `json:"captcha" form:"captcha" validate:"required" label:"验证码"` // 验证码 CaptchaId string `json:"captchaId" form:"captchaId" validate:"required"` // 验证码ID } + +// GetAdminUserPage 获取列表-分页 +type GetAdminUserPage struct { + Access string `json:"access" form:"access" label:"账号"` + NickName string `json:"nick_name" form:"nick_name" label:"昵称"` + IsAdmin int `json:"is_admin" form:"is_admin" label:"是否管理员"` // 是否管理员(0:否 1:是) + Status *int `json:"status" form:"status" label:"状态"` // 状态(1:正常 2:审核中 3:审核失败) + IsDeleted *int `json:"is_deleted" form:"is_deleted" label:"是否被删除"` // 是否被删除(0:否 1:是) + IsDisabled *int `json:"is_disabled" form:"is_disabled" label:"是否被禁用"` // 是否被禁用(0:否 1:是) + Phone string `json:"phone" form:"phone" label:"手机号"` + Page int `json:"page" form:"page" label:"页码"` + PageSize int `json:"page_size" form:"page_size" label:"每页个数"` +} + +// AddAdminUser 新增 +type AddAdminUser struct { + Access string `json:"access" form:"access" label:"账号"` + Password string `json:"password" form:"password" label:"密码"` + NickName string `json:"nick_name" form:"nick_name" label:"昵称"` + IsAdmin int `json:"is_admin" form:"is_admin" label:"是否管理员"` // 是否管理员(0:否 1:是) + Status *int `json:"status" form:"status" label:"状态"` // 状态(1:正常 2:审核中 3:审核失败) + IsDeleted *int `json:"is_deleted" form:"is_deleted" label:"是否被删除"` // 是否被删除(0:否 1:是) + IsDisabled *int `json:"is_disabled" form:"is_disabled" label:"是否被禁用"` // 是否被禁用(0:否 1:是) + Phone string `json:"phone" form:"phone" label:"手机号"` + Avatar string `json:"avatar" form:"avatar" label:"头像"` + Sex int `json:"sex" form:"sex" label:"性别"` + Email string `json:"email" form:"email" label:"邮箱"` +} + +// PutAdminUser 修改 +type PutAdminUser struct { + Access string `json:"access" form:"access" validate:"required" label:"账号"` + IsDeleted int `json:"is_deleted" form:"is_deleted" validate:"oneof=0 1" label:"删除状态"` // 是否被删除(0:否 1:是) + IsDisabled int `json:"is_disabled" form:"is_disabled" validate:"oneof=0 1" label:"禁用状态"` // 是否被禁用(0:否 1:是) + NickName string `json:"nick_name" form:"nick_name" validate:"required" label:"昵称"` + IsAdmin int `json:"is_admin" form:"is_admin" label:"是否管理员"` // 是否管理员(0:否 1:是) + Phone string `json:"phone" form:"phone" validate:"required" label:"手机号"` + Avatar string `json:"avatar" form:"avatar" label:"头像"` + Sex int `json:"sex" form:"sex" validate:"required,oneof=1 2" label:"性别"` // (1:男 2:女) + Email string `json:"email" form:"email" label:"邮箱"` +} + +// PutAdminUserStatus 修改状态 +type PutAdminUserStatus struct { + Status int `json:"status" form:"status" validate:"required,oneof=1 2 3" label:"状态"` // 状态(1:正常 2:审核中 3:审核失败) +} + +// PutAdminUserDisabled 修改禁用状态 +type PutAdminUserDisabled struct { + IsDisabled int `json:"is_disabled" form:"is_disabled" validate:"oneof=0 1" label:"禁用状态"` // 是否被禁用(0:否 1:是) +} + +// PutAdminUserPassword 修改用户密码 +type PutAdminUserPassword struct { + Password string `json:"password" form:"password" validate:"required" label:"原密码"` + NewPassword string `json:"new_password" form:"new_password" validate:"required" label:"新密码"` + UserId string `json:"user_id" form:"user_id" validate:"required" label:"用户id"` +} + +// DeleteAdminUser 删除用户-批量 +type DeleteAdminUser struct { + UserIds []string `json:"user_ids" form:"user_ids" validate:"required" label:"用户id"` +} diff --git a/api/router/router.go b/api/router/router.go index cf3367d..fecab10 100644 --- a/api/router/router.go +++ b/api/router/router.go @@ -243,6 +243,38 @@ func privateRouter(r *gin.Engine, api controller.Api) { editorGroup.POST("", api.Editor.EditorUpload) } } + + // 用户 + userGroup := adminGroup.Group("/user") + { + // 后台用户 + userAdminGroup := userGroup.Group("/admin") + { + // 获取列表-分页 + userAdminGroup.GET("/page", api.AdminUser.GetAdminUserPage) + + // 新增 + userAdminGroup.POST("", api.AdminUser.AddAdminUser) + + // 修改 + userAdminGroup.PUT("/:user_id", api.AdminUser.PutAdminUser) + + // 修改状态 + userAdminGroup.PUT("/status/:user_id", api.AdminUser.PutAdminUserStatus) + + // 修改禁用状态 + userAdminGroup.PUT("/disabled/:user_id", api.AdminUser.PutAdminUserDisabled) + + // 修改密码 + userAdminGroup.PUT("/password", api.AdminUser.PutAdminUserPassword) + + // 退出登陆 + userAdminGroup.PUT("loginout", api.AdminUser.LoginOut) + + // 删除用户-批量 + userAdminGroup.DELETE("", api.AdminUser.DeleteAdminUser) + } + } } // 获取分享数据 diff --git a/go.mod b/go.mod index 33bcf3d..185bf2e 100644 --- a/go.mod +++ b/go.mod @@ -16,6 +16,7 @@ require ( github.com/go-redis/redis/v8 v8.11.5 github.com/goccy/go-json v0.10.2 github.com/golang-jwt/jwt/v5 v5.2.1 + github.com/google/uuid v1.4.0 github.com/mojocn/base64Captcha v1.3.6 github.com/robfig/cron/v3 v3.0.0 github.com/sirupsen/logrus v1.9.3 diff --git a/go.sum b/go.sum index 0e644ce..0b1dae9 100644 --- a/go.sum +++ b/go.sum @@ -67,6 +67,8 @@ github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 h1:DACJavvAHhabrF0 github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= +github.com/google/uuid v1.4.0 h1:MtMxsa51/r9yyhkyLsVeVt0B+BGQZzpQiTQ4eHZ8bc4= +github.com/google/uuid v1.4.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E=