ekristen/aws-nuke

View on GitHub
resources/eks-nodegroups.go

Summary

Maintainability
A
25 mins
Test Coverage
package resources

import (
    "context"

    "fmt"
    "time"

    "github.com/aws/aws-sdk-go/aws"
    "github.com/aws/aws-sdk-go/service/eks"

    "github.com/ekristen/libnuke/pkg/registry"
    "github.com/ekristen/libnuke/pkg/resource"
    "github.com/ekristen/libnuke/pkg/types"

    "github.com/ekristen/aws-nuke/v3/pkg/nuke"
)

const EKSNodegroupResource = "EKSNodegroup"

func init() {
    registry.Register(&registry.Registration{
        Name:     EKSNodegroupResource,
        Scope:    nuke.Account,
        Resource: &EKSNodegroup{},
        Lister:   &EKSNodegroupLister{},
        DeprecatedAliases: []string{
            "EKSNodegroups",
        },
    })
}

type EKSNodegroupLister struct{}

func (l *EKSNodegroupLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
    opts := o.(*nuke.ListerOpts)
    svc := eks.New(opts.Session)

    var clusterNames []*string
    var resources []resource.Resource

    clusterInputParams := &eks.ListClustersInput{
        MaxResults: aws.Int64(100),
    }

    // fetch all cluster names
    for {
        resp, err := svc.ListClusters(clusterInputParams)
        if err != nil {
            return nil, err
        }

        clusterNames = append(clusterNames, resp.Clusters...)

        if resp.NextToken == nil {
            break
        }

        clusterInputParams.NextToken = resp.NextToken
    }

    nodegroupsInputParams := &eks.ListNodegroupsInput{
        MaxResults: aws.Int64(100),
    }
    describeNodegroupInputParams := &eks.DescribeNodegroupInput{}

    // fetch the associated node groups
    for _, clusterName := range clusterNames {
        nodegroupsInputParams.ClusterName = clusterName
        describeNodegroupInputParams.ClusterName = clusterName

        for {
            resp, err := svc.ListNodegroups(nodegroupsInputParams)
            if err != nil {
                return nil, err
            }

            for _, nodegroupName := range resp.Nodegroups {
                describeNodegroupInputParams.NodegroupName = nodegroupName
                nodegroupDescriptionResponse, err := svc.DescribeNodegroup(describeNodegroupInputParams)
                if err != nil {
                    return nil, err
                }
                resources = append(resources, &EKSNodegroup{
                    svc:       svc,
                    nodegroup: nodegroupDescriptionResponse.Nodegroup,
                })
            }

            if resp.NextToken == nil {
                nodegroupsInputParams.NextToken = nil
                break
            }

            nodegroupsInputParams.NextToken = resp.NextToken
        }
    }

    return resources, nil
}

type EKSNodegroup struct {
    svc       *eks.EKS
    nodegroup *eks.Nodegroup
}

func (ng *EKSNodegroup) Remove(_ context.Context) error {
    _, err := ng.svc.DeleteNodegroup(&eks.DeleteNodegroupInput{
        ClusterName:   ng.nodegroup.ClusterName,
        NodegroupName: ng.nodegroup.NodegroupName,
    })
    return err
}

func (ng *EKSNodegroup) Properties() types.Properties {
    properties := types.NewProperties()
    properties.Set("Cluster", ng.nodegroup.ClusterName)
    properties.Set("Profile", ng.nodegroup.NodegroupName)
    if ng.nodegroup.CreatedAt != nil {
        properties.Set("CreatedAt", ng.nodegroup.CreatedAt.Format(time.RFC3339))
    }
    for k, v := range ng.nodegroup.Tags {
        properties.SetTag(&k, v)
    }
    return properties
}

func (ng *EKSNodegroup) String() string {
    return fmt.Sprintf("%s:%s", *ng.nodegroup.ClusterName, *ng.nodegroup.NodegroupName)
}