Skip to main content

Publish a MediaPlayer2 MPRIS device to D-BUS.

Project description

▶️ Add MPRIS Integration to Media Players

mpris_server provides adapters to integrate MPRIS support in your media player or device.

Whereas existing MPRIS libraries for Python implement clients for apps with existing MPRIS support, mpris_server is a library to implement MPRIS support in apps that don't already have it. If you want to give your media player an MPRIS interface, mpris_server is right for you.

mpris_server is a fork of Mopidy-MPRIS that was extended and made into a general purpose library.

Check out 📺chromecast_mpris for an app that uses mpris_server.

Features

Implements the following from the MPRIS specification:

  • MediaPlayer2
  • MediaPlayer2.Player
  • MediaPlayer2.Playlist
  • MediaPlayer2.TrackList

The library also provides an event handler that emits org.freedesktop.DBus.Properties.PropertiesChanged in response to changes in your media player. This allows for real-time updates from your media player to DBus.

Installation

Requirements

Installing PyGObject

On Debian-derived distributions like Ubuntu, install python3-gi with apt. On Arch, you'll want to install python-gobject. On macOS, install pygobject3 via brew.

Use pip to install PyGObject>=3.34.0 if there are no installation candidates available in your vendor's package repositories.

PyPI

pip3 install mpris_server

Github

Clone the repo, run pip3 install -r requirements.txt, followed by python3 setup.py install.

Usage

Implement adapters.MprisAdapter

Subclass adapters.MprisAdapter and implement each method.

After subclassing, pass an instance to an instance of server.Server.

Implement events.EventAdapter

Subclass adapters.EventAdapter. This interface has a good default implementation, only override its methods if your app calls for it.

If you choose to re-implement its methods, call emit_changes() with the corresponding interface and a List[str] of properties that changed.

Integrate the adapter with your application to emit changes in your media player that DBus needs to know about. For example, if the user pauses the media player, be sure to call EventAdapter.on_playpause() in the app. DBus won't know about the change otherwise.

Create the Server and Publish

Create an instance of server.Server, pass it an instance of your MprisAdapter, and call publish() to publish your media player via DBus.

mpris = Server('MyMediaPlayer', adapter=my_adapter)
mpris.publish() 

Call loop() to enter the DBus event loop, or enter the DBus event loop elsewhere in your code.

mpris.loop() 

Or:

from gi.repository import GLib

loop = GLib.MainLoop()
loop.run()

Example

from mpris_server.adapters import MprisAdapter, Track
from mpris_server.events import EventAdapter
from mpris_server.server import Server

from my_app import app  # custom app you want to integrate


class MyAppAdapter(MprisAdapter):
    # Make sure to implement all methods on MprisAdapter, not just get_current_track()
    def get_current_track(self) -> Track:
        ...
    # and so on


class MyAppEventHandler(EventAdapter):
    # EventAdapter has good default implementations for its methods.
    # Only override the default methods if it suits your app.

    def on_app_event(self, event: str):
        # trigger DBus updates based on events in your app
        if event == 'pause':
            self.on_playpause()
        ...
    # and so on

# create mpris adapter and initialize mpris server
my_adapter = MyAppAdapter()
mpris = Server('MyApp', adapter=my_adapter)

# initialize app integration with mpris
event_handler = MyAppEventHandler()
app.register_event_handler(event_handler)

# publish and serve
mpris.loop()

License

See LICENSE. Message me if you'd like to use this project with a different license.

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

mpris_server-0.2.0.tar.gz (13.3 kB view details)

Uploaded Source

Built Distribution

mpris_server-0.2.0-py2.py3-none-any.whl (14.8 kB view details)

Uploaded Python 2Python 3

File details

Details for the file mpris_server-0.2.0.tar.gz.

File metadata

  • Download URL: mpris_server-0.2.0.tar.gz
  • Upload date:
  • Size: 13.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.2

File hashes

Hashes for mpris_server-0.2.0.tar.gz
Algorithm Hash digest
SHA256 b39b5a1c93b5f15905f62deb29a09b768b56e5ca4bf81d62aaaa34e4e13dcc76
MD5 b6dc37f57e072b12db87683076ddb3cb
BLAKE2b-256 76c600e8598be7fc0e1b37897d1c7bb8332ff5965ee5df9046e241c52b80406d

See more details on using hashes here.

File details

Details for the file mpris_server-0.2.0-py2.py3-none-any.whl.

File metadata

  • Download URL: mpris_server-0.2.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 14.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.2

File hashes

Hashes for mpris_server-0.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e2a28b105d6b7cca173e64dabd5b19655a08b1582020914f7f456f8144c1216a
MD5 9d5220c29c3f0706965df539b659e769
BLAKE2b-256 f9119a9c2e96f147f3c3ab15db3a0b3ddb81ffb26ac5bcf54e90379f28430242

See more details on using hashes here.

Supported by

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