NAME

App::Wubot::Conditions - evaluation conditions on reactor rules

VERSION

version 0.3.3

SYNOPSIS

use App::Wubot::Conditions;

my $cond = App::Wubot::Conditions->new();

# prints 'OK'
print "OK\n" if $cond->istrue( "foo equals 5", { foo => 5 } );

DESCRIPTION

There are a number of conditions that are available for the rules:

- {fieldname} equals {value}
  - values of field {fieldname} on the message equals the specified value

- {fieldname} matches {regexp}
  - value of field {fieldname} matches specified regexp

- {fieldname} imatches {regexp}
  - case insensitve regexp match

- contains {fieldname}
  - the message contains the field, the value of the field may be undefined or 0

- {fieldname} is false
  - the field has a value that is false according to perl, i.e. undef, 0, or ""

- {fieldname} is true
  - the field has a value which is true according to perl, i.e. not undef, 0, or ""

You can also make numeric comparisons between fields and values or fields and other fields.

- operators: <, <=, >, >=,
  - {fieldname} {operator} {value}
  - {fieldname} {operator} {fieldname}

- examples:
  - size > 300
  - heatindex > temperature

Any rule can be prefixed by NOT, as in:

- NOT title matches foo
  - true unless the title contains 'foo'

You can string together multiple rules using AND and OR. You MUST capitalize the "AND" and "OR" or else the rule will not be parsed properly.

- subject is true AND body is true
  - true if the subject and body are populated

- title matches foo OR body matches foo
  - true if the title or body contains the string 'foo'

- NOT title matches foo AND NOT body matches foo
  - true as long as 'foo' does not occur in either the title or body

SUBROUTINES/METHODS

istrue( $condition, $message )

Process conditions on the specified message. Returns a true value if the message satisfies the condition.

LIMITATIONS

Unfortunately you can not (yet) use parens within conditions. Conditions are evaluated from left to right in order, e.g.

- x is true AND y is true OR z is true
  - evaluates as: x is true AND ( y is true OR z is true )

The main mechanism for nesting conditions is to use rule trees. Child rules are only evaluated if the parent rule matches, so parent and child rules are logically combined by AND. For example, set the field 'foo' to the value '1' based on the following logic:

( x is true OR y is true ) AND ( a is true OR b is true )

You could create the following rule tree:

rules:
  - name: check x and y
    condition: x is true OR y is true
    rules:
      - name: check a and b
        condition: a is true OR b is true
        plugin: SetField
        config:
          field: foo
          value: 1