-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathrate_policy_action.go
166 lines (140 loc) · 5.5 KB
/
rate_policy_action.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
package appsec
import (
"context"
"fmt"
"net/http"
"github.com/akamai/AkamaiOPEN-edgegrid-golang/v10/pkg/session"
validation "github.com/go-ozzo/ozzo-validation/v4"
)
type (
// The RatePolicyAction interface supports retrieving and modifying the action associated with
// a specified rate policy, or with all rate policies in a security policy.
RatePolicyAction interface {
// GetRatePolicyActions returns a list of all rate policies currently in use with the actions each policy takes when conditions are met.
//
// See: https://techdocs.akamai.com/application-security/reference/get-rate-policies-actions
GetRatePolicyActions(ctx context.Context, params GetRatePolicyActionsRequest) (*GetRatePolicyActionsResponse, error)
// UpdateRatePolicyAction
//
// See: https://techdocs.akamai.com/application-security/reference/put-rate-policy-action
UpdateRatePolicyAction(ctx context.Context, params UpdateRatePolicyActionRequest) (*UpdateRatePolicyActionResponse, error)
}
// GetRatePolicyActionsRequest is used to retrieve a configuration's rate policies and their associated actions.
GetRatePolicyActionsRequest struct {
ConfigID int `json:"configId"`
Version int `json:"version"`
PolicyID string `json:"policyId"`
RatePolicyID int `json:"id"`
Ipv4Action string `json:"ipv4Action"`
Ipv6Action string `json:"ipv6Action"`
}
// GetRatePolicyActionsResponse is returned from a call to GetRatePolicyActions.
GetRatePolicyActionsResponse struct {
RatePolicyActions []struct {
ID int `json:"id"`
Ipv4Action string `json:"ipv4Action,omitempty"`
Ipv6Action string `json:"ipv6Action,omitempty"`
} `json:"ratePolicyActions,omitempty"`
}
// UpdateRatePolicyActionRequest is used to update the actions for a rate policy.
UpdateRatePolicyActionRequest struct {
ConfigID int `json:"-"`
Version int `json:"-"`
PolicyID string `json:"-"`
RatePolicyID int `json:"-"`
Ipv4Action string `json:"ipv4Action"`
Ipv6Action string `json:"ipv6Action"`
}
// UpdateRatePolicyActionResponse is returned from a call to UpdateRatePolicy.
UpdateRatePolicyActionResponse struct {
ID int `json:"id"`
Ipv4Action string `json:"ipv4Action"`
Ipv6Action string `json:"ipv6Action"`
}
// RatePolicyActionPost is used to describe actions that may be taken as part of a rate policy.
RatePolicyActionPost struct {
ID int `json:"id"`
Ipv4Action string `json:"ipv4Action"`
Ipv6Action string `json:"ipv6Action"`
}
)
// Validate validates a GetRatePolicyActionsRequest.
func (v GetRatePolicyActionsRequest) Validate() error {
return validation.Errors{
"ConfigID": validation.Validate(v.ConfigID, validation.Required),
"Version": validation.Validate(v.Version, validation.Required),
"PolicyID": validation.Validate(v.PolicyID, validation.Required),
}.Filter()
}
// Validate validates an UpdateRatePolicyActionRequest.
func (v UpdateRatePolicyActionRequest) Validate() error {
return validation.Errors{
"ConfigID": validation.Validate(v.ConfigID, validation.Required),
"Version": validation.Validate(v.Version, validation.Required),
"PolicyID": validation.Validate(v.PolicyID, validation.Required),
"RatePolicyID": validation.Validate(v.RatePolicyID, validation.Required),
}.Filter()
}
func (p *appsec) GetRatePolicyActions(ctx context.Context, params GetRatePolicyActionsRequest) (*GetRatePolicyActionsResponse, error) {
logger := p.Log(ctx)
logger.Debug("GetRatePolicyActions")
if err := params.Validate(); err != nil {
return nil, fmt.Errorf("%w: %s", ErrStructValidation, err.Error())
}
uri := fmt.Sprintf(
"/appsec/v1/configs/%d/versions/%d/security-policies/%s/rate-policies",
params.ConfigID,
params.Version,
params.PolicyID)
req, err := http.NewRequestWithContext(ctx, http.MethodGet, uri, nil)
if err != nil {
return nil, fmt.Errorf("failed to create GetRatePolicyActions request: %w", err)
}
var result GetRatePolicyActionsResponse
resp, err := p.Exec(req, &result)
if err != nil {
return nil, fmt.Errorf("get rate policy actions request failed: %w", err)
}
defer session.CloseResponseBody(resp)
if resp.StatusCode != http.StatusOK {
return nil, p.Error(resp)
}
if params.RatePolicyID != 0 {
var filteredResult GetRatePolicyActionsResponse
for _, val := range result.RatePolicyActions {
if val.ID == params.RatePolicyID {
filteredResult.RatePolicyActions = append(filteredResult.RatePolicyActions, val)
}
}
return &filteredResult, nil
}
return &result, nil
}
func (p *appsec) UpdateRatePolicyAction(ctx context.Context, params UpdateRatePolicyActionRequest) (*UpdateRatePolicyActionResponse, error) {
logger := p.Log(ctx)
logger.Debug("UpdateRatePolicyAction")
if err := params.Validate(); err != nil {
return nil, fmt.Errorf("%w: %s", ErrStructValidation, err.Error())
}
uri := fmt.Sprintf(
"/appsec/v1/configs/%d/versions/%d/security-policies/%s/rate-policies/%d",
params.ConfigID,
params.Version,
params.PolicyID,
params.RatePolicyID,
)
req, err := http.NewRequestWithContext(ctx, http.MethodPut, uri, nil)
if err != nil {
return nil, fmt.Errorf("failed to create UpdateRatePolicyAction request: %w", err)
}
var result UpdateRatePolicyActionResponse
resp, err := p.Exec(req, &result, params)
if err != nil {
return nil, fmt.Errorf("update rate policy action request failed: %w", err)
}
defer session.CloseResponseBody(resp)
if resp.StatusCode != http.StatusOK && resp.StatusCode != http.StatusCreated {
return nil, p.Error(resp)
}
return &result, nil
}