10 Commits
1.3 ... 1.7

Author SHA1 Message Date
d7100267ce version bump 2024-06-14 21:32:30 +02:00
4c08363b7f use one type of execute
replaced ` by $()
2024-06-14 21:29:15 +02:00
d975e38ef3 add preselection of last selected item #1 2024-06-14 21:25:04 +02:00
a3c476ca20 clear screen on cancel 2024-04-28 21:42:52 +02:00
db7f539bd1 version bump 2023-12-17 20:58:13 +01:00
0c1c0d4788 set custom text by using ~ (tilde) in filename
foo~bar@example.org will show "foo" in s3h and connect to
"bar@example.org"
2023-12-17 20:56:55 +01:00
53212b705a ~/.s3h might be a symlink 2023-10-09 19:46:27 +02:00
453a453f4f version bump 2023-09-16 22:07:39 +02:00
31b5e29c69 echo ssh command 2023-09-16 22:03:41 +02:00
8b10b4b709 stable build uses s3h.sh version no 2023-09-16 22:01:07 +02:00
3 changed files with 50 additions and 9 deletions

View File

@ -2,10 +2,15 @@
NAME=s3h
VERSION=1.2
VERSION=`../../s3h.sh -v`
REVISION=1
ARCH=all
if ! git tag -l |fgrep $VERSION; then
git tag $VERSION
git push origin $VERSION
fi
curdir=`dirname $0`
workdir="$curdir/${NAME}_${VERSION}-${REVISION}_${ARCH}"
mkdir -p "$workdir"

52
s3h.sh
View File

@ -2,8 +2,8 @@
# config
DIALOG=dialog #gdialog kdialog
START_DIR='~/.s3h'
VERSION="1.3"
START_DIR="$HOME/.s3h"
VERSION="1.7"
# TODO: use opt parsing
if [[ $# -eq 1 && "$1" == "-v" ]]; then
@ -15,6 +15,8 @@ if [[ $# -eq 1 && -d "$1" ]]; then
START_DIR="$1"
fi
START_DIR=$(realpath "$START_DIR")
if [[ ! -d "$START_DIR" ]]; then
echo "start directory '$START_DIR' does not exist" >&2
echo -e "either create or set 'start directory' parameter\n" >&2
@ -22,6 +24,19 @@ if [[ ! -d "$START_DIR" ]]; then
exit 2
fi
LAST="$START_DIR/.last"
# check if there was a last call, if so fake while loop variable
preselect=''
if [[ -f "$LAST" ]]; then
last=$(cat "$LAST")
# check if config file still exists
if [[ -f "$last" ]]; then
dir=$(dirname "$last")
preselect=$(basename "$last")
fi
fi
# select config file
configFile=''
while [[ -z "$configFile" ]]; do
@ -38,14 +53,20 @@ while [[ -z "$configFile" ]]; do
fi
# add directory selectors
dirs=`find $dir -mindepth 1 -maxdepth 1 ! -name '.*' -type d -printf "%f\n" |sort`
dirs=$(find $dir -mindepth 1 -maxdepth 1 ! -name '.*' -type d -printf "%f\n" |sort)
for d in $dirs; do
para+=("$d" "<$d>")
done
# add file selectors
files=`find $dir -mindepth 1 -maxdepth 1 ! -name '.*' -type f -printf "%f\n" |sort`
files=$(find $dir -mindepth 1 -maxdepth 1 ! -name '.*' -type f -printf "%f\n" |sort)
for d in $files; do
# text before ~ is tag
if [[ "$d" == *"~"* ]]; then
tag="${d%%~*}"
para+=("$d" "$tag")
else
para+=("$d" "$d")
fi
done
if [[ ${#para[@]} -eq 0 ]]; then
@ -57,8 +78,13 @@ while [[ -z "$configFile" ]]; do
fi
# run dialog
ret=$("$DIALOG" --no-tags --stdout --menu "select connection" 0 0 0 ${para[@]} 2>&1)
dialogOptions=''
if [[ ! -z "$preselect" ]]; then
dialogOptions="$dialogOptions --default-item $preselect"
fi
ret=$("$DIALOG" --no-tags --stdout $dialogOptions --menu "select connection" 0 0 0 ${para[@]} 2>&1)
if [[ $? -ne 0 ]]; then
clear
exit 1
fi
@ -71,7 +97,7 @@ while [[ -z "$configFile" ]]; do
configFile=$ret
fi
else
dir=`dirname "$dir"`
dir=$(dirname "$dir")
fi
done
@ -95,6 +121,16 @@ if [[ -f "$configFile" ]]; then
# clear screen // remove dialog colors
echo "config file '$configFile' selected. connecting..."
# execute ssh
ssh ${para[@]} `basename "$configFile"`
# save selected configFile for next call of s3h
echo "$configFile" > "$LAST"
# extract user@host if ~ in config file name
login=$(basename "$configFile")
if [[ "$login" == *"~"* ]]; then
login="${login#*~}"
fi
# execute ssh
echo "Running 'ssh ${para[@]} $login'"
ssh ${para[@]} "$login"
fi

View File