Python
Supported frameworks and package managers
Code analysis
Snyk Code supports the following frameworks:
Django
Flask
Jinja2
PyYAML
Requests
urllib3
Open source and licensing
Features may not be available, depending on your plan. See the Plans and pricing page for more details.
Package managers / Features | CLI support | Git support | License scanning | Fix PRs |
---|---|---|---|---|
✔︎ | ✔︎ | ✔︎ | ✔︎ | |
✔︎ | ✔︎ | ✔︎ | ||
✔︎ | ✔︎ | ✔︎ | ||
setup.py | ✔︎ | ✔︎ |
Snyk builds a dependency tree and then uses the vulnerability database to find vulnerabilities in any of the dependencies in the tree.
How Snyk analyzes and builds the tree varies depending on the language and package manager for the Project and the location of your Project.
To scan your Projects, you must first install the relevant package manager and ensure that your Project contains the supported manifest files.
Getting started with Snyk for Python across environments
Snyk CLI
Prerequisites
Set the default Organization for all Snyk tests (code analysis).
Ensure you have installed the relevant package manager before you begin using the Snyk CLI (open source).
Ensure you have included the relevant manifest files supported by Snyk before testing.
Code analysis
To start testing your code using Snyk Code open your repository in a terminal and run the following command:
To customize test options, run other commands, exclude directories and files, and explore the results in different formats, see the following:
Open source and licensing
Snyk CLI options for Python
For information about the snyk test
options available for use with Python, see Options for Python Projects in the test
command help.
For the available snyk monitor
options, see Options for Python Projects in the monitor
command help.
Pip and Snyk CLI
Run pip install
before scanning with the CLI,for
for example:
Pip requirements.txt
files specify only top-level dependencies, not nested or transitive ones. Therefore, the full Pip Project must be installed to ensure the CLI can build a complete dependency tree.
Poetry and Snyk CLI
To build the dependency tree for a Poetry application, Snyk uses pyproject.toml
and poetry.lock
files. Both files must be present for Snyk to scan Poetry dependencies and identify issues.
If no poetry.lock
file is present; you should run poetry lock
to generate one before scanning.
PEP 621 is a standard for defining direct dependencies in pyproject.toml
files, which is different from how Poetry does this.
Snyk does not currently support PEP 621.
Pipenv and Snyk CLI
To build the dependency tree for a Pipenv application, Snyk uses Pipfile
and Pipfile.lock
files. Both files must be present for Snyk to scan Pipenv dependencies and identify issues.
Run pip install
before scanning with the CLI.
Run pipenv install
to ensure the CLI can build an up-to-date, accurate dependency tree using pipenv graph
.
setup.py and Snyk CLI
To build the dependency tree, Snyk analyzes the setup.py
file, and detects packages listed in the install_requires
key.
This file will not be discovered automatically by the CLI. It must be specified manually using the --file
option, for example:
You can also convert setup.py
to requirements.txt
by installing the packages into a virtual environment and then running pip freeze
.
Snyk Web UI (Git repository integration)
To scan your Projects, you must ensure your repository contains the supported manifest files
Pip and Git repositories
URLs in requirements.txt
files are not supported. They are removed before resolving the dependencies in the files.
To scan pip Projects, Snyk analyzes your requirements.txt
files using native pip
tooling in an isolated Linux environment.
pip Projects scanned using the Git integration will be given the same name as the directory where they are contained.
Snyk imports any file that follows the **/*req*.txt
pattern. This can help if you have renamed the requirements.txt
files, for example, to requirements-dev.txt
.
Snyk also looks for files using the **/requirements/*.txt
pattern. This can help if you have placed your files in a requirements
folder, for example, requirements/requirements.txt
.
If you are using a package manager that creates different manifest file formats from requirements.txt
, then you may be able to convert or export the manifest file to the requirements.txt
format.
An example follows of how dephell
is used to convert from Conda environments.yml
to a requirements.txt
.
Poetry and Git repositories
To scan Poetry Projects, Snyk inspects your pyproject.toml
and poetry.lock
files.
You can choose whether Snyk should include dev dependencies when scanning your Poetry Projects.
Snyk regards non-dev dependencies to be those declared in tool.poetry.dependencies
, the implicit main
group. All others are classed as dev dependencies.
Poetry dev dependencies are not included in scans by default. To change this, modify your settings as follows:
Log in to your Snyk account and navigate to the relevant Group and Organization.
Select Settings, then Languages.
Select Edit settings for Python.
Enable or disable the Scan Poetry dev dependencies option under the Poetry dev dependencies settings.
Pipenv and Git repositories
Private PyPI mirrors are not supported. Pipfiles
specifying a private mirror as their only source will not be imported.
To scan Pipenv Projects, Snyk analyzes your Pipfile
and Pipfile.lock
files using native pipenv
tooling in an isolated Linux environment.
Private packages and those with non-Linux OS requirements may be unresolvable and omitted from the dependency tree.
If a Pipfile.lock
is present, any unresolved packages it contains are added to the top level of the dependency tree using versions from the lock file.
You can choose whether Snyk should include dependencies specified in [dev-packages]
when scanning your Pipenv Projects.
Pipenv dev dependencies are not included in scans by default. To change this, modify your settings as follows:
Log in to your Snyk account and navigate to the relevant Group and Organization.
Select Settings, then Languages.
Select Edit settings for Python.
Enable or disable the Scan Pipenv dev dependencies option under the Pipenv settings.
Python version support
Some Python Projects may contain dependencies that require specific versions of Python.
Therefore, the version of Python used when scanning can affect the dependency tree Snyk generates.
You can specify the version of Python that Snyk uses to scan dependencies in both the CLI and Git integration.
Setting Python version in CLI Projects
To set the Python version in the CLI, add the following option to snyk test
or snyk monitor
with the name of the Python binary:
For details, see the Test command help and the Monitor command help.
Setting Python version in Git Projects
Pip and Python versions
When scanning pip Projects imported from Git, Snyk uses the version of Python specified in Organization settings or .snyk
files.
The supported versions are 2.7
, 3.7
, 3.8
, 3.9
, 3.10
,3.11
,3.12
.
Snyk uses a recent patch
version for each of the supported minor
series.
By default, Snyk tests pip Projects using Python 3.7.
The behavior of imports, re-tests, and PR checks for Projects with dependencies requiring a higher version of Python varies according to the version specified:
Python 3.8 or above - scans will fail with an error including details of the first failed package, the Python version it requires, and the Python version used.
Python 2.7 or 3.7 - scans will succeed, but the incompatible dependencies are omitted from the results.
To define which Python minor version Snyk uses to test your Git-imported pip Projects, you can use Organization settings and .snyk
policy files.
To define the Python version for all Projects in an Organization:
Log in to your Snyk account and navigate to the relevant Group and Organization.
Select Settings, then Languages.
Select Edit settings for Python.
From the Python version dropdown, select the Python version to use when testing Projects for this Organization.
If you require a Project in an Organization to use a different Python version, you may add a .snyk
file to the Project repository and specify the desired version.
The .snyk
file must be in the same directory as the Project manifest file.
Snyk will select which Python version according to the major
, minor
and patch
versions specified in the .snyk
file.
Major
version only (for example, 2 or 3) - scanned with defaultminor
versions - 2.7 or 3.7Major
andminor
version (for example, 3.7, 3.8, 3.9, 3.10, 3.11, 3.12) - scanned with 3.7, 3.8, 3.9, 3.10, 3.11 or 3.12Major
,minor
andpatch
version (or example, 3.8.x, 3.9.x, 3.10.x, 3.11.x, 3.12.x) - the specificpatch
version is ignored, scanned with default versions of 3.8, 3.9, 3.10, 3.11 or 3.12Any versions specified with an unsupported
minor
version will default to 2.7 or 3.7
Pipenv and Python versions
Supported Python versions are 3.8
, 3.9
, 3.10
, 3.11
, 3.12
.
Snyk uses Python version information specified in each Pipfile
to choose the major and minor versions to use in scanning, for example:
Specific patch versions are ignored; Snyk uses a recent patch version from each series.
Snyk defaults to Python 3.10
if the Pipfile
contains:
No Python version information
Only a major version
An unsupported version
Poetry and Python versions
There is no need to inform Snyk about Python versions for Poetry Projects.
Poetry files contain sufficient information to build a full dependency tree without running native tooling.
Snyk integrations
If you are using any of the supported IDEs to write Python, there are some configurations you must add to scan Python manifest files properly.
If you are using a virtual environment, you must add the PYTHON_PATH
to the Additional Options text input in the Snyk integration settings, for example, --command=.venv/bin/python
. Snyk tries to look for a *req*.txt
file in the root of the Project as it is seen in the IDE.
However, if you have manifest files in other directories within the root of the Project, Snyk cannot identify them. For Snyk to find them, you must use the --all-projects
option. Snyk then recursively searches each Project directory to find all the manifest files.
If those directories each require a different virtual environment to run, the Snyk scan will not be successful because it will use one virtual environment to search for installed dependencies. In this case, it is best to use the CLI or the Git integration to get vulnerability information on all the dependencies listed in each Project directory.
Troubleshooting
If you need help, contact Snyk Support.
Last updated