// Copyright 2019 Yunion // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package k8s import ( "yunion.io/x/jsonutils" ) type RoleCreateOpt struct { NamespaceResourceCreateOptions Rule []string `help:"role rule, e.g: 'apps/v1:deployments:get,watch,list'"` } func (o *RoleCreateOpt) Params() (jsonutils.JSONObject, error) { ret, err := o.NamespaceResourceCreateOptions.Params() if err != nil { return nil, err } params := ret.(*jsonutils.JSONDict) rules, err := parsePolicyRules(o.Rule) if err != nil { return nil, err } params.Add(jsonutils.Marshal(rules), "rules") return params, nil } type RoleUpdateOpt struct { NamespaceResourceUpdateOptions Rule []string `help:"role rule, e.g: 'apps/v1:deployments:get,watch,list'"` } func (o *RoleUpdateOpt) Params() (jsonutils.JSONObject, error) { params := jsonutils.NewDict() rules, err := parsePolicyRules(o.Rule) if err != nil { return nil, err } params.Add(jsonutils.Marshal(rules), "rules") return params, nil }