-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.go
73 lines (63 loc) · 1.76 KB
/
config.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
package rbac
type RoleConfig struct {
Role string `json:"role,omitempty" yaml:"role,omitempty"`
Parents []string `json:"parents,omitempty" yaml:"parents,omitempty"`
Children []string `json:"children,omitempty" yaml:"children,omitempty"`
}
type AccessConfig struct {
Role string `json:"role,omitempty" yaml:"role,omitempty"`
Permissions []string `json:"permissions,omitempty" yaml:"permissions,omitempty"`
}
type Config struct {
CreateMissingRoles bool `json:"createMissingRoles,omitempty" yaml:"createMissingRoles,omitempty"`
RoleHierarchy []RoleConfig `json:"roleHierarchy,omitempty" yaml:"roleHierarchy,omitempty"`
AccessControl []AccessConfig `json:"accessControl,omitempty" yaml:"accessControl,omitempty"`
}
func NewWithConfig(cfg Config) (*RBAC, error) {
rbac := New()
err := rbac.Apply(cfg)
return rbac, err
}
func (rbac *RBAC) Apply(cfg Config) error {
rbac.SetCreateMissingRoles(cfg.CreateMissingRoles)
for _, role := range cfg.RoleHierarchy {
if err := rbac.AddRole(role.Role); err != nil {
return err
}
}
for _, role := range cfg.RoleHierarchy {
r, err := rbac.Role(role.Role)
if err != nil {
return err
}
for _, parent := range role.Parents {
p, err := rbac.Role(parent)
if err != nil {
return err
}
if err = r.AddParent(p); err != nil {
return err
}
}
for _, child := range role.Children {
c, err := rbac.Role(child)
if err != nil {
return err
}
if err = r.AddChild(c); err != nil {
return err
}
}
}
for _, access := range cfg.AccessControl {
r, err := rbac.Role(access.Role)
if err != nil {
return err
}
if len(access.Permissions) == 0 {
continue
}
r.AddPermissions(access.Permissions[0], access.Permissions[1:]...)
}
return nil
}