正在显示
17 个修改的文件
包含
507 行增加
和
18 行删除
@@ -389,6 +389,9 @@ type( | @@ -389,6 +389,9 @@ type( | ||
389 | } | 389 | } |
390 | SystemUserAccountUpdateRequest struct{ | 390 | SystemUserAccountUpdateRequest struct{ |
391 | Id int64 `path:"id"` | 391 | Id int64 `path:"id"` |
392 | + Name string `json:"name"` // 姓名 | ||
393 | + Roles []int64 `json:"roles"` // 权限角色 | ||
394 | + Status int `json:"enable"` // 状态 1:启用 2:禁用 | ||
392 | } | 395 | } |
393 | SystemUserAccountUpdateResponse struct{} | 396 | SystemUserAccountUpdateResponse struct{} |
394 | 397 |
@@ -2,7 +2,9 @@ package role | @@ -2,7 +2,9 @@ package role | ||
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "context" | 4 | "context" |
5 | + "github.com/samber/lo" | ||
5 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | 6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" |
7 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | 8 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" |
7 | 9 | ||
8 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" | 10 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" |
@@ -29,13 +31,24 @@ func (l *SystemGetRoleLogic) SystemGetRole(req *types.RoleGetRequest) (resp *typ | @@ -29,13 +31,24 @@ func (l *SystemGetRoleLogic) SystemGetRole(req *types.RoleGetRequest) (resp *typ | ||
29 | var ( | 31 | var ( |
30 | conn = l.svcCtx.DefaultDBConn() | 32 | conn = l.svcCtx.DefaultDBConn() |
31 | role *domain.Role | 33 | role *domain.Role |
34 | + users []*domain.User | ||
35 | + userToken = contextdata.GetUserTokenFromCtx(l.ctx) | ||
32 | ) | 36 | ) |
33 | if role, err = l.svcCtx.RoleRepository.FindOne(l.ctx, conn, req.Id); err != nil { | 37 | if role, err = l.svcCtx.RoleRepository.FindOne(l.ctx, conn, req.Id); err != nil { |
34 | return nil, xerr.NewErrMsgErr("角色不存在", err) | 38 | return nil, xerr.NewErrMsgErr("角色不存在", err) |
35 | } | 39 | } |
40 | + _, users, _ = l.svcCtx.UserRepository.FindByCompanyRoles(l.ctx, conn, userToken.CompanyId, []int64{role.Id}, domain.NewQueryOptions().WithFindOnly()) | ||
41 | + typesRole := NewTypesRole(role) | ||
42 | + lo.ForEach(users, func(item *domain.User, index int) { | ||
43 | + typesRole.Users = append(typesRole.Users, types.RoleUser{ | ||
44 | + Id: item.Id, | ||
45 | + Name: item.Name, | ||
46 | + }) | ||
47 | + }) | ||
36 | resp = &types.RoleGetResponse{ | 48 | resp = &types.RoleGetResponse{ |
37 | - Role: NewTypesRole(role), | 49 | + Role: typesRole, |
38 | } | 50 | } |
51 | + | ||
39 | for _, auth := range domain.Auths { | 52 | for _, auth := range domain.Auths { |
40 | resp.AuthList = append(resp.AuthList, types.Auth{ | 53 | resp.AuthList = append(resp.AuthList, types.Auth{ |
41 | Id: auth.Id, | 54 | Id: auth.Id, |
@@ -92,12 +92,6 @@ func NewTypesRole(item *domain.Role) types.RoleItem { | @@ -92,12 +92,6 @@ func NewTypesRole(item *domain.Role) types.RoleItem { | ||
92 | role types.RoleItem | 92 | role types.RoleItem |
93 | users []types.RoleUser = make([]types.RoleUser, 0) | 93 | users []types.RoleUser = make([]types.RoleUser, 0) |
94 | ) | 94 | ) |
95 | - lo.ForEach(item.Users, func(item domain.User, index int) { | ||
96 | - users = append(users, types.RoleUser{ | ||
97 | - Id: item.Id, | ||
98 | - Name: item.Name, | ||
99 | - }) | ||
100 | - }) | ||
101 | role = types.RoleItem{ | 95 | role = types.RoleItem{ |
102 | Id: item.Id, | 96 | Id: item.Id, |
103 | CompanyId: item.CompanyId, | 97 | CompanyId: item.CompanyId, |
@@ -35,6 +35,7 @@ func (l *SystemSearchRoleLogic) SystemSearchRole(req *types.RoleSearchRequest) ( | @@ -35,6 +35,7 @@ func (l *SystemSearchRoleLogic) SystemSearchRole(req *types.RoleSearchRequest) ( | ||
35 | userToken = contextdata.GetUserTokenFromCtx(l.ctx) | 35 | userToken = contextdata.GetUserTokenFromCtx(l.ctx) |
36 | roles []*domain.Role | 36 | roles []*domain.Role |
37 | total int64 | 37 | total int64 |
38 | + users []*domain.User | ||
38 | ) | 39 | ) |
39 | queryOptions := domain.IndexCompanyId(userToken.CompanyId)() | 40 | queryOptions := domain.IndexCompanyId(userToken.CompanyId)() |
40 | if req.Page != 0 && req.Size != 0 { | 41 | if req.Page != 0 && req.Size != 0 { |
@@ -57,17 +58,27 @@ func (l *SystemSearchRoleLogic) SystemSearchRole(req *types.RoleSearchRequest) ( | @@ -57,17 +58,27 @@ func (l *SystemSearchRoleLogic) SystemSearchRole(req *types.RoleSearchRequest) ( | ||
57 | }) | 58 | }) |
58 | return | 59 | return |
59 | } | 60 | } |
61 | + roleIds := domain.Values(roles, func(item *domain.Role) int64 { | ||
62 | + return item.Id | ||
63 | + }) | ||
64 | + _, users, _ = l.svcCtx.UserRepository.FindByCompanyRoles(l.ctx, conn, userToken.CompanyId, roleIds, domain.NewQueryOptions().WithFindOnly()) | ||
60 | lo.ForEach(roles, func(item *domain.Role, index int) { | 65 | lo.ForEach(roles, func(item *domain.Role, index int) { |
61 | role := NewTypesRole(item) | 66 | role := NewTypesRole(item) |
62 | - role.UsersDesc = usersDesc(item) | 67 | + usersAll := make([]domain.User, 0) |
68 | + for _, u := range users { | ||
69 | + if lo.Contains(u.Roles, item.Id) { | ||
70 | + usersAll = append(usersAll, *u) | ||
71 | + } | ||
72 | + } | ||
73 | + role.UsersDesc = usersDesc(usersAll) | ||
63 | role.AuthsDesc = authsDesc(item) | 74 | role.AuthsDesc = authsDesc(item) |
64 | resp.List = append(resp.List, role) | 75 | resp.List = append(resp.List, role) |
65 | }) | 76 | }) |
66 | return | 77 | return |
67 | } | 78 | } |
68 | 79 | ||
69 | -func usersDesc(item *domain.Role) string { | ||
70 | - users := lo.Slice(item.Users, 0, 3) | 80 | +func usersDesc(usersAll []domain.User) string { |
81 | + users := lo.Slice(usersAll, 0, 3) | ||
71 | var ( | 82 | var ( |
72 | nameList = make([]string, 0) | 83 | nameList = make([]string, 0) |
73 | desc string = " " | 84 | desc string = " " |
@@ -79,7 +90,7 @@ func usersDesc(item *domain.Role) string { | @@ -79,7 +90,7 @@ func usersDesc(item *domain.Role) string { | ||
79 | return desc | 90 | return desc |
80 | } | 91 | } |
81 | desc = fmt.Sprintf("%s%s", strings.Join(nameList, "、"), | 92 | desc = fmt.Sprintf("%s%s", strings.Join(nameList, "、"), |
82 | - lo.Ternary(len(item.Users) > 3, fmt.Sprintf("...共%d人", len(item.Users)), ""), | 93 | + lo.Ternary(len(usersAll) > 3, fmt.Sprintf("...共%d人", len(usersAll)), ""), |
83 | ) | 94 | ) |
84 | return desc | 95 | return desc |
85 | } | 96 | } |
@@ -67,10 +67,20 @@ func (l *SystemUserAccountSaveLogic) SystemUserAccountSave(req *types.SystemUser | @@ -67,10 +67,20 @@ func (l *SystemUserAccountSaveLogic) SystemUserAccountSave(req *types.SystemUser | ||
67 | AuditStatus: domain.UserAuditStatusPassed, | 67 | AuditStatus: domain.UserAuditStatusPassed, |
68 | } | 68 | } |
69 | user.WithName(name) | 69 | user.WithName(name) |
70 | + if user, err = l.svcCtx.UserRepository.Insert(ctx, conn, user); err != nil { | ||
71 | + return err | ||
72 | + } | ||
70 | for _, roleId := range req.Roles { | 73 | for _, roleId := range req.Roles { |
74 | + if _, err = l.svcCtx.UserRoleRepository.Insert(l.ctx, conn, &domain.UserRole{ | ||
75 | + CompanyId: user.CompanyId, | ||
76 | + UserId: user.Id, | ||
77 | + RoleId: roleId, | ||
78 | + }); err != nil { | ||
79 | + return err | ||
80 | + } | ||
71 | user.AddRole(roleId) | 81 | user.AddRole(roleId) |
72 | } | 82 | } |
73 | - if user, err = l.svcCtx.UserRepository.Insert(ctx, conn, user); err != nil { | 83 | + if user, err = l.svcCtx.UserRepository.UpdateWithVersion(ctx, conn, user); err != nil { |
74 | return err | 84 | return err |
75 | } | 85 | } |
76 | return nil | 86 | return nil |
@@ -2,6 +2,11 @@ package user | @@ -2,6 +2,11 @@ package user | ||
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "context" | 4 | "context" |
5 | + "github.com/samber/lo" | ||
6 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction" | ||
7 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | ||
8 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
9 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | ||
5 | 10 | ||
6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" | 11 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" |
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" | 12 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" |
@@ -24,7 +29,49 @@ func NewSystemUserAccountUpdateLogic(ctx context.Context, svcCtx *svc.ServiceCon | @@ -24,7 +29,49 @@ func NewSystemUserAccountUpdateLogic(ctx context.Context, svcCtx *svc.ServiceCon | ||
24 | } | 29 | } |
25 | 30 | ||
26 | func (l *SystemUserAccountUpdateLogic) SystemUserAccountUpdate(req *types.SystemUserAccountUpdateRequest) (resp *types.SystemUserAccountUpdateResponse, err error) { | 31 | func (l *SystemUserAccountUpdateLogic) SystemUserAccountUpdate(req *types.SystemUserAccountUpdateRequest) (resp *types.SystemUserAccountUpdateResponse, err error) { |
27 | - // todo: add your logic here and delete this line | ||
28 | - | 32 | + var ( |
33 | + userToken = contextdata.GetUserTokenFromCtx(l.ctx) | ||
34 | + user *domain.User | ||
35 | + conn = l.svcCtx.DefaultDBConn() | ||
36 | + ) | ||
37 | + if user, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, req.Id); err != nil { | ||
38 | + return nil, xerr.NewErrMsgErr("用户不存在", err) | ||
39 | + } | ||
40 | + if user.CompanyId != userToken.CompanyId { | ||
41 | + return nil, xerr.NewErrMsgErr("无权限更改", err) | ||
42 | + } | ||
43 | + if req.Name != user.Name { | ||
44 | + user.WithName(req.Name) | ||
45 | + } | ||
46 | + removeList, addList := lo.Difference(user.Roles, req.Roles) | ||
47 | + if len(removeList) > 0 || len(addList) > 0 { | ||
48 | + user.Roles = req.Roles | ||
49 | + } | ||
50 | + user.Enable = req.Status | ||
51 | + if err = transaction.UseTrans(l.ctx, l.svcCtx.DB, func(ctx context.Context, conn transaction.Conn) error { | ||
52 | + if user, err = l.svcCtx.UserRepository.UpdateWithVersion(ctx, conn, user); err != nil { | ||
53 | + return err | ||
54 | + } | ||
55 | + if len(removeList) > 0 || len(addList) > 0 { | ||
56 | + if err = l.svcCtx.UserRoleRepository.DeleteByUser(ctx, conn, user.Id); err != nil { | ||
57 | + return err | ||
58 | + } | ||
59 | + user.Roles = []int64{} | ||
60 | + for _, roleId := range req.Roles { | ||
61 | + if _, err = l.svcCtx.UserRoleRepository.Insert(l.ctx, conn, &domain.UserRole{ | ||
62 | + CompanyId: user.CompanyId, | ||
63 | + UserId: user.Id, | ||
64 | + RoleId: roleId, | ||
65 | + }); err != nil { | ||
66 | + return err | ||
67 | + } | ||
68 | + user.AddRole(roleId) | ||
69 | + } | ||
70 | + } | ||
71 | + return nil | ||
72 | + }, true); err != nil { | ||
73 | + return nil, xerr.NewErrMsgErr("更新用户信息失败", err) | ||
74 | + } | ||
75 | + resp = &types.SystemUserAccountUpdateResponse{} | ||
29 | return | 76 | return |
30 | } | 77 | } |
@@ -39,6 +39,7 @@ type ServiceContext struct { | @@ -39,6 +39,7 @@ type ServiceContext struct { | ||
39 | UserLoveFlagRepository domain.UserLoveFlagRepository | 39 | UserLoveFlagRepository domain.UserLoveFlagRepository |
40 | UserReadArticleRepository domain.UserReadArticleRepository | 40 | UserReadArticleRepository domain.UserReadArticleRepository |
41 | UserRepository domain.UserRepository | 41 | UserRepository domain.UserRepository |
42 | + UserRoleRepository domain.UserRoleRepository | ||
42 | 43 | ||
43 | ApiAuthService authlib.ApiAuthService | 44 | ApiAuthService authlib.ApiAuthService |
44 | SmsService smslib.SMSService | 45 | SmsService smslib.SMSService |
@@ -80,6 +81,7 @@ func NewServiceContext(c config.Config) *ServiceContext { | @@ -80,6 +81,7 @@ func NewServiceContext(c config.Config) *ServiceContext { | ||
80 | UserRepository: repository.NewUserRepository(cache.NewCachedRepository(mlCache)), | 81 | UserRepository: repository.NewUserRepository(cache.NewCachedRepository(mlCache)), |
81 | UserReadArticleRepository: repository.NewUserReadArticleRepository(cache.NewCachedRepository(mlCache)), | 82 | UserReadArticleRepository: repository.NewUserReadArticleRepository(cache.NewCachedRepository(mlCache)), |
82 | ArticleTagRepository: repository.NewArticleTagRepository(cache.NewCachedRepository(mlCache)), | 83 | ArticleTagRepository: repository.NewArticleTagRepository(cache.NewCachedRepository(mlCache)), |
84 | + UserRoleRepository: repository.NewUserRoleRepository(cache.NewCachedRepository(mlCache)), | ||
83 | } | 85 | } |
84 | } | 86 | } |
85 | 87 |
@@ -690,6 +690,9 @@ type SystemUserAccountEnableResponse struct { | @@ -690,6 +690,9 @@ type SystemUserAccountEnableResponse struct { | ||
690 | 690 | ||
691 | type SystemUserAccountUpdateRequest struct { | 691 | type SystemUserAccountUpdateRequest struct { |
692 | Id int64 `path:"id"` | 692 | Id int64 `path:"id"` |
693 | + Name string `json:"name"` // 姓名 | ||
694 | + Roles []int64 `json:"roles"` // 权限角色 | ||
695 | + Status int `json:"enable"` // 状态 1:启用 2:禁用 | ||
693 | } | 696 | } |
694 | 697 | ||
695 | type SystemUserAccountUpdateResponse struct { | 698 | type SystemUserAccountUpdateResponse struct { |
cmd/discuss/doc/dsl/api/user_role.api
0 → 100644
1 | + | ||
2 | +syntax = "v1" | ||
3 | + | ||
4 | +info( | ||
5 | + title: "xx实例" | ||
6 | + desc: "xx实例" | ||
7 | + author: "author" | ||
8 | + email: "email" | ||
9 | + version: "v1" | ||
10 | +) | ||
11 | + | ||
12 | +@server( | ||
13 | + prefix: user_role/v1 | ||
14 | + group: user_role | ||
15 | + jwt: JwtAuth | ||
16 | +) | ||
17 | +service Core { | ||
18 | + @handler getUserRole | ||
19 | + post /user_role/:id (UserRoleGetRequest) returns (UserRoleGetResponse) | ||
20 | + @handler saveUserRole | ||
21 | + post /user_role (UserRoleSaveRequest) returns (UserRoleSaveResponse) | ||
22 | + @handler deleteUserRole | ||
23 | + delete /user_role/:id (UserRoleDeleteRequest) returns (UserRoleDeleteResponse) | ||
24 | + @handler updateUserRole | ||
25 | + put /user_role/:id (UserRoleUpdateRequest) returns (UserRoleUpdateResponse) | ||
26 | + @handler searchUserRole | ||
27 | + post /user_role/search (UserRoleSearchRequest) returns (UserRoleSearchResponse) | ||
28 | +} | ||
29 | + | ||
30 | +type ( | ||
31 | + UserRoleGetRequest { | ||
32 | + Id int64 `path:"id"` | ||
33 | + } | ||
34 | + UserRoleGetResponse struct{ | ||
35 | + UserRole UserRoleItem `json:"user_role"` | ||
36 | + } | ||
37 | + | ||
38 | + UserRoleSaveRequest struct{ | ||
39 | + UserRole UserRoleItem `json:"user_role"` | ||
40 | + } | ||
41 | + UserRoleSaveResponse struct{} | ||
42 | + | ||
43 | + UserRoleDeleteRequest struct{ | ||
44 | + Id int64 `path:"id"` | ||
45 | + } | ||
46 | + UserRoleDeleteResponse struct{} | ||
47 | + | ||
48 | + UserRoleUpdateRequest struct{ | ||
49 | + Id int64 `path:"id"` | ||
50 | + UserRole UserRoleItem `json:"user_role"` | ||
51 | + } | ||
52 | + UserRoleUpdateResponse struct{} | ||
53 | + | ||
54 | + UserRoleSearchRequest struct{ | ||
55 | + Page int `json:"page"` | ||
56 | + Size int `json:"size"` | ||
57 | + } | ||
58 | + UserRoleSearchResponse{ | ||
59 | + List []UserRoleItem `json:"list"` | ||
60 | + Total int64 `json:"total"` | ||
61 | + } | ||
62 | + UserRoleItem struct{ | ||
63 | + | ||
64 | + } | ||
65 | +) |
cmd/discuss/doc/dsl/rpc/user_role.proto
0 → 100644
1 | + | ||
2 | +syntax = "proto3"; | ||
3 | + | ||
4 | +option go_package ="./pb"; | ||
5 | + | ||
6 | +package pb; | ||
7 | + | ||
8 | +message UserRoleGetReq { | ||
9 | + int64 Id = 1; | ||
10 | +} | ||
11 | +message UserRoleGetResp{ | ||
12 | + UserRoleItem User = 1; | ||
13 | +} | ||
14 | + | ||
15 | +message UserRoleSaveReq { | ||
16 | + | ||
17 | +} | ||
18 | +message UserRoleSaveResp{ | ||
19 | + | ||
20 | +} | ||
21 | + | ||
22 | +message UserRoleDeleteReq { | ||
23 | + int64 Id = 1; | ||
24 | +} | ||
25 | +message UserRoleDeleteResp{ | ||
26 | + | ||
27 | +} | ||
28 | + | ||
29 | +message UserRoleUpdateReq { | ||
30 | + int64 Id = 1; | ||
31 | +} | ||
32 | +message UserRoleUpdateResp{ | ||
33 | + | ||
34 | +} | ||
35 | + | ||
36 | +message UserRoleSearchReq { | ||
37 | + int64 PageNumber = 1; | ||
38 | + int64 PageSize = 2; | ||
39 | +} | ||
40 | +message UserRoleSearchResp{ | ||
41 | + repeated UserRoleItem List =1; | ||
42 | + int64 Total =2; | ||
43 | +} | ||
44 | +message UserRoleItem { | ||
45 | + | ||
46 | +} | ||
47 | + | ||
48 | +service UserRoleService { | ||
49 | + rpc UserRoleGet(UserRoleGetReq) returns(UserRoleGetResp); | ||
50 | + rpc UserRoleSave(UserRoleSaveReq) returns(UserRoleSaveResp); | ||
51 | + rpc UserRoleDelete(UserRoleDeleteReq) returns(UserRoleDeleteResp); | ||
52 | + rpc UserRoleUpdate(UserRoleUpdateReq) returns(UserRoleUpdateResp); | ||
53 | + rpc UserRoleSearch(UserRoleSearchReq) returns(UserRoleSearchResp); | ||
54 | +} |
@@ -16,6 +16,7 @@ func Migrate(db *gorm.DB) { | @@ -16,6 +16,7 @@ func Migrate(db *gorm.DB) { | ||
16 | &models.UserLoveFlag{}, | 16 | &models.UserLoveFlag{}, |
17 | &models.UserReadArticle{}, | 17 | &models.UserReadArticle{}, |
18 | &models.User{}, | 18 | &models.User{}, |
19 | + &models.UserRole{}, | ||
19 | &models.Role{}, | 20 | &models.Role{}, |
20 | &models.Company{}, | 21 | &models.Company{}, |
21 | &models.UserFollow{}, | 22 | &models.UserFollow{}, |
1 | +package models | ||
2 | + | ||
3 | +import ( | ||
4 | + "gorm.io/gorm" | ||
5 | +) | ||
6 | + | ||
7 | +type UserRole struct { | ||
8 | + Id int64 // 唯一标识 | ||
9 | + CompanyId int64 // 公司ID | ||
10 | + UserId int64 | ||
11 | + RoleId int64 | ||
12 | + CreatedAt int64 | ||
13 | + UpdatedAt int64 | ||
14 | + DeletedAt int64 | ||
15 | + Version int | ||
16 | +} | ||
17 | + | ||
18 | +func (m *UserRole) TableName() string { | ||
19 | + return "user_role" | ||
20 | +} | ||
21 | + | ||
22 | +func (m *UserRole) BeforeCreate(tx *gorm.DB) (err error) { | ||
23 | + // m.CreatedAt = time.Now().Unix() | ||
24 | + // m.UpdatedAt = time.Now().Unix() | ||
25 | + return | ||
26 | +} | ||
27 | + | ||
28 | +func (m *UserRole) BeforeUpdate(tx *gorm.DB) (err error) { | ||
29 | + // m.UpdatedAt = time.Now().Unix() | ||
30 | + return | ||
31 | +} | ||
32 | + | ||
33 | +func (m *UserRole) CacheKeyFunc() string { | ||
34 | + return "" | ||
35 | +} | ||
36 | + | ||
37 | +func (m *UserRole) CacheKeyFuncByObject(obj interface{}) string { | ||
38 | + if v, ok := obj.(*UserRole); ok { | ||
39 | + return v.CacheKeyFunc() | ||
40 | + } | ||
41 | + return "" | ||
42 | +} | ||
43 | + | ||
44 | +func (m *UserRole) CachePrimaryKeyFunc() string { | ||
45 | + return "" | ||
46 | +} |
@@ -242,6 +242,39 @@ func (repository *UserRepository) FindDepartmentUsers(ctx context.Context, conn | @@ -242,6 +242,39 @@ func (repository *UserRepository) FindDepartmentUsers(ctx context.Context, conn | ||
242 | return total, dms, nil | 242 | return total, dms, nil |
243 | } | 243 | } |
244 | 244 | ||
245 | +func (repository *UserRepository) FindByCompanyRoles(ctx context.Context, conn transaction.Conn, companyId int64, roles []int64, queryOptions map[string]interface{}) (int64, []*domain.User, error) { | ||
246 | + var ( | ||
247 | + tx = conn.DB() | ||
248 | + ms []*models.User | ||
249 | + dms = make([]*domain.User, 0) | ||
250 | + total int64 | ||
251 | + ) | ||
252 | + queryFunc := func() (interface{}, error) { | ||
253 | + tx = tx.Model(&ms).Order("id asc") | ||
254 | + tx.Select("id", "name", "roles") | ||
255 | + tx.Where("company_id = ?", companyId) | ||
256 | + tx.Where("flag = ?", domain.UserAdmin) | ||
257 | + tx.Where("id in (select user_id from user_role where role_id in(?)) ", roles) | ||
258 | + if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { | ||
259 | + return dms, tx.Error | ||
260 | + } | ||
261 | + return dms, nil | ||
262 | + } | ||
263 | + | ||
264 | + if _, err := repository.Query(queryFunc); err != nil { | ||
265 | + return 0, nil, err | ||
266 | + } | ||
267 | + | ||
268 | + for _, item := range ms { | ||
269 | + if dm, err := repository.ModelToDomainModel(item); err != nil { | ||
270 | + return 0, dms, err | ||
271 | + } else { | ||
272 | + dms = append(dms, dm) | ||
273 | + } | ||
274 | + } | ||
275 | + return total, dms, nil | ||
276 | +} | ||
277 | + | ||
245 | func (repository *UserRepository) FindCompanyPositions(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*domain.User, error) { | 278 | func (repository *UserRepository) FindCompanyPositions(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*domain.User, error) { |
246 | var ( | 279 | var ( |
247 | tx = conn.DB() | 280 | tx = conn.DB() |
1 | +package repository | ||
2 | + | ||
3 | +import ( | ||
4 | + "context" | ||
5 | + "github.com/jinzhu/copier" | ||
6 | + "github.com/pkg/errors" | ||
7 | + "github.com/tiptok/gocomm/pkg/cache" | ||
8 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/models" | ||
9 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction" | ||
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | ||
11 | + "gorm.io/gorm" | ||
12 | +) | ||
13 | + | ||
14 | +type UserRoleRepository struct { | ||
15 | + *cache.CachedRepository | ||
16 | +} | ||
17 | + | ||
18 | +func (repository *UserRoleRepository) Insert(ctx context.Context, conn transaction.Conn, dm *domain.UserRole) (*domain.UserRole, error) { | ||
19 | + var ( | ||
20 | + err error | ||
21 | + m = &models.UserRole{} | ||
22 | + tx = conn.DB() | ||
23 | + ) | ||
24 | + if m, err = repository.DomainModelToModel(dm); err != nil { | ||
25 | + return nil, err | ||
26 | + } | ||
27 | + if tx = tx.Model(m).Save(m); tx.Error != nil { | ||
28 | + return nil, tx.Error | ||
29 | + } | ||
30 | + dm.Id = m.Id | ||
31 | + return repository.ModelToDomainModel(m) | ||
32 | + | ||
33 | +} | ||
34 | + | ||
35 | +func (repository *UserRoleRepository) Update(ctx context.Context, conn transaction.Conn, dm *domain.UserRole) (*domain.UserRole, error) { | ||
36 | + var ( | ||
37 | + err error | ||
38 | + m *models.UserRole | ||
39 | + tx = conn.DB() | ||
40 | + ) | ||
41 | + if m, err = repository.DomainModelToModel(dm); err != nil { | ||
42 | + return nil, err | ||
43 | + } | ||
44 | + queryFunc := func() (interface{}, error) { | ||
45 | + tx = tx.Model(m).Updates(m) | ||
46 | + return nil, tx.Error | ||
47 | + } | ||
48 | + if _, err = repository.Query(queryFunc, m.CacheKeyFunc()); err != nil { | ||
49 | + return nil, err | ||
50 | + } | ||
51 | + return repository.ModelToDomainModel(m) | ||
52 | +} | ||
53 | + | ||
54 | +func (repository *UserRoleRepository) UpdateWithVersion(ctx context.Context, transaction transaction.Conn, dm *domain.UserRole) (*domain.UserRole, error) { | ||
55 | + var ( | ||
56 | + err error | ||
57 | + m *models.UserRole | ||
58 | + tx = transaction.DB() | ||
59 | + ) | ||
60 | + if m, err = repository.DomainModelToModel(dm); err != nil { | ||
61 | + return nil, err | ||
62 | + } | ||
63 | + oldVersion := dm.Version | ||
64 | + m.Version += 1 | ||
65 | + queryFunc := func() (interface{}, error) { | ||
66 | + tx = tx.Model(m).Select("*").Where("id = ?", m.Id).Where("version = ?", oldVersion).Updates(m) | ||
67 | + if tx.RowsAffected == 0 { | ||
68 | + return nil, domain.ErrUpdateFail | ||
69 | + } | ||
70 | + return nil, tx.Error | ||
71 | + } | ||
72 | + if _, err = repository.Query(queryFunc, m.CacheKeyFunc()); err != nil { | ||
73 | + return nil, err | ||
74 | + } | ||
75 | + return repository.ModelToDomainModel(m) | ||
76 | +} | ||
77 | + | ||
78 | +func (repository *UserRoleRepository) Delete(ctx context.Context, conn transaction.Conn, dm *domain.UserRole) (*domain.UserRole, error) { | ||
79 | + var ( | ||
80 | + tx = conn.DB() | ||
81 | + m = &models.UserRole{Id: dm.Identify().(int64)} | ||
82 | + ) | ||
83 | + queryFunc := func() (interface{}, error) { | ||
84 | + tx = tx.Where("id = ?", m.Id).Delete(m) | ||
85 | + return m, tx.Error | ||
86 | + } | ||
87 | + if _, err := repository.Query(queryFunc, m.CacheKeyFunc()); err != nil { | ||
88 | + return dm, err | ||
89 | + } | ||
90 | + return repository.ModelToDomainModel(m) | ||
91 | +} | ||
92 | + | ||
93 | +func (repository *UserRoleRepository) DeleteByUser(ctx context.Context, conn transaction.Conn, userId int64) error { | ||
94 | + var ( | ||
95 | + tx = conn.DB() | ||
96 | + m = &models.UserRole{} | ||
97 | + ) | ||
98 | + queryFunc := func() (interface{}, error) { | ||
99 | + tx = tx.Where("user_id = ?", userId).Delete(m) | ||
100 | + return m, tx.Error | ||
101 | + } | ||
102 | + if _, err := repository.Query(queryFunc, m.CacheKeyFunc()); err != nil { | ||
103 | + return err | ||
104 | + } | ||
105 | + return nil | ||
106 | +} | ||
107 | + | ||
108 | +func (repository *UserRoleRepository) FindOne(ctx context.Context, conn transaction.Conn, id int64) (*domain.UserRole, error) { | ||
109 | + var ( | ||
110 | + err error | ||
111 | + tx = conn.DB() | ||
112 | + m = new(models.UserRole) | ||
113 | + ) | ||
114 | + queryFunc := func() (interface{}, error) { | ||
115 | + tx = tx.Model(m).Where("id = ?", id).First(m) | ||
116 | + if errors.Is(tx.Error, gorm.ErrRecordNotFound) { | ||
117 | + return nil, domain.ErrNotFound | ||
118 | + } | ||
119 | + return m, tx.Error | ||
120 | + } | ||
121 | + cacheModel := new(models.UserRole) | ||
122 | + cacheModel.Id = id | ||
123 | + if err = repository.QueryCache(cacheModel.CacheKeyFunc, m, queryFunc); err != nil { | ||
124 | + return nil, err | ||
125 | + } | ||
126 | + return repository.ModelToDomainModel(m) | ||
127 | +} | ||
128 | + | ||
129 | +func (repository *UserRoleRepository) Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*domain.UserRole, error) { | ||
130 | + var ( | ||
131 | + tx = conn.DB() | ||
132 | + ms []*models.UserRole | ||
133 | + dms = make([]*domain.UserRole, 0) | ||
134 | + total int64 | ||
135 | + ) | ||
136 | + queryFunc := func() (interface{}, error) { | ||
137 | + tx = tx.Model(&ms).Order("id desc") | ||
138 | + if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { | ||
139 | + return dms, tx.Error | ||
140 | + } | ||
141 | + return dms, nil | ||
142 | + } | ||
143 | + | ||
144 | + if _, err := repository.Query(queryFunc); err != nil { | ||
145 | + return 0, nil, err | ||
146 | + } | ||
147 | + | ||
148 | + for _, item := range ms { | ||
149 | + if dm, err := repository.ModelToDomainModel(item); err != nil { | ||
150 | + return 0, dms, err | ||
151 | + } else { | ||
152 | + dms = append(dms, dm) | ||
153 | + } | ||
154 | + } | ||
155 | + return total, dms, nil | ||
156 | +} | ||
157 | + | ||
158 | +func (repository *UserRoleRepository) ModelToDomainModel(from *models.UserRole) (*domain.UserRole, error) { | ||
159 | + to := &domain.UserRole{} | ||
160 | + err := copier.Copy(to, from) | ||
161 | + return to, err | ||
162 | +} | ||
163 | + | ||
164 | +func (repository *UserRoleRepository) DomainModelToModel(from *domain.UserRole) (*models.UserRole, error) { | ||
165 | + to := &models.UserRole{} | ||
166 | + err := copier.Copy(to, from) | ||
167 | + return to, err | ||
168 | +} | ||
169 | + | ||
170 | +func NewUserRoleRepository(cache *cache.CachedRepository) domain.UserRoleRepository { | ||
171 | + return &UserRoleRepository{CachedRepository: cache} | ||
172 | +} |
@@ -39,6 +39,7 @@ type UserRepository interface { | @@ -39,6 +39,7 @@ type UserRepository interface { | ||
39 | FindOne(ctx context.Context, conn transaction.Conn, id int64) (*User, error) | 39 | FindOne(ctx context.Context, conn transaction.Conn, id int64) (*User, error) |
40 | FindOneByCompanyIdAndPhone(ctx context.Context, conn transaction.Conn, companyId int64, phone string, status []int) (*User, error) | 40 | FindOneByCompanyIdAndPhone(ctx context.Context, conn transaction.Conn, companyId int64, phone string, status []int) (*User, error) |
41 | Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*User, error) | 41 | Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*User, error) |
42 | + FindByCompanyRoles(ctx context.Context, conn transaction.Conn, companyId int64, roles []int64, queryOptions map[string]interface{}) (int64, []*User, error) | ||
42 | FindDepartmentUsers(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*User, error) | 43 | FindDepartmentUsers(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*User, error) |
43 | FindCompanyPositions(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*User, error) | 44 | FindCompanyPositions(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*User, error) |
44 | } | 45 | } |
cmd/discuss/interanl/pkg/domain/user_role.go
0 → 100644
1 | +package domain | ||
2 | + | ||
3 | +import ( | ||
4 | + "context" | ||
5 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction" | ||
6 | +) | ||
7 | + | ||
8 | +type UserRole struct { | ||
9 | + Id int64 // 唯一标识 | ||
10 | + CompanyId int64 // 公司ID | ||
11 | + UserId int64 | ||
12 | + RoleId int64 | ||
13 | + CreatedAt int64 | ||
14 | + UpdatedAt int64 | ||
15 | + DeletedAt int64 | ||
16 | + Version int | ||
17 | +} | ||
18 | + | ||
19 | +type UserRoleRepository interface { | ||
20 | + Insert(ctx context.Context, conn transaction.Conn, dm *UserRole) (*UserRole, error) | ||
21 | + Update(ctx context.Context, conn transaction.Conn, dm *UserRole) (*UserRole, error) | ||
22 | + UpdateWithVersion(ctx context.Context, conn transaction.Conn, dm *UserRole) (*UserRole, error) | ||
23 | + Delete(ctx context.Context, conn transaction.Conn, dm *UserRole) (*UserRole, error) | ||
24 | + DeleteByUser(ctx context.Context, conn transaction.Conn, userId int64) error | ||
25 | + FindOne(ctx context.Context, conn transaction.Conn, id int64) (*UserRole, error) | ||
26 | + Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*UserRole, error) | ||
27 | +} | ||
28 | + | ||
29 | +func (m *UserRole) Identify() interface{} { | ||
30 | + if m.Id == 0 { | ||
31 | + return nil | ||
32 | + } | ||
33 | + return m.Id | ||
34 | +} |
1 | -CREATE TABLE `comment` ( | 1 | +CREATE TABLE `department` ( |
2 | `id` int(0) NOT NULL COMMENT '唯一标识', | 2 | `id` int(0) NOT NULL COMMENT '唯一标识', |
3 | PRIMARY KEY (`id`) USING BTREE | 3 | PRIMARY KEY (`id`) USING BTREE |
4 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; | 4 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; |
5 | 5 | ||
6 | -CREATE TABLE `department` ( | 6 | +CREATE TABLE `role` ( |
7 | `id` int(0) NOT NULL COMMENT '唯一标识', | 7 | `id` int(0) NOT NULL COMMENT '唯一标识', |
8 | PRIMARY KEY (`id`) USING BTREE | 8 | PRIMARY KEY (`id`) USING BTREE |
9 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; | 9 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; |
10 | 10 | ||
11 | -CREATE TABLE `role` ( | 11 | +CREATE TABLE `user` ( |
12 | `id` int(0) NOT NULL COMMENT '唯一标识', | 12 | `id` int(0) NOT NULL COMMENT '唯一标识', |
13 | PRIMARY KEY (`id`) USING BTREE | 13 | PRIMARY KEY (`id`) USING BTREE |
14 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; | 14 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; |
15 | 15 | ||
16 | -CREATE TABLE `user` ( | 16 | +CREATE TABLE `user_role` ( |
17 | `id` int(0) NOT NULL COMMENT '唯一标识', | 17 | `id` int(0) NOT NULL COMMENT '唯一标识', |
18 | PRIMARY KEY (`id`) USING BTREE | 18 | PRIMARY KEY (`id`) USING BTREE |
19 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; | 19 | ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; |
-
请 注册 或 登录 后发表评论