krucible-go-client

module
v0.1.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 16, 2020 License: Apache-2.0

README

Krucible Go Client

This is the Go client for Krucible, the platform for creating ephemeral Kubernetes clusters optimised for testing and development.

Installation

The Krucible Go client is built using Go modules and thus that is the recommended way of including the Krucible client into your project.

go get github.com/Krucible/krucible-go-client

Usage

To get started, import the krucible package and create a client:

import "github.com/Krucible/krucible-go-client/krucible"

client := krucible.NewClient(krucible.ClientConfig{
	AccountID:    "4ad69a63-bb6c-49a8-9c6f-6a166fb5acff",
	APIKeyId:     "146d98c4-327d-4a2d-b85a-49590246e136",
	APIKeySecret: "0da8afd2911904aa9bad8862a3e7478a",
})
Creating a cluster

You should then be able to create new Krucible clusters with CreateCluster:

cluster, clientset, err := client.CreateCluster(krucible.CreateClusterConfig{
	DisplayName: "my-krucible-cluster",
})

CreateCluster returns a krucible.Cluster struct, containing metadata about your cluster, and a kubernetes.Clientset that is set up to connect to the new cluster.

Getting the cluster expiry time:

fmt.Println(cluster.ExpiresAt)

Listing the pods in the default namespace:

pods, err := clientset.CoreV1().
	Pods("default").
	List(
		context.Background(),
		metav1.ListOptions{},
	)
Getting a cluster

Get existing clusters with GetCluster:

cluster, err = client.GetCluster("51b831d4-a9d6-4489-913e-6df70fcc8ea8")

Here cluster is a krucible.Cluster struct, containing metadata about the cluster.

Getting a cluster clientset

Get a Kubernetes client-go Clientset, configured to connect to a given cluster:

cs, err := client.GetClusterClientset("51b831d4-a9d6-4489-913e-6df70fcc8ea8")

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL