Skip to content

DNS filtering solution for Internet service providers

Last reviewed: 28 days ago

Introduction

Internet service providers are constantly exploring new revenue opportunities to expand their business, and many are now turning to security as a value-added service alongside their connectivity offerings. Traditionally, integrating security with connectivity posed significant challenges due to the reliance on legacy solutions that required costly on-premises hardware. This makes it difficult to deploy and manage and introduces post-deployment struggles with scalability and availability.

Today these limitations can be addressed through cloud-based solutions like Cloudflare Gateway, our Secure Web Gateway service. Cloudflare Gateway's DNS filtering capabilities allow service providers to offer enhanced security as a value-added service for residential and mobile subscribers or B2B clients. With easy-to-create policies backed by Cloudflare's extensive threat intelligence, service providers can effectively safeguard their customers from accessing potentially harmful domains.

Moreover, Cloudflare Gateway eliminates concerns around availability, performance, and scalability, as it is built on Cloudflare's 1.1.1.1 public DNS resolver, one of the fastest and most widely-used DNS resolvers in the world.

Furthermore, this solution opens up opportunities for developing additional services beyond security, such as parental controls or tailored filtering profiles for B2B clients.

Solution

Providing DNS security to the service providers' end customers with Cloudflare is straightforward. Service providers simply forward their public DNS requests to their Cloudflare tenant, and Cloudflare will filter DNS queries in accordance with the configured DNS filtering policies.

Figure 1: The service provider subscribers send DNS queries to the service provider DNS server, which will forward them to Cloudflare Gateway to apply DNS filtering policies.

Cloudflare Gateway, like all Cloudflare services, utilizes anycast technology, ensuring that all service provider DNS queries are directed to the nearest Cloudflare point of presence.

To distinguish queries originating from the service provider from those coming from other customers, admins configure a location in their Cloudflare tenant dashboard. When a DNS location is created, Gateway assigns IPv4/IPv6 addresses and DoT/DoH hostnames for that location. These assigned IP addresses and hostnames are then used by the service provider to send DNS queries for resolution. In turn, the service provider configures the location object with the public IP addresses of their on-premises DNS servers, allowing Cloudflare to accurately associate queries with the corresponding location.

DNS filtering is then enforced through DNS policies set up by the service provider to detect domains linked to security risks. Cloudflare continuously updates the list of risky domains using its extensive threat intelligence. When a DNS query matches a flagged domain, the corresponding action specified in the DNS policy is executed. This action can be a 'Block,' where Gateway responds with 0.0.0.0 for IPv4 queries or :: for IPv6 queries, or displays a custom block page hosted by Cloudflare. Alternatively, an [Override](/cloudflare-one/policies/gateway/dns-policies/#override) action can redirect the DNS query to a block page hosted by the service provider.

Figure 2: A DNS policy to prevent users from navigating to malicious domains. The action is to override and redirect the DNS query to a block page hosted by the service provider.

To achieve more precise control over which domains are allowed or blocked, the service provider can configure additional Allowed Domain and Blocked Domains policies. By setting these policies with lower precedence than the Security Risks policy, the service provider can override the Security Risks policy for specific domains.

To streamline the management of allowed and blocked domains, use lists. Lists are easily updated through the dashboard or via APIs, making policy adjustments more efficient.

Figure 3: DNS policies are applied according to their order of precedence. In this example, the 'Allow List Policy' and 'Block List Policy' will be considered before the 'Security List' policy.

Additionally, all DNS queries forwarded to Cloudflare Gateway are logged and can be exported to external systems using Logpush.

Additional offerings based on DNS filtering capabilities

Service providers can enhance their offerings by using Cloudflare Gateway DNS policies to deliver additional value-added services alongside the base DNS security service. By using the same solution, service providers can develop customized content category filtering services. These services can be easily constructed using Cloudflare's built-in content categories and application types, as well as the service provider's own custom allow and block lists.

Some potential applications include:

  • Parental Control Services: This service can block categories such as adult themes, child abuse, violence, and questionable content to ensure a safer online environment for children.
  • Educational Services: Designed for schools and educational organizations, this service can extend beyond parental controls by blocking additional categories like CIPA, gambling, and entertainment, thereby promoting a focused learning atmosphere.
  • Enterprise Services: This offering allows businesses to easily restrict access to non-work-related domains, including categories such as entertainment, social networking, gambling, shopping & auctions, society & lifestyle, and sports.

To differentiate these additional services from the core DNS security offering, the service provider would create additional DNS locations, one for each service. Cloudflare would be able to distinguish DNS queries for these services if the service provider sends them to one of the unique identifiers of a location. Each location has a unique DoH and DoT hostname and a unique destination IPv6 address. Cloudflare can also provision dedicated destination IPv4 addresses per location.