forked from equinixmetal-archive/packngo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vrf.go
187 lines (149 loc) · 5.26 KB
/
vrf.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
package packngo
import (
"path"
)
const (
vrfBasePath = "/vrfs"
)
type VRFService interface {
List(projectID string, opts *ListOptions) ([]VRF, *Response, error)
Create(projectID string, input *VRFCreateRequest) (*VRF, *Response, error)
Update(vrfID string, update *VRFUpdateRequest) (*VRF, *Response, error)
Get(vrfID string, opts *GetOptions) (*VRF, *Response, error)
ListIPs(vrfID string, opts *GetOptions) ([]IPAddressReservation, *Response, error)
Delete(vrfID string) (*Response, error)
}
type VRF struct {
ID string `json:"id"`
Name string `json:"name"`
Description string `json:"description"`
LocalASN int `json:"local_asn,omitempty"`
IPRanges []string `json:"ip_ranges,omitempty"`
Project *Project `json:"project,omitempty"`
Metro *Metro `json:"metro,omitempty"`
Href string `json:"href"`
CreatedAt string `json:"created_at,omitempty"`
UpdatedAt string `json:"updated_at,omitempty"`
}
type VRFCreateRequest struct {
// Metro id or code
Metro string `json:"metro"`
// Name is the name of the VRF. It must be unique per project.
Name string `json:"name"`
// Description of the VRF to be created.
Description string `json:"description"`
// LocalASN is the ASN of the local network.
LocalASN int `json:"local_asn,omitempty"`
// IPRanges is a list of all IPv4 and IPv6 Ranges that will be available to
// BGP Peers. IPv4 addresses must be /8 or smaller with a minimum size of
// /29. IPv6 must be /56 or smaller with a minimum size of /64. Ranges must
// not overlap other ranges within the VRF.
IPRanges []string `json:"ip_ranges,omitempty"`
}
type VRFUpdateRequest struct {
// Name is the name of the VRF. It must be unique per project.
Name *string `json:"name,omitempty"`
// Description of the VRF to be created.
Description *string `json:"description,omitempty"`
// LocalASN is the ASN of the local network.
LocalASN *int `json:"local_asn,omitempty"`
// IPRanges is a list of all IPv4 and IPv6 Ranges that will be available to
// BGP Peers. IPv4 addresses must be /8 or smaller with a minimum size of
// /29. IPv6 must be /56 or smaller with a minimum size of /64. Ranges must
// not overlap other ranges within the VRF.
IPRanges *[]string `json:"ip_ranges,omitempty"`
}
type VRFServiceOp struct {
client *Client
}
func (s *VRFServiceOp) List(projectID string, opts *ListOptions) (vrfs []VRF, resp *Response, err error) {
if validateErr := ValidateUUID(projectID); validateErr != nil {
return nil, nil, validateErr
}
type vrfsRoot struct {
VRFs []VRF `json:"vrfs"`
Meta meta `json:"meta"`
}
endpointPath := path.Join(projectBasePath, projectID, vrfBasePath)
apiPathQuery := opts.WithQuery(endpointPath)
for {
subset := new(vrfsRoot)
resp, err = s.client.DoRequest("GET", apiPathQuery, nil, subset)
if err != nil {
return nil, resp, err
}
vrfs = append(vrfs, subset.VRFs...)
if apiPathQuery = nextPage(subset.Meta, opts); apiPathQuery != "" {
continue
}
return
}
}
func (s *VRFServiceOp) ListIPs(vrfID string, opts *ListOptions) (ips []IPAddressReservation, resp *Response, err error) {
if validateErr := ValidateUUID(vrfID); validateErr != nil {
return nil, nil, validateErr
}
endpointPath := path.Join(vrfBasePath, vrfID, ipBasePath)
apiPathQuery := opts.WithQuery(endpointPath)
// ipList represents collection of IP Address reservations
type ipList struct {
IPs []IPAddressReservation `json:"ip_addresses,omitempty"`
}
results := new(ipList)
resp, err = s.client.DoRequest("GET", apiPathQuery, nil, results)
if err != nil {
return nil, resp, err
}
return results.IPs, resp, err
}
func (s *VRFServiceOp) Get(vrfID string, opts *GetOptions) (*VRF, *Response, error) {
if validateErr := ValidateUUID(vrfID); validateErr != nil {
return nil, nil, validateErr
}
endpointPath := path.Join(vrfBasePath, vrfID)
apiPathQuery := opts.WithQuery(endpointPath)
metalGateway := new(VRF)
resp, err := s.client.DoRequest("GET", apiPathQuery, nil, metalGateway)
if err != nil {
return nil, resp, err
}
return metalGateway, resp, err
}
func (s *VRFServiceOp) Create(projectID string, input *VRFCreateRequest) (*VRF, *Response, error) {
if validateErr := ValidateUUID(projectID); validateErr != nil {
return nil, nil, validateErr
}
apiPath := path.Join(projectBasePath, projectID, vrfBasePath)
output := new(VRF)
resp, err := s.client.DoRequest("POST", apiPath, input, output)
if err != nil {
return nil, nil, err
}
return output, resp, nil
}
// Update updates an existing VRF
func (s *VRFServiceOp) Update(vrfID string, updateRequest *VRFUpdateRequest) (*VRF, *Response, error) {
if validateErr := ValidateUUID(vrfID); validateErr != nil {
return nil, nil, validateErr
}
opts := &GetOptions{}
endpointPath := path.Join(vrfBasePath, vrfID)
apiPathQuery := opts.WithQuery(endpointPath)
vrf := new(VRF)
resp, err := s.client.DoRequest("PUT", apiPathQuery, updateRequest, vrf)
if err != nil {
return nil, resp, err
}
return vrf, resp, err
}
func (s *VRFServiceOp) Delete(vrfID string) (*Response, error) {
if validateErr := ValidateUUID(vrfID); validateErr != nil {
return nil, validateErr
}
apiPath := path.Join(vrfBasePath, vrfID)
resp, err := s.client.DoRequest("DELETE", apiPath, nil, nil)
if err != nil {
return nil, err
}
return resp, nil
}