Skip to content

Commit

Permalink
Merge pull request #320 from ekristen/rebuy-876
Browse files Browse the repository at this point in the history
feat(resource): add ecs capacity provider
  • Loading branch information
ekristen authored Sep 26, 2024
2 parents ca740fa + ca82c3a commit 3ad9974
Showing 1 changed file with 98 additions and 0 deletions.
98 changes: 98 additions & 0 deletions resources/ecs-capacity-provider.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
package resources

import (
"context"
"fmt"

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

"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 ECSCapacityProviderResource = "ECSCapacityProvider"

func init() {
registry.Register(&registry.Registration{
Name: ECSCapacityProviderResource,
Scope: nuke.Account,
Lister: &ECSCapacityProviderLister{},
})
}

type ECSCapacityProvider struct {
svc *ecs.ECS
ARN *string
Name *string
Status *string
Tags []*ecs.Tag
}

func (r *ECSCapacityProvider) Remove(_ context.Context) error {
_, err := r.svc.DeleteCapacityProvider(&ecs.DeleteCapacityProviderInput{
CapacityProvider: r.ARN,
})

return err
}

func (r *ECSCapacityProvider) Filter() error {
// The FARGATE and FARGATE_SPOT capacity providers cannot be deleted
if *r.Name == "FARGATE" || *r.Name == "FARGATE_SPOT" {
return fmt.Errorf("unable to delete, fargate managed")
}

return nil
}

func (r *ECSCapacityProvider) String() string {
return *r.ARN
}

func (r *ECSCapacityProvider) Properties() types.Properties {
return types.NewPropertiesFromStruct(r)
}

//---------------------------------------

type ECSCapacityProviderLister struct{}

func (l *ECSCapacityProviderLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
opts := o.(*nuke.ListerOpts)
var resources []resource.Resource

svc := ecs.New(opts.Session)

params := &ecs.DescribeCapacityProvidersInput{
MaxResults: aws.Int64(100),
}

for {
output, err := svc.DescribeCapacityProviders(params)
if err != nil {
return nil, err
}

for _, capacityProviders := range output.CapacityProviders {
resources = append(resources, &ECSCapacityProvider{
svc: svc,
ARN: capacityProviders.CapacityProviderArn,
Name: capacityProviders.Name,
Status: capacityProviders.Status,
Tags: capacityProviders.Tags,
})
}

if output.NextToken == nil {
break
}

params.NextToken = output.NextToken
}

return resources, nil
}

0 comments on commit 3ad9974

Please sign in to comment.