---
title: Configure Cloud Connector rules using Terraform
description: Create Cloud Connector rules using the Terraform Cloudflare provider.
image: https://developers.cloudflare.com/core-services-preview.png
---

> Documentation Index  
> Fetch the complete documentation index at: https://developers.cloudflare.com/rules/llms.txt  
> Use this file to discover all available pages before exploring further. 

[Skip to content](#%5Ftop) 

# Configure Cloud Connector rules using Terraform

You can create Cloud Connector rules using the [Terraform Cloudflare provider ↗](https://registry.terraform.io/providers/cloudflare/cloudflare/latest).

To get started with Terraform for Cloudflare configuration, refer to [Get started](https://developers.cloudflare.com/terraform/installing/).

## Required permissions

The [API token](https://developers.cloudflare.com/fundamentals/api/get-started/create-token/) used by Terraform must have at least the following permission:

* _Zone_ \> _Cloud Connector_ \> _Write_

## Example configuration

Note

Terraform code snippets below refer to the v4 SDK only.

The following example Terraform configuration creates Cloud Connector rules for various [supported providers](https://developers.cloudflare.com/rules/cloud-connector/providers/) to route traffic between them based on URI paths:

```
resource "cloudflare_cloud_connector_rules" "cloud_connector_rules" {  zone_id = "<ZONE_ID>"
  rules {    description = "Route /data to GCP bucket"    enabled     = true    expression  = "(http.request.uri.path wildcard \"*/data/*\")"    provider    = "gcp_storage"    parameters {      host = "mystorage.storage.googleapis.com"    }  }
  rules {    description = "Route /resources to AWS bucket"    enabled     = true    expression  = "(http.request.uri.path wildcard \"*/resources/*\")"    provider    = "aws_s3"    parameters {      host = "mystorage.s3.ams.amazonaws.com"    }  }
  rules {    description = "Route /files to Azure bucket"    enabled     = true    expression  = "(http.request.uri.path wildcard \"*/files/*\")"    provider    = "azure_storage"    parameters {      host = "mystorage.blob.core.windows.net"    }  }
  rules {    description = "Route /images to R2 bucket"    enabled     = true    expression  = "(http.request.uri.path wildcard \"*/images/*\")"    provider    = "cloudflare_r2"    parameters {      host = "mybucketcustomdomain.example.com"    }  }}
```

## More resources

Refer to the [Terraform Cloudflare provider documentation ↗](https://registry.terraform.io/providers/cloudflare/cloudflare/latest/docs) for more information on the `cloudflare_cloud_connector_rules` resource.

```json
{"@context":"https://schema.org","@type":"TechArticle","@id":"https://developers.cloudflare.com/rules/cloud-connector/create-terraform/#page","headline":"Configure Cloud Connector rules using Terraform · Cloudflare Rules docs","description":"Create Cloud Connector rules using the Terraform Cloudflare provider.","url":"https://developers.cloudflare.com/rules/cloud-connector/create-terraform/","inLanguage":"en","image":"https://developers.cloudflare.com/core-services-preview.png","dateModified":"2026-05-05","publisher":{"@type":"Organization","name":"Cloudflare","url":"https://www.cloudflare.com/"},"isPartOf":{"@type":"WebSite","@id":"https://developers.cloudflare.com/#website","name":"Cloudflare Docs","url":"https://developers.cloudflare.com/"},"keywords":["Terraform","AWS","Azure"]}
{"@context":"https://schema.org","@type":"BreadcrumbList","itemListElement":[{"@type":"ListItem","position":1,"item":{"@id":"/directory/","name":"Directory"}},{"@type":"ListItem","position":2,"item":{"@id":"/rules/","name":"Rules"}},{"@type":"ListItem","position":3,"item":{"@id":"/rules/cloud-connector/","name":"Cloud Connector"}},{"@type":"ListItem","position":4,"item":{"@id":"/rules/cloud-connector/create-terraform/","name":"Configure Cloud Connector rules using Terraform"}}]}
```
