/
cidrmap.go
222 lines (178 loc) · 6.83 KB
/
cidrmap.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
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
package gtm
import (
"context"
"fmt"
"net/http"
)
//
// Handle Operations on gtm cidrmaps
// Based on 1.4 schema
//
// CidrMaps contains operations available on a Cidrmap resource
// See: https://developer.akamai.com/api/web_performance/global_traffic_management/v1.html
type CidrMaps interface {
// NewCidrMap creates a new CidrMap object.
NewCidrMap(context.Context, string) *CidrMap
// Instantiate new Assignment struct
NewCidrAssignment(context.Context, *CidrMap, int, string) *CidrAssignment
// ListCidrMaps retreieves all CidrMaps
// See: https://developer.akamai.com/api/web_performance/global_traffic_management/v1.html#getcidrmaps
ListCidrMaps(context.Context, string) ([]*CidrMap, error)
// GetCidrMap retrieves a CidrMap with the given name.
// See: https://developer.akamai.com/api/web_performance/global_traffic_management/v1.html#getcidrmap
GetCidrMap(context.Context, string, string) (*CidrMap, error)
// Create the datacenter identified by the receiver argument in the specified domain.
// See: https://developer.akamai.com/api/web_performance/global_traffic_management/v1.html#putcidrmap
CreateCidrMap(context.Context, *CidrMap, string) (*CidrMapResponse, error)
// Delete the datacenter identified by the receiver argument from the domain specified.
// See: https://developer.akamai.com/api/web_performance/global_traffic_management/v1.html#deletecidrmap
DeleteCidrMap(context.Context, *CidrMap, string) (*ResponseStatus, error)
// Update the datacenter identified in the receiver argument in the provided domain.
// See: https://developer.akamai.com/api/web_performance/global_traffic_management/v1.html#putcidrmap
UpdateCidrMap(context.Context, *CidrMap, string) (*ResponseStatus, error)
}
//CidrAssignment represents a GTM cidr assignment element
type CidrAssignment struct {
DatacenterBase
Blocks []string `json:"blocks"`
}
// CidrMap represents a GTM cidrMap element
type CidrMap struct {
DefaultDatacenter *DatacenterBase `json:"defaultDatacenter"`
Assignments []*CidrAssignment `json:"assignments,omitempty"`
Name string `json:"name"`
Links []*Link `json:"links,omitempty"`
}
// CidrMapList represents a GTM returned cidrmap list body
type CidrMapList struct {
CidrMapItems []*CidrMap `json:"items"`
}
// Validate validates CidrMap
func (cidr *CidrMap) Validate() error {
if len(cidr.Name) < 1 {
return fmt.Errorf("CidrMap is missing Name")
}
if cidr.DefaultDatacenter == nil {
return fmt.Errorf("CidrMap is missing DefaultDatacenter")
}
return nil
}
// NewCidrMap creates a new CidrMap object
func (p *gtm) NewCidrMap(ctx context.Context, name string) *CidrMap {
logger := p.Log(ctx)
logger.Debug("NewCidrMap")
cidrmap := &CidrMap{Name: name}
return cidrmap
}
// ListCidrMaps retrieves all CidrMaps
func (p *gtm) ListCidrMaps(ctx context.Context, domainName string) ([]*CidrMap, error) {
logger := p.Log(ctx)
logger.Debug("ListCidrMaps")
var cidrs CidrMapList
getURL := fmt.Sprintf("/config-gtm/v1/domains/%s/cidr-maps", domainName)
req, err := http.NewRequestWithContext(ctx, http.MethodGet, getURL, nil)
if err != nil {
return nil, fmt.Errorf("failed to create ListCidrMaps request: %w", err)
}
setVersionHeader(req, schemaVersion)
resp, err := p.Exec(req, &cidrs)
if err != nil {
return nil, fmt.Errorf("ListCidrMaps request failed: %w", err)
}
if resp.StatusCode != http.StatusOK {
return nil, p.Error(resp)
}
return cidrs.CidrMapItems, nil
}
// GetCidrMap retrieves a CidrMap with the given name.
func (p *gtm) GetCidrMap(ctx context.Context, name, domainName string) (*CidrMap, error) {
logger := p.Log(ctx)
logger.Debug("GetCidrMap")
var cidr CidrMap
getURL := fmt.Sprintf("/config-gtm/v1/domains/%s/cidr-maps/%s", domainName, name)
req, err := http.NewRequestWithContext(ctx, http.MethodGet, getURL, nil)
if err != nil {
return nil, fmt.Errorf("failed to create GetCidrMap request: %w", err)
}
setVersionHeader(req, schemaVersion)
resp, err := p.Exec(req, &cidr)
if err != nil {
return nil, fmt.Errorf("GetCidrMap request failed: %w", err)
}
if resp.StatusCode != http.StatusOK {
return nil, p.Error(resp)
}
return &cidr, nil
}
// NewCidrAssignment instantiate new Assignment struct
func (p *gtm) NewCidrAssignment(ctx context.Context, _ *CidrMap, dcid int, nickname string) *CidrAssignment {
logger := p.Log(ctx)
logger.Debug("NewCidrAssignment")
cidrAssign := &CidrAssignment{}
cidrAssign.DatacenterId = dcid
cidrAssign.Nickname = nickname
return cidrAssign
}
// CreateCidrMap creates CidrMap in provided domain
func (p *gtm) CreateCidrMap(ctx context.Context, cidr *CidrMap, domainName string) (*CidrMapResponse, error) {
logger := p.Log(ctx)
logger.Debug("CreateCidrMap")
// Use common code. Any specific validation needed?
return cidr.save(ctx, p, domainName)
}
// UpdateCidrMap updates CidrMap in given domain
func (p *gtm) UpdateCidrMap(ctx context.Context, cidr *CidrMap, domainName string) (*ResponseStatus, error) {
logger := p.Log(ctx)
logger.Debug("UpdateCidrMap")
// common code
stat, err := cidr.save(ctx, p, domainName)
if err != nil {
return nil, err
}
return stat.Status, err
}
// save CidrMap in given domain. Common path for Create and Update.
func (cidr *CidrMap) save(ctx context.Context, p *gtm, domainName string) (*CidrMapResponse, error) {
if err := cidr.Validate(); err != nil {
return nil, fmt.Errorf("CidrMap validation failed. %w", err)
}
putURL := fmt.Sprintf("/config-gtm/v1/domains/%s/cidr-maps/%s", domainName, cidr.Name)
req, err := http.NewRequestWithContext(ctx, http.MethodPut, putURL, nil)
if err != nil {
return nil, fmt.Errorf("failed to create AsMap request: %w", err)
}
var mapresp CidrMapResponse
setVersionHeader(req, schemaVersion)
resp, err := p.Exec(req, &mapresp, cidr)
if err != nil {
return nil, fmt.Errorf("CidrMap request failed: %w", err)
}
if resp.StatusCode != http.StatusOK && resp.StatusCode != http.StatusCreated {
return nil, p.Error(resp)
}
return &mapresp, nil
}
// DeleteCidrMap deletes CidrMap in provided domain
func (p *gtm) DeleteCidrMap(ctx context.Context, cidr *CidrMap, domainName string) (*ResponseStatus, error) {
logger := p.Log(ctx)
logger.Debug("DeleteCidrMap")
if err := cidr.Validate(); err != nil {
logger.Errorf("CidrMap validation failed. %w", err)
return nil, fmt.Errorf("CidrMap validation failed. %w", err)
}
delURL := fmt.Sprintf("/config-gtm/v1/domains/%s/cidr-maps/%s", domainName, cidr.Name)
req, err := http.NewRequestWithContext(ctx, http.MethodDelete, delURL, nil)
if err != nil {
return nil, fmt.Errorf("failed to create Delete request: %w", err)
}
var mapresp ResponseBody
setVersionHeader(req, schemaVersion)
resp, err := p.Exec(req, &mapresp)
if err != nil {
return nil, fmt.Errorf("CidrMap request failed: %w", err)
}
if resp.StatusCode != http.StatusOK {
return nil, p.Error(resp)
}
return mapresp.Status, nil
}