wok-next view dropbear/stuff/sshx @ rev 18015

dropbear: pppssh may use ssh keys
author Pascal Bellard <pascal.bellard@slitaz.org>
date Sat May 02 12:05:22 2015 +0200 (2015-05-02)
parents 31599711e814
children 56c606af68bc
line source
1 #!/bin/sh
3 xdbclient()
4 {
5 read host data
6 svr=${DISPLAY#*:}
7 n=$((10+($RANDOM % 90))); dpy=localhost:$n
8 scr=${DISPLAY/${DISPLAY%.*}/$dpy}
9 r=""
10 while true; do
11 a="$1"
12 r="$r $1"; shift
13 case "$a" in
14 -[piIlLRWKBJ]) r="$r $1"; shift;;
15 -*) ;;
16 *) break ;;
17 esac
18 done
19 [ -n "$1" ] || set -- "${TERM:-xterm} -ls || ${TERM:-sakura} -l || xterm -ls"
20 exec dbclient -f -R $((6000+$n)):localhost:$((6000+${svr%.*})) $r \
21 "xauth add $dpy $data; export DISPLAY=$scr; $@ ; xauth remove $dpy" \
22 </dev/null >/dev/null
23 }
25 pppssh()
26 {
27 ssh="dbclient -y"
28 $ssh $1 true || {
29 [ -z "$DROPBEAR_PASSWORD" ] && echo -n "ssh password: " &&
30 read -s -t 30 DROPBEAR_PASSWORD && export DROPBEAR_PASSWORD
31 $ssh $1 true || exit 1
32 }
33 for i in $4 ; do
34 echo "route add -net $i dev \$1"
35 done > /etc/ppp/ip-up.d/pppssh$$
36 chmod +x /etc/ppp/ip-up.d/pppssh$$
37 n=10.$(($$%256)).$(($$/256))
38 ppp="/usr/sbin/pppd local noauth nodetach"
39 $ppp ${2:-$n.1:$n.2} passive pty "$ssh $1 $ppp ${3:-proxyarp} notty" \
40 ipparam pppssh$$
41 rm -f /etc/ppp/ip-up.d/pppssh$$
42 }
44 case "$(basename $0)" in
45 ppp*) [ -z "$1" ] && cat <<EOT || pppssh "$@" ;;
46 Usage: $0 '[sshargs] user@remote' '[localip:remoteip] [localpppargs]' 'remotepppargs' 'routes'
47 Example: $0 tux@slitaz.org '' '' '192.168.1.0/24 10.1.2.0/24'
48 EOT
49 *) [ -z "$DISPLAY" ] && exec dbclient "$@"
50 xauth list $DISPLAY | xdbclient "$@"
51 esac