# JBOPS - Just a Bunch Of Plex Scripts Most of these scripts utilize a combination of [Tautulli](https://github.com/Tautulli/Tautulli), [python-plexapi](https://github.com/pkkid/python-plexapi), and [requests](http://docs.python-requests.org/en/master/user/install/#install). For use of config.ini for common variables please use [plexapi.CONFIG](http://python-plexapi.readthedocs.io/en/latest/configuration.html) Default location `~/.config/plexapi/config.ini` ```python # To find path import plexapi print(plexapi.CONFIG_PATH) ``` ### Contact [![PM](https://img.shields.io/badge/Discord-Scripts-lightgrey.svg?colorB=7289da)](https://discord.gg/tQcWEUp) [![PM](https://img.shields.io/badge/Reddit-Message-lightgrey.svg)](https://www.reddit.com/user/Blacktwin/) [![PM](https://img.shields.io/badge/Plex-Message-orange.svg)](https://forums.plex.tv/u/blacktwin) [![Issue](https://img.shields.io/badge/Submit-Issue-red.svg)](https://github.com/blacktwin/JBOPS/issues/new) ### Donation [![Donate](https://img.shields.io/badge/Donate-PayPal-blue.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=4J6RPWZ9J9YML) <details> <summary>Coins?</summary> <details> <summary>BTC:</summary> FCb4F3bv1hHCJxq6HJMQiAMn883v3okdh </details> <details> <summary>BCH:</summary> qr758vkn7nv6hx0ur9m2tlv8q4qjrvg6pg3yw4kzwq </details> <details> <summary>ETH:</summary> 0xa76c8EB9A4955023F0dAABfb32FCD2b460910F2b </details> <details> <summary>LTC:</summary> MCw3r6rC8jNCcUvSMSu9EqQyyvEDp8EpEf </details> </details> ## Scripts List [![Gist](https://img.shields.io/badge/gist-Blacktwin-green.svg)](https://gist.github.com/blacktwin) Scripts pulled from my gist profile. <details> <summary><a href="https://github.com/blacktwin/JBOPS/tree/master/maps">Maps</a></summary> <table> <tr> <th>Example</th> <th>File</th> <th>Description</th> </tr> <tr> <td><a href="https://github.com/blacktwin/JBOPS/raw/master/maps/EU_map_example.PNG"><img src="https://img.shields.io/badge/Image-EU_map-blue.svg" alt=""</a> <a href="https://github.com/blacktwin/JBOPS/raw/master/maps/NA_map_example.PNG"><img src="https://img.shields.io/badge/Image-NA_map-blue.svg" alt=""</a> <a href="https://github.com/blacktwin/JBOPS/raw/master/maps/World_map_example.PNG"><img src="https://img.shields.io/badge/Image-World_map-blue.svg" alt=""</a> <a href="https://github.com/blacktwin/JBOPS/blob/master/maps/geojson_example.geojson"><img src="https://img.shields.io/badge/Image-geojson-blue.svg" alt=""</a></td> <td><a href="../master/maps/ips_to_maps.py"ips_to_maps>Maps</a></td> <td>Using Tautulli data, draw a map connecting Server to Clients based on IP addresses.</td> </tr> </table> </details> <details> <summary><a href="https://github.com/blacktwin/JBOPS/tree/master/fun">Fun</a></summary> <table> <tr> <th>Gist</th> <th>File</th> <th>Description</th> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/397f07724abebd1223ba6ea644ea1669"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/fun/aired_today_playlist.py">aired_today_playlist</a></td> <td>Create a Plex Playlist with what was aired on this today's month-day, sort by oldest first. If Playlist from yesterday exists delete and create today's. If today's Playlist exists exit.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/4ccb79c7d01a95176b8e88bf4890cd2b"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/fun/plexapi_haiku.py">plexapi_haiku</a></td> <td>Create a hiaku from titles found in Plex.</td> </tr> </table> </details> <details> <summary><a href="https://github.com/blacktwin/JBOPS/tree/master/killstream">Kill stream</a> </summary> <b> Killing streams is a Plex Pass feature. These scripts will only work for Plex Pass users. </b> <table> <tr> <th>Gist</th> <th>File</th> <th>Description</th> </tr> <tr> <td></td> <td><a href="../master/killstream/watch_limit.py">watch_limit</a></td> <td>Kill streams if user has watched too much Plex Today.</td> </tr> <tr> <td></td> <td><a href="../master/killstream/play_limit.py">play_limit</a></td> <td>Kill streams if user has played too much Plex Today.</td> </tr> <tr> <td></td> <td><a href="../master/killstream/kill_time.py">kill_time</a></td> <td>Limit number of plays of TV Show episodes during time of day. Idea is to reduce continuous plays while sleeping.</td> </tr> <tr> <td></td> <td><a href="../master/killstream/kill_stream.py">kill_stream</a></td> <td>Use Conditions, Arguements, and Parameters to kill a Plex stream. See killsteam section <a href="../master/killstream/readme.md">readme.md</a></td> </tr> </table> </details> <details> <summary><a href="https://github.com/blacktwin/JBOPS/tree/master/notify">Notify</a></summary> <table> <tr> <th>Gist</th> <th>File</th> <th>Description</th> </tr> <tr> <td></td> <td><a href="../master/notify/notify_delay.py">notify_delay</a></td> <td>Delay Notification Agent message for concurrent streams.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/e6d589a9af9bdf168717951083861e93"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/find_unwatched_notify.py">find_unwatched_notify</a></td> <td>Find what was added TFRAME ago and not watched and notify admin using Tautulli.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/1094dcf38249f36c8d374e0cba7a86cd"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/notify_added_custom.py">notify_added_custom</a></td> <td>Send an email with what was added to Plex in the past week using Tautulli. Email includes title (TV: Show Name: Episode Name; Movie: Movie Title), time added, image, and summary.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/099c07d8099c18a378bba6415d9253ba"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/notify_fav_tv_all_movie.py">notify_fav_tv_all_movie</a></td> <td>Notify users of recently added episode to show that they have watched at least LIMIT times via email. Also notify users of new movies.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/a2d4b2f2c3b616f1d6da0752fecb2ae7"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/notify_newip.py">notify_newip</a></td> <td>If a new IP is found send notification via the Email Notification Agent. Email contains User's Avatar image, link to location, IP address, and User's Email address.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/a327055da54d7feb3eef10e64a8b661a"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/notify_on_added.py">notify_on_added</a></td> <td>Send an Email notification when a specific show is added to Plex. Add shows to list that you want notifications for.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/18960ff01c03b67a05594daa6f53660c"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/notify_user_favorites.py">notify_user_favorites</a></td> <td>Notify users of recently added episode to show that they have watched at least LIMIT times via email.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/066c66328a795ebd6079a575e14f0b8b"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/notify_user_newip.py">notify_user_newip</a></td> <td>Notify user that their account has been accessed by a new IP. IP is cleared to make sure notification is sent again.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/261c416dbed08291e6d12f6987d9bafa"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/notify/twitter_notify.py">twitter_notify</a></td> <td>Post to Twitter when TV/Movie is added to Plex. Include custom message and embed poster image. Option to tweet to TWITTER_USER if title is inside TITLE_FIND.</td> </tr> </table> </details> <details> <summary><a href="https://github.com/blacktwin/JBOPS/tree/master/utility">Utility</a></summary> <table> <tr> <th>Gist</th> <th>File</th> <th>Description</th> </tr> <tr> <td></td> <td><a href="../master/utility/plex_api_parental_control.py">plex_api_parental_control</a></td> <td>Set as cron or task for times of allowing and not allowing user access to server. Unsharing will kill any current stream from user before unsharing.</td> </tr> <tr> <td></td> <td><a href="../master/utility/plex_api_share.py">plex_api_share</a></td> <td>Share or unshare libraries</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/f4149c296f2d1ffd1cbd863c37bb3a3c"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/bypass_auth_name.py">bypass_auth_name</a></td> <td>Use Tautulli to pull last IP address from user and add to List of IP addresses and networks that are allowed without auth in Plex. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/0332f2dc9534bdf412ff3f664e9513c0"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/delete_watched_TV.py">delete_watched_TV</a></td> <td>From a list of TV shows, check if users in a list has watched shows episodes. If all users in list have watched an episode of listed show, then delete episode. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/76b0abf88181618af4598092dd6b0dbb"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/find_plex_meta.py">find_plex_meta</a></td> <td>Find location of Plex metadata. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/603d5da5b70b366e98d0d82d1aa1a470"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/find_unwatched.py">find_unwatched</a></td> <td>Find what was added TFRAME ago and not watched using Tautulli. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/f435aa0ccd498b0840d2407d599bf31d"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/grab_gdrive_media.py">grab_gdrive_media</a></td> <td>Grab media (videos, pictures) from Google Drive. All videos and pictures were automatically synced from Google Photos to Google Drive. Puts media into MEDIA_TYPE/YEAR/MONTH-DAY/FILE.ext directory structure. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/85a63ffd70c6ccb7c1faa70a8f33fc2e"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/plex_api_poster_pull.py">plex_api_poster_pull</a></td> <td>Pull Movie and TV Show poster images from Plex. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/17b58156f69cc52026b71fe4d5afea05"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/plex_imgur_dl.py">plex_imgur_dl</a></td> <td>Pull poster images from Imgur and places them inside Shows root folder. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/f10e0a1e85af00e878963b4570a99054"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/plex_theme_songs.py">plex_theme_songs</a></td> <td>Download theme songs from Plex TV Shows. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/45c420cbba4e18aadc8cc5090a67b9d1"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/plexapi_delete_playlists.py">plexapi_delete_playlists</a></td> <td>Delete all playlists from Plex using PlexAPI. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/df58032de3e6f4d29f7ea562aeaebbab"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/plexapi_search_file.py">plexapi_search_file</a></td> <td>Find full path for Plex items. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/3752a76fa0b3fc6d19e842af7b812184"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/refresh_next_episode.py">refresh_next_episode</a></td> <td>Refresh the next episode of show once current episode is watched. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/370ca42ee20a33fb00c8253fa9bd0de7"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/remove_watched_movies.py">remove_watched_movies</a></td> <td>Find Movies that have been watched by a list of users. If all users have watched movie then delete. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/2f619e62d99edcec27f680998379664c"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/utility/stream_limiter_ban_email.py">stream_limiter_ban_email</a></td> <td>This is indented to restrict a user to the LIMIT amount of concurrent streams. User will be warned, punished, and banned completely if violations continue.</td> </tr> </table> </details> <details> <summary><a href="https://github.com/blacktwin/JBOPS/tree/master/reporting">Reporting</a></summary> <table> <tr> <th>Gist</th> <th>File</th> <th>Description</th> </tr> <tr> <td></td> <td><a href="../master/reporting/weekly_stats_reporting.py">weekly_stats_reporting</a></td> <td>Pull library and user statistics of last week.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/21823b3394f5b077d42495b21570b593"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/reporting/added_to_plex.py">added_to_plex</a></td> <td>Find when media was added between STARTFRAME and ENDFRAME to Plex through Tautulli.</td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/f070dff29ddbeb87973be9c0a94a1df7"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/reporting/check_play.py">check_play</a></td> <td>Check if user has play a file more than 3 times but has not finished watching. Hoping to catch play failures. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/1a8933252ad1a9bc2c97395a020c144a"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/reporting/check_plex_log.py">check_plex_log</a></td> <td>Checking plex logs for debug code WARN and 'Failed to obtain a streaming resource for transcode of key /library/metadata/"titleID"'. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/561c3a404754eb7b9e543867619d3251"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/reporting/drive_check.py">drive_check</a></td> <td>Check if drive exists. If not then notify via Tautulli notifier agent. </td> </tr> <tr> <td><a href="https://gist.github.com/blacktwin/bd905d39ab71c5d7c628e27fddd1086e"><img src="https://img.shields.io/badge/gist-original-green.svg"></a></td> <td><a href="../master/reporting/userplays_weekly_reporting.py">userplays_weekly_reporting</a></td> <td>Use Tautulli to count how many plays per user occurred this week and send email via Tautulli.</td> </tr> </table> </details> ---- <details> <summary>Setting Up Tautulli for Custom Scripts</summary> #### Enabling Scripts in Tautulli: Taultulli > Settings > Notification Agents > Add a Notification Agent > Script #### Configuration Taultulli > Settings > Notification Agents > New Script > Configuration: - [ ] Set scripts location to location of your script - [ ] Scroll down to option you want to use and select the script from the drop down menu - [ ] Set desired Script Timeout value - [ ] Optional - Add a description of the script for easy reference - [ ] Save #### Triggers Taultulli > Settings > Notification Agents > New Script > Triggers: - [ ] Check desired trigger - [ ] Save #### Conditions Taultulli > Settings > Notification Agents > New Script > Conditions: - [ ] Set desired conditions - [ ] Save For more information on Tautulli conditions see [here](https://github.com/Tautulli/Tautulli-Wiki/wiki/Custom-Notification-Conditions) #### Script Arguments Taultulli > Settings > Notification Agents > New Script > Script Arguments: - [ ] Select desired trigger - [ ] Input desired notification parameters (List of parameters will likely be found inside script) - [ ] Save - [ ] Close </details> --- <details> <summary>Common variables</summary> <details> <summary>Plex</summary> - [ ] PLEX_URL - Local/Remote IP to connect to Plex ('http://localhost:32400', 'https://x.x.x.x:32412', etc.) - [ ] PLEX_TOKEN - [Plex](https://support.plex.tv/hc/en-us/articles/204059436-Finding-an-authentication-token-X-Plex-Token) or Tautulli Settings > Plex.tv Account > PMS Token </details> <details> <summary>Tautulli</summary> - [ ] TAUTULLI_URL - Local/Remote IP to connect to Tautulli ('http://localhost:8181', 'https://x.x.x.x:8182', etc.) - [ ] TAUTULLI_APIKEY - Tautulli Settings > Access Control > Enable API - API Key </details> </details>