title | pcx_content_type | sidebar | head | |||||||
---|---|---|---|---|---|---|---|---|---|---|
Configure via API |
how-to |
|
|
import { APIRequest } from "~/components";
You can configure Cloud Connector rules using the Cloudflare API.
The API token used in API requests to manage Cloud Connector rules must have at least the following permission:
- Zone > Cloud Connector > Write
:::note
A token with this permission is only valid for the Cloud Connector endpoints described in this page. You cannot use it to interact with the http_cloud_connector
phase via Rulesets API.
:::
To obtain the complete endpoint, append the Cloud Connector endpoints listed below to the Cloudflare API base URL:
https://api.cloudflare.com/client/v4
The {zone_id}
argument is the zone ID (a hexadecimal string). You can find this value in the Cloudflare dashboard.
The following table summarizes the available operations.
Operation | Verb + Endpoint |
---|---|
List Cloud Connector rules | GET /zones/{zone_id}/cloud_connector/rules |
Create/update/delete Cloud Connector rules | PUT /zones/{zone_id}/cloud_connector/rules |
The following example returns a list of existing Cloud Connector rules:
{
"result": [
{
"id": "<RULE_1_ID>",
"provider": "aws_s3",
"expression": "http.request.uri.path wildcard \"/images/*\"",
"description": "Connect to S3 bucket containing images",
"enabled": true,
"parameters": {
"host": "examplebucketwithimages.s3.north-eu.amazonaws.com"
}
}
],
"success": true,
"errors": [],
"messages": []
}
:::caution To create a new rule and keep all existing rules, you must include them all in your request body. Omitting an existing rule in the request body will delete the corresponding Cloud Connector rule. :::
The following example request will replace all existing Cloud Connector rules with a single rule:
<APIRequest path="/zones/{zone_id}/cloud_connector/rules" method="PUT" json={[ { expression: 'http.request.uri.path wildcard "/images/*"', provider: "cloudflare_r2", description: "Connect to R2 bucket containing images", parameters: { host: "mybucketcustomdomain.example.com", }, }, ]} />
The required body parameters for each rule are: expression
, provider
, and parameters.host
.
The provider
value must be one of the following: cloudflare_r2
, aws_s3
, azure_storage
, and gcp_storage
.