Skip to main content

Secure guardrails in Semgrep

Secure guardrails guide developers towards fixing security issues in the early stages of development. By deploying secure guardrails, you can:

  • Prevent issues from merging into production or default branches. This improves security posture and reduces the growth of the vulnerability backlog.
  • Reduce the time and cost to address issues—the earlier a vulnerability is detected, the faster it is to fix.

The deployment of secure guardrails maximizes the impact of early detection by providing specific and actionable remediation guidance to developers. Customization enables you to set the amount of alerts that developers receive.

This document defines secure guardrails and presents an overview of the guardrail deployment process in Semgrep.

Time to fix a true positive vulnerability Figure. Secure guardrails maximize the potential impact of early detection by providing tailored remediation guidance to developers. (Chart for illustration purposes only.)

Secure guardrails consist of:

Content

The content that identifies, explains, and provides remediation guidance for the security issue, such as the Semgrep rule and Semgrep Assistant (AI) remediation guidance.

Semgrep uses rules, which are instructions that detect patterns in your code, such as security issues, bugs, and more. Semgrep generates and reports findings to you whenever it finds code that matches the patterns defined by rules.

Semgrep rules also include a message that guides remediation and provides other metadata about the vulnerability, such as its OWASP category, which are presented to the developer. Further improvements to this guidance are made through Semgrep Assistant.

Interface
The developer-native interface where the developer can see the content and triage or remediate the finding, such as Visual Studio Code (VS Code), pre-commit on CLI, or GitHub pull request comments. See all supported interfaces.

Semgrep products provide the content; the Semgrep web app provides the means to configure developer notifications Figure. Semgrep products provide the content of the guardrail, namely its rules and suggested remediations. The Semgrep web app provides the means to configure and deploy guardrails: what rules to deploy as well as where and how to alert developers.

Qualities of secure guardrails

Speed

Scans must be quick to successfully integrate into developer workflows without slowing them down.

The following table lists the speed of a Semgrep scan in relation to the environment the scan is run in:

InterfaceScope of scanAnalysisTypical speed
IDE (per keystroke and on save)Current fileSingle-function, single-fileIn a few seconds
CLI on commit (through pre-commit)Files staged for commit (cross-function, single-file analysis)Cross-function, single-fileUnder 5 minutes
PR or MR commentsAll committed files and changes in the PR or MRCross-function, single-file analysisUnder 5 minutes

Support for developer interfaces (pre-build)

Guardrails should be able to provide remediation guidance and means to triage findings or give feedback within developer interfaces.

Semgrep supports the following interfaces:

InterfaceSupported providers and appsTriage and remediation actions
IDEsVisual Studio Code (VS Code)
  • Receive human-written remediation guidance.
  • Ignore or apply a 1-click autofix, if it is available, to findings individually.
IntelliJ-based IDEs
PR or MR commentsAll GitHub plans
  • Receive human-written and Semgrep Assistant remediation guidance*; you can customize the confidence level at which the AI leaves a comment.
  • Ignore or apply a 1-click autofix, if it is available, to findings individually.
All GitLab plans
All Bitbucket plans
Azure Devops Cloud
CLI through pre-commitMost terminal emulator apps
  • Receive human-written remediation guidance.
  • Ignore or apply a 1-click autofix, if it is available, to findings individually.

*To receive Assistant guidance, check that your source code manager (SCM) is supported: list of supported source code managers (SCMs).

Semgrep remediation guidance in VS Code
Semgrep remediation guidance in VS Code > Quick fix menu Figure. Remediation message provided in VS Code. The message appears when a user hovers over findings, which are marked with squiggly lines. Developers can click the Quick Fix button to either ignore the finding or, if the rule provides an autofix, apply the fix.

A PR comment detecting a hardcoded secret Figure. A PR comment detecting a hardcoded secret.

Customizability

Every organization has its own secure coding practices. Customizability ensures that the tool can adapt to the unique needs of an organization.

Semgrep provides customizability through:

  • Custom rules - You can create custom rules and deploy them as guardrails. Learn more about Semgrep rule structure in the next section.
  • Assistant Memories - this feature allows you to add and save additional context when Semgrep Assistant provides remediation. For example, you can provide organization-specific public keys, which Semgrep Assistant remembers.

Assistant Memories form within a finding's details page Figure. A form on a finding's details page where you can enter additional instructions or context.

Remediation guidance

Remediation guidance can come in three forms:

  • The rule's message
  • AI-generated remediation guidance through Semgrep Assistant
  • The rule's fix

Much of the remediation guidance originates from the rule itself, which is also used to generate Semgrep Assistant's advice (if Assistant is enabled). Learning the basic Semgrep rule structure can help you:

  • Customize remediation through your organization-specific rules.
    • Writing your own rules provides you with a means to tailor Semgrep to your organization with or without Assistant.
  • Write and deploy guardrails of your own.

The following example illustrates a basic Semgrep rule.

Figure. A simple Semgrep rule that illustrates the common fields or keys used to create guardrails. Scroll through the Rule pane to view all the fields used to define the rule.

Click to view a line-by-line explanation of each field in the sample rule.
rules:
# The name of the rule (required):
- id: fix-and-message-demo-copy
# The language of the target code (required):
languages:
- python
# How severe the impact of the finding is (required):
severity: ERROR
# Description and advice that appears in the IDE,
# PR or MR comment, or CLI (required):
message: >-
You're using an unsafe function.
Prefer safe_function() if possible.
# The matching logic of the rule (required):
pattern: unsafe_function(...)
# A substitution that resolves the finding (optional).
fix: safe_function(...)
# Metadata is optional but helpful to AI-generated remediation.
metadata:
# A category that describes the rule. Typically security:
category: security
# Confidence of the rule to detect true positives:
confidence: HIGH
# How likely an attacker can exploit the issue:
likelihood: HIGH
# Indicates how much damage a vulnerability can cause:
impact: HIGH
# A sub-type under category. Typically vuln, audit, or secure default:
subcategory:
- vuln

The rule message

This description explains why the finding was generated and outlines general advice on resolving the issue. Messages notify developers in all interfaces where you've deployed a guardrail.

AI-generated remediation guidance and code suggestions (Semgrep Assistant)

This is a tailored, step-by-step outline of what a developer must change to fix the insecure code. The guidance makes use of the Semgrep rule, AI's understanding of code, and a prompt tree that incorporates inputs such as:

  • Prior triage decisions
  • Custom instructions
  • Broader context of the file

Semgrep PR comment with detailed remediation steps Figure. AI-generated guidance. Developers are able to commit the suggestion directly.

info
  • Within developer-native interfaces, Semgrep Assistant only appears in PR or MR comments. Assistant guidance does not appear in the IDE or pre-commit.
  • You can adjust when the guidance is shown to developers based on the level of confidence in the guidance.

The rule's human-written autofix (fix)

Sometimes a rule can resolve a finding by replacing, for example, an insecure function with a secure one. These rules make use of Semgrep's autofix feature, which enables rule-writers to provide a human-written fix.

Semgrep Assistant does not provide a code snippet suggestion when a human-written fix is provided in the rule.

Deploy secure guardrails

Prerequisites

For AppSec engineers

For developers

  • You must have a Semgrep account.
  • You must have joined your Semgrep organization.
  • To use Semgrep with your IDE, you must install the extension for the IDE and sign in to Semgrep through the extension.
  • To use Semgrep with pre-commit, you must install and set up pre-commit, then sign in to Semgrep through the CLI.

Rules can be configured on a per-product, per-interface basis to notify developers when a finding from that rule is detected. The customization enables you to manage the amount of notifications a developer may receive. The following table describes how to deploy guardrails for each product and interface:

InterfaceSemgrep CodeSemgrep SecretsSemgrep Supply Chain
IDETo notify developers of findings from a rule, add the rule to your Policies.Coming soon
PR or MR commentsTo notify developers, a rule must be in Comment mode; you can configure your Policies to include only high confidence, high severity rules.Developers receive comments about any reachable vulnerability of high or critical severity.
CLI through pre-commitTo notify developers of findings from a rule, add the rule to your Policies.Developers are notified of all findings by default.

Policies page > Code tab Figure. Policies page > Code tab. Rules should be in either Comment or Block mode to leave a PR or MR comment.

Next steps


Not finding what you need in this doc? Ask questions in our Community Slack group, or see Support for other ways to get help.