Files
Anthropic-Cybersecurity-Skills/skills/performing-yara-rule-development-for-detection/references/api-reference.md
T
mukul975 c21af3347e Complete folder anatomy for all 649 cybersecurity skills + update LICENSE to Mahipal
- Add scripts/agent.py and references/api-reference.md to all remaining skills
- Update all 648 LICENSE files: copyright now reads 'Mahipal'
- Add implementing-security-monitoring-with-datadog (new skill with full anatomy)
- All 649 skills now have: SKILL.md, LICENSE, scripts/agent.py, references/api-reference.md
2026-03-11 00:22:12 +01:00

1.9 KiB

API Reference: YARA Rule Development for Detection

yara-python API

Method Description
yara.compile(filepath=path) Compile rule from file
yara.compile(source=string) Compile rule from string
yara.compile(filepaths={ns: path}) Compile with namespaces
rules.match(filepath=path) Scan file against compiled rules
rules.match(data=bytes) Scan bytes in memory
rules.match(filepath, timeout=30) Scan with timeout

Match Object Attributes

Attribute Description
match.rule Name of matching rule
match.namespace Rule namespace
match.tags Rule tags list
match.meta Rule metadata dict
match.strings List of (offset, identifier, data)

YARA Rule Structure

rule RuleName : tag1 tag2 {
    meta:
        description = "..."
        author = "..."
        date = "2025-01-01"
        hash = "sha256_of_sample"
    strings:
        $s1 = "string" ascii
        $s2 = "wide_string" wide
        $h1 = { 4D 5A 90 00 }
        $r1 = /regex[0-9]+/
    condition:
        uint16(0) == 0x5A4D and 3 of ($s*)
}

Condition Operators

Operator Description
X of ($s*) X or more strings match
all of ($s*) All strings match
any of ($s*) At least one matches
uint16(0) == 0x5A4D PE file magic bytes
filesize < 10MB File size constraint

Python Libraries

Library Version Purpose
yara-python >=4.3 Compile and scan YARA rules
hashlib stdlib SHA256 of samples
re stdlib String extraction

References