Summary: | GroupDAV resource crashes when selected in Akonadi Console | ||
---|---|---|---|
Product: | [Frameworks and Libraries] Akonadi | Reporter: | Ingo Ratsdorf <ingo> |
Component: | DAV Resource | Assignee: | kdepim bugs <kdepim-bugs> |
Status: | RESOLVED WORKSFORME | ||
Severity: | crash | CC: | greg |
Priority: | NOR | ||
Version: | unspecified | ||
Target Milestone: | --- | ||
Platform: | Compiled Sources | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Ingo Ratsdorf
2011-02-06 10:52:01 UTC
Hi Ingo, Are you using self-compiled packages for all of KDE? I've never seen this behavior and would like to replicate your setup. Cheers, Grégory Hi Grégory, I am following the groupdav resource for quite a while and had an older version reasonably well working before some code was shifted from KCal to KCalCore, at which point I could not compile anymore as Kubuntu 10.04 had no headers and libs for it. I yesterday upgraded to Kubuntu 10.10 and to KDE 4.6 RC which allowed me to make the groupdav latest version from Git. Note: I have downloded the whole kdepim-runtime but made only teh groupdav resource and installed it. All complied without glitches just two warning and linked fine, also installed correctly as far as I can tell. Yet, the groupdavresource randomly crashes on startup. In akonadiconsule, it will only show contacts, not calendars or tasks. Selecting calendars or tasks will crash the resource. My groupdav server is eGroupware 1.9.002 from SVN which is running fine with the old pre KCalCore groupdav resource on another machine. I had to patch the CMakeList.txt file in order to compile and install the groupdav client. I added the usual KDE requirements plus the kcfg_ macro, that I can never find in any packed or some reason. Nevertheless as I said, it compiled and linked fine. Currently, he latest groupdav resource does not work at all for me. Regards, Ingo Hi Ingo, I'm still not able to compile the latest DAV resource on Kubuntu 10.10. One issue is the missing kcalcore. Then I had to hack through the CMakeLists.txt, as I guess you did, to change the minimum versions required. Even if I was able to compile the resource, I would have put a big red flag on using such versions. As a final note, and as you are using eGroupware, can you try to apply the changes mentioned in this bug report : https://bugs.kde.org/show_bug.cgi?id=265096 and tell me if that helps. Cheers, Grégory Hi Grégory, I applied the mentioned patch which seems to make the pre KCalCore groupdav resource work without throwing warnings about invalid data. Yet it has no influence on the latest groupdav resource. I used wireshark to trace HTTP requests and responses. All REPORT calls seem to go through fine, but EVERY TIME the groupdav sends a GET and received a (good looking) response from the server, the resource will crash. Very funny. This is a typical request and response directly before the resource crashes: GET /groupdav.php/calendar/1091.ics HTTP/1.1 Host: groupware.envirology.co.nz Connection: Keep-Alive User-Agent: KDE DAV groupware client Pragma: no-cache Cache-control: no-cache Accept: text/html, image/jpeg;q=0.9, image/png;q=0.9, text/*;q=0.9, image/*;q=0.9, */*;q=0.8 Accept-Encoding: x-gzip, x-deflate, gzip, deflate Accept-Charset: utf-8, utf-8;q=0.5, *;q=0.5 Accept-Language: en-US,en;q=0.9 Cookie: last_loginid=ingo; last_domain=default Authorization: Basic xxxxxxxxxxxxxxxxxxxxx HTTP/1.1 200 OK Date: Tue, 08 Feb 2011 04:58:33 GMT Server: Apache Expires: Thu, 19 Nov 1981 08:52:00 GMT X-Dav-Powered-By: EGroupware 1.9.005 CalDAV/CardDAV/GroupDAV server Content-Encoding: identity ETag: EGw-1091:0:1297074806-wGE Cache-Control: maxage=1 Pragma: public Set-Cookie: last_loginid=ingo; expires=Tue, 22-Feb-2011 04:58:33 GMT; path=/; domain=groupware.envirology.co.nz Set-Cookie: last_domain=default; expires=Tue, 22-Feb-2011 04:58:33 GMT; path=/; domain=groupware.envirology.co.nz Content-length: 836 Keep-Alive: timeout=3, max=99 Connection: Keep-Alive Content-Type: text/calendar; charset=utf-8 BEGIN:VCALENDAR VERSION:2.0 PRODID:-//eGroupWare//NONSGML eGroupWare Calendar 1.9.002//EN METHOD:PUBLISH BEGIN:VTIMEZONE TZID:Pacific/Auckland X-LIC-LOCATION:Pacific/Auckland BEGIN:DAYLIGHT TZOFFSETFROM:+1200 TZOFFSETTO:+1300 TZNAME:NZDT DTSTART:19700927T020000 RRULE:FREQ=YEARLY;BYDAY=-1SU;BYMONTH=9 END:DAYLIGHT BEGIN:STANDARD TZOFFSETFROM:+1300 TZOFFSETTO:+1200 TZNAME:NZST DTSTART:19700405T030000 RRULE:FREQ=YEARLY;BYDAY=1SU;BYMONTH=4 END:STANDARD END:VTIMEZONE BEGIN:VEVENT DTSTART;VALUE=DATE:20100619 DTEND;VALUE=DATE:20100620 CLASS:PRIVATE SUMMARY:SOME DESCRIPTION HERE RRULE:FREQ=YEARLY PRIORITY:5 TRANSP:TRANSPARENT UID:gsukn30pqulfv2l5951l59bibs@google.com STATUS:CONFIRMED CREATED:20110130T102608Z LAST-MODIFIED:20110130T102608Z DTSTAMP:20110208T045834Z END:VEVENT END:VCALENDAR I'll try to recompile and see what happens. This is all too strange. Cheers. Hi. I should chnage the bug title, actually. The resource crashes whenever an actual calendar element is fetched from the server, ie every GET. This applies only to VTODO's and VCALENDAR's, not VCARD's. VCARD's load fine. In that respect, I have included some console output just before the crash: korganizer(2883)/libakonadi Akonadi::SessionPrivate::init: "" korganizer(2883)/libakonadi Akonadi::SessionPrivate::reconnect: connectToServer "/home/ingo/.local/share/akonadi/socket-ingo-laptop/akonadiserver.socket" korganizer(2883)/libakonadi Akonadi::SessionPrivate::dataReceived: Server protocol version is: 28 korganizer(2883)/libakonadi Akonadi::PluginRegistry::findBestMatchImpl: Looking for "default for application/x-vnd.akonadi.calendar.todo" korganizer(2883)/libakonadi Akonadi::PluginRegistry::findBestMatchImpl: Considering serializer plugin for type "text/calendar" as the closest match korganizer(2883)/libakonadi Akonadi::PluginRegistry::findBestMatchImpl: -> got AkonadiFuture::SerializerPluginKCal and am happy with it. korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal) KCal::ICalFormat::fromRawString: parse error korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: Failed to parse incidence! korganizer(2883)/akonadiserializer (calendar) AkonadiFuture::SerializerPluginKCal::deserialize: "" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Unable to deserialize payload part: "RFC822" korganizer(2883)/libakonadi Akonadi::ItemSerializer::deserialize: Payload data was: "" korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal): No IncidencePtr payload korganizer(2883)/kdepimlibs (kcal) KCal::ResourceCalendar::load: Done loading resource "akonadi calendar" korganizer(2883)/kdecore (KConfigSkeleton) KCoreConfigSkeleton::writeConfig: ingo@ingo-laptop:~$ korganizer(2883)/libakonadi Akonadi::Firstrun::~Firstrun: done korganizer(2883)/libakonadi Akonadi::SessionPrivate::dataReceived: Server protocol version is: 28 korganizer(2883)/kdepimlibs (kcal) KCal::ResourceAkonadi::subresources: ("akonadi:?collection=32", "akonadi:?collection=34", "akonadi:?collection=36") korganizer(2883)/kdepimlibs (kcal) KCal::ResourceAkonadi::subresources: ("akonadi:?collection=32", "akonadi:?collection=34", "akonadi:?collection=36") korganizer(2883)/kdepimlibs (kcal) KCal::ResourceAkonadi::subresources: ("akonadi:?collection=32", "akonadi:?collection=34", "akonadi:?collection=36") korganizer(2883)/kdepimlibs (kcal) KCal::ResourceAkonadi::subresources: ("akonadi:?collection=32", "akonadi:?collection=34", "akonadi:?collection=36") korganizer(2883)/kdepimlibs (kcal) KCal::ResourceAkonadi::subresources: ("akonadi:?collection=32", "akonadi:?collection=34", "akonadi:?collection=36") I guess from the above, that Akonadi cannot serialise the VCALENDAR information received, for whatever reason. As per my previous comment, the elemnt is returned correctly from the server. I have meanwhile recompiled the resource: NO CHANGE IN BEHAVIOUR. Build information below: ingo@ingo-laptop:/data/ingo/projects/kdepim-runtime$ make Scanning dependencies of target akonadi_davgroupware_resource_automoc Generating davitemdeletejob.moc Generating davitemfetchjob.moc Generating configdialog.moc Generating davgroupwareresource.moc Generating settings.moc Generating davitemcreatejob.moc Generating davitemmodifyjob.moc Generating davcollectionsmultifetchjob.moc Generating etagcache.moc Generating davcollectiondeletejob.moc Generating setupwizard.moc Generating davcollectionsfetchjob.moc Generating davitemslistjob.moc Generating moc_urlconfigurationdialog.cpp Generating moc_davitemsfetchjob.cpp Generating moc_davprincipalhomesetsfetchjob.cpp Generating moc_davcollectionmodifyjob.cpp [ 0%] Built target akonadi_davgroupware_resource_automoc Scanning dependencies of target akonadi_davgroupware_resource [ 2%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/akonadi_davgroupware_resource_automoc.o [ 5%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davcollection.o [ 8%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davcollectiondeletejob.o [ 11%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davcollectionsfetchjob.o [ 13%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davcollectionmodifyjob.o [ 16%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davcollectionsmultifetchjob.o [ 19%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davprotocolbase.o [ 22%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davitem.o [ 25%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davitemcreatejob.o [ 27%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davitemdeletejob.o [ 30%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davitemfetchjob.o [ 33%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davitemmodifyjob.o [ 36%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davitemsfetchjob.o [ 38%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davitemslistjob.o [ 41%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davmanager.o [ 44%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davmultigetprotocol.o [ 47%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davprincipalhomesetsfetchjob.o [ 50%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/davutils.o /data/ingo/projects/kdepim-runtime/resources/dav/common/davutils.cpp: In function ‘DavUtils::Protocol DavUtils::protocolByName(const QString&)’: /data/ingo/projects/kdepim-runtime/resources/dav/common/davutils.cpp:99: warning: ‘protocol’ may be used uninitialized in this function [ 52%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/common/etagcache.o [ 55%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/protocols/caldavprotocol.o [ 58%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/protocols/carddavprotocol.o [ 61%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/__/protocols/groupdavprotocol.o [ 63%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/configdialog.o [ 66%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/davgroupwareresource.o [ 69%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/davprotocolattribute.o [ 72%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/setupwizard.o [ 75%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/settings.o [ 77%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/urlconfigurationdialog.o [ 80%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/settingsbase.o [ 83%] Building CXX object resources/dav/resource/CMakeFiles/akonadi_davgroupware_resource.dir/settingsadaptor.o Linking CXX executable akonadi_davgroupware_resource [100%] Built target akonadi_davgroupware_resource Sooooo.... still walking in the pitch dark. Cheers, Ingo Hi Grégory, did you have a chance to look into this? Any chance that you could send me a binary copy of your version (I386)? Cheers, Ingo Hi Ingo, > did you have a chance to look into this? I still haven't managed to get the resource to compile on KUbuntu 10.10, mostly because I'm not familiar with this distro and can't find where to get the KCalCore headers. Where did you get yours from? If you give me the repo you used I'll be able to at least compile, which would be a great progress for this report :) > Any chance that you could send me a binary copy of your version (I386)? I'm developing and compiling in a non-standard location, and with trunk, so I doubt my binaries will help here. If I recompile the resource cleanly, no problems to send you this. Cheers, Grégory Official news: The groupdav resource only works with the latest version of KDE with a certain serialiser installed that - as I understand - ships as part of the kdepim-runtime lot. If you just install this resource without all the rest - it will not work and throw an exception. I have now backported all calls of KCalCore back to KCal. And I can confirm the resource is now working. Apart from the fact that it is useless in KOranaiser and Kontact because you cannot select the resource when adding events. I figured out that you can only select Akonadi resources, but no "folders" so to speak, which the groupdav resource represents - a folder with todos, tasks and addressbooks within it. Does that maybe needs a new Korganiser and Kontact as well? Hi Ingo, > I have now backported all calls of KCalCore back to KCal. And I can confirm the > resource is now working. Nice work :) > Apart from the fact that it is useless in KOranaiser and Kontact because you > cannot select the resource when adding events. I figured out that you can only > select Akonadi resources, but no "folders" so to speak, which the groupdav > resource represents - a folder with todos, tasks and addressbooks within it. > Does that maybe needs a new Korganiser and Kontact as well? Yes, the DAV resource stores all discovered collections (calendars, to-do lists, address books) under a common root, that is represented as a directory. KOrg 4.4.x and previous do not display the collections recursively. This requires a 4.6beta release. Hopefully RC1 will be tagged soon, giving you a more stable environment to work into than what may be the case with the latest beta. Cheers, Grégory |