# K8s
[data:image/s3,"s3://crabby-images/a0219/a021954c9e9fff6a41d84649e28f92a6bd5702f3" alt="Module Version"](https://hex.pm/packages/k8s)
[data:image/s3,"s3://crabby-images/e74d1/e74d1c9d32f838d41c4670000c7c383d5ff9f345" alt="Coverage Status"](https://coveralls.io/github/coryodaniel/k8s?branch=develop)
[data:image/s3,"s3://crabby-images/7d3f8/7d3f8f80528a2ffef1de50c1bf1d3aedeac583c9" alt="Last Updated"](https://github.com/coryodaniel/k8s/commits/develop)
[data:image/s3,"s3://crabby-images/4bf18/4bf18114987e66d313cea6fff3659740a95f0e2d" alt="Build Status CI"](https://github.com/coryodaniel/k8s/actions/workflows/ci.yaml)
[data:image/s3,"s3://crabby-images/3fa90/3fa909d5e358b32b3df2cb7c6f813983c0dd9fc9" alt="Build Status Elixir"](https://github.com/coryodaniel/k8s/actions/workflows/elixir_matrix.yaml)
[data:image/s3,"s3://crabby-images/7b8f8/7b8f8e2e150479bc8097fbcb601baa1915993458" alt="Build Status K8s"](https://github.com/coryodaniel/k8s/actions/workflows/k8s_matrix.yaml)
[data:image/s3,"s3://crabby-images/9b6db/9b6db7b2704213e584cc9930ef42bd36a0019b92" alt="Hex Docs"](https://hexdocs.pm/k8s/)
[data:image/s3,"s3://crabby-images/b3df1/b3df10e39caf72e24775b198bf49a255043edced" alt="Total Download"](https://hex.pm/packages/k8s)
[data:image/s3,"s3://crabby-images/bd5d6/bd5d637d807b0758fa7877f133cac05bfa9c93a5" alt="License"](https://github.com/coryodaniel/k8s/blob/develop/LICENSE)
[K8s](https://hexdocs.pm/k8s/usage.html) - Kubernetes API Client for Elixir
## Features
* A client API for humans đŠđŧđ§đŠđģđŠđŊđŠđžđ§đģđ§đŊđ§đ§đžđ¨đŧđ¨đžđ¨đŋ
* đŽ Kubernetes resources, groups, and CRDs are autodiscovered at boot time. No swagger file to include or override.
* Client supports standard HTTP calls, async batches, wait on status â˛ī¸, and watchers đ
* âī¸ HTTP Request middleware
* Multiple clusters â â â
* đ Multiple authentication credentials
* đ¤ serviceaccount
* token
* đ certificate
* auth-provider
* Pluggable auth providers!
* đ Tested against Kubernetes versions 1.10+ and master
* đ ī¸ CRD support
* đ Integrated with `:telemetry`
* âšī¸ Kubernetes resource and version helper functions
* 𧰠Kube config file parsing
* đī¸ Macro free; fast compile & fast startup
## Installation
The package can be installed by adding `:k8s` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:k8s, "~> 1.0"}
]
end
```
## Usage
Check out the [Usage Guide](https://hexdocs.pm/k8s/usage.html) for in-depth examples.
Most functions are also written using doctests.
* [K8s.Client doctests](https://hexdocs.pm/k8s/K8s.Client.html)
* [K8s.Conn doctests](https://hexdocs.pm/k8s/K8s.Conn.html)
* [K8s.Resource doctests](https://hexdocs.pm/k8s/K8s.Resource.html)
* [K8s.Version doctests](https://hexdocs.pm/k8s/K8s.Version.html)
If you are interested in building Kubernetes Operators or Schedulers, check out [Bonny](https://github.com/coryodaniel/bonny).
## tl;dr Examples
### Configure a cluster connection
Cluster connections can be created using the `K8s.Conn` module.
`K8s.Conn.from_file/1` will use the current context in your kubeconfig.
```elixir
{:ok, conn} = K8s.Conn.from_file("path/to/kubeconfig.yaml")
```
`K8s.Conn.from_file/2` accepts a keyword list to set the `:user`, `:cluster`, and/or `:context`
Connections can also be created in-cluster from a service account.
```elixir
{:ok, conn} = K8s.Conn.from_service_account("/path/to/service-account/directory")
```
Check out the [connection guide](https://hexdocs.pm/k8s/connections.html) for additional details.
### Creating a deployment
```elixir
{:ok, conn} = K8s.Conn.from_file("path/to/kubeconfig.yaml")
opts = [namespace: "default", name: "nginx", image: "nginx:nginx:1.7.9"]
{:ok, resource} = K8s.Resource.from_file("priv/deployment.yaml", opts)
operation = K8s.Client.create(resource)
{:ok, deployment} = K8s.Client.run(conn, operation)
```
### Listing deployments
In a namespace:
```elixir
{:ok, conn} = K8s.Conn.from_file("path/to/kubeconfig.yaml")
operation = K8s.Client.list("apps/v1", "Deployment", namespace: "prod")
{:ok, deployments} = K8s.Client.run(conn, operation)
```
Across all namespaces:
```elixir
{:ok, conn} = K8s.Conn.from_file("path/to/kubeconfig.yaml")
operation = K8s.Client.list("apps/v1", "Deployment", namespace: :all)
{:ok, deployments} = K8s.Client.run(conn, operation)
```
### Getting a deployment
```elixir
{:ok, conn} = K8s.Conn.from_file("path/to/kubeconfig.yaml")
operation = K8s.Client.get("apps/v1", :deployment, [namespace: "default", name: "nginx-deployment"])
{:ok, deployment} = K8s.Client.run(conn, operation)
```