diff options
author | Henning Brauer <henning@cvs.openbsd.org> | 2002-10-29 15:23:39 +0000 |
---|---|---|
committer | Henning Brauer <henning@cvs.openbsd.org> | 2002-10-29 15:23:39 +0000 |
commit | db25701398022c99c908b358c23ae072c51a0d3a (patch) | |
tree | d3ad51b704b6cea28b86b0865f61dc5756bd0c87 /sbin/pfctl/parse.y | |
parent | d14216b62186ac44ecda8e4d1d56ed2a08576575 (diff) |
introduce
set require-order [yes|no]
default is yes.
with set to "no", it isn't required to have the rules in order (options,
scrub, nat, filter) any more, though of course NATing still happens before
filtering and so on, so one has to take care.
ok camield@ mcbride@ dhartmei@
idea discussed with a whole lotta more people and basically ok for everyone ;-)
Diffstat (limited to 'sbin/pfctl/parse.y')
-rw-r--r-- | sbin/pfctl/parse.y | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/sbin/pfctl/parse.y b/sbin/pfctl/parse.y index 73cecd889ef..cc4a5e767e9 100644 --- a/sbin/pfctl/parse.y +++ b/sbin/pfctl/parse.y @@ -1,4 +1,4 @@ -/* $OpenBSD: parse.y,v 1.175 2002/10/27 13:53:59 henning Exp $ */ +/* $OpenBSD: parse.y,v 1.176 2002/10/29 15:23:38 henning Exp $ */ /* * Copyright (c) 2001 Markus Friedl. All rights reserved. @@ -61,6 +61,7 @@ static u_int16_t returnicmpdefault = (ICMP_UNREACH << 8) | ICMP_UNREACH_PORT; static u_int16_t returnicmp6default = (ICMP6_DST_UNREACH << 8) | ICMP6_DST_UNREACH_NOPORT; static int blockpolicy = PFRULE_DROP; +static int require_order = 1; enum { PFCTL_STATE_NONE = 0, @@ -261,6 +262,7 @@ typedef struct { %token NOROUTE FRAGMENT USER GROUP MAXMSS MAXIMUM TTL TOS DROP %token FRAGNORM FRAGDROP FRAGCROP %token SET OPTIMIZATION TIMEOUT LIMIT LOGINTERFACE BLOCKPOLICY +%token REQUIREORDER YES %token ANTISPOOF FOR %token <v.string> STRING %token <v.i> PORTUNARY PORTBINARY @@ -338,6 +340,16 @@ option : SET OPTIMIZATION STRING { YYERROR; blockpolicy = PFRULE_RETURN; } + | SET REQUIREORDER YES { + if (pf->opts & PF_OPT_VERBOSE) + printf("set require-order yes\n"); + require_order = 1; + } + | SET REQUIREORDER NO { + if (pf->opts & PF_OPT_VERBOSE) + printf("set require-order no\n"); + require_order = 0; + } ; string : string STRING { @@ -2308,7 +2320,7 @@ expand_rdr(struct pf_rdr *r, struct node_if *interfaces, int check_rulestate(int desired_state) { - if (rulestate > desired_state) { + if (require_order && (rulestate > desired_state)) { yyerror("Rules must be in order: options, normalization, " "translation, filter"); return (1); @@ -2375,6 +2387,7 @@ lookup(char *s) { "rdr", RDR}, { "reassemble", FRAGNORM}, { "reply-to", REPLYTO}, + { "require-order", REQUIREORDER}, { "return", RETURN}, { "return-icmp",RETURNICMP}, { "return-icmp6",RETURNICMP6}, @@ -2388,6 +2401,7 @@ lookup(char *s) { "tos", TOS}, { "ttl", TTL}, { "user", USER}, + { "yes", YES}, }; const struct keywords *p; |