Import Projects
Depending on the integrations you have configured and the language and package managers in your tech stack, you can import Projects into Snyk using the following:
A source control integration with your Git repositories
The Snyk CLI with CI/CD
The best import route varies based on the languages and package managers in your tech stack.
Here are some key points to determine the best starting point. See Git repositories and CI/CD comparisons for more details.
Ways to get started with Snyk
See the Getting started section and Start scanning using the CLI, Web UI, or AP for more details.
Snyk offers various integration methods to meet your needs, as described here.
Git integration
You can connect your repositories for automatic scanning. See Snyk SCM integrations for more details.
For a small number of applications, typically under a hundred, follow these steps.
Navigate to Settings and then to Integrations, and connect to Git code repositories using a tile on the Integrations page.
In the settings for the integration:
Disable the automatic fixes and PR/Merge checks when first onboarding Projects
Enable after a steady state is reached and blocking is desired.
From the Projects listing, add Projects using the Web UI.
Monitor results in Git code repositories.
For hundreds or thousands of repositories, you can use the V1 API v1 Import targets endpoint to import your Projects. This takes advantage of an existing source control integration and can be used to automate processes.
The snyk-api-import tool uses the API to manage onboarding at scale for large enterprises and is the suggested tool to use at scale. You must mirror the source control structure when using the snyk-api-import tool.
Snyk CLI
The Snyk CLI allows granular scanning of individual Projects.
You must formulate a command for each type of test to perform: open source, code, infrastructure as code, or container tests.
Follow these steps to use the CLI:
Install the CLI using one of the appropriate methods as part of the build script.
In the script, navigate to the Project folder.
Run the appropriate
snyk test
orsnyk monitor
commands with the appropriate options for the type of scan being run. Where to implement testing in your scripts is generally flexible, but most commonly, testing is done prior to deployment. Use themonitor
command alone for Snyk Open Source and Snyk Container to report vulnerabilities passively. In using gating with thetest
command, the idea is to break the build if issues are found that meet particular criteria like--severity-threshold
or any number of options in the CLI or snyk-filter plugin. In general, thetest
ormonitor
commands or both are typically run for open source after the dependencies are installed on the build system. A typical command might look like one of the following:Code:
snyk code test --org=[org-id]
Open source:
snyk test --all-projects --org=[org-id]
snyk monitor --all-projects --org=[org-id]
Refer to the documentation for container and infrastructure as code scans for information about how to scan those types of Projects.
Review results either locally when running
snyk test
, or in the Web UI when using monitor or report functions.
Demonstrations of various pipeline integrations can be found on Snyk-Labs
Snyk API
You can scan using the Snyk API. This enables large-scale automated scanning.
The process is:
Navigate to Settings and Service Accounts and generate an API token.
Call the Snyk API in pipelines.
Handle the results programmatically.
Change the code if needed.
Scanning using the API is useful to accomplish the following:
Trigger scans through pipelines.
Scale across your Project portfolio.
Identify new issues in real-time.
Last updated