Order of enforcement
With Cloudflare Gateway, you can enable and configure any combination of DNS, network, and HTTP policies.
flowchart TB
    %% Accessibility
    accTitle: Gateway order of enforcement
    accDescr: Flowchart describing the order of enforcement for Gateway policies.
 subgraph Resolution["Resolution"]
        dns2["1.1.1.1"]
        dns4["Custom resolver"]
        dns3["Resolver policies <br>(Enterprise users only)"]
        internal["Internal DNS"]
  end
 subgraph DNS["DNS"]
        dns1["DNS policies"]
        Resolution
  end
 subgraph HTTP["HTTP policies"]
        http1{{"Do Not Inspect policies"}}
        http2["Isolate policies  <br>(with Browser Isolation add-on)"]
        http3["Allow, Block, Do Not Scan, Quarantine, and Redirect policies, DLP, and anti-virus scanning"]
        https["HTTP (port 80) or<br>HTTPS (port 443)?"]
  end
 subgraph Proxy["Proxy"]
        HTTP
        network1["Network policies"]
        nonhttp["Non-HTTP(S) traffic"]
  end
 subgraph Egress["Egress"]
        egress1["Egress policies <br>(Enterprise users only)"]
  end
    start(["Traffic"]) --> dns0[/"DNS query"/] & http0["Network connections"]
    dns0 ----> dns1
    dns1 -- Resolved by --> dns2
    dns1 --> dns3
    dns3 -- Resolved by --> dns4
    dns2 -----> internet(["Internet"])
    dns4 -----> internet
    dns4 ---> cloudflare["Private network services <br>(Cloudflare Tunnel, Magic WAN, WARP Connector)"]
    http1 -- Do Not Inspect --> internet
    http1 -- Inspect --> http2
    http2 --> http3
    http0 --> magic["Magic Firewall (Enterprise users only)"]
    magic --> egress1
    egress1 --> tcp["Check for origin availability (TCP SYN)"]
    tcp --> network1
    http3 --> internet
    https -- HTTPS --> http1
    https -- HTTP --> http2
    network1 --> https & nonhttp
    dns3 -- Resolved by --> internal & dns2
    nonhttp -----> internet
    https@{ shape: hex}
    http0@{ shape: lean-r}
When a user connects to a server with Gateway, Gateway first establishes a TCP connection with the destination server on the port the user requested. Because TCP traffic is proxied by Cloudflare, the connection Gateway establishes with the origin is independent from the connection users establish with Gateway. This means Gateway assigns a new source IP and port to the user's connection and no details from the user's TCP handshake are included in the TCP handshake with the origin server.
If the TCP connection to the destination server is successful, Gateway will apply policies. If Gateway policies allow the connection, Gateway will connect the user to the destination server. If Gateway policies block the connection, Gateway will end the connection and will not send any data between the user and the destination server. If the TCP connection to the destination server is unsuccessful, Gateway will not run any policies and retry TCP connections from the user to the server.
flowchart TD
    %% Accessibility
    accTitle: How Gateway proxy works
    accDescr: Flowchart describing how the Gateway proxy uses the Happy Eyeballs algorithm to establish TCP connections and proxy user traffic.
    %% Flowchart
    A[User's device sends TCP SYN to Gateway] --> B[Gateway sends TCP SYN to origin server]
    B --> C{{Origin server responds with TCP SYN-ACK?}}
    C -->|Yes| E[TCP handshakes completed]
    C -->|No| D[Connection fails]
    E --> F{{Connection allowed?}}
    F -->|Allow policy| G[Gateway proxies traffic bidirectionally]
    F -->|Block policy| H[Connection blocked by firewall policies]
    %% Styling
    style D stroke:#D50000
    style G stroke:#00C853
    style H stroke:#D50000
Connections to Zero Trust will always appear in your Zero Trust network session logs regardless of connection success. Because Gateway does not inspect failed connections, they will not appear in your Gateway activity logs.
Gateway applies your policies in the following order:
- DNS policies with selectors evaluated before resolution
- DNS policies with selectors evaluated after resolution
- HTTP policies
- Network policies
- Resolver policies (if applicable)
- Egress policies (if applicable)
DNS policies are standalone. For example, if you block a site with a DNS policy but do not create a corresponding HTTP policy, users can still access the site if they know its IP address.
Next, Gateway evaluates HTTP policies in a specific order. For example, if you block a specific source IP in an HTTP policy but allow the IP range in a network policy, the IP address will be blocked.
Lastly, if traffic passes your HTTP policies, Gateway checks the traffic against your network policies. For example, even if you create a Do Not Inspect HTTP policy for a site, it can be blocked by a subsequent network policy.
For proxied HTTP/3 traffic, Gateway applies your policies in the following order:
- DNS policies
- Network policies
- HTTP policies
Gateway evaluates DNS policies first in order of DNS resolution, then in order of precedence.
When DNS queries are received, Gateway evaluates policies with pre-resolution selectors, resolves the DNS query, then evaluates policies with post-resolution selectors. This means policies with selectors evaluated before DNS resolution take precedence. For example, the following set of policies will block example.com:
| Precedence | Selector | Operator | Value | Action | 
|---|---|---|---|---|
| 1 | Resolved Country IP Geolocation | is | United States | Allow | 
| 2 | Domain | is | example.com | Block | 
Despite an explicit Allow policy ordered first, policy 2 takes precedence because the Domain selector is evaluated before DNS resolution.
If a policy contains both pre-resolution and post-resolution selectors, Gateway will evaluate the entire policy after DNS resolution. For information on when each selector is evaluated, refer to the list of DNS selectors.
Gateway evaluates network policies in order of precedence.
Gateway applies HTTP policies based on a combination of action type and order of precedence:
- All Do Not Inspect policies are evaluated first, in order of precedence.
- If no policies match, all Isolate policies are evaluated in order of precedence.
- All Allow, Block and Do Not Scan policies are evaluated in order of precedence.
- The body of the HTTP request, including Data Loss Prevention (DLP), AV scanning, and file sandboxing, is evaluated.
This order of enforcement allows Gateway to first determine whether decryption should occur. If a site matches a Do Not Inspect policy, it is automatically allowed through Gateway and bypasses all other HTTP policies.
Next, Gateway checks decrypted traffic against your Isolate policies. When a user makes a request which triggers an Isolate policy, the request will be rerouted to a remote browser.
Next, Gateway evaluates all Allow, Block, and Do Not Scan policies. These policies apply to both isolated and non-isolated traffic. For example, if example.com is isolated and example.com/subpage is blocked, Gateway will block the subpage (example.com/subpage) inside of the remote browser.
Lastly, Gateway inspects the body of the HTTP request by evaluating it against DLP policies, and running anti-virus scanning and file sandboxing. If DLP Block policies are present, the action Gateway ultimately takes may not match the action it initially logs. For more information, refer to DLP policy precedence.
When resolver policies are present, Gateway first evaluates any DNS policies with pre-resolution selectors, then routes any DNS queries according to the order of precedence of your resolver policies, and lastly evaluates any DNS policies with post-resolution selectors.
Order of precedence refers to the priority of individual policies within the DNS, network, or HTTP policy builder. Gateway evaluates policies in ascending order beginning with the lowest value.
The order of precedence follows the first match principle. Once traffic matches an Allow or Block policy, evaluation stops and no subsequent policies can override the decision. Therefore, Cloudflare recommends assigning the most specific policies and exceptions with the highest precedence and the most general policies with the lowest precedence.
In the Zero Trust dashboard, policies are in order of precedence from top to bottom of the list. Policies begin with precedence 1 and count upward. You can modify the order of precedence by dragging and dropping individual policies in the dashboard.
To update the precedence of a policy with the Cloudflare API, use the Update a Zero Trust Gateway rule endpoint to update the precedence field.
For Gateway configurations with DLP policies, Gateway will filter and log traffic based on first match, then scan the body of the HTTP request for matching content. Because of the first match principle, Gateway may perform and log a decision for traffic, then perform a contradicting decision. For example, if traffic is first allowed with an Allow HTTP policy, then blocked with a DLP Block policy, Gateway will log the initial Allow action despite ultimately blocking the request.
If Gateway traffic is headed to a private IP address protected as an Access application, that traffic will still be evaluated by the destination application's Access policies, even if a Gateway Allow policy matched first. Gateway Block policies that match traffic will terminate any other policy evaluation. This is expected behavior. A Gateway Allow policy does not override or bypass Access policies.
Suppose you have a list of policies arranged in the following order of precedence:
- 
DNS policies: Precedence Selector Operator Value Action 1 Host is example.comBlock 2 Host is test.example.comAllow 3 Domain matches regex .\Block 
- 
HTTP policies: Precedence Selector Operator Value Action 1 Host is example.comBlock 2 Host is test2.example.comDo Not Inspect 
- 
Network policies: Precedence Selector Operator Value Action 1 Destination Port is 80Block 2 Destination port is 443Allow 3 SNI Domain is test.example.comBlock 
When a user goes to https://test.example.com, Gateway performs the following operations:
- 
Evaluate DNS request against DNS policies: - Policy #1 does not match test.example.com— move on to check Policy #2.
- Policy #2 matches, so DNS resolution is allowed.
- Policy #3 is not evaluated because there has already been an explicit match.
 
- Policy #1 does not match 
- 
Evaluate HTTPS request against HTTP policies: - Policy #2 is evaluated first because Do Not Inspect always takes precedence over Allow and Block. Since there is no match, move on to check Policy #1.
- Policy #1 does not match test.example.com. Since there are no matching Block policies, the request passes the HTTP filter and moves on to network policy evaluation.
 
- 
Evaluate HTTPS request against network policies: - Policy #1 does not match because port 80 is used for standard HTTP, not HTTPS.
- Policy #2 matches, so the request is allowed and proxied to the upstream server.
- Policy #3 is not evaluated because there has already been an explicit match.
 
Therefore, the user is able to connect to https://test.example.com.
When arranging policies in Zero Trust, Gateway automatically calculates the precedence for rearranged policies.
When using the API to create a policy, unless the precedence is explicitly defined in the policy, Gateway will assign precedence to policies starting at 1000. Every time a new policy is added to the bottom of the order, Gateway will calculate the current highest precedence in the account and add a random integer between 1 and 100 to 1000 so that it now claims the maximum precedence in the account. To manually update a policy's precedence, use the Update a Zero Trust Gateway rule endpoint. You can set a policy's precedence to any value that is not already in use.
Changing the order within the Zero Trust dashboard or API may result in configuration issues when using Terraform.
You can manage the order of execution of your Gateway policies using Terraform. With version 5 of the Terraform Cloudflare provider, Gateway users can list their policies in a Terraform file with any desired integer precedence value. Cloudflare recommends starting with a precedence of 1000 and adding extra space between each policy's precedence for any future policies. For example:
resource "cloudflare_zero_trust_gateway_policy" "policy_1" {  account_id = var.cloudflare_account_id  # other attributes...  precedence = 1000}
resource "cloudflare_zero_trust_gateway_policy" "policy_2" {  account_id = var.cloudflare_account_id  # other attributes...  precedence = 2000}
resource "cloudflare_zero_trust_gateway_policy" "policy_3" {  account_id = var.cloudflare_account_id  # other attributes...  precedence = 3000}To avoid precedence calculation errors when reordering policies with Terraform, you should move one policy at a time before running terraform plan and terraform apply. If you use both Terraform and the Zero Trust dashboard or API, sync your polices with terraform refresh before reordering policies in Terraform. Alternatively, you can set your account to read-only in the Zero Trust dashboard, only allowing changes using the API or Terraform.
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