package apis import ( "IotAdmin/app/system/models" "IotAdmin/common/permission" "net/http" "IotAdmin/core/sdk/api" "IotAdmin/core/sdk/pkg/jwt-auth/user" _ "IotAdmin/core/sdk/pkg/response" "IotAdmin/app/system/service" "IotAdmin/app/system/service/dto" "github.com/gin-gonic/gin" "github.com/gin-gonic/gin/binding" "github.com/google/uuid" "golang.org/x/crypto/bcrypt" ) type SysUserApi struct { api.Api } // GetPage // @Summary 列表用户信息数据 // @Description 获取JSON // @Tags 用户 // @Param username query string false "username" // @Success 200 {string} {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user [get] // @Security Bearer func (e *SysUserApi) GetPage(c *gin.Context) { s := service.SysUserService{} req := dto.SysUserGetPageReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } //数据权限检查 p := permission.GetPermissionFromContext(c) list := make([]models.SysUser, 0) var count int64 err = s.GetPage(&req, p, &list, &count) if err != nil { e.Error(500, err, "查询失败") return } e.PageOK(list, int(count), req.GetPageIndex(), req.GetPageSize(), "查询成功") } // Get // @Summary 获取用户 // @Description 获取JSON // @Tags 用户 // @Param userId path int true "用户编码" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user/{id} [get] // @Security Bearer func (e *SysUserApi) Get(c *gin.Context) { s := service.SysUserService{} req := dto.SysUserById{} err := e.MakeContext(c). MakeOrm(). Bind(&req, nil). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } var object models.SysUser // 数据权限检查 p := permission.GetPermissionFromContext(c) err = s.GetUser(&req, p, &object) if err != nil { e.Error(http.StatusUnprocessableEntity, err, "查询失败") return } e.OK(object, "查询成功") } // Insert // @Summary 创建用户 // @Description 获取JSON // @Tags 用户 // @Accept application/json // @Product application/json // @Param data body dto.SysUserInsertReq true "用户数据" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user [post] // @Security Bearer func (e *SysUserApi) Insert(c *gin.Context) { s := service.SysUserService{} req := dto.SysUserInsertReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } // 设置创建人 req.SetCreateBy(user.GetUserId(c)) err = s.Insert(&req) if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } e.OK(req.GetId(), "创建成功") } // Update // @Summary 修改用户数据 // @Description 获取JSON // @Tags 用户 // @Accept application/json // @Product application/json // @Param data body dto.SysUserUpdateReq true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user [put] // @Security Bearer func (e *SysUserApi) Update(c *gin.Context) { s := service.SysUserService{} req := dto.SysUserUpdateReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } req.SetUpdateBy(user.GetUserId(c)) //数据权限检查 p := permission.GetPermissionFromContext(c) err = s.Update(&req, p) if err != nil { e.Logger.Error(err) return } e.OK(req.GetId(), "更新成功") } // Delete // @Summary 删除用户数据 // @Description 删除数据 // @Tags 用户 // @Param userId path int true "userId" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user [delete] // @Security Bearer func (e *SysUserApi) Delete(c *gin.Context) { s := service.SysUserService{} req := dto.SysUserById{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } // 设置编辑人 req.SetUpdateBy(user.GetUserId(c)) // 数据权限检查 p := permission.GetPermissionFromContext(c) err = s.Remove(&req, p) if err != nil { e.Logger.Error(err) return } e.OK(req.GetId(), "删除成功") } // UpdateStatus 修改用户状态 // @Summary 修改用户状态 // @Description 获取JSON // @Tags 用户 // @Accept application/json // @Product application/json // @Param data body dto.UpdateSysUserStatusReq true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user/change-status [put] // @Security Bearer func (e *SysUserApi) UpdateStatus(c *gin.Context) { s := service.SysUserService{} req := dto.UpdateSysUserStatusReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON, nil). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } req.SetUpdateBy(user.GetUserId(c)) //数据权限检查 p := permission.GetPermissionFromContext(c) err = s.UpdateStatus(&req, p) if err != nil { e.Logger.Error(err) return } e.OK(req.GetId(), "更新成功") } // GetUserRole // @Summary 获取用户角色 // @Description 获取JSON // @Tags 用户 // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user/roles/{id} [get] // @Security Bearer func (e *SysUserApi) GetUserRole(c *gin.Context) { req := dto.SysUserById{} s := service.SysUserService{} err := e.MakeContext(c). MakeOrm(). MakeService(&s.Service). Bind(&req, nil). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } p := permission.GetPermissionFromContext(c) data := &models.SysUser{} err = s.GetUserRole(&req, p, data) if err != nil { e.Logger.Error(err) return } e.OK(data, "获取成功") } // GetProfile // @Summary 获取个人中心用户 // @Description 获取JSON // @Tags 系統接口/个人中心 // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys/profile [get] // @Security Bearer func (e *SysUserApi) GetProfile(c *gin.Context) { s := service.SysUserService{} req := dto.SysUserById{} err := e.MakeContext(c). MakeOrm(). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } req.Id = user.GetUserId(c) sysUser := models.SysUser{} roles := make([]models.SysRole, 0) posts := make([]models.SysPost, 0) err = s.GetProfile(&req, &sysUser, &roles, &posts) if err != nil { e.Logger.Errorf("get user profile error, %s", err.Error()) e.Error(500, err, "获取用户信息失败") return } e.OK(gin.H{ "user": sysUser, "roles": roles, "posts": posts, }, "查询成功") } // GetInfo // @Summary 获取个人信息 // @Description 获取JSON // @Tags 系統接口/个人中心 // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys/get-info [get] // @Security Bearer func (e *SysUserApi) GetInfo(c *gin.Context) { req := dto.SysUserById{} s := service.SysUserService{} r := service.SysRoleService{} err := e.MakeContext(c). MakeOrm(). MakeService(&r.Service). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } var roles = make([]string, 1) roles[0] = user.GetRoleKey(c) var permissions = make([]string, 1) permissions[0] = "*:*:*" var buttons = make([]string, 1) buttons[0] = "*:*:*" var mp = make(map[string]interface{}) mp["roles"] = roles if user.GetRoleKey(c) == "admin" || user.GetRoleKey(c) == "系统管理员" { mp["permissions"] = permissions mp["buttons"] = buttons } else { list, _ := r.GetById(user.GetRoleId(c)) mp["permissions"] = list mp["buttons"] = list } sysUser := models.SysUser{} req.Id = user.GetUserId(c) err = s.GetInfo(&req, &sysUser) if err != nil { e.Error(http.StatusForbidden, err, "鉴权失败") return } mp["avatar"] = sysUser.Avatar //mp["avatar"] = "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif" //if sysUser.Avatar != "" { // mp["avatar"] = sysUser.Avatar //} mp["userId"] = sysUser.UserId mp["userName"] = sysUser.Username mp["nickName"] = sysUser.NickName mp["phone"] = sysUser.Phone mp["email"] = sysUser.Email mp["orgId"] = sysUser.OrgId if sysUser.Org != nil { mp["orgName"] = sysUser.Org.OrgName } mp["remark"] = sysUser.Remark e.OK(mp, "") } // ResetPwd 重置用户密码 // @Summary 重置用户密码 // @Description 获取JSON // @Tags 用户 // @Accept application/json // @Product application/json // @Param data body dto.ResetSysUserPwdReq true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-user/reset-pwd [put] // @Security Bearer func (e *SysUserApi) ResetPwd(c *gin.Context) { s := service.SysUserService{} req := dto.ResetSysUserPwdReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } req.SetUpdateBy(user.GetUserId(c)) // 数据权限检查 p := permission.GetPermissionFromContext(c) err = s.ResetPwd(&req, p) if err != nil { e.Logger.Error(err) return } e.OK(req.GetId(), "更新成功") } // UpdatePwd // @Summary 修改密码 // @Description 获取JSON // @Tags 系統接口/个人中心 // @Accept application/json // @Product application/json // @Param data body dto.PassWord true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys/pwd [put] // @Security Bearer func (e *SysUserApi) UpdatePwd(c *gin.Context) { s := service.SysUserService{} req := dto.PassWord{} err := e.MakeContext(c). MakeOrm(). Bind(&req). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } // 数据权限检查 p := permission.GetPermissionFromContext(c) var hash []byte if hash, err = bcrypt.GenerateFromPassword([]byte(req.NewPassword), bcrypt.DefaultCost); err != nil { req.NewPassword = string(hash) } err = s.UpdatePwd(user.GetUserId(c), req.OldPassword, req.NewPassword, p) if err != nil { e.Logger.Error(err) e.Error(http.StatusForbidden, err, "密码修改失败") return } e.OK(nil, "密码修改成功") } // UpdateAvatar // @Summary 修改头像 // @Description 获取JSON // @Tags 系統接口/个人中心 // @Accept multipart/form-data // @Param file formData file true "file" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys/avatar [put] // @Security Bearer func (e *SysUserApi) UpdateAvatar(c *gin.Context) { s := service.SysUserService{} req := dto.UpdateSysUserAvatarReq{} err := e.MakeContext(c). MakeOrm(). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } // 数据权限检查 p := permission.GetPermissionFromContext(c) form, _ := c.MultipartForm() files := form.File["avatar"] guid := uuid.New().String() filPath := "static/upload-file/" + guid + ".jpg" for _, file := range files { e.Logger.Debugf("upload avatar file: %s", file.Filename) // 上传文件至指定目录 err = c.SaveUploadedFile(file, filPath) if err != nil { e.Logger.Errorf("save file error, %s", err.Error()) e.Error(500, err, "") return } } req.UserId = p.UserId req.Avatar = "/" + filPath err = s.UpdateAvatar(&req, p) if err != nil { e.Logger.Error(err) return } e.OK(filPath, "修改成功") }