forked from rebuy-de/aws-nuke
-
Notifications
You must be signed in to change notification settings - Fork 0
/
accessanalyzer-analyzers.go
72 lines (59 loc) · 1.57 KB
/
accessanalyzer-analyzers.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package resources
import (
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/accessanalyzer"
"github.com/dngferreira/aws-nuke/v2/pkg/types"
)
type AccessAnalyzer struct {
svc *accessanalyzer.AccessAnalyzer
arn string
name string
status string
tags map[string]*string
}
func init() {
register("AccessAnalyzer", ListAccessAnalyzer,
mapCloudControl("AWS::AccessAnalyzer::Analyzer"))
}
func ListAccessAnalyzer(sess *session.Session) ([]Resource, error) {
svc := accessanalyzer.New(sess)
params := &accessanalyzer.ListAnalyzersInput{
Type: aws.String("ACCOUNT"),
}
resources := make([]Resource, 0)
err := svc.ListAnalyzersPages(params,
func(page *accessanalyzer.ListAnalyzersOutput, lastPage bool) bool {
for _, analyzer := range page.Analyzers {
resources = append(resources, &AccessAnalyzer{
svc: svc,
arn: *analyzer.Arn,
name: *analyzer.Name,
status: *analyzer.Status,
tags: analyzer.Tags,
})
}
return true
})
if err != nil {
return nil, err
}
return resources, nil
}
func (a *AccessAnalyzer) Remove() error {
_, err := a.svc.DeleteAnalyzer(&accessanalyzer.DeleteAnalyzerInput{AnalyzerName: &a.name})
return err
}
func (a *AccessAnalyzer) Properties() types.Properties {
properties := types.NewProperties()
properties.Set("ARN", a.arn)
properties.Set("Name", a.name)
properties.Set("Status", a.status)
for k, v := range a.tags {
properties.SetTag(&k, v)
}
return properties
}
func (a *AccessAnalyzer) String() string {
return a.name
}