From ae56411a0ba298afc84ee4635836d39f2c5253d2 Mon Sep 17 00:00:00 2001 From: Jasper Aelvoet <82276344+jasperaelvoet@users.noreply.github.com> Date: Tue, 15 Aug 2023 16:50:09 +0200 Subject: [PATCH 1/2] Possible YT fallback implementation --- lidarr/Audio.service.bash | 115 ++++++++++++++++++++++++++++++++++++++ lidarr/extended.conf | 1 + 2 files changed, 116 insertions(+) diff --git a/lidarr/Audio.service.bash b/lidarr/Audio.service.bash index 6a7ac9e..c7b8d58 100644 --- a/lidarr/Audio.service.bash +++ b/lidarr/Audio.service.bash @@ -1387,6 +1387,121 @@ SearchProcess () { touch "/config/extended/logs/notfound/$wantedAlbumId--$lidarrArtistForeignArtistId--$lidarrAlbumForeignAlbumId" chmod 777 "/config/extended/logs/notfound/$wantedAlbumId--$lidarrArtistForeignArtistId--$lidarrAlbumForeignAlbumId" fi + + if [ $notFoundYoutubeFallback == "true" ]; then + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Falling back to YouTube" + + query_param="release:${lidarrAlbumTitle} AND artist:${lidarrArtistName}&fmt=json" + album_id=$(curl --get --data-urlencode "query=${query_param}" --data-urlencode "fmt=json" "https://musicbrainz.org/ws/2/release/" | jq -r '.releases[0].id') + album_data=$(curl --get "https://musicbrainz.org/ws/2/release/${album_id}?inc=recordings&fmt=json") + tracks=$(jq -r '.media[0].tracks' <<< "$album_data" ) + + downloadedAlbumTitleClean="$(echo "$4" | sed -e "s%[^[:alpha:][:digit:]._' ]% %g" -e "s/ */ /g" | sed 's/^[.]*//' | sed 's/[.]*$//g' | sed 's/^ *//g' | sed 's/ *$//g')" + downloadedAlbumFolder="$lidarrArtistNameSanitized-$downloadedAlbumTitleClean ($3)-${albumquality^^}-$1-$2" + + if [[ -z $album_id ]]; then + echo "Album not found on MusicBrainz." + else + if [ -d "/temp-yt-dl" ]; then + rm -rf "/temp-yt-dl" + fi + + mkdir -p /temp-yt-dl/ + chmod 777 -R /temp-yt-dl/ + chomd 777 -R "${audioPath}/incomplete/" + + jq -c '.[]' <<< "$tracks" | while read track; do + track_title=$(jq -r '.title' <<< "$track") + track_id=$(jq -r '.id' <<< "$track") + yt-dlp --audio-quality highest --audio-format aac -o "/temp-yt-dl/${track_id}" -x "ytsearch:${lidarrArtistName} - ${track_title} (Audio)" + ffmpeg -i "/temp-yt-dl/${track_id}.m4a" -metadata title="${track_title}" -metadata artist="${lidarrArtistName}" -metadata album="${lidarrAlbumTitle}" "${audioPath}/incomplete/${track_id}.m4a" + done + + if [ -d "/temp-yt-dl" ]; then + rm -rf "/temp-yt-dl" + fi + + if [ "$enableBeetsTagging" == "true" ]; then + if [ -f /config/extended/beets-error ]; then + rm /config/extended/beets-error + fi + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Processing files with beets..." + ProcessWithBeets "$audioPath"/incomplete/ + + if [ -f /config/extended/beets-error ]; then + return + fi + fi + + if [ "$enableReplaygainTags" == "true" ]; then + AddReplaygainTags "$audioPath/incomplete" + else + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Replaygain Tagging Disabled (set enableReplaygainTags=true to enable...)" + fi + + albumquality="$(find "$audioPath"/incomplete/ -type f -regex ".*/.*\.\(flac\|opus\|m4a\|mp3\)" | head -n 1 | egrep -i -E -o "\.{1}\w*$" | sed 's/\.//g')" + downloadedAlbumFolder="$lidarrArtistNameSanitized-$downloadedAlbumTitleClean ($3)-${albumquality^^}-$1-$2" + + find "$audioPath/incomplete" -type f -regex ".*/.*\.\(flac\|opus\|m4a\|mp3\)" -print0 | while IFS= read -r -d '' audio; do + file="${audio}" + filenoext="${file%.*}" + filename="$(basename "$audio")" + extension="${filename##*.}" + filenamenoext="${filename%.*}" + if [ ! -d "$audioPath/complete" ]; then + mkdir -p "$audioPath"/complete + chmod 777 "$audioPath"/complete + fi + mkdir -p "$audioPath/complete/$downloadedAlbumFolder" + mv "$file" "$audioPath/complete/$downloadedAlbumFolder"/ + done + + chmod -R 777 "$audioPath"/complete + + if [ -d "$audioPath/complete/$downloadedAlbumFolder" ]; then + NotifyLidarrForImport "$audioPath/complete/$downloadedAlbumFolder" + + LidarrTaskStatusCheck + CheckLidarrBeforeImport "$checkLidarrAlbumId" + if [ "$alreadyImported" == "true" ]; then + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Already Imported, skipping..." + rm -rf "$audioPath"/incomplete/* + fi + fi + + if [ -d "$audioPath/complete/$downloadedAlbumFolder" ]; then + NotifyLidarrForImport "$audioPath/complete/$downloadedAlbumFolder" + + LidarrTaskStatusCheck + CheckLidarrBeforeImport "$checkLidarrAlbumId" + if [ "$alreadyImported" == "true" ]; then + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Already Imported, skipping..." + rm -rf "$audioPath"/incomplete/* + fi + fi + + if [ -d "$audioPath/complete/$downloadedAlbumFolder" ]; then + NotifyLidarrForImport "$audioPath/complete/$downloadedAlbumFolder" + + LidarrTaskStatusCheck + CheckLidarrBeforeImport "$checkLidarrAlbumId" + if [ "$alreadyImported" == "true" ]; then + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Already Imported, skipping..." + rm -rf "$audioPath"/incomplete/* + fi + fi + + if [ -d "$audioPath/complete/$downloadedAlbumFolder" ]; then + rm -rf "$audioPath"/incomplete/* + fi + + LidarrTaskStatusCheck + CheckLidarrBeforeImport "$checkLidarrAlbumId" + if [ "$alreadyImported" == "true" ]; then + break + fi + fi + fi else log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Skip marking album as not found because it's a new release for 7 days..." fi diff --git a/lidarr/extended.conf b/lidarr/extended.conf index fc8cd4c..db627eb 100644 --- a/lidarr/extended.conf +++ b/lidarr/extended.conf @@ -24,6 +24,7 @@ searchSort="date" # date or album :: Sorts the missing/cutoff list by release da matchDistance="5" # The number of changes required to transform the searched album title into a possible found album title match... (0, requires a perfect match) lidarrSearchForMissing="true" # true = enabled :: When artists are added, search for them using Lidarr's built in functionality retryNotFound="90" ## :: Number of days between re-attempting the download of previously notfound albums +notFoundYoutubeFallback="false" # true = enabled :: When the album is marked it not found, it will download the audio via YouTube (less acurate). It will continue trying to download via deezer/tidal. # CLIENT dlClientSource="deezer" # deezer, tidal or both :: set to both, to use both clients, tidal requires extra steps, view logging output From 93a951533711674f52f3c03c1f2cc00388589e65 Mon Sep 17 00:00:00 2001 From: Jasper Aelvoet <82276344+jasperaelvoet@users.noreply.github.com> Date: Wed, 16 Aug 2023 14:05:15 +0200 Subject: [PATCH 2/2] Replace musicbrainz with build in lidarr api --- lidarr/Audio.service.bash | 33 +++++++++++++++++++-------------- 1 file changed, 19 insertions(+), 14 deletions(-) diff --git a/lidarr/Audio.service.bash b/lidarr/Audio.service.bash index c7b8d58..8a3944a 100644 --- a/lidarr/Audio.service.bash +++ b/lidarr/Audio.service.bash @@ -1391,16 +1391,16 @@ SearchProcess () { if [ $notFoundYoutubeFallback == "true" ]; then log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: Falling back to YouTube" - query_param="release:${lidarrAlbumTitle} AND artist:${lidarrArtistName}&fmt=json" - album_id=$(curl --get --data-urlencode "query=${query_param}" --data-urlencode "fmt=json" "https://musicbrainz.org/ws/2/release/" | jq -r '.releases[0].id') - album_data=$(curl --get "https://musicbrainz.org/ws/2/release/${album_id}?inc=recordings&fmt=json") - tracks=$(jq -r '.media[0].tracks' <<< "$album_data" ) + lidarrAlbumData=$(curl -X GET "$arrUrl/api/v1/album/${checkLidarrAlbumId}" --header "X-Api-Key:"${arrApiKey} -H "Content-Type: application/json") + + lidarrAlbumId=$(jq -r '.releases[0].albumId' <<< "$lidarrAlbumData") + tracks=$(curl -X GET "$arrUrl/api/v1/track?albumId=${lidarrAlbumId}" --header "X-Api-Key:"${arrApiKey} -H "Content-Type: application/json") downloadedAlbumTitleClean="$(echo "$4" | sed -e "s%[^[:alpha:][:digit:]._' ]% %g" -e "s/ */ /g" | sed 's/^[.]*//' | sed 's/[.]*$//g' | sed 's/^ *//g' | sed 's/ *$//g')" downloadedAlbumFolder="$lidarrArtistNameSanitized-$downloadedAlbumTitleClean ($3)-${albumquality^^}-$1-$2" - if [[ -z $album_id ]]; then - echo "Album not found on MusicBrainz." + if [[ -z $lidarrAlbumId ]]; then + echo "Album not found on Lidarr." else if [ -d "/temp-yt-dl" ]; then rm -rf "/temp-yt-dl" @@ -1408,13 +1408,18 @@ SearchProcess () { mkdir -p /temp-yt-dl/ chmod 777 -R /temp-yt-dl/ - chomd 777 -R "${audioPath}/incomplete/" - - jq -c '.[]' <<< "$tracks" | while read track; do - track_title=$(jq -r '.title' <<< "$track") - track_id=$(jq -r '.id' <<< "$track") - yt-dlp --audio-quality highest --audio-format aac -o "/temp-yt-dl/${track_id}" -x "ytsearch:${lidarrArtistName} - ${track_title} (Audio)" - ffmpeg -i "/temp-yt-dl/${track_id}.m4a" -metadata title="${track_title}" -metadata artist="${lidarrArtistName}" -metadata album="${lidarrAlbumTitle}" "${audioPath}/incomplete/${track_id}.m4a" + chmod 777 -R "${audioPath}/incomplete/" + + trackLength=$(echo $tracks | jq length) + trackLength=$((trackLength-1)) + for i in `seq 0 $trackLength` + do + trackTitle=$(jq -r ".[$i].title" <<< "$tracks") + trackId=$(jq -r ".[$i].foreignTrackId" <<< "$tracks") + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: $trackTitle :: Downloading from YouTube" + yt-dlp -q --audio-quality highest --audio-format aac -o "/temp-yt-dl/${trackId}" -x "ytsearch:${lidarrArtistName} - ${trackTitle} (Audio)" + log "$page :: $wantedAlbumListSource :: $processNumber of $wantedListAlbumTotal :: $lidarrArtistName :: $lidarrAlbumTitle :: $lidarrAlbumType :: $trackTitle :: Adding metadata" + ffmpeg -hide_banner -loglevel error -i "/temp-yt-dl/${trackId}.m4a" -metadata title="${trackTitle}" -metadata artist="${lidarrArtistName}" -metadata album="${lidarrAlbumTitle}" "${audioPath}/incomplete/${trackId}.m4a" done if [ -d "/temp-yt-dl" ]; then @@ -2056,4 +2061,4 @@ for (( ; ; )); do sleep $audioScriptInterval done -exit +exit \ No newline at end of file