Skip to content

Standalone program to fetch authentication tokens for AWS EKS Clusters

License

Notifications You must be signed in to change notification settings

lyuzizheng/eks-auth

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

eks-auth

Standalone program to fetch authentication tokens for AWS EKS Clusters

Description

This is a standalone program to fetch authentication tokens for AWS EKS Clusters. It functions in much the same way as aws eks get-token and supports similar arguments.

Under the hood it uses the AWS Go SDK v2 and will respect certain environment variables such as AWS_REGION, AWS_PROFILE, and other variables related to authentication.

  1. This is useful for using tools such as Atlantis. When running terraform with pre-generated plans (such as in Atlantis), using exec for authentication is preferred over fetching a token with the aws_eks_cluster_auth data source since the latter will only fetch a short-lived token during the plan phase, which may be expired by the time the apply is executed.

  2. Fits for container eks authentication using `user.exec`` inside the kubeconfig, a typical usage is including this binary inside your image and make it an executable, follow the usage tutorial below

This was created as a ligher-weight alternative to installing the AWS cli, along with a Python interpreter, in an Docker image when the only feature of the CLI being used is EKS authentication.

Installation

  1. Download the approptiate tar.gz file for your platform from the Releases page and extract it. Copy the binary eks-auth to a location in your $PATH.
  2. Directly use this command in your dockerfile during build stage
# Dockerfile
RUN curl -L https://github.com/Brabalawuka/eks-auth/releases/download/v0.0.2/eks-auth -o /usr/local/bin/eks-auth
RUN chmod +x /usr/local/bin/eks-auth

Usage

You must already be authenticated to AWS, or have appropriate environment variables configured to allow for authentication to take place. For details see the documentation for the AWS SDK for Go V2.

To obtain an authentication token, simply execute eks-auth passing the name of the cluster to authenticate to:

eks-auth --cluster-name <my-cluster>

Additionally, it is possible to assume another IAM role to perform the authentication, or adding a region

eks-auth --cluster-name my-cluster --role-arn arn:aws:iam::123456789012:role/cluster-admin-role --region us-east-1

Your current role must have the appropriate permissions necessary to assume the role specified by --role-arn. This role will also be used to sign the generated token.

Terraform example

Here is an example of how to initialize the kubernetes Terraform provider using this program. The eks-auth binary must be accessible in the $PATH where terraform is run (such as /usr/bin in an Atlantis Docker image).

data "aws_eks_cluster" "cluster" {
  name = "my-cluster"
}

provider "kubernetes" {
  host                   = data.aws_eks_cluster.cluster.endpoint
  cluster_ca_certificate = data.aws_eks_cluster.cluster.certificate_authority[0].data
  exec {
    api_version = "client.authentication.k8s.io/v1beta1"
    args        = ["--cluster-name", data.aws_eks_cluster.cluster.id]
    command     = "eks-auth"
  }
}

Kubeconfig Example

Alterntively, for triggering this inside a kubeconfig that you container is using, as specified by the kubernetes authentication methods, you may do the follow:

# other configs
users:
  - name: xxxxx
    user:
      exec:
        apiVersion: client.authentication.k8s.io/v1beta1
        args:
          - --region
          - ap-northeast-1
          - --cluster-name
          - my-k8s-cluster
          - --role
          - arn:aws:iam::xxxxxxx
        command: eks-auth
        env: null

Other providers, such as Helm similarly support exec authentication.

About

Standalone program to fetch authentication tokens for AWS EKS Clusters

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 100.0%