Setting firewall symbolic constants
Matthew Seaman
m.seaman at infracaninophile.co.uk
Tue Mar 30 15:01:48 UTC 2010
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
On 30/03/2010 13:52:57, Walter wrote:
> In the example firewall rule set in rc.firewall, there are
> the following lines:
>
> # set these to your outside interface network
> oif="$firewall_simple_oif"
> onet="$firewall_simple_onet"
>
> # set these to your inside interface network
> iif="$firewall_simple_iif"
> inet="$firewall_simple_inet"
>
> Can these be set by the system automatically? Specifically
> $firewall_simple_onet?
>
> When the IP changes on the ISP's side, I'd like to
> have this detected and updated in the rules without my
> manual intervention. Do I need to write a utility and
> run in crontab? Or is there a better way?
>
> I'm off-list, so please reply directly to this e-mail addy.
If you switch to using PF rather than IPFW, this is very easy.
In a PF ruleset, the name of an interface is expanded to a list of all
of the IP numbers configured on it. So you'll frequently see rules like
this:
ext_if = "de0"
[...]
pass log on $ext_if proto tcp \
from any to any port smtp \
flags S/SA keep state
You can also say $ext_if:network to mean the locally attached network on
that inerface. Works with both IPv4 and IPv6.
One important wrnkle -- normally the resolution from interface name to
IP number happens just once, when the rules are initially loaded. If
your interface has a dynamic address, simple enclose the i/f name in
brackets, like so: ($ext_if) This causes PF to update the mapping as
the IP number changes. It's less efficient, which is why it isn't
usually done for a machine with fixed addresses, but that won't cause
you any problems for typical DSL or even Cable speeds.
Cheers,
Matthew
- --
Dr Matthew J Seaman MA, D.Phil. 7 Priory Courtyard
Flat 3
PGP: http://www.infracaninophile.co.uk/pgpkey Ramsgate
Kent, CT11 9PW
-----BEGIN PGP SIGNATURE-----
Version: GnuPG/MacGPG2 v2.0.14 (Darwin)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org/
iEYEARECAAYFAkuyElMACgkQ8Mjk52CukIy6LQCePtDUIteOMTnUQVYBZ2eUogfU
nUgAn1U87/YBfSw/jBaP1nn9370zbzEN
=eUTt
-----END PGP SIGNATURE-----
More information about the freebsd-questions
mailing list