summaryrefslogtreecommitdiff
path: root/bin/menuscripts/keyadd
blob: 5a38bfbd167bf5578fac2c2430ef44fc6de28fbb (plain)
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
#!/bin/sh

log()
{
	herbe "keyadd" "$1" &
	>&2 printf '%s\n' "$1"
}

SSHFOLDER="$HOME/.ssh"

# Test if can connect to ssh-agent
ssh-add -l > /dev/null 2>&1
if [ $? -gt 1 ] # ignore if there are no identities
then
	log "Could not connect to agent."
	exit 1
fi

delete=0
if [ "$1" = "-d" ] 
then
    delete=1
    shift
fi

if [ "$1" ]
then
    key_pretty="$1"
else
	key_pretty="$(find "$SSHFOLDER" -iname "*.pub" |
        sed "s@$SSHFOLDER/\(.*\)\.pub\$@\1@" |
        commander -xc)"
fi
[ "$key_pretty" ] || exit 1
key="$SSHFOLDER/$key_pretty"

if [ ! -f "$key" ] 
then
    log "No key found at: $key"
    exit 1
fi

if [ "$delete" -eq 1 ]
then
	ssh-add -q -d - < "$key".pub 2> /dev/null &&
		log "Deleted $key_pretty." ||
		log "Could not delete."
    exit
fi

# check if key is already added
if ssh-add -l | grep -q "$(ssh-keygen -lf "$key")"
then
	log "Key already added."
    exit 1
fi

HOST="$(hostname)"
export PASSWORD="keys/$HOST/ssh/$key_pretty"
export SSH_ASKPASS="sshpass"
ssh-add -q - < "$key" &&
    log "Added $key_pretty."