Go to file
Blacktwin c6ed7286dc #83
2018-07-09 08:30:11 -04:00
fun play_lst check 2018-03-29 09:48:20 -04:00
killstream Exit if a sessionID wasn't provided 2018-06-20 10:45:00 -07:00
maps cleaning special characters from region, city, and friendly names. 2018-06-12 09:56:13 -04:00
notify Delete test.txt 2018-06-12 09:55:19 -04:00
reporting make search and parsing str in case of int. 2018-04-08 21:38:02 -04:00
utility Merge remote-tracking branch 'origin/master' 2018-06-12 10:04:01 -04:00
config.ini create config.ini 2018-06-16 11:26:24 -04:00
README.md #83 2018-07-09 08:30:11 -04:00
requirements.txt requirements file. 2018-06-12 14:02:08 -04:00
scriptHeaderTemplate.txt updated metadata section for tautulli 2018-03-29 09:49:28 -04:00

JBOPS - Just a Bunch Of Plex Scripts

Most of these scripts utilize a combination of Tautulli, python-plexapi, and requests.

For use of config.ini for common variables please use plexapi.CONFIG

Default location ~/.config/plexapi/config.ini

# To find path
import plexapi
print(plexapi.CONFIG_PATH)

Contact

PM PM PM Issue

Donation

Donate

Coins?
BTC: FCb4F3bv1hHCJxq6HJMQiAMn883v3okdh
BCH: qr758vkn7nv6hx0ur9m2tlv8q4qjrvg6pg3yw4kzwq
ETH: 0xa76c8EB9A4955023F0dAABfb32FCD2b460910F2b
LTC: MCw3r6rC8jNCcUvSMSu9EqQyyvEDp8EpEf

Scripts List

Gist

Scripts pulled from my gist profile.

Maps
Example File Description
Maps Using Tautulli data, draw a map connecting Server to Clients based on IP addresses.
Fun
Gist File Description
aired_today_playlist 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.
plexapi_haiku Create a hiaku from titles found in Plex.
Kill stream

Killing streams is a Plex Pass feature. These scripts will only work for Plex Pass users.
Gist File Description
watch_limit Kill streams if user has watched too much Plex Today.
play_limit Kill streams if user has played too much Plex Today.
kill_time Limit number of plays of TV Show episodes during time of day. Idea is to reduce continuous plays while sleeping.
kill_stream Use Conditions, Arguements, and Parameters to kill a Plex stream. See killsteam section readme.md
Notify
Gist File Description
notify_delay Delay Notification Agent message for concurrent streams.
find_unwatched_notify Find what was added TFRAME ago and not watched and notify admin using Tautulli.
notify_added_custom 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.
notify_fav_tv_all_movie Notify users of recently added episode to show that they have watched at least LIMIT times via email. Also notify users of new movies.
notify_newip 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.
notify_on_added Send an Email notification when a specific show is added to Plex. Add shows to list that you want notifications for.
notify_user_favorites Notify users of recently added episode to show that they have watched at least LIMIT times via email.
notify_user_newip Notify user that their account has been accessed by a new IP. IP is cleared to make sure notification is sent again.
twitter_notify 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.
Utility
Gist File Description
plex_api_parental_control 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.
plex_api_share Share or unshare libraries
bypass_auth_name 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.
delete_watched_TV 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.
find_plex_meta Find location of Plex metadata.
find_unwatched Find what was added TFRAME ago and not watched using Tautulli.
grab_gdrive_media 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.
plex_api_poster_pull Pull Movie and TV Show poster images from Plex.
plex_imgur_dl Pull poster images from Imgur and places them inside Shows root folder.
plex_theme_songs Download theme songs from Plex TV Shows.
plexapi_delete_playlists Delete all playlists from Plex using PlexAPI.
plexapi_search_file Find full path for Plex items.
refresh_next_episode Refresh the next episode of show once current episode is watched.
remove_watched_movies Find Movies that have been watched by a list of users. If all users have watched movie then delete.
stream_limiter_ban_email 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.
Reporting
Gist File Description
weekly_stats_reporting Pull library and user statistics of last week.
added_to_plex Find when media was added between STARTFRAME and ENDFRAME to Plex through Tautulli.
check_play Check if user has play a file more than 3 times but has not finished watching. Hoping to catch play failures.
check_plex_log Checking plex logs for debug code WARN and 'Failed to obtain a streaming resource for transcode of key /library/metadata/"titleID"'.
drive_check Check if drive exists. If not then notify via Tautulli notifier agent.
userplays_weekly_reporting Use Tautulli to count how many plays per user occurred this week and send email via Tautulli.

Setting Up Tautulli for Custom Scripts

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

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

Common variables
Plex
Tautulli