forked from rebuy-de/aws-nuke
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cognito-identity-providers.go
92 lines (74 loc) · 2.12 KB
/
cognito-identity-providers.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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
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/cognitoidentityprovider"
"github.com/dngferreira/aws-nuke/v2/pkg/types"
"github.com/sirupsen/logrus"
)
type CognitoIdentityProvider struct {
svc *cognitoidentityprovider.CognitoIdentityProvider
name *string
providerType *string
userPoolName *string
userPoolId *string
}
func init() {
register("CognitoIdentityProvider", ListCognitoIdentityProviders)
}
func ListCognitoIdentityProviders(sess *session.Session) ([]Resource, error) {
svc := cognitoidentityprovider.New(sess)
userPools, poolErr := ListCognitoUserPools(sess)
if poolErr != nil {
return nil, poolErr
}
resources := []Resource{}
for _, userPoolResource := range userPools {
userPool, ok := userPoolResource.(*CognitoUserPool)
if !ok {
logrus.Errorf("Unable to case CognitoUserPool")
continue
}
listParams := &cognitoidentityprovider.ListIdentityProvidersInput{
UserPoolId: userPool.id,
MaxResults: aws.Int64(50),
}
for {
output, err := svc.ListIdentityProviders(listParams)
if err != nil {
return nil, err
}
for _, provider := range output.Providers {
resources = append(resources, &CognitoIdentityProvider{
svc: svc,
name: provider.ProviderName,
providerType: provider.ProviderType,
userPoolName: userPool.name,
userPoolId: userPool.id,
})
}
if output.NextToken == nil {
break
}
listParams.NextToken = output.NextToken
}
}
return resources, nil
}
func (p *CognitoIdentityProvider) Remove() error {
_, err := p.svc.DeleteIdentityProvider(&cognitoidentityprovider.DeleteIdentityProviderInput{
UserPoolId: p.userPoolId,
ProviderName: p.name,
})
return err
}
func (p *CognitoIdentityProvider) Properties() types.Properties {
properties := types.NewProperties()
properties.Set("Type", p.providerType)
properties.Set("UserPoolName", p.userPoolName)
properties.Set("Name", p.name)
return properties
}
func (p *CognitoIdentityProvider) String() string {
return *p.userPoolName + " -> " + *p.name
}