1996-08-05 04:38:51 +02:00
|
|
|
.Dd July 20, 1996
|
1995-10-26 06:36:24 +01:00
|
|
|
.Dt IPFW 8 SMM
|
|
|
|
.Os FreeBSD
|
1994-11-17 10:50:30 +01:00
|
|
|
.Sh NAME
|
1995-10-26 06:36:24 +01:00
|
|
|
.Nm ipfw
|
1996-02-24 14:39:46 +01:00
|
|
|
.Nd controlling utility for IP firewall
|
1994-11-17 10:50:30 +01:00
|
|
|
.Sh SYNOPSIS
|
1996-08-13 21:43:24 +02:00
|
|
|
.Nm
|
1996-02-24 14:39:46 +01:00
|
|
|
.Ar file
|
|
|
|
.Nm ipfw
|
1997-02-10 16:36:54 +01:00
|
|
|
.Oo
|
|
|
|
.Fl f
|
|
|
|
|
|
|
|
|
.Fl q
|
|
|
|
.Oc
|
1996-02-24 14:39:46 +01:00
|
|
|
flush
|
|
|
|
.Nm ipfw
|
1997-02-10 16:36:54 +01:00
|
|
|
.Oo
|
|
|
|
.Fl q
|
|
|
|
.Oc
|
1996-02-24 14:39:46 +01:00
|
|
|
zero
|
1996-12-23 03:03:15 +01:00
|
|
|
.Op Ar number
|
1996-02-24 14:39:46 +01:00
|
|
|
.Nm ipfw
|
|
|
|
delete
|
|
|
|
.Ar number
|
|
|
|
.Nm ipfw
|
1996-12-23 03:03:15 +01:00
|
|
|
.Op Fl aftN
|
1996-02-24 14:39:46 +01:00
|
|
|
list
|
1995-10-26 06:36:24 +01:00
|
|
|
.Nm ipfw
|
1997-02-10 16:36:54 +01:00
|
|
|
.Oo
|
|
|
|
.Fl ftN
|
|
|
|
.Oc
|
|
|
|
show
|
|
|
|
.Nm ipfw
|
|
|
|
.Oo
|
|
|
|
.Fl q
|
|
|
|
.Oc
|
1996-02-24 14:39:46 +01:00
|
|
|
add
|
1996-12-23 03:03:15 +01:00
|
|
|
.Op Ar number
|
1996-02-24 14:39:46 +01:00
|
|
|
.Ar action
|
1997-01-16 22:04:29 +01:00
|
|
|
.Op log
|
1996-02-24 14:39:46 +01:00
|
|
|
.Ar proto
|
|
|
|
from
|
|
|
|
.Ar src
|
|
|
|
to
|
|
|
|
.Ar dst
|
1997-01-16 22:04:29 +01:00
|
|
|
.Op via Ar name | ipno
|
1996-12-23 03:03:15 +01:00
|
|
|
.Op Ar options
|
1994-11-17 10:50:30 +01:00
|
|
|
.Sh DESCRIPTION
|
1996-02-24 14:39:46 +01:00
|
|
|
If used as shown in the first synopsis line, the
|
|
|
|
.Ar file
|
|
|
|
will be read line by line and applied as arguments to the
|
1996-08-13 21:43:24 +02:00
|
|
|
.Nm
|
1996-02-24 14:39:46 +01:00
|
|
|
command.
|
|
|
|
.Pp
|
1996-08-13 21:43:24 +02:00
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
code works by going through the rule-list for each packet,
|
1996-02-24 14:39:46 +01:00
|
|
|
until a match is found.
|
1996-07-10 21:44:30 +02:00
|
|
|
All rules have two associated counters, a packet count and
|
1996-02-24 14:39:46 +01:00
|
|
|
a byte count.
|
|
|
|
These counters are updated when a packet matches the rule.
|
|
|
|
.Pp
|
1996-07-10 21:44:30 +02:00
|
|
|
The rules are ordered by a ``line-number'' from 1 to 65534 that is used
|
|
|
|
to order and delete rules. Rules are tried in increasing order, and the
|
|
|
|
first rule that matches a packet applies.
|
|
|
|
Multiple rules may share the same number and apply in
|
|
|
|
the order in which they were added.
|
|
|
|
.Pp
|
1997-05-15 11:00:39 +02:00
|
|
|
If a rule is added without a number, it is numbered 100 higher
|
1996-07-10 21:44:30 +02:00
|
|
|
than the previous rule. If the highest defined rule number is
|
|
|
|
greater than 65434, new rules are appended to the last rule.
|
|
|
|
.Pp
|
|
|
|
The delete operation deletes the first rule with number
|
|
|
|
.Ar number ,
|
|
|
|
if any.
|
|
|
|
.Pp
|
|
|
|
The list command prints out the current rule set.
|
|
|
|
.Pp
|
1997-02-10 16:36:54 +01:00
|
|
|
The show command is equivalent to `ipfw -a list'.
|
|
|
|
.Pp
|
1996-07-10 21:44:30 +02:00
|
|
|
The zero operation zeroes the counters associated with rule number
|
|
|
|
.Ar number .
|
|
|
|
.Pp
|
|
|
|
The flush operation removes all rules.
|
1996-02-24 14:39:46 +01:00
|
|
|
.Pp
|
|
|
|
One rule is always present:
|
|
|
|
.Bd -literal -offset center
|
|
|
|
65535 deny all from any to any
|
|
|
|
.Ed
|
1996-12-23 03:03:15 +01:00
|
|
|
.Pp
|
1996-07-10 21:44:30 +02:00
|
|
|
This rule is the default policy, i.e., don't allow anything at all.
|
1997-02-10 16:36:54 +01:00
|
|
|
Your job in setting up rules is to modify this policy to match your
|
|
|
|
needs.
|
1996-02-24 14:39:46 +01:00
|
|
|
.Pp
|
|
|
|
The following options are available:
|
|
|
|
.Bl -tag -width flag
|
|
|
|
.It Fl a
|
|
|
|
While listing, show counter values. This option is the only way to see
|
|
|
|
accounting records.
|
1996-08-31 19:58:23 +02:00
|
|
|
.It Fl f
|
|
|
|
Don't ask for confirmation for commands that can cause problems if misused
|
|
|
|
(ie; flush).
|
|
|
|
.Ar Note ,
|
|
|
|
if there is no tty associated with the process, this is implied.
|
1997-02-10 16:36:54 +01:00
|
|
|
.It Fl q
|
|
|
|
While adding or flushing, be quiet about actions (implies '-f'). This is
|
|
|
|
useful for adjusting rules by executing multiple ipfw commands in a script
|
|
|
|
(e.g. sh /etc/rc.firewall), or by processing a file of many ipfw rules,
|
|
|
|
across a remote login session. If a flush is performed in normal
|
|
|
|
(verbose) mode, it prints a message. Because all rules are flushed, the
|
|
|
|
message cannot be delivered to the login session, the login session is
|
|
|
|
closed and the remainder of the ruleset is not processed. Access to the
|
|
|
|
console is required to recover.
|
1996-06-15 03:38:51 +02:00
|
|
|
.It Fl t
|
|
|
|
While listing, show last match timestamp.
|
1996-02-24 14:39:46 +01:00
|
|
|
.It Fl N
|
1996-09-15 02:08:30 +02:00
|
|
|
Try to resolve addresses and service names in output.
|
1996-02-24 14:39:46 +01:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
.Ar action :
|
|
|
|
.Bl -hang -offset flag -width 1234567890123456
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar allow
|
1996-06-15 03:38:51 +02:00
|
|
|
Allow packets that match rule.
|
1996-02-24 14:39:46 +01:00
|
|
|
The search terminates.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar pass
|
1996-06-15 03:38:51 +02:00
|
|
|
Same as allow.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar accept
|
1996-06-15 03:38:51 +02:00
|
|
|
Same as allow.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar count
|
1996-06-15 03:38:51 +02:00
|
|
|
Update counters for all packets that match rule.
|
1996-07-10 21:44:30 +02:00
|
|
|
The search continues with the next rule.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar deny
|
1996-02-24 14:39:46 +01:00
|
|
|
Discard packets that match this rule.
|
|
|
|
The search terminates.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar reject
|
1996-07-10 21:44:30 +02:00
|
|
|
Discard packets that match this rule, and try to send an ICMP notice.
|
|
|
|
The search terminates.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar divert port
|
1996-07-10 21:44:30 +02:00
|
|
|
Divert packets that match this rule to the divert socket bound to port
|
|
|
|
.Ar port .
|
1996-02-24 14:39:46 +01:00
|
|
|
The search terminates.
|
|
|
|
.El
|
|
|
|
.Pp
|
1997-01-16 22:04:29 +01:00
|
|
|
When a packet matches a rule with the ``log''
|
1996-02-24 14:39:46 +01:00
|
|
|
keyword, a message will be printed on the console.
|
1996-06-15 03:38:51 +02:00
|
|
|
If the kernel was compiled with the
|
1996-12-23 03:03:15 +01:00
|
|
|
.Dv IP_FIREWALL_VERBOSE_LIMIT
|
1996-06-15 03:38:51 +02:00
|
|
|
option, then logging will cease after the number of packets
|
1996-11-05 23:27:33 +01:00
|
|
|
specified by the option are received for that particular
|
1996-06-15 03:38:51 +02:00
|
|
|
chain entry. Logging may then be re-enabled by clearing
|
|
|
|
the packet counter for that entry.
|
1996-02-24 14:39:46 +01:00
|
|
|
.Pp
|
|
|
|
.Ar proto :
|
|
|
|
.Bl -hang -offset flag -width 1234567890123456
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar ip
|
1996-02-24 14:39:46 +01:00
|
|
|
All packets match.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar all
|
1996-02-24 14:39:46 +01:00
|
|
|
All packets match.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar tcp
|
1996-02-24 14:39:46 +01:00
|
|
|
Only TCP packets match.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar udp
|
1996-02-24 14:39:46 +01:00
|
|
|
Only UDP packets match.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar icmp
|
1996-02-24 14:39:46 +01:00
|
|
|
Only ICMP packets match.
|
1996-12-23 03:03:15 +01:00
|
|
|
.It Ar <number|name>
|
1996-08-13 21:43:24 +02:00
|
|
|
Only packets for the specified protocol matches (see
|
|
|
|
.Pa /etc/protocols
|
|
|
|
for a complete list).
|
1996-02-24 14:39:46 +01:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
.Ar src
|
|
|
|
and
|
|
|
|
.Ar dst :
|
1996-06-15 03:38:51 +02:00
|
|
|
.Pp
|
|
|
|
.Bl -hang -offset flag
|
1997-01-16 22:04:29 +01:00
|
|
|
.It Ar <address/mask>
|
|
|
|
.Op Ar ports
|
1996-06-15 03:38:51 +02:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Em <address/mask>
|
|
|
|
may be specified as:
|
1996-02-24 14:39:46 +01:00
|
|
|
.Bl -hang -offset flag -width 1234567890123456
|
|
|
|
.It Ar ipno
|
|
|
|
An ipnumber of the form 1.2.3.4.
|
|
|
|
Only this exact ip number match the rule.
|
|
|
|
.It Ar ipno/bits
|
|
|
|
An ipnumber with a mask width of the form 1.2.3.4/24.
|
|
|
|
In this case all ip numbers from 1.2.3.0 to 1.2.3.255 will match.
|
|
|
|
.It Ar ipno:mask
|
1996-07-10 21:44:30 +02:00
|
|
|
An ipnumber with a mask width of the form 1.2.3.4:255.255.240.0.
|
1996-02-24 14:39:46 +01:00
|
|
|
In this case all ip numbers from 1.2.0.0 to 1.2.15.255 will match.
|
|
|
|
.El
|
|
|
|
.Pp
|
1997-01-16 22:04:29 +01:00
|
|
|
The sense of the match can be inverted by preceding an address with the
|
|
|
|
``not'' modifier, causing all other addresses to be matched instead. This
|
|
|
|
does not affect the selection of port numbers.
|
|
|
|
.Pp
|
1996-06-15 03:38:51 +02:00
|
|
|
With the TCP and UDP
|
|
|
|
.Em protocols ,
|
1997-01-16 22:04:29 +01:00
|
|
|
optional
|
|
|
|
.Em ports
|
1996-06-15 03:38:51 +02:00
|
|
|
may be specified as:
|
|
|
|
.Pp
|
|
|
|
.Bl -hang -offset flag
|
1996-06-29 03:21:07 +02:00
|
|
|
.It Ns {port|port-port} Ns Op ,port Ns Op ,...
|
1996-06-15 03:38:51 +02:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
Service names (from
|
|
|
|
.Pa /etc/services )
|
|
|
|
may not be used instead of a numeric port value.
|
|
|
|
Also, note that a range may only be specified as the first value,
|
|
|
|
and the port list is limited to
|
1996-12-23 03:03:15 +01:00
|
|
|
.Dv IP_FW_MAX_PORTS
|
|
|
|
(as defined in
|
|
|
|
.Pa /usr/src/sys/netinet/ip_fw.h )
|
1996-06-15 03:38:51 +02:00
|
|
|
ports.
|
|
|
|
.Pp
|
1996-02-24 14:39:46 +01:00
|
|
|
If ``via''
|
|
|
|
.Ar name
|
|
|
|
is specified, only packets received via or on their way out of an interface
|
|
|
|
matching
|
|
|
|
.Ar name
|
|
|
|
will match this rule.
|
|
|
|
.Pp
|
|
|
|
If ``via''
|
|
|
|
.Ar ipno
|
|
|
|
is specified, only packets received via or on their way out of an interface
|
|
|
|
having the address
|
|
|
|
.Ar ipno
|
|
|
|
will match this rule.
|
|
|
|
.Pp
|
|
|
|
.Ar options :
|
|
|
|
.Bl -hang -offset flag -width 1234567890123456
|
|
|
|
.It frag
|
1996-06-15 03:38:51 +02:00
|
|
|
Matches if the packet is a fragment and this is not the first fragment
|
1996-02-24 14:39:46 +01:00
|
|
|
of the datagram.
|
|
|
|
.It in
|
|
|
|
Matches if this packet was on the way in.
|
|
|
|
.It out
|
|
|
|
Matches if this packet was on the way out.
|
|
|
|
.It ipoptions Ar spec
|
1996-06-15 03:38:51 +02:00
|
|
|
Matches if the IP header contains the comma separated list of
|
|
|
|
options specified in
|
|
|
|
.Ar spec .
|
|
|
|
The supported IP options are:
|
1996-12-23 03:03:15 +01:00
|
|
|
.Ar ssrr
|
1996-06-15 03:38:51 +02:00
|
|
|
(strict source route),
|
1996-12-23 03:03:15 +01:00
|
|
|
.Ar lsrr
|
1996-06-15 03:38:51 +02:00
|
|
|
(loose source route),
|
1996-12-23 03:03:15 +01:00
|
|
|
.Ar rr
|
1996-06-15 03:38:51 +02:00
|
|
|
(record packet route), and
|
1996-12-23 03:03:15 +01:00
|
|
|
.Ar ts
|
1996-06-15 03:38:51 +02:00
|
|
|
(timestamp).
|
|
|
|
The absence of a particular option may be denoted
|
|
|
|
with a ``!''.
|
1996-02-24 14:39:46 +01:00
|
|
|
.It established
|
1996-07-02 02:29:22 +02:00
|
|
|
Matches packets that have the RST or ACK bits set.
|
1996-02-24 14:39:46 +01:00
|
|
|
TCP packets only.
|
|
|
|
.It setup
|
|
|
|
Matches packets that have the SYN bit set but no ACK bit.
|
|
|
|
TCP packets only.
|
|
|
|
.It tcpflags Ar spec
|
1996-06-15 03:38:51 +02:00
|
|
|
Matches if the TCP header contains the comma separated list of
|
|
|
|
flags specified in
|
|
|
|
.Ar spec .
|
|
|
|
The supported TCP flags are:
|
1996-12-23 03:03:15 +01:00
|
|
|
.Ar fin ,
|
|
|
|
.Ar syn ,
|
|
|
|
.Ar rst ,
|
|
|
|
.Ar psh ,
|
|
|
|
.Ar ack ,
|
1996-06-15 03:38:51 +02:00
|
|
|
and
|
1996-12-23 03:03:15 +01:00
|
|
|
.Ar urg .
|
1996-06-15 03:38:51 +02:00
|
|
|
The absence of a particular flag may be denoted
|
|
|
|
with a ``!''.
|
|
|
|
.It icmptypes Ar types
|
|
|
|
Matches if the ICMP type is in the list
|
|
|
|
.Ar types .
|
|
|
|
The list may be specified as any combination of ranges
|
|
|
|
or individual types separated by commas.
|
1996-02-24 14:39:46 +01:00
|
|
|
.El
|
|
|
|
.Sh CHECKLIST
|
|
|
|
Here are some important points to consider when designing your
|
|
|
|
rules:
|
1996-12-23 03:03:15 +01:00
|
|
|
.Bl -bullet -hang -offset flag
|
1996-02-24 14:39:46 +01:00
|
|
|
.It
|
|
|
|
Remember that you filter both packets going in and out.
|
1996-06-15 03:38:51 +02:00
|
|
|
Most connections need packets going in both directions.
|
1996-02-24 14:39:46 +01:00
|
|
|
.It
|
|
|
|
Remember to test very carefully.
|
1996-06-15 03:38:51 +02:00
|
|
|
It is a good idea to be near the console when doing this.
|
1996-02-24 14:39:46 +01:00
|
|
|
.It
|
|
|
|
Don't forget the loopback interface.
|
|
|
|
.El
|
|
|
|
.Sh FINE POINTS
|
|
|
|
There is one kind of packet that the firewall will always discard,
|
|
|
|
that is an IP fragment with a fragment offset of one.
|
|
|
|
This is a valid packet, but it only has one use, to try to circumvent
|
|
|
|
firewalls.
|
|
|
|
.Pp
|
|
|
|
If you are logged in over a network, loading the LKM version of
|
|
|
|
.Nm
|
|
|
|
is probably not as straightforward as you would think.
|
|
|
|
I recommend this command line:
|
|
|
|
.Bd -literal -offset center
|
|
|
|
modload /lkm/ipfw_mod.o && \e
|
|
|
|
ipfw add 32000 allow all from any to any
|
|
|
|
.Ed
|
1996-12-23 03:03:15 +01:00
|
|
|
.Pp
|
1996-06-15 03:38:51 +02:00
|
|
|
Along the same lines, doing an
|
1996-02-24 14:39:46 +01:00
|
|
|
.Bd -literal -offset center
|
|
|
|
ipfw flush
|
|
|
|
.Ed
|
1996-12-23 03:03:15 +01:00
|
|
|
.Pp
|
1996-02-24 14:39:46 +01:00
|
|
|
in similar surroundings is also a bad idea.
|
1996-07-10 21:44:30 +02:00
|
|
|
.Sh PACKET DIVERSION
|
|
|
|
A divert socket bound to the specified port will receive all packets diverted
|
|
|
|
to that port; see
|
|
|
|
.Xr divert 4 .
|
|
|
|
If no socket is bound to the destination port, or if the kernel
|
|
|
|
wasn't compiled with divert socket support, diverted packets are dropped.
|
1994-11-17 10:50:30 +01:00
|
|
|
.Sh EXAMPLES
|
1995-10-26 06:36:24 +01:00
|
|
|
This command adds an entry which denies all tcp packets from
|
|
|
|
.Em hacker.evil.org
|
|
|
|
to the telnet port of
|
|
|
|
.Em wolf.tambov.su
|
|
|
|
from being forwarded by the host:
|
|
|
|
.Pp
|
1996-06-15 03:38:51 +02:00
|
|
|
.Dl ipfw add deny tcp from hacker.evil.org to wolf.tambov.su 23
|
1995-10-26 06:36:24 +01:00
|
|
|
.Pp
|
|
|
|
This one disallows any connection from the entire hackers network to
|
|
|
|
my host:
|
|
|
|
.Pp
|
|
|
|
.Dl ipfw addf deny all from 123.45.67.0/24 to my.host.org
|
|
|
|
.Pp
|
1997-05-15 02:51:08 +02:00
|
|
|
Here is a good usage of the list command to see accounting records
|
|
|
|
and timestamp information:
|
1995-10-26 06:36:24 +01:00
|
|
|
.Pp
|
1996-06-16 01:01:44 +02:00
|
|
|
.Dl ipfw -at l
|
1995-10-26 06:36:24 +01:00
|
|
|
.Pp
|
1997-05-15 02:51:08 +02:00
|
|
|
or in short form without timestamps:
|
1995-10-26 06:36:24 +01:00
|
|
|
.Pp
|
1996-06-15 03:38:51 +02:00
|
|
|
.Dl ipfw -a l
|
1995-10-26 06:36:24 +01:00
|
|
|
.Pp
|
1996-07-10 21:44:30 +02:00
|
|
|
This rule diverts all incoming packets from 192.168.2.0/24 to divert port 5000:
|
|
|
|
.Pp
|
|
|
|
.Dl ipfw divert 5000 all from 192.168.2.0/24 to any in
|
1994-11-17 10:50:30 +01:00
|
|
|
.Sh SEE ALSO
|
1996-08-05 04:38:51 +02:00
|
|
|
.Xr divert 4 ,
|
1995-10-26 06:36:24 +01:00
|
|
|
.Xr ip 4 ,
|
|
|
|
.Xr ipfirewall 4 ,
|
1996-08-05 04:38:51 +02:00
|
|
|
.Xr protocols 5 ,
|
|
|
|
.Xr services 5 ,
|
1995-10-26 06:36:24 +01:00
|
|
|
.Xr reboot 8 ,
|
|
|
|
.Xr syslogd 8
|
1994-11-17 10:50:30 +01:00
|
|
|
.Sh BUGS
|
1995-10-26 06:36:24 +01:00
|
|
|
.Pp
|
|
|
|
.Em WARNING!!WARNING!!WARNING!!WARNING!!WARNING!!WARNING!!WARNING!!
|
|
|
|
.Pp
|
|
|
|
This program can put your computer in rather unusable state. When
|
|
|
|
using it for the first time, work on the console of the computer, and
|
|
|
|
do
|
|
|
|
.Em NOT
|
|
|
|
do anything you don't understand.
|
|
|
|
.Pp
|
1996-08-05 04:38:51 +02:00
|
|
|
When manipulating/adding chain entries, service and protocol names are
|
1996-06-15 03:38:51 +02:00
|
|
|
not accepted.
|
1996-08-13 21:43:24 +02:00
|
|
|
.Sh AUTHORS
|
|
|
|
Ugen J. S. Antsilevich,
|
|
|
|
Poul-Henning Kamp,
|
|
|
|
Alex Nash,
|
|
|
|
Archie Cobbs.
|
|
|
|
API based upon code written by Daniel Boulet for BSDI.
|
1994-11-17 10:50:30 +01:00
|
|
|
.Sh HISTORY
|
1996-08-13 21:43:24 +02:00
|
|
|
.Nm
|
1996-08-23 02:57:08 +02:00
|
|
|
first appeared in
|
|
|
|
.Fx 2.0 .
|