9 Commits
1.2 ... 1.5

Author SHA1 Message Date
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
aad26d3fdd add version + -v cli parameter 2023-09-16 21:53:58 +02:00
87a453c24c added quickstart instructions 2023-09-08 22:59:28 +02:00
19eef79c2d example global options file 2023-09-03 20:43:17 +02:00
5 changed files with 39 additions and 4 deletions

View File

@ -9,3 +9,10 @@ Select a ssh config file which will be used to connect to a host via - you guess
``` ```
Sample structure of `start directory` can be found in `test`. Sample structure of `start directory` can be found in `test`.
## Quickstart
```
mkdir ~/.s3h
touch root@example.org
./s3h.sh
```

View File

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

28
s3h.sh
View File

@ -2,12 +2,21 @@
# config # config
DIALOG=dialog #gdialog kdialog DIALOG=dialog #gdialog kdialog
START_DIR='~/.s3h' START_DIR="$HOME/.s3h"
VERSION="1.5"
# TODO: use opt parsing
if [[ $# -eq 1 && "$1" == "-v" ]]; then
echo "$VERSION"
exit 0
fi
if [[ $# -eq 1 && -d "$1" ]]; then if [[ $# -eq 1 && -d "$1" ]]; then
START_DIR="$1" START_DIR="$1"
fi fi
START_DIR=`realpath "$START_DIR"`
if [[ ! -d "$START_DIR" ]]; then if [[ ! -d "$START_DIR" ]]; then
echo "start directory '$START_DIR' does not exist" >&2 echo "start directory '$START_DIR' does not exist" >&2
echo -e "either create or set 'start directory' parameter\n" >&2 echo -e "either create or set 'start directory' parameter\n" >&2
@ -38,7 +47,13 @@ while [[ -z "$configFile" ]]; do
# add file selectors # 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 for d in $files; do
para+=("$d" "$d") # text before ~ is tag
if [[ "$d" == *"~"* ]]; then
tag="${d%%~*}"
para+=("$d" "$tag")
else
para+=("$d" "$d")
fi
done done
if [[ ${#para[@]} -eq 0 ]]; then if [[ ${#para[@]} -eq 0 ]]; then
@ -88,6 +103,13 @@ if [[ -f "$configFile" ]]; then
# clear screen // remove dialog colors # clear screen // remove dialog colors
echo "config file '$configFile' selected. connecting..." echo "config file '$configFile' selected. connecting..."
# extract user@host if ~ in config file name
login=`basename "$configFile"`
if [[ "$login" == *"~"* ]]; then
login="${login#*~}"
fi
# execute ssh # execute ssh
ssh ${para[@]} `basename "$configFile"` echo "Running 'ssh ${para[@]} $login'"
ssh ${para[@]} "$login"
fi fi

View File

1
test/foo11/.options Normal file
View File

@ -0,0 +1 @@
-o AddKeysToAgent=yes