#!/usr/bin/env bash fileName="rusefi_$SHORT_BOARD_NAME.ini" USER=$1 PASS=$2 HOST=$3 SCRIPT_NAME=$(basename "$0") if [ ! "$SHORT_BOARD_NAME" ]; then echo "No SHORT_BOARD_NAME" exit 1 fi if [ ! "$USER" ] || [ ! "$PASS" ] || [ ! "$HOST" ]; then echo "upload_ini.sh says No Secrets, exiting" exit 0 fi pwd echo -e "\nUploading all .ini files into [$INI_DESTINATION_FOLDER] subfolder" ls -l . if [ "$fileName" == "no" ]; then echo "[upload_ini] signature file not needed" exit 0 fi echo "[upload_ini] Looking for signature in [$fileName]..." sig=$(grep "^\s*signature\s*=" $fileName | cut -f2 -d "=") if [ ! -z "$sig" -a "$sig" != " " ]; then echo "* found signature: $sig" if [[ "$sig" =~ rusEFI\ ([a-zA-Z0-9_-]+)\.([0-9]{4})\.([0-9]{2})\.([0-9]{2})\.([a-zA-Z0-9_-]+)\.([a-zA-Z0-9_-]+) ]]; then branch=${BASH_REMATCH[1]} year=${BASH_REMATCH[2]} month=${BASH_REMATCH[3]} day=${BASH_REMATCH[4]} board=${BASH_REMATCH[5]} hash=${BASH_REMATCH[6]} path="$branch/$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 $PASS sftp -o StrictHostKeyChecking=no ${USER}@${HOST} <