forked from cloudflare/cloudflare-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ip_access_rules.go
89 lines (74 loc) · 3.33 KB
/
ip_access_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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
package cloudflare
import (
"context"
"fmt"
"net/http"
"github.com/goccy/go-json"
)
type ListIPAccessRulesOrderOption string
type ListIPAccessRulesMatchOption string
type IPAccessRulesModeOption string
const (
IPAccessRulesConfigurationTarget ListIPAccessRulesOrderOption = "configuration.target"
IPAccessRulesConfigurationValue ListIPAccessRulesOrderOption = "configuration.value"
IPAccessRulesMatchOptionAll ListIPAccessRulesMatchOption = "all"
IPAccessRulesMatchOptionAny ListIPAccessRulesMatchOption = "any"
IPAccessRulesModeBlock IPAccessRulesModeOption = "block"
IPAccessRulesModeChallenge IPAccessRulesModeOption = "challenge"
IPAccessRulesModeJsChallenge IPAccessRulesModeOption = "js_challenge"
IPAccessRulesModeManagedChallenge IPAccessRulesModeOption = "managed_challenge"
IPAccessRulesModeWhitelist IPAccessRulesModeOption = "whitelist"
)
type ListIPAccessRulesFilters struct {
Configuration IPAccessRuleConfiguration `json:"configuration,omitempty"`
Match ListIPAccessRulesMatchOption `json:"match,omitempty"`
Mode IPAccessRulesModeOption `json:"mode,omitempty"`
Notes string `json:"notes,omitempty"`
}
type ListIPAccessRulesParams struct {
Direction string `url:"direction,omitempty"`
Filters ListIPAccessRulesFilters `url:"filters,omitempty"`
Order ListIPAccessRulesOrderOption `url:"order,omitempty"`
PaginationOptions
}
type IPAccessRuleConfiguration struct {
Target string `json:"target,omitempty"`
Value string `json:"value,omitempty"`
}
type IPAccessRule struct {
AllowedModes []IPAccessRulesModeOption `json:"allowed_modes"`
Configuration IPAccessRuleConfiguration `json:"configuration"`
CreatedOn string `json:"created_on"`
ID string `json:"id"`
Mode IPAccessRulesModeOption `json:"mode"`
ModifiedOn string `json:"modified_on"`
Notes string `json:"notes"`
}
type ListIPAccessRulesResponse struct {
Result []IPAccessRule `json:"result"`
ResultInfo `json:"result_info"`
Response
}
// ListIPAccessRules fetches IP Access rules of a zone/user/account. You can
// filter the results using several optional parameters.
//
// API references:
// - https://developers.cloudflare.com/api/operations/ip-access-rules-for-a-user-list-ip-access-rules
// - https://developers.cloudflare.com/api/operations/ip-access-rules-for-a-zone-list-ip-access-rules
// - https://developers.cloudflare.com/api/operations/ip-access-rules-for-an-account-list-ip-access-rules
func (api *API) ListIPAccessRules(ctx context.Context, rc *ResourceContainer, params ListIPAccessRulesParams) ([]IPAccessRule, *ResultInfo, error) {
if rc.Identifier == "" {
return []IPAccessRule{}, &ResultInfo{}, ErrMissingResourceIdentifier
}
uri := buildURI(fmt.Sprintf("/%s/%s/firewall/access_rules/rules", rc.Level, rc.Identifier), params)
res, err := api.makeRequestContext(ctx, http.MethodGet, uri, nil)
if err != nil {
return []IPAccessRule{}, &ResultInfo{}, err
}
result := ListIPAccessRulesResponse{}
err = json.Unmarshal(res, &result)
if err != nil {
return []IPAccessRule{}, &ResultInfo{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}
return result.Result, &result.ResultInfo, nil
}