Skip to content

Commit

Permalink
Merge pull request #26 from oreillymedia/CL-869-glue-security-config
Browse files Browse the repository at this point in the history
Add module to handle Glue security configurations
  • Loading branch information
gsoria authored May 29, 2024
2 parents 2d84fb6 + 9517b36 commit fca7b90
Showing 1 changed file with 68 additions and 0 deletions.
68 changes: 68 additions & 0 deletions resources/glue-securityconfigurations.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
package resources

import (
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/glue"
"github.com/rebuy-de/aws-nuke/v2/pkg/types"
)

type GlueSecurityConfiguration struct {
svc *glue.Glue
name *string
}

func init() {
register("GlueSecurityConfiguration", ListGlueSecurityConfigurations)
}

func ListGlueSecurityConfigurations(sess *session.Session) ([]Resource, error) {
svc := glue.New(sess)
resources := []Resource{}

params := &glue.GetSecurityConfigurationsInput{
MaxResults: aws.Int64(25),
}

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

for _, securityConfiguration := range output.SecurityConfigurations {
resources = append(resources, &GlueSecurityConfiguration{
svc: svc,
name: securityConfiguration.Name,
})
}

// Check if there are more security configurations to fetch
if output.NextToken == nil || *output.NextToken == "" {
break
}

params.NextToken = output.NextToken
}

return resources, nil
}

func (f *GlueSecurityConfiguration) Remove() error {
_, err := f.svc.DeleteSecurityConfiguration(&glue.DeleteSecurityConfigurationInput{
Name: f.name,
})

return err
}

func (f *GlueSecurityConfiguration) Properties() types.Properties {
properties := types.NewProperties()
properties.Set("Name", f.name)

return properties
}

func (f *GlueSecurityConfiguration) String() string {
return *f.name
}

0 comments on commit fca7b90

Please sign in to comment.