diff options
Diffstat (limited to 'plugins/groupwise-account-setup')
-rw-r--r-- | plugins/groupwise-account-setup/camel-gw-listener.c | 177 |
1 files changed, 117 insertions, 60 deletions
diff --git a/plugins/groupwise-account-setup/camel-gw-listener.c b/plugins/groupwise-account-setup/camel-gw-listener.c index 09c36fa9fe..cbfbb233b6 100644 --- a/plugins/groupwise-account-setup/camel-gw-listener.c +++ b/plugins/groupwise-account-setup/camel-gw-listener.c @@ -30,6 +30,7 @@ #include "camel-i18n.h" #include <e-gw-connection.h> #include <e-passwords.h> +#include "widgets/misc/e-error.h" /*stores some info about all currently existing groupwise accounts list of GwAccountInfo structures */ @@ -252,9 +253,13 @@ modify_esource (const char* conf_key, GwAccountInfo *old_account_info, const cha CamelURL *url; gboolean found_group; GConfClient* client; - + const char *poa_address; + url = camel_url_new (old_account_info->source_url, NULL); - old_relative_uri = g_strdup_printf ("%s@%s/", url->user, url->host); + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; + old_relative_uri = g_strdup_printf ("%s@%s/", url->user, poa_address); client = gconf_client_get_default (); list = e_source_list_new_for_gconf (client, conf_key); groups = e_source_list_peek_groups (list); @@ -305,13 +310,24 @@ add_calendar_tasks_sources (GwAccountInfo *info) char *relative_uri; const char *soap_port; const char * use_ssl; - + const char *poa_address; + url = camel_url_new (info->source_url, NULL); + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; soap_port = camel_url_get_param (url, "soap_port"); + if (!soap_port || strlen (soap_port) == 0) soap_port = "7181"; - use_ssl = camel_url_get_param (url, "use_ssl"); - relative_uri = g_strdup_printf ("%s@%s/", url->user, url->host); + + use_ssl = camel_url_get_param (url, "soap_ssl"); + if (use_ssl) + use_ssl = "always"; + else + use_ssl = NULL; + + relative_uri = g_strdup_printf ("%s@%s/", url->user, poa_address); add_esource ("/apps/evolution/calendar/sources", info->name, _("Calendar"), url->user, relative_uri, soap_port, use_ssl); add_esource ("/apps/evolution/tasks/sources", info->name, _("Checklist"), url->user, relative_uri, soap_port, use_ssl); @@ -329,12 +345,19 @@ remove_calendar_tasks_sources (GwAccountInfo *info) CamelURL *url; char *relative_uri; const char *soap_port; + const char *poa_address; url = camel_url_new (info->source_url, NULL); + + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; + soap_port = camel_url_get_param (url, "soap_port"); if (!soap_port || strlen (soap_port) == 0) soap_port = "7181"; - relative_uri = g_strdup_printf ("%s@%s/", url->user, url->host); + + relative_uri = g_strdup_printf ("%s@%s/", url->user, poa_address); remove_esource ("/apps/evolution/calendar/sources", info->name, _("Calendar"), relative_uri); remove_esource ("/apps/evolution/tasks/sources", info->name, _("Checklist"), relative_uri); camel_url_free (url); @@ -357,51 +380,57 @@ get_addressbook_names_from_server (char *source_url) char *prompt; char *uri; const char *use_ssl; + const char *poa_address; url = camel_url_new (source_url, NULL); if (url == NULL) { return NULL; } + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return NULL; + soap_port = camel_url_get_param (url, "soap_port"); if (!soap_port || strlen (soap_port) == 0) soap_port = "7181"; - use_ssl = camel_url_get_param (url, "use_ssl"); - key = g_strdup_printf ("groupwise://%s@%s/", url->user, url->host); + use_ssl = camel_url_get_param (url, "soap_ssl"); + key = g_strdup_printf ("groupwise://%s@%s/", url->user, poa_address); if (use_ssl) - uri = g_strdup_printf ("https://%s:%s/soap", url->host, soap_port); + uri = g_strdup_printf ("https://%s:%s/soap", poa_address, soap_port); else - uri = g_strdup_printf ("http://%s:%s/soap", url->host, soap_port); + uri = g_strdup_printf ("http://%s:%s/soap", poa_address, soap_port); failed_auth = ""; + cnc = NULL; do { prompt = g_strdup_printf (_("%sEnter password for %s (user %s)"), - failed_auth, url->host, url->user); + failed_auth, poa_address, url->user); password = e_passwords_ask_password (prompt, "Groupwise", key, prompt, TRUE, E_PASSWORDS_REMEMBER_FOREVER, &remember, NULL); g_free (prompt); - /*FIXME warn user that he can not get all his address books if he cancels */ - if (!password) - return NULL; + + if (!password) + break; cnc = e_gw_connection_new (uri, url->user, password); failed_auth = _("Failed to authenticate.\n"); } while (cnc == NULL); - + if (E_IS_GW_CONNECTION(cnc)) { book_list = NULL; status = e_gw_connection_get_address_book_list (cnc, &book_list); if (status == E_GW_CONNECTION_STATUS_OK) return book_list; - else - return NULL; + + } - - + e_error_run (NULL, "mail:gw-accountsetup-error", poa_address, NULL); + return NULL; } -static void +static gboolean add_addressbook_sources (EAccount *account) { CamelURL *url; @@ -413,54 +442,51 @@ add_addressbook_sources (EAccount *account) GList *books_list, *temp_list; GConfClient* client; const char* use_ssl; - + const char *poa_address; + + url = camel_url_new (account->source->url, NULL); if (url == NULL) { - return; + return FALSE; } + + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return FALSE; + soap_port = camel_url_get_param (url, "soap_port"); if (!soap_port || strlen (soap_port) == 0) soap_port = "7181"; - use_ssl = camel_url_get_param (url, "use_ssl"); - base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, url->host); + use_ssl = camel_url_get_param (url, "soap_ssl"); + base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, poa_address); client = gconf_client_get_default (); list = e_source_list_new_for_gconf (client, "/apps/evolution/addressbook/sources" ); group = e_source_group_new (account->name, base_uri); books_list = get_addressbook_names_from_server (account->source->url); - if (! books_list) { - source = e_source_new ("Frequent Contacts", g_strconcat (";", "Frequent Contacts", NULL)); + temp_list = books_list; + if (!temp_list) + return FALSE; + for (; temp_list != NULL; temp_list = g_list_next (temp_list)) { + const char *book_name = e_gw_container_get_name (E_GW_CONTAINER(temp_list->data)); + source = e_source_new (book_name, g_strconcat (";",book_name, NULL)); e_source_set_property (source, "auth", "plain/password"); + e_source_set_property (source, "auth-domain", "Groupwise"); e_source_set_property (source, "port", soap_port); e_source_set_property(source, "user", url->user); - e_source_set_property (source, "auth-domain", "Groupwise"); - e_source_set_property (source, "completion", "true"); + + if (!e_gw_container_get_is_writable (E_GW_CONTAINER(temp_list->data))) + e_source_set_property (source, "completion", "true"); + if (e_gw_container_get_is_frequent_contacts (E_GW_CONTAINER(temp_list->data))) + e_source_set_property (source, "completion", "true"); e_source_set_property (source, "use_ssl", use_ssl); e_source_group_add_source (group, source, -1); g_object_unref (source); - } else { + g_object_unref (E_GW_CONTAINER(temp_list->data)); - temp_list = books_list; - for (; temp_list != NULL; temp_list = g_list_next (temp_list)) { - const char *book_name = e_gw_container_get_name (E_GW_CONTAINER(temp_list->data)); - source = e_source_new (book_name, g_strconcat (";",book_name, NULL)); - e_source_set_property (source, "auth", "plain/password"); - e_source_set_property (source, "auth-domain", "Groupwise"); - e_source_set_property (source, "port", soap_port); - e_source_set_property(source, "user", url->user); - - if (!e_gw_container_get_is_writable (E_GW_CONTAINER(temp_list->data))) - e_source_set_property (source, "completion", "true"); - if (e_gw_container_get_is_frequent_contacts (E_GW_CONTAINER(temp_list->data))) - e_source_set_property (source, "completion", "true"); - e_source_set_property (source, "use_ssl", use_ssl); - e_source_group_add_source (group, source, -1); - g_object_unref (source); - g_object_unref (E_GW_CONTAINER(temp_list->data)); - - } - - g_list_free (books_list); } + + g_list_free (books_list); + e_source_list_add_group (list, group, -1); e_source_list_sync (list, NULL); @@ -468,6 +494,8 @@ add_addressbook_sources (EAccount *account) g_object_unref (list); g_object_unref (client); g_free (base_uri); + + return TRUE; } static void @@ -486,23 +514,31 @@ modify_addressbook_sources ( EAccount *account, GwAccountInfo *existing_account_ GSList *sources; ESource *source; GConfClient *client; + const char *poa_address; url = camel_url_new (existing_account_info->source_url, NULL); if (url == NULL) { return; } - old_base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, url->host); + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; + + old_base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, poa_address); camel_url_free (url); url = camel_url_new (account->source->url, NULL); if (url == NULL) return ; - new_base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, url->host); + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; + new_base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, poa_address); soap_port = camel_url_get_param (url, "soap_port"); if (!soap_port || strlen (soap_port) == 0) soap_port = "7181"; - use_ssl = camel_url_get_param (url, "use_ssl"); + use_ssl = camel_url_get_param (url, "soap_ssl"); client = gconf_client_get_default (); list = e_source_list_new_for_gconf (client, "/apps/evolution/addressbook/sources" ); @@ -558,14 +594,21 @@ remove_addressbook_sources (GwAccountInfo *existing_account_info) char *base_uri; const char *soap_port; GConfClient *client; + const char *poa_address; + url = camel_url_new (existing_account_info->source_url, NULL); if (url == NULL) { return; } + + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; + soap_port = camel_url_get_param (url, "soap_port"); if (!soap_port || strlen (soap_port) == 0) soap_port = "7181"; - base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, url->host); + base_uri = g_strdup_printf ("groupwise://%s@%s", url->user, poa_address); client = gconf_client_get_default (); list = e_source_list_new_for_gconf (client, "/apps/evolution/addressbook/sources" ); groups = e_source_list_peek_groups (list); @@ -598,6 +641,8 @@ account_added (EAccountList *account_listener, EAccount *account) { GwAccountInfo *info; + gboolean status; + if (!is_groupwise_account (account)) return; @@ -605,8 +650,9 @@ account_added (EAccountList *account_listener, EAccount *account) info->uid = g_strdup (account->uid); info->name = g_strdup (account->name); info->source_url = g_strdup (account->source->url); - add_calendar_tasks_sources (info); - add_addressbook_sources (account); + status = add_addressbook_sources (account); + if (status) + add_calendar_tasks_sources (info); groupwise_accounts = g_list_append (groupwise_accounts, info); } @@ -645,7 +691,8 @@ account_changed (EAccountList *account_listener, EAccount *account) const char *soap_port; GwAccountInfo *existing_account_info; const char *use_ssl; - + const char *poa_address; + is_gw_account = is_groupwise_account (account); existing_account_info = lookup_account_info (account->uid); @@ -669,15 +716,25 @@ account_changed (EAccountList *account_listener, EAccount *account) /* some info of groupwise account is changed . update the sources with new info if required */ url = camel_url_new (existing_account_info->source_url, NULL); - old_relative_uri = g_strdup_printf ("%s@%s/", url->user, url->host); + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; + old_relative_uri = g_strdup_printf ("%s@%s/", url->user, poa_address); camel_url_free (url); url = camel_url_new (account->source->url, NULL); + + poa_address = camel_url_get_param (url, "poa"); + if (!poa_address || strlen (poa_address) ==0) + return; soap_port = camel_url_get_param (url, "soap_port"); if (!soap_port || strlen (soap_port) == 0) soap_port = "7181"; - use_ssl = camel_url_get_param (url, "use_ssl"); - relative_uri = g_strdup_printf ("%s@%s/", url->user, url->host); + use_ssl = camel_url_get_param (url, "soap_ssl"); + if (use_ssl) + use_ssl = "always"; + + relative_uri = g_strdup_printf ("%s@%s/", url->user, poa_address); if (strcmp (existing_account_info->name, account->name) != 0 || strcmp (existing_account_info->source_url, account->source->url) != 0) { |