mirror of https://github.com/k3s-io/k3s
104 lines
3.1 KiB
Go
104 lines
3.1 KiB
Go
|
/*
|
||
|
Copyright 2014 The Kubernetes Authors.
|
||
|
|
||
|
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 resource
|
||
|
|
||
|
import (
|
||
|
"k8s.io/apimachinery/pkg/api/meta"
|
||
|
"k8s.io/apimachinery/pkg/types"
|
||
|
"k8s.io/client-go/discovery"
|
||
|
"k8s.io/client-go/rest"
|
||
|
"k8s.io/client-go/restmapper"
|
||
|
)
|
||
|
|
||
|
type RESTClientGetter interface {
|
||
|
ToRESTConfig() (*rest.Config, error)
|
||
|
ToDiscoveryClient() (discovery.CachedDiscoveryInterface, error)
|
||
|
ToRESTMapper() (meta.RESTMapper, error)
|
||
|
}
|
||
|
|
||
|
type ClientConfigFunc func() (*rest.Config, error)
|
||
|
type RESTMapperFunc func() (meta.RESTMapper, error)
|
||
|
type CategoryExpanderFunc func() (restmapper.CategoryExpander, error)
|
||
|
|
||
|
// RESTClient is a client helper for dealing with RESTful resources
|
||
|
// in a generic way.
|
||
|
type RESTClient interface {
|
||
|
Get() *rest.Request
|
||
|
Post() *rest.Request
|
||
|
Patch(types.PatchType) *rest.Request
|
||
|
Delete() *rest.Request
|
||
|
Put() *rest.Request
|
||
|
}
|
||
|
|
||
|
// RequestTransform is a function that is given a chance to modify the outgoing request.
|
||
|
type RequestTransform func(*rest.Request)
|
||
|
|
||
|
// NewClientWithOptions wraps the provided RESTClient and invokes each transform on each
|
||
|
// newly created request.
|
||
|
func NewClientWithOptions(c RESTClient, transforms ...RequestTransform) RESTClient {
|
||
|
if len(transforms) == 0 {
|
||
|
return c
|
||
|
}
|
||
|
return &clientOptions{c: c, transforms: transforms}
|
||
|
}
|
||
|
|
||
|
type clientOptions struct {
|
||
|
c RESTClient
|
||
|
transforms []RequestTransform
|
||
|
}
|
||
|
|
||
|
func (c *clientOptions) modify(req *rest.Request) *rest.Request {
|
||
|
for _, transform := range c.transforms {
|
||
|
transform(req)
|
||
|
}
|
||
|
return req
|
||
|
}
|
||
|
|
||
|
func (c *clientOptions) Get() *rest.Request {
|
||
|
return c.modify(c.c.Get())
|
||
|
}
|
||
|
|
||
|
func (c *clientOptions) Post() *rest.Request {
|
||
|
return c.modify(c.c.Post())
|
||
|
}
|
||
|
func (c *clientOptions) Patch(t types.PatchType) *rest.Request {
|
||
|
return c.modify(c.c.Patch(t))
|
||
|
}
|
||
|
func (c *clientOptions) Delete() *rest.Request {
|
||
|
return c.modify(c.c.Delete())
|
||
|
}
|
||
|
func (c *clientOptions) Put() *rest.Request {
|
||
|
return c.modify(c.c.Put())
|
||
|
}
|
||
|
|
||
|
// ContentValidator is an interface that knows how to validate an API object serialized to a byte array.
|
||
|
type ContentValidator interface {
|
||
|
ValidateBytes(data []byte) error
|
||
|
}
|
||
|
|
||
|
// Visitor lets clients walk a list of resources.
|
||
|
type Visitor interface {
|
||
|
Visit(VisitorFunc) error
|
||
|
}
|
||
|
|
||
|
// VisitorFunc implements the Visitor interface for a matching function.
|
||
|
// If there was a problem walking a list of resources, the incoming error
|
||
|
// will describe the problem and the function can decide how to handle that error.
|
||
|
// A nil returned indicates to accept an error to continue loops even when errors happen.
|
||
|
// This is useful for ignoring certain kinds of errors or aggregating errors in some way.
|
||
|
type VisitorFunc func(*Info, error) error
|