Documentation ¶
Index ¶
- Constants
- Variables
- func DescribeDefaultSecurityGroups(svc ec2iface.EC2API) ([]string, error)
- func GetDefaultVpcId(vpc Vpc) (string, error)
- func GetEC2ResourceNameTagValue(tags []*ec2.Tag) (string, error)
- func GetEc2ServiceClient(region string) ec2iface.EC2API
- func GetEnabledRegions() ([]string, error)
- func GetTargetRegions(enabledRegions []string, selectedRegions []string, excludedRegions []string) ([]string, error)
- func IsNukeable(resourceType string, resourceTypes []string) bool
- func IsValidResourceType(resourceType string, allResourceTypes []string) bool
- func ListResourceTypes() []string
- func NukeAllResources(account *AwsAccountResources, regions []string) error
- func NukeDefaultSecurityGroupRules(sgs []DefaultSecurityGroup) error
- func NukeVpcs(vpcs []Vpc) error
- type ACMPCA
- type AMIs
- type ASGroups
- type AccessAnalyzer
- type AwsAccountResources
- type AwsRegionResource
- type AwsResources
- type CloudWatchDashboards
- type CloudWatchLogGroups
- type DBClusters
- type DBInstances
- type DefaultSecurityGroup
- type DynamoDB
- type EBSVolumes
- type EC2Instances
- type EC2VPCs
- type ECSClusters
- type ECSServices
- type EIPAddresses
- type EKSClusters
- type Elasticaches
- type ElbDeleteError
- type IAMUsers
- type ImageAvailableError
- type KmsCheckIncludeResult
- type KmsCustomerKeys
- type LambdaDeleteError
- type LambdaFunctions
- type LaunchConfigs
- type LoadBalancers
- type LoadBalancersV2
- type NatGateways
- type OIDCProviders
- type OpenSearchDomains
- type RdsDeleteError
- type S3Bucket
- type S3Buckets
- func (bucket S3Buckets) MaxBatchSize() int
- func (bucket S3Buckets) MaxConcurrentGetSize() int
- func (bucket S3Buckets) Nuke(session *session.Session, identifiers []string) error
- func (bucket S3Buckets) ObjectMaxBatchSize() int
- func (bucket S3Buckets) ResourceIdentifiers() []string
- func (bucket S3Buckets) ResourceName() string
- type SecretsManagerSecrets
- type Snapshots
- type SqsQueue
- type TooManyAccessAnalyzersErr
- type TooManyCloudWatchDashboardsErr
- type TooManyEKSClustersErr
- type TooManyLogGroupsErr
- type TooManyNatErr
- type TooManyOIDCProvidersErr
- type TooManyOpenSearchDomainsErr
- type TransitGateways
- type TransitGatewaysRouteTables
- type TransitGatewaysVpcAttachment
- type VPCEndpointDeleteTimeoutError
- type Vpc
Constants ¶
const AwsResourceExclusionTagKey = "cloud-nuke-excluded"
const (
GlobalRegion string = "global"
)
Variables ¶
var GovCloudRegions = []string{
"us-gov-east-1",
"us-gov-west-1",
}
GovCloudRegions contains all of the U.S. GovCloud regions. In accounts with GovCloud enabled, these are the only available regions.
var OptInNotRequiredRegions = []string{
"eu-north-1",
"ap-south-1",
"eu-west-3",
"eu-west-2",
"eu-west-1",
"ap-northeast-3",
"ap-northeast-2",
"ap-northeast-1",
"sa-east-1",
"ca-central-1",
"ap-southeast-1",
"ap-southeast-2",
"eu-central-1",
"us-east-1",
"us-east-2",
"us-west-1",
"us-west-2",
}
OptInNotRequiredRegions contains all regions that are enabled by default on new AWS accounts Beginning in Spring 2019, AWS requires new regions to be explicitly enabled See https://aws.amazon.com/blogs/security/setting-permissions-to-enable-accounts-for-upcoming-aws-regions/
Functions ¶
func DescribeDefaultSecurityGroups ¶ added in v0.1.8
func GetDefaultVpcId ¶ added in v0.1.8
func GetEC2ResourceNameTagValue ¶ added in v0.11.2
Given an slice of tags, return the value of the Name tag
func GetEc2ServiceClient ¶ added in v0.1.8
func GetEnabledRegions ¶ added in v0.1.8
GetEnabledRegions - Get all regions that are enabled (DescribeRegions excludes those not enabled by default)
func GetTargetRegions ¶ added in v0.1.11
func GetTargetRegions(enabledRegions []string, selectedRegions []string, excludedRegions []string) ([]string, error)
GetTargetRegions - Used enabled, selected and excluded regions to create a final list of valid regions
func IsNukeable ¶ added in v0.1.9
IsNukeable - Checks if we should nuke a resource or not
func IsValidResourceType ¶ added in v0.1.9
IsValidResourceType - Checks if a resourceType is valid or not
func ListResourceTypes ¶ added in v0.1.9
func ListResourceTypes() []string
ListResourceTypes - Returns list of resources which can be passed to --resource-type
func NukeAllResources ¶
func NukeAllResources(account *AwsAccountResources, regions []string) error
NukeAllResources - Nukes all aws resources
func NukeDefaultSecurityGroupRules ¶ added in v0.1.8
func NukeDefaultSecurityGroupRules(sgs []DefaultSecurityGroup) error
Types ¶
type ACMPCA ¶ added in v0.5.0
type ACMPCA struct {
ARNs []string
}
ACMPA - represents all ACMPA
func (ACMPCA) MaxBatchSize ¶ added in v0.5.0
func (ACMPCA) ResourceIdentifiers ¶ added in v0.5.0
ResourceIdentifiers - The volume ids of the ebs volumes
func (ACMPCA) ResourceName ¶ added in v0.5.0
ResourceName - the simple name of the aws resource
type AMIs ¶ added in v0.0.4
type AMIs struct {
ImageIds []string
}
AMIs - represents all user owned AMIs
func (AMIs) MaxBatchSize ¶ added in v0.1.2
func (AMIs) ResourceIdentifiers ¶ added in v0.0.4
ResourceIdentifiers - The AMI image ids
func (AMIs) ResourceName ¶ added in v0.0.4
ResourceName - the simple name of the aws resource
type ASGroups ¶
type ASGroups struct {
GroupNames []string
}
ASGroups - represents all auto scaling groups
func (ASGroups) MaxBatchSize ¶ added in v0.1.2
func (ASGroups) ResourceIdentifiers ¶
ResourceIdentifiers - The group names of the auto scaling groups
func (ASGroups) ResourceName ¶
ResourceName - the simple name of the aws resource
type AccessAnalyzer ¶ added in v0.4.0
type AccessAnalyzer struct {
AnalyzerNames []string
}
AccessAnalyzer - represents all AWS secrets manager secrets that should be deleted.
func (AccessAnalyzer) MaxBatchSize ¶ added in v0.4.0
func (analyzer AccessAnalyzer) MaxBatchSize() int
func (AccessAnalyzer) Nuke ¶ added in v0.4.0
func (analyzer AccessAnalyzer) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (AccessAnalyzer) ResourceIdentifiers ¶ added in v0.4.0
func (analyzer AccessAnalyzer) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the ec2 instances
func (AccessAnalyzer) ResourceName ¶ added in v0.4.0
func (analyzer AccessAnalyzer) ResourceName() string
ResourceName - the simple name of the aws resource
type AwsAccountResources ¶
type AwsAccountResources struct {
Resources map[string]AwsRegionResource
}
func GetAllResources ¶
func GetAllResources(targetRegions []string, excludeAfter time.Time, resourceTypes []string, configObj config.Config) (*AwsAccountResources, error)
GetAllResources - Lists all aws resources
type AwsRegionResource ¶
type AwsRegionResource struct {
Resources []AwsResources
}
type AwsResources ¶
type CloudWatchDashboards ¶ added in v0.6.0
type CloudWatchDashboards struct {
DashboardNames []string
}
CloudWatchDashboards - represents all CloudWatch Dashboards that should be deleted.
func (CloudWatchDashboards) MaxBatchSize ¶ added in v0.6.0
func (cwdb CloudWatchDashboards) MaxBatchSize() int
func (CloudWatchDashboards) Nuke ¶ added in v0.6.0
func (cwdb CloudWatchDashboards) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (CloudWatchDashboards) ResourceIdentifiers ¶ added in v0.6.0
func (cwdb CloudWatchDashboards) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the ec2 instances
func (CloudWatchDashboards) ResourceName ¶ added in v0.6.0
func (cwdb CloudWatchDashboards) ResourceName() string
ResourceName - the simple name of the aws resource
type CloudWatchLogGroups ¶ added in v0.11.0
type CloudWatchLogGroups struct {
Names []string
}
CloudWatchLogGroup - represents all ec2 instances
func (CloudWatchLogGroups) MaxBatchSize ¶ added in v0.11.0
func (r CloudWatchLogGroups) MaxBatchSize() int
func (CloudWatchLogGroups) Nuke ¶ added in v0.11.0
func (r CloudWatchLogGroups) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (CloudWatchLogGroups) ResourceIdentifiers ¶ added in v0.11.0
func (r CloudWatchLogGroups) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the ec2 instances
func (CloudWatchLogGroups) ResourceName ¶ added in v0.11.0
func (r CloudWatchLogGroups) ResourceName() string
ResourceName - the simple name of the aws resource
type DBClusters ¶ added in v0.1.14
type DBClusters struct {
InstanceNames []string
}
func (DBClusters) MaxBatchSize ¶ added in v0.1.14
func (instance DBClusters) MaxBatchSize() int
func (DBClusters) Nuke ¶ added in v0.1.14
func (instance DBClusters) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (DBClusters) ResourceIdentifiers ¶ added in v0.1.14
func (instance DBClusters) ResourceIdentifiers() []string
ResourceIdentifiers - The instance names of the rds db instances
func (DBClusters) ResourceName ¶ added in v0.1.14
func (instance DBClusters) ResourceName() string
type DBInstances ¶ added in v0.1.14
type DBInstances struct {
InstanceNames []string
}
func (DBInstances) MaxBatchSize ¶ added in v0.1.14
func (instance DBInstances) MaxBatchSize() int
func (DBInstances) Nuke ¶ added in v0.1.14
func (instance DBInstances) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (DBInstances) ResourceIdentifiers ¶ added in v0.1.14
func (instance DBInstances) ResourceIdentifiers() []string
ResourceIdentifiers - The instance names of the rds db instances
func (DBInstances) ResourceName ¶ added in v0.1.14
func (instance DBInstances) ResourceName() string
type DefaultSecurityGroup ¶ added in v0.1.8
type DefaultSecurityGroup struct { GroupName string GroupId string Region string // contains filtered or unexported fields }
func GetDefaultSecurityGroups ¶ added in v0.1.8
func GetDefaultSecurityGroups(regions []string) ([]DefaultSecurityGroup, error)
type DynamoDB ¶ added in v0.5.2
type DynamoDB struct {
DynamoTableNames []string
}
func (DynamoDB) MaxBatchSize ¶ added in v0.5.2
func (DynamoDB) ResourceIdentifiers ¶ added in v0.5.2
func (DynamoDB) ResourceName ¶ added in v0.5.2
type EBSVolumes ¶
type EBSVolumes struct {
VolumeIds []string
}
EBSVolumes - represents all ebs volumes
func (EBSVolumes) MaxBatchSize ¶ added in v0.1.2
func (volume EBSVolumes) MaxBatchSize() int
func (EBSVolumes) Nuke ¶
func (volume EBSVolumes) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (EBSVolumes) ResourceIdentifiers ¶
func (volume EBSVolumes) ResourceIdentifiers() []string
ResourceIdentifiers - The volume ids of the ebs volumes
func (EBSVolumes) ResourceName ¶
func (volume EBSVolumes) ResourceName() string
ResourceName - the simple name of the aws resource
type EC2Instances ¶
type EC2Instances struct {
InstanceIds []string
}
EC2Instances - represents all ec2 instances
func (EC2Instances) MaxBatchSize ¶ added in v0.1.2
func (instance EC2Instances) MaxBatchSize() int
func (EC2Instances) Nuke ¶
func (instance EC2Instances) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (EC2Instances) ResourceIdentifiers ¶
func (instance EC2Instances) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the ec2 instances
func (EC2Instances) ResourceName ¶
func (instance EC2Instances) ResourceName() string
ResourceName - the simple name of the aws resource
type EC2VPCs ¶ added in v0.7.1
func (EC2VPCs) MaxBatchSize ¶ added in v0.7.1
func (EC2VPCs) ResourceIdentifiers ¶ added in v0.7.1
ResourceIdentifiers - The instance ids of the ec2 instances
func (EC2VPCs) ResourceName ¶ added in v0.7.1
ResourceName - the simple name of the aws resource
type ECSClusters ¶ added in v0.1.22
type ECSClusters struct {
ClusterArns []string
}
ECSClusters - Represents all ECS clusters found in a region
func (ECSClusters) MaxBatchSize ¶ added in v0.1.22
func (clusters ECSClusters) MaxBatchSize() int
func (ECSClusters) Nuke ¶ added in v0.1.22
func (clusters ECSClusters) Nuke(awsSession *session.Session, identifiers []string) error
Nuke - nuke all ECS Cluster resources
func (ECSClusters) ResourceIdentifiers ¶ added in v0.1.22
func (clusters ECSClusters) ResourceIdentifiers() []string
ResourceIdentifiers - the collected ECS clusters
func (ECSClusters) ResourceName ¶ added in v0.1.22
func (clusters ECSClusters) ResourceName() string
ResourceName - The simple name of the aws resource
type ECSServices ¶ added in v0.1.4
ECSServices - Represents all ECS services found in a region
func (ECSServices) MaxBatchSize ¶ added in v0.1.4
func (services ECSServices) MaxBatchSize() int
func (ECSServices) Nuke ¶ added in v0.1.4
func (services ECSServices) Nuke(awsSession *session.Session, identifiers []string) error
Nuke - nuke all ECS service resources
func (ECSServices) ResourceIdentifiers ¶ added in v0.1.4
func (services ECSServices) ResourceIdentifiers() []string
ResourceIdentifiers - The ARNs of the collected ECS services
func (ECSServices) ResourceName ¶ added in v0.1.4
func (services ECSServices) ResourceName() string
ResourceName - The simple name of the aws resource
type EIPAddresses ¶ added in v0.1.2
type EIPAddresses struct {
AllocationIds []string
}
EBSVolumes - represents all ebs volumes
func (EIPAddresses) MaxBatchSize ¶ added in v0.1.2
func (address EIPAddresses) MaxBatchSize() int
func (EIPAddresses) Nuke ¶ added in v0.1.2
func (address EIPAddresses) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (EIPAddresses) ResourceIdentifiers ¶ added in v0.1.2
func (address EIPAddresses) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the eip addresses
func (EIPAddresses) ResourceName ¶ added in v0.1.2
func (address EIPAddresses) ResourceName() string
ResourceName - the simple name of the aws resource
type EKSClusters ¶ added in v0.1.5
type EKSClusters struct {
Clusters []string
}
EKSClusters - Represents all EKS clusters found in a region
func (EKSClusters) MaxBatchSize ¶ added in v0.1.5
func (clusters EKSClusters) MaxBatchSize() int
func (EKSClusters) Nuke ¶ added in v0.1.5
func (clusters EKSClusters) Nuke(awsSession *session.Session, identifiers []string) error
Nuke - nuke all EKS Cluster resources
func (EKSClusters) ResourceIdentifiers ¶ added in v0.1.5
func (clusters EKSClusters) ResourceIdentifiers() []string
ResourceIdentifiers - The Name of the collected EKS clusters
func (EKSClusters) ResourceName ¶ added in v0.1.5
func (clusters EKSClusters) ResourceName() string
ResourceName - The simple name of the aws resource
type Elasticaches ¶ added in v0.7.5
type Elasticaches struct {
ClusterIds []string
}
Elasticaches - represents all Elasticache clusters
func (Elasticaches) MaxBatchSize ¶ added in v0.7.5
func (cache Elasticaches) MaxBatchSize() int
func (Elasticaches) Nuke ¶ added in v0.7.5
func (cache Elasticaches) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (Elasticaches) ResourceIdentifiers ¶ added in v0.7.5
func (cache Elasticaches) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the ec2 instances
func (Elasticaches) ResourceName ¶ added in v0.7.5
func (cache Elasticaches) ResourceName() string
ResourceName - the simple name of the aws resource
type ElbDeleteError ¶
type ElbDeleteError struct{}
func (ElbDeleteError) Error ¶
func (e ElbDeleteError) Error() string
type IAMUsers ¶ added in v0.1.26
type IAMUsers struct {
UserNames []string
}
IAMUsers - represents all IAMUsers on the AWS Account
func (IAMUsers) MaxBatchSize ¶ added in v0.1.26
Tentative batch size to ensure AWS doesn't throttle
func (IAMUsers) ResourceIdentifiers ¶ added in v0.1.26
ResourceIdentifiers - The IAM UserNames
func (IAMUsers) ResourceName ¶ added in v0.1.26
ResourceName - the simple name of the aws resource
type ImageAvailableError ¶ added in v0.1.2
type ImageAvailableError struct{}
func (ImageAvailableError) Error ¶ added in v0.1.2
func (e ImageAvailableError) Error() string
type KmsCheckIncludeResult ¶ added in v0.11.1
KmsCheckIncludeResult - structure used results of evaluation: not null KeyId - key should be included
type KmsCustomerKeys ¶ added in v0.9.2
type KmsCustomerKeys struct {
KeyIds []string
}
func (KmsCustomerKeys) MaxBatchSize ¶ added in v0.9.2
func (r KmsCustomerKeys) MaxBatchSize() int
MaxBatchSize - Requests batch size
func (KmsCustomerKeys) Nuke ¶ added in v0.9.2
func (c KmsCustomerKeys) Nuke(session *session.Session, keyIds []string) error
Nuke - remove all customer managed keys
func (KmsCustomerKeys) ResourceIdentifiers ¶ added in v0.9.2
func (c KmsCustomerKeys) ResourceIdentifiers() []string
ResourceIdentifiers - The IAM UserNames
func (KmsCustomerKeys) ResourceName ¶ added in v0.9.2
func (c KmsCustomerKeys) ResourceName() string
ResourceName - the simple name of the aws resource
type LambdaDeleteError ¶ added in v0.1.24
type LambdaDeleteError struct {
// contains filtered or unexported fields
}
func (LambdaDeleteError) Error ¶ added in v0.1.24
func (e LambdaDeleteError) Error() string
type LambdaFunctions ¶ added in v0.1.24
type LambdaFunctions struct {
LambdaFunctionNames []string
}
func (LambdaFunctions) MaxBatchSize ¶ added in v0.1.24
func (lambda LambdaFunctions) MaxBatchSize() int
func (LambdaFunctions) Nuke ¶ added in v0.1.24
func (lambda LambdaFunctions) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (LambdaFunctions) ResourceIdentifiers ¶ added in v0.1.24
func (lambda LambdaFunctions) ResourceIdentifiers() []string
ResourceIdentifiers - The names of the lambda functions
func (LambdaFunctions) ResourceName ¶ added in v0.1.24
func (lambda LambdaFunctions) ResourceName() string
type LaunchConfigs ¶ added in v0.1.3
type LaunchConfigs struct {
LaunchConfigurationNames []string
}
LaunchConfigs - represents all launch configurations
func (LaunchConfigs) MaxBatchSize ¶ added in v0.1.3
func (config LaunchConfigs) MaxBatchSize() int
func (LaunchConfigs) Nuke ¶ added in v0.1.3
func (config LaunchConfigs) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (LaunchConfigs) ResourceIdentifiers ¶ added in v0.1.3
func (config LaunchConfigs) ResourceIdentifiers() []string
ResourceIdentifiers - The names of the launch configurations
func (LaunchConfigs) ResourceName ¶ added in v0.1.3
func (config LaunchConfigs) ResourceName() string
ResourceName - the simple name of the aws resource
type LoadBalancers ¶
type LoadBalancers struct {
Names []string
}
LoadBalancers - represents all load balancers
func (LoadBalancers) MaxBatchSize ¶ added in v0.1.2
func (balancer LoadBalancers) MaxBatchSize() int
func (LoadBalancers) Nuke ¶
func (balancer LoadBalancers) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (LoadBalancers) ResourceIdentifiers ¶
func (balancer LoadBalancers) ResourceIdentifiers() []string
ResourceIdentifiers - The names of the load balancers
func (LoadBalancers) ResourceName ¶
func (balancer LoadBalancers) ResourceName() string
ResourceName - the simple name of the aws resource
type LoadBalancersV2 ¶
type LoadBalancersV2 struct {
Arns []string
}
LoadBalancersV2 - represents all load balancers
func (LoadBalancersV2) MaxBatchSize ¶ added in v0.1.2
func (balancer LoadBalancersV2) MaxBatchSize() int
func (LoadBalancersV2) Nuke ¶
func (balancer LoadBalancersV2) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (LoadBalancersV2) ResourceIdentifiers ¶
func (balancer LoadBalancersV2) ResourceIdentifiers() []string
ResourceIdentifiers - The arns of the load balancers
func (LoadBalancersV2) ResourceName ¶
func (balancer LoadBalancersV2) ResourceName() string
ResourceName - the simple name of the aws resource
type NatGateways ¶ added in v0.3.0
type NatGateways struct {
NatGatewayIDs []string
}
NatGateways - represents all AWS secrets manager secrets that should be deleted.
func (NatGateways) MaxBatchSize ¶ added in v0.3.0
func (secret NatGateways) MaxBatchSize() int
func (NatGateways) Nuke ¶ added in v0.3.0
func (ngw NatGateways) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (NatGateways) ResourceIdentifiers ¶ added in v0.3.0
func (ngw NatGateways) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the ec2 instances
func (NatGateways) ResourceName ¶ added in v0.3.0
func (ngw NatGateways) ResourceName() string
ResourceName - the simple name of the aws resource
type OIDCProviders ¶ added in v0.9.0
type OIDCProviders struct {
ProviderARNs []string
}
OIDCProviders - represents all AWS OpenID Connect providers that should be deleted.
func (OIDCProviders) MaxBatchSize ¶ added in v0.9.0
func (oidcprovider OIDCProviders) MaxBatchSize() int
func (OIDCProviders) Nuke ¶ added in v0.9.0
func (oidcprovider OIDCProviders) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (OIDCProviders) ResourceIdentifiers ¶ added in v0.9.0
func (oidcprovider OIDCProviders) ResourceIdentifiers() []string
ResourceIdentifiers - The ARNs of the OIDC providers.
func (OIDCProviders) ResourceName ¶ added in v0.9.0
func (oidcprovider OIDCProviders) ResourceName() string
ResourceName - the simple name of the aws resource
type OpenSearchDomains ¶ added in v0.7.0
type OpenSearchDomains struct {
DomainNames []string
}
OpenSearchDomains represents all OpenSearch domains found in a region
func (OpenSearchDomains) MaxBatchSize ¶ added in v0.7.0
func (domains OpenSearchDomains) MaxBatchSize() int
MaxBatchSize returns the number of resources that should be nuked at a time. A small number is used to ensure AWS doesn't throttle. OpenSearch Domains do not support bulk delete, so we will be deleting this many in parallel using go routines. We conservatively pick 10 here, both to limit overloading the runtime and to avoid AWS throttling with many API calls.
func (OpenSearchDomains) Nuke ¶ added in v0.7.0
func (domains OpenSearchDomains) Nuke(awsSession *session.Session, identifiers []string) error
Nuke nukes all OpenSearch domain resources
func (OpenSearchDomains) ResourceIdentifiers ¶ added in v0.7.0
func (domains OpenSearchDomains) ResourceIdentifiers() []string
ResourceIdentifiers the collected OpenSearch Domains
func (OpenSearchDomains) ResourceName ¶ added in v0.7.0
func (domains OpenSearchDomains) ResourceName() string
ResourceName is the simple name of the aws resource
type RdsDeleteError ¶ added in v0.1.14
type RdsDeleteError struct {
// contains filtered or unexported fields
}
func (RdsDeleteError) Error ¶ added in v0.1.14
func (e RdsDeleteError) Error() string
type S3Bucket ¶ added in v0.1.18
type S3Bucket struct { Name string CreationDate time.Time Region string Tags []map[string]string Error error IsValid bool InvalidReason string }
S3Bucket - represents S3 bucket
type S3Buckets ¶ added in v0.1.17
type S3Buckets struct {
Names []string
}
S3Buckets - represents all S3 Buckets
func (S3Buckets) MaxBatchSize ¶ added in v0.1.17
MaxBatchSize decides how many S3 buckets to delete in one call.
func (S3Buckets) MaxConcurrentGetSize ¶ added in v0.1.18
MaxConcurrentGetSize decides how many S3 buckets to fetch in one call.
func (S3Buckets) ObjectMaxBatchSize ¶ added in v0.1.17
ObjectMaxBatchSize decides how many unique objects of an S3 bucket (object + version = unique object) to delete in one call.
func (S3Buckets) ResourceIdentifiers ¶ added in v0.1.17
ResourceIdentifiers - The names of the S3 buckets
func (S3Buckets) ResourceName ¶ added in v0.1.17
ResourceName - the simple name of the aws resource
type SecretsManagerSecrets ¶ added in v0.2.0
type SecretsManagerSecrets struct {
SecretIDs []string
}
SecretsManagerSecrets - represents all AWS secrets manager secrets that should be deleted.
func (SecretsManagerSecrets) MaxBatchSize ¶ added in v0.2.0
func (secret SecretsManagerSecrets) MaxBatchSize() int
func (SecretsManagerSecrets) Nuke ¶ added in v0.2.0
func (secret SecretsManagerSecrets) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (SecretsManagerSecrets) ResourceIdentifiers ¶ added in v0.2.0
func (secret SecretsManagerSecrets) ResourceIdentifiers() []string
ResourceIdentifiers - The instance ids of the ec2 instances
func (SecretsManagerSecrets) ResourceName ¶ added in v0.2.0
func (secret SecretsManagerSecrets) ResourceName() string
ResourceName - the simple name of the aws resource
type Snapshots ¶ added in v0.0.4
type Snapshots struct {
SnapshotIds []string
}
Snapshots - represents all user owned Snapshots
func (Snapshots) MaxBatchSize ¶ added in v0.1.2
func (Snapshots) ResourceIdentifiers ¶ added in v0.0.4
ResourceIdentifiers - The Snapshot snapshot ids
func (Snapshots) ResourceName ¶ added in v0.0.4
ResourceName - the simple name of the aws resource
type SqsQueue ¶ added in v0.1.30
type SqsQueue struct {
QueueUrls []string
}
SqsQueue - represents all sqs queues
func (SqsQueue) MaxBatchSize ¶ added in v0.1.30
func (SqsQueue) ResourceIdentifiers ¶ added in v0.1.30
ResourceIdentifiers - The arns of the sqs queues
func (SqsQueue) ResourceName ¶ added in v0.1.30
ResourceName - the simple name of the aws resource
type TooManyAccessAnalyzersErr ¶ added in v0.4.0
type TooManyAccessAnalyzersErr struct{}
func (TooManyAccessAnalyzersErr) Error ¶ added in v0.4.0
func (err TooManyAccessAnalyzersErr) Error() string
type TooManyCloudWatchDashboardsErr ¶ added in v0.6.0
type TooManyCloudWatchDashboardsErr struct{}
func (TooManyCloudWatchDashboardsErr) Error ¶ added in v0.6.0
func (err TooManyCloudWatchDashboardsErr) Error() string
type TooManyEKSClustersErr ¶ added in v0.7.0
type TooManyEKSClustersErr struct{}
func (TooManyEKSClustersErr) Error ¶ added in v0.7.0
func (err TooManyEKSClustersErr) Error() string
type TooManyLogGroupsErr ¶ added in v0.11.0
type TooManyLogGroupsErr struct{}
func (TooManyLogGroupsErr) Error ¶ added in v0.11.0
func (err TooManyLogGroupsErr) Error() string
type TooManyNatErr ¶ added in v0.3.0
type TooManyNatErr struct{}
func (TooManyNatErr) Error ¶ added in v0.3.0
func (err TooManyNatErr) Error() string
type TooManyOIDCProvidersErr ¶ added in v0.9.0
type TooManyOIDCProvidersErr struct{}
func (TooManyOIDCProvidersErr) Error ¶ added in v0.9.0
func (err TooManyOIDCProvidersErr) Error() string
type TooManyOpenSearchDomainsErr ¶ added in v0.7.0
type TooManyOpenSearchDomainsErr struct{}
func (TooManyOpenSearchDomainsErr) Error ¶ added in v0.7.0
func (err TooManyOpenSearchDomainsErr) Error() string
type TransitGateways ¶ added in v0.1.26
type TransitGateways struct {
Ids []string
}
TransitGateways - represents all transit gateways
func (TransitGateways) MaxBatchSize ¶ added in v0.1.26
func (tgw TransitGateways) MaxBatchSize() int
MaxBatchSize - Tentative batch size to ensure AWS doesn't throttle
func (TransitGateways) Nuke ¶ added in v0.1.26
func (tgw TransitGateways) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (TransitGateways) ResourceIdentifiers ¶ added in v0.1.26
func (tgw TransitGateways) ResourceIdentifiers() []string
ResourceIdentifiers - The Ids of the transit gateways
func (TransitGateways) ResourceName ¶ added in v0.1.26
func (tgw TransitGateways) ResourceName() string
ResourceName - the simple name of the aws resource
type TransitGatewaysRouteTables ¶ added in v0.1.26
type TransitGatewaysRouteTables struct {
Ids []string
}
TransitGatewaysRouteTables - represents all transit gateways route tables
func (TransitGatewaysRouteTables) MaxBatchSize ¶ added in v0.1.26
func (tgw TransitGatewaysRouteTables) MaxBatchSize() int
MaxBatchSize - Tentative batch size to ensure AWS doesn't throttle
func (TransitGatewaysRouteTables) Nuke ¶ added in v0.1.26
func (tgw TransitGatewaysRouteTables) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (TransitGatewaysRouteTables) ResourceIdentifiers ¶ added in v0.1.26
func (tgw TransitGatewaysRouteTables) ResourceIdentifiers() []string
ResourceIdentifiers - The arns of the transit gateways route tables
func (TransitGatewaysRouteTables) ResourceName ¶ added in v0.1.26
func (tgw TransitGatewaysRouteTables) ResourceName() string
ResourceName - the simple name of the aws resource
type TransitGatewaysVpcAttachment ¶ added in v0.1.26
type TransitGatewaysVpcAttachment struct {
Ids []string
}
TransitGatewaysVpcAttachment - represents all transit gateways vpc attachments
func (TransitGatewaysVpcAttachment) MaxBatchSize ¶ added in v0.1.26
func (tgw TransitGatewaysVpcAttachment) MaxBatchSize() int
MaxBatchSize - Tentative batch size to ensure AWS doesn't throttle
func (TransitGatewaysVpcAttachment) Nuke ¶ added in v0.1.26
func (tgw TransitGatewaysVpcAttachment) Nuke(session *session.Session, identifiers []string) error
Nuke - nuke 'em all!!!
func (TransitGatewaysVpcAttachment) ResourceIdentifiers ¶ added in v0.1.26
func (tgw TransitGatewaysVpcAttachment) ResourceIdentifiers() []string
ResourceIdentifiers - The Ids of the transit gateways
func (TransitGatewaysVpcAttachment) ResourceName ¶ added in v0.1.26
func (tgw TransitGatewaysVpcAttachment) ResourceName() string
ResourceName - the simple name of the aws resource
type VPCEndpointDeleteTimeoutError ¶ added in v0.11.5
type VPCEndpointDeleteTimeoutError struct{}
func (VPCEndpointDeleteTimeoutError) Error ¶ added in v0.11.5
func (e VPCEndpointDeleteTimeoutError) Error() string
type Vpc ¶ added in v0.1.8
func GetDefaultVpcs ¶ added in v0.1.8
GetDefaultVpcs needs a slice of vpcs that already have service clients and regions assigned, either via NewVpcPerRegion() (as in the CLI) or manually (as in the mock tests)
func NewVpcPerRegion ¶ added in v0.1.8
NewVpcPerRegion merely assigns a service client and region to a VPC object The CLI calls this, but the tests don't because the tests need to use a mocked service client.
Source Files ¶
- access_analyzer.go
- access_analyzer_types.go
- acmpca.go
- acmpca_types.go
- ami.go
- ami_types.go
- asg.go
- asg_types.go
- aws.go
- cloudwatch_dashboard.go
- cloudwatch_dashboard_types.go
- cloudwatch_loggroup.go
- cloudwatch_loggroup_types.go
- dynamodb.go
- dynamodb_types.go
- ebs.go
- ebs_types.go
- ec2.go
- ec2_types.go
- ec2_vpc.go
- ecs_cluster.go
- ecs_cluster_types.go
- ecs_service.go
- ecs_service_types.go
- eip.go
- eip_types.go
- eks.go
- eks_types.go
- elasticache.go
- elasticache_types.go
- elb.go
- elb_types.go
- elbv2.go
- elbv2_types.go
- globals.go
- iam.go
- iam_types.go
- kms_customer_key.go
- kms_customer_key_types.go
- lambda.go
- lambda_types.go
- launch_config.go
- launch_config_types.go
- nat_gateway.go
- nat_gateway_types.go
- oidc_provider.go
- oidc_provider_types.go
- opensearch.go
- opensearch_types.go
- rds.go
- rds_cluster.go
- rds_cluster_types.go
- rds_types.go
- s3.go
- s3_types.go
- secrets_manager.go
- secrets_manager_types.go
- snapshot.go
- snapshot_types.go
- sqs.go
- sqs_types.go
- transit_gateway.go
- transit_gateway_types.go
- types.go