2016-12-16 04:51:19 +01:00
|
|
|
# Public Domain
|
|
|
|
# Zev Weiss, 2016
|
2021-06-07 02:00:50 +02:00
|
|
|
# $OpenBSD: allow-deny-users.sh,v 1.6 2021/06/07 00:00:50 djm Exp $
|
2016-12-16 04:51:19 +01:00
|
|
|
|
|
|
|
tid="AllowUsers/DenyUsers"
|
|
|
|
|
2016-12-19 04:32:57 +01:00
|
|
|
me="$LOGNAME"
|
2016-12-19 23:35:23 +01:00
|
|
|
if [ "x$me" = "x" ]; then
|
2016-12-19 04:32:57 +01:00
|
|
|
me=`whoami`
|
|
|
|
fi
|
2016-12-16 04:51:19 +01:00
|
|
|
other="nobody"
|
|
|
|
|
2018-07-13 04:13:50 +02:00
|
|
|
cp $OBJ/sshd_proxy $OBJ/sshd_proxy.orig
|
|
|
|
|
2016-12-16 04:51:19 +01:00
|
|
|
test_auth()
|
|
|
|
{
|
|
|
|
deny="$1"
|
|
|
|
allow="$2"
|
|
|
|
should_succeed="$3"
|
|
|
|
failmsg="$4"
|
|
|
|
|
2018-07-13 04:13:50 +02:00
|
|
|
cp $OBJ/sshd_proxy.orig $OBJ/sshd_proxy
|
2021-06-07 02:00:50 +02:00
|
|
|
test -z "$deny" || echo DenyUsers="$deny" >> $OBJ/sshd_proxy
|
|
|
|
test -z "$allow" || echo AllowUsers="$allow" >> $OBJ/sshd_proxy
|
2016-12-16 04:51:19 +01:00
|
|
|
|
2018-07-13 04:13:50 +02:00
|
|
|
${SSH} -F $OBJ/ssh_proxy "$me@somehost" true
|
2016-12-16 04:51:19 +01:00
|
|
|
status=$?
|
|
|
|
|
|
|
|
if (test $status -eq 0 && ! $should_succeed) \
|
|
|
|
|| (test $status -ne 0 && $should_succeed); then
|
|
|
|
fail "$failmsg"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# DenyUsers AllowUsers should_succeed failure_message
|
|
|
|
test_auth "" "" true "user in neither DenyUsers nor AllowUsers denied"
|
|
|
|
test_auth "$other $me" "" false "user in DenyUsers allowed"
|
|
|
|
test_auth "$me $other" "" false "user in DenyUsers allowed"
|
|
|
|
test_auth "" "$other" false "user not in AllowUsers allowed"
|
|
|
|
test_auth "" "$other $me" true "user in AllowUsers denied"
|
|
|
|
test_auth "" "$me $other" true "user in AllowUsers denied"
|
|
|
|
test_auth "$me $other" "$me $other" false "user in both DenyUsers and AllowUsers allowed"
|
|
|
|
test_auth "$other $me" "$other $me" false "user in both DenyUsers and AllowUsers allowed"
|