Skip to main content

Alternative dynamic RPM bindings for Python

Project description

rpmdyn

Alternative dynamic RPM bindings for Python.

PyPI

Overview

rpmdyn provides an alternative means of using the rpm library from Python via dynamic binding (FFI).

This project is intended to support testing Python code based on the rpm library in CI or development environments where installing official bindings is too much of a hassle. You may find it useful if you have tried rpm-py-installer and ran into problems with it.

⚠️Major caveat⚠️: the provided RPM bindings are far from complete! Bindings have been implemented "on demand" to fit the author's needs.

Here's a comparison between a few different ways of accessing RPM Python bindings to help you understand if this project may be of use to you:

OS package rpmdyn rpm-py-installer
pip-installable from PyPI?
Usable in virtualenv? ❌¹
Supports multiple Python versions? ❌²
No compilers/headers needed? ❌³
Secure supply chain? ❌⁴
Complete bindings? ❌⁵
  1. Only usable if you enable system site-packages, which is generally unacceptable.
  2. While there are no hard and fast rules around what kinds of packages a Linux distribution provides, it is common for a distribution to choose one primary supported Python version and only provide libraries for that version.
  3. rpm-py-installer works by compiling RPM bindings and thus needs a compiler.
  4. rpm-py-installer downloads RPM sources insecurely with no validation of checksums or signatures. This is an issue if you only want to use known versions of all dependencies, and will not work at all in a firewalled setup (e.g. which only allows access to an internal PyPI registry).
  5. rpmdyn implements only a small subset of RPM bindings, as bindings need to be implemented manually. The set of available bindings reflects the needs of rpmdyn contributors.

Usage

Install rpmdyn and it will automatically be used by default:

  • if real (native) RPM bindings are available, then import rpm will use those.
  • otherwise, import rpm will use rpmdyn.

This is achieved via a PTH hook. If you wish to disable this behavior, set the RPMDYN_HOOK environment variable to 0.

License

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rpmdyn-2024.9.tar.gz (55.3 kB view details)

Uploaded Source

Built Distribution

rpmdyn-2024.9-py3-none-any.whl (36.9 kB view details)

Uploaded Python 3

File details

Details for the file rpmdyn-2024.9.tar.gz.

File metadata

  • Download URL: rpmdyn-2024.9.tar.gz
  • Upload date:
  • Size: 55.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for rpmdyn-2024.9.tar.gz
Algorithm Hash digest
SHA256 9f7c3fd668a2734c07d3234290ceb468065d9eebf38871d861a3e797f4d5b4c3
MD5 a506ee9eaa08ea263e6d950c726c445f
BLAKE2b-256 31fce3a48e5700592232bec9dcd48fde7edbb91311562d41a8d05c43391b3385

See more details on using hashes here.

Provenance

File details

Details for the file rpmdyn-2024.9-py3-none-any.whl.

File metadata

  • Download URL: rpmdyn-2024.9-py3-none-any.whl
  • Upload date:
  • Size: 36.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for rpmdyn-2024.9-py3-none-any.whl
Algorithm Hash digest
SHA256 f3cd68f13e225a1f3a5472960797807bb441be6808356b7e7a678ce4f8353e79
MD5 f598d656a6d4197080872b65c326dea1
BLAKE2b-256 0508e0664a261c367dcc74ff55a3bcfe62c5157a7f883bf15997f573d7d7140d

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page