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
Bearertoken in theAuthorizationheader - 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bdfaf0b57e0a0a28c8120c2df884b3fecb620030a1a8ee057ed9e0d5eeff5848
|
|
| MD5 |
1ec39fc9cd6bbf03d54fcf0d24108b41
|
|
| BLAKE2b-256 |
7514bfd6f6f7181e16f4e4b85dc22cfdb5f6c805918d2334b2a4c9a46e54a8b4
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e6da621ea19b094611f4c7a117e26446458566ad33571e21dcc2e0c7fbb98ddb
|
|
| MD5 |
5f0a6f5d63a6c90ff3f322bc20204726
|
|
| BLAKE2b-256 |
e0c16e8f632a2cad43358799c41c52192289685d15381d73bde350c5f7a843c7
|