blob: 2d19fab107b8481e500aad6a3ed2ab1a60df9376 [file] [log] [blame]
Jamie Hannaford924c09d2014-11-19 12:05:38 +01001package secgroups
2
3import (
4 "github.com/mitchellh/mapstructure"
5
Jamie Hannaforda493e642014-11-19 12:40:30 +01006 "github.com/rackspace/gophercloud"
Jamie Hannaford924c09d2014-11-19 12:05:38 +01007 "github.com/rackspace/gophercloud/pagination"
8)
9
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010010// SecurityGroup represents a security group.
Jamie Hannaford924c09d2014-11-19 12:05:38 +010011type SecurityGroup struct {
Jamie Hannaford2f226172014-11-25 11:52:25 +010012 // The unique ID of the group. If Neutron is installed, this ID will be
13 // represented as a string UUID; if Neutron is not installed, it will be a
14 // numeric ID. For the sake of consistency, we always cast it to a string.
15 ID string
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010016
17 // The human-readable name of the group, which needs to be unique.
18 Name string
19
20 // The human-readable description of the group.
Jamie Hannaford924c09d2014-11-19 12:05:38 +010021 Description string
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010022
23 // The rules which determine how this security group operates.
24 Rules []Rule
25
Jamie Hannaford04abbc72014-11-21 11:27:57 +010026 // The ID of the tenant to which this security group belongs.
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010027 TenantID string `mapstructure:"tenant_id"`
Jamie Hannaford924c09d2014-11-19 12:05:38 +010028}
29
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010030// Rule represents a security group rule, a policy which determines how a
31// security group operates and what inbound traffic it allows in.
Jamie Hannaford924c09d2014-11-19 12:05:38 +010032type Rule struct {
Jamie Hannaford2f226172014-11-25 11:52:25 +010033 // The unique ID. If Neutron is installed, this ID will be
34 // represented as a string UUID; if Neutron is not installed, it will be a
35 // numeric ID. For the sake of consistency, we always cast it to a string.
36 ID string
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010037
38 // The lower bound of the port range which this security group should open up
39 FromPort int `mapstructure:"from_port"`
40
41 // The upper bound of the port range which this security group should open up
42 ToPort int `mapstructure:"to_port"`
43
44 // The IP protocol (e.g. TCP) which the security group accepts
45 IPProtocol string `mapstructure:"ip_protocol"`
46
47 // The CIDR IP range whose traffic can be received
48 IPRange IPRange `mapstructure:"ip_range"`
49
Jamie Hannaford04abbc72014-11-21 11:27:57 +010050 // The security group ID to which this rule belongs
Jamie Hannaford2f226172014-11-25 11:52:25 +010051 ParentGroupID string `mapstructure:"parent_group_id"`
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010052
53 // Not documented.
54 Group Group
Jamie Hannaford924c09d2014-11-19 12:05:38 +010055}
56
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010057// IPRange represents the IP range whose traffic will be accepted by the
58// security group.
Jamie Hannaford924c09d2014-11-19 12:05:38 +010059type IPRange struct {
60 CIDR string
61}
62
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010063// Group represents a group.
Jamie Hannafordb38dd312014-11-19 13:02:11 +010064type Group struct {
65 TenantID string `mapstructure:"tenant_id"`
66 Name string
67}
68
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010069// SecurityGroupPage is a single page of a SecurityGroup collection.
Jamie Hannaford924c09d2014-11-19 12:05:38 +010070type SecurityGroupPage struct {
71 pagination.SinglePageBase
72}
73
74// IsEmpty determines whether or not a page of Security Groups contains any results.
75func (page SecurityGroupPage) IsEmpty() (bool, error) {
76 users, err := ExtractSecurityGroups(page)
77 if err != nil {
78 return false, err
79 }
80 return len(users) == 0, nil
81}
82
83// ExtractSecurityGroups returns a slice of SecurityGroups contained in a single page of results.
84func ExtractSecurityGroups(page pagination.Page) ([]SecurityGroup, error) {
85 casted := page.(SecurityGroupPage).Body
86 var response struct {
87 SecurityGroups []SecurityGroup `mapstructure:"security_groups"`
88 }
89
90 err := mapstructure.Decode(casted, &response)
91 return response.SecurityGroups, err
92}
Jamie Hannaforda493e642014-11-19 12:40:30 +010093
94type commonResult struct {
95 gophercloud.Result
96}
97
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +010098// CreateResult represents the result of a create operation.
Jamie Hannaforda493e642014-11-19 12:40:30 +010099type CreateResult struct {
100 commonResult
101}
102
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +0100103// GetResult represents the result of a get operation.
Jamie Hannafordb38dd312014-11-19 13:02:11 +0100104type GetResult struct {
105 commonResult
106}
107
Jamie Hannaford7f34d8e2014-11-20 12:24:55 +0100108// UpdateResult represents the result of an update operation.
Jamie Hannaford30c74662014-11-19 15:37:34 +0100109type UpdateResult struct {
110 commonResult
111}
112
Jamie Hannaford04abbc72014-11-21 11:27:57 +0100113// Extract will extract a SecurityGroup struct from most responses.
Jamie Hannaforda493e642014-11-19 12:40:30 +0100114func (r commonResult) Extract() (*SecurityGroup, error) {
115 if r.Err != nil {
116 return nil, r.Err
117 }
118
119 var response struct {
120 SecurityGroup SecurityGroup `mapstructure:"security_group"`
121 }
122
123 err := mapstructure.Decode(r.Body, &response)
124
125 return &response.SecurityGroup, err
126}
Jamie Hannaford8badf1e2014-11-19 14:39:26 +0100127
Jamie Hannaford04abbc72014-11-21 11:27:57 +0100128// CreateRuleResult represents the result when adding rules to a security group.
129type CreateRuleResult struct {
Jamie Hannaford8badf1e2014-11-19 14:39:26 +0100130 gophercloud.Result
131}
132
Jamie Hannaford04abbc72014-11-21 11:27:57 +0100133// Extract will extract a Rule struct from a CreateRuleResult.
134func (r CreateRuleResult) Extract() (*Rule, error) {
Jamie Hannaford8badf1e2014-11-19 14:39:26 +0100135 if r.Err != nil {
136 return nil, r.Err
137 }
138
139 var response struct {
140 Rule Rule `mapstructure:"security_group_rule"`
141 }
142
143 err := mapstructure.Decode(r.Body, &response)
144
145 return &response.Rule, err
146}