package cloudflare import ( "encoding/json" "time" "github.com/pkg/errors" ) /* PageRuleTarget is the target to evaluate on a request. Currently Target must always be "url" and Operator must be "matches". Value is the URL pattern to match against. */ type PageRuleTarget struct { Target string `json:"target"` Constraint struct { Operator string `json:"operator"` Value string `json:"value"` } `json:"constraint"` } /* PageRuleAction is the action to take when the target is matched. Valid IDs are: always_online always_use_https browser_cache_ttl browser_check cache_level disable_apps disable_performance disable_railgun disable_security edge_cache_ttl email_obfuscation forwarding_url ip_geolocation mirage rocket_loader security_level server_side_exclude smart_errors ssl waf */ type PageRuleAction struct { ID string `json:"id"` Value interface{} `json:"value"` } // PageRuleActions maps API action IDs to human-readable strings var PageRuleActions = map[string]string{ "always_online": "Always Online", // Value of type string "always_use_https": "Always Use HTTPS", // Value of type interface{} "browser_cache_ttl": "Browser Cache TTL", // Value of type int "browser_check": "Browser Integrity Check", // Value of type string "cache_level": "Cache Level", // Value of type string "disable_apps": "Disable Apps", // Value of type interface{} "disable_performance": "Disable Performance", // Value of type interface{} "disable_railgun": "Disable Railgun", // Value of type string "disable_security": "Disable Security", // Value of type interface{} "edge_cache_ttl": "Edge Cache TTL", // Value of type int "email_obfuscation": "Email Obfuscation", // Value of type string "forwarding_url": "Forwarding URL", // Value of type map[string]interface "ip_geolocation": "IP Geolocation Header", // Value of type string "mirage": "Mirage", // Value of type string "rocket_loader": "Rocker Loader", // Value of type string "security_level": "Security Level", // Value of type string "server_side_exclude": "Server Side Excludes", // Value of type string "smart_errors": "Smart Errors", // Value of type string "ssl": "SSL", // Value of type string "waf": "Web Application Firewall", // Value of type string } // PageRule describes a Page Rule. type PageRule struct { ID string `json:"id,omitempty"` Targets []PageRuleTarget `json:"targets"` Actions []PageRuleAction `json:"actions"` Priority int `json:"priority"` Status string `json:"status"` // can be: active, paused ModifiedOn time.Time `json:"modified_on,omitempty"` CreatedOn time.Time `json:"created_on,omitempty"` } // PageRuleDetailResponse is the API response, containing a single PageRule. type PageRuleDetailResponse struct { Success bool `json:"success"` Errors []string `json:"errors"` Messages []string `json:"messages"` Result PageRule `json:"result"` } // PageRulesResponse is the API response, containing an array of PageRules. type PageRulesResponse struct { Success bool `json:"success"` Errors []string `json:"errors"` Messages []string `json:"messages"` Result []PageRule `json:"result"` } /* CreatePageRule creates a new Page Rule for a zone. API reference: https://api.cloudflare.com/#page-rules-for-a-zone-create-a-page-rule POST /zones/:zone_identifier/pagerules */ func (api *API) CreatePageRule(zoneID string, rule PageRule) error { uri := "/zones/" + zoneID + "/pagerules" res, err := api.makeRequest("POST", uri, rule) if err != nil { return errors.Wrap(err, errMakeRequestError) } var r PageRuleDetailResponse err = json.Unmarshal(res, &r) if err != nil { return errors.Wrap(err, errUnmarshalError) } return nil } /* ListPageRules returns all Page Rules for a zone. API reference: https://api.cloudflare.com/#page-rules-for-a-zone-list-page-rules GET /zones/:zone_identifier/pagerules */ func (api *API) ListPageRules(zoneID string) ([]PageRule, error) { uri := "/zones/" + zoneID + "/pagerules" res, err := api.makeRequest("GET", uri, nil) if err != nil { return []PageRule{}, errors.Wrap(err, errMakeRequestError) } var r PageRulesResponse err = json.Unmarshal(res, &r) if err != nil { return []PageRule{}, errors.Wrap(err, errUnmarshalError) } return r.Result, nil } /* PageRule fetches detail about one Page Rule for a zone. API reference: https://api.cloudflare.com/#page-rules-for-a-zone-page-rule-details GET /zones/:zone_identifier/pagerules/:identifier */ func (api *API) PageRule(zoneID, ruleID string) (PageRule, error) { uri := "/zones/" + zoneID + "/pagerules/" + ruleID res, err := api.makeRequest("GET", uri, nil) if err != nil { return PageRule{}, errors.Wrap(err, errMakeRequestError) } var r PageRuleDetailResponse err = json.Unmarshal(res, &r) if err != nil { return PageRule{}, errors.Wrap(err, errUnmarshalError) } return r.Result, nil } /* ChangePageRule lets change individual settings for a Page Rule. This is in contrast to UpdatePageRule which replaces the entire Page Rule. API reference: https://api.cloudflare.com/#page-rules-for-a-zone-change-a-page-rule PATCH /zones/:zone_identifier/pagerules/:identifier */ func (api *API) ChangePageRule(zoneID, ruleID string, rule PageRule) error { uri := "/zones/" + zoneID + "/pagerules/" + ruleID res, err := api.makeRequest("PATCH", uri, rule) if err != nil { return errors.Wrap(err, errMakeRequestError) } var r PageRuleDetailResponse err = json.Unmarshal(res, &r) if err != nil { return errors.Wrap(err, errUnmarshalError) } return nil } /* UpdatePageRule lets you replace a Page Rule. This is in contrast to ChangePageRule which lets you change individual settings. API reference: https://api.cloudflare.com/#page-rules-for-a-zone-update-a-page-rule PUT /zones/:zone_identifier/pagerules/:identifier */ func (api *API) UpdatePageRule(zoneID, ruleID string, rule PageRule) error { uri := "/zones/" + zoneID + "/pagerules/" + ruleID res, err := api.makeRequest("PUT", uri, nil) if err != nil { return errors.Wrap(err, errMakeRequestError) } var r PageRuleDetailResponse err = json.Unmarshal(res, &r) if err != nil { return errors.Wrap(err, errUnmarshalError) } return nil } /* DeletePageRule deletes a Page Rule for a zone. API reference: https://api.cloudflare.com/#page-rules-for-a-zone-delete-a-page-rule DELETE /zones/:zone_identifier/pagerules/:identifier */ func (api *API) DeletePageRule(zoneID, ruleID string) error { uri := "/zones/" + zoneID + "/pagerules/" + ruleID res, err := api.makeRequest("DELETE", uri, nil) if err != nil { return errors.Wrap(err, errMakeRequestError) } var r PageRuleDetailResponse err = json.Unmarshal(res, &r) if err != nil { return errors.Wrap(err, errUnmarshalError) } return nil }