mirror of
https://gitlab.com/shorewall/code.git
synced 2025-01-24 14:39:04 +01:00
Document passed() in the config basics document
Signed-off-by: Tom Eastep <teastep@shorewall.net>
This commit is contained in:
parent
da0653cb2f
commit
5fc391cb58
@ -1985,6 +1985,33 @@ SSH(ACCEPT) net:$MYIP $FW
|
|||||||
@disposition are used to generated the --log-prefix in logging rules. When
|
@disposition are used to generated the --log-prefix in logging rules. When
|
||||||
either is empty, the historical value is used to generate the
|
either is empty, the historical value is used to generate the
|
||||||
--log-prefix.</para>
|
--log-prefix.</para>
|
||||||
|
|
||||||
|
<para>Within an action body, if a parameter is omitted in a DEFAULTS
|
||||||
|
statement, then the value of the corresponding action and Shorewall
|
||||||
|
variables is '-', while if the parameter is specified as '-' in the
|
||||||
|
parameter list, the value of the action/Shorewall variable is '', if it is
|
||||||
|
expanded before the DEFAULTS statement.</para>
|
||||||
|
|
||||||
|
<para>Additionally, when an expression is evaluated, the value 0 evaluates
|
||||||
|
as false, so '?IF @n' and '?IF $n' fail if the nth parameter is passed
|
||||||
|
with value zero. To make testing of the presense of parameters more
|
||||||
|
efficient and uniform, an new function has been added in Shorewall 5.0.7
|
||||||
|
for use in ?IF and ?ELSEIF:</para>
|
||||||
|
|
||||||
|
<simplelist>
|
||||||
|
<member>?IF [!] passed(<variable>)</member>
|
||||||
|
</simplelist>
|
||||||
|
|
||||||
|
<para>where <variable> is an action or Shorewall variable.</para>
|
||||||
|
|
||||||
|
<para>'passed(@n)' and 'passed($n)' evaluate to true if the nth parameter
|
||||||
|
is not empty and its contents are other than '-'. If '!' is present, the
|
||||||
|
result is inverted.</para>
|
||||||
|
|
||||||
|
<para>In this simple form, the expression is evaluated by the compiler
|
||||||
|
without having to invoke the (expensive) Perl exec() function. The
|
||||||
|
'passed' function may also be used in more complex expressions, but exec()
|
||||||
|
will be invoked to evaluate those expressions. </para>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
<section id="Conditional">
|
<section id="Conditional">
|
||||||
|
Loading…
Reference in New Issue
Block a user