s3: libsmb: Fix SMB2 client rename bug to a Windows server.
authorJeremy Allison <jra@samba.org>
Tue, 30 Jun 2020 21:00:41 +0000 (14:00 -0700)
committerJeremy Allison <jra@samba.org>
Wed, 1 Jul 2020 18:59:53 +0000 (18:59 +0000)
commitf59490dc2d07107d32d6e888f2814011ab2845b7
tree9755325d91ae9125afa3be26e86ed2dadd8d4a97
parentd30865014569f4b9a1261d9f0c40bc4fc98f883e
s3: libsmb: Fix SMB2 client rename bug to a Windows server.

Fix bug where renaming to a target name of one
UCS2 character (name length 2 bytes) fails to
a Windows 10 SMB2 server.

The Windows 10 SMB2 server has a minimum length
for a SMB2_FILE_RENAME_INFORMATION buffer of
24 bytes. It returns NT_STATUS_INFO_LENGTH_MISMATCH
if the length is less. This isn't an alignment
issue as Windows client happily 2-byte align
for larget target name sizes. Also the Windows 10
SMB1 server doesn't have this restriction.

If the name length is too short, pad out with
zeros to 24 bytes.

Hard to add a test for this as we don't want to
add this silly restriction to the Samba server
as it would break all non-Windows clients.

BUG: https://bugzilla.samba.org/show_bug.cgi?id=14403

Signed-off-by: Jeremy Allison <jra@samba.org>
Reviewed-by: Volker Lendecke <vl@samba.org>
Autobuild-User(master): Jeremy Allison <jra@samba.org>
Autobuild-Date(master): Wed Jul  1 18:59:53 UTC 2020 on sn-devel-184
source3/libsmb/cli_smb2_fnum.c