From c89e5cd67b4abb06f2390bf5b9f403686d88a058 Mon Sep 17 00:00:00 2001 From: RandomNinjaAtk Date: Mon, 5 Sep 2022 14:39:39 -0400 Subject: [PATCH] Create PlexNotify.bash --- root/scripts/PlexNotify.bash | 78 ++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 root/scripts/PlexNotify.bash diff --git a/root/scripts/PlexNotify.bash b/root/scripts/PlexNotify.bash new file mode 100644 index 0000000..ae74a8e --- /dev/null +++ b/root/scripts/PlexNotify.bash @@ -0,0 +1,78 @@ +#!/usr/bin/env bash +version="1.0.000" + +notfidedBy="Sonarr" +arrRootFolderPath="$(dirname "$sonarr_episodefile_path")" +arrFolderPath="$radarr_movie_path" +arrEventType="$sonarr_eventtype" +movieExtrasPath="$1" + +# Debugging Settings +#enableExtras=false + +# auto-clean up log file to reduce space usage +if [ -f "/config/logs/PlexNotify.txt" ]; then + find /config/logs -type f -name "PlexNotify.txt" -size +1024k -delete +fi + +exec &>> "/config/logs/PlexNotify.txt" +chmod 666 "/config/logs/PlexNotify.txt" + +log () { + m_time=`date "+%F %T"` + echo $m_time" :: PlexNotify :: "$1 +} + +if [ "$enableExtras" == "true" ]; then + if [ -z "$movieExtrasPath" ]; then + log "MovieExtras script is enabled, skipping..." + exit + fi +fi + +if [ "$arrEventType" == "Test" ]; then + log "$notfidedBy :: Tested Successfully" + exit 0 +fi + +# Validate connection +plexVersion=$(curl -s "$plexUrl/?X-Plex-Token=$plexToken" | xq . | jq -r '.MediaContainer."@version"') +if [ $plexVersion = null ]; then + log "$notfidedBy :: ERROR :: Cannot communicate with Plex" + log "$notfidedBy :: ERROR :: Please check your plexUrl and plexToken" + log "$notfidedBy :: ERROR :: Configured plexUrl \"$plexUrl\"" + log "$notfidedBy :: ERROR :: Configured plexToken \"$plexToken\"" + log "$notfidedBy :: ERROR :: Exiting..." + exit +else + log "$notfidedBy :: Plex Connection Established, version: $plexVersion" +fi + +plexLibraries="$(curl -s "$plexUrl/library/sections?X-Plex-Token=$plexToken")" +plexLibraryData=$(echo "$plexLibraries" | xq ".MediaContainer.Directory") +if echo "$plexLibraryData" | grep "^\[" | read; then + plexLibraryData=$(echo "$plexLibraries" | xq ".MediaContainer.Directory[]") + plexKeys=($(echo "$plexLibraries" | xq ".MediaContainer.Directory[]" | jq -r '."@key"')) +else + plexKeys=($(echo "$plexLibraries" | xq ".MediaContainer.Directory" | jq -r '."@key"')) +fi + +if echo "$plexLibraryData" | grep "\"@path\": \"$arrRootFolderPath" | read; then + sleep 0.01 +else + log "$notfidedBy :: ERROR: No Plex Library found containing path \"$arrRootFolderPath\"" + log "$notfidedBy :: ERROR: Add \"$arrRootFolderPath\" as a folder to a Plex Movie Library" + exit 1 +fi + +for key in ${!plexKeys[@]}; do + plexKey="${plexKeys[$key]}" + plexKeyData="$(echo "$plexLibraryData" | jq -r "select(.\"@key\"==\"$plexKey\")")" + if echo "$plexKeyData" | grep "\"@path\": \"$arrRootFolderPath" | read; then + plexFolderEncoded="$(jq -R -r @uri <<<"$arrFolderPath")" + curl -s "$plexUrl/library/sections/$plexKey/refresh?path=$plexFolderEncoded&X-Plex-Token=$plexToken" + log "$notfidedBy :: Plex Scan notification sent! ($arrFolderPath)" + fi +done + +exit