(Created page with "== Introduction == The architecture decision to make the transition from Nokia-supported components for contacts and calendar data (PIM) storage, email storage and transports, a…") |
(→Data Synchronization) |
||
| Line 84: | Line 84: | ||
'''Step 1''': | '''Step 1''': | ||
* keep Buteo Sync Framework | * keep Buteo Sync Framework | ||
| - | * replace SyncML engine for Google Contact sync in Tablet with SyncEvolution + Synthesis: | + | * replace SyncML engine for Google Contact sync in Tablet with SyncEvolution + Synthesis: |
| + | ** The [http://meego.gitorious.org/meego-middleware/syncevolution/blobs/master/src/backends/buteo/ButeoBridge.cpp existing Buteo sync plugin] must also [https://bugs.meego.com/show_bug.cgi?id=15031 support Google Contacts]. No support for any other SyncML peer. This is the only SyncML peer which was tested with Buteo in MeeGo (done by the Intel Tablet team), so not supporting other SyncML peers in step 1 is not a regression. | ||
| + | ** [https://bugs.meego.com/show_bug.cgi?id=15030 Preserving local extensions] when synchronizing with Google depends on [https://bugs.meego.com/show_bug.cgi?id=15029 hard-coding capabilities of that peer] and [https://bugs.meego.com/show_bug.cgi?id=15030 support for unknown properties]. | ||
| + | ** Google Contact sync might run in parallel with CalDAV sync. The SyncEvolution sync plugin must support that. Must [https://bugs.meego.com/show_bug.cgi?id=681 replace global variables]. | ||
'''Step 2''': | '''Step 2''': | ||
Contents |
The architecture decision to make the transition from Nokia-supported components for contacts and calendar data (PIM) storage, email storage and transports, and sync back to the components used in MeeGo Netbook (Evolution Data Server and SyncEvolution) was announced publicly on March 7th. Planning the execution of that change is currently (end of March 2011) in progress.
This page gathers information about the PIM + mail storages and sync. Main author and point of contact is Patrick Ohly. It includes information contributed by various people, mentioned with email address below.
Information that has not been confirmed is marked with a question mark.
Maemo solution: QtMobility/QtOrganizer (API) + KCalCore (KDE) + modifications + mKCal (sqlite storage)
EDS: QtMobility/QtOrganizer (API) + libecal/libical (client side) + EDS (server side, stored in iCalendar 2.0 text file)
Used by: calendar app (Sirisha Muppavarapu), clock app (originally Todd Brandt, currently no active maintainer (?))
Advantages of mKCal:
Disadvantages of mKCal:
Plan:
Maemo solution: QtContacts (API) + QtContacts-Tracker (glue code) + Tracker (storage)
EDS: QtContacts (API) + libebook (client side) + EDS (server side, storage of vCards in Berkley DB)
Used by: libseaside/meego-app-contacts/meego-handset-people/ContactPicker.qml (Connie Berardi and [1]), SMS and Messaging apps (Ben Drucker), various parts of Tablet UX via QML binding, obexd for Phone Book Access Protocol (PBAP) plugin, libfolks)
Advantages of Tracker:
Disadvantages of Tracker:
Plan:
Opens:
Maemo solution: QtMobility/QtMessaging API + Qt Messaging Framework (QMF, actual implementation)
EDS: QMF-compatible API (?) + Camel library (part of EDS, but not running in the daemon itself yet)
Used by: mail app (Carl Wong), SMS storage plugin (Ben Drucker)
Advantages of QMF:
Plan A (details)
Plan B:
Maemo solution: Buteo Sync Framework, Buteo SyncML, Buteo Sync Plugins, Buteo Media Transfer Protocol (MTP)
Alternative: SyncEvolution, Synthesis SyncML, Buteo Media Transfer Protocol
Advantages of Buteo:
Disadvantages of Buteo:
Step 1:
Step 2:
Further improvements to SyncEvolution/MTP: