Difference between revisions of "Projects/PIM/RSS framework for Akonadi"

< Projects‎ | PIM
Jump to: navigation, search
(mark as done)
Line 6: Line 6:
* How to represent tagged items in the UI?
* How to represent tagged items in the UI?
* Can we share model code with Stephen's new (item) models?
* Can we share model code with Stephen's new (item) models?
* Feed* -> Feed::Id?
* Feed* -> Feed::Id? ''' - Dmitry, almost done'''
* Flattening the Feed class Hierarchy?
* Flattening the Feed class Hierarchy? ''' - done'''
* Expiry
* Expiry
* Trash?
* Trash?

Revision as of 12:54, 25 May 2009


Akonadi sprint notes

  • Roadmap?
  • Multiple resources
  • Profiling krss using real data and optimization
  • How to represent tagged items in the UI?
  • Can we share model code with Stephen's new (item) models?
  • Feed* -> Feed::Id? - Dmitry, almost done
  • Flattening the Feed class Hierarchy? - done
  • Expiry
  • Trash?
  • Filtering
  • Icons (see below)

Akonadi wishlist:

  • Batch jobs
  • Search

Needs research

  • What are possible settings for the resource?
  • Read up on OPML/RSS/Atom spec (+ on the itunes podcast extension so we can set appropriate attributes; other extensions?)
  • Possible Nepomuk RSS ontology (I found one on the web, not sure if it's correct)


  • Akonadi (default) tag provider (Dmitry, in process) - basically done but the resource needs adaptation
  • Use Tag class everywhere (Dmitry, in process) - done
  • Refactor the chain: KRss::Item should hold Akonadi::Item which in turn should hold KRss::ItemPayload (as payload) and make the RSS serializer plugin work with KRss::ItemPayload instead of KRss::Item (Dmitry) - done
  • Finish the virtual RSS resource for managing virtual/search RSS feeds (Dmitry. The code floats around somewhere on my disk. There were two blockers on the Akonadi side - the DBus deadlocks and support for link/unlink jobs - which are finally resolved)
  • Proper handling of icons in feed/item/tag classes (Dmitry)
  • Replace the hard-coded values with consts ("application/rss+xml" and so on) (Dmitry)
  • Use stl algorithms instead of Q_FOREACH (Dmitry)
  • Split the item into 2 parts: Headers and Content (Dmitry) - done
  • If the resource was not configured by the user (for example when migrating the feedlist from Akregator) create a new OPML file in the default location (somewhere in .kde/share/apps/)
  • BUG: when configuring the resource, tags are not imported from the OPML document (maybe it makes sense to have an option 'Import categories and folders as tags')
  • Make TreeNode public and pass it around by shared_ptr and kill AbstractFeed* classes (WIP)
  • Don't use Akonadi IDs in the public interfaces
  • Replace Akonadi::ItemFetchScope with our own ItemFetchScope
  • BUG: Make the Akonadi RSS (de)serializer plugin more reliable wrt empty items - done
  • BUG: content of the item gets erased when attaching a tag to it
  • Fine-tune monitoring as it affects the performance of the library a lot
  • Add FetchFeedJob test
  • Add ExportOpmlJob test
  • ItemDeleteJob should only mark items as deleted and probably hardlink them into 'Trash' virtual collection

Long-term project goals

  • Port Akregator to this framework
  • Create a generic RSS Akonadi resource that allows to easily add other types of RSS sources (RSS feeds from an Openchange server, online feed readers)
  • Implement an RSS resource for the Newsgator.com online reader
  • Get KDE4/Akonadi/this RSS framework up and running on my N800 so I can *finally* read feeds everywhere and sync them via NG.com

Bugs to track down

  • aboutToQuit() is not called when manually removing the resource via akonadiconsole (tracked down). aboutToQuit() is called from within AgentBase::quit() so it's invoked only in the second case:
    • When removing a resource via akonadiconsole the calling sequence is:
      • AgentManager::removeInstance(instance)
      • org::freedesktop::Akonadi::AgentManager::removeAgentInstance(id) - via D-Bus
      • org::freedesktop::Akonadi::Agent::Control::cleanup() - via D-Bus
    • When removing a resource at 'akonadictl stop' the calling sequence is:
      • org::freedesktop::Akonadi::AgentManager::~AgentManager() - from akonadictl
      • org::freedesktop::Akonadi::AgentManager::AgentManager::cleanup()
      • org::freedesktop::Akonadi::Agent::Control::quit() - via D-Bus for every agent

Akonadi wishlist

Now at the core TODO-List

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V.Legal