/
security_group_rules.go
74 lines (65 loc) · 2.38 KB
/
security_group_rules.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
package resources
import (
"context"
"github.com/cloudquery/plugin-sdk/v4/schema"
"github.com/cloudquery/plugin-sdk/v4/transformers"
"github.com/dihedron/cq-plugin-utils/format"
"github.com/dihedron/cq-plugin-utils/transform"
"github.com/dihedron/cq-source-openstack/client"
"github.com/gophercloud/gophercloud/openstack/networking/v2/extensions/security/rules"
)
func SecurityGroupRules() *schema.Table {
return &schema.Table{
Name: "openstack_security_group_rules",
Resolver: fetchSecurityGroupRules,
Transform: transformers.TransformWithStruct(
&rules.SecGroupRule{},
transformers.WithPrimaryKeys("ID"),
transformers.WithNameTransformer(transform.TagNameTransformer), // use cq-name tags to translate name
transformers.WithTypeTransformer(transform.TagTypeTransformer), // use cq-type tags to translate type
transformers.WithSkipFields("Links"),
),
// Columns: []schema.Column{
// {
// Name: "security_group_rule_ids",
// Type: schema.TypeStringArray,
// Description: "The collection of IP addresses associated with the port.",
// Resolver: transform.Apply(
// transform.OnObjectField("Rules.ID"),
// transform.NilIfZero(),
// ),
// },
// },
}
}
func fetchSecurityGroupRules(ctx context.Context, meta schema.ClientMeta, parent *schema.Resource, res chan<- interface{}) error {
api := meta.(*client.Client)
neutron, err := api.GetServiceClient(client.NetworkV2)
if err != nil {
api.Logger().Error().Err(err).Msg("error retrieving client")
return err
}
opts := rules.ListOpts{}
allPages, err := rules.List(neutron, opts).AllPages()
if err != nil {
api.Logger().Error().Err(err).Str("options", format.ToPrettyJSON(opts)).Msg("error listing security group rules with options")
return err
}
allSecurityGroupRules, err := rules.ExtractRules(allPages)
if err != nil {
api.Logger().Error().Err(err).Msg("error extracting security group rules")
return err
}
api.Logger().Debug().Int("count", len(allSecurityGroupRules)).Msg("security group rules retrieved")
for _, rule := range allSecurityGroupRules {
if ctx.Err() != nil {
api.Logger().Debug().Msg("context done, exit")
break
}
rule := rule
// api.Logger().Debug().Str("data", format.ToPrettyJSON(rule)).Msg("streaming security group rules")
api.Logger().Debug().Str("id", rule.ID).Msg("streaming security group rule")
res <- rule
}
return nil
}