|
|
@ -1,6 +1,12 @@
|
|
|
|
#!/usr/bin/env bash
|
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
version=1.0.4
|
|
|
|
|
|
|
|
if [ -z "$lidarr_artist_path" ]; then
|
|
|
|
|
|
|
|
lidarr_artist_path="$1"
|
|
|
|
|
|
|
|
notfidedBy=Extended_Script
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
notfidedBy=Lidarr
|
|
|
|
|
|
|
|
fi
|
|
|
|
lidarrRootFolderPath="$(dirname "$lidarr_artist_path")"
|
|
|
|
lidarrRootFolderPath="$(dirname "$lidarr_artist_path")"
|
|
|
|
version=1.0.3
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# auto-clean up log file to reduce space usage
|
|
|
|
# auto-clean up log file to reduce space usage
|
|
|
|
if [ -f "/config/logs/PlexNotify.txt" ]; then
|
|
|
|
if [ -f "/config/logs/PlexNotify.txt" ]; then
|
|
|
@ -16,21 +22,21 @@ log () {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if [ "$lidarr_eventtype" == "Test" ]; then
|
|
|
|
if [ "$lidarr_eventtype" == "Test" ]; then
|
|
|
|
log "Tested Successfully"
|
|
|
|
log "$notfidedBy :: Tested Successfully"
|
|
|
|
exit 0
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# Validate connection
|
|
|
|
# Validate connection
|
|
|
|
plexVersion=$(curl -s "$plexUrl/?X-Plex-Token=$plexToken" | xq . | jq -r '.MediaContainer."@version"')
|
|
|
|
plexVersion=$(curl -s "$plexUrl/?X-Plex-Token=$plexToken" | xq . | jq -r '.MediaContainer."@version"')
|
|
|
|
if [ $plexVersion = null ]; then
|
|
|
|
if [ $plexVersion = null ]; then
|
|
|
|
log "ERROR :: Cannot communicate with Plex"
|
|
|
|
log "$notfidedBy :: ERROR :: Cannot communicate with Plex"
|
|
|
|
log "ERROR :: Please check your plexUrl and plexToken"
|
|
|
|
log "$notfidedBy :: ERROR :: Please check your plexUrl and plexToken"
|
|
|
|
log "ERROR :: Configured plexUrl \"$plexUrl\""
|
|
|
|
log "$notfidedBy :: ERROR :: Configured plexUrl \"$plexUrl\""
|
|
|
|
log "ERROR :: Configured plexToken \"$plexToken\""
|
|
|
|
log "$notfidedBy :: ERROR :: Configured plexToken \"$plexToken\""
|
|
|
|
log "ERROR :: Exiting..."
|
|
|
|
log "$notfidedBy :: ERROR :: Exiting..."
|
|
|
|
exit
|
|
|
|
exit
|
|
|
|
else
|
|
|
|
else
|
|
|
|
log "Plex Connection Established, version: $plexVersion"
|
|
|
|
log "$notfidedBy :: Plex Connection Established, version: $plexVersion"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
plexLibraries="$(curl -s "$plexUrl/library/sections?X-Plex-Token=$plexToken")"
|
|
|
|
plexLibraries="$(curl -s "$plexUrl/library/sections?X-Plex-Token=$plexToken")"
|
|
|
@ -41,16 +47,16 @@ elif echo "$plexLibraries" | xq ".MediaContainer.Directory[] | select(.\"@type\"
|
|
|
|
plexKeys=($(echo "$plexLibraries" | xq ".MediaContainer.Directory[] | select(.\"@type\"==\"artist\")" | jq -r '."@key"'))
|
|
|
|
plexKeys=($(echo "$plexLibraries" | xq ".MediaContainer.Directory[] | select(.\"@type\"==\"artist\")" | jq -r '."@key"'))
|
|
|
|
plexLibraryData=$(echo "$plexLibraries" | xq ".MediaContainer.Directory[] | select(.\"@type\"==\"artist\")")
|
|
|
|
plexLibraryData=$(echo "$plexLibraries" | xq ".MediaContainer.Directory[] | select(.\"@type\"==\"artist\")")
|
|
|
|
else
|
|
|
|
else
|
|
|
|
log "ERROR: No Plex Music Type libraries found"
|
|
|
|
log "$notfidedBy :: ERROR: No Plex Music Type libraries found"
|
|
|
|
log "ERROR: Exiting..."
|
|
|
|
log "$notfidedBy :: ERROR: Exiting..."
|
|
|
|
exit 1
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if echo "$plexLibraryData" | grep "\"@path\": \"$lidarrRootFolderPath" | read; then
|
|
|
|
if echo "$plexLibraryData" | grep "\"@path\": \"$lidarrRootFolderPath" | read; then
|
|
|
|
sleep 0.01
|
|
|
|
sleep 0.01
|
|
|
|
else
|
|
|
|
else
|
|
|
|
log "ERROR: No Plex Library found containing path \"$lidarrRootFolderPath\""
|
|
|
|
log "$notfidedBy :: ERROR: No Plex Library found containing path \"$lidarrRootFolderPath\""
|
|
|
|
log "ERROR: Add \"$lidarrRootFolderPath\" as a folder to a Plex Music Library"
|
|
|
|
log "$notfidedBy :: ERROR: Add \"$lidarrRootFolderPath\" as a folder to a Plex Music Library"
|
|
|
|
exit 1
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
@ -59,7 +65,7 @@ for key in ${!plexKeys[@]}; do
|
|
|
|
if echo "$plexLibraryData" | grep "\"@path\": \"$lidarrRootFolderPath" | read; then
|
|
|
|
if echo "$plexLibraryData" | grep "\"@path\": \"$lidarrRootFolderPath" | read; then
|
|
|
|
plexFolderEncoded="$(jq -R -r @uri <<<"$lidarr_artist_path")"
|
|
|
|
plexFolderEncoded="$(jq -R -r @uri <<<"$lidarr_artist_path")"
|
|
|
|
curl -s "$plexUrl/library/sections/$plexKey/refresh?path=$plexFolderEncoded&X-Plex-Token=$plexToken"
|
|
|
|
curl -s "$plexUrl/library/sections/$plexKey/refresh?path=$plexFolderEncoded&X-Plex-Token=$plexToken"
|
|
|
|
log "Plex Scan notification sent! ($lidarr_artist_path)"
|
|
|
|
log "$notfidedBy :: Plex Scan notification sent! ($lidarr_artist_path)"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|