https://github.com/cloudflare/terraform-provider-cloudflare
Cloudflare Terraform Provider
https://github.com/cloudflare/terraform-provider-cloudflare
cloudflare terraform terraform-provider
Last synced: about 9 hours ago
JSON representation
Cloudflare Terraform Provider
- Host: GitHub
- URL: https://github.com/cloudflare/terraform-provider-cloudflare
- Owner: cloudflare
- License: apache-2.0
- Created: 2017-06-05T20:54:12.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2025-05-13T01:31:35.000Z (1 day ago)
- Last Synced: 2025-05-13T01:34:58.090Z (1 day ago)
- Topics: cloudflare, terraform, terraform-provider
- Language: Go
- Homepage: https://registry.terraform.io/providers/cloudflare/cloudflare
- Size: 69.5 MB
- Stars: 1,042
- Watchers: 46
- Forks: 678
- Open Issues: 102
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-list - terraform-provider-cloudflare
README
# Cloudflare Terraform Provider
The [Cloudflare Terraform provider](https://registry.terraform.io/providers/cloudflare/cloudflare/latest/docs) provides convenient access to
the [Cloudflare REST API](https://developers.cloudflare.com/api) from Terraform.## Requirements
This provider requires Terraform CLI 1.0 or later. You can [install it for your system](https://developer.hashicorp.com/terraform/install)
on Hashicorp's website.## Usage
Add the following to your `main.tf` file:
```hcl
# Declare the provider and version
terraform {
required_providers {
cloudflare = {
source = "cloudflare/cloudflare"
version = "~> 5.0.0"
}
}
}# Initialize the provider
provider "cloudflare" {
# The preferred authorization scheme for interacting with the Cloudflare API. [Create a token](https://developers.cloudflare.com/fundamentals/api/get-started/create-token/).
api_token = "Sn3lZJTBX6kkg7OdcBUAxOO963GEIyGQqnFTOFYY" # or set CLOUDFLARE_API_TOKEN env variable
# The previous authorization scheme for interacting with the Cloudflare API. When possible, use API tokens instead of Global API keys.
api_key = "144c9defac04969c7bfad8efaa8ea194" # or set CLOUDFLARE_API_KEY env variable
# The previous authorization scheme for interacting with the Cloudflare API, used in conjunction with a Global API key.
api_email = "[email protected]" # or set CLOUDFLARE_EMAIL env variable
# Used when interacting with the Origin CA certificates API. [View/change your key](https://developers.cloudflare.com/fundamentals/api/get-started/ca-keys/#viewchange-your-origin-ca-keys).
user_service_key = "v1.0-144c9defac04969c7bfad8ef-631a41d003a32d25fe878081ef365c49503f7fada600da935e2851a1c7326084b85cbf6429c4b859de8475731dc92a9c329631e6d59e6c73da7b198497172b4cefe071d90d0f5d2719" # or set CLOUDFLARE_API_USER_SERVICE_KEY env variable
}# Configure a resource
resource "cloudflare_zone" "example_zone" {
account = {
id = "023e105f4ecef8ad9ca31a8372d0c353"
}
name = "example.com"
type = "full"
}
```Initialize your project by running `terraform init` in the directory.
Additional examples can be found in the [./examples](./examples) folder within this repository, and you can
refer to the full documentation on [the Terraform Registry](https://registry.terraform.io/providers/cloudflare/cloudflare/latest/docs).### Provider Options
When you initialize the provider, the following options are supported. It is recommended to use environment variables for sensitive values like access tokens.
If an environment variable is provided, then the option does not need to be set in the terraform source.| Property | Environment variable | Required | Default value |
| ---------------- | --------------------------------- | -------- | ------------- |
| user_service_key | `CLOUDFLARE_API_USER_SERVICE_KEY` | false | — |
| api_token | `CLOUDFLARE_API_TOKEN` | false | — |
| api_key | `CLOUDFLARE_API_KEY` | false | — |
| api_email | `CLOUDFLARE_EMAIL` | false | — |## Semantic versioning
This package generally follows [SemVer](https://semver.org/spec/v2.0.0.html) conventions, though certain backwards-incompatible changes may be released as minor versions:
1. Changes to library internals which are technically public but not intended or documented for external use. _(Please open a GitHub issue to let us know if you are relying on such internals.)_
2. Changes that we do not expect to impact the vast majority of users in practice.We take backwards-compatibility seriously and work hard to ensure you can rely on a smooth upgrade experience.
We are keen for your feedback; please open an [issue](https://www.github.com/cloudflare/terraform-provider-cloudflare/issues) with questions, bugs, or suggestions.
## Maintenance
This SDK is actively maintained, however, many issues are tracked outside of GitHub on internal Cloudflare systems. Members of the community are welcome to join and discuss your issues during our weekly triage meetings. For urgent issues, please contact [Cloudflare support](https://www.support.cloudflare.com/s/?language=en_US).
* [Community triage meeting](https://calendar.google.com/calendar/embed?src=c_dbf6ce250643f2e60f806d28f3fc09a9de24cbe0ab3ffb699838303d2adfc9e4%40group.calendar.google.com&ctz=America%2FLos_Angeles)
## Contributing
See [the contributing documentation](./CONTRIBUTING.md).