API examples
Use the Rulesets API to configure custom rules via API.
The skip
action supports different skip options, according to the security features or products that you wish to skip.
This page contains examples of different skip rule scenarios for custom rules. Take the following into account:
-
The
$ZONE_ID
value is the ID of the zone where you want to add the rule. -
The
$RULESET_ID
value is the ID of the entry point ruleset of thehttp_request_firewall_custom
phase. For details on obtaining this ruleset ID, refer to List and view rulesets. The API examples in this page add a skip rule to an existing ruleset using the Create a zone ruleset rule operation.However, the entry point ruleset may not exist yet. In this case, invoke the Create a zone ruleset operation to create the entry point ruleset with a skip rule. Refer to Create ruleset for an example.
-
Although each example only includes one action parameter, you can use several skip options in the same rule by specifying the
ruleset
,phases
, andproducts
action parameters simultaneously.
This example invokes the Create a zone ruleset rule operation to add a skip rule to the existing http_request_firewall_custom
phase entry point ruleset with ID $RULESET_ID
. The rule will skip all remaining rules in the current ruleset for requests matching the rule expression.
Required API token permissions
At least one of the following token permissions
is required:
Response Compression Write
Config Settings Write
Dynamic URL Redirects Write
Cache Settings Write
Custom Errors Write
Origin Write
Managed headers Write
Zone Transform Rules Write
Mass URL Redirects Write
Magic Firewall Write
L4 DDoS Managed Ruleset Write
HTTP DDoS Managed Ruleset Write
Sanitize Write
Transform Rules Write
Select Configuration Write
Bot Management Write
Zone WAF Write
Account WAF Write
Account Rulesets Write
Logs Write
Logs Write
curl https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/$RULESET_ID/rules \ --request POST \ --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \ --json '{ "action": "skip", "action_parameters": { "ruleset": "current" }, "expression": "http.request.uri.path contains \"/skip-current-ruleset/\"", "description": "" }'
This example invokes the Create a zone ruleset rule operation to add a rule to the existing http_request_firewall_custom
phase entry point ruleset with ID $RULESET_ID
. The rule will skip the http_ratelimit
phase for requests matching the rule expression.
Required API token permissions
At least one of the following token permissions
is required:
Response Compression Write
Config Settings Write
Dynamic URL Redirects Write
Cache Settings Write
Custom Errors Write
Origin Write
Managed headers Write
Zone Transform Rules Write
Mass URL Redirects Write
Magic Firewall Write
L4 DDoS Managed Ruleset Write
HTTP DDoS Managed Ruleset Write
Sanitize Write
Transform Rules Write
Select Configuration Write
Bot Management Write
Zone WAF Write
Account WAF Write
Account Rulesets Write
Logs Write
Logs Write
curl https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/$RULESET_ID/rules \ --request POST \ --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \ --json '{ "action": "skip", "action_parameters": { "phases": [ "http_ratelimit" ] }, "expression": "http.request.uri.path contains \"/skip-phase/\"", "description": "" }'
Refer to Available skip options for the list of phases you can skip.
This example invokes the Create a zone ruleset rule operation to add a rule that:
- Skips the
http_ratelimit
phase - Disables event logging for the current rule
Required API token permissions
At least one of the following token permissions
is required:
Response Compression Write
Config Settings Write
Dynamic URL Redirects Write
Cache Settings Write
Custom Errors Write
Origin Write
Managed headers Write
Zone Transform Rules Write
Mass URL Redirects Write
Magic Firewall Write
L4 DDoS Managed Ruleset Write
HTTP DDoS Managed Ruleset Write
Sanitize Write
Transform Rules Write
Select Configuration Write
Bot Management Write
Zone WAF Write
Account WAF Write
Account Rulesets Write
Logs Write
Logs Write
curl https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/$RULESET_ID/rules \ --request POST \ --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \ --json '{ "action": "skip", "action_parameters": { "phases": [ "http_ratelimit" ] }, "logging": { "enabled": false }, "expression": "http.request.uri.path contains \"/disable-logging/\"", "description": "" }'
Refer to Available skip options: Logging for more information on disabling logging for requests that match a skip rule.
This example uses the Create a zone ruleset rule operation to add a rule that skips the Zone Lockdown and User Agent Blocking products for requests matching the rule expression.
Required API token permissions
At least one of the following token permissions
is required:
Response Compression Write
Config Settings Write
Dynamic URL Redirects Write
Cache Settings Write
Custom Errors Write
Origin Write
Managed headers Write
Zone Transform Rules Write
Mass URL Redirects Write
Magic Firewall Write
L4 DDoS Managed Ruleset Write
HTTP DDoS Managed Ruleset Write
Sanitize Write
Transform Rules Write
Select Configuration Write
Bot Management Write
Zone WAF Write
Account WAF Write
Account Rulesets Write
Logs Write
Logs Write
curl https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/$RULESET_ID/rules \ --request POST \ --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \ --json '{ "action": "skip", "action_parameters": { "products": [ "zoneLockdown", "uaBlock" ] }, "expression": "http.request.uri.path contains \"/skip-products/\"", "description": "" }'
Refer to Available skip options for the list of products you can skip.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark