pkg/apis/duck
Christoph Stäbler 0736c742cf
Add SinkAudience to SourceStatus (#2844)
2023-10-02 13:16:21 +00:00
..
ducktypes Avoid importing apis/duck from apis/duck/<<version>> (#1388) 2020-07-10 17:49:37 -07:00
images Move duck typing document to markdown (#1184) 2020-04-07 07:59:00 -07:00
v1 Add SinkAudience to SourceStatus (#2844) 2023-10-02 13:16:21 +00:00
v1alpha1 Made changes to addressable and address status. (#2713) 2023-04-03 15:12:33 +00:00
v1beta1 Eventing TLS: validate that Destination.CACerts is a PEM encoded cert (#2743) 2023-05-18 14:43:13 +00:00
ABOUT.md Source validation fixes (#2251) 2021-09-09 09:52:59 -07:00
OWNERS update OWNERS files to use teams with active members (#2672) 2023-02-06 16:58:45 +00:00
README.md Spelling (#1797) 2020-10-18 14:22:57 -07:00
cached.go bump to k8s 1.18 (#1428) 2020-09-11 07:54:00 -07:00
cached_test.go Use go sync/atomic instead of go.uber.org/atomic (#2777) 2023-08-02 16:26:48 +00:00
const.go add ability to opt-out of bindings (#970) 2020-01-07 08:56:51 -08:00
doc.go Link to the doc on Duck Typing, which I missed adding before. (#105) 2018-09-28 16:33:22 -07:00
enqueue.go bump to k8s 1.18 (#1428) 2020-09-11 07:54:00 -07:00
enqueue_test.go bump k8s dependencies and update min version to v1.25 (#2745) 2023-05-23 14:06:11 +00:00
interface.go bump to k8s 1.18 (#1428) 2020-09-11 07:54:00 -07:00
patch.go Bump assorted dependencies (#2140) 2021-06-02 02:50:30 -07:00
patch_test.go Bump gomodules.xyz/jsonpatch/v2 from 2.2.0 to 2.3.0 (#2789) 2023-08-15 13:28:40 +00:00
register.go Fix revive related linting issues (#2131) 2021-05-26 01:10:28 -07:00
scale_test.go Align linters with serving (enables stylecheck and asciicheck) (#1738) 2020-09-23 07:37:40 -07:00
typed.go bump to k8s 1.18 (#1428) 2020-09-11 07:54:00 -07:00
typed_test.go drop fake dynamic client workaround (#2310) 2021-10-13 08:28:48 -07:00
unstructured.go Implement a base library for implementing "Pod Spec"-able bindings. (#915) 2019-12-02 08:58:34 -08:00
unstructured_test.go Add errorlint and fix all existing issues (#1855) 2020-10-29 01:14:35 -07:00
verify.go Go1.19 changes (#2631) 2022-11-03 22:34:05 +00:00
verify_test.go Spelling (#1797) 2020-10-18 14:22:57 -07:00

README.md

Duck Types

Knative leverages duck-typing to interact with resources inside of Kubernetes without explicit knowledge of the full resource shape. knative/pkg defines three duck types that are used throughout Knative: Addressable, Binding, and Source.

For APIs leveraging ObjectReference, the context of the resource in question identifies the duck-type. To enable the case where no ObjectReference is used, we have labeled the Custom Resource Definition with the duck-type. Those labels are as follows:

Label Duck-Type
duck.knative.dev/addressable=true Addressable
duck.knative.dev/binding=true Binding
duck.knative.dev/source=true Source

Addressable Shape

Addressable is expected to be the following shape:

apiVersion: group/version
kind: Kind
status:
  address:
    url: http://host/path?query

Binding Shape

Binding is expected to be in the following shape:

(with direct subject)

apiVersion: group/version
kind: Kind
spec:
  subject:
    apiVersion: group/version
    kind: SomeKind
    namespace: the-namespace
    name: a-name

(with indirect subject)

apiVersion: group/version
kind: Kind
spec:
  subject:
    apiVersion: group/version
    kind: SomeKind
    namespace: the-namespace
    selector:
      matchLabels:
        key: value

Source Shape

Source is expected to be in the following shape:

(with ref sink)

apiVersion: group/version
kind: Kind
spec:
  sink:
    ref:
      apiVersion: group/version
      kind: AnAddressableKind
      name: a-name
  ceOverrides:
    extensions:
      key: value
status:
  observedGeneration: 1
  conditions:
    - type: Ready
      status: "True"
  sinkUri: http://host

(with uri sink)

apiVersion: group/version
kind: Kind
spec:
  sink:
    uri: http://host/path?query
  ceOverrides:
    extensions:
      key: value
status:
  observedGeneration: 1
  conditions:
    - type: Ready
      status: "True"
  sinkUri: http://host/path?query

(with ref and uri sink)

apiVersion: group/version
kind: Kind
spec:
  sink:
    ref:
      apiVersion: group/version
      kind: AnAddressableKind
      name: a-name
    uri: /path?query
  ceOverrides:
    extensions:
      key: value
status:
  observedGeneration: 1
  conditions:
    - type: Ready
      status: "True"
  sinkUri: http://host/path?query