By Manny Fernandez

August 20, 2019

Conditional DNS Forwarding with FortiGate and FortiProxy

Today I was working with a customer that was running FortiProxy in a Proof-of-Concept.  One of the requirements was to have certain domains use a particular DNS server while all other traffic destined for all other domains, go straight out to 4.2.2.2 and 8.8.8.8.  This is called Conditional DNS Forwarding and it is supported by both the FortiGates and the FortiProxy.  In this example, I will choose a fictitious name for a city and use .com, .net, and .org as the domains I want to forward to internal DNS.

There are two parts to this configuration.

  1. Enable recursive DNS on the particular interface users will see and query.
  2. Configure the domain-names and the DNS servers they should be going to resolve.

The fictitious name will be City1.  In my fake environment, city1.com will go to 10.243.13.1, 10.243.13.10, 10.243.13.100  as the DNS Servers, city1.net will go to 10.243.16.1, 10.243.16.10, 10.243.16.100 and city1.org will go to 10.244.14.1, 10.244.14.10, 10.244.14.100

Here we go:

Enable Recursive DNS on Interface

First let’s enable the recursive DNS Services on the interface(s) where the DNS queries will come from.

Graphical User Interface Option

A. Interface the FortiProxy / FortiGate will listen to DNS queries on.
B. Turn on the `Recursive` mode.
C. Press OK.

Command Line Interface Option

config system dns-server
       edit "FDZ-OFF"
            set mode recursive
            set dnsfilter-profile ''
       next
end

#FDZ-OFF is the name of my interface

Configuring Conditional Queries

Since we are using three DNS servers, you cannot do this via the GUI so there will only be a CLI representation of this command.

config system dns-database
     edit "city1.com"
         set domain "city1.com"
         set authoritative disable
         set forwarder "10.243.13.1" "10.243.13.10" "10.243.13.100" 
     next
     edit "city1.net"
         set domain "city1.net"
         set authoritative disable
         set forwarder "10.243.16.1" "10.243.16.10" "10.243.16.100" 
     next
     edit "city1.org"
         set domain "city1.net"
         set authoritative disable
        set forwarder "10.244.14.1" "10.244.14.10" "10.244.14.100" 
     next
end

DNS Flow

We can see above that the three domains for city1  (.com, .net and .org respectively).  All DNS queries destined to any of the three domains (city1.com, city1.net, city1.org) will be sent to its three DNS servers.  All other requests will be sent to the DNS Servers configured under Network , DNS.

The current DNS servers are from a FortiGate, FortiProxy configuration is below.

In FortiProxy, the section is labeled differently.  In the Proxy model, is is labeled DNS Settings where the Fortigate is only DNS.

Hope this helps.

 

 

 

 

 

Recent posts

  • If you've spent any time configuring user authentication on... Full Story

  • DNS is one of those technologies that quietly underpins... Full Story

  • BGP issues on FortiGate firewalls usually trace back to... Full Story

  • Every time your laptop talks to your router, a... Full Story

  • If you've spent any time configuring NAT on a... Full Story

  • If you have spent any time configuring firewall policies... Full Story

  • High availability on FortiGate is one of those features... Full Story

  • If you've configured SD-WAN on a FortiGate, you've almost... Full Story

  • FortiLink is the management protocol that turns a FortiSwitch... Full Story

  • FortiSwitches are pretty rock solid from Mean Time Between... Full Story

  • This is a quicky tip.  Have you ever gone... Full Story

  • DNS is one of those quiet pieces of internet... Full Story

  • This article is an updated version of the previous... Full Story

  • You will add ns2 as a secondary (slave) BIND9... Full Story

  • In the process of deploying my lab, I needed... Full Story

  • RFC 8805, used to be known as Self-Correcting IP... Full Story

  • Years back, I wrote an article about certificate pinning. ... Full Story

  • FortiGates have the ability to send alerts to Microsoft... Full Story

  • In this post, I am going to walk through... Full Story

  • Troubleshooting VoIP on a FortiGate can feel like trying... Full Story

  • Prior to FortiOS 7.0, there were three commands to... Full Story

  • In this post, I am going to go over... Full Story

  • What we are going to do:  We are going... Full Story

  • Choosing between FGCP (FortiGate Clustering Protocol) and FGSP (FortiGate... Full Story

  • Creating a VLAN on macOS (The "Pro" Move) A... Full Story

  • This blog post explores the logic behind how macOS... Full Story

  • Pretty Fly for a Wi-Fi Tell My Wi-Fi Love... Full Story

  • Part of my daily gig is creating BoMs (Bill-of-Materials)... Full Story

  • ICMP introduces several security risks, but careful filtering, rate... Full Story

  • The command diag debug application dhcps -1 enables full... Full Story

  • In the world of FortiOS, execute tac report is... Full Story

  • LLDP; What is it The Link Layer Discovery Protocol... Full Story

  • What it actually does When you run diagnose fdsm... Full Story

  • Monkey Bites are bite-sized, high-impact security insights designed for... Full Story

  • I have run macOS in macOS with Parallels but... Full Story

  • Don't be confused with my other FortiNAC posts where... Full Story

  • This is the third session in a multi-part article... Full Story

  • Today I was configuring key-based authentication on a FortiGate... Full Story

  • Netcat, often called the "Swiss Army knife" of networking,... Full Story

  • At its core, IEEE 802.1X is a network layer... Full Story

  • In case you did not see the previous FortiNAC... Full Story

  • This is our 5th session where we are going... Full Story

  • Now that we have Wireshark installed and somewhat configured,... Full Story

  • The Philosophy of Packet Analysis Troubleshooting isn't about looking... Full Story

  • At work, they wanted us to keep track of... Full Story

  • Overview FortiOS 8.0 introduces custom tags as a first-class... Full Story

  • These are two distinct mechanisms on FortiOS, and conflating... Full Story