Skip to main content

Flavor Pack packaging system implementing Progressive Secure Package Format (PSPF/2025)

Project description

Flavorpack: Progressive Secure Polyglot Packaging Toolchain

License Python 3.11+ uv Ruff CI

Beta: Flavorpack is under active development. The PSPF 2025 format is stable, and core packaging workflows are tested across 6 platforms (Linux, macOS, Windows, FreeBSD — amd64/arm64). APIs may still evolve before 1.0.

Flavorpack is a cross-language packaging system that creates self-contained, portable executables using the Progressive Secure Package Format (PSPF) 2025 Edition. It enables you to ship Python applications as single binaries that "just work" - no installation, no dependencies, no configuration required.

Note: The package name is flavorpack, but the command-line tool is flavor.

🎯 Key Features

  • Single-File Distribution: Package entire applications into one executable file
  • Cross-Language Support: Python orchestrator with Go and Rust launchers
  • Secure by Default: Ed25519 signature verification ensures package integrity
  • Progressive Extraction: Extract only what's needed, when it's needed
  • Smart Caching: Persistent work environment with intelligent validation
  • Zero Dependencies: End users need nothing pre-installed

🚀 Quick Start

Prerequisites

  • Python 3.11 or higher
  • UV package manager (curl -LsSf https://astral.sh/uv/install.sh | sh)
  • Go 1.26+ and Rust 1.86+ (for building helpers - see src/flavor-go/go.mod and src/flavor-rs/Cargo.toml)

Installation (Source Only)

Note: Flavorpack is not yet available on PyPI. Source installation is currently the only option.

# Clone the repository
git clone https://github.com/provide-io/flavorpack.git
cd flavorpack

# Set up environment and install dependencies
uv sync

# Build the Go and Rust helpers (required)
make build-helpers
# or directly: ./build.sh

Creating Your First Package

# Package a Python application
flavor pack --manifest pyproject.toml --output myapp.psp

# Run the packaged application
./myapp.psp

# Verify package integrity
flavor verify myapp.psp

📦 PSPF Format

The Progressive Secure Package Format is a polyglot file format that works as both an OS executable and a structured package. Each .psp file contains a native launcher, package metadata, and compressed data slots.

See the PSPF Format Specification for the complete binary layout diagram and technical details.

📚 Documentation

🏗️ Architecture

Flavorpack consists of three main components:

  1. Python Orchestrator (src/flavor/)

    • Manages the build process and dependency resolution
    • Creates manifests and handles Python packaging
    • Provides CLI interface for package operations
  2. Native Helpers (src/flavor-go/, src/flavor-rs/)

    • Launchers: Extract and execute packages at runtime, perform Ed25519 signature verification, manage workenv caching
    • Builders: Assemble PSPF packages from manifests, implement the PSPF/2025 binary format, handle slot packing and metadata encoding
    • Built binaries are placed in dist/bin/ for distribution

🔒 Security

Every PSPF package includes cryptographic integrity verification:

  • Ed25519 signatures ensure packages haven't been tampered with
  • Public keys are embedded in the package index
  • Signature verification happens automatically on every launch
  • Optional deterministic builds with --key-seed for reproducibility

🧪 Testing

# Run the test suite
make test

# Run with coverage
make test-cov

# Test cross-language compatibility
make validate-pspf

# Run specific test categories
pytest -m unit        # Fast unit tests
pytest -m integration # Integration tests
pytest -m security    # Security tests

# Test cross-language compatibility with Pretaster
make validate-pspf

Test Taxonomy

Flavorpack uses a shared test-intent taxonomy across Python, Go, and Rust. Use the root make targets instead of guessing which language-native runner to invoke first.

make test-unit
make test-integration
make test-cross-language
make test-security
make test-adversarial
make test-property
make test-fuzz
make test-mutation
make test-smoke
make test-fast
make test-slow

Intent categories:

  • unit: small isolated behaviors
  • integration: multi-component behavior in one implementation
  • cross_language: parity/interoperability across Python, Go, and Rust
  • security: trust, verification, integrity, permissions, policy
  • adversarial: hostile inputs and boundary-violation attempts
  • property: parameterized and invariant-driven tests
  • fuzz: native malformed-input discovery
  • mutation: test-suite strength checks
  • smoke: minimal high-signal sanity checks

Cost selectors are separate from intent:

  • fast
  • slow
  • ci

Use both security and adversarial when a test intentionally tries to violate a security boundary.

Quality Engineering

Use the root quality targets to run the same cross-language workflows locally that CI now runs as observational jobs:

make quality-python-fast
make quality-python-deep
make quality-go-fast
make quality-go-deep
make quality-rust-fast
make quality-rust-deep
make quality-ci

The tools run in strict mode. In this rollout phase, the dedicated quality-observability jobs are wired into CI but are not intended to be required merge checks yet. A failing observability job means that the quality workflow itself surfaced an issue; merge policy remains a separate repository setting.

🙏 Acknowledgments

Flavorpack is built on the shoulders of giants:

  • UV for fast Python package management
  • The Python, Go, and Rust communities for excellent tooling

Built with ❤️ by the provide.io team

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

flavorpack-0.4.1-py3-none-win_arm64.whl (8.6 MB view details)

Uploaded Python 3Windows ARM64

flavorpack-0.4.1-py3-none-win_amd64.whl (9.4 MB view details)

Uploaded Python 3Windows x86-64

flavorpack-0.4.1-py3-none-manylinux2014_x86_64.whl (8.9 MB view details)

Uploaded Python 3

flavorpack-0.4.1-py3-none-manylinux2014_aarch64.whl (8.1 MB view details)

Uploaded Python 3

flavorpack-0.4.1-py3-none-macosx_11_0_arm64.whl (8.2 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

flavorpack-0.4.1-py3-none-macosx_10_9_x86_64.whl (8.9 MB view details)

Uploaded Python 3macOS 10.9+ x86-64

File details

Details for the file flavorpack-0.4.1-py3-none-win_arm64.whl.

File metadata

  • Download URL: flavorpack-0.4.1-py3-none-win_arm64.whl
  • Upload date:
  • Size: 8.6 MB
  • Tags: Python 3, Windows ARM64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for flavorpack-0.4.1-py3-none-win_arm64.whl
Algorithm Hash digest
SHA256 5a2fa3948f384394fa46884feea4b1763b71df74e23e15f7bb7d2847224b2b38
MD5 889324b24f9a4a2b25dc81e25506a33b
BLAKE2b-256 291c74d89645b3eb98acba9fb99b9b5dfdf05dd785b421661daff74e7bc421af

See more details on using hashes here.

Provenance

The following attestation bundles were made for flavorpack-0.4.1-py3-none-win_arm64.whl:

Publisher: release.yml on provide-io/flavorpack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flavorpack-0.4.1-py3-none-win_amd64.whl.

File metadata

  • Download URL: flavorpack-0.4.1-py3-none-win_amd64.whl
  • Upload date:
  • Size: 9.4 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for flavorpack-0.4.1-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 7e6f3bf4b19c471aa96e24518cecc1415986c4d4b7071efde2f56587c72add8b
MD5 eae5f433d50ffc7c2814c005e0f3d4b3
BLAKE2b-256 6f5a90f9abf741ae6d500285a4f4bc642d64171cd1f034393a1c75e4e60bc81e

See more details on using hashes here.

Provenance

The following attestation bundles were made for flavorpack-0.4.1-py3-none-win_amd64.whl:

Publisher: release.yml on provide-io/flavorpack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flavorpack-0.4.1-py3-none-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for flavorpack-0.4.1-py3-none-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 7b929471b915ee15fbadb35c7710b483df10cd4cabf4d01f9a9ad79c270b81c3
MD5 b044aba8261274130ec0f73f1cf30f1d
BLAKE2b-256 db8fdf4189c02b0eac446d788e89ccf48d05c6fb3d8fbec23ed738ee0ff6adf8

See more details on using hashes here.

Provenance

The following attestation bundles were made for flavorpack-0.4.1-py3-none-manylinux2014_x86_64.whl:

Publisher: release.yml on provide-io/flavorpack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flavorpack-0.4.1-py3-none-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for flavorpack-0.4.1-py3-none-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 d515988cea555e323e8b78d54a2feb004cf9d4b39fa8f4efc6d10239aee7a1d1
MD5 11bc014e736808f14750e5be8a072fb7
BLAKE2b-256 04f6efc22266c981896f9c6059bc8e14cd30a634b1f091d56a948c5a4623745d

See more details on using hashes here.

Provenance

The following attestation bundles were made for flavorpack-0.4.1-py3-none-manylinux2014_aarch64.whl:

Publisher: release.yml on provide-io/flavorpack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flavorpack-0.4.1-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for flavorpack-0.4.1-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 33a79dca85f8455accbea60d58301d0f2d2d62158f02c38cd3cc9d0d64f47b23
MD5 11924c1e3056aebdfdc3eaf992407c66
BLAKE2b-256 6e609e05a561ecc0de56aef97cdd896a4859dc3c9393ca424395b9ce3c866554

See more details on using hashes here.

Provenance

The following attestation bundles were made for flavorpack-0.4.1-py3-none-macosx_11_0_arm64.whl:

Publisher: release.yml on provide-io/flavorpack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flavorpack-0.4.1-py3-none-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for flavorpack-0.4.1-py3-none-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 d66669a6942b1b0200c1a6ed4e800161ebd463f4fec33b6084d631e2554e8581
MD5 06a6dbeed3d42a7b8996144d774b6fd1
BLAKE2b-256 2333b0cc14c8f67db04370d1f3256181b5b3ce4a21f26468158a1d947debaeb6

See more details on using hashes here.

Provenance

The following attestation bundles were made for flavorpack-0.4.1-py3-none-macosx_10_9_x86_64.whl:

Publisher: release.yml on provide-io/flavorpack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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