Skip to content

Krucible/krucible-go-client

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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")