resources/cloudwatch-insight-rule.go
package resources
import (
"context"
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/service/cloudwatch"
"github.com/ekristen/libnuke/pkg/registry"
"github.com/ekristen/libnuke/pkg/resource"
"github.com/ekristen/libnuke/pkg/types"
"github.com/ekristen/aws-nuke/v3/pkg/nuke"
)
const CloudWatchInsightRuleResource = "CloudWatchInsightRule"
func init() {
registry.Register(®istry.Registration{
Name: CloudWatchInsightRuleResource,
Scope: nuke.Account,
Resource: &CloudWatchInsightRule{},
Lister: &CloudWatchInsightRuleLister{},
})
}
type CloudWatchInsightRuleLister struct{}
func (l *CloudWatchInsightRuleLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
opts := o.(*nuke.ListerOpts)
svc := cloudwatch.New(opts.Session)
resources := make([]resource.Resource, 0)
params := &cloudwatch.DescribeInsightRulesInput{
MaxResults: aws.Int64(25),
}
for {
output, err := svc.DescribeInsightRules(params)
if err != nil {
return nil, err
}
for _, rules := range output.InsightRules {
resources = append(resources, &CloudWatchInsightRule{
svc: svc,
Name: rules.Name,
State: rules.State,
})
}
if output.NextToken == nil {
break
}
params.NextToken = output.NextToken
}
return resources, nil
}
type CloudWatchInsightRule struct {
svc *cloudwatch.CloudWatch
Name *string
State *string
}
func (r *CloudWatchInsightRule) Remove(_ context.Context) error {
_, err := r.svc.DeleteInsightRules(&cloudwatch.DeleteInsightRulesInput{
RuleNames: []*string{r.Name},
})
return err
}
func (r *CloudWatchInsightRule) Properties() types.Properties {
return types.NewPropertiesFromStruct(r)
}
func (r *CloudWatchInsightRule) String() string {
return *r.Name
}