-
-
Notifications
You must be signed in to change notification settings - Fork 78
/
Copy pathgenerate-and-send-ssh-key.sh
executable file
·167 lines (145 loc) · 4 KB
/
generate-and-send-ssh-key.sh
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
#!/bin/bash
# these are the defaults for the commandline-options
KEYSIZE=4096
PASSPHRASE=
FILENAME=~/.ssh/id_test
KEYTYPE=rsa
HOST=host
USER=${USER}
# use "-p <port>" if the ssh-server is listening on a different port
SSH_OPTS="-o PubkeyAuthentication=no"
#
# NO MORE CONFIG SETTING BELOW THIS LINE
#
function usage() {
echo "Specify some parameters, valid ones are:"
echo " -u (--user) <username>, default: ${USER}"
echo " -f (--file) <file>, default: ${FILENAME}"
echo " -h (--host) <hostname>, default: ${HOST}"
echo " -p (--port) <port>, default: <default ssh port>"
echo " -k (--keysize) <size>, default: ${KEYSIZE}"
echo " -t (--keytype) <type>, default: ${KEYTYPE}, typical values are 'rsa' or 'ed25519'"
echo " -P (--passphrase) <key-passphrase>, default: ${PASSPHRASE}"
exit 2
}
if [[ $# < 1 ]];then
usage
fi
while [[ $# > 0 ]]
do
key="$1"
shift
case $key in
-u*|--user)
USER="$1"
shift
;;
-f*|--file)
FILENAME="$1"
shift
;;
-h*|--host)
HOST="$1"
shift
;;
-p*|--port)
SSH_OPTS="${SSH_OPTS} -p $1"
shift
;;
-k*|--keysize)
KEYSIZE="$1"
shift
;;
-t*|--keytype)
KEYTYPE="$1"
shift
;;
-P*|--passphrase)
PASSPHRASE="$1"
shift
;;
*)
# unknown option
usage "unknown parameter: $key, "
;;
esac
done
echo
echo "Transferring key from ${FILENAME} to ${USER}@${HOST} using options '${SSH_OPTS}', keysize ${KEYSIZE} and keytype: ${KEYTYPE}"
echo
echo "Press ENTER to continue or CTRL-C to abort"
read
# check that we have all necessary parts
SSH_KEYGEN=`which ssh-keygen`
SSH=`which ssh`
SSH_COPY_ID=`which ssh-copy-id`
if [ -z "${SSH_KEYGEN}" ];then
echo Could not find the 'ssh-keygen' executable
exit 1
fi
if [ -z "${SSH}" ];then
echo Could not find the 'ssh' executable
exit 1
fi
echo
# perform the actual work
if [ -f "${FILENAME}" ];then
echo Using existing key
else
echo Creating a new key using ${SSH-KEYGEN}
${SSH_KEYGEN} -t $KEYTYPE -b $KEYSIZE -f "${FILENAME}" -N "${PASSPHRASE}"
RET=$?
if [ ${RET} -ne 0 ];then
echo ssh-keygen failed: ${RET}
exit 1
fi
fi
if [ ! -f "${FILENAME}.pub" ];then
echo Did not find the expected public key at ${FILENAME}.pub
exit 1
fi
echo
echo Having key-information
ssh-keygen -l -f "${FILENAME}"
echo
echo Adjust permissions of generated key-files locally
chmod 0600 "${FILENAME}" "${FILENAME}.pub"
RET=$?
if [ ${RET} -ne 0 ];then
echo chmod failed: ${RET}
exit 1
fi
echo
echo Copying the key to the remote machine ${USER}@${HOST}, this usually will ask for the password
if [ -z "${SSH_COPY_ID}" ];then
echo Could not find the 'ssh-copy-id' executable, using manual copy instead
cat "${FILENAME}.pub" | ssh ${SSH_OPTS} ${USER}@${HOST} 'cat >> ~/.ssh/authorized_keys'
else
${SSH_COPY_ID} ${SSH_OPTS} -i ${FILENAME}.pub ${USER}@${HOST}
RET=$?
if [ ${RET} -ne 0 ];then
echo Executing ssh-copy-id via ${SSH_COPY_ID} failed, trying to manually copy the key-file instead
cat "${FILENAME}.pub" | ssh ${SSH_OPTS} ${USER}@${HOST} 'cat >> ~/.ssh/authorized_keys'
fi
fi
RET=$?
if [ ${RET} -ne 0 ];then
echo ssh-copy-id failed: ${RET}
exit 1
fi
echo
echo Adjusting permissions to avoid errors in ssh-daemon, this may ask once more for the password
${SSH} ${SSH_OPTS} ${USER}@${HOST} "chmod go-w ~ && chmod 700 ~/.ssh && chmod 600 ~/.ssh/authorized_keys"
RET=$?
if [ ${RET} -ne 0 ];then
echo ssh-chmod failed: ${RET}
exit 1
fi
# Cut out PubKeyAuth=no here as it should work without it now
echo
echo Setup finished, now try to run ${SSH} `echo ${SSH_OPTS} | sed -e 's/-o PubkeyAuthentication=no//g'` -i "${FILENAME}" ${USER}@${HOST}
echo
echo If it still does not work, you can try the following steps:
echo "- Check if ~/.ssh/config has some custom configuration for this host"
echo "- Make sure the type of key is supported, e.g. 'dsa' is deprecated and might be disabled"
echo "- Try running ssh with '-v' and look for clues in the resulting output"