driftctl/pkg/middlewares/aws_default_vpc.go

54 lines
1.3 KiB
Go
Raw Normal View History

2020-12-15 10:07:03 +00:00
package middlewares
import (
"github.com/sirupsen/logrus"
2021-12-06 13:29:39 +00:00
"github.com/snyk/driftctl/pkg/resource"
"github.com/snyk/driftctl/pkg/resource/aws"
2020-12-15 10:07:03 +00:00
)
// Default VPC should not be shown as unmanaged as they are present by default
// This middleware ignores default VPC from unmanaged resources if they are not managed by IaC
2020-12-15 10:07:03 +00:00
type AwsDefaultVPC struct{}
func NewAwsDefaultVPC() AwsDefaultVPC {
return AwsDefaultVPC{}
}
2021-08-09 14:03:04 +00:00
func (m AwsDefaultVPC) Execute(remoteResources, resourcesFromState *[]*resource.Resource) error {
2020-12-15 10:07:03 +00:00
2021-08-09 14:03:04 +00:00
newRemoteResources := make([]*resource.Resource, 0)
2020-12-15 10:07:03 +00:00
for _, remoteResource := range *remoteResources {
existInState := false
// Ignore all resources other than default VPC
if remoteResource.ResourceType() != aws.AwsDefaultVpcResourceType {
2020-12-15 10:07:03 +00:00
newRemoteResources = append(newRemoteResources, remoteResource)
continue
}
for _, stateResource := range *resourcesFromState {
2021-08-09 14:03:04 +00:00
if remoteResource.Equal(stateResource) {
2020-12-15 10:07:03 +00:00
existInState = true
break
}
}
if existInState {
newRemoteResources = append(newRemoteResources, remoteResource)
}
if !existInState {
logrus.WithFields(logrus.Fields{
"id": remoteResource.ResourceId(),
"type": remoteResource.ResourceType(),
2020-12-15 10:07:03 +00:00
}).Debug("Ignoring default VPC as it is not managed by IaC")
}
}
*remoteResources = newRemoteResources
return nil
}