Summary: | webdav kioslave unable to delete folder on apache dav_fs enabled webdav folder | ||
---|---|---|---|
Product: | [Unmaintained] kio | Reporter: | Martin van Es <bugs> |
Component: | http | Assignee: | kdelibs bugs <kdelibs-bugs> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | daniel.eckl, dhawes, fabiamo, florian.lindner |
Priority: | NOR | ||
Version: | 4.3 | ||
Target Milestone: | --- | ||
Platform: | Ubuntu | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: | |||
Attachments: | Patch making the directory deletion work for the WebDAV kio slave. |
Description
Martin van Es
2009-10-05 13:11:14 UTC
A little addition: deleting a folder using DAVExplorer (the Java client) succeeds without problems. Renaming a folder results in the same error. Bug is still present in 4.3.2 I think I've found the problem. When I delete the folder using konqueror the webdav kioslave sends the following command to my server: DELETE /test HTTP/1.1 Then my server replies: HTTP/1.1 301 Moved Permanently Location: http://******/test/ And the directory stays where it is (no success). DAVExplorer sends this line to my server: DELETE /test/ HTTP/1.1 And my server replies: HTTP/1.1 204 No Content After that DAVExplorer asks: PROPFIND / HTTP/1.1 And receives: HTTP/1.1 207 Multi-Status Containing the directory-listing xml output, without test (success). Reading up on the RFC, the Apache server does exactly what it should do: There is a standing convention that when a collection is referred to by its name without a trailing slash, the trailing slash is automatically appended. Due to this, a resource may accept a URI without a trailing "/" to point to a collection. In this case it SHOULD return a content-location header in the response pointing to the URI ending with the "/". For example, if a client invokes a method on http://foo.bar/blah (no trailing slash), the resource http://foo.bar/blah/ (trailing slash) may respond as if the operation were invoked on it, and should return a content-location header with http://foo.bar/blah/ in it. In general clients SHOULD use the "/" form of collection names. In this case, Apache says that the client should look at .../test/ and Konqueror should follow that path (instead of choking). Better would be to start the DELETE request on the collection by appending the trailing / to prevent the redirection altogether. Bug is still present in 4.3.4 I can confirm the mentioned behaviour. Neither deleting nor renaming of folders is possible. Created attachment 40351 [details]
Patch making the directory deletion work for the WebDAV kio slave.
More a workaround than a solution.
Correcting the delete behaviour is as simple (I have attached a patch for kdelibs 4.3.4), however correcting the renaming behaviour requires a more in-depth change. I tried setting the UDS_DISPLAY_NAME to what UDS_NAME is now and appending a slash to the UDS_NAME for directories (webdav "collections"). Unfortunately, this solution confuses Dolphin, because he constructs the new URL of the renaming from the old URL and using setFileName. This doesn't work, because the filename can't be identified properly due to the trailing slash. In fact, the new name is simply appended to the old URL. I have no idea what would be a clean solution. This bug is still present in 4.4.1. Even getting the delete to work would be a relief IMVHO. This is a duplicate of https://bugs.kde.org/show_bug.cgi?id=187970 SVN commit 1113484 by adawit: - Fixed both BR# 209508 and BR#187970. BUG: 209508 BUG: 187970 M +38 -1 http.cpp M +1 -0 http.h WebSVN link: http://websvn.kde.org/?view=rev&revision=1113484 *** Bug 184923 has been marked as a duplicate of this bug. *** Bug still existing in KDE 4.10.3. Uhm... wow. access.log: 12.34.56.78 - username [03/Jun/2013:19:16:07 +0200] "DELETE /folder/subfolder HTTP/1.1" 301 250 "-" "Mozilla/5.0 (X11; Linux x86_64) KHTML/4.10.3 (like Gecko) Konqueror/4.10" |