ApiServerSource reference

version

This topic provides reference information about the configurable fields for the ApiServerSource object.

ApiServerSource

An ApiServerSource definition supports the following fields:

FieldDescriptionRequired or optional
apiVersionSpecifies the API version, for example sources.knative.dev/v1.Required
kindIdentifies this resource object as an ApiServerSource object.Required
metadataSpecifies metadata that uniquely identifies the ApiServerSource object. For example, a name.Required
specSpecifies the configuration information for this ApiServerSource object.Required
spec.modeEventMode controls the format of the event. Set to Reference to send a dataref event type for the resource being watched. Only a reference to the resource is included in the event payload. Set to Resource to have the full resource lifecycle event in the payload. Defaults to Reference.Optional
spec.ownerResourceOwner is an additional filter to only track resources that are owned by a specific resource type. If ResourceOwner matches Resources[n] then Resources[n] is allowed to pass the ResourceOwner filter.Optional
spec.resourcesThe resources that the source tracks so it can send related lifecycle events from the Kubernetes ApiServer. Includes an optional label selector to help filter.Required
spec.serviceAccountNameThe name of the ServiceAccount to use to run this source. Defaults to default if not set.Optional
spec.sinkA reference to an object that resolves to a URI to use as the sink.Required
spec.ceOverridesDefines overrides to control the output format and modifications to the event sent to the sink.Optional

Owner parameter

ResourceOwner is an additional filter to only track resources that are owned by a specific resource type. If ResourceOwner matches Resources[n] then Resources[n] is allowed to pass the ResourceOwner filter.

An owner definition supports the following fields:

FieldDescriptionRequired or optional
apiVersionAPI version of the resource to watch.Required
kindKind of the resource to watch.Required

Example: Owner parameter

  1. apiVersion: sources.knative.dev/v1
  2. kind: ApiServerSource
  3. metadata:
  4. name: <apiserversource>
  5. namespace: <namespace>
  6. spec:
  7. ...
  8. owner:
  9. apiVersion: apps/v1
  10. kind: Deployment
  11. ...

Resources parameter

The resources parameter specifies the resources that the source tracks so that it can send related lifecycle events from the Kubernetes ApiServer. The parameter includes an optional label selector to help filter.

A resources definition supports the following fields:

FieldDescriptionRequired or optional
apiVersionAPI version of the resource to watch.Required
kindKind of the resource to watch.Required
selectorLabelSelector filters this source to objects to those resources pass the label selector.Optional
selector.matchExpressionsA list of label selector requirements. The requirements are ANDed.Use one of matchExpressions or matchLabels
selector.matchExpressions.keyThe label key that the selector applies to.Required if using matchExpressions
selector.matchExpressions.operatorRepresents a key’s relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.Required if using matchExpressions
selector.matchExpressions.valuesAn array of string values. If operator is In or NotIn, the values array must be non-empty. If operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.Required if using matchExpressions
selector.matchLabelsA map of key-value pairs. Each key-value pair in the matchLabels map is equivalent to an element of matchExpressions, where the key field is matchLabels.<key>, the operator is In, and the values array contains only “matchLabels.“. The requirements are ANDed.Use one of matchExpressions or matchLabels

Example: Resources parameter

Given the following YAML, the ApiServerSource object receives events for all Pods and Deployments in the namespace:

  1. apiVersion: sources.knative.dev/v1
  2. kind: ApiServerSource
  3. metadata:
  4. name: <apiserversource>
  5. namespace: <namespace>
  6. spec:
  7. # ...
  8. resources:
  9. - apiVersion: v1
  10. kind: Pod
  11. - apiVersion: apps/v1
  12. kind: Deployment

Example: Resources parameter using matchExpressions

Given the following YAML, ApiServerSource object receives events for all Pods in the namespace that have a label app=myapp or app=yourapp:

  1. apiVersion: sources.knative.dev/v1
  2. kind: ApiServerSource
  3. metadata:
  4. name: <apiserversource>
  5. namespace: <namespace>
  6. spec:
  7. # ...
  8. resources:
  9. - apiVersion: v1
  10. kind: Pod
  11. selector:
  12. matchExpressions:
  13. - key: app
  14. operator: In
  15. values:
  16. - myapp
  17. - yourapp

Example: Resources parameter using matchLabels

Given the following YAML, the ApiServerSource object receives events for all Pods in the namespace that have a label app=myapp:

  1. apiVersion: sources.knative.dev/v1
  2. kind: ApiServerSource
  3. metadata:
  4. name: <apiserversource>
  5. namespace: <namespace>
  6. spec:
  7. # ...
  8. resources:
  9. - apiVersion: v1
  10. kind: Pod
  11. selector:
  12. matchLabels:
  13. app: myapp

Sink parameter

Sink is a reference to an object that resolves to a URI to use as the sink.

A sink definition supports the following fields:

FieldDescriptionRequired or optional
refThis points to an Addressable.Required if not using uri
ref.apiVersionAPI version of the referent.Required if using ref
ref.kindKind of the referent.Required if using ref
ref.namespaceNamespace of the referent. If omitted this defaults to the object holding it.Optional
ref.nameName of the referent.Required if using ref
uriThis can be an absolute URL with a non-empty scheme and non-empty host that points to the target or a relative URI. Relative URIs are resolved using the base URI retrieved from Ref.Required if not using ref

Note

At least one of ref or uri is required. If both are specified, uri is resolved into the URL from the Addressable ref result.

Example: Sink parameter

Given the following YAML, if ref resolves into "http://mysink.default.svc.cluster.local", then uri is added to this resulting in "http://mysink.default.svc.cluster.local/extra/path".

  1. apiVersion: sources.knative.dev/v1
  2. kind: ApiServerSource
  3. metadata:
  4. name: <apiserversource>
  5. namespace: <namespace>
  6. spec:
  7. ...
  8. sink:
  9. ref:
  10. apiVersion: v1
  11. kind: Service
  12. namespace: default
  13. name: mysink
  14. uri: /extra/path

Contract

This results in the K_SINK environment variable being set on the sink container as "http://mysink.default.svc.cluster.local/extra/path".

CloudEvent Overrides

CloudEvent Overrides defines overrides to control the output format and modifications of the event sent to the sink.

A ceOverrides definition supports the following fields:

FieldDescriptionRequired or optional
extensionsSpecifies which attributes are added or overridden on the outbound event. Each extensions key-value pair is set independently on the event as an attribute extension.Optional

Note

Only valid CloudEvent attribute names are allowed as extensions. You cannot set the spec defined attributes from the extensions override configuration. For example, you can not modify the type attribute.

Example: CloudEvent Overrides

  1. apiVersion: sources.knative.dev/v1
  2. kind: ApiServerSource
  3. metadata:
  4. name: <apiserversource>
  5. namespace: <namespace>
  6. spec:
  7. ...
  8. ceOverrides:
  9. extensions:
  10. extra: this is an extra attribute
  11. additional: 42

Contract

This results in the K_CE_OVERRIDES environment variable being set on the sink container as follows:

  1. { "extensions": { "extra": "this is an extra attribute", "additional": "42" } }