From: Jeremy Allison Date: Tue, 22 Mar 2005 23:45:57 +0000 (+0000) Subject: r5981: Hack to fix DFS code to work with Win98 server. JERRY PLEASE REVIEW THIS ! X-Git-Tag: samba-misc-tags/initial-v3-0-unstable~5059 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=1ee180a6dd7f8d787396f359a8ff3ed25433357b;p=thirdparty%2Fsamba.git r5981: Hack to fix DFS code to work with Win98 server. JERRY PLEASE REVIEW THIS ! I don't think this is correct - it just happens to work and fix bug #2530 to return all the files. Jeremy. --- diff --git a/source/libsmb/clidfs.c b/source/libsmb/clidfs.c index dcffdf42fe4..e2456800ddc 100644 --- a/source/libsmb/clidfs.c +++ b/source/libsmb/clidfs.c @@ -595,8 +595,26 @@ BOOL cli_resolve_path( const char *mountpt, struct cli_state *rootcli, const cha /* we got an error, check for DFS referral */ - if ( !cli_dfs_check_error(rootcli) ) + if ( !cli_dfs_check_error(rootcli) ) { + /* Check for Win98 server - doesn't support this call. */ + uint32 flgs2 = SVAL(rootcli->inbuf,smb_flg2); + + /* only deal with DS when we negotiated NT_STATUS codes and UNICODE */ + + if ( !( (flgs2&FLAGS2_32_BIT_ERROR_CODES) && (flgs2&FLAGS2_UNICODE_STRINGS) ) ) { + uint8 eclass = 0; + uint32 ecode = 0; + cli_dos_error(rootcli, &eclass, &ecode); + if ((eclass == ERRDOS) && (ecode == ERRbadfunc)) { + rootcli->dfsroot = 0; + *targetcli = rootcli; + pstrcpy( targetpath, path ); + return True; + } + } + return False; + } /* check for the referral */