Scan third-party dependencies
This article walks you through the setup needed to scan your project with Semgrep Supply Chain and its configuration and customization options. Once you enable Semgrep Supply Chain, it automatically scans repositories that you have added to Semgrep AppSec Platform, but your repository must first meet the requirements for a successful scan.
Project directory structure
To scan your project with Semgrep Supply Chain, it must have a manifest file or lockfile and use supported package managers and filenames.
Semgrep Supply Chain can correctly parse code files, manifest files, and lockfiles in subfolders as well. Code files that use the dependencies in the manifest file or lockfile must be nested in the same directory as the manifest file or lockfile. Manifest files and lockfiles must all use supported file names.
In the following example, Semgrep Supply Chain assumes that all code files using the dependencies in my-project/running/lockfile.json
are nested in my-project/running/
or deeper directories.
/my-project
├───/running
│ ├───lockfile.json
│ ├───bar.js
│ └───/uphill
│ ├───lockfile.json
│ └────foo.js
├───/biking
If you have code files in my-project/biking,
Semgrep Supply Chain does not associate them with the dependencies in my-project/running/lockfile.json.
If there is another manifest file or lockfile in my-project/running
, such as my-project/running/uphill/lockfile.json
, then this overrides the original my-project/running/lockfile.json
for all code files in my-project/running/uphill/
or deeper directories.
To run a Semgrep Supply Chain scan, generate a dependency tree for Apache Maven.
Enable Semgrep Supply Chain
- Sign in to Semgrep AppSec Platform.
- Click Settings.
- In the Deployment tab, navigate to Supply Chain (SCA), and click the Supply Chain scans toggle if it is not already enabled.
Scan frequency
You can modify your CI configuration so that Semgrep Supply Chain scans your code at a specified frequency or whenever a specific event occurs, such as opening a pull request or merge request.
Rule updates
Semgrep Supply Chain frequently receives rule updates. To take advantage of these updates, adjust the frequency with which Semgrep Supply Chain scans your codebase.
If a rule is updated, findings generated against the revised rule are considered new findings, even if the previous version generated a finding. The new finding is not affected by any triage actions on findings related to the prior version of the rule. Because the finding is new, you'll also receive notifications through the channels you've set up, such as Slack.
Schedule scans
The following table is a summary of methods and resources to set up schedules for different CI providers.
CI provider | Where to set schedule |
---|---|
GitHub Actions | See Sample CI configs for information on how to modify your semgrep.yml file |
GitLab CI/CD | Refer to GitLab documentation |
Jenkins | Refer to Jenkins documentation |
Bitbucket Pipelines | Refer to Bitbucket documentation |
CircleCI | Refer to CircleCI documentation |
Buildkite | Refer to Buildkite documentation |
Azure Pipelines | Refer to Azure documentation |
Event-triggered scans
You can configure your CI/CD system to trigger a Semgrep Supply Chain scan whenever one of the following events occurs:
Event | Scope of scan | Dependency rule set |
Pull or merge request | Diff-aware scan | All dependency rules |
Push or scheduled event, such as a cron job | Full scan | All dependency rules |
Scan a project without lockfiles (beta)
To participate in this beta, reach out to support@semgrep.com.
Semgrep Supply Chain can scan Java projects built using Maven or Gradle Wrapper without the need for lockfiles.
-
Ensure that the environment where you run Semgrep scans has installed all of the dependencies required to build your project, such as Java and Maven.
-
Initiate a Semgrep scan, ensuring that you include the
--allow-local-builds
flag:semgrep ci --allow-local-builds
For existing CI jobs, you may have to edit your configuration file to include this flag. Semgrep builds the project, using the build information included in the
pom.xml
orbuild.gradle
file to determine the set of dependencies used by the project.
The build.gradle
or pom.xml
file used by Semgrep to build the project is listed in the Scan Summary after the scan completes successfully.
Figure. Supply Chain scan summary listing a manifest file.
- Semgrep Managed Scanning cannot determine the dependencies in a project when there is no manifest file or lockfile, so Supply Chain scans will not return any findings.
- By default, Semgrep doesn't surface errors generated during a scan. To view errors in the CLI output, include the
--verbose
when initiating your scan:semgrep ci --allow-local-builds --verbose
Run a scan using the CLI
You can start a stand-alone Semgrep Supply Chain scan by running the following command in the CLI:
semgrep ci --supply-chain
Semgrep prints a list of findings directly to the CLI, including the finding's reachability determination, severity level, a brief description, and suggested remediation.
You can also view your results in Semgrep AppSec Platform. It displays all of the information displayed in the CLI, but it also offers you the ability to:
- See additional finding details, such as whether the finding is always reachable or if it's reachable if certain conditions are met, and its transitivity status
- Use the dependency search feature
- Use the license compliance feature
Scan a monorepo's dependencies
Semgrep Supply Chain supports the scanning of monorepos. As outlined in Project directory structure, findings are grouped by directory based on the manifest file or lockfile present in the monorepo.
Block pull or merge requests
Semgrep can help block pull requests (PRs) or merge requests (MRs) when it matches a blocking finding. When one or more findings is blocking, Semgrep returns exit code 1
, and you can use this result to set up additional checks to enforce a block in your CI/CD pipeline, such as not allowing merge of the PR/MR. This action applies to full and diff-aware scans.
Semgrep Supply Chain versions v0.122.0 and earlier automatically aided in blocking pull/merge requests if it discovered reachable findings in the code, but later versions do not do this. You can, however, configure Semgrep Supply Chain to help block scans whenever all of the following conditions are met:
- It detects reachable findings in direct dependencies
- The reachable findings are of critical or high severity
- There is an upgrade available for the affected dependency; this is to prevent blocking when there is no resolution for the vulnerability
To enable Scan Blocking:
- Sign in to Semgrep AppSec Platform.
- Go to Settings > Deployment and navigate to the Supply Chain (SCA) section.
- Click Scan Blocking.
Alternatively, you can configure your version control system to prevent merging if Semgrep Supply Chain identifies reachable findings.
Not finding what you need in this doc? Ask questions in our Community Slack group, or see Support for other ways to get help.