Skip to main content

Video indexing and playback web service

Project description

multimedia

This is a thin web client for a directory containing video files.

Installation

Installation is optional. It's recommended to use multimedia directly either by using uvx or docker (see running below).

pip install multimedia

Requirements

FFmpeg is required for video processing (thumbnail generation and metadata extraction).

  • macOS: brew install ffmpeg
  • Ubuntu/Debian: sudo apt install ffmpeg
  • Windows: Download from ffmpeg.org or use choco install ffmpeg

When using Docker, FFmpeg is included in the image.

Running

Using Docker

docker run \
    -p 8028:8028 \
    -v ${PWD}:/media \
    ozkatz/multimedia

Using UV

If you have uv installed, you can call multimedia directly with uvx:

MULTIMEDIA_DIR="${PWD}" uvx multimedia

Using pip

If installed via pip, simply run:

MULTIMEDIA_DIR="${PWD}" multimedia

Configuration

Configuring Multimedia is done using environment variables. Typically, minimal configuration is required:

Env var Default Value Description
MULTIMEDIA_DIR . Path to the directory to index video files and images from
MULTIMEDIA_PASSPHRASE (none) If set, requires this passphrase to access the UI and API

Authentication

To protect your multimedia server with a passphrase:

MULTIMEDIA_DIR="${PWD}" MULTIMEDIA_PASSPHRASE="your-secret-passphrase" uvx multimedia

When a passphrase is configured:

  • Users must enter the passphrase in the browser before accessing the UI
  • API requests require a Bearer token in the Authorization header
  • The passphrase is stored in the browser's session storage (cleared when tab closes)

Usage

Once you have a multimedia server running, access it in your web browser:

http://localhost:8028/

Development

Prerequisites

  • Python 3.10+
  • Node.js 18+
  • uv (Python package manager)
  • FFmpeg (for video processing)

Setup

Clone the repository and install dependencies:

git clone https://github.com/ozkatz/multimedia.git
cd multimedia

# Install Python dependencies
uv sync

# Install frontend dependencies
cd frontend
npm install

Building the Frontend

The React frontend must be built before running the server:

cd frontend
npm run build

This outputs the production build to src/multimedia/static/.

Running in Development

Start the backend server:

MULTIMEDIA_DIR="/path/to/videos" uv run multimedia

For frontend development with hot reload, run in a separate terminal:

cd frontend
npm run dev

The Vite dev server proxies API requests to http://localhost:8028.

Building for Distribution

Build the Python package:

# Ensure frontend is built first
cd frontend && npm run build && cd ..

# Build wheel
uv build

The wheel will be in dist/.

Publishing to PyPI

To publish a new version:

# Build frontend and package
cd frontend && npm run build && cd ..
uv build

# Publish to PyPI (requires PyPI token)
uv publish

To publish to TestPyPI first:

uv publish --publish-url https://test.pypi.org/legacy/

Set your PyPI token via environment variable or keyring:

export UV_PUBLISH_TOKEN=pypi-your-token-here

Building Docker Image

docker build -t multimedia .

License

This project is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.

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

multimedia-0.1.2.tar.gz (114.9 kB view details)

Uploaded Source

Built Distribution

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

multimedia-0.1.2-py3-none-any.whl (90.8 kB view details)

Uploaded Python 3

File details

Details for the file multimedia-0.1.2.tar.gz.

File metadata

  • Download URL: multimedia-0.1.2.tar.gz
  • Upload date:
  • Size: 114.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.2

File hashes

Hashes for multimedia-0.1.2.tar.gz
Algorithm Hash digest
SHA256 bdfaf0b57e0a0a28c8120c2df884b3fecb620030a1a8ee057ed9e0d5eeff5848
MD5 1ec39fc9cd6bbf03d54fcf0d24108b41
BLAKE2b-256 7514bfd6f6f7181e16f4e4b85dc22cfdb5f6c805918d2334b2a4c9a46e54a8b4

See more details on using hashes here.

File details

Details for the file multimedia-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: multimedia-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 90.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.2

File hashes

Hashes for multimedia-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e6da621ea19b094611f4c7a117e26446458566ad33571e21dcc2e0c7fbb98ddb
MD5 5f0a6f5d63a6c90ff3f322bc20204726
BLAKE2b-256 e0c16e8f632a2cad43358799c41c52192289685d15381d73bde350c5f7a843c7

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