New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

pdm-conda

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

pdm-conda

A PDM plugin to resolve/install/uninstall project dependencies with Conda

  • 0.18.3
  • PyPI
  • Socket score

Maintainers
1

pdm-conda

A PDM plugin to resolve/install/uninstall project dependencies with Conda.

Configuration

Config itemDescriptionDefault valuePossible valuesEnvironment variable
conda.activeForce plugin usage or notTruePDM_CONDA_ACTIVE
conda.runnerConda runner executablecondaconda, mamba, micromambaPDM_CONDA_RUNNER
conda.solverSolver to use for Conda resolutioncondaconda, libmambaPDM_CONDA_SOLVER
conda.channelsConda channels to use, order will be enforced[]
conda.as-default-managerUse Conda to install all possible requirementsFalsePDM_CONDA_AS_DEFAULT_MANAGER
conda.batched-commandsExecute batched install and remove Conda commands, when True the command is executed only at the endFalsePDM_CONDA_BATCHED_COMMANDS
conda.excludesArray of dependencies to exclude from Conda resolution[]
conda.auto-excludesIf cannot find package with Conda, add it to excludes listFalsePDM_CONDA_AUTO_EXCLUDES
conda.installation-methodInstallation method to use when installing dependencies with Condahard-linkhard-link, copyPDM_CONDA_INSTALLATION_METHOD
conda.dependenciesArray of dependencies to install with Conda, analogue to project.dependencies[]
conda.optional-dependenciesGroups of optional dependencies to install with Conda, analogue to project.optional-dependencies{}
conda.dev-dependenciesGroups of development dependencies to install with Conda, analogue to tool.pdm.dev-dependencies{}
conda.pypi-mapping.download-dirPyPI-Conda mapping download directory$HOME/.pdm-conda/PDM_CONDA_PYPI_MAPPING_DIR
conda.pypi-mapping.urlPyPI-Conda mapping urlhttps://github.com/regro/cf-graph-countyfair/raw/master/mappings/pypi/grayskull_pypi_mapping.yamlPDM_CONDA_PYPI_MAPPING_URL

All configuration items use prefix pdm.tool, this is a viable configuration:

[tool.pdm.conda]
runner = "micromamba"
channels = ["conda-forge/noarch", "conda-forge", "anaconda"]
dependencies = ["pdm"]
as-default-manager = true
auto-excludes = true
solver = "libmamba"
excludes = ["pytest-cov"] # don't install with conda even if it's a dependency from other packages
installation-method = "copy"
batched-commands = true
active = false

[tool.pdm.conda.pypi-mapping]
download-dir = "/tmp"
url = "https://url/to/mapping.yaml"

[tool.pdm.conda.optional-dependencies]
extra = ["anaconda:ffmpeg"] # non python dependency, obtained from anaconda channel

[tool.pdm.conda.dev-dependencies]
dev = ["pytest"]

Usage

This plugin adds capabilities to the default PDM commands.

Working commands

The following commands were tested and work:

  • pdm init:
    • To list/use Conda managed python you must specify the Conda runner with -cr or --runner.
    • You also can specify a default Conda channel with -c or --channel.
  • pdm lock
  • pdm install
  • pdm add:
    • To add a Conda managed package --conda flag can be used multiple times followed a package (analogue to --editable).
    • You can specify per package Conda channel using conda notation channel::package.
    • You also can specify a default Conda channel with -c or --channel.
    • With flag -r or --runner you can specify the Conda runner to use.
    • With flag -ce or --conda-excludes you can add PyPi packages to the excluded from Conda resolution.
    • With flag --conda-as-default-manager you can set conda.as-default-manager to True.
  • pdm remove
  • pdm update
  • pdm list
  • pdm info
  • pdm use
  • pdm venv:
    • create:
      • To list/use Conda managed python you must specify the Conda runner with -w or --with.
      • You can completely override the Conda environment name with -cn or --conda-name, the resulting environment won't follow PDM environment naming conventions.
    • list
    • remove

How it works

Using conda/libmamba solver

PDM invokes Conda solver to resolve conda packages each time a PDM candidate makes a change in the last Conda resolution.

If only Conda packages are used (i.e. setting conda.as-default-manager to true and no conda.excludes) then Conda solver is invoked only once.

Settings overridden

In order to use Conda to install packages some settings were overriden:

  • python.use_venv if conda settings detected in pyproject.toml this setting is set to True.
  • python.in_project if conda settings detected in pyproject.toml and this setting was not previously set then is set to False.
  • python.use_pyenv if conda settings detected in pyproject.toml this setting is set to False.
  • venv.backend if conda settings detected in pyproject.toml this setting is set to conda.runner.
  • venv.location if conda settings detected in pyproject.toml, VIRTUAL_ENV or CONDA_PREFIX environment variables are set and this setting was not previously set then is set to the value of the environment variable.
  • install.parallel if some Conda managed packages are to be uninstalled or updated this option is disabled momentarily.

Some environment variables were overridden too:

  • PDM_IGNORE_ACTIVE_VENV if conda settings detected in pyproject.toml and VIRTUAL_ENV or CONDA_PREFIX environment variables are set then this variable is set to False.

All this changes will be maintained only during the execution of the command, after that the settings will be restored to the previous values.

Lock strategy
  • Lock strategy no_cross_platform for pdm lock is always forced as Conda doesn't produce cross-platform locks.
  • Lock strategy static_urls for Conda managed packages is always forced, independently of the lock strategy used for PyPi packages.
  • Lock strategy direct_minimal_versions for Conda managed packages will partially work as Conda doesn't have an option to force this mode on a resolution.

Development

For development docker-compose files exist in deploy directory, helper script deploy/docker-compose.sh can be used for executing docker.

For running dev environment:

bash deploy/docker-compose.sh -d up

And for productive environment:

bash deploy/docker-compose.sh up

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc