#!/bin/sh # This script can be used as a "remote shell" command that is only # capable of pretending to connect to "localhost". This is useful # for testing or for running a local copy where the sender and the # receiver needs to use different options (e.g. --fake-super). If # we get a -l USER option, we try to use "sudo -u USER" to run the # command. user='' do_cd=y # Default path is user's home dir, just like ssh. while : ; do case "$1" in -l) user="$2"; shift; shift ;; -l*) user=`echo "$1" | sed 's/^-l//'`; shift ;; --no-cd) do_cd=n; shift ;; -*) shift ;; localhost) shift; break ;; *) echo "lsh: unable to connect to host $1" 1>&2; exit 1 ;; esac done if [ "$user" ]; then prefix='' if [ $do_cd = y ]; then home=`perl -e "print((getpwnam('$user'))[7])"` prefix="cd '$home' &&" fi sudo -H -u "$user" sh -c "$prefix $*" else if [ $do_cd = y ]; then cd || exit 1 fi eval "${@}" fi
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
Makefile | File | 80 B | 0644 |
|
atomic-rsync | File | 3.9 KB | 0644 |
|
cvs2includes | File | 1.18 KB | 0644 |
|
deny-rsync | File | 997 B | 0644 |
|
file-attr-restore | File | 4.82 KB | 0644 |
|
files-to-excludes | File | 534 B | 0644 |
|
git-set-file-times | File | 910 B | 0644 |
|
instant-rsyncd | File | 2.72 KB | 0644 |
|
logfilter | File | 1.07 KB | 0644 |
|
lsh | File | 2.21 KB | 0644 |
|
lsh.sh | File | 956 B | 0644 |
|
mapfrom | File | 629 B | 0644 |
|
mapto | File | 621 B | 0644 |
|
mnt-excl | File | 1.8 KB | 0644 |
|
munge-symlinks | File | 1.43 KB | 0644 |
|
rrsync | File | 7.07 KB | 0644 |
|
rsync-no-vanished | File | 267 B | 0644 |
|
rsync-slash-strip | File | 643 B | 0644 |
|
rsyncstats | File | 8.56 KB | 0644 |
|
savetransfer.c | File | 4.45 KB | 0644 |
|