package aws import ( "fmt" "github.com/snyk/driftctl/enumeration/alerter" "github.com/snyk/driftctl/enumeration/remote/alerts" "github.com/snyk/driftctl/enumeration/remote/aws/repository" "github.com/snyk/driftctl/enumeration/remote/common" remoteerror "github.com/snyk/driftctl/enumeration/remote/error" tf "github.com/snyk/driftctl/enumeration/remote/terraform" "github.com/sirupsen/logrus" "github.com/snyk/driftctl/enumeration/resource" "github.com/snyk/driftctl/enumeration/resource/aws" ) type S3BucketMetricsEnumerator struct { repository repository.S3Repository factory resource.ResourceFactory providerConfig tf.TerraformProviderConfig alerter alerter.AlerterInterface } func NewS3BucketMetricsEnumerator(repo repository.S3Repository, factory resource.ResourceFactory, providerConfig tf.TerraformProviderConfig, alerter alerter.AlerterInterface) *S3BucketMetricsEnumerator { return &S3BucketMetricsEnumerator{ repository: repo, factory: factory, providerConfig: providerConfig, alerter: alerter, } } func (e *S3BucketMetricsEnumerator) SupportedType() resource.ResourceType { return aws.AwsS3BucketMetricResourceType } func (e *S3BucketMetricsEnumerator) Enumerate() ([]*resource.Resource, error) { buckets, err := e.repository.ListAllBuckets() if err != nil { return nil, remoteerror.NewResourceListingErrorWithType(err, string(e.SupportedType()), aws.AwsS3BucketResourceType) } results := make([]*resource.Resource, 0, len(buckets)) for _, bucket := range buckets { region, err := e.repository.GetBucketLocation(*bucket.Name) if err != nil { alerts.SendEnumerationAlert(common.RemoteAWSTerraform, e.alerter, remoteerror.NewResourceScanningError(err, string(e.SupportedType()), *bucket.Name)) continue } if region == "" || region != e.providerConfig.DefaultAlias { logrus.WithFields(logrus.Fields{ "region": region, "bucket": *bucket.Name, }).Debug("Skipped bucket") continue } metricsConfigurationList, err := e.repository.ListBucketMetricsConfigurations(bucket, region) if err != nil { return nil, remoteerror.NewResourceListingError(err, string(e.SupportedType())) } for _, metric := range metricsConfigurationList { id := fmt.Sprintf("%s:%s", *bucket.Name, *metric.Id) results = append( results, e.factory.CreateAbstractResource( string(e.SupportedType()), id, map[string]interface{}{ "region": region, }, ), ) } } return results, nil }