aboutsummaryrefslogtreecommitdiffstats
path: root/mail/e-mail-backend.c
diff options
context:
space:
mode:
authorMilan Crha <mcrha@redhat.com>2012-09-05 21:41:16 +0800
committerMilan Crha <mcrha@redhat.com>2012-09-05 21:42:03 +0800
commit511acab89a83114aad35e9c6f76a8f284907dab9 (patch)
tree4455567f90a3708dc43b172491388daf0f8c590e /mail/e-mail-backend.c
parent86c5e71225cda76616a5a5d5cfba46b84351b863 (diff)
downloadgsoc2013-evolution-511acab89a83114aad35e9c6f76a8f284907dab9.tar
gsoc2013-evolution-511acab89a83114aad35e9c6f76a8f284907dab9.tar.gz
gsoc2013-evolution-511acab89a83114aad35e9c6f76a8f284907dab9.tar.bz2
gsoc2013-evolution-511acab89a83114aad35e9c6f76a8f284907dab9.tar.lz
gsoc2013-evolution-511acab89a83114aad35e9c6f76a8f284907dab9.tar.xz
gsoc2013-evolution-511acab89a83114aad35e9c6f76a8f284907dab9.tar.zst
gsoc2013-evolution-511acab89a83114aad35e9c6f76a8f284907dab9.zip
Bug #682425 - Can do network operations on disabled accounts
Diffstat (limited to 'mail/e-mail-backend.c')
-rw-r--r--mail/e-mail-backend.c91
1 files changed, 42 insertions, 49 deletions
diff --git a/mail/e-mail-backend.c b/mail/e-mail-backend.c
index 81a16ed745..251bce953a 100644
--- a/mail/e-mail-backend.c
+++ b/mail/e-mail-backend.c
@@ -137,14 +137,25 @@ mail_backend_prepare_for_offline_cb (EShell *shell,
{
GtkWindow *window;
EMailSession *session;
- ESourceRegistry *registry;
- GList *list, *link;
- const gchar *extension_name;
+ EMailAccountStore *account_store;
+ GQueue queue = G_QUEUE_INIT;
gboolean synchronize = FALSE;
+ if (e_shell_backend_is_started (E_SHELL_BACKEND (backend))) {
+ if (!e_activity_get_cancellable (activity)) {
+ GCancellable *cancellable;
+
+ cancellable = camel_operation_new ();
+ e_activity_set_cancellable (activity, cancellable);
+ g_object_unref (cancellable);
+ }
+
+ e_shell_backend_add_activity (E_SHELL_BACKEND (backend), activity);
+ }
+
window = e_shell_get_active_window (shell);
session = e_mail_backend_get_session (backend);
- registry = e_mail_session_get_registry (session);
+ account_store = e_mail_ui_session_get_account_store (E_MAIL_UI_SESSION (session));
if (e_shell_get_network_available (shell) &&
e_shell_backend_is_started (E_SHELL_BACKEND (backend)))
@@ -157,34 +168,21 @@ mail_backend_prepare_for_offline_cb (EShell *shell,
CAMEL_SESSION (session), FALSE);
}
- extension_name = E_SOURCE_EXTENSION_MAIL_ACCOUNT;
- list = e_source_registry_list_sources (registry, extension_name);
-
- for (link = list; link != NULL; link = g_list_next (link)) {
- ESource *source = E_SOURCE (link->data);
+ e_mail_account_store_queue_enabled_services (account_store, &queue);
+ while (!g_queue_is_empty (&queue)) {
CamelService *service;
- const gchar *uid;
-
- uid = e_source_get_uid (source);
- service = camel_session_ref_service (
- CAMEL_SESSION (session), uid);
+ service = g_queue_pop_head (&queue);
if (service == NULL)
continue;
- /* FIXME Not passing a GCancellable. */
if (CAMEL_IS_STORE (service))
e_mail_store_go_offline (
- CAMEL_STORE (service),
- G_PRIORITY_DEFAULT,
- NULL, (GAsyncReadyCallback)
- mail_backend_store_operation_done_cb,
+ CAMEL_STORE (service), G_PRIORITY_DEFAULT,
+ e_activity_get_cancellable (activity),
+ (GAsyncReadyCallback) mail_backend_store_operation_done_cb,
g_object_ref (activity));
-
- g_object_unref (service);
}
-
- g_list_free_full (list, (GDestroyNotify) g_object_unref);
}
static void
@@ -193,46 +191,41 @@ mail_backend_prepare_for_online_cb (EShell *shell,
EMailBackend *backend)
{
EMailSession *session;
- ESourceRegistry *registry;
- GList *list, *link;
- const gchar *extension_name;
+ EMailAccountStore *account_store;
+ GQueue queue = G_QUEUE_INIT;
- session = e_mail_backend_get_session (backend);
- registry = e_mail_session_get_registry (session);
+ if (e_shell_backend_is_started (E_SHELL_BACKEND (backend))) {
+ if (!e_activity_get_cancellable (activity)) {
+ GCancellable *cancellable;
- camel_session_set_online (CAMEL_SESSION (session), TRUE);
+ cancellable = camel_operation_new ();
+ e_activity_set_cancellable (activity, cancellable);
+ g_object_unref (cancellable);
+ }
- extension_name = E_SOURCE_EXTENSION_MAIL_ACCOUNT;
- list = e_source_registry_list_sources (registry, extension_name);
+ e_shell_backend_add_activity (E_SHELL_BACKEND (backend), activity);
+ }
- for (link = list; link != NULL; link = g_list_next (link)) {
- ESource *source = E_SOURCE (link->data);
- CamelService *service;
- const gchar *uid;
+ session = e_mail_backend_get_session (backend);
+ account_store = e_mail_ui_session_get_account_store (E_MAIL_UI_SESSION (session));
- if (!e_source_get_enabled (source))
- continue;
+ camel_session_set_online (CAMEL_SESSION (session), TRUE);
- uid = e_source_get_uid (source);
- service = camel_session_ref_service (
- CAMEL_SESSION (session), uid);
+ e_mail_account_store_queue_enabled_services (account_store, &queue);
+ while (!g_queue_is_empty (&queue)) {
+ CamelService *service;
+ service = g_queue_pop_head (&queue);
if (service == NULL)
continue;
- /* FIXME Not passing a GCancellable. */
if (CAMEL_IS_STORE (service))
e_mail_store_go_online (
- CAMEL_STORE (service),
- G_PRIORITY_DEFAULT,
- NULL, (GAsyncReadyCallback)
- mail_backend_store_operation_done_cb,
+ CAMEL_STORE (service), G_PRIORITY_DEFAULT,
+ e_activity_get_cancellable (activity),
+ (GAsyncReadyCallback) mail_backend_store_operation_done_cb,
g_object_ref (activity));
-
- g_object_unref (service);
}
-
- g_list_free_full (list, (GDestroyNotify) g_object_unref);
}
/* Helper for mail_backend_prepare_for_quit_cb() */