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.1.tar.gz (55.3 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for rpmdyn-2024.1.tar.gz
Algorithm Hash digest
SHA256 dd33322e38fef6f7560de1cd2ede0b94dc2d750748985ac1ba11f55b887a4fec
MD5 6eda8312fe13f6f6243377ded4675809
BLAKE2b-256 e57dfebaff63eb3afc0718f5375a5bb534abcd9476dac3de6ca840c49bde7a09

See more details on using hashes here.

Provenance

File details

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

File metadata

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

File hashes

Hashes for rpmdyn-2024.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d40023393a6911dc90a55cbd8b52e6039aa39b8e7b2b69ac192b2a3d43bc7686
MD5 b257686278d49e449b1a6df3daba384c
BLAKE2b-256 93c83c5de3447e2c5c38258c4da6bc3acf956cfa8fbc3983ff2706196a9a9b28

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