2014-07-27 19:48:56 +02:00
|
|
|
# TODO: Umlaute werden beim Download der xml über alle serien nicht richtig übergeben. evtl mit %-Code arbeiten
|
2014-07-27 02:59:45 +02:00
|
|
|
|
2014-07-27 19:48:56 +02:00
|
|
|
### CONFIG ###
|
2014-07-27 02:59:45 +02:00
|
|
|
apikey="2C9BB45EFB08AD3B"
|
|
|
|
productname="SaneRename for OTR (ALPHA) v0.2"
|
|
|
|
|
2014-07-27 19:48:56 +02:00
|
|
|
function eecho {
|
|
|
|
if [ -z "$silent" ]; then
|
|
|
|
echo "$1" "$2" "$3"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
### Check input ###
|
|
|
|
while getopts "f:l:s" optval; do
|
|
|
|
case $optval in
|
|
|
|
"f")
|
|
|
|
path=$OPTARG;;
|
|
|
|
"s")
|
|
|
|
silent=1;;
|
|
|
|
"l")
|
|
|
|
lang="$OPTARG";;
|
|
|
|
"?")
|
2014-07-29 10:28:45 +02:00
|
|
|
echo "Usage: $0 -f pathToAvi [-s] [-l LANG]"
|
|
|
|
exit;;
|
2014-07-27 19:48:56 +02:00
|
|
|
":")
|
2014-07-29 10:28:45 +02:00
|
|
|
echo "No argument value for option $OPTARG"
|
|
|
|
exit;;
|
2014-07-27 19:48:56 +02:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
eecho " :: $productname"
|
|
|
|
eecho " :: by Leroy Foerster"
|
|
|
|
eecho
|
|
|
|
|
|
|
|
|
|
|
|
if [ -z "$path" ]; then
|
|
|
|
echo "Usage: $0 -f pathToAvi [-s] [-l LANG]"
|
2014-07-29 10:28:45 +02:00
|
|
|
exit
|
2014-07-27 02:59:45 +02:00
|
|
|
fi
|
|
|
|
|
2014-07-27 19:48:56 +02:00
|
|
|
case "$lang" in
|
|
|
|
de*)
|
|
|
|
lang="de";;
|
|
|
|
en*)
|
|
|
|
lang="en";;
|
|
|
|
us*)
|
|
|
|
lang="en";;
|
|
|
|
fr*)
|
|
|
|
lang="fr";;
|
|
|
|
"")
|
|
|
|
lang="de";;
|
|
|
|
*)
|
|
|
|
echo "Language not recognized: $lang"
|
|
|
|
exit 11;;
|
|
|
|
esac
|
|
|
|
|
2014-07-29 10:34:05 +02:00
|
|
|
PwD=$(readlink -e $0)
|
|
|
|
PwD=$(dirname "$PwD")
|
2014-07-27 02:59:45 +02:00
|
|
|
|
2014-07-27 19:48:56 +02:00
|
|
|
file_name="$(basename $path)"
|
|
|
|
file_suffix="${file_name##*.}"
|
|
|
|
file_dir="$(dirname $path)"
|
|
|
|
|
|
|
|
if [ ! -f "$path" ]; then
|
|
|
|
echo "This is no file!"
|
|
|
|
echo "$path"
|
|
|
|
exit 10
|
|
|
|
fi
|
|
|
|
|
2014-07-27 02:59:45 +02:00
|
|
|
|
|
|
|
# Split filename into fields, divided by _ (underscores)
|
|
|
|
|
2014-07-27 19:48:56 +02:00
|
|
|
fields="${file_name//_/ }"
|
2014-07-27 02:59:45 +02:00
|
|
|
|
|
|
|
# If first field is a number (cutlist id)
|
|
|
|
firstField="${fields%% *}"
|
|
|
|
test $firstField -eq 0 2>/dev/null
|
|
|
|
if [ $? -ne 2 ]; then
|
|
|
|
fields=${fields##$firstField }
|
|
|
|
fi
|
|
|
|
|
|
|
|
fieldsTitle=${fields%% [0-9][0-9].*} # Cut off everything after the title: date, hour, sender, ...
|
|
|
|
fieldsSender=${fields##*-[0-9][0-9]} # Cut off everything bevor the sender: title, date, time, ...
|
|
|
|
|
|
|
|
fieldsDate=${fields%%$fieldsSender} # Cut off the sender
|
|
|
|
fieldsDate=${fieldsDate##$fieldsTitle } # Cut off the title, now we do have the date and time
|
|
|
|
fieldsTime=${fieldsDate##* }
|
|
|
|
fieldsDate=${fieldsDate%% *}
|
|
|
|
|
|
|
|
fieldsDateInv=$(date +%d.%m.%Y --date="${fieldsDate//./-}") # Convert YY.MM.DD to DD.MM.YY
|
|
|
|
fieldsTime=${fieldsTime/-/:} # Convert HH-MM to HH:MM
|
|
|
|
|
|
|
|
fieldsTitle=${fieldsTitle// s /\'s } # Replace a single s with 's
|
|
|
|
if [ "$lang" == "de" ]; then
|
|
|
|
fieldsTitle=${fieldsTitle//Ae/Ä} # Replace Umlauts
|
|
|
|
fieldsTitle=${fieldsTitle//Oe/Ö}
|
|
|
|
fieldsTitle=${fieldsTitle//Ue/Ü}
|
|
|
|
fieldsTitle=${fieldsTitle//ae/ä}
|
|
|
|
fieldsTitle=${fieldsTitle//oe/ö}
|
|
|
|
fieldsTitle=${fieldsTitle//ue/ü}
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
2014-07-29 10:34:05 +02:00
|
|
|
eecho -e " Work dir:\t$PwD"
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho -e " Datum:\t$fieldsDateInv"
|
|
|
|
eecho -e " Uhrzeit:\t$fieldsTime"
|
|
|
|
eecho -e " Titel:\t$fieldsTitle"
|
2014-07-27 02:59:45 +02:00
|
|
|
|
2014-07-29 10:45:19 +02:00
|
|
|
if [ -f "$PwD/series.cache" ]; then # Search the series cache
|
|
|
|
series_id=$(grep "$series_title" "$PwD/series.cache");
|
2014-07-27 02:59:45 +02:00
|
|
|
fi
|
2014-07-29 10:45:19 +02:00
|
|
|
if [ -n "$series_id" ]; then # And get the TvDB series ID from there
|
|
|
|
series_title=${series_id%|#|*}
|
|
|
|
series_id=${series_id#*|#|}
|
|
|
|
eecho -e " Cache:\tSeries found.\tID: $series_id"
|
|
|
|
else # Otherwise ask TvDB whether they do know the series
|
|
|
|
# ------------ Series ID abrufen anhand vom Titel der Serie -------------------- ;;
|
|
|
|
series_db="https://www.thetvdb.com/api/GetSeries.php?seriesname=$fieldsTitle&language=$lang"
|
|
|
|
wget "$series_db" -O "$PwD/series.xml" -o /dev/null
|
|
|
|
error=$?
|
|
|
|
if [ $error -ne 0 ]; then
|
|
|
|
eecho "Downloading $series_db failed (Exit code: $error)!"
|
|
|
|
exit 2
|
|
|
|
fi
|
|
|
|
|
|
|
|
series_id=$(grep -m 1 "seriesid" "$PwD/series.xml") # Get series id (needed later)
|
|
|
|
if [ -z "$series_id" ]; then
|
|
|
|
eecho -e " TVDB:\tSeries NOT found!"
|
|
|
|
exit 3
|
|
|
|
fi
|
|
|
|
|
|
|
|
series_title=$(grep -m 1 "SeriesName" "$PwD/series.xml") # Get series name from TvDB (for user)
|
|
|
|
series_alias=$(grep -m 1 "AliasName" "$PwD/series.xml")
|
|
|
|
series_id=${series_id%<*} # Remove XML tags
|
|
|
|
series_id=${series_id#*>}
|
|
|
|
series_title=${series_title%<*}
|
|
|
|
series_title=${series_title#*>}
|
|
|
|
series_alias=${series_alias%<*}
|
|
|
|
series_alias=${series_alias#*>}
|
|
|
|
|
2014-07-29 10:49:08 +02:00
|
|
|
echo "$series_title|#|$series_id" >> "$PwD/series.cache"
|
2014-07-29 10:45:19 +02:00
|
|
|
eecho -e " TVDB:\tSeries found.\tID: $series_id"
|
2014-07-27 02:59:45 +02:00
|
|
|
fi
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho -e "\t\t\t\tName: $series_title"
|
2014-07-27 02:59:45 +02:00
|
|
|
if [ -n "$series_alias" ]; then
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho -e "\t\t\t\tAlias: $series_alias"
|
2014-07-27 02:59:45 +02:00
|
|
|
fi
|
|
|
|
|
2014-07-29 10:45:19 +02:00
|
|
|
|
2014-07-27 02:59:45 +02:00
|
|
|
# ------------ EPG vom jeweiligen Tag herunterladen, durchsuchen anhand der Ausstrahlungszeit ------------- ;;
|
|
|
|
# Download OTR EPG data and search for series and time
|
2014-07-29 10:49:08 +02:00
|
|
|
if [ ! -f "$PwD/epg-$fieldsDate.csv" ]; then # didnt cache this file
|
2014-07-29 10:34:05 +02:00
|
|
|
rm -f ${PwD// /\\ }/epg-*.csv 2> /dev/null
|
2014-07-29 10:49:08 +02:00
|
|
|
epg_csv="https://www.onlinetvrecorder.com/epg/csv/epg_20${fieldsDate//./_}.csv"
|
|
|
|
wget "$epg_csv" -O "$PwD/epg-$fieldsDate.csv" -o /dev/null
|
2014-07-27 02:59:45 +02:00
|
|
|
error=$?
|
|
|
|
if [ $error -ne 0 ]; then
|
2014-07-29 10:49:08 +02:00
|
|
|
eecho "Downloading $epg_csv failed (Exit code: $error)!"
|
2014-07-27 02:59:45 +02:00
|
|
|
exit 4
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2014-07-29 10:34:05 +02:00
|
|
|
epg="$(grep "$series_title" "$PwD/epg-$fieldsDate.csv" | grep "$fieldsTime")"
|
2014-07-27 02:59:45 +02:00
|
|
|
if [ -z "$epg" ]; then
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho " EPG:\tSeries not found in EPG data"
|
2014-07-27 02:59:45 +02:00
|
|
|
exit 5
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# Parse EPG data
|
|
|
|
OLDIFS=$IFS
|
|
|
|
IFS=";"
|
|
|
|
read epg_id epg_start epg_end epg_duration epg_sender epg_title epg_type epg_text epg_genre epg_fsk epg_language epg_weekday epg_additional epg_rpt epg_downloadlink epg_infolink epg_programlink <<< "$epg"
|
|
|
|
IFS=$OLDIFS
|
|
|
|
|
|
|
|
|
|
|
|
episode_title="${epg_text%%.*}" # Text begins with episode title
|
|
|
|
if [ -z "$episode_title" ]; then
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho " EPG:\tNo Episode title found"
|
2014-07-27 02:59:45 +02:00
|
|
|
exit 5
|
|
|
|
fi
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho -e " EPG:\tEpisode title:\t$episode_title"
|
2014-07-27 02:59:45 +02:00
|
|
|
|
|
|
|
|
|
|
|
# Download Episode list of series
|
|
|
|
episode_db="https://www.thetvdb.com/api/$apikey/series/$series_id/all/$lang.xml"
|
2014-07-29 10:34:05 +02:00
|
|
|
wget $episode_db -O "$PwD/episodes.xml" -o /dev/null
|
2014-07-27 02:59:45 +02:00
|
|
|
error=$?
|
|
|
|
if [ $error -ne 0 ]; then
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho "Downloading $episode_db failed (Exit code: $error)!"
|
2014-07-27 02:59:45 +02:00
|
|
|
exit 6
|
|
|
|
fi
|
|
|
|
|
2014-07-29 10:28:45 +02:00
|
|
|
while true; do
|
2014-07-29 10:34:05 +02:00
|
|
|
episode_info=$(grep "$episode_title" "$PwD/episodes.xml" -B 10) # Get XML data of episode
|
2014-07-29 10:28:45 +02:00
|
|
|
if [ -z "$episode_info" ]; then
|
|
|
|
episode_title=${episode_title% *}
|
|
|
|
eecho -e " EPG:\tEpisode title:\t$episode_title"
|
|
|
|
else
|
|
|
|
break;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if [ -z "$episode_info" ]; then
|
|
|
|
echo "No episode info found"
|
|
|
|
exit 13
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-07-27 02:59:45 +02:00
|
|
|
episode_number=$(echo -e "$episode_info" | grep -m 1 "episodenumber") # Get episode number
|
|
|
|
episode_season=$(echo -e "$episode_info" | grep -m 1 "season") # Get season number
|
|
|
|
episode_number=${episode_number%<*} # remove xml tags
|
|
|
|
episode_number=${episode_number#*>}
|
|
|
|
episode_season=${episode_season%<*}
|
|
|
|
episode_season=${episode_season#*>}
|
|
|
|
|
|
|
|
# add leading zero
|
|
|
|
if [ $episode_number -le 9 ]; then
|
|
|
|
episode_number="0$episode_number"
|
|
|
|
fi
|
|
|
|
if [ $episode_season -le 9 ]; then
|
|
|
|
episode_season="0$episode_season"
|
|
|
|
fi
|
|
|
|
|
2014-07-27 19:48:56 +02:00
|
|
|
eecho -e " TvDB: Season:\t$episode_season"
|
|
|
|
eecho -e " Episode:\t$episode_number"
|
2014-07-27 02:59:45 +02:00
|
|
|
|
2014-07-27 19:48:56 +02:00
|
|
|
echo "${series_title// /.}..S${episode_season}E${episode_number}..${episode_title// /.}.$file_suffix"
|