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 to this repository, we’ll ask you to make Semgrep, Inc. a joint owner of your contributions. While you still own copyright rights to your rule, joint ownership allows Semgrep, Inc. to license these contributions to other Semgrep Registry users pursuant to the LGPL 2.1 under the Commons Clause. See full license details.
Note: To contribute, review the Contributing to Semgrep rules documentation.
You can also contact us at support@semgrep.com to make Semgrep rule contributions. We will import your rules for everyone 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.