Create a redirect rule via API
Use the Rulesets API to create a redirect rule via API.
Add redirect rules to the entry point ruleset of the http_request_dynamic_redirect phase at the zone level. Refer to the Rulesets API documentation for more information on creating a ruleset and supplying a list of rules for the ruleset.
 Basic rule settings
A redirect rule must have:
actionset toredirect- An 
action_parametersobject with additional configuration settings — refer to Available settings for details. 
 Example requests
The following request of the Create a zone ruleset operation creates a phase entry point ruleset for the http_request_dynamic_redirect phase at the zone level, and defines a single redirect rule with a dynamic URL redirect. Use this operation if you have not created a phase entry point ruleset for the http_request_dynamic_redirect phase yet.
Requestcurl https://api.cloudflare.com/client/v4/zones/{zone_id}/rulesets \
--header "Authorization: Bearer <API_TOKEN>" \
--header "Content-Type: application/json" \
--data '{  "name": "Redirect rules ruleset",  "kind": "zone",  "phase": "http_request_dynamic_redirect",  "rules": [    {      "expression": "(ip.geoip.country eq \"GB\" or ip.geoip.country eq \"FR\") and http.request.uri.path eq \"/\"",      "description": "Redirect GB and FR users in home page to localized site.",      "action": "redirect",      "action_parameters": {        "from_value": {          "target_url": {            "expression": "lower(concat(\"https://\", ip.geoip.country, \".example.com\"))"          },          "status_code": 307,          "preserve_query_string": true        }      }    }  ]}'
Response
{"result": {"id": "528f4f03bf0da53a29907199625867be","name": "Redirect rules ruleset","kind": "zone","version": "1","rules": [{"id": "235e557b92fd4e5e8753ee665a9ddd75","version": "1","expression": "(ip.geoip.country eq \"GB\" or ip.geoip.country eq \"FR\") and http.request.uri.path eq \"/\"","description": "Redirect GB and FR users in home page to localized site.","action": "redirect","action_parameters": {"from_value": {"target_url": {"expression": "lower(concat(\"https://\", ip.geoip.country, \".example.com\"))"},"status_code": 307,"preserve_query_string": true}},"last_updated": "2022-09-28T09:20:42Z",}],"last_updated": "2022-09-28T09:20:42Z","phase": "http_request_dynamic_redirect"},"success": true,"errors": [],"messages": []}
If there is already a phase entry point ruleset for the http_request_dynamic_redirect phase, use the Update a zone ruleset operation instead, like in the following example:
Requestcurl --request PUT \https://api.cloudflare.com/client/v4/zones/{zone_id}/rulesets/{ruleset_id} \
--header "Authorization: Bearer <API_TOKEN>" \
--header "Content-Type: application/json" \
--data '{  "name": "Redirect rules ruleset",  "kind": "zone",  "phase": "http_request_dynamic_redirect",  "rules": [    {      "expression": "(ip.geoip.country eq \"GB\" or ip.geoip.country eq \"FR\") and http.request.uri.path eq \"/\"",      "description": "Redirect GB and FR users in home page to localized site.",      "action": "redirect",      "action_parameters": {        "from_value": {          "target_url": {            "expression": "lower(concat(\"https://\", ip.geoip.country, \".example.com\"))"          },          "status_code": 307,          "preserve_query_string": true        }      }    },    {      "expression": "http.request.uri.path eq \"/contacts.html\"",      "description": "Redirect to new contacts page.",      "action": "redirect",      "action_parameters": {        "from_value": {          "target_url": {            "value": "https://example.com/contact-us/"          },          "status_code": 308        }      }    }  ]}'
Response
{"result": {"id": "528f4f03bf0da53a29907199625867be","name": "Redirect rules ruleset","description": "","kind": "zone","version": "2","rules": [{"id": "235e557b92fd4e5e8753ee665a9ddd75","version": "1","action": "redirect","action_parameters": {"from_value": {"target_url": {"expression": "lower(concat(\"https://\", ip.geoip.country, \".example.com\"))"},"status_code": 307,"preserve_query_string": true}},"expression": "(ip.geoip.country eq \"GB\" or ip.geoip.country eq \"FR\") and http.request.uri.path eq \"/\"","description": "Redirect GB and FR users in home page to localized site.","last_updated": "2022-10-03T15:38:51.658387Z","ref": "235e557b92fd4e5e8753ee665a9ddd75","enabled": true},{"id": "cfad5efbfcd1440fb5b30cf30f95ece3","version": "1","action": "redirect","action_parameters": {"from_value": {"target_url": {"value": "https://example.com/contact-us/"},"status_code": 308}},"expression": "http.request.uri.path eq \"/contacts.html\"","description": "Redirect to new contacts page.","last_updated": "2022-10-03T15:38:51.658387Z","ref": "cfad5efbfcd1440fb5b30cf30f95ece3","enabled": true}],"last_updated": "2022-10-03T15:38:51.658387Z","phase": "http_request_dynamic_redirect"},"success": true,"errors": [],"messages": []}
 Required API token permissions
The API token used in API requests to manage redirect rules must have at least the following permission:
- Zone > Dynamic Redirect > Edit