Get started
Having access to Cloudflare’s provisioning capabilities allows you to more easily create and manage Cloudflare accounts. The following steps will get you started on making API calls to provision accounts, users, and services.
Before using the Tenant API, you need to create an account, verify your email address, and add your billing information.
After you sign your partner agreement with Cloudflare, Cloudflare will add certain entitlements to your account that allow you to provision and manage custom accounts. If you have signed your partner agreement and your account has not yet been enabled, contact partners@cloudflare.com.
You also need to retrieve your API key to authenticate your requests to the Tenant API.
For more details on using the Cloudflare API, refer to our API overview.
Each customer or team that uses Cloudflare should have their own account. This ensures proper security and access of resources. Each account acts as a container of zones and other resources. Depending on your needs, you may even provision multiple accounts for a single customer or team.
When you create an account with the Tenant API, your Cloudflare user owns that account from creation, ongoing management, and finally deletion.
To create an account under your tenant using the dashboard:
- Log into the Cloudflare dashboard ↗.
- Go to Tenants > Managed Accounts.
- Select Create Account.
- Enter the Account Name, Account Description, and Tenant Unit.
- Choose the appropriate account subscription.
- Select Add Account.
To create an account using the API, make a POST request to the /accounts endpoint and include the following values:
- 
namestring- The name of the account that is displayed in the Cloudflare dashboard.
 
- 
typeenum- Valid values are standard(default) andenterprise. For self-serve customers, usestandard. For enterprise customers, useenterprise.
 
- Valid values are 
- 
unitobject- 
Information related to the tenant unit. 
- 
idstring- (optional) ID of the unit to create this account on. Needs to be specified if user administers multiple tenants. Unit ID is the unit_tagfrom your tenant details.
 
- (optional) ID of the unit to create this account on. Needs to be specified if user administers multiple tenants. Unit ID is the 
 
- 
All KYC parameters are text fields, have a 120 character limit, and are optional unless enforced by the Tenant.
- 
business_namestring- (optional) The name of the business associated with this account.
 
- 
business_addressstring- (optional) The address of the business associated with this account.
 
- 
business_emailstring- (optional) The email of the business associated with this account.
 
- 
business_phonestring- (optional) The phone number of the business associated with this account.
 
- 
external_metadatastring- (optional) External metadata for this account.
 
curl "https://api.cloudflare.com/client/v4/accounts" \--header "X-Auth-Email: <EMAIL>" \--header "X-Auth-Key: <API_KEY>" \--header "Content-Type: application/json" \--data '{  "name": "<ACCOUNT_NAME>",  "type": "standard"}'A successful request will return an HTTP status of 200 and the following response body:
{  "result": {    "id": "2bab6ace8c72ed3f09b9eca6db1396bb",    "name": "<ACCOUNT_NAME>",    "type": "standard",    "settings": {      "enforce_twofactor": false    }  },  "success": true,  "errors": [],  "messages": []}A request with a unit ID:
curl "https://api.cloudflare.com/client/v4/accounts" \--header "X-Auth-Email: <EMAIL>" \--header "X-Auth-Key: <API_KEY>" \--header "Content-Type: application/json" \--data '{  "name": "<ACCOUNT_NAME>",  "type": "standard",  "unit": {    "id": "1a2b3c4d5e6f7g8h"  }}'A request with a unit ID and KYC:
curl "https://api.cloudflare.com/client/v4/accounts" \--header "X-Auth-Email: <EMAIL>" \--header "X-Auth-Key: <API_KEY>" \--header "Content-Type: application/json" \--data '{  "name": "<ACCOUNT_NAME>",  "type": "standard",  "business_name": "Cloudflare",  "business_email": "email@business.com",  "business_address": "San Francisco",  "business_phone": "1234567890",  "external_metadata": "{'\''testKey'\'': '\''testValue'\''}",  "unit": {    "id": "1a2b3c4d5e6f7g8h"  }}'Now that you have created an account, you need to either give your customer direct access to Cloudflare or build an interface for them to interact with.
The first method gives customers control over all aspects of Cloudflare, while the latter allows you to integrate your customer's Cloudflare experience into a dashboard that you control and that they may already be familiar with.
When you grant user access to an account, Cloudflare will send an invitation to the user so they can get access to the account. If they do not already have a Cloudflare user, Cloudflare will take them through the process of creating one. Once created, they will be given access to the account and any zones already created.
If you want to give customers access to their individual accounts, it is the same as if you were inviting a teammate to help manage your account.
You can also grant access to the Cloudflare dashboard by using the API.
curl 'https://api.cloudflare.com/client/v4/accounts/<CUSTOMER_ACCOUNT_ID>/members' \--header "X-Auth-Email: <EMAIL>" \--header "X-Auth-Key: <API_KEY>" \--header "Content-Type: application/json" \--data '{  "email": "<CUSTOMER_EMAIL>",  "roles": ["<USER_ROLE>"]}'In most cases, you will want to create new users with a role of Administrator which always has the ID 05784afa30c1afe1440e79d9351c7430.
If your customer is on an Enterprise plan, they have access to a broader set of user roles. To get a full list of available roles, send a GET request to the API.
If you want greater control over how customers use Cloudflare or if you want your customers to use an existing dashboard of yours that they already know, use the Cloudflare API to build this experience.
This means that you will be making API calls to Cloudflare on behalf of your customers. To avoid getting rate limited by our API, Cloudflare recommend that you create accounts and users for each of your customers. Changes made by customer A should go through user A and changes made by customer B should go through user B.
To grant access via an interface, you need to create a service user, as no one will log in to the dashboard with them. If you are planning to use this method, Cloudflare will enable you to see the API key in order to make API calls as this user.
curl "https://api.cloudflare.com/client/v4/users" \--header "X-Auth-Email: <EMAIL>" \--header "X-Auth-Key: <API_KEY>" \--header "Content-Type: application/json" \--data '{  "email": "<ID@example.com>"}'{  "result": {    "id": "60758bd48392a06215ae817bc35084b6",    "email": "<ID@example.com>",    "first_name": null,    "last_name": null,    "username": "17bd2796b374cec14976ac3bced85c05",    "telephone": null,    "country": null,    "created_on": "2019-02-21T23:20:28.645256Z",    "modified_on": "2019-02-21T23:20:28.645256Z",    "two_factor_authentication": {      "enabled": false,      "locked": false    },    "api_key": "xxx"  },  "success": true,  "errors": [],  "messages": []}Now that you have a customer account and customer users (or service users), you need to create a zone.
To do this, send a POST request to the /zones endpoint (including the customer account ID you received in Step 1).
curl "https://api.cloudflare.com/client/v4/zones" \--header "X-Auth-Email: <EMAIL>" \--header "X-Auth-Key: <API_KEY>" \--header "Content-Type: application/json" \--data '{  "name": "example.com",  "account": {    "id": "<CUSTOMER_ACCOUNT_ID>"  }}'Now that you have a zone provisioned for the customer, you can add the appropriate zone plan based on your reseller agreement.
To create a zone subscription, typically used to upgrade a zone's plan from PARTNERS_FREE to a paid Zone plan, send a POST request to the /zones/{zone_id}/subscription endpoint and include the following values:
- 
rate_planobject- Contains the zone plan corresponding to what customers would order in the dashboard. For a list of available values, refer to Zone subscriptions.
 
- 
component_valuesarray- Additional services depending on your reseller agreement, such as additional page_rules.
 
- Additional services depending on your reseller agreement, such as additional 
- 
frequencystring- How often the subscription is renewed automatically (defaults to "monthly").
 
- How often the subscription is renewed automatically (defaults to 
curl 'https://api.cloudflare.com/client/v4/zones/{zone_id}/subscription' \--header "Authorization: Bearer <API_TOKEN>" \--header "Content-Type: application/json" \--data '{  "rate_plan": {    "id": "<RATE_PLAN>"  },  "frequency": "annual"}'curl 'https://api.cloudflare.com/client/v4/zones/{zone_id}/subscription' \--header "Authorization: Bearer <API_TOKEN>" \--header "Content-Type: application/json" \--data '{  "rate_plan": {    "id": "PARTNERS_BIZ"  },  "component_values": [    {      "name": "page_rules",      "value": 50    }  ]}Depending on your agreement, you may be allowed to resell other add-on services. These are provisioned as account-level subscriptions.
To create an account subscription, send a POST request to the /accounts/{account_id}/subscriptions endpoint and include the following values:
- 
rate_planobject- Contains the account subscription corresponding to a specific add-on service. For a list of available values, refer to Available subscriptions.
 
- 
component_valuesarray- Additional services depending on your reseller agreement, such as additional endpoints for load balancing or additional seats for Cloudflare Zero Trust. If not included, the subscription includes the default values associated with each purchase.
 
- 
frequencystring- How often the subscription is renewed automatically (defaults to "monthly").
 
- How often the subscription is renewed automatically (defaults to 
curl 'https://api.cloudflare.com/client/v4/accounts/{account_id}/subscriptions' \--header "Authorization: Bearer <API_TOKEN>" \--header "Content-Type: application/json" \--data '{  "rate_plan": {    "id": "<RATE_PLAN_NAME>"  }}'Once you have added the necessary subscriptions, you or your customer can move on to configuring various services and fine-tuning account and zone settings.
Configuration can be done by anyone with access to the account (as well as the correct user permissions). This process does not differ from configuring any other Cloudflare account. For additional guidance, refer to our Product docs.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark