Zone-level
When you enable Authenticated Origin Pulls (AOP) for a zone, all proxied traffic to your zone is authenticated at the origin web server.
Make sure your zone is using an SSL/TLS encryption mode of Full or higher.
First, upload a certificate to your origin.
To use a Cloudflare certificate (which uses a specific CA), download the .PEM file and upload it to your origin. This certificate is not the same as the Cloudflare origin CA certificate and will not appear on your Dashboard.
To use a custom certificate, follow the API instructions to upload a custom certificate to Cloudflare, but use the origin_tls_client_auth endpoint. Then, upload the certificate to your origin.
With the certificate installed, set up your origin web server to accept client certificates.
Check the examples below for Apache and NGINX or refer to your origin web server documentation - e.g. HAProxy ↗, Traefik ↗, Caddy ↗.
Apache example
 SSLVerifyDepth 1SSLCACertificateFile /path/to/origin-pull-ca.pemFor this example, you would have saved your certificate to /path/to/origin-pull-ca.pem.
NGINX example
 ssl_verify_client optional;ssl_client_certificate /etc/nginx/certs/cloudflare.crt;For this example, you would have saved your certificate to /etc/nginx/certs/cloudflare.crt.
At this point, you may also want to enable logging on your origin so that you can verify the configuration is working.
Then, enable the Authenticated Origin Pulls feature as an option for your Cloudflare zone.
This step sets the TLS Client Auth to require Cloudflare to use a client certificate when connecting to your origin server.
To enable Authenticated Origin Pulls in the dashboard:
- Log in to your Cloudflare account ↗ and go to a specific domain.
- Go to SSL/TLS > Origin Server.
- For Authenticated Origin Pulls, switch the toggle to On.
To enable or disable Authenticated Origin Pulls with the API, send a PATCH request with tls_client_auth as the setting name in the URI path, and the value parameter set to your desired setting ("on" or "off").
Use the Cloudflare API to send a PUT request to enable zone-level authenticated origin pulls.
If you had set up logging on your origin during step 2, test and confirm that Authenticated Origin Pulls is working.
Once you can confirm everything is working as expected for your specific origin setup, configure your origin to enforce the authentication.
Apache example
 SSLVerifyClient requireNGINX example
 ssl_verify_client on;After completing the process, you can use curl to send requests directly to your origin IPs, verifying that the requests fail due to certificate validation being enforced.
You can configure alerts to receive notifications before your AOP certificates expire.
Zone-level Authenticated Origin Pulls Certificate Expiration Alert
 Who is it for?Customers that upload their own certificate to use with zone-level Authenticated Origin Pull (AOP) to secure connections from Cloudflare to their origin server. AOP certificate expiration notifications are sent 30 days and 14 days before the certificate expiry.
Other options / filtersNone.
Included withAuthenticated Origin Pull.
What should you do if you receive one?Upload a renewed certificate to use for zone-level AOP.
Refer to Cloudflare Notifications for more information on how to set up an alert.
Refer to Manage certificates for further options.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- 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