2022-03-04 04:26:39 +00:00
|
|
|
#!/usr/bin/env bash
|
2022-03-04 06:27:44 +00:00
|
|
|
log_file=/var/log/hash-files.log
|
2022-03-22 04:18:08 +00:00
|
|
|
md5_bin=$(which md5sum)
|
|
|
|
mktemp_bin=$(which mktemp)
|
2022-03-04 06:27:44 +00:00
|
|
|
DateTimeStamp=$(date +\%D_\%T)
|
|
|
|
|
2022-03-04 04:26:39 +00:00
|
|
|
set -a
|
|
|
|
source .env 2>&1 > /dev/null
|
|
|
|
set +a
|
|
|
|
|
|
|
|
## Functions
|
|
|
|
############
|
|
|
|
|
|
|
|
write_log () {
|
2022-03-04 05:20:25 +00:00
|
|
|
#echo " ++ Write to log.
|
|
|
|
# +++++++++++++++"
|
2022-03-04 05:30:06 +00:00
|
|
|
## Use on systems managed with systemd
|
|
|
|
# printf 'hash-files: %s\n' "$1" | systemd-cat
|
|
|
|
printf '%s hash-files: %s\n' "$DateTimeStamp" "$1" >> $log_file
|
2022-03-04 04:26:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
create_list_of_files () {
|
2022-03-04 05:07:11 +00:00
|
|
|
#echo "=== Get list of files in $Working_Directory. ===
|
|
|
|
#=================================================="
|
2022-03-04 05:16:40 +00:00
|
|
|
IFS=$'\n'
|
|
|
|
for file in $(find $Working_Fullpath -maxdepth 1 -type f); do
|
|
|
|
list_of_files+=( $file )
|
|
|
|
done
|
|
|
|
write_log "List of files created successfully."
|
|
|
|
unset IFS
|
2022-03-04 04:26:39 +00:00
|
|
|
}
|
|
|
|
|
2022-03-21 23:50:31 +00:00
|
|
|
mdls_files () {
|
|
|
|
IFS=$'\n'
|
|
|
|
for file in $list_of_files; do
|
2022-03-26 17:55:59 +00:00
|
|
|
echo "=== mdls info ===
|
|
|
|
==========="
|
2022-03-26 17:57:45 +00:00
|
|
|
mdls $file
|
2022-03-21 23:50:31 +00:00
|
|
|
done
|
|
|
|
}
|
2022-03-04 04:26:39 +00:00
|
|
|
hash_files () {
|
2022-03-04 05:07:11 +00:00
|
|
|
#echo "=== Hash files. ===
|
|
|
|
#======================"
|
2022-03-04 05:16:40 +00:00
|
|
|
IFS=$'\n'
|
|
|
|
for file in ${list_of_files[@]}; do
|
2022-03-22 04:18:08 +00:00
|
|
|
hash=$($md5_bin $file | awk '{ print $1 }')
|
2022-03-04 05:16:40 +00:00
|
|
|
list_of_hashes+=( $hash )
|
|
|
|
done
|
|
|
|
write_log "Files hashed successfully."
|
|
|
|
unset IFS
|
2022-03-04 04:26:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
create_csv () {
|
2022-03-04 05:07:11 +00:00
|
|
|
#echo "=== Create array of comma-separated-values. ===
|
|
|
|
#=================================================="
|
|
|
|
for i in ${!list_of_files[@]}; do
|
|
|
|
csv_array+=( ${list_of_files[i]},${list_of_hashes[i]} )
|
|
|
|
done
|
|
|
|
export csv_array
|
2022-03-04 05:16:40 +00:00
|
|
|
write_log "CSV Array creation successful."
|
2022-03-04 04:26:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
write_data () {
|
2022-03-04 05:07:11 +00:00
|
|
|
#echo "=== Write data to a .csv file. ===
|
|
|
|
#===================================="
|
2022-03-22 04:18:08 +00:00
|
|
|
temp_csv_file=$($mktemp_bin)
|
2022-03-04 05:07:11 +00:00
|
|
|
printf '%s,%s\n' "File Path" "File Hash" >> $temp_csv_file
|
|
|
|
for line in ${csv_array[@]};do
|
|
|
|
printf '%s\n' $line
|
|
|
|
done >> $temp_csv_file
|
|
|
|
# cat $temp_csv_file
|
2022-03-04 05:16:40 +00:00
|
|
|
write_log "$temp_csv_file written successfully."
|
2022-03-04 04:26:39 +00:00
|
|
|
}
|
|
|
|
|
2022-03-04 04:37:15 +00:00
|
|
|
cleanup () {
|
2022-03-04 05:16:40 +00:00
|
|
|
write_log "Cleanup completed successfully."
|
2022-03-04 04:37:15 +00:00
|
|
|
}
|
|
|
|
|
2022-03-04 04:26:39 +00:00
|
|
|
## Main
|
|
|
|
#######
|
|
|
|
|
2022-03-04 04:37:15 +00:00
|
|
|
trap cleanup EXIT
|
|
|
|
|
2022-03-04 04:26:39 +00:00
|
|
|
echo "Main Start"
|
|
|
|
create_list_of_files
|
2022-03-21 23:50:31 +00:00
|
|
|
mdls_files
|
|
|
|
#hash_files
|
|
|
|
#if [ ${#list_of_files[@]} != ${#list_of_hashes[@]} ];then
|
|
|
|
# echo "Error! Number of files and hashes differs. Exiting..." && exit
|
|
|
|
#else
|
|
|
|
# create_csv
|
|
|
|
#fi
|
|
|
|
#write_data
|
2022-03-04 04:26:39 +00:00
|
|
|
|
|
|
|
#while $list_of_files >=1; do
|
|
|
|
#done
|
|
|
|
|
|
|
|
|