-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathserver_user.go
More file actions
59 lines (55 loc) · 1.48 KB
/
server_user.go
File metadata and controls
59 lines (55 loc) · 1.48 KB
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
package caskin
// CreateUser
// if there does not exist the user then create a new one
// 1. no permission checking
// 2. create a new user into metadata database
func (s *server) CreateUser(user User) error {
if err := s.DBCreateCheck(user); err != nil {
return err
}
return s.DB.Create(user)
}
// RecoverUser
// if there exist the user but soft deleted then recover it
// 1. no permission checking
// 2. recover the soft delete one user at metadata database
func (s *server) RecoverUser(user User) error {
if err := s.DBRecoverCheck(user); err != nil {
return err
}
return s.DB.Recover(user)
}
// DeleteUser
// if there exist the user delete user
// 1. no permission checking
// 2. delete all user's g in all domain
// 3. delete the user g in superadmin
// 4. soft delete one user in metadata database
func (s *server) DeleteUser(user User) error {
if err := s.IDInterfaceDeleteCheck(user); err != nil {
return err
}
domains, err := s.DB.GetAllDomain()
if err != nil {
return err
}
for _, v := range domains {
if err = s.Enforcer.RemoveUserInDomain(user, v); err != nil {
return err
}
}
if err = s.DeleteSuperadmin(user); err != nil {
return err
}
return s.DB.DeleteByID(user, user.GetID())
}
// UpdateUser
// if there exist the user update user
// 1. no permission checking
// 1. just update user's properties
func (s *server) UpdateUser(user User) error {
if err := s.IDInterfaceUpdateCheck(user, newByE(user)); err != nil {
return err
}
return s.DB.Update(user)
}