package aws import ( "github.com/aws/aws-sdk-go/service/iam" "github.com/cloudskiff/driftctl/pkg/remote/aws/repository" remoteerror "github.com/cloudskiff/driftctl/pkg/remote/error" "github.com/cloudskiff/driftctl/pkg/resource" resourceaws "github.com/cloudskiff/driftctl/pkg/resource/aws" "github.com/cloudskiff/driftctl/pkg/terraform" "github.com/sirupsen/logrus" "github.com/zclconf/go-cty/cty" ) type IamPolicySupplier struct { reader terraform.ResourceReader deserializer *resource.Deserializer repository repository.IAMRepository runner *terraform.ParallelResourceReader } func NewIamPolicySupplier(provider *AWSTerraformProvider, deserializer *resource.Deserializer, repository repository.IAMRepository) *IamPolicySupplier { return &IamPolicySupplier{ provider, deserializer, repository, terraform.NewParallelResourceReader(provider.Runner().SubRunner()), } } func (s *IamPolicySupplier) Resources() ([]resource.Resource, error) { policies, err := s.repository.ListAllPolicies() if err != nil { return nil, remoteerror.NewResourceEnumerationError(err, resourceaws.AwsIamPolicyResourceType) } results := make([]cty.Value, 0) if len(policies) > 0 { for _, policy := range policies { u := *policy s.runner.Run(func() (cty.Value, error) { return s.readPolicy(&u) }) } results, err = s.runner.Wait() if err != nil { return nil, err } } return s.deserializer.Deserialize(resourceaws.AwsIamPolicyResourceType, results) } func (s *IamPolicySupplier) readPolicy(resource *iam.Policy) (cty.Value, error) { res, err := s.reader.ReadResource( terraform.ReadResourceArgs{ Ty: resourceaws.AwsIamPolicyResourceType, ID: *resource.Arn, }, ) if err != nil { logrus.Warnf("Error reading iam policy %s[%s]: %+v", *resource.Arn, resourceaws.AwsIamPolicyResourceType, err) return cty.NilVal, err } return *res, nil }