> I've found the following clever ssh-agent stanza in Richard Crowley's
> `.profile`[https://raw.github.com/rcrowley/home/master/.profile]:
> 
> which ssh-agent >/dev/null && {
>         : ${SSH_AUTH_SOCK:=$(echo /tmp/ssh-*/agent.* | cut -d" " -f1)}
>         [ -S "$SSH_AUTH_SOCK" ] && {
>                 export SSH_AUTH_SOCK
>         } || {
>                 eval $(ssh-agent)
>                 ssh-add
>         }
> }
> 
> Wondering why it doesn't work properly in OpenBSD ksh as I am not so
> good with POSIX sh.

Can't really tell which part doesn't work in OpenBSD ksh (I got used to
mksh and it got a lot of bashism lately). Anyway, I personally would
rather write it like this (not tested, I personally use
~/.ssh-agent-info to store ssh-agent's socket and PID):

if which ssh-agent >/dev/null
then
        test -z "$SSH_AUTH_SOCK" && \
                SSH_AUTH_SOCK=`echo /tmp/ssh-*/agent.* | cut -d\  -f1`
        if test -S "$SSH_AUTH_SOCK"
        then
                export SSH_AUTH_SOCK
        else
                eval `ssh-agent`
                ssh-add
        fi
fi

Hmm, just glanced over OpenBSD's manual for ksh and it seems all
constructs used are supported by OpenBSD's ksh - so the original code
should work there too... strange... or is TMPDIR set to something other
then /tmp? Does ssh-agent place its socket into /tmp/ssh-*/agent.*? (The
manual only states the socket lives in $TMPDIR/ssh-*/agent._ppid_.)

-- 
Eckehard Berns

Reply via email to