Documentation ¶
Overview ¶
Package duck defines logic for defining and consuming "duck typed" Kubernetes resources. Producers define partial resource definitions that resource authors may choose to implement to interoperate with consumers of these "duck typed" interfaces. For more information see: https://docs.google.com/document/d/16j8C91jML4fQRQPhnHihNJUJDcbvW0RM1YAX2REHgyY/edit#
Index ¶
- Constants
- func AsStructuredWatcher(wf cache.WatchFunc, obj runtime.Object) cache.WatchFunc
- func ConformsToType(instance interface{}, iface Implementable) (bool, error)
- func CreateMergePatch(before, after interface{}) ([]byte, error)
- func FromUnstructured(obj Marshalable, target interface{}) error
- func NewProxyWatcher(ch chan watch.Event) watch.Interface
- func VerifyType(instance interface{}, iface Implementable) error
- type CachedInformerFactory
- type EnqueueInformerFactory
- type Implementable
- type InformerFactory
- type JSONPatch
- type Marshalable
- type Populatable
- type TypedInformerFactory
Constants ¶
const (
GroupName = "duck.knative.dev"
)
Variables ¶
This section is empty.
Functions ¶
func AsStructuredWatcher ¶
AsStructuredWatcher is public for testing only. TODO(mattmoor): Move tests for this to `package duck` and make private.
func ConformsToType ¶
func ConformsToType(instance interface{}, iface Implementable) (bool, error)
ConformsToType will return true or false depending on whether a concrete resource properly implements the provided Implementable duck type.
It will return an error if marshal/unmarshalling fails
func CreateMergePatch ¶
func FromUnstructured ¶
func FromUnstructured(obj Marshalable, target interface{}) error
FromUnstructured takes unstructured object from (say from client-go/dynamic) and converts it into our duck types.
func NewProxyWatcher ¶
NewProxyWatcher creates new proxyWatcher by wrapping a channel
func VerifyType ¶
func VerifyType(instance interface{}, iface Implementable) error
VerifyType verifies that a particular concrete resource properly implements the provided Implementable duck type. It is expected that under the resource definition implementing a particular "Fooable" that one would write:
type ConcreteResource struct { ... } // Check that ConcreteResource properly implement Fooable. err := duck.VerifyType(&ConcreteResource{}, &something.Fooable{})
This will return an error if the duck typing is not satisfied.
Types ¶
type CachedInformerFactory ¶
type CachedInformerFactory struct { Delegate InformerFactory // contains filtered or unexported fields }
CachedInformerFactory implements InformerFactory by delegating to another InformerFactory, but memoizing the results.
func (*CachedInformerFactory) Get ¶
func (cif *CachedInformerFactory) Get(gvr schema.GroupVersionResource) (cache.SharedIndexInformer, cache.GenericLister, error)
Get implements InformerFactory.
type EnqueueInformerFactory ¶
type EnqueueInformerFactory struct { Delegate InformerFactory EventHandler cache.ResourceEventHandler }
EnqueueInformerFactory implements InformerFactory by delegating to another InformerFactory, but attaching a ResourceEventHandler to the informer.
func (*EnqueueInformerFactory) Get ¶
func (cif *EnqueueInformerFactory) Get(gvr schema.GroupVersionResource) (cache.SharedIndexInformer, cache.GenericLister, error)
Get implements InformerFactory.
type Implementable ¶
type Implementable interface { // GetFullType returns an instance of a full resource wrapping // an instance of this Implementable that can populate its fields // to verify json roundtripping. GetFullType() Populatable }
Implementable is implemented by the Fooable duck type that consumers are expected to embed as a `.status.fooable` field.
type InformerFactory ¶
type InformerFactory interface { // Get returns a synced Informer/Lister pair for the provided schema.GroupVersionResource. Get(schema.GroupVersionResource) (cache.SharedIndexInformer, cache.GenericLister, error) }
InformerFactory is used to create Informer/Lister pairs for a schema.GroupVersionResource
type JSONPatch ¶
type JSONPatch []jsonpatch.JsonPatchOperation
func CreatePatch ¶
func (JSONPatch) MarshalJSON ¶
type Marshalable ¶
Marshallable is implementated by the Unstructured K8s types.
type Populatable ¶
type Populatable interface { // Populate fills in all possible fields, so that we can verify that // they roundtrip properly through JSON. Populate() }
Populatable is implemented by a skeleton resource wrapping an Implementable duck type. It will generally have TypeMeta, ObjectMeta, and a Status field wrapping a Fooable field.
type TypedInformerFactory ¶
type TypedInformerFactory struct { Client dynamic.Interface Type apis.Listable ResyncPeriod time.Duration StopChannel <-chan struct{} }
TypedInformerFactory implements InformerFactory such that the elements tracked by the informer/lister have the type of the canonical "obj".
func (*TypedInformerFactory) Get ¶
func (dif *TypedInformerFactory) Get(gvr schema.GroupVersionResource) (cache.SharedIndexInformer, cache.GenericLister, error)
Get implements InformerFactory.