Skip to main content

Minimal Python library to programmatically construct Debian .deb packages

Project description

debx

Coverage Status tests PyPI - Version PyPI - Types PyPI - License

A lightweight Python library for creating, reading, and manipulating Debian package (.deb) files.

Features

  • Read and extract content from Debian packages
  • Create custom Debian packages programmatically
  • Parse and manipulate Debian control files (RFC822-style format)
  • Low-level AR archive manipulation
  • No external dependencies - uses only Python standard library
  • Command-line interface for creating and unpacking .deb packages

Installation

pip install debx

Quick Start

Reading a Debian Package

from debx import DebReader

# Open a .deb file
with open("package.deb", "rb") as f:
    reader = DebReader(f)

    # Extract control file
    control_file = reader.control.extractfile("control")
    control_content = control_file.read().decode("utf-8")
    print(control_content)
    
    # List files in the data archive
    print(reader.data.getnames())
    
    # Extract a file from the data archive
    file_data = reader.data.extractfile("usr/bin/example").read()

Creating a Debian Package

from debx import DebBuilder, Deb822

# Initialize the builder
builder = DebBuilder()

# Create control information
control = Deb822({
    "Package": "example",
    "Version": "1.0.0",
    "Architecture": "all",
    "Maintainer": "Example Maintainer <maintainer@example.com>",
    "Description": "Example package\n This is an example package created with debx.",
    "Section": "utils",
    "Priority": "optional"
})

# Add control file
builder.add_control_entry("control", control.dump())

# Add files to the package
builder.add_data_entry(b"#!/bin/sh\necho 'Hello, world!'\n", "/usr/bin/example", mode=0o755)

# Add a symlink
builder.add_data_entry(b"", "/usr/bin/example-link", symlink_to="/usr/bin/example")

# Build the package
with open("example.deb", "wb") as f:
    f.write(builder.pack())

Working with Debian Control Files

from debx import Deb822

# Parse a control file
control = Deb822.parse("""
Package: example
Version: 1.0.0
Description: Example package
 This is a multi-line description
 with several paragraphs.
""")

print(control["Package"])  # "example"
print(control["Description"])  # Contains the full multi-line description

# Modify a field
control["Version"] = "1.0.1"

# Add a new field
control["Priority"] = "optional"

# Write back to string
print(control.dump())

Command-Line Interface

debx includes a command-line interface for packing and unpacking Debian packages.

Packing a Debian Package

The pack command allows you to create a .deb package from files on your system:

debx pack \
    --control control:control \
              preinst:preinst:mode=0755 \
    --data src/binary:/usr/bin/example:mode=0755 \
           src/config:/etc/example/config \
           src/directory:/opt/example \
    --output example.deb

The format for specifying files is:

source_path:destination_path[:modifiers]

Available modifiers:

  • mode=0755 - Set file permissions
  • uid=1000 - Set file owner ID
  • gid=1000 - Set file group ID
  • mtime=1234567890 - Set file modification time

When specifying a directory, all files within that directory will be included in the package while preserving the directory structure.

Unpacking a Debian Package

The unpack command extracts a .deb package into a directory:

debx unpack package.deb --directory output_dir

This will extract the internal AR archive members (debian-binary, control.tar.gz, data.tar.*) to the specified directory.

License

MIT License

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

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

debx-0.1.7.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

debx-0.1.7-py3-none-any.whl (10.8 kB view details)

Uploaded Python 3

File details

Details for the file debx-0.1.7.tar.gz.

File metadata

  • Download URL: debx-0.1.7.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.25

File hashes

Hashes for debx-0.1.7.tar.gz
Algorithm Hash digest
SHA256 4447daa31729f4fe85aa8c938e9c9917093a3eebb996ebfeb1108dd2f23c9133
MD5 335cc7cb0abd67eb72d04043d325eedf
BLAKE2b-256 3d7cf87fb6406a22ede90e4567ff3bf109b7f9c3bd0c576ecaa37a094de3baba

See more details on using hashes here.

File details

Details for the file debx-0.1.7-py3-none-any.whl.

File metadata

  • Download URL: debx-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 10.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.25

File hashes

Hashes for debx-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 99f0c79a48a785eb830d2daab9e9cc726c6b22f081c88eaee944aefe902911c3
MD5 747b3789e5559c82657e43f5a69f3710
BLAKE2b-256 9dfbf6461a62c9d58ce9c10b289599192f961e2c75076bbaddd9cb2d3f9c8f28

See more details on using hashes here.

Supported by

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