No description
Find a file
2022-05-11 13:00:23 +05:30
models Added listenForUser config option for servers 2022-05-11 07:20:06 +05:30
services Tweaks 2022-05-11 07:49:49 +05:30
store Tweaks 2022-05-11 07:49:49 +05:30
utils Cleanup and tweaks 2022-05-11 03:27:06 +05:30
.gitignore Major refactor 2022-05-11 01:53:12 +05:30
LICENSE Major refactor 2022-05-11 01:53:12 +05:30
main.py Tweaks 2022-05-11 07:49:49 +05:30
README.md README tweaks 2022-05-11 13:00:23 +05:30
requirements.txt Fixed versions in requirements.txt 2022-05-11 06:40:28 +05:30

Discord Rich Presence for Plex

A Python script that displays your Plex status on Discord using Rich Presence.

Current Version: 2.1.1

Getting Started

  1. Install Python 3.10 - Make sure to tick "Add Python 3.10 to PATH" during the installation
  2. Download this repository's contents
  3. Extract the folder contained in the above ZIP file
  4. Navigate a command-line interface (cmd.exe, PowerShell, bash, etc.) into the above-extracted directory
  5. Install the required Python modules by running python -m pip install -U -r requirements.txt
  6. Start the script by running python main.py

When the script runs for the first time, a config.json file will be created in the working directory and you will be prompted to complete the authentication flow to allow the script to retrieve an access token for your Plex account.

The script must be running on the same machine as your Discord client.

Configuration - config.json

Reference

  • logging
    • debug (boolean, default: true) - Outputs additional debug-helpful information to the console if enabled.
  • display
    • useRemainingTime (boolean, default: false) - Displays your media's remaining time instead of elapsed time in your Rich Presence if enabled.
  • users (list)
    • token (string) - An access token associated with your Plex account. (X-Plex-Token, Authenticating with Plex)
    • servers (list)
      • name (string) - Name of the Plex Media Server you wish to connect to.
      • listenForUser (string, optional) - The script will respond to alerts originating only from this username. Defaults to the parent user's username if not set.
      • blacklistedLibraries (list, optional) - Alerts originating from libraries in this list are ignored.
      • whitelistedLibraries (list, optional) - If set, alerts originating from libraries that are not in this list are ignored.

Example

{
  "logging": {
    "debug": true
  },
  "display": {
    "useRemainingTime": false
  },
  "users": [
    {
      "token": "HPbrz2NhfLRjU888Rrdt",
      "servers": [
        {
          "name": "Bob's Home Media Server"
        },
        {
          "name": "A Friend's Server",
          "listenForUser": "xyz",
          "whitelistedLibraries": ["Movies"]
        }
      ]
    }
  ]
}

License

This project is licensed under the MIT License. See the LICENSE file for details.

Credits