-
Notifications
You must be signed in to change notification settings - Fork 174
/
userupdatelogic.go
93 lines (79 loc) · 2.64 KB
/
userupdatelogic.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package userservicelogic
import (
"context"
"errors"
"github.com/feihua/zero-admin/rpc/sys/gen/model"
"github.com/feihua/zero-admin/rpc/sys/gen/query"
"github.com/feihua/zero-admin/rpc/sys/sysclient"
"github.com/zeromicro/go-zero/core/logc"
"github.com/feihua/zero-admin/rpc/sys/internal/svc"
"github.com/zeromicro/go-zero/core/logx"
)
// UserUpdateLogic
/*
Author: LiuFeiHua
Date: 2023/12/18 14:37
*/
type UserUpdateLogic struct {
ctx context.Context
svcCtx *svc.ServiceContext
logx.Logger
}
func NewUserUpdateLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UserUpdateLogic {
return &UserUpdateLogic{
ctx: ctx,
svcCtx: svcCtx,
Logger: logx.WithContext(ctx),
}
}
// UserUpdate 更新用户(id为1是系统预留超级管理员用户,不能更新)
func (l *UserUpdateLogic) UserUpdate(in *sysclient.UserUpdateReq) (*sysclient.UserUpdateResp, error) {
//id为1是系统预留超级管理员用户,不能更新
if in.Id == 1 {
logc.Errorf(l.ctx, "更新用户异常,参数userId:%d,异常:%s", in.Id, "id为1是系统预留超级管理员用户,不能更新")
return nil, errors.New("更新用户异常")
}
//查询用户是否存在
q := query.SysUser
user, err := q.WithContext(l.ctx).Where(q.ID.Eq(in.Id)).First()
if err != nil {
logc.Errorf(l.ctx, "更新用户异常,参数userId:%d,异常:%s", in.Id, "用户不存在")
return nil, errors.New("查询用户异常")
}
sysUser := &model.SysUser{
ID: in.Id,
Name: in.Name,
NickName: &in.NickName,
Avatar: &in.Avatar,
Password: user.Password,
Salt: user.Salt,
Email: &in.Email,
Mobile: &in.Mobile,
Status: in.Status,
DeptID: in.DeptId,
CreateBy: user.CreateBy,
CreateTime: user.CreateTime,
UpdateBy: &in.UpdateBy,
JobID: in.JobId,
}
_, err = q.WithContext(l.ctx).Where(q.ID.Eq(in.Id)).Updates(sysUser)
if err != nil {
logc.Errorf(l.ctx, "更新用户异常,参数userId:%d,异常:%s", in.Id, err.Error())
return nil, errors.New("更新用户异常")
}
_, err = query.SysUserRole.WithContext(l.ctx).Where(query.SysUserRole.UserID.Eq(in.Id)).Delete()
if err != nil {
logc.Errorf(l.ctx, "删除用户与角色关联异常,参数userId:%d,异常:%s", in.Id, err.Error())
return nil, errors.New("更新用户异常")
}
err = query.SysUserRole.WithContext(l.ctx).Create(&model.SysUserRole{
UserID: in.Id,
RoleID: in.RoleId,
CreateBy: in.UpdateBy,
})
if err != nil {
logc.Errorf(l.ctx, "添加用户与角色关联异常,参数userId:%d, roleId: %d,异常:%s", in.Id, in.RoleId, err.Error())
return nil, errors.New("更新用户异常")
}
return &sysclient.UserUpdateResp{}, nil
}