blob: 5eec323ca12366a0da83d5ee943fae00949b927f (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
#!/usr/bin/env bash
#
# Wrapper around autossh and start-stop-daemon for basic persistence. Intended
# to be called as a script from profile.d for automatic SSH tunnels.
#
# Takes one required option -p, the autossh monitoring port number to use. Cut
# the options off with -- and the remainder of the arguments are passed to the
# autossh binary.
#
# $ psshd -p 9001 -- -fN -D 8001 remotehost
#
# @author Tom Ryder <tom@sanctum.geek.nz>
# @copyright 2013
#
# Path to autossh binary (not any wrapper script)
autossh='/usr/lib/autossh/autossh'
# Path to start-stop-daemon binary
startstopdaemon='/sbin/start-stop-daemon'
# Neither of those are likely to be in your PATH if you're a normal user, so we
# hardcode the paths and test for their existence
if [[ ! -x "$autossh" ]]; then
printf "Can't execute ${autossh}!\n" >&2
exit 1
elif [[ ! -x "$startstopdaemon" ]]; then
printf "Can't execute ${startstopdaemon}!\n" >&2
exit 1
fi
# Get port in options
while getopts ':p:' opt
do
case "$opt" in
p)
port="$OPTARG"
;;
\?)
printf "Invalid option $OPTARG\n" >&2
exit 1
;;
:)
printf "Option -$OPTARG requires an argument\n" >&2
exit 1
;;
esac
done
shift "$((OPTIND-1))"
# If no port, give up with usage instructions
if [[ ! -n "$port" ]]
then
printf "USAGE: $0 -p <port number> -- <ssh arguments>\n"
exit 1
fi
# Set up a PID dir
dir="${TMPDIR:-/tmp}/psshd-${UID}"
if ! mkdir -p "$dir"; then
printf "Couldn't create directory ${dir} for PID file\n" >&2
exit 1
fi
# Export the two settings autossh absolutely needs
AUTOSSH_PIDFILE="${dir}/psshd-port-${port}.pid"
AUTOSSH_PORT="$port"
export AUTOSSH_PIDFILE AUTOSSH_PORT
# Use start-stop-daemon to run it sanely
"$startstopdaemon" \
--start \
--quiet \
--pidfile "$AUTOSSH_PIDFILE" \
--exec "$autossh" \
-- "$@"
|