Skip to main content

Media Player Broker

Project description

README

Media Player Broker (mpb) is an application that helps you play and track media you have watched over disparet locations. mpb keeps track of what you have played at Location A so when you are at Location B you can see what you have watched from either location to avoid digging through history command output over SSH.

mpb is not a player itself but it can be configured to launch your player of choice to view media.

The Need

Rather than living in the cloud I have my videos duplicated at various locations. I needed something that remembers what episode of MacGyver I had watched in one location so when I was in another location I could continue watching the next episode without digging through history output or keeping track of what was played where.

mpb consists of a CLI application (the client) and a database (couchdb). From the client you injest your media metadata. This extracts the file names from file paths and stores the data in the database. After injesting, you can list your media which shows you the media Item, whether it has been watched or not along with a Rating, Notes, and the Sources the item is available at. You can then use the play command along with the Item to watch the Item. After playback is completed you are prompted to mark the item as played/watched, Rate it and add Notes - all of which are used in the list command to show what you have already watched and what is new.

mpb can also be used by multiple 'users' - you can share a 'user' so your wife can see what you have watched or you can keep separate users so your wife sees what she has watched and you know what you have watched.

Install

We recommend using pipx to install mpbroker: pipx install mpbroker. You can also install via pip: pip install --user mpbroker.

mpbroker uses a config file to store your setup. This file contains information such as your media player, the database url, and types of data to injest. You can grab the sample config file from mpbroker/example/user_config.toml and place it in a config location. mpbroker searches the following locations for the config file (in order of precedence):

  • $MPB_CONFIG_HOME: set this environment variable to any path you like and place the mpbroker user_config.toml file in this location
  • $XDG_CONFIG_HOME/mpbroker
  • $APPDATA/mpbroker
  • $HOME/.config/mpbroker

Configure

Notices

  • an example user_config.toml file can be found in the project example directory
  • if you do not want to use the standard locations and do not want to set a MPB_CONFIG_HOME envvar you can set MPB_CONFIG_HOME on the command line before calling mpb such as MPB_CONFIG_HOME=/opt/tmp mpb list 'The_Matrix'

To set up MPB you need to:

  • create your user_config.toml file (see above for locations of this file)
  • configure your user_config.toml file (at a minimum you will need to set/change the database.db_uri value)
  • ensure your mpb database is available
    • use the db-init command to initialize your db if it is a new instance!

If you are testing mpb or do not have a database you can use docker-compose to start a local database with docker-compose up from the project's docker-compose.yml file. If you use the local database your database.db_uri would be: http://admin:couchdb@localhost:5984

Using MPB

mpb has built in help (mpb --help) which should give you enough info to get going.

A Quick Start:

  • you will likely want to injest some media
  • next you can use list to view/find an item to play
  • finally you can play an item

Injestion

Injestion is the process of loading media metadata into your mpbroker database.

Extract Metadata

Extracting metadata on injestion increases the injestion time but adds the following data to each injested media item:

file_size: # filesize in human readable format (569 MiB, 1.1 GiB)
file_type: # file type (video/H265)
file_format: # file format (Matroska)
encoding: # encoding (x265)
duration: # duration in human readable format (1 h 52 min, 2 h 48 min)
resolution: # resulution in width x height format (720 x 480)
aspect_ratio: # display aspect ratio (16:9)
audio_format:  audio format (AAC)
audio_sampling: audio sample rate (48000)

Injestion Time Details

  • ~500 videos
    • with metadata extraction: 6.05s
    • without metadata extraction: 99.05s
  • 2785 videos
    • with metadata extraction: 596.53s
    • without metadata extraction: 72.75s

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

mpbroker-0.7.2.tar.gz (27.4 kB view details)

Uploaded Source

Built Distribution

mpbroker-0.7.2-py3-none-any.whl (29.3 kB view details)

Uploaded Python 3

File details

Details for the file mpbroker-0.7.2.tar.gz.

File metadata

  • Download URL: mpbroker-0.7.2.tar.gz
  • Upload date:
  • Size: 27.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.4 Linux/5.17.4-artix1-1

File hashes

Hashes for mpbroker-0.7.2.tar.gz
Algorithm Hash digest
SHA256 f71e53061051879009c0ee1ffb7f65df686a86c9a9ee355f3d5c906a1cbaa8b0
MD5 299dbeb84d1d9914088a685d3f72de04
BLAKE2b-256 11311b742bb005736bf5835dc647e5465d15a3315d124b3bc3e752788aa31849

See more details on using hashes here.

File details

Details for the file mpbroker-0.7.2-py3-none-any.whl.

File metadata

  • Download URL: mpbroker-0.7.2-py3-none-any.whl
  • Upload date:
  • Size: 29.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.4 Linux/5.17.4-artix1-1

File hashes

Hashes for mpbroker-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d33c4d61cfc08aed40172c0110e52b27799cca7b443e1644ffe2124c9c61043a
MD5 72424b77c4de2cf4da5638e96e06658a
BLAKE2b-256 a3a408a8e3168c1e2c184e4fde8895386b356401ef5375397ea995f6a5575f9b

See more details on using hashes here.

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