blob: 2e6e285b404bc4290bba76e04826eb8242adb72c (
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
#!/usr/bin/env bash
#
# Test smbcontrol close-denied-share command.
#
# Copyright (C) 2020 Volker Lendecke
if [ $# -lt 6 ]; then
echo Usage: test_close_denied_share.sh \
SERVERCONFFILE SHARESEC SMBCLIENT SMBCONTROL IP SHARE
exit 1
fi
CONF=$1
SHARESEC=$2
SMBCLIENT=$3
SMBCONTROL=$4
SERVER=$5
SHARE=$6
incdir=$(dirname $0)/../../../testprogs/blackbox
. $incdir/subunit.sh
failed=0
cd $SELFTEST_TMPDIR || exit 1
rm -f smbclient-stdin smbclient-stdout
mkfifo smbclient-stdin smbclient-stdout
CLI_FORCE_INTERACTIVE=1
export CLI_FORCE_INTERACTIVE
${SMBCLIENT} //${SERVER}/${SHARE} ${CONF} -U${USER}%${PASSWORD} \
<smbclient-stdin >smbclient-stdout &
CLIENT_PID=$!
sleep 1
exec 100>smbclient-stdin 101<smbclient-stdout
# consume the smbclient startup message
head -n 1 <&101
testit "smbcontrol" ${SMBCONTROL} ${CONF} smbd close-denied-share ${SHARE} ||
failed=$(expr $failed + 1)
sleep 1
echo dir >&100
COUNT=$(head -n 2 <&101 |
grep NT_STATUS_NETWORK_NAME_DELETED |
wc -l)
testit "Verify close-denied-share did not kill valid client" \
test $COUNT -eq 0 || failed=$(expr $failed + 1)
testit "Deny access" ${SHARESEC} ${CONF} --replace S-1-1-0:DENIED/0x0/FULL \
${SHARE} || failed=$(expr $failed + 1)
testit "smbcontrol" ${SMBCONTROL} ${CONF} smbd close-denied-share ${SHARE} ||
failed=$(expr $failed + 1)
sleep 1
echo dir >&100
COUNT=$(head -n 2 <&101 |
grep NT_STATUS_NETWORK_NAME_DELETED |
wc -l)
testit "Verify close-denied-share did kill now-invalid client" \
test $COUNT -eq 1 || failed=$(expr $failed + 1)
kill ${CLIENT_PID}
rm -f smbclient-stdin smbclient-stdout
testit "Allow access" ${SHARESEC} ${CONF} --replace S-1-1-0:ALLOWED/0x0/FULL \
${SHARE} || failed=$(expr $failed + 1)
testok $0 $failed
|