Universal Cloudflare tool for Strands Agents - manage Zones, DNS, Workers, KV, R2, D1, Pages, AI, Tunnels and other services.
Project description
strands-cloudflare
A universal Cloudflare tool for Strands Agents. Dynamically access the entire Cloudflare API through a single tool using the official cloudflare-python SDK.
Installation
pip install strands-cloudflare
Quick Start
from strands import Agent
from strands_cloudflare import use_cloudflare
agent = Agent(tools=[use_cloudflare])
agent("List all my Cloudflare zones")
Configuration
Set your Cloudflare credentials as environment variables:
# Option 1: API Token (recommended)
export CLOUDFLARE_API_TOKEN="your-api-token"
# Option 2: API Key + Email
export CLOUDFLARE_API_KEY="your-api-key"
export CLOUDFLARE_EMAIL="your-email@example.com"
# Optional defaults
export CLOUDFLARE_ACCOUNT_ID="your-account-id"
export CLOUDFLARE_ZONE_ID="your-zone-id"
How It Works
This tool dynamically maps to any cloudflare-python SDK method. Specify:
| Parameter | Description |
|---|---|
service |
SDK service path (e.g., zones, dns.records, workers.scripts) |
operation |
Method to call (e.g., list, get, create, delete, update) |
params |
JSON string of parameters for the operation |
account_id |
Cloudflare account ID (optional, uses env var if not set) |
zone_id |
Cloudflare zone ID (optional, uses env var if not set) |
Service Discovery
Use "_" to discover available services and operations:
# List all top-level services
use_cloudflare(service="_", operation="_")
# List operations available on a service
use_cloudflare(service="dns.records", operation="_")
Usage Examples
Zones
# List all zones
use_cloudflare(service="zones", operation="list")
# Get specific zone
use_cloudflare(service="zones", operation="get", zone_id="abc123")
DNS Records
# List DNS records
use_cloudflare(service="dns.records", operation="list", zone_id="abc123")
# Create DNS record
use_cloudflare(
service="dns.records",
operation="create",
zone_id="abc123",
params='{"type": "A", "name": "www", "content": "192.0.2.1", "proxied": true}'
)
# Update DNS record
use_cloudflare(
service="dns.records",
operation="update",
zone_id="abc123",
params='{"dns_record_id": "record-id", "type": "A", "name": "www", "content": "192.0.2.2"}'
)
# Delete DNS record
use_cloudflare(
service="dns.records",
operation="delete",
zone_id="abc123",
params='{"dns_record_id": "record-id"}'
)
Workers
# List Workers scripts
use_cloudflare(service="workers.scripts", operation="list", account_id="xyz")
# Get Worker script
use_cloudflare(
service="workers.scripts",
operation="get",
account_id="xyz",
params='{"script_name": "my-worker"}'
)
# List Worker routes
use_cloudflare(service="workers.routes", operation="list", zone_id="abc123")
KV Storage
# List KV namespaces
use_cloudflare(service="kv.namespaces", operation="list", account_id="xyz")
# Create KV namespace
use_cloudflare(
service="kv.namespaces",
operation="create",
account_id="xyz",
params='{"title": "MY_KV"}'
)
# List keys in namespace
use_cloudflare(
service="kv.namespaces.keys",
operation="list",
account_id="xyz",
params='{"namespace_id": "ns-id"}'
)
D1 Database
# List D1 databases
use_cloudflare(service="d1.database", operation="list", account_id="xyz")
# Query D1 database
use_cloudflare(
service="d1.database",
operation="query",
account_id="xyz",
params='{"database_id": "db-id", "sql": "SELECT * FROM users"}'
)
R2 Storage
# List R2 buckets
use_cloudflare(service="r2.buckets", operation="list", account_id="xyz")
# Create R2 bucket
use_cloudflare(
service="r2.buckets",
operation="create",
account_id="xyz",
params='{"name": "my-bucket"}'
)
Cloudflare Tunnels (Zero Trust)
# List tunnels
use_cloudflare(service="zero_trust.tunnels", operation="list", account_id="xyz")
# Create tunnel
use_cloudflare(
service="zero_trust.tunnels",
operation="create",
account_id="xyz",
params='{"name": "my-tunnel", "tunnel_secret": "base64-secret"}'
)
# Get tunnel config
use_cloudflare(
service="zero_trust.tunnels.configurations",
operation="get",
account_id="xyz",
params='{"tunnel_id": "tunnel-id"}'
)
Workers AI
# Run AI model
use_cloudflare(
service="ai",
operation="run",
account_id="xyz",
params='{"model_name": "@cf/meta/llama-2-7b-chat-int8", "prompt": "Hello, how are you?"}'
)
Cache
# Purge everything
use_cloudflare(
service="cache",
operation="purge",
zone_id="abc123",
params='{"purge_everything": true}'
)
# Purge specific URLs
use_cloudflare(
service="cache",
operation="purge",
zone_id="abc123",
params='{"files": ["https://example.com/style.css"]}'
)
Pages
# List Pages projects
use_cloudflare(service="pages.projects", operation="list", account_id="xyz")
# Get project details
use_cloudflare(
service="pages.projects",
operation="get",
account_id="xyz",
params='{"project_name": "my-site"}'
)
Service Reference
| Service Path | Description |
|---|---|
zones |
Zone management |
dns.records |
DNS record management |
workers.scripts |
Worker scripts |
workers.routes |
Worker routes |
kv.namespaces |
KV storage namespaces |
kv.namespaces.keys |
KV keys |
kv.namespaces.values |
KV values |
d1.database |
D1 SQL databases |
r2.buckets |
R2 object storage |
pages.projects |
Pages projects |
zero_trust.tunnels |
Cloudflare Tunnels |
zero_trust.access.applications |
Access applications |
firewall.rules |
Firewall rules |
cache |
Cache operations |
ssl.certificate_packs |
SSL certificates |
load_balancers |
Load balancers |
ai |
Workers AI |
queues |
Queues |
vectorize.indexes |
Vectorize indexes |
images.v1 |
Cloudflare Images |
stream |
Cloudflare Stream |
With Strands Agent
from strands import Agent
from strands_cloudflare import use_cloudflare
agent = Agent(tools=[use_cloudflare])
# Natural language queries work seamlessly
agent("Create a DNS A record for api.example.com pointing to 203.0.113.50")
agent("List all my Workers scripts")
agent("Purge the cache for my zone")
agent("List all Cloudflare tunnels in my account")
agent("Query my D1 database for all users")
Security
- API tokens/keys are never logged or included in responses
- Sensitive data (keys, tokens, secrets) is automatically redacted from output
- Use API tokens with minimal required permissions
Requirements
- Python 3.9+
strands-agentscloudflare
License
Apache License 2.0
Links
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file strands_cloudflare-0.2.0.tar.gz.
File metadata
- Download URL: strands_cloudflare-0.2.0.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e4ea3c5d9b190b349a332ed8641d484561adbf63786b42ffeff9ea27cf563410
|
|
| MD5 |
0a85580902ede3f6b7d29822162c1666
|
|
| BLAKE2b-256 |
95bc5f46d1ac367709e6ebdf5e13e0deab065910bd250f03b1c1f7837bc15643
|
File details
Details for the file strands_cloudflare-0.2.0-py3-none-any.whl.
File metadata
- Download URL: strands_cloudflare-0.2.0-py3-none-any.whl
- Upload date:
- Size: 11.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
03b982ee7c799136af6d57d56000efd90372cc2b303b1d631a9d62aa6f125aa4
|
|
| MD5 |
022b4e810249974816ae97e0c1cb0a09
|
|
| BLAKE2b-256 |
5c4b02fd0fd7fd25d579080b69c9891c352db64580bf6a5826e2822e5f54aadb
|