<link href="https://fonts.googleapis.com/css?family=Roboto:100,100italic,200,200italic,300,300italic,400,400italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic&amp;display=swap" rel="stylesheet"/>
4 minutes reading time (715 words)

Whitelist countries in OPNsense using MaxMind GeoIP and firewall aliases

How to set up whitelisting in OPNsense to allow a country list using MaxMind's free GeoIP database and firewall aliases

1. Get a MaxMind GeoIP license key

Sign up for a free MaxMind account

Generate a license key

Generate a license key

Manage License Keys - Generate new license key

License key description: OPNsense
Will this key be used for GeoIP update: No

Copy the license key and save it in your password manager

Click Continue

2. Get URL for GeoIP database updates

GeoIP2 / GeoLite2 - Download Files

GeoLite2 Country: CSV Format - Get Permalinks

Copy the database URL

# Database URL https://download.maxmind.com/app/geoip_download?edition_id=GeoLite2-Country-SV&license_key=YOUR_LICENSE_KEY&suffix=zip

3. Configure OPNsense firewall to use GeoIP

Firewall - Aliases - GeoIP Settings

URL: enter the MaxMind database URL

You'll need to replace YOUR_LICENSE_KEY

Click Apply

Firewall - Aliases - GeoIP Settings

URL: enter the MaxMind database URL:
https://download.maxmind.com/app/geoip_download?edition_id=GeoLite2-Country-CSV&license_key=YOUR_LICENSE_KEY&suffix=zip

You'll need to replace YOUR_LICENSE_KEY

Click Apply

4. Create firewall alias for whitelisted countries

Firewall - Aliases - Add

Name: whitelist_countries
Type: GeoIP

Click on the drop-down list of countries for a region e.g Europe

Select the countries you want to add to the whitelist

Save and Apply the changes

5. Create firewall alias for a specific country

Next we will create a whitelist to allow only the UK

Firewall - Aliases - Add

Name: allow_uk
Type: GeoIP
Region: select UK

Save and Apply the changes

6. Example: Allow one specific country

In this example, we will edit the firewall NAT rules to only allow one country to access specific network ports used by our phone system. No client devices outside of the UK should be connecting to the phone system using these ports.

We will edit the firewall NAT rules for the phone system ports and set the source to the allow_uk alias we created in the previous step.

Firewall - NAT - Port forward
Edit the firewall rule: 3cx-server HTTPS

Source - Advanced

Source: allow_uk

Save and Apply changes 

Repeat the steps to add the source whitelist to the other phone system firewall NAT rules

7. Example: Allow all whitelisted countries

In this example, we will apply the whitelist_countries firewall alias to the firewall NAT rules to restrict access to the web server

Firewall - NAT - Port forward
Edit the web server firewall rules
Source: whitelist_countries

Repeat the steps for both the HTTP and HTTPS NAT rules

Related Posts

 

Comments

No comments made yet. Be the first to submit a comment
Already Registered? Login Here
Friday, 24 October 2025
You can help support this website by buying me a coffee!
Buy Me A Coffee