aboutsummaryrefslogtreecommitdiffstats
path: root/mail/em-folder-utils.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/em-folder-utils.c')
-rw-r--r--mail/em-folder-utils.c54
1 files changed, 37 insertions, 17 deletions
diff --git a/mail/em-folder-utils.c b/mail/em-folder-utils.c
index 686750a8c7..8302cebef7 100644
--- a/mail/em-folder-utils.c
+++ b/mail/em-folder-utils.c
@@ -339,24 +339,31 @@ emfu_copy_folder_selected (EMailSession *session,
gpointer data)
{
struct _copy_folder_data *cfd = data;
+ CamelProvider *provider, *toprovider;
CamelStore *tostore = NULL;
- CamelService *service;
- gboolean store_is_local;
- const gchar *uid;
+ CamelService *service, *toservice;
+ gboolean store_is_local, tostore_is_local, session_is_online;
gchar *tobase = NULL;
GError *local_error = NULL;
if (uri == NULL)
goto fail;
+ session_is_online = camel_session_get_online (CAMEL_SESSION (session));
+
service = CAMEL_SERVICE (cfd->source_store);
- camel_service_connect_sync (service, NULL, &local_error);
+ provider = camel_service_get_provider (service);
+ store_is_local = (provider->flags & CAMEL_PROVIDER_IS_LOCAL) != 0;
+
+ e_mail_folder_uri_parse (
+ CAMEL_SESSION (session), uri,
+ &tostore, &tobase, &local_error);
if (local_error != NULL) {
e_alert_submit (
alert_sink, cfd->delete ?
- "mail:no-move-folder-nostore" :
- "mail:no-copy-folder-nostore",
+ "mail:no-move-folder-to-nostore" :
+ "mail:no-copy-folder-to-nostore",
cfd->source_folder_name, uri,
local_error->message, NULL);
goto fail;
@@ -364,8 +371,29 @@ emfu_copy_folder_selected (EMailSession *session,
g_return_if_fail (CAMEL_IS_STORE (service));
- uid = camel_service_get_uid (CAMEL_SERVICE (cfd->source_store));
- store_is_local = (g_strcmp0 (uid, E_MAIL_SESSION_LOCAL_UID) == 0);
+ toservice = CAMEL_SERVICE (tostore);
+ toprovider = camel_service_get_provider (toservice);
+ tostore_is_local = (toprovider->flags & CAMEL_PROVIDER_IS_LOCAL) != 0;
+
+ if (!session_is_online && (!store_is_local || !tostore_is_local)) {
+ e_alert_submit (
+ alert_sink,
+ "mail:online-operation",
+ store_is_local ? uri : cfd->source_folder_name,
+ NULL);
+ goto fail;
+ }
+
+ camel_service_connect_sync (service, NULL, &local_error);
+ if (local_error != NULL) {
+ e_alert_submit (
+ alert_sink, cfd->delete ?
+ "mail:no-move-folder-nostore" :
+ "mail:no-copy-folder-nostore",
+ cfd->source_folder_name, uri,
+ local_error->message, NULL);
+ goto fail;
+ }
if (cfd->delete && store_is_local &&
emfu_is_special_local_folder (cfd->source_folder_name)) {
@@ -376,15 +404,7 @@ emfu_copy_folder_selected (EMailSession *session,
goto fail;
}
- if (!e_mail_folder_uri_parse (
- CAMEL_SESSION (session), uri,
- &tostore, &tobase, &local_error))
- tostore = NULL;
-
- if (tostore != NULL)
- camel_service_connect_sync (
- CAMEL_SERVICE (tostore), NULL, &local_error);
-
+ camel_service_connect_sync (toservice, NULL, &local_error);
if (local_error != NULL) {
e_alert_submit (
alert_sink, cfd->delete ?