本文整理匯總了Golang中github.com/openshift/origin/pkg/authorization/authorizer.DefaultAuthorizationAttributes.RuleMatches方法的典型用法代碼示例。如果您正苦於以下問題:Golang DefaultAuthorizationAttributes.RuleMatches方法的具體用法?Golang DefaultAuthorizationAttributes.RuleMatches怎麽用?Golang DefaultAuthorizationAttributes.RuleMatches使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/openshift/origin/pkg/authorization/authorizer.DefaultAuthorizationAttributes
的用法示例。
在下文中一共展示了DefaultAuthorizationAttributes.RuleMatches方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: ResolveGettableNamespaces
func (e clusterRoleEvaluator) ResolveGettableNamespaces(scope string, clusterPolicyGetter client.ClusterPolicyLister) ([]string, error) {
_, scopeNamespace, _, err := e.parseScope(scope)
if err != nil {
return nil, err
}
rules, err := e.resolveRules(scope, clusterPolicyGetter)
if err != nil {
return nil, err
}
attributes := authorizer.DefaultAuthorizationAttributes{
APIGroup: kapi.GroupName,
Verb: "get",
Resource: "namespaces",
}
errors := []error{}
for _, rule := range rules {
matches, err := attributes.RuleMatches(rule)
if err != nil {
errors = append(errors, err)
continue
}
if matches {
return []string{scopeNamespace}, nil
}
}
return []string{}, kutilerrors.NewAggregate(errors)
}