Rules Format
Rules files allow you to specify actions to perform when criteria are met with certain fields or state.
The rules files are in yaml format and are specified in the config.ini using rulesFiles=
setting.
There can be multiple files using a semicolon separated listed.
Each file can have multiple rules.
The files will automatically reloaded when they are changed, you do NOT need to restart capture.
Check out the rules gallery for inspiration, or add your rule file to help out others!
Each rule must have a
- name - friendly name
- when - when is the rule checked
- ops - A set of operations to perform
A rule then must also have one of the following
- fields - what fields to check
- bpf - A bpf expression
Sample rule that will drop all tls packets after the first 20 packets
---
version: 1
rules:
- name: "Drop tls"
when: "fieldSet"
fields:
protocols:
- tls
ops:
_maxPacketsToSave: 20
If you want to add several rules, then the synatax is as follows. Make sure to have only one “rules:” per file.
---
version: 1
rules:
- name: "Drop localhost"
when: "fieldSet"
fields:
ip.src:
- 127.0.0.1
ops:
_maxPacketsToSave: 10
- name: "Drop localhost"
when: "fieldSet"
fields:
ip.dst:
- 127.0.0.1
ops:
_maxPacketsToSave: 10
When
Possible values for the when field, only available when using a field check:
- sessionSetup - Check just during the first few packets of a session.
- afterClassify - Check after the session has run thru the classifiers
- fieldSet - Check when ever a field has been set, the most common value for when
- beforeMiddleSave - Check before doing a mid save
- beforeFinalSave - Check before doing a final save
- beforeBothSave - Check before either a mid or final save
Possible values for the when field, only available when using a bpf check:
- sessionSetup - Check just during the first few packets of a session. The config settings dontSaveBPFs and minPacketsSaveBPFs are converted to sessionSetup rules.
- everyPacket - Check after every packet
Fields
A map of field expressions and values for each field, one value from each field expression must be set. Currently not all field expressions are supported, but will be added over time.
The following example would require that the protocols field is set to tls and that host.http was set to one of the 3 values. If those two fields are set, then it will add tlsrulestest to the protocols field.
- name: "Set tlsrulestest on certain hosts"
when: "fieldSet"
fields:
protocols:
- tls
host.http:
- www.aol.com
- mail.google.com
- foo.bar.com
ops:
"protocols": "tlsrulestest"
String Fields Modifier
While we don’t support wildcards in strings fields, we do support 3 different modifiers that allow you to perform some of the same actions. Rules support endsWith, startsWith, or contains modifiers which are placed after the field name separated by a comma. So for example you could do the following to get aol.com, google.com, and any sub hostnames of those two domains.
- name: "Set tlsrulestest on certain hosts and any subdomains"
when: "fieldSet"
fields:
protocols:
- tls
host.http:
- aol.com
- google.com
host.http,endsWith:
- .aol.com
- .google.com
ops:
"protocols": "tlsrulestest"
Numeric ranges
Since Akrime 3.4.1 you can also specify numeric ranges for integer fields. Use the format of MIN-MAX. For example this rule requires the src port to be < 1024 and dst port be > 1024
- name: "low src high dst"
when: "fieldSet"
fields:
protocols:
- tls
port.src
- 1-1023
port.dst
- 1024-65535
ops:
"protocols": "lowsrcport"
NOT fields
Since Arkime 5.1.1 you can also speciy fields that match when a value is NOT in the list for string and integer fields. These fields can not be used with the fieldSet when attribute. To special a NOT field use a exclamtion mark before the field name.
- name: "NOT example"
when: "beforeFinalSave"
fields:
"!protocols":
- tcp
- http
- dns
ip.src: 10.0.0.2
ops:
"tags": "nottcpdnshttp"
Ops
The operations are a map of the fields to set in the session. There are some special field names that set meta data about the session.
Special field names
_dontSaveSPI: 1
- Don’t save SPI data for session, either 0 or 1_maxPacketsToSave: 20
- Try to save at most 20 packets, max value is 65535. Arkime will sometimes save more packets if it couldn’t determine to stop saving packets until later._minPacketsBeforeSavingSPI: 33
- Don’t save SPI data unless 33 many packets have been sent/received, max value is 255_dropByDst: 5
- (Since 1.5) drop all traffic to dst ip:port for 5 minutes. This is good for dropping traffic that is going to the cloud and has shifting ips._dropBySrc: 10
- (Since 1.5) drop all traffic from src ip:port for 10 minutes. You probably almost never want to use this._dontCheckYara: 1
- (Since 1.6) don’t check yara for remaining packets of session, either 0 or 1_closeNow: 1
- (Since 5.4.1) mark the session to be closed now_flipSrcDst: 1
- (Since 5.6.0) flip the src and dst ip/port for the session
The following example would not save syn scans, it requires all 3 fields to be set
- name: "Drop syn scan"
when: "beforeFinalSave"
fields:
packets.src: 1
packets.dst: 0
tcpflags.syn: 1
ops:
_dontSaveSPI: 1
The _dropByDst
and _dropBySrc
are very powerful if you want to drop traffic where the src/dst ips could be ever shifting, such as a host on AWS.
The packets are also dropped very early in the Arkime packet flow, so it can help with cpu.
Here is an example that will start dropping any traffic to a ip that was used to talk to ad.beacon.something.example.com.
Of course if other hosts use that same server from host header sharing that traffic will be dropped too, so be careful.
- name: "Drop ad beacon"
when: "fieldSet"
fields:
host.http:
- ad.beacon.something.example.com
- ad2.beacon.something.example.com
ops:
_dontSaveSPI: 1
_dropByDst: 10
Integer Ops Bounding
Since Arkime 4.1.0 it is possible to have operations that only change a value if the value is less than or greater than the new value.
This is useful when you have 2 rules changing the same value, and you want to make sure which rule will be used.
To specify, use min NEWVALUE
to only change the value if less and max NEWVALUE
to only change the value if greater.
In the example below, if foo.aol.com is seen, the first rule sets packets to save to 20 no matter what the previous value is, the second rule will NOT override it to 200 since it has the min modifier.
Think of it as doing a min(current value, 200)
or min(20, 200)
which would be 20
.
- name: "foo.aol.com"
when: "fieldSet"
fields:
host.http:
- foo.aol.com
ops:
_maxPacketsToSave: 20
- name: "*.aol.com"
when: "fieldSet"
fields:
host.http,endsWith:
- .aol.com
ops:
_maxPacketsToSave: "min 200"
Logging
Since 3.0.0 you can log when a rule is matched using the optional log element.
- name: "Drop ad beacon"
log: true
when: "fieldSet"
fields:
host.http:
- ad.beacon.something.example.com
ops:
_dropByDst: 10
Special Fields
Capture rules supports some special fields that don’t aren’t actually written to OpenSearch/Elasticsearch.
Field | Description |
---|---|
ip.dst:port | The destination ip and port in string format |
dst.ip:port | The destination ip and port in string format |
tcp.synSet | (since 5.6.0) For the session and all linked session if a syn/syn-ack was received 0 - not set, 1 - src set, 2 - dst set, 3 - both set |
Values from config file
Starting with 5.6.0 rules values can come from the config file or environment variables.
Use the new “${varname}” syntax will allow you to have either the config file value of varname=value
or the environment variable value of ARKIME_varname=value
.
For example:
- name: "Drop tls"
when: "fieldSet"
fields:
protocols:
- tls
ops:
_maxPacketsToSave: ${maxPacketsToSave}