2023-09-07 14:34:05 +02:00
|
|
|
#!/usr/bin/env bash
|
2023-09-07 15:00:53 +02:00
|
|
|
scriptVersion="1.2"
|
2023-09-07 14:34:05 +02:00
|
|
|
scriptName="LyricExtractor"
|
|
|
|
|
|
|
|
#### Import Settings
|
|
|
|
source /config/extended.conf
|
|
|
|
#### Import Functions
|
|
|
|
source /config/extended/functions
|
|
|
|
#### Create Log File
|
|
|
|
logfileSetup
|
|
|
|
|
|
|
|
SECONDS=0
|
|
|
|
|
|
|
|
if [ "$lidarr_eventtype" == "Test" ]; then
|
|
|
|
log "Tested Successfully"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2023-09-07 15:00:53 +02:00
|
|
|
verifyConfig
|
|
|
|
getArrAppInfo
|
|
|
|
verifyApiAccess
|
|
|
|
|
|
|
|
if [ -z "$lidarr_album_id" ]; then
|
|
|
|
lidarr_album_id="$1"
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
getAlbumArtist="$(curl -s "$arrUrl/api/v1/album/$lidarr_album_id" -H "X-Api-Key: ${arrApiKey}" | jq -r .artist.artistName)"
|
|
|
|
getAlbumArtistPath="$(curl -s "$arrUrl/api/v1/album/$lidarr_album_id" -H "X-Api-Key: ${arrApiKey}" | jq -r .artist.path)"
|
|
|
|
getTrackPath="$(curl -s "$arrUrl/api/v1/trackFile?albumId=$lidarr_album_id" -H "X-Api-Key: ${arrApiKey}" | jq -r .[].path | head -n1)"
|
2023-09-07 14:34:05 +02:00
|
|
|
getFolderPath="$(dirname "$getTrackPath")"
|
2023-09-07 15:00:53 +02:00
|
|
|
getAlbumFolderName="$(basename "$getFolderPath")"
|
|
|
|
|
|
|
|
log "Processing :: $getAlbumFolderName :: Processing Files..."
|
2023-09-07 14:34:05 +02:00
|
|
|
|
|
|
|
if echo "$getFolderPath" | grep "$getAlbumArtistPath" | read; then
|
|
|
|
if [ ! -d "$getFolderPath" ]; then
|
|
|
|
log "ERROR :: \"$getFolderPath\" Folder is missing :: Exiting..."
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
log "ERROR :: $getAlbumArtistPath not found within \"$getFolderPath\" :: Exiting..."
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ls "$getFolderPath" | grep "lrc" | read; then
|
|
|
|
log "Processing :: $getAlbumFolderName :: Removing existing lrc files"
|
|
|
|
find "$getFolderPath" -type f -iname "*.lrc" -delete
|
|
|
|
fi
|
|
|
|
|
|
|
|
find "$getFolderPath" -type f -regex ".*/.*\.\(flac\|opus\|m4a\|mp3\)" -print0 | while IFS= read -r -d '' file; do
|
|
|
|
fileName=$(basename -- "$file")
|
|
|
|
fileExt="${fileName##*.}"
|
|
|
|
fileNameNoExt="${fileName%.*}"
|
|
|
|
|
|
|
|
if [ "$fileExt" == "flac" ]; then
|
|
|
|
log "Processing :: $getAlbumFolderName :: $fileName :: Getting Lyrics from embedded metadata"
|
|
|
|
getLyrics="$(ffprobe -loglevel 0 -print_format json -show_format -show_streams "$file" | jq -r ".format.tags.LYRICS" 2>/dev/null | sed "s/null//g" | sed "/^$/d")"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$fileExt" == "opus" ]; then
|
|
|
|
log "Processing :: $getAlbumFolderName :: $fileName :: Getting Lyrics from embedded metadata"
|
|
|
|
getLyrics="$(ffprobe -loglevel 0 -print_format json -show_format -show_streams "$file" | jq -r ".streams[].tags.LYRICS" 2>/dev/null | sed "s/null//g" | sed "/^$/d")"
|
2023-09-07 15:00:53 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -z "$getLyrics" ]; then
|
|
|
|
lrcFile="${file%.*}.lrc"
|
|
|
|
log "Processing :: $getAlbumFolderName :: $fileName :: Extracting Lyrics..."
|
|
|
|
echo -n "$getLyrics" > "$lrcFile"
|
|
|
|
log "Processing :: $getAlbumFolderName :: $fileName :: Lyrics extracted to: $fileNameNoExt.lrc"
|
|
|
|
chmod 666 "$lrcFile"
|
|
|
|
else
|
|
|
|
log "Processing :: $getAlbumFolderName :: $fileName :: Lyrics not found..."
|
|
|
|
fi
|
2023-09-07 14:34:05 +02:00
|
|
|
done
|
|
|
|
|
|
|
|
duration=$SECONDS
|
|
|
|
log "Processing :: $getAlbumFolderName :: Finished in $(($duration / 60 )) minutes and $(($duration % 60 )) seconds!"
|
|
|
|
exit
|