These are sample ipsec.conf(5) configuration files for opportunistic encryption, with comments. Much of this configuration will be unnecessary with the new defaults proposed for FreeS/WAN 2.x.
Full instructions are in our quickstart guide.
The ipsec.conf file for an initiate-only opportunistic setup is:
# general IPsec setup
config setup
# Use the default interface
interfaces=%defaultroute
# Use auto= parameters in conn descriptions to control startup actions.
plutoload=%search
plutostart=%search
uniqueids=yes
# defaults for subsequent connection descriptions
conn %default
# How to authenticate gateways
authby=rsasig
# default is
# load connection description into Pluto's database
# so it can respond if another gatway initiates
# individual connection descriptions may override this
auto=add
# description for opportunistic connections
conn me-to-anyone
left=%defaultroute # all connections should use default route
right=%opportunistic # anyone we can authenticate
leftrsasigkey=%dnsondemand # NEW: look up keys in DNS as-needed
rightrsasigkey=%dnsondemand # (not at connection load time)
rekey=no # let unused connections die
keylife=1h # short
auto=route # set up for opportunistic
leftid=@xy.example.com # our identity for IPSec negotiations
# must match DNS and ipsec.secrets
Normally, you need to do only two things:
However, some people may need to customize the interfaces= line in the "config setup" section. All other sections are identical for any standalone machine doing opportunistic encryption.
The @ sign in the leftid= makes the ID go "over the wire" as a Fully Qualified Domain Name (FQDN). Without it, an IP address would be used and this won't work.
The conn is not used to supply either public key. Your private key is in ipsec.secrets(5) and, for opportunistic encryption, the public keys for remote gateways are all looked up in DNS.
FreeS/WAN authenticates opportunistic encryption by RSA signature only, so "public key" and "private key" refer to these keys.
While the left and right designations here are arbitrary, we follow a convention of using left for local and right for remote.
Continue configuring initiate-only opportunism.
# description for opportunistic connections
conn me-to-anyone
left=%defaultroute # all connections should use default route
right=%opportunistic # anyone we can authenticate
leftrsasigkey=%dnsondemand # NEW: look up keys in DNS as-needed
rightrsasigkey=%dnsondemand # (not at connection load time)
rekey=no # let unused connections die
keylife=1h # short
auto=route # set up for opportunistic
Note that leftid= has been removed. With no explicit setting, leftid= defaults to the IP of your public interface.
Continue configuring full opportunism.
conn subnet-to-anyone # must be above me-to-anyone
also=me-to-anyone
leftsubnet=42.42.42.0/24
conn me-to-anyone # just like for full opportunism
left=%defaultroute
right=%opportunistic
leftrsasigkey=%dnsondemand
rightrsasigkey=%dnsondemand
keylife=1h
rekey=no
auto=route # be sure this is enabled
# Note there is NO leftid=
Note that a subnet described in ipsec.conf(5) need not correspond to a physical network segment. This is discussed in more detail in our advanced configuration document.
If required, a gateway can easily provide this service for more than one subnet. You just add a connection description for each.
Continue configuring an opportunistic gateway.