Dagger
Search

kubectl

The goal of this module is to be the one stop shop for interacting with a kubernetes cluster. The main challenge when doing this is how authentication is done against the cluster. Eventually this module should support all most used methods. Each top level method is in charge of creating a container with all the tools and credentials ready to go for kubectl commands to be executed. For an example on how this is implemented you can check out the `KubectlEks` method.

Installation

dagger install github.com/matipan/daggerverse/kubectl@v0.0.1

Entrypoint

Return Type
Kubectl !
Arguments
NameTypeDefault ValueDescription
kubeconfigFile !-No description provided
Example
dagger -m github.com/matipan/daggerverse/kubectl@81eaa2f85e75ed348ba99eaace27a95a37eb119c call \
 --kubeconfig file:path
func (m *myModule) example(kubeconfig *File) *Kubectl  {
	return dag.
			Kubectl(kubeconfig)
}
@function
def example(kubeconfig: dagger.File) -> dag.Kubectl:
	return (
		dag.kubectl(kubeconfig)
	)
@func()
example(kubeconfig: File): Kubectl {
	return dag
		.kubectl(kubeconfig)
}

Types

Kubectl 🔗

kubeconfig() 🔗

Return Type
File !
Example
dagger -m github.com/matipan/daggerverse/kubectl@81eaa2f85e75ed348ba99eaace27a95a37eb119c call \
 --kubeconfig file:path kubeconfig
func (m *myModule) example(kubeconfig *File) *File  {
	return dag.
			Kubectl(kubeconfig).
			Kubeconfig()
}
@function
def example(kubeconfig: dagger.File) -> dagger.File:
	return (
		dag.kubectl(kubeconfig)
		.kubeconfig()
	)
@func()
example(kubeconfig: File): File {
	return dag
		.kubectl(kubeconfig)
		.kubeconfig()
}

kubectlEks() 🔗

KubectlEks returns a KubectlCLI with aws-iam-authenticator and AWS credentials configured to communicate with an EKS cluster.

Return Type
Cli !
Arguments
NameTypeDefault ValueDescription
awsConfigFile -No description provided
awsCredsFile !-No description provided
awsProfileString !-No description provided
Example
dagger -m github.com/matipan/daggerverse/kubectl@81eaa2f85e75ed348ba99eaace27a95a37eb119c call \
 --kubeconfig file:path kubectl-eks --aws-creds file:path --aws-profile string
func (m *myModule) example(kubeconfig *File, awsCreds *File, awsProfile string) *KubectlCli  {
	return dag.
			Kubectl(kubeconfig).
			KubectlEks(awsCreds, awsProfile)
}
@function
def example(kubeconfig: dagger.File, aws_creds: dagger.File, aws_profile: str) -> dag.KubectlCli:
	return (
		dag.kubectl(kubeconfig)
		.kubectl_eks(aws_creds, aws_profile)
	)
@func()
example(kubeconfig: File, awsCreds: File, awsProfile: string): KubectlCli {
	return dag
		.kubectl(kubeconfig)
		.kubectlEks(awsCreds, awsProfile)
}

Cli 🔗

KubectlCLI is a child module that holds a Container that should already be configured to talk to a k8s cluster.

container() 🔗

Return Type
Container !
Example
dagger -m github.com/matipan/daggerverse/kubectl@81eaa2f85e75ed348ba99eaace27a95a37eb119c call \
 kubectl-eks --aws-creds file:path --aws-profile string \
 container
func (m *myModule) example(awsCreds *File, awsProfile string) *Container  {
	return dag.
			Kubectl().
			KubectlEks(awsCreds, awsProfile).
			Container()
}
@function
def example(aws_creds: dagger.File, aws_profile: str) -> dagger.Container:
	return (
		dag.kubectl()
		.kubectl_eks(aws_creds, aws_profile)
		.container()
	)
@func()
example(awsCreds: File, awsProfile: string): Container {
	return dag
		.kubectl()
		.kubectlEks(awsCreds, awsProfile)
		.container()
}

exec() 🔗

Exec runs the specified kubectl command. NOTE: kubectl should be specified as part of the cmd variable. For example, to list pods: [“get”, “pods”, “-n”, “namespace”]

Return Type
String !
Arguments
NameTypeDefault ValueDescription
cmd[String ! ] !-No description provided
Example
dagger -m github.com/matipan/daggerverse/kubectl@81eaa2f85e75ed348ba99eaace27a95a37eb119c call \
 kubectl-eks --aws-creds file:path --aws-profile string \
 exec --cmd string1 --cmd string2
func (m *myModule) example(ctx context.Context, awsCreds *File, awsProfile string, cmd []string) string  {
	return dag.
			Kubectl().
			KubectlEks(awsCreds, awsProfile).
			Exec(ctx, cmd)
}
@function
async def example(aws_creds: dagger.File, aws_profile: str, cmd: List[str]) -> str:
	return await (
		dag.kubectl()
		.kubectl_eks(aws_creds, aws_profile)
		.exec(cmd)
	)
@func()
async example(awsCreds: File, awsProfile: string, cmd: string[]): Promise<string> {
	return dag
		.kubectl()
		.kubectlEks(awsCreds, awsProfile)
		.exec(cmd)
}

debugSh() 🔗

DebugSh is a helper function that developers can use to get a terminal into the container where the commands are run and troubleshoot potential misconfigurations. For example: dagger call –kubeconfig kubeconfig.yaml kubectl-eks –aws-creds ~/.aws/credentials –aws-profile “example” –aws-config ~/.aws/config debug-sh terminal

Return Type
Container !
Example
dagger -m github.com/matipan/daggerverse/kubectl@81eaa2f85e75ed348ba99eaace27a95a37eb119c call \
 kubectl-eks --aws-creds file:path --aws-profile string \
 debug-sh
func (m *myModule) example(awsCreds *File, awsProfile string) *Container  {
	return dag.
			Kubectl().
			KubectlEks(awsCreds, awsProfile).
			DebugSh()
}
@function
def example(aws_creds: dagger.File, aws_profile: str) -> dagger.Container:
	return (
		dag.kubectl()
		.kubectl_eks(aws_creds, aws_profile)
		.debug_sh()
	)
@func()
example(awsCreds: File, awsProfile: string): Container {
	return dag
		.kubectl()
		.kubectlEks(awsCreds, awsProfile)
		.debugSh()
}