m (→Contact Storage) |
(→Contact Storage) |
||
| (7 intermediate revisions not shown) | |||
| Line 7: | Line 7: | ||
Information that has not been confirmed is marked with a question mark. | Information that has not been confirmed is marked with a question mark. | ||
| + | [[File:Qtcontacts-kcal-eds.png]] | ||
== Calendar Storage == | == Calendar Storage == | ||
| - | '''Maemo solution''': QtMobility/QtOrganizer (API) + KCalCore ( | + | '''Maemo solution''': QtMobility/QtOrganizer (API) + KCalCore (MeeGo) + modifications + mKCal (sqlite storage)<br> |
| - | '''EDS proposal''': QtMobility/QtOrganizer (API) + [[/ | + | '''EDS proposal''': QtMobility/QtOrganizer (API) + KCalCore (KDE-compatible) + [[/KCal-EDS/]] + libecal/libical (client side) + EDS (server side, stored in iCalendar 2.0 text file)<br> |
'''Used by''': calendar app ([mailto:sirisha.muppavarapu@intel.com Sirisha Muppavarapu]), clock app (originally [mailto:todd.e.brandt@intel.com Todd Brandt]) | '''Used by''': calendar app ([mailto:sirisha.muppavarapu@intel.com Sirisha Muppavarapu]), clock app (originally [mailto:todd.e.brandt@intel.com Todd Brandt]) | ||
| Line 21: | Line 22: | ||
Plan: | Plan: | ||
| - | * use upstream KDE version of KCalCore (current MeeGo version has semantic differences in event->dtEnd()) | + | * use upstream KDE version of KCalCore (current MeeGo version has semantic differences in event->dtEnd()), with those changes that are necessary to run in MeeGo (embedded KDateTime, timed integration) |
| - | * write [[/ | + | * write [[/KCal-EDS|storage which uses libecal/EDS]] |
* [[/eds-improvements|EDS improvements]] | * [[/eds-improvements|EDS improvements]] | ||
== Contact Storage == | == Contact Storage == | ||
| - | '''Maemo solution''': QtContacts (API) + QtContacts-Tracker ( | + | '''Maemo solution''': QtContacts (API) + QtContacts-Tracker (mapping to storage, searching) + Tracker (storage) + contactsd (updating presence information in Tracker)<br> |
'''EDS proposal''': QtContacts (API) + [[/QtContacts storage plugin|QtContacts-EDS]] + libebook (client side) + EDS (server side, storage of vCards in Berkley DB); libfolks as replacement for contactsd<br> | '''EDS proposal''': QtContacts (API) + [[/QtContacts storage plugin|QtContacts-EDS]] + libebook (client side) + EDS (server side, storage of vCards in Berkley DB); libfolks as replacement for contactsd<br> | ||
| - | '''Used by''': libseaside/meego-app-contacts/meego-handset-people/ContactPicker.qml ([mailto:connie.berardi@intel.com Connie Berardi] and [mailto:kaitlin.rupert@intel.com]), SMS and Messaging apps ([mailto:benjamin.t.drucker@intel.com Ben Drucker]), various parts of Tablet UX via QML binding, obexd for Phone Book Access Protocol (PBAP) plugin)<br> | + | '''Used by''': libseaside/meego-app-contacts/meego-handset-people/ContactPicker.qml ([mailto:connie.berardi@intel.com Connie Berardi] and [mailto:kaitlin.rupert@intel.com Kaitlin Rupert]), SMS and Messaging apps ([mailto:benjamin.t.drucker@intel.com Ben Drucker]), various parts of Tablet UX via QML binding, obexd for Phone Book Access Protocol (PBAP) plugin)<br> |
'''Advantages of Tracker''': | '''Advantages of Tracker''': | ||
| Line 59: | Line 60: | ||
* already works as a stand-alone daemon | * already works as a stand-alone daemon | ||
| - | '''Plan A [[/ | + | '''Plan A [[/email-design|(details)]]''' |
* kudos to [mailto:srinivasa.ragavan.venkateswaran@intel.com Srinivasa (Srini) Venkateswaran] for this proposal | * kudos to [mailto:srinivasa.ragavan.venkateswaran@intel.com Srinivasa (Srini) Venkateswaran] for this proposal | ||
* write simplistic server which runs Camel | * write simplistic server which runs Camel | ||
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 (MeeGo) + modifications + mKCal (sqlite storage)
EDS proposal: QtMobility/QtOrganizer (API) + KCalCore (KDE-compatible) + KCal-EDS + 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)
Advantages of mKCal:
Disadvantages of mKCal (current implementation):
Plan:
Maemo solution: QtContacts (API) + QtContacts-Tracker (mapping to storage, searching) + Tracker (storage) + contactsd (updating presence information in Tracker)
EDS proposal: QtContacts (API) + QtContacts-EDS + libebook (client side) + EDS (server side, storage of vCards in Berkley DB); libfolks as replacement for contactsd
Used by: libseaside/meego-app-contacts/meego-handset-people/ContactPicker.qml (Connie Berardi and Kaitlin Rupert), SMS and Messaging apps (Ben Drucker), various parts of Tablet UX via QML binding, obexd for Phone Book Access Protocol (PBAP) plugin)
Advantages of Tracker:
Disadvantages of Tracker:
Plan:
Opens:
Maemo solution: QtMobility/QtMessaging (API) + Qt Messaging Framework (QMF, actual implementation)
EDS proposal: QtMobility/QtMessaging (API) + 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)
Some possible variations of plan A:
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: