Summary: | Dolphin can not copy files over sftp | ||
---|---|---|---|
Product: | [Unmaintained] kio | Reporter: | Ruchir Brahmbhatt <ruchir.brahmbhatt> |
Component: | general | Assignee: | David Faure <faure> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | asn, faure, peter.penz19 |
Priority: | NOR | ||
Version: | SVN | ||
Target Milestone: | --- | ||
Platform: | openSUSE | ||
OS: | Unspecified | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Ruchir Brahmbhatt
2009-03-12 11:56:30 UTC
Reproducible in 4.2.90. kio_sftp has been rewritten using libssh in trunk KDE 4.4. I've tested it and it works just fine. openSUSE has backported the fix to KDE 4.3. available in the build service. Could please confirm that the bug is fixed. Still not working. I tested dolphin from both factory and oss repos but none can copy files over sftp. Do you have the rights to copy a file to the directory on the remote server? What kind of file is it? How big is the file? Does the copy start but not finish? What ssh/sftp server is running? Please be more precise, I don't have a crystal ball. http://www.catb.org/~esr/faqs/smart-questions.html#beprecise I'm logged in to my system as normal user but I login with root to sftp. It's a small text file. File is 3.3KiB big Copy starts and finish(as per the notifications) how ever I don't see the file in dolphin as well as console(logged in to same system from konsole for verifying). Also when I try to copy again, it shows warning that file already exists!!! Target system if fedora11 with openssh. Hope this gives enough information. Ok, I can reproduce it. It looks like there is a bug in redirection. It looks like dolphin doesn't recognize the redirection. The file is copied to / on the server. kio_sftp(17173) kdemain: *** Starting kio_sftp kio_sftp(17173) sftpProtocol::sftpProtocol: pid = 17173 kio_sftp(17173) sftpProtocol::setHost: setHost(): "root" @ "milliways.cynapses.org" : 0 kio_sftp(17173) sftpProtocol::setHost: setHost(): mPort= 22 kio_sftp(17173) sftpProtocol::stat: KUrl("sftp://root@milliways.cynapses.org") kio_sftp(17173) sftpProtocol::openConnection: username= "root" , host= "milliways.cynapses.org" , port= 22 kio_sftp(17173) sftpProtocol::openConnection: checking cache: info.username = "root" , info.url = "sftp://root@milliways.cynapses.org:22" kio_sftp(17173) sftpProtocol::openConnection: Creating the SSH options kio_sftp(17173) sftpProtocol::openConnection: Creating the SSH session kio_sftp(17173) sftpProtocol::openConnection: Trying to connect to the SSH server kio_sftp(17173) sftpProtocol::openConnection: Getting the SSH server hash kio_sftp(17173) sftpProtocol::openConnection: Checking if the SSH server is known kio_sftp(17173) sftpProtocol::openConnection: Trying to authenticate with the server kio_sftp(17173) sftpProtocol::openConnection: Trying to authenticate public key kio_sftp(17173) sftpProtocol::openConnection: Trying to request the sftp session kio_sftp(17173) sftpProtocol::openConnection: Trying to initialize the sftp session kio_sftp(17173) sftpProtocol::openConnection: Caching info.username = "root" , info.url = "sftp://root@milliways.cynapses.org:22" kio_sftp(17173) sftpProtocol::canonicalizePath: Path to canonicalize: "." kio_sftp(17173) sftpProtocol::canonicalizePath: Canonicalized path: "/root" kio_sftp(17173) sftpProtocol::stat: redirecting to "sftp://root@milliways.cynapses.org/root" kio_sftp(17173) sftpProtocol::stat: KUrl("sftp://root@milliways.cynapses.org/root") kio_sftp(17173) sftpProtocol::listDir: list directory: KUrl("sftp://root@milliways.cynapses.org") kio_sftp(17173) sftpProtocol::canonicalizePath: Path to canonicalize: "." kio_sftp(17173) sftpProtocol::canonicalizePath: Canonicalized path: "/root" kio_sftp(17173) sftpProtocol::listDir: redirecting to "sftp://root@milliways.cynapses.org/root" kio_sftp(17173) sftpProtocol::listDir: list directory: KUrl("sftp://root@milliways.cynapses.org/root") kio_sftp(17173) sftpProtocol::listDir: readdir: "/root" , details: "2" kio_sftp(17173) sftpProtocol::stat: KUrl("sftp://root@milliways.cynapses.org") kio_sftp(17173) sftpProtocol::canonicalizePath: Path to canonicalize: "." kio_sftp(17173) sftpProtocol::canonicalizePath: Canonicalized path: "/root" kio_sftp(17173) sftpProtocol::stat: redirecting to "sftp://root@milliways.cynapses.org/root" kio_sftp(17173) sftpProtocol::stat: KUrl("sftp://root@milliways.cynapses.org/root") kio_sftp(17173) sftpProtocol::put: put(): KUrl("sftp://root@milliways.cynapses.org/file.txt") , permissions = "420" , overwrite = 0 , resume = 0 kio_sftp(17173) sftpProtocol::put: Appending .part extension to "/file.txt" kio_sftp(17173) sftpProtocol::put: Trying to open: "/file.txt.part" , mode= "420" David, is this a bug in dolphin/konqueror or am I doing something wrong in kio_sftp? listDir() and stat() redirect to a canonicalized path if the stat() or listDir() fails. sftp://user@host to -> sftp://user@host/homedir The redirection works, you get the right content displayed and in the address bar of konqueror or dolphin the right url is displayed. If you copy a file to the redirected directory it tries to copy the file to /. See the log in comment #6. It works just fine using krusader. Will thinks that it could be a problem of dolphinpart. Nice one. It works in iconview and not in listview (but only because of a side effect in the dropEvent code of each view). The bug is that m_controller->url() does not contain the new URL. Fix coming up soon. SVN commit 1025419 by dfaure: Update the controller's url upon redirection, otherwise pasting would paste into the old url. BUG: 186947 M +5 -0 dolphincontroller.cpp M +7 -1 dolphincontroller.h M +8 -2 dolphinview.cpp M +6 -0 dolphinview.h WebSVN link: http://websvn.kde.org/?view=rev&revision=1025419 Thanks David, I was not aware that this might be a Dolphin issue. |