driftctl/enumeration/remote/aws/vpc_security_group_enumerat...

49 lines
1.3 KiB
Go

package aws
import (
"github.com/snyk/driftctl/enumeration/remote/aws/repository"
remoteerror "github.com/snyk/driftctl/enumeration/remote/error"
"github.com/snyk/driftctl/enumeration/resource"
resourceaws "github.com/snyk/driftctl/enumeration/resource/aws"
"github.com/aws/aws-sdk-go/aws"
)
type VPCSecurityGroupEnumerator struct {
repository repository.EC2Repository
factory resource.ResourceFactory
}
func NewVPCSecurityGroupEnumerator(repo repository.EC2Repository, factory resource.ResourceFactory) *VPCSecurityGroupEnumerator {
return &VPCSecurityGroupEnumerator{
repo,
factory,
}
}
func (e *VPCSecurityGroupEnumerator) SupportedType() resource.ResourceType {
return resourceaws.AwsSecurityGroupResourceType
}
func (e *VPCSecurityGroupEnumerator) Enumerate() ([]*resource.Resource, error) {
securityGroups, _, err := e.repository.ListAllSecurityGroups()
if err != nil {
return nil, remoteerror.NewResourceListingError(err, string(e.SupportedType()))
}
results := make([]*resource.Resource, 0, len(securityGroups))
for _, item := range securityGroups {
results = append(
results,
e.factory.CreateAbstractResource(
string(e.SupportedType()),
aws.StringValue(item.GroupId),
map[string]interface{}{},
),
)
}
return results, nil
}