2018-01-09 18:57:14 +00:00
|
|
|
# Kubernetes's OpenAPI Specification
|
|
|
|
|
2018-11-26 18:23:56 +00:00
|
|
|
This folder contains an [OpenAPI specification](https://github.com/OAI/OpenAPI-Specification) for Kubernetes API.
|
2018-01-09 18:57:14 +00:00
|
|
|
|
|
|
|
## Vendor Extensions
|
|
|
|
|
2018-03-06 22:33:18 +00:00
|
|
|
Kubernetes extends OpenAPI using these extensions. Note the version that
|
2018-01-09 18:57:14 +00:00
|
|
|
extensions has been added.
|
|
|
|
|
|
|
|
### `x-kubernetes-group-version-kind`
|
|
|
|
|
|
|
|
Operations and Definitions may have `x-kubernetes-group-version-kind` if they
|
|
|
|
are associated with a [kubernetes resource](https://github.com/kubernetes/community/blob/master/contributors/devel/api-conventions.md#resources).
|
|
|
|
|
|
|
|
|
|
|
|
For example:
|
|
|
|
|
|
|
|
``` json
|
|
|
|
"paths": {
|
|
|
|
...
|
|
|
|
"/api/v1/namespaces/{namespace}/pods/{name}": {
|
|
|
|
...
|
|
|
|
"get": {
|
|
|
|
...
|
|
|
|
"x-kubernetes-group-version-kind": {
|
|
|
|
"group": "",
|
|
|
|
"version": "v1",
|
|
|
|
"kind": "Pod"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### `x-kubernetes-action`
|
|
|
|
|
|
|
|
Operations and Definitions may have `x-kubernetes-action` if they
|
|
|
|
are associated with a [kubernetes resource](https://github.com/kubernetes/community/blob/master/contributors/devel/api-conventions.md#resources).
|
|
|
|
Action can be one of `get`, `list`, `put`, `patch`, `post`, `delete`, `deletecollection`, `watch`, `watchlist`, `proxy`, or `connect`.
|
|
|
|
|
|
|
|
|
|
|
|
For example:
|
|
|
|
|
|
|
|
``` json
|
|
|
|
"paths": {
|
|
|
|
...
|
|
|
|
"/api/v1/namespaces/{namespace}/pods/{name}": {
|
|
|
|
...
|
|
|
|
"get": {
|
|
|
|
...
|
|
|
|
"x-kubernetes-action": "list"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### `x-kubernetes-patch-strategy` and `x-kubernetes-patch-merge-key`
|
|
|
|
|
|
|
|
Some of the definitions may have these extensions. For more information about PatchStrategy and PatchMergeKey see
|
2018-03-06 22:33:18 +00:00
|
|
|
[strategic-merge-patch](https://git.k8s.io/community/contributors/devel/strategic-merge-patch.md).
|