mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
Scopes: Add type filter (#84866)
Co-authored-by: Kyle Brandt <kyle@grafana.com>
This commit is contained in:
parent
99b5671fbe
commit
dfe61db7a5
@ -1,6 +1,8 @@
|
|||||||
package scope
|
package scope
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||||
"k8s.io/apimachinery/pkg/runtime"
|
"k8s.io/apimachinery/pkg/runtime"
|
||||||
"k8s.io/apimachinery/pkg/runtime/schema"
|
"k8s.io/apimachinery/pkg/runtime/schema"
|
||||||
@ -49,6 +51,22 @@ func (b *ScopeAPIBuilder) InstallSchema(scheme *runtime.Scheme) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
err = scheme.AddFieldLabelConversionFunc(
|
||||||
|
scope.ScopeResourceInfo.GroupVersionKind(),
|
||||||
|
func(label, value string) (string, string, error) {
|
||||||
|
fieldSet := SelectableFields(&scope.Scope{})
|
||||||
|
for key := range fieldSet {
|
||||||
|
if label == key {
|
||||||
|
return label, value, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return "", "", fmt.Errorf("field label not supported for %s: %s", scope.ScopeResourceInfo.GroupVersionKind(), label)
|
||||||
|
},
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// Link this version to the internal representation.
|
// Link this version to the internal representation.
|
||||||
// This is used for server-side-apply (PATCH), and avoids the error:
|
// This is used for server-side-apply (PATCH), and avoids the error:
|
||||||
// "no kind is registered for the type"
|
// "no kind is registered for the type"
|
||||||
|
@ -5,6 +5,8 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||||
|
"k8s.io/apimachinery/pkg/fields"
|
||||||
|
"k8s.io/apimachinery/pkg/labels"
|
||||||
"k8s.io/apimachinery/pkg/runtime"
|
"k8s.io/apimachinery/pkg/runtime"
|
||||||
"k8s.io/apiserver/pkg/registry/generic"
|
"k8s.io/apiserver/pkg/registry/generic"
|
||||||
genericregistry "k8s.io/apiserver/pkg/registry/generic/registry"
|
genericregistry "k8s.io/apiserver/pkg/registry/generic/registry"
|
||||||
@ -13,6 +15,7 @@ import (
|
|||||||
grafanaregistry "github.com/grafana/grafana/pkg/apiserver/registry/generic"
|
grafanaregistry "github.com/grafana/grafana/pkg/apiserver/registry/generic"
|
||||||
grafanarest "github.com/grafana/grafana/pkg/apiserver/rest"
|
grafanarest "github.com/grafana/grafana/pkg/apiserver/rest"
|
||||||
"github.com/grafana/grafana/pkg/services/apiserver/utils"
|
"github.com/grafana/grafana/pkg/services/apiserver/utils"
|
||||||
|
apistore "k8s.io/apiserver/pkg/storage"
|
||||||
)
|
)
|
||||||
|
|
||||||
var _ grafanarest.Storage = (*storage)(nil)
|
var _ grafanarest.Storage = (*storage)(nil)
|
||||||
@ -28,7 +31,7 @@ func newScopeStorage(scheme *runtime.Scheme, optsGetter generic.RESTOptionsGette
|
|||||||
store := &genericregistry.Store{
|
store := &genericregistry.Store{
|
||||||
NewFunc: resourceInfo.NewFunc,
|
NewFunc: resourceInfo.NewFunc,
|
||||||
NewListFunc: resourceInfo.NewListFunc,
|
NewListFunc: resourceInfo.NewListFunc,
|
||||||
PredicateFunc: grafanaregistry.Matcher,
|
PredicateFunc: Matcher,
|
||||||
DefaultQualifiedResource: resourceInfo.GroupResource(),
|
DefaultQualifiedResource: resourceInfo.GroupResource(),
|
||||||
SingularQualifiedResource: resourceInfo.SingularGroupResource(),
|
SingularQualifiedResource: resourceInfo.SingularGroupResource(),
|
||||||
TableConvertor: utils.NewTableConverter(
|
TableConvertor: utils.NewTableConverter(
|
||||||
@ -52,7 +55,7 @@ func newScopeStorage(scheme *runtime.Scheme, optsGetter generic.RESTOptionsGette
|
|||||||
UpdateStrategy: strategy,
|
UpdateStrategy: strategy,
|
||||||
DeleteStrategy: strategy,
|
DeleteStrategy: strategy,
|
||||||
}
|
}
|
||||||
options := &generic.StoreOptions{RESTOptions: optsGetter, AttrFunc: grafanaregistry.GetAttrs}
|
options := &generic.StoreOptions{RESTOptions: optsGetter, AttrFunc: GetAttrs}
|
||||||
if err := store.CompleteWithOptions(options); err != nil {
|
if err := store.CompleteWithOptions(options); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -66,7 +69,7 @@ func newScopeDashboardStorage(scheme *runtime.Scheme, optsGetter generic.RESTOpt
|
|||||||
store := &genericregistry.Store{
|
store := &genericregistry.Store{
|
||||||
NewFunc: resourceInfo.NewFunc,
|
NewFunc: resourceInfo.NewFunc,
|
||||||
NewListFunc: resourceInfo.NewListFunc,
|
NewListFunc: resourceInfo.NewListFunc,
|
||||||
PredicateFunc: grafanaregistry.Matcher,
|
PredicateFunc: Matcher,
|
||||||
DefaultQualifiedResource: resourceInfo.GroupResource(),
|
DefaultQualifiedResource: resourceInfo.GroupResource(),
|
||||||
SingularQualifiedResource: resourceInfo.SingularGroupResource(),
|
SingularQualifiedResource: resourceInfo.SingularGroupResource(),
|
||||||
TableConvertor: utils.NewTableConverter(
|
TableConvertor: utils.NewTableConverter(
|
||||||
@ -90,9 +93,33 @@ func newScopeDashboardStorage(scheme *runtime.Scheme, optsGetter generic.RESTOpt
|
|||||||
UpdateStrategy: strategy,
|
UpdateStrategy: strategy,
|
||||||
DeleteStrategy: strategy,
|
DeleteStrategy: strategy,
|
||||||
}
|
}
|
||||||
options := &generic.StoreOptions{RESTOptions: optsGetter, AttrFunc: grafanaregistry.GetAttrs}
|
options := &generic.StoreOptions{RESTOptions: optsGetter, AttrFunc: GetAttrs}
|
||||||
if err := store.CompleteWithOptions(options); err != nil {
|
if err := store.CompleteWithOptions(options); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return &storage{Store: store}, nil
|
return &storage{Store: store}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func GetAttrs(obj runtime.Object) (labels.Set, fields.Set, error) {
|
||||||
|
s, ok := obj.(*scope.Scope)
|
||||||
|
if !ok {
|
||||||
|
return nil, nil, fmt.Errorf("not a scope")
|
||||||
|
}
|
||||||
|
|
||||||
|
return labels.Set(s.Labels), SelectableFields(s), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Matcher returns a generic.SelectionPredicate that matches on label and field selectors.
|
||||||
|
func Matcher(label labels.Selector, field fields.Selector) apistore.SelectionPredicate {
|
||||||
|
return apistore.SelectionPredicate{
|
||||||
|
Label: label,
|
||||||
|
Field: field,
|
||||||
|
GetAttrs: GetAttrs,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func SelectableFields(obj *scope.Scope) fields.Set {
|
||||||
|
return generic.MergeFieldsSets(generic.ObjectMetaFieldsSet(&obj.ObjectMeta, false), fields.Set{
|
||||||
|
"spec.type": obj.Spec.Type,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user