summaryrefslogtreecommitdiff
path: root/python
diff options
context:
space:
mode:
authorJoe Guo <joeg@catalyst.net.nz>2018-04-27 11:27:59 +1200
committerAndrew Bartlett <abartlet@samba.org>2018-05-12 02:09:28 +0200
commit51333c153844ae22eed645a0ce6c70eef78d1963 (patch)
tree593dd67261052100833a19c3c06a18f23318fd55 /python
parent34e35c4c80f8722d15770754393ce8673fc74a3b (diff)
downloadsamba-51333c153844ae22eed645a0ce6c70eef78d1963.tar.gz
samba-51333c153844ae22eed645a0ce6c70eef78d1963.tar.bz2
samba-51333c153844ae22eed645a0ce6c70eef78d1963.zip
traffic_packets: replace level 102 to 101 for packet_srvsvc_21
Level 102 will cause WERR_ACCESS_DENIED error against Windows, because: > If the level is 102 or 502, the Windows implementation checks whether > the caller is a member of one of the groups previously mentioned or > is a member of the Power Users local group. It passed against Samba since this check is not implemented by Samba yet. refer to: https://msdn.microsoft.com/en-us/library/cc247297.aspx#Appendix_A_80 Signed-off-by: Joe Guo <joeg@catalyst.net.nz> Reviewed-by: Andrew Bartlett <abartlet@samba.org> Reviewed-by: Garming Sam <garming@catalyst.net.nz>
Diffstat (limited to 'python')
-rw-r--r--python/samba/emulate/traffic_packets.py20
1 files changed, 18 insertions, 2 deletions
diff --git a/python/samba/emulate/traffic_packets.py b/python/samba/emulate/traffic_packets.py
index 390041b9513..2f1691d8568 100644
--- a/python/samba/emulate/traffic_packets.py
+++ b/python/samba/emulate/traffic_packets.py
@@ -935,9 +935,25 @@ def packet_srvsvc_16(packet, conversation, context):
def packet_srvsvc_21(packet, conversation, context):
- # NetSrvGetInfo
+ """NetSrvGetInfo
+
+ FIXME: Level changed from 102 to 101 here, to bypass Windows error.
+
+ Level 102 will cause WERR_ACCESS_DENIED error against Windows, because:
+
+ > If the level is 102 or 502, the Windows implementation checks whether
+ > the caller is a member of one of the groups previously mentioned or
+ > is a member of the Power Users local group.
+
+ It passed against Samba since this check is not implemented by Samba yet.
+
+ refer to:
+
+ https://msdn.microsoft.com/en-us/library/cc247297.aspx#Appendix_A_80
+
+ """
srvsvc = context.get_srvsvc_connection()
server_unc = "\\\\" + context.server
- level = 102
+ level = 101
srvsvc.NetSrvGetInfo(server_unc, level)
return True