ast-grep-essentials is a community-led collection of ast-grep rules to help developers mitigate security vulnerabilities and enforce best practices in their codebases.
Tip
Please read the CodeRabbit documentation to understand how to use ast-grep in CodeRabbit reviews.
ast-grep-essentials │ ├── rules │ ├── javascript │ │ ├── jwt │ │ │ ├── rule1.yml │ │ │ ├── rule2.yml │ │ │ └── ... │ │ ├── ... │ │ └── ... │ └── go │ ├── jwt-go │ │ ├── rule1.yml │ ├── utils │ ├── script1.yml │ ├── script2.yml │ └── ... │ └── tests ├── javascript │ ├── rule1-test.yml │ ├── rule2-test.yml │ └── ... ├── ... └── ... The package is organized into three main directories:
rules: Containsast-greprules categorized by language and security category.utils: Houses utility configs to support rule management.tests: Includes test cases for validating the effectiveness of the rules across different languages.
Within the rules directory, you'll find the following structure:
language: Each language supported byast-grep(e.g., Python, JavaScript).category: Rules categorized based on security concerns (e.g., Input Validation, Authentication).
Tip
Read the ast-grep > documentation to understand the rule configuration and the rule object properties.
Each rule file should have the following structure:
# Unique across the package, not just the language id: rule-id # The language property that the rule is going to get matched against language: "language" # e.g., javaScript, go # A short description of the rule message: "Rule message" # A more detailed explanation of the rule note: "Rule note" # Severity level of the rule (e.g., hint, warning) severity: "severity" # ast-grep rule property, check documentation for more information rule: ...Inside the tests directory, tests are organized by language:
language: Test cases specific to the corresponding language's rules.rule-file: each test rule file should have by convention therule-file-name-test.ymlformat.
Note
Tests should follow the ast-grep testing rules format. Please refer to the ast-grep documentation
This project relies on the community to contribute rules. Please open a pull request with your rules and tests. Please ensure that the rules are truly essential and have a low false positive rate.
Join the discussion on our Discord server.