Meego Wiki
Views

Architecture/planning/evolution-data-server/QtContacts storage plugin

From MeeGo wiki
(Difference between revisions)
Jump to: navigation, search
Line 31: Line 31:
* [[http://bugreports.qt.nokia.com/browse/QTMOBILITY-1590 QTMOBILITY-1590]] QtVersit contact importer does not follow RFC-2426 for LOGO/PHOTO value
* [[http://bugreports.qt.nokia.com/browse/QTMOBILITY-1590 QTMOBILITY-1590]] QtVersit contact importer does not follow RFC-2426 for LOGO/PHOTO value
* [[http://bugreports.qt.nokia.com/browse/QTMOBILITY-1589 QTMOBILITY-1589]] QtVersit writes/reads QContactGeoLocation's latitude/longitude in reverse order (Compared to RFC-2426 and libebook)
* [[http://bugreports.qt.nokia.com/browse/QTMOBILITY-1589 QTMOBILITY-1589]] QtVersit writes/reads QContactGeoLocation's latitude/longitude in reverse order (Compared to RFC-2426 and libebook)
-
* [[https://bugzilla.gnome.org/show_bug.cgi?id=650952 GNOME #650952]] EDS displays misleading warnings such as "libebook-WARNING **: unknown field name `X-GENDER'"
+
* [[https://bugzilla.gnome.org/show_bug.cgi?id=650952 GNOME #650952]] EDS displays misleading warnings such as "libebook-WARNING **: unknown field name `X-GENDER'" (NO FEEDBACK - MINOR)
-
* [[https://bugzilla.gnome.org/show_bug.cgi?id=650950 GNOME #650950]] EDS: Queries should iterate over all attributes with the same name for proper matching
+
* [[https://bugzilla.gnome.org/show_bug.cgi?id=650950 GNOME #650950]] EDS: Queries should iterate over all attributes with the same name for proper matching (ACCEPTED UPSTREAM)
-
* [[https://bugzilla.gnome.org/show_bug.cgi?id=651054 GNOME #651054]] EDS: Support queries based on "photo" contact field. This is needed for EDS-side QContactAvatar::FieldImageUrl filtering.
+
* [[https://bugzilla.gnome.org/show_bug.cgi?id=651054 GNOME #651054]] EDS: Support queries based on "photo" contact field. This is needed for EDS-side QContactAvatar::FieldImageUrl filtering. (ACCEPTED UPSTREAM)
 +
* [[https://bugzilla.gnome.org/show_bug.cgi?id=651113 GNOME #651113]] EDS: Support queries based on date field (e.g. birthday, anniversary).

Revision as of 07:18, 26 May 2011

QtContacts-EDS

Can be based on [existing Harmattan EDS plugin], which does not work as-is because of Nokia-specific API extensions.

Necessary changes:

  • avoid ID mapping because it requires reading all contacts at startup:
    • must change EDS to use 32 bit integers as local IDs for that (patch ready)
    • QtContacts-EDS supports (collision-safe) ID hashing as fallback if EDS is not patched (Define USE_ID_HASHING at compilation time to enable)
  • convert between QtContacts and vCard using QtVersit, with EDS specific properties and including custom properties for QtContactDetails which have no other mapping to vCard (same approach as in SyncEvolution QtContacts backend)

Goals for initial milestone:

  • full support for all QContactDetails, including custom ones and additional fields of details which map to well-known vCard properties (QContactUrl::SubTypeFavourite, QContactAvatar::videoUrl, QContactOrganization::FieldLocation...)
    • QContactGeoLocation detail is not interoperable with libebook/EDS because QtVersit reverses latitude/longitude in the vCard [QTMOBILITY-1589]
    • QContactOnlineAccount is not interoperable with libebook/EDS (not direct equivalent is available in vCard)
    • There does not seem to be any equivalent for X-EVOLUTION-MANAGER in QtContacts, no mapping is done for this extension
    • QContactOrganization::FieldDepartment is not fully interoperable with libebook/EDS (libebook can only parse one department)
    • QContactOrganization does not have any API for binary (QImage) organization logo (Only URL: QContactOrganization::FieldLocation) but libebook supports both
    • The following details are not interoperable with libebook/EDS (but they can be saved): QContactGender, QContactFamily::FieldChildren (X-CHILDREN), QContactGlobalPresence, QContactFavorite, QContactHobby, QContactPresence, QContactRingtone, QContactSyncTarget.
  • change notifications (added/updated/removed)
    • There does not seem to be any signal in ebook view for selfContactIdChange?
  • mapping of QtContacts filters to EDS queries, with unsupported filters implemented by QtContacts after retrieving contacts (slower than filtering in EDS daemon)
    • TODO: complete list of native searches
  • Errors are properly handled and reported to the client application

Goals for later milestones:

  • performance

Related bugs:

  • [QTMOBILITY-1298] QtVersit does not allow custom properties to have complex types
  • [QTMOBILITY-1592] QContactManagerEngine schema definitions are incomplete
  • [QTMOBILITY-1590] QtVersit contact importer does not follow RFC-2426 for LOGO/PHOTO value
  • [QTMOBILITY-1589] QtVersit writes/reads QContactGeoLocation's latitude/longitude in reverse order (Compared to RFC-2426 and libebook)
  • [GNOME #650952] EDS displays misleading warnings such as "libebook-WARNING **: unknown field name `X-GENDER'" (NO FEEDBACK - MINOR)
  • [GNOME #650950] EDS: Queries should iterate over all attributes with the same name for proper matching (ACCEPTED UPSTREAM)
  • [GNOME #651054] EDS: Support queries based on "photo" contact field. This is needed for EDS-side QContactAvatar::FieldImageUrl filtering. (ACCEPTED UPSTREAM)
  • [GNOME #651113] EDS: Support queries based on date field (e.g. birthday, anniversary).
Personal tools