1*557f75e5SDag-Erling Smørgrav# $OpenBSD: cfgparse.sh,v 1.5 2015/05/29 03:05:13 djm Exp $ 2*557f75e5SDag-Erling Smørgrav# Placed in the Public Domain. 3*557f75e5SDag-Erling Smørgrav 4*557f75e5SDag-Erling Smørgravtid="config parse" 5*557f75e5SDag-Erling Smørgrav 6*557f75e5SDag-Erling Smørgrav# This is a reasonable proxy for IPv6 support. 7*557f75e5SDag-Erling Smørgravif ! config_defined HAVE_STRUCT_IN6_ADDR ; then 8*557f75e5SDag-Erling Smørgrav SKIP_IPV6=yes 9*557f75e5SDag-Erling Smørgravfi 10*557f75e5SDag-Erling Smørgrav 11*557f75e5SDag-Erling Smørgrav# We need to use the keys generated for the regression test because sshd -T 12*557f75e5SDag-Erling Smørgrav# will fail if we're not running with SUDO (no permissions for real keys) or 13*557f75e5SDag-Erling Smørgrav# if we are # running tests on a system that has never had sshd installed 14*557f75e5SDag-Erling Smørgrav# (keys won't exist). 15*557f75e5SDag-Erling Smørgrav 16*557f75e5SDag-Erling Smørgravgrep "HostKey " $OBJ/sshd_config > $OBJ/sshd_config_minimal 17*557f75e5SDag-Erling SmørgravSSHD_KEYS="`cat $OBJ/sshd_config_minimal`" 18*557f75e5SDag-Erling Smørgrav 19*557f75e5SDag-Erling Smørgravverbose "reparse minimal config" 20*557f75e5SDag-Erling Smørgrav($SUDO ${SSHD} -T -f $OBJ/sshd_config_minimal >$OBJ/sshd_config.1 && 21*557f75e5SDag-Erling Smørgrav $SUDO ${SSHD} -T -f $OBJ/sshd_config.1 >$OBJ/sshd_config.2 && 22*557f75e5SDag-Erling Smørgrav diff $OBJ/sshd_config.1 $OBJ/sshd_config.2) || fail "reparse minimal config" 23*557f75e5SDag-Erling Smørgrav 24*557f75e5SDag-Erling Smørgravverbose "reparse regress config" 25*557f75e5SDag-Erling Smørgrav($SUDO ${SSHD} -T -f $OBJ/sshd_config >$OBJ/sshd_config.1 && 26*557f75e5SDag-Erling Smørgrav $SUDO ${SSHD} -T -f $OBJ/sshd_config.1 >$OBJ/sshd_config.2 && 27*557f75e5SDag-Erling Smørgrav diff $OBJ/sshd_config.1 $OBJ/sshd_config.2) || fail "reparse regress config" 28*557f75e5SDag-Erling Smørgrav 29*557f75e5SDag-Erling Smørgravverbose "listenaddress order" 30*557f75e5SDag-Erling Smørgrav# expected output 31*557f75e5SDag-Erling Smørgravcat > $OBJ/sshd_config.0 <<EOD 32*557f75e5SDag-Erling Smørgravlistenaddress 1.2.3.4:1234 33*557f75e5SDag-Erling Smørgravlistenaddress 1.2.3.4:5678 34*557f75e5SDag-Erling SmørgravEOD 35*557f75e5SDag-Erling Smørgrav[ X${SKIP_IPV6} = Xyes ] || cat >> $OBJ/sshd_config.0 <<EOD 36*557f75e5SDag-Erling Smørgravlistenaddress [::1]:1234 37*557f75e5SDag-Erling Smørgravlistenaddress [::1]:5678 38*557f75e5SDag-Erling SmørgravEOD 39*557f75e5SDag-Erling Smørgrav 40*557f75e5SDag-Erling Smørgrav# test input sets. should all result in the output above. 41*557f75e5SDag-Erling Smørgrav# test 1: addressfamily and port first 42*557f75e5SDag-Erling Smørgravcat > $OBJ/sshd_config.1 <<EOD 43*557f75e5SDag-Erling Smørgrav${SSHD_KEYS} 44*557f75e5SDag-Erling Smørgravaddressfamily any 45*557f75e5SDag-Erling Smørgravport 1234 46*557f75e5SDag-Erling Smørgravport 5678 47*557f75e5SDag-Erling Smørgravlistenaddress 1.2.3.4 48*557f75e5SDag-Erling SmørgravEOD 49*557f75e5SDag-Erling Smørgrav[ X${SKIP_IPV6} = Xyes ] || cat >> $OBJ/sshd_config.1 <<EOD 50*557f75e5SDag-Erling Smørgravlistenaddress ::1 51*557f75e5SDag-Erling SmørgravEOD 52*557f75e5SDag-Erling Smørgrav 53*557f75e5SDag-Erling Smørgrav($SUDO ${SSHD} -T -f $OBJ/sshd_config.1 | \ 54*557f75e5SDag-Erling Smørgrav grep 'listenaddress ' >$OBJ/sshd_config.2 && 55*557f75e5SDag-Erling Smørgrav diff $OBJ/sshd_config.0 $OBJ/sshd_config.2) || \ 56*557f75e5SDag-Erling Smørgrav fail "listenaddress order 1" 57*557f75e5SDag-Erling Smørgrav# test 2: listenaddress first 58*557f75e5SDag-Erling Smørgravcat > $OBJ/sshd_config.1 <<EOD 59*557f75e5SDag-Erling Smørgrav${SSHD_KEYS} 60*557f75e5SDag-Erling Smørgravlistenaddress 1.2.3.4 61*557f75e5SDag-Erling Smørgravport 1234 62*557f75e5SDag-Erling Smørgravport 5678 63*557f75e5SDag-Erling Smørgravaddressfamily any 64*557f75e5SDag-Erling SmørgravEOD 65*557f75e5SDag-Erling Smørgrav[ X${SKIP_IPV6} = Xyes ] || cat >> $OBJ/sshd_config.1 <<EOD 66*557f75e5SDag-Erling Smørgravlistenaddress ::1 67*557f75e5SDag-Erling SmørgravEOD 68*557f75e5SDag-Erling Smørgrav 69*557f75e5SDag-Erling Smørgrav($SUDO ${SSHD} -T -f $OBJ/sshd_config.1 | \ 70*557f75e5SDag-Erling Smørgrav grep 'listenaddress ' >$OBJ/sshd_config.2 && 71*557f75e5SDag-Erling Smørgrav diff $OBJ/sshd_config.0 $OBJ/sshd_config.2) || \ 72*557f75e5SDag-Erling Smørgrav fail "listenaddress order 2" 73*557f75e5SDag-Erling Smørgrav 74*557f75e5SDag-Erling Smørgrav# cleanup 75*557f75e5SDag-Erling Smørgravrm -f $OBJ/sshd_config.[012] 76