当前位置: 首页 > 文档资料 > Casbin 中文文档 >

RoleManager API

优质
小牛编辑
142浏览
2023-12-01

角色管理器

RoleManager提供接口来定义管理角色的操作。 添加匹配函数到角色管理器允许在角色名称和域中使用通配符。

AddNamedMatchingFunc()

AddNamedMatchingFunc 通过 ptype 角色管理器添加MatchingFunc MatchingFunc将在操作角色匹配时工作。

    e.AddNamedMatchingFunc("g", "", util.KeyMatch)
    _, _ = e.AddGroupingPolicies([][]string{{"*", "admin", "domain1"}})
    _, _ = e.GetRoleManager().HasLink("bob", "admin", "domain1") // -> true, nil

例如:

Go
    e, _ := casbin.NewEnforcer("path/to/model", "path/to/policy")
    e.AddNamedMatchingFunc("g", "", util.MatchKey)

AddNamedDomainMatchingFunc()

AddNamedDomainMatchingFunc 通过 ptype 把MatchingFunc 添加到 RoleManager中。 DomainMatchingFunc 类似于上面列出的 MatchingFunc

例如:

Go
    e, _ := casbin.NewEnforcer("path/to/model", "path/to/policy")
    e.AddNamedDomainMatchingFunc("g", "", util.MatchKey)

GetRoleManager()

GetRoleManager 获取现存的 g 的role manager。

例如:

Go
    rm := e.GetRoleManager()

Clear()

Clear清除所有存储的数据并将角色管理器重置到初始状态。

例如:

Go
    rm.Clear()

AddLink()

AddLink添加了两个角色之间的继承链接。 角色: 名称1 和 角色: 名称2 域是角色的前缀(可以用于其他目的)。

例如:

Go
    rm.AddLink("u1", "g1", "domain1")

DeleteLink()

DeleteLink 删除两个角色之间的继承链接。 role: name1 和 role: name2. 域是角色的前缀(可以用于其他目的)。

例如:

Go
    rm := DeleteLink("u1", "g1", "domain1")

HasLink()

HasLink 决定两种角色之间是否存在联系。 role: name1 继承自 role: name2. 域是角色的前缀(可以用于其他目的)。

例如:

Go
    rm.HasLink("u1", "g1", "domain1")

GetRoles()

GetRoles 获取一个用户所继承的角色 域是角色的前缀(可以用于其他目的)。

例如:

Go
    rm.GetRoles("u1", "domain1")

GetUsers()

GetUsers 获取继承自一个角色的用户 域是用户的前缀(可以用于其他目的)。

例如:

Go
    rm.GetUsers("g1")

PrintRoles()

PrintRoles 打印所有的角色到日志。

例如:

Go
    rm.PrintRoles()

SetLogger()

SetLogger设置角色管理器的日志。

例如:

Go
    logger := log.DefaultLogger{}
    logger.EnableLog(true)
    rm.SetLogger(&logger)
    _ = rm.PrintRoles()

GetDomains()

GetDomains 获取用户拥有的域

例如:

Go
    result, err := rm.GetDomains(name)
← 域内基于角色的访问控制 API数据权限 →