Welcome! This repository is the standard library for open source Semgrep rules.
In addition to the rules in this repository, the Semgrep Registry offers proprietary Pro rules that enable interfile and interprocedural analysis.
- Find rules: search for open source and Pro rules through the Semgrep registry search.
- Use rules: Scan your code with these rules through Semgrep AppSec Platform
- Contribute to rules: see Contributing to Semgrep rules for more information.
To start writing and using Semgrep rules, see Learn Semgrep syntax and Writing rules. Then, run existing and custom Semgrep rules locally with the Semgrep command line interface (Semgrep CLI) or continuously with Semgrep in CI while using Semgrep AppSec Platform.
See Writing rules for information including:
- Pattern syntax, describing what Semgrep patterns can do in detail, and example use cases of the ellipsis operator, metavariables.
- Rule syntax, describing Semgrep YAML rule files, which can have multiple patterns, detailed output messages, and autofixes. The syntax allows the composition of individual patterns with boolean operators.
You can also learn how to write rules using the interactive, example-based Semgrep rule tutorial.
We welcome Semgrep rule contributions directly to this repository! When submitting your contribution, you grant Semgrep, Inc. a license to use, modify, and distribute your contribution under the Semgrep Rules License v. 1.0. This ensures your rule can be shared with other Semgrep Registry users.
To contribute, please review our Contributing to Semgrep rules guidelines.
You can also reach out to us at support@semgrep.com, and we will help import your rules for others to use!
Join Slack for the fastest answers to your questions! Or contact the team at support@semgrep.com.
If you fork this repository or create your own, you can add a GitHub Action to your workflow that will automatically test your rules using the latest version of Semgrep. See our semgrep-rules-test example.
Rulesets are groups of rules organized by purpose, language, or framework sourced from the Semgrep Registry. If you want to modify existing rulesets or create your own, please contact us at support@semgrep.com.