Syntax des Abschnitts „Bedingungen“
In diesem Dokument wird beschrieben, wie Sie den condition-Abschnitt einer YARA-L-Abfrage verwenden können. Der Abschnitt condition wird für die Suche und in Dashboards verwendet. Er ist für Regeln erforderlich und enthält Logik zum weiteren Filtern von Ergebnissen. Bei Verwendung in einer Such- oder Dashboard-Abfrage wird nur die Ausgabe angezeigt, die den Bedingungen entspricht. Wenn sie in einer Erkennungsregel verwendet werden, müssen die Bedingungen erfüllt sein, damit eine Benachrichtigung ausgelöst wird.
Im Abschnitt condition können Sie boolesche Operatoren, Vergleichsoperatoren und Ergebnisse von outcome-Variablen verwenden, um festzulegen, ob die Abfrage ausgelöst werden soll.
condition-Abschnitt definieren
Definieren Sie die Bedingungsausdrücke für Ereignisse und Platzhaltervariablen im Abschnitt condition. Sie können auch eine Abgleichbedingung für Ereignisse und Platzhalter angeben, die im Abschnitt events definiert sind. Optional können Sie das Keyword and verwenden, um eine Abgleichbedingung mit Ergebnisvariablen anzugeben, die im Abschnitt outcome definiert sind (siehe Syntax für Ergebnisabschnitt).
Sie können die Ausdrücke mit den Schlüsselwörtern and oder or verknüpfen:
Verwenden Sie
andzwischen den Bedingungen.Verwenden Sie
ornur, wenn die Abfrage eine einzelne Ereignisvariable enthält.
Verwenden Sie das Zeichen # im Abschnitt condition vor einem beliebigen Ereignis- oder Platzhaltervariablennamen, um die Anzahl der unterschiedlichen Ereignisse oder Werte darzustellen, die alle Bedingungen im Abschnitt events erfüllen. Beispiel:
#c > 1 bedeutet, dass die Variable c mehr als einmal vorkommen muss.
Verwenden Sie das Zeichen $ im Abschnitt condition vor dem Namen einer Ergebnisvariablen, um den Wert dieses Ergebnisses darzustellen. Wenn es vor einem Ereignis- oder Platzhaltervariablennamen verwendet wird (z. B. $event), steht es für #event > 0.
Bei dieser Beispielregel wird ein Ergebnis zurückgegeben, wenn es innerhalb eines 10-Minuten-Zeitraums (wie im Abschnitt match definiert) mehr als fünf fehlgeschlagene Anmeldeversuche für jeden Nutzer gibt (wie im Abschnitt condition definiert):
rule failed_logins
{
meta:
author = "Security Team"
description = "Detects multiple failed user logins within 10-minute windows."
severity = "HIGH"
events:
$e.metadata.event_type = "USER_LOGIN"
$e.security_result.action = "FAIL"
$user = $e.target.user.userid
match:
$user over 10m
outcome:
$failed_login_count = count($e.metadata.id)
$first_fail_time = min($e.metadata.event_timestamp.seconds)
condition:
#e >= 5
}
Begrenzte und unbegrenzte Bedingungen
Sie können in einer Abfrage begrenzte oder unbegrenzte Bedingungen verwenden:
Durch begrenzte Bedingungen wird erzwungen, dass die zugehörige Ereignisvariable vorhanden ist. Das bedeutet, dass mindestens ein Auftreten des Ereignisses in der Erkennung enthalten sein muss. Die folgenden Bedingungen sind begrenzt:
$var // equivalent to #var > 0#var > n // where n >= 0#var >= m // where m > 0Mit unbegrenzten Bedingungen kann das Fehlen eines Ereignisses über einen bestimmten Zeitraum hinweg erkannt werden, z. B. ein Bedrohungsereignis ohne ein Ereignis zur Risikominderung innerhalb eines Zeitfensters von 10 Minuten. Bei ungebundenen Bedingungen kann die zugehörige Ereignisvariable nicht vorhanden sein (Abfragen ohne Existenz). Das bedeutet, dass das Ereignis möglicherweise nicht in einem erkannten Vorfall vorkommt und jeder Verweis auf Felder in der Ereignisvariablen einen Nullwert ergibt.
Die folgenden Bedingungen sind unbegrenzt:
!$var // equivalent to #var = 0#var >= 0#var < n // where n > 0#var <= m // where m >= 0
Anforderungen für Anfragen zum Nichtvorhandensein
Damit eine Abfrage zum Nichtvorhandensein kompiliert werden kann, muss sie die folgenden Anforderungen erfüllen:
- Mindestens ein UDM-Ereignis muss eine begrenzte Bedingung haben (d. h., es muss mindestens ein UDM-Ereignis vorhanden sein).
- Wenn ein Platzhalter eine unbegrenzte Bedingung hat, muss er mindestens einem begrenzten UDM-Ereignis zugeordnet sein.
- Wenn eine Entität eine unbegrenzte Bedingung hat, muss sie mindestens einem begrenzten UDM-Ereignis zugeordnet sein.
Beispiel: Abfrage zur Nichtexistenz
Betrachten Sie die folgende Abfrage, in der der Bedingungsabschnitt fehlt:
rule NonexistenceExample {
meta:
author = "Google Security"
description = "Example: non-existence query."
events:
$u1.metadata.event_type = "NETWORK_CONNECTION" // $u1 is a UDM event.
$u2.metadata.event_type = "NETWORK_CONNECTION" // $u2 is a UDM event.
$e1.graph.metadata.entity_type = "FILE" // $e1 is an entity.
$e2.graph.metadata.entity_type = "FILE" // $e2 is an entity.
$user = $u1.principal.user.userid // Match variable is required for multi-event query.
// Placeholder Associations:
// u1 u2
// | \ /
// port ip
// | \
// e1 e2
$u1.target.port = $port
$e1.graph.entity.port = $port
$u1.principal.ip = $ip
$u2.target.ip = $ip
$e2.graph.entity.ip = $ip
// UDM-Entity Associations:
// u1 - u2
// | \ |
// e1 e2
$u1.metadata.event_type = $u2.metadata.event_type
$e1.graph.entity.hostname = $u1.principal.hostname
$e2.graph.entity.hostname = $u1.target.hostname
$e2.graph.entity.hostname = $u2.principal.hostname
match:
$user over 5m
condition:
//Add valid condition
}Abschnitt „Gültige Bedingung“
Hier sind einige gültige Beispiele für den Bedingungsabschnitt:
$u1 and !$u2 and $e1 and $e2- Alle UDM-Ereignisse und ‑Entitäten sind im Abschnitt „condition“ vorhanden.
- Mindestens ein UDM-Ereignis ist begrenzt.
$u1 and !$u2 and $e1 and !$e2$e2ist unbegrenzt und zulässig, da es mit$u1verknüpft ist, das begrenzt ist. Wenn$e2nicht mit$u1verknüpft wäre, wäre das ungültig.#port > 50 and #ip = 0- Im Abschnitt „condition“ sind keine UDM-Ereignisse und ‑Entitäten vorhanden. Die vorhandenen Platzhalter decken jedoch alle UDM-Ereignisse und ‑Entitäten ab.
$ipist sowohl$u1als auch$u2zugewiesen und#ip = 0ist eine unbegrenzte Bedingung. Begrenzte Bedingungen sind jedoch stärker als unbegrenzte Bedingungen. Da$port$u1zugewiesen ist und#port > 50eine begrenzte Bedingung ist, ist$u1weiterhin begrenzt.
Ungültiger Abschnitt für Bedingungen
Hier sind einige ungültige Beispiele für den Bedingungsabschnitt:
$u1 and $e1- Jedes UDM-Ereignis und jede UDM-Entität, die im Abschnitt
eventsaufgeführt ist, muss auch im Abschnittconditionaufgeführt sein (oder es muss ein Platzhalter dafür zugewiesen sein, der im Abschnittconditionaufgeführt ist). $u1, $u2, $e1, $u2, #port > 50- Kommas sind als Trennzeichen für Bedingungen nicht zulässig.
!$u1 and !$u2 and $e1 and $e2- Verstößt gegen die erste Anforderung, dass mindestens ein UDM-Ereignis begrenzt ist.
($u1 or #port < 50) and $u2 and $e1 and $e2- Das
or-Keyword wird bei unbegrenzten Bedingungen nicht unterstützt. ($u1 or $u2) and $e1 and $e2- Das Keyword
orwird nicht zwischen verschiedenen Ereignisvariablen unterstützt. not $u1 and $u2 and $e1 and $e2- Das
not-Schlüsselwort ist für Ereignis- und Platzhalterbedingungen nicht zulässig. #port < 50 and #ip = 0- Die Platzhalter verweisen zwar auf alle UDM-Ereignisse und ‑Entitäten, aber jede zugehörige Bedingung ist unbegrenzt. Das bedeutet, dass keines der UDM-Ereignisse begrenzt ist, was dazu führt, dass die Regel nicht kompiliert werden kann.
Ergebnisbedingungen
Sie können Bedingungen für Ergebnisvariablen im Abschnitt condition einfügen, die mit dem Keyword and oder or verknüpft oder dem Keyword not vorangestellt sind.
Die Bedingungen für das Ergebnis werden je nach Art der Ergebnisvariablen unterschiedlich angegeben:
integer: Vergleich mit einem Ganzzahl-Literal mit Operatoren
=, >, >=, <, <=, !=Beispiel:$risk_score > 10float: Vergleich mit einem Gleitkomma-Literal mit Operatoren
=, >, >=, <, <=, !=Beispiel:$risk_score <= 5.5string: Vergleich mit einem Stringliteral mit
=oder!=Beispiel:$severity = "HIGH"Liste mit Ganzzahlen oder Arrays: Bedingung mit der Funktion
arrays.containsangeben Beispiel:arrays.contains($event_ids, "id_1234")
Wenn Sie in einer Abfrage mit einem match-Abschnitt eine Ergebnisbedingung angeben, wird die Abfrage für das Abfragekontingent als Multi-Event-Abfrage klassifiziert. Weitere Informationen zur Syntax für den Abgleich finden Sie unter Syntax für den Abgleich.
Beschränkungen
Vermeiden Sie die Verwendung einer
match-Variablen imcondition-Abschnitt. Es handelt sich um einen semantischen Fehler, da Ereignisse nach demmatch-Variablenwert gruppiert werden.Vermeiden Sie es, nur ungebundene Bedingungen für alle
event-Variablen anzugeben, denen einematch-Variable zugewiesen ist. Es handelt sich um einen semantischen Fehler. Damit einmatch-Variablenwert zurückgegeben wird, muss mindestens ein Ereignis vorhanden sein, das den Wert enthält.Wenn Sie ein gleitendes Fenster verwenden, muss die Pivot-Ereignisvariable in mindestens einer begrenzten Bedingung enthalten sein.
Nächste Schritte
- Syntax des Optionsbereichs
- „oder“ im Bedingungsabschnitt verwenden
- N OF-Syntax mit Ereignisvariablen verwenden
Weitere Informationen
- Ausdrücke, Operatoren und Konstrukte in YARA-L 2.0
- Funktionen in YARA-L 2.0
- Zusammengesetzte Erkennungsregeln erstellen
- Beispiele: YARA-L 2.0-Abfragen
Benötigen Sie weitere Hilfe? Antworten von Community-Mitgliedern und Google SecOps-Experten erhalten