mirror of
https://github.com/freebsd/freebsd-src.git
synced 2024-11-28 00:22:48 +00:00
65 lines
2.6 KiB
Plaintext
65 lines
2.6 KiB
Plaintext
filter-rule = [ insert ] action in-out [ options ] [ tos ] [ ttl ]
|
|
[ proto ] [ ip ] .
|
|
|
|
insert = "@" decnumber .
|
|
action = block | "pass" | log | "count" | call .
|
|
in-out = "in" | "out" .
|
|
options = [ log ] [ "quick" ] [ "on" interface-name [ dup ] [ froute ] ] .
|
|
tos = "tos" decnumber | "tos" hexnumber .
|
|
ttl = "ttl" decnumber .
|
|
proto = "proto" protocol .
|
|
ip = srcdst [ flags ] [ with withopt ] [ icmp ] [ keep ] .
|
|
|
|
block = "block" [ "return-icmp"[return-code] | "return-rst" ] .
|
|
log = "log" [ "body" ] [ "first" ] [ "or-block" ] .
|
|
call = "call" [ "now" ] function-name .
|
|
dup = "dup-to" interface-name[":"ipaddr] .
|
|
froute = "fastroute" | "to" interface-name .
|
|
protocol = "tcp/udp" | "udp" | "tcp" | "icmp" | decnumber .
|
|
srcdst = "all" | fromto .
|
|
fromto = "from" object "to" object .
|
|
|
|
object = addr [ port-comp | port-range ] .
|
|
addr = "any" | nummask | host-name [ "mask" ipaddr | "mask" hexnumber ] .
|
|
port-comp = "port" compare port-num .
|
|
port-range = "port" port-num range port-num .
|
|
flags = "flags" flag { flag } [ "/" flag { flag } ] .
|
|
with = "with" | "and" .
|
|
icmp = "icmp-type" icmp-type [ "code" decnumber ] .
|
|
return-code = "("icmp-code")" .
|
|
keep = "keep" "state" | "keep" "frags" .
|
|
|
|
nummask = host-name [ "/" decnumber ] .
|
|
host-name = ipaddr | hostname | "any" .
|
|
ipaddr = host-num "." host-num "." host-num "." host-num .
|
|
host-num = digit [ digit [ digit ] ] .
|
|
port-num = service-name | decnumber .
|
|
|
|
withopt = [ "not" | "no" ] opttype [ withopt ] .
|
|
opttype = "ipopts" | "short" | "frag" | "opt" ipopts .
|
|
optname = ipopts [ "," optname ] .
|
|
ipopts = optlist | "sec-class" [ secname ] .
|
|
secname = seclvl [ "," secname ] .
|
|
seclvl = "unclass" | "confid" | "reserv-1" | "reserv-2" | "reserv-3" |
|
|
"reserv-4" | "secret" | "topsecret" .
|
|
icmp-type = "unreach" | "echo" | "echorep" | "squench" | "redir" |
|
|
"timex" | "paramprob" | "timest" | "timestrep" | "inforeq" |
|
|
"inforep" | "maskreq" | "maskrep" | decnumber .
|
|
icmp-code = decumber | "net-unr" | "host-unr" | "proto-unr" | "port-unr" |
|
|
"needfrag" | "srcfail" | "net-unk" | "host-unk" | "isolate" |
|
|
"net-prohib" | "host-prohib" | "net-tos" | "host-tos" .
|
|
optlist = "nop" | "rr" | "zsu" | "mtup" | "mtur" | "encode" | "ts" | "tr" |
|
|
"sec" | "lsrr" | "e-sec" | "cipso" | "satid" | "ssrr" | "addext" |
|
|
"visa" | "imitd" | "eip" | "finn" .
|
|
|
|
hexnumber = "0" "x" hexstring .
|
|
hexstring = hexdigit [ hexstring ] .
|
|
decnumber = digit [ decnumber ] .
|
|
|
|
compare = "=" | "!=" | "<" | ">" | "<=" | ">=" | "eq" | "ne" | "lt" | "gt" |
|
|
"le" | "ge" .
|
|
range = "<>" | "><" .
|
|
hexdigit = digit | "a" | "b" | "c" | "d" | "e" | "f" .
|
|
digit = "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9" .
|
|
flag = "F" | "S" | "R" | "P" | "A" | "U" .
|