pfSense
This tutorial explains how to set up a policy-based or route-based IPsec VPN with a pfSense device.
(Policy-based only) LAN interface configuration
- From the pfSense WebGUI, select Interfaces > LAN.
- Choose an interface from the Available network ports list.
- Select Add. The General Configuration dialog displays.
Refer to the image below for guidance on which values to use.
data:image/s3,"s3://crabby-images/b3eb9/b3eb9f413e9d9ebf66f45d5bc8b9e8b44f19fb1d" alt="General configuration dialog for interface setup for a policy based configuration"
Field | Value |
---|
Enable | ✔️ Enable interface |
Description | LAN |
IPv4 Configuration Type | Static IPv4 |
IPv6 Configuration Type | Static IPv6 |
MSS | 1446 |
Phase 1
Policy-based configuration
data:image/s3,"s3://crabby-images/ca346/ca346a77298425d8bf5b652cd9692452b38af4e1" alt="pfSense IPsec phase 1 setting values for a policy based configuration"
Field | Value |
---|
Description | Name |
Key Exchange Version | IKE v2 |
Internet Protocol | IPv4 |
Interface | WAN |
Remote Gateway | <Anycast IP provided by Cloudflare> |
data:image/s3,"s3://crabby-images/f04e0/f04e0b2ac03c2a9f531716627748d90bd03910c9" alt="pfSense IPsec phase 1 expiration and replacement values for a policy based configuration"
Field | Value |
---|
Life Time | 28800 |
Rekey Time | 14400 |
Reauth Time | 0 |
Route-based configuration
data:image/s3,"s3://crabby-images/ca346/ca346a77298425d8bf5b652cd9692452b38af4e1" alt="pfSense IPsec phase 1 setting values for a route based configuration"
Field | Value |
---|
Description | Name |
Key Exchange Version | IKE v2 |
Internet Protocol | IPv4 |
Interface | WAN |
Remote Gateway | <Anycast IP provided by Cloudflare> |
data:image/s3,"s3://crabby-images/f04e0/f04e0b2ac03c2a9f531716627748d90bd03910c9" alt="pfSense IPsec phase 1 expiration and replacement values for a route based configuration"
Field | Value |
---|
Life Time | 28800 |
Rekey Time | 14400 |
Reauth Time | 0 |
Phase 2
Policy-based configuration
data:image/s3,"s3://crabby-images/31758/3175899e3e406c6f0402de1defa77e009837fd54" alt="pfSense IPsec phase 2 general information values"
Field | Value |
---|
Description | Name |
Mode | Tunnel IPv4 |
Local Network | <Local Network to be tunneled> |
NAT/BINAT translation | None |
Remote Network | Remote network available via the tunnel |
data:image/s3,"s3://crabby-images/032f7/032f75933f3ad13fd8335dfdc7bf659eb49a5734" alt="pfSense IPsec phase 2 key exchange values"
Field | Value |
---|
Protocol | ESP |
Encryption Algorithm | ✔️ AES128-GCM, 128 bits |
PFS key group | 14 (2048 bit) |
data:image/s3,"s3://crabby-images/30e64/30e64cf4d7616d2542fc5285e815cf07c50af077" alt="pfSense IPsec phase 2 key exchange values"
Field | Value |
---|
Life Time | 3600 |
Rekey Time | 3240 |
Rand Time | 360 |
Automatically ping host | Specify an IP address available via the tunnel. Refer to the Description field for more information. |
Route-based configuration
data:image/s3,"s3://crabby-images/3881e/3881e6b093cb795c1ee7465123a8b1089662be3f" alt="pfSense IPsec phase 2 general information for a route based configuration"
data:image/s3,"s3://crabby-images/4e6cd/4e6cd05592a718927f8fa397b63c236e9f30f3cc" alt="pfSense IPsec phase 2 network settings for a route based configuration"
Field | Value |
---|
Description | Name |
Mode | Routed (VTI) |
Local Network | <Local Tunnel Inside IP> |
Remote Network | <Remote Tunnel Inside IP> |
data:image/s3,"s3://crabby-images/032f7/032f75933f3ad13fd8335dfdc7bf659eb49a5734" alt="pfSense IPsec phase 2 key exchange values for a route based configuration"
Field | Value |
---|
Protocol | ESP |
Encryption Algorithm | ✔️ AES128-GCM, 128 bits |
PFS key group | 14 (2048 bit) |
data:image/s3,"s3://crabby-images/30e64/30e64cf4d7616d2542fc5285e815cf07c50af077" alt="pfSense IPsec phase 2 key exchange values"
Field | Value |
---|
Life Time | 3600 |
Rekey Time | 3240 |
Rand Time | 360 |
Automatically ping host | Specify an IP address available via the tunnel. Refer to the Description field for more information. |
(Route-based only) Interface assignment
- From the pfSense WebGUI, select Interfaces > LAN.
- Choose an interface from the Available network ports list.
- Select Add. The General Configuration dialog displays.
Refer to the image below for guidance on which values to use.
data:image/s3,"s3://crabby-images/b3eb9/b3eb9f413e9d9ebf66f45d5bc8b9e8b44f19fb1d" alt="General configuration dialog for interface setup for a policy based configuration"
Field | Value |
---|
Enable | ✔️ Enable interface |
Description | LAN |
IPv4 Configuration Type | Static IPv4 |
IPv6 Configuration Type | Static IPv6 |
MSS | 1446 |
- From the pfSense WebGUI, select Interfaces > Assignments.
data:image/s3,"s3://crabby-images/824c4/824c4f8e76e6fbc2c8daeffd21b04310f705c5a6" alt="pfSense interface assignment settings for route based configuration"
- From Available network ports, select + Add.
data:image/s3,"s3://crabby-images/0f26f/0f26f35d2871706986d11d6eeb046d8cba92b7b9" alt="Adding an interface to a pfSense interface assignment with a route based configuration"
- Under Interface, select OPT1.
data:image/s3,"s3://crabby-images/d62cd/d62cdaa0cfc26ccf60daa9e22ab07665f756b3e5" alt="pfSense interface general configuration settings for a route based configuration"
- Ensure Enable interface is selected.
- For Description, add a description to help you identify the interface.
- For MSS, enter 1446, which should be the same as the LAN interface.
- Select Save to save your changes when you are done.
Routing configuration
- From the pfSense WebGUI, select System, Routing, Static Routes.
- On the Static Routes page, select Add.
- Create static routes for all network that will be routed via the tunnel with Gateway as the IPsec VTI interface.
data:image/s3,"s3://crabby-images/0ff38/0ff38fa946f70a791852b06a5aba4981de43964e" alt="pfSense interface routing configuration settings for a route based configuration"
Firewall configuration
- From the pfSense WebGUI, select Firewall Rules.
- Select LAN.
- Ensure a rule exists that allows traffic from LAN to IPsec.
- Select Save when you are done.
If you need to allow traffic from IPsec to LAN, you will need to create rules that allow this.