2024-06-05 10:47:36 -05:00
|
|
|
package scope
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"k8s.io/apimachinery/pkg/api/errors"
|
|
|
|
"k8s.io/apimachinery/pkg/apis/meta/internalversion"
|
|
|
|
"k8s.io/apimachinery/pkg/runtime"
|
|
|
|
"k8s.io/apimachinery/pkg/runtime/schema"
|
|
|
|
"k8s.io/apiserver/pkg/registry/rest"
|
|
|
|
|
|
|
|
scope "github.com/grafana/grafana/pkg/apis/scope/v0alpha1"
|
|
|
|
)
|
|
|
|
|
|
|
|
type findScopeDashboardsREST struct {
|
|
|
|
scopeDashboardStorage *storage
|
|
|
|
}
|
|
|
|
|
|
|
|
var (
|
|
|
|
_ rest.Storage = (*findScopeDashboardsREST)(nil)
|
|
|
|
_ rest.SingularNameProvider = (*findScopeDashboardsREST)(nil)
|
|
|
|
_ rest.Connecter = (*findScopeDashboardsREST)(nil)
|
|
|
|
_ rest.Scoper = (*findScopeDashboardsREST)(nil)
|
|
|
|
_ rest.StorageMetadata = (*findScopeDashboardsREST)(nil)
|
|
|
|
)
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) New() runtime.Object {
|
|
|
|
return &scope.FindScopeDashboardBindingsResults{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) Destroy() {}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) NamespaceScoped() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) GetSingularName() string {
|
|
|
|
return "FindScopeDashboardsResult" // not sure if this is actually used, but it is required to exist
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) ProducesMIMETypes(verb string) []string {
|
|
|
|
return []string{"application/json"} // and parquet!
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) ProducesObject(verb string) interface{} {
|
|
|
|
return &scope.FindScopeDashboardBindingsResults{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) ConnectMethods() []string {
|
|
|
|
return []string{"GET"}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) NewConnectOptions() (runtime.Object, bool, string) {
|
|
|
|
return nil, false, "" // true means you can use the trailing path as a variable
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *findScopeDashboardsREST) Connect(ctx context.Context, name string, opts runtime.Object, responder rest.Responder) (http.Handler, error) {
|
2024-07-01 10:42:34 -05:00
|
|
|
// See: /pkg/services/apiserver/builder/helper.go#L34
|
2024-06-05 10:47:36 -05:00
|
|
|
// The name is set with a rewriter hack
|
|
|
|
if name != "name" {
|
|
|
|
return nil, errors.NewNotFound(schema.GroupResource{}, name)
|
|
|
|
}
|
|
|
|
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
raw, err := f.scopeDashboardStorage.List(ctx, &internalversion.ListOptions{})
|
|
|
|
if err != nil {
|
|
|
|
w.WriteHeader(500)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
all, ok := raw.(*scope.ScopeDashboardBindingList)
|
|
|
|
if !ok {
|
|
|
|
w.WriteHeader(500)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
scopes := req.URL.Query()["scope"]
|
|
|
|
results := &scope.FindScopeDashboardBindingsResults{
|
|
|
|
Message: fmt.Sprintf("Find: %s", scopes),
|
|
|
|
Items: make([]scope.ScopeDashboardBinding, 0),
|
|
|
|
}
|
|
|
|
|
|
|
|
// we can improve the performance by calling .List once per scope if they are index by labels.
|
|
|
|
// The API stays the same thou.
|
|
|
|
for _, item := range all.Items {
|
|
|
|
for _, s := range scopes {
|
|
|
|
if item.Spec.Scope == s {
|
|
|
|
results.Items = append(results.Items, item)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
responder.Object(200, results)
|
|
|
|
}), nil
|
|
|
|
}
|