mirror of https://github.com/OISF/suricata
doc: integer keywords
Ticket: 6628 Document the generic detection capabilities for integer keywords. and make every integer keyword pointing to this section.pull/10277/head
parent
d05f3ac791
commit
b8bc2c7e0f
@ -0,0 +1,77 @@
|
|||||||
|
.. _rules-integer-keywords:
|
||||||
|
|
||||||
|
Integer Keywords
|
||||||
|
================
|
||||||
|
|
||||||
|
Many keywords will match on an integer value on the network traffic.
|
||||||
|
These are unsigned integers that can be 8, 16, 32 or 64 bits.
|
||||||
|
|
||||||
|
Simple example::
|
||||||
|
|
||||||
|
bsize:integer value;
|
||||||
|
|
||||||
|
The integer value can be written as base-10 like ``100`` or as
|
||||||
|
an hexadecimal value like ``0x64``.
|
||||||
|
|
||||||
|
The most direct example is to match for equality, but there are
|
||||||
|
different modes.
|
||||||
|
|
||||||
|
Comparison modes
|
||||||
|
----------------
|
||||||
|
|
||||||
|
Integers can be matched for
|
||||||
|
* Equality
|
||||||
|
* Inequality
|
||||||
|
* Greater than
|
||||||
|
* Less than
|
||||||
|
* Range
|
||||||
|
* Negated range
|
||||||
|
* Bitmask
|
||||||
|
* Negated Bitmask
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Comparisons are strict by default. Ranges are thus exclusive.
|
||||||
|
That means a range between 1 and 4 will match 2 and 3, but neither 1 nor 4.
|
||||||
|
Negated range !1-4 will match for 1 or below and for 4 or above.
|
||||||
|
|
||||||
|
Examples::
|
||||||
|
|
||||||
|
bsize:19; # equality
|
||||||
|
bsize:=0x13; # equality
|
||||||
|
bsize:!0x14; # inequality
|
||||||
|
bsize:!=20; # inequality
|
||||||
|
bsize:>21; # greater than
|
||||||
|
bsize:>=21; # greater than or equal
|
||||||
|
bsize:<22; # lesser than
|
||||||
|
bsize:<=22; # lesser than or equal
|
||||||
|
bsize:19-22; # range between value1 and value2
|
||||||
|
bsize:!19-22; # negated range between value1 and value2
|
||||||
|
bsize:&0xc0=0x80; # bitmask mask is compared to value for equality
|
||||||
|
bsize:&0xc0!=0; # bitmask mask is compared to value for inequality
|
||||||
|
|
||||||
|
Enumerations
|
||||||
|
------------
|
||||||
|
|
||||||
|
Some integers on the wire represent an enumeration, that is, some values
|
||||||
|
have a string/meaning associated to it.
|
||||||
|
Rules can be written using one of these strings to check for equality.
|
||||||
|
This is meant to make rules more human-readable and equivalent for matching.
|
||||||
|
|
||||||
|
Examples::
|
||||||
|
|
||||||
|
websocket.opcode:text;
|
||||||
|
websocket.opcode:1; # behaves the same
|
||||||
|
|
||||||
|
Bitmasks
|
||||||
|
--------
|
||||||
|
|
||||||
|
Some integers on the wire represent multiple bits.
|
||||||
|
Some of these bits have a string/meaning associated to it.
|
||||||
|
Rules can be written using a list (comma-separated) of these strings,
|
||||||
|
where each item can be negated.
|
||||||
|
|
||||||
|
Examples::
|
||||||
|
|
||||||
|
websocket.flags:fin,!comp;
|
||||||
|
websocket.flags:&0xc0=0x80; # behaves the same
|
Loading…
Reference in New Issue