Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/glitch452/MMM-PlexNowPlaying
A MagicMirror2 module that displays the list of playback sessions for a Plex Media Server.
https://github.com/glitch452/MMM-PlexNowPlaying
Last synced: about 2 months ago
JSON representation
A MagicMirror2 module that displays the list of playback sessions for a Plex Media Server.
- Host: GitHub
- URL: https://github.com/glitch452/MMM-PlexNowPlaying
- Owner: glitch452
- License: mit
- Created: 2019-10-15T03:25:16.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2022-02-14T12:45:14.000Z (almost 3 years ago)
- Last Synced: 2024-08-04T10:02:42.842Z (5 months ago)
- Language: JavaScript
- Size: 115 KB
- Stars: 27
- Watchers: 2
- Forks: 6
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-mmm - **MMM-PlexNowPlaying**
README
# MMM-PlexNowPlaying
This is a module for the [MagicMirror²](https://github.com/MichMich/MagicMirror/) smart mirror project.
This module displays the list of playback sessions for a [Plex Media Server](https://plex.tv).
| Status | Version | Date | Maintained? | Minimum MagicMirror² Version |
|:------- |:------- |:---------- |:----------- |:---------------------------- |
| Working | `1.2.0` | 2021-08-05 | Yes |`2.2.1` |### Example
![Example of MMM-PlexNowPlaying](images/sample.png?raw=true "Example screenshot")### Dependencies
1. A [Plex Media Server](https://plex.tv) installation for the source of the data## Installation
To install the module, use your terminal to:
1. Navigate to your MagicMirror's modules folder. If you are using the default installation directory, use the command:
`cd ~/MagicMirror/modules`
2. Copy the module to your computer by executing the following command:
`git clone https://github.com/glitch452/MMM-PlexNowPlaying.git`## Using the module
### MagicMirror² Configuration
To use this module, add the following configuration block to the modules array in the `config/config.js` file:
```js
var config = {
modules: [
...
{
module: "MMM-PlexNowPlaying",
position: "top_left",
header: "Plex: Now Playing",
config: {
serverProtocol: "http",
serverAddress: "x.x.x.x",
serverPort: 32400,
xPlexToken: "xxxxxxxxxxxxxxxxxxxx"
// See below for more Configuration Options
}
},
...
]
}
```### Configuration Options
| Option | Details
|:----------------------- |:-------------
| `serverAddress` | **REQUIRED** - IP Address or Hostname of the server.
**Type:** `string`
| `xPlexToken` | **REQUIRED** - An X-Plex-Token for a user that has access to the server's session list.
See [Finding an authentication token](https://support.plex.tv/articles/204059436-finding-an-authentication-token-x-plex-token/) for more details on how to obtain the token.
**Type:** `string`
| `serverPort` | *Optional* - The port to use when connecting to the server.
**Type:** `number`
**Default:** `32400`
| `serverProtocol` | *Optional* - The protocol to use when connecting to the server. Note: https will work with newer Plex Server versions, however MagicMirror may not be able to connect via https.
**Type:** `string`
**Default:** `"http"`
**Options:** `"http"`, `"https"`
| `updateInterval` | *Optional* - The number of seconds to wait before requesting an update of the data from the Plex Server. The minimum value is `2`.
**Type:** `number`
**Default:** `30`
| `fontSize` | *Optional* - The main font size to use for the module text.
**Type:** `string`
**Default:** `"medium"`
**Options:** `"x-small"`, `"small"`, `"medium"`, `"large"`, `"x-large"`
| `fontColor` | *Optional* - The colour to use for the module text.
**Type:** `string`
**Default:** MagicMirror's default color
**Options:** Any valid CSS color value. See [w3schools](https://www.w3schools.com/cssref/css_colors_legal.asp) for more info.
| `userNameFilter` | *Optional* - Replace usernames with custom names. i.e. if someone uses the username `plex.user.123`, the module can display their actual name instead by adding an entry into this object that maps the user name to the friendly name.
**Example:** `{ "user_name": "Custom Name", "plex.user.123": "John Smith" }`
**Type:** `object`
**Default:** `{}`
| `showUser` | *Optional* - When `true`, the user avatar and username are shown for each item in the list.
**Type:** `boolean`
**Default:** `true`
| `showPoster` | *Optional* - When `true`, the thubmail image is show for each item in the list with a supported image.
**Type:** `boolean`
**Default:** `true`
| `showStatusIcons` | *Optional* - When `true`, the status indicator icons are shown in the list. These icons include the playback state (playing/paused), connection type (local/remote) and connection security status (secure/insecure).
**Type:** `boolean`
**Default:** `true`
| `headerTemplate` | *Optional* - The text template to use for the module header text when there is at least one stream displayed. The sting `"{header_text}"` will be replaced with the module's header text. The string `"{play_count}"` will be replaced with the number of streams displayed.
**Type:** `string`
**Default:** `"{header_text} ({play_count})"`
| `headerTemplateZero` | *Optional* - The text template to use for the module header text when there are no streams displayed. The sting `"{header_text}"` will be replaced with the module's header text. The string `"{play_count}"` will be replaced with the number of streams displayed.
**Type:** `string`
**Default:** `"{header_text}"`
| `hideWhenNothingPlaying`| *Optional* - When `true`, this module will be completely hidden when there are no streams.
**Type:** `boolean`
**Default:** `false`
| `enableProgressTimer` | *Optional* - When `true`, the progress bars will be incremented between data updates from the server. This makes the progress bar animation smoother with smaller jumps, which is especially noticeable with shorter media files, such as music.
**Type:** `boolean`
**Default:** `true`
| `networkFilter` | *Optional* - Whether to show only Local streams, only Remote streams of Both.
**Type:** `string`
**Default:** `"both"`
**Options:** `"local"`, `"remote"`, `"both"`
| `playStateFilter` | *Optional* - Whether to show only Playing streams, only Paused streams of Both.
**Type:** `string`
**Default:** `"both"`
**Options:** `"playing"`, `"paused"`, `"both"`
| `userWhiteList` | *Optional* - When set, items will only show up if the user is in this list.
**Type:** `array` of `string`
**Default:** `[]`
| `userBlackList` | *Optional* - Items will NOT show up if the user is in this list. This has a higher priority than `userWhiteList`.
**Type:** `array` of `string`
**Default:** `[]`
| `typeWhiteList` | *Optional* - When set, items will only show up if the type is in this list.
**Item Types**: `"movie"`, `"episode"`, `"track"`, `"photo"`, `"trailer"`, `"livetv"`, `"other"`.
**Type:** `array` of `string`
**Default:** `[]`
| `typeBlackList` | *Optional* - Items will NOT show up if the type is in this list. This has a higher priority than `typeWhiteList`. See `typeWhiteList` for the list of Item Types.
**Type:** `array` of `string`
**Default:** `[]`
| `libraryWhiteList` | *Optional* - When set, an item will only show up if the name of its Library is in this list.
**Item Types**: `""`, `"Trailers"`, `"Other"`.
**Type:** `array` of `string`
**Default:** `[]`
| `libraryBlackList` | *Optional* - An item will NOT show up if the name of its Library is in this list. This has a higher priority than `libraryWhiteList`. See `libraryWhiteList` for the list of Library Names.
**Type:** `array` of `string`
**Default:** `[]`
| `animationSpeed` | *Optional* - The number of milliseconds to use for the animation when updating the on-screen display of this module. The minimum value is `0`.
**Type:** `number`
**Default:** `0`
| `initialLoadDelay` | *Optional* - The number of seconds to wait before starting to run this module. The minimum value is `0`.
**Type:** `number`
**Default:** `0`
| `retryDelay` | *Optional* - The number of seconds to wait before trying to request the data again after a data retrieval failure.
**Type:** `number`
**Default:** `5`## Updates
To update the module to the latest version, use your terminal to:
1. Navigate to your MMM-PlexNowPlaying folder. If you are using the default installation directory, use the command:
`cd ~/MagicMirror/modules/MMM-PlexNowPlaying`
2. Update the module by executing the following command:
`git pull`If you have changed the module on your own, the update will fail.
To force an update (WARNING! your changes will be lost), reset the module and then update with the following commands:
```
git reset --hard
git pull
```## Manually Choose a Version
To use an older version of this module, use your terminal to:
1. Navigate to your MMM-PlexNowPlaying folder. If you are using the default installation directory, use the command:
`cd ~/MagicMirror/modules/MMM-PlexNowPlaying`
2. Fetch all the available tags
`git fetch`
3. Show all the available tags
`git tag`
4. Checkout one of the available tags
`git checkout {tag_name}`
Example: `git checkout v1.0.0`To switch back to the latest version, use your terminal to:
1. Navigate to your MMM-PlexNowPlaying folder. If you are using the default installation directory, use the command:
`cd ~/MagicMirror/modules/MMM-PlexNowPlaying`
2. Checkout the master branch
`git checkout master`## License
### The MIT License (MIT)
Copyright © 2019 David Dearden
Permission is hereby granted, free of charge, to any person
obtaining a copy of this software and associated documentation
files (the “Software”), to deal in the Software without
restriction, including without limitation the rights to use,
copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the
Software is furnished to do so, subject to the following
conditions:The above copyright notice and this permission notice shall be
included in all copies or substantial portions of the Software.**The software is provided “as is”, without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the software.**