summaryrefslogtreecommitdiffstats
path: root/regress/putty-kex.sh
blob: 22f8bd7060f6f953751c451f2b703b183989b05f (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
#	$OpenBSD: putty-kex.sh,v 1.11 2024/02/09 08:56:59 dtucker Exp $
#	Placed in the Public Domain.

tid="putty KEX"

puttysetup

cp ${OBJ}/sshd_proxy ${OBJ}/sshd_proxy_bak

# Enable group1, which PuTTY now disables by default
echo "KEX=dh-group1-sha1" >>${OBJ}/.putty/sessions/localhost_proxy

# Grepping algos out of the binary is pretty janky, but AFAIK there's no way
# to query supported algos.
kex=""
for k in `$SSH -Q kex`; do
	if strings "${PLINK}" | grep -E "^${k}$" >/dev/null; then
		kex="${kex} ${k}"
	else
		trace "omitting unsupported KEX ${k}"
	fi
done

for k in ${kex}; do
	verbose "$tid: kex $k"
	cp ${OBJ}/sshd_proxy_bak ${OBJ}/sshd_proxy
	echo "KexAlgorithms ${k}" >>${OBJ}/sshd_proxy

	env HOME=$PWD ${PLINK} -v -load localhost_proxy -batch -i ${OBJ}/putty.rsa2 true \
	    2>${OBJ}/log/putty-kex-$k.log
	if [ $? -ne 0 ]; then
		fail "KEX $k failed"
	fi
	kexmsg=`grep -E '^Doing.* key exchange' ${OBJ}/log/putty-kex-$k.log`
	trace putty: ${kexmsg}
done