v0.5.0
REST focused Typescript classes for Kubernetes APIs, and tools for generating API interfaces
Repository
Current version released
a year ago
/x/kubernetes_apis
Purpose
Generated, typed interfaces to make every possible Kubernetes API request and work with richer data structures.
Actual request transports implemented in /x/kubernetes_client
.
Usage
Hereās a basic request, listing all Pods in the default
namespace.
It uses the autoDetectClient()
entrypoint which returns the first usable client.
import { autoDetectClient } from 'https://deno.land/x/kubernetes_client@v0.7.0/mod.ts';
import { CoreV1Api } from 'https://deno.land/x/kubernetes_apis/builtin/core@v1/mod.ts';
const kubernetes = await autoDetectClient();
const coreApi = new CoreV1Api(kubernetes).namespace("default");
const podList = await coreApi.getPodList();
console.log(podList);
// see files in examples/ for more API demos (watching, creation, etc)
When running locally (with kubectl
set up), you probably just to add --allow-run=kubectl
to run this.
For a container being deployed onto a cluster, thereās more flags to provide instead;
see /x/kubernetes_client
for more information.
Changelog
v0.5.0
on2023-08-19
:- Updating
/x/kubernetes_client
API contract tov0.7.0
. - Actually implement PodExec, PodAttach, PodPortForward APIs with a new tunnel implementation.
- Includes ābuiltinā APIs generated from K8s
v1.28.0
.- New APIs:
admissionregistration.k8s.io/v1beta1
,certificates.k8s.io/v1alpha1
. - Also, API additions for sidecar containers and
SelfSubjectReview
.
- New APIs:
- Fix several structures incorrectly typed as
{}
instead ofJSONValue
.
- Updating
v0.4.0
on2023-02-10
:- Updating
/x/kubernetes_client
API contract tov0.5.0
. - Breaking change: The return type of delete functions has been widened to a union.
- If you were using a deletion response, you can use type narrowing to detect which Kind was returned.
- See #4 for more information.
- Includes ābuiltinā APIs generated from K8s
v1.26.1
.- Numerous alpha and beta APIs removed, including autoscaling, batch, and policy
- Further API changes are detailed in Github Releases.
cert-manager
CRDs have been updated. Removes v1beta1, v1alpha3, and v1alpha2 APIs.argo-cd
CRDs have been updated. Adds a newApplicationSet
CRD.- Some nested structures were deduplicated to reduce code size.
- Added CRDs for Vertical Pod Autoscaler.
- Add
streamPodLogs
to allow fetching pod logs as aReadableStream<string>
.
- Updating
v0.3.2
on2021-12-02
:- Updating
/x/kubernetes_client
API contract tov0.3.2
. - Includes ābuiltinā APIs generated from K8s
v1.22.4
.- Numerous
v1beta1
API versions were removed in favor of stablev1
APIs. - Further API changes are detailed in Github Releases.
- Numerous
cert-manager
andexternal-dns
CRDs have been updated from the latest releases.- Added CRDs for
argo-cd
.
- Updating
v0.3.1
on2021-05-09
:- Updating
/x/kubernetes_client
API contract tov0.2.4
. - Includes ābuiltinā APIs generated from K8s
v1.21.0
.get
functions no longer acceptexport
orexact
.
cert-manager
andexternal-dns
CRDs have been updated from the latest releases.
- Updating
v0.3.0
on2021-02-28
:- Updating
/x/kubernetes_client
API contract tov0.2.0
.- Breaking change!
- If you import
autoDetectClient
and other client APIs from thiscommon.ts
, those now come fromclient.ts
instead (or just import/x/kubernetes_client
yourself). - This upstream release vastly improves cluster client detection logic.
- Now handles v1.Status error payloads when processing any response body.
- Added shebang and execute bit to every script in
examples/
. - Optimized redundencies out of cert-manager structures (half the file size now)
- Updating
v0.2.0
on2020-12-29
:- Includes ābuiltinā APIs generated from K8s
v1.20
. - Patching and deletion is more stable; mistype error messages are vastly improved.
- ApiExtensions and ApiRegistration groups are now included.
- Updating
/x/kubernetes_client
API contract tov0.1.2
. - Reflector implementation has been moved up to
/x/kubernetes_client
. - Coreās proxy endpoints (Node/Pod/Service) are now implemented and usable.
- CRDs are now generated from original YAML instead of from a clusterās generated APIs.
- cert-managerās CRDs have been updated to
v1
and external-dnsās CRDs also added.
- Includes ābuiltinā APIs generated from K8s
v0.1.0
on2020-11-17
:- Initial release, with ābuiltinā APIs generated from K8s
v1.19
. - Thereās still a fair amount of TODOs for particular resources, and structure types.
- A workable Reflector implementation is included.
- cert-managerās CRDs have a generated client as well, as an experiment.
- Initial release, with ābuiltinā APIs generated from K8s
TODO
- PATCH requests
- Solidify Quantity, Duration, etc
- Reconcile deletion response kinds (might still be fallout)
- Story for generating API clients directly from CRD specifications
- Story for generating the whole API surface of a specific cluster
- Move Reflector implementation upstream to
/x/kubernetes_client