Top Related Projects
Repository of yara rules
YARA signature and IOC database for my scanners and tools
Suricata is a network Intrusion Detection System, Intrusion Prevention System and Network Security Monitoring engine developed by the OISF and the Suricata community.
Elastic Security detection content for Endpoint
Quick Overview
YARA is a tool aimed at helping malware researchers identify and classify malware samples. It allows users to create descriptions of malware families based on textual or binary patterns. These descriptions, called YARA rules, can be used to scan files, processes, or memory dumps to find matching patterns.
Pros
- Highly flexible and powerful pattern matching capabilities
- Supports a wide range of data types and operators
- Integrates well with other security tools and platforms
- Active community and regular updates
Cons
- Steep learning curve for creating complex rules
- Performance can be impacted when using many complex rules
- Limited built-in support for analyzing encrypted or packed malware
- Requires manual creation and maintenance of rules
Code Examples
- Basic YARA rule structure:
rule ExampleRule
{
meta:
description = "This is a basic YARA rule"
author = "Your Name"
date = "2023-04-20"
strings:
$string1 = "suspicious_string"
$hex_string = { 4D 5A 90 00 03 00 00 00 }
condition:
$string1 or $hex_string
}
- Using logical operators in conditions:
rule LogicalOperators
{
strings:
$a = "function_name1"
$b = "function_name2"
$c = "function_name3"
condition:
2 of ($a, $b, $c) and filesize < 1MB
}
- Using regular expressions:
rule RegexExample
{
strings:
$email = /[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}/
condition:
$email
}
Getting Started
-
Install YARA:
git clone https://github.com/VirusTotal/yara.git cd yara ./bootstrap.sh ./configure make sudo make install
-
Create a YARA rule file (e.g.,
myrule.yar
) with your rules. -
Run YARA on a file or directory:
yara myrule.yar /path/to/file_or_directory
-
For more advanced usage, refer to the official documentation.
Competitor Comparisons
Repository of yara rules
Pros of rules
- Extensive collection of pre-written YARA rules for various malware families and threats
- Community-driven project with frequent updates and contributions
- Ready-to-use rules for immediate implementation in security systems
Cons of rules
- May include outdated or less accurate rules if not regularly maintained
- Potential for false positives due to the broad nature of some rules
- Requires careful review and testing before deployment in production environments
Code comparison
rules:
rule Cryptolocker {
meta:
description = "Detect Cryptolocker ransomware"
strings:
$a = "CryptoLocker"
condition:
$a
}
yara:
int yr_compiler_add_string(
YR_COMPILER* compiler,
const char* identifier,
const char* string,
int flags)
{
// Implementation details
}
The rules repository focuses on providing YARA rule definitions, while the yara repository contains the core YARA engine implementation. The code snippets illustrate this difference, with rules showing a sample YARA rule and yara displaying a C function from the compiler.
YARA signature and IOC database for my scanners and tools
Pros of signature-base
- Extensive collection of pre-made YARA rules for various threats
- Regularly updated with new signatures for emerging malware
- Includes additional tools and scripts for threat detection
Cons of signature-base
- Focused on signatures rather than the YARA engine itself
- May require more frequent updates to stay current with threats
- Potentially higher false positive rate due to broader rule coverage
Code Comparison
YARA (rule definition):
rule ExampleRule {
strings:
$a = "suspicious_string"
condition:
$a
}
signature-base (rule example):
rule APT_MAL_GENERIC {
meta:
description = "Detects generic APT malware"
strings:
$s1 = "cmd.exe /c " nocase
$s2 = "powershell.exe -nop -w hidden -c " nocase
condition:
any of them
}
YARA is a tool for creating and using rules to identify and classify malware samples, while signature-base is a collection of pre-made YARA rules and other detection mechanisms. YARA provides the foundation for creating custom rules, whereas signature-base offers a ready-to-use set of rules for various threats. Users looking to develop their own rules may prefer YARA, while those seeking immediate threat detection capabilities might find signature-base more suitable.
Suricata is a network Intrusion Detection System, Intrusion Prevention System and Network Security Monitoring engine developed by the OISF and the Suricata community.
Pros of Suricata
- Real-time network traffic analysis and intrusion detection
- Supports multi-threading for high-performance processing
- Extensive protocol support and application layer inspection
Cons of Suricata
- Higher resource consumption due to complex analysis
- Steeper learning curve for rule writing and configuration
- Limited to network-based detection, unlike YARA's file-based approach
Code Comparison
Suricata rule example:
alert http $HOME_NET any -> $EXTERNAL_NET any (msg:"Suspicious HTTP Request";
content:"GET"; http_method; content:"/malicious.php"; http_uri;
sid:1000001; rev:1;)
YARA rule example:
rule SuspiciousFile {
strings:
$suspicious = "malicious_function"
condition:
$suspicious
}
Both tools use rule-based detection, but Suricata focuses on network traffic while YARA targets file content. Suricata rules are more network-oriented, specifying protocols and IP ranges. YARA rules are simpler and concentrate on file characteristics and content matching.
Elastic Security detection content for Endpoint
Pros of protections-artifacts
- Focuses on Elastic Security-specific rules and detections
- Provides a comprehensive set of security content for Elastic environments
- Includes additional artifacts like machine learning jobs and dashboards
Cons of protections-artifacts
- Limited to Elastic Security ecosystem
- May have a steeper learning curve for users not familiar with Elastic Stack
- Less versatile for general-purpose malware analysis compared to YARA
Code Comparison
YARA rule example:
rule ExampleRule {
strings:
$a = "suspicious_string"
condition:
$a
}
Elastic rule example:
rule:
name: Suspicious Process Execution
type: eql
query: |
process where process.name == "suspicious.exe"
Summary
YARA is a versatile, widely-used tool for malware analysis and pattern matching across various platforms. It offers a simple yet powerful syntax for creating detection rules.
protections-artifacts, on the other hand, is tailored specifically for Elastic Security users. It provides a comprehensive set of security content, including detection rules, machine learning jobs, and dashboards, making it a valuable resource for organizations using the Elastic Stack for security monitoring and threat detection.
While YARA excels in general-purpose malware analysis, protections-artifacts shines in Elastic-specific environments, offering a more integrated approach to security within the Elastic ecosystem.
Pros of red_team_tool_countermeasures
- Focuses specifically on countermeasures against known red team tools
- Provides detailed detection rules and mitigation strategies
- Regularly updated with new threat intelligence
Cons of red_team_tool_countermeasures
- Limited scope compared to YARA's versatility
- Requires more manual implementation and customization
- May not be as effective against novel or custom malware
Code Comparison
YARA rule example:
rule suspicious_behavior {
strings:
$a = "CreateRemoteThread"
$b = "VirtualAllocEx"
condition:
$a and $b
}
red_team_tool_countermeasures detection rule example:
<Sysmon schemaversion="4.30">
<EventFiltering>
<RuleGroup name="Suspicious Process Creation">
<ProcessCreate onmatch="include">
<CommandLine condition="contains">powershell.exe -nop -w hidden</CommandLine>
</ProcessCreate>
</RuleGroup>
</EventFiltering>
</Sysmon>
Both repositories offer valuable tools for threat detection and analysis. YARA provides a flexible pattern matching language for malware identification, while red_team_tool_countermeasures focuses on specific countermeasures against known red team tools. YARA is more versatile and can be applied to various file types, while red_team_tool_countermeasures offers more targeted detection rules for specific attack techniques.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
YARA in a nutshell
YARA is a tool aimed at (but not limited to) helping malware researchers to identify and classify malware samples. With YARA you can create descriptions of malware families (or whatever you want to describe) based on textual or binary patterns. Each description, a.k.a. rule, consists of a set of strings and a boolean expression which determine its logic. Let's see an example:
rule silent_banker : banker
{
meta:
description = "This is just an example"
threat_level = 3
in_the_wild = true
strings:
$a = {6A 40 68 00 30 00 00 6A 14 8D 91}
$b = {8D 4D B0 2B C1 83 C0 27 99 6A 4E 59 F7 F9}
$c = "UVODFRYSIHLNWPEJXQZAKCBGMT"
condition:
$a or $b or $c
}
The above rule is telling YARA that any file containing one of the three strings must be reported as silent_banker. This is just a simple example, more complex and powerful rules can be created by using wild-cards, case-insensitive strings, regular expressions, special operators and many other features that you'll find explained in YARA's documentation.
YARA is multi-platform, running on Windows, Linux and Mac OS X, and can be used through its command-line interface or from your own Python scripts with the yara-python extension.
Additional resources
Do you use GitHub for storing your YARA rules? YARA-CI may be a useful addition to your toolbelt. This is GitHub application that provides continuous testing for your rules, helping you to identify common mistakes and false positives.
If you plan to use YARA to scan compressed files (.zip, .tar, etc) you should take a look at yextend, a very helpful extension to YARA developed and open-sourced by Bayshore Networks.
Additionally, the guys from InQuest have curated an awesome list of YARA-related stuff.
Who's using YARA
- 0x101 Cyber Security
- Adlice
- AlienVault
- Avast
- BAE Systems
- Bayshore Networks, Inc.
- Binalyze
- BinaryAlert
- Blueliv
- Cado Security
- Cisco Talos Intelligence Group
- Cloudina Security
- Cofense
- Conix
- Corelight
- CounterCraft
- Cuckoo Sandbox
- Cyber Triage
- Cybereason
- Digita Security
- Dragos Platform
- Dtex Systems
- ESET
- ESTsecurity
- Elastic Security
- Fidelis XPS
- FireEye, Inc.
- Forcepoint
- Fox-IT
- FSF
- Guidance Software
- Heroku
- Hornetsecurity
- ICS Defense
- InQuest
- IntelOwl
- Joe Security
- Kaspersky Lab
- KnowBe4
- Koodous
- Laika BOSS
- Lastline, Inc.
- libguestfs
- LimaCharlie
- Malpedia
- Malwation
- McAfee Advanced Threat Defense
- Metaflows
- NBS System
- ndaal
- NetLock
- Nextron Systems
- Nozomi Networks
- osquery
- Payload Security
- PhishMe
- Picus Security
- Radare2
- RedSocks Security
- ReversingLabs
- Scanii
- SecondWrite
- SonicWall
- SpamStopsHere
- Spyre
- stoQ
- Sublime Security
- SumoLogic
- Tanium
- Tenable Network Security
- Tenzir
- The DigiTrust Group
- ThreatConnect
- ThreatStream, Inc.
- Thug
- Threat.Zone
- TouchWeb
- Trend Micro
- UnpacMe
- UpSight Security Inc.
- Uptycs Inc
- Veeam
- Verisys Antivirus API
- VirusTotal Intelligence
- VMRay
- Volexity
- We Watch Your Website
- x64dbg
- YALIH
Are you using it? Want to see your site listed here?
Top Related Projects
Repository of yara rules
YARA signature and IOC database for my scanners and tools
Suricata is a network Intrusion Detection System, Intrusion Prevention System and Network Security Monitoring engine developed by the OISF and the Suricata community.
Elastic Security detection content for Endpoint
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot