Version: unknown (using KDE 3.1.93 (CVS >= 20031111), compiled sources) Compiler: gcc version 3.3.2 OS: Linux (i686) release 2.6.0-test9-mm4 When browsing a password protected smb-share, I am asked to type my password for every subfolder and file I open instead of only once for the entire share. This makes getting at files in subfolder a total pain!
BTW: This looks like bug #26069 (in kde 2.x) which is marked RESOLVED?!
The question is basically: do you use samba 2 or samba 3 (i.e. is your kio_smb linked against libsmbclient or not)
I'm using samba 3 and kio_smb is linked against libsmbclient.
*** Bug 69067 has been marked as a duplicate of this bug. ***
This is a VERY annoying bug indeed... I hope this will get fixed soon? :$ Thanks in advance!
*** Bug 71030 has been marked as a duplicate of this bug. ***
The same issue with 3.2 final on Mandrake. I am browsing smb resorces using konqi and smb:/ Password is prompted all the time when browsing different directories on the same machine in the net (e.g. when going deeper and deeper into shares tree). It's critical to fix it ASAP (IMHO).
Same here with samba 3.0.2a and kio-smb-3.2.0-48926cl from Conectiva Linux snapshot. A simple refresh (F5) will make the password prompt appear again. $ ldd /usr/lib/kde3/lib/kde3/kio_smb.so|grep smb libsmbclient.so.0 => /usr/lib/./libsmbclient.so.0 (0x4126a000) $ rpm -qf /usr/lib/./libsmbclient.so.0 libsmbclient0-3.0.2a-49421cl
CVS commit by coolo: Making KDE Enterprise-Ready in redirecting in case the user name changed CCMAIL: 68893-done@bugs.kde.org M +13 -11 kio_smb_browse.cpp 1.30 --- kdebase/kioslave/smb/kio_smb_browse.cpp #1.29:1.30 @@ -44,6 +44,6 @@ using namespace KIO; int SMBSlave::cache_stat(const SMBUrl &url, struct stat* st ) { - int result = smbc_stat(url.toSmbcUrl(), st); - kdDebug(KIO_SMB) << "smbc_stat " << url.toSmbcUrl() << " " << errno << " " << result << endl; + int result = smbc_stat( url.toSmbcUrl(), st); + kdDebug(KIO_SMB) << "smbc_stat " << url.prettyUrl() << " " << errno << " " << result << endl; return result; } @@ -57,5 +57,4 @@ bool SMBSlave::browse_stat_path(const SM SMBUrl url = _url; - again: if(cache_stat(url, &st) == 0) { @@ -115,6 +114,8 @@ bool SMBSlave::browse_stat_path(const SM if (!ignore_errors) { if (errno == EPERM || errno == EACCES) - if (checkPassword(url)) - goto again; + if (checkPassword(url)) { + redirection( url ); + return false; + } reportError(url); @@ -140,5 +141,4 @@ void SMBSlave::stat( const KURL& kurl ) { redirection(url); - finished(); return; } @@ -280,5 +280,5 @@ void SMBSlave::reportError(const SMBUrl void SMBSlave::listDir( const KURL& kurl ) { - kdDebug(KIO_SMB) << "SMBSlave::listDir on " << kurl << endl; + kdDebug(KIO_SMB) << "SMBSlave::listDir on " << kurl.url() << endl; // check (correct) URL @@ -299,5 +299,4 @@ void SMBSlave::listDir( const KURL& kurl UDSAtom atom; - again: dirfd = smbc_opendir( m_current_url.toSmbcUrl() ); kdDebug(KIO_SMB) << "SMBSlave::listDir open " << m_current_url.toSmbcUrl() << " " << m_current_url.getType() << " " << dirfd << endl; @@ -406,6 +405,9 @@ void SMBSlave::listDir( const KURL& kurl { if (errno == EPERM || errno == EACCES) - if (checkPassword(m_current_url)) - goto again; + if (checkPassword(m_current_url)) { + redirection( m_current_url ); + finished(); + return; + } reportError(m_current_url);
*** Bug 76760 has been marked as a duplicate of this bug. ***
*** Bug 42663 has been marked as a duplicate of this bug. ***