50 lines
1.1 KiB
Bash
Executable File
50 lines
1.1 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# user=$1
|
|
# pass=$2
|
|
# host=$3
|
|
|
|
if [ ! "$1" ] || [ ! "$2" ] || [ ! "$3" ]; then
|
|
echo "No Secrets"
|
|
exit 0
|
|
fi
|
|
|
|
pwd
|
|
echo -e "\nUploading .ini files"
|
|
ls -l .
|
|
|
|
for f in *.ini; do if [[ -f "$f" ]]; then
|
|
echo "Processing file $f:"
|
|
sig=$(grep "^ *signature *=" $f | cut -f2 -d "=")
|
|
if [ ! -z "$sig" -a "$sig" != " " ]; then
|
|
echo "* found signature: $sig"
|
|
if [[ "$sig" =~ rusEFI.*([0-9]{4})\.([0-9]{2})\.([0-9]{2})\.([a-zA-Z0-9_-]+)\.([0-9]+) ]]; then
|
|
year=${BASH_REMATCH[1]}
|
|
month=${BASH_REMATCH[2]}
|
|
day=${BASH_REMATCH[3]}
|
|
board=${BASH_REMATCH[4]}
|
|
hash=${BASH_REMATCH[5]}
|
|
path="$year/$month/$day/$board/$hash.ini"
|
|
echo "* found path: $path"
|
|
# we do not have ssh for this user
|
|
# sftp does not support -p flag on mkdir :(
|
|
sshpass -p $2 sftp -o StrictHostKeyChecking=no $1@$3 <<SSHCMD
|
|
cd rusefi
|
|
mkdir $year
|
|
mkdir $year/$month
|
|
mkdir $year/$month/$day
|
|
mkdir $year/$month/$day/$board
|
|
put $f $path
|
|
SSHCMD
|
|
retVal=$?
|
|
if [ $retVal -ne 0 ]; then
|
|
echo "Upload failed"
|
|
exit 1
|
|
fi
|
|
echo "* upload done!"
|
|
else
|
|
echo "Unexpected $sig"
|
|
fi
|
|
fi
|
|
fi; done
|