resources/eks-nodegroups.go
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(®istry.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)
}