181 lines
5.3 KiB
Bash
Executable File
181 lines
5.3 KiB
Bash
Executable File
#!/bin/bash
|
|
# @author 6543
|
|
# @version 0.1
|
|
# @date 2019-02-07
|
|
|
|
## Options/Parameter
|
|
# $1:
|
|
# -a | add files of md5-file to db
|
|
# -r | remove files of md5-file from db
|
|
# -d | mark files from md5-file ad deleted
|
|
# -ee | export md5 of existing files
|
|
# -ed | export md5 of deleted fiels
|
|
#
|
|
# $2: <paht of md5-file>
|
|
# [$3]: <path to movie folder>
|
|
|
|
{ #set enviroemnt
|
|
readonly TRUE=1 #like <stdbool.h>
|
|
readonly FALSE=0 #like <stdbool.h>
|
|
readonly TTSYNC_EXIST=0
|
|
readonly TTSYNC_BACKUP=1
|
|
readonly TTSYNC_REMOTE=2
|
|
readonly TTSYNC_DEL=3
|
|
readonly globalconf="/etc/tt/global"
|
|
}
|
|
|
|
{ #get options & args
|
|
readonly mode=$(echo $1 | tr -d '-')
|
|
readonly md5="$2"
|
|
moviedir="$3"
|
|
}
|
|
|
|
{ #db
|
|
dbname="tt_test"
|
|
dbhost="localhost"
|
|
dbuser="root"
|
|
dbpwd=""
|
|
}
|
|
|
|
function help() {
|
|
#help menue
|
|
echo "$0 is part of the TerabyteTerminator Project"
|
|
echo ""
|
|
echo "import-md5-list <mode> <md5-file> [moviedir]"
|
|
echo " modes:"
|
|
echo " -a add files of md5-file to db"
|
|
echo " -r remove files of md5-file from db"
|
|
echo " -d mark files from md5-file ad deleted"
|
|
echo " -ee export md5 of existing files"
|
|
echo " -ed export md5 of deleted fiels"
|
|
echo ""
|
|
echo " moviedir: Is optional if it is already in the global config"
|
|
|
|
exit 0
|
|
}
|
|
if [ "$mode" == "help" ] && help
|
|
|
|
##check & prepair args
|
|
[ ${mode:0:1} == "e" ] && touch "$md5"
|
|
[ -f "$md5" ] || { echo "md5 \"$md5\" do not exist"; exit 1; } # check md5
|
|
[ -z "$moviedir" ] && [ -f "$globalconf" ] && { # if (no argument) and (globalconf exist)
|
|
if [ -z "$(grep "moviedir=" "$globalconf" )" ]; then # and (moviedir is NOT in globalconf)
|
|
echo 'neither "movie folder" is set in global config nor given as argument'
|
|
exit 2
|
|
else # and (moviedir is in globalconf)
|
|
moviedir="$(grep "moviedir=" "$globalconf" | cut -d '=' -f 2)"
|
|
fi
|
|
}
|
|
[ -d "$moviedir" ] || { echo "moviedir \"$moviedir\" do not exist"; exit 3; } # check moviedir
|
|
moviedir=""$(echo $moviedir | sed 's|/$||g')""
|
|
[ -z "$moviedir" ] && exit 255 #catch case moviedir="/"
|
|
|
|
## functions
|
|
function md5_in_add() {
|
|
cat $md5 | while read line; do #for each line in md5
|
|
local md5=$(echo $line | cut -c -32)
|
|
local path=$(echo $line | cut -c 33- | sed 's/^\ //g')
|
|
local relrevpath=$(echo $path | sed "s|^$moviedir||g" | sed 's|^/||g' | sed 's|/$||g' | rev)
|
|
local name=$(echo $relrevpath | cut -d '/' -f 1 | rev)
|
|
local folder=$(echo $relrevpath | cut -d '/' -f 2- | rev)
|
|
[ "$(db_query "SELECT COUNT(ID) FROM File WHERE MD5='$md5' AND Folder='$folder' AND Name='$name';")" == "0" ] && { #wenn KEIN gleicher Eintrag Vorhanden
|
|
db_query "INSERT INTO File (MD5, Folder, Name, TTSync) VALUES ('$md5', '$folder', '$name', $TTSYNC_EXIST );" #-> handle in future: ";'()"
|
|
}
|
|
done
|
|
|
|
exit 0
|
|
}
|
|
|
|
function md5_rm() {
|
|
cat $md5 | while read line; do #for each line in md5
|
|
local md5=$(echo $line | cut -c -32)
|
|
local path=$(echo $line | cut -c 33- | sed 's/^\ //g')
|
|
local relrevpath=$(echo $path | sed "s|^$moviedir||g" | sed 's|^/||g' | sed 's|/$||g' | rev)
|
|
local name=$(echo $relrevpath | cut -d '/' -f 1 | rev)
|
|
local folder=$(echo $relrevpath | cut -d '/' -f 2- | rev)
|
|
db_query "DELETE FROM File WHERE MD5='$md5' AND Folder='$folder' AND Name='$name';" #-> handle in future: ";'()"
|
|
done
|
|
|
|
exit 0
|
|
}
|
|
|
|
function md5_in_del() {
|
|
cat $md5 | while read line; do #for each line in md5
|
|
local md5=$(echo $line | cut -c -32)
|
|
local path=$(echo $line | cut -c 33- | sed 's/^\ //g')
|
|
local relrevpath=$(echo $path | sed "s|^$moviedir||g" | sed 's|^/||g' | sed 's|/$||g' | rev)
|
|
local name=$(echo $relrevpath | cut -d '/' -f 1 | rev)
|
|
local folder=$(echo $relrevpath | cut -d '/' -f 2- | rev)
|
|
|
|
if [ "$(db_query "SELECT COUNT(ID) FROM File WHERE MD5='$md5' AND Folder='$folder' AND Name='$name';")" -gt "0" ]; then #wenn gleicher Eintrag Vorhanden
|
|
db_query "UPDATE File SET TTSync=$TTSYNC_DEL WHERE MD5='$md5' AND Folder='$folder' AND Name='$name';" #-> handle in future: ";'()"
|
|
else #Ansonsten Erstelle Del eintrag
|
|
db_query "INSERT INTO File (MD5, Folder, Name, TTSync) VALUES ('$md5', '$folder', '$name', $TTSYNC_DEL );" #-> handle in future: ";'()"
|
|
fi
|
|
done
|
|
|
|
exit 0
|
|
}
|
|
|
|
function md5_out_exist() {
|
|
db_query "SELECT CONCAT(MD5, ' ', ' ' ,'$moviedir/', Folder, '/', Name) FROM File WHERE TTSync=$TTSYNC_EXIST OR TTSync=$TTSYNC_BACKUP;" >> $md5
|
|
exit 0
|
|
}
|
|
|
|
function md5_out_del() {
|
|
db_query "SELECT CONCAT(MD5, ' ', ' ' ,'$moviedir/', Folder, '/', Name) FROM File WHERE TTSync=$TTSYNC_DEL;" >> $md5
|
|
exit 0
|
|
}
|
|
|
|
# help functions
|
|
|
|
# db_query <query> -> result
|
|
function db_query() {
|
|
local args="-sN" #no headers, no grid
|
|
args+=" -h$dbhost"
|
|
args+=" -u$dbuser"
|
|
[ -n "$dbpwd" ] && args+=" -p$dbpwd"
|
|
args+=" $dbname"
|
|
echo $@ | mysql $args
|
|
}
|
|
|
|
# db_exist_md5 <md5> -> true/false 0/1
|
|
function db_exist_md5() {
|
|
result=($(db_query "SELECT COUNT(md5) FROM File WHERE File.MD5 LIKE '$1';"))
|
|
if [ "${result[2]}" -gt "0" ]; then
|
|
echo true
|
|
return $TRUE
|
|
else
|
|
echo false
|
|
return $FALSE
|
|
fi
|
|
}
|
|
|
|
# db_F-ID_getPath <F-ID> -> <Path>
|
|
function db_id_getPath() {
|
|
db_query "SELECT CONCAT('$moviedir/', Folder, '/', Name) FROM File WHERE ID=$1;"
|
|
}
|
|
|
|
case "$mode" in
|
|
"a") #in_add
|
|
md5_in_add
|
|
;;
|
|
"r") #rm
|
|
md5_rm
|
|
;;
|
|
"d")
|
|
md5_in_del
|
|
;;
|
|
"ee" | "e" )
|
|
md5_out_exist
|
|
;;
|
|
"ed" )
|
|
md5_out_exist
|
|
;;
|
|
*)
|
|
echo "wrong arguments"
|
|
echo ""
|
|
help
|
|
;;
|
|
esac
|