[evolution-data-server] Bug #602820 - Test validity of a book_view before using it in LDAP



commit 2f891d4eb4e1cf905ffd6b3f9fb806bb07255986
Author: Milan Crha <mcrha redhat com>
Date:   Mon Jan 25 13:16:59 2010 +0100

    Bug #602820 - Test validity of a book_view before using it in LDAP

 addressbook/backends/ldap/e-book-backend-ldap.c |   71 ++++++++++++++---------
 1 files changed, 44 insertions(+), 27 deletions(-)
---
diff --git a/addressbook/backends/ldap/e-book-backend-ldap.c b/addressbook/backends/ldap/e-book-backend-ldap.c
index 0c57d4f..f147f4d 100644
--- a/addressbook/backends/ldap/e-book-backend-ldap.c
+++ b/addressbook/backends/ldap/e-book-backend-ldap.c
@@ -498,14 +498,6 @@ can_browse (EBookBackend *backend)
 		strcmp (e_source_get_property (e_book_backend_get_source (backend), "can-browse"), "1") == 0;
 }
 
-static void
-book_view_notify_status (EDataBookView *view, const gchar *status)
-{
-	if (!view)
-		return;
-	e_data_book_view_notify_status_message (view, status);
-}
-
 static EDataBookView*
 find_book_view (EBookBackendLDAP *bl)
 {
@@ -526,6 +518,36 @@ find_book_view (EBookBackendLDAP *bl)
 	return rv;
 }
 
+static gboolean
+book_view_is_valid (EBookBackendLDAP *bl, EDataBookView *book_view)
+{
+	gboolean found = FALSE;
+	EList *views;
+	EIterator *iter;
+
+	if (!book_view)
+		return FALSE;
+
+	views = e_book_backend_get_book_views (E_BOOK_BACKEND (bl));
+
+	for (iter = e_list_get_iterator (views); e_iterator_is_valid (iter) && !found; e_iterator_next (iter)) {
+		found = book_view == e_iterator_get (iter);
+	}
+
+	g_object_unref (iter);
+	g_object_unref (views);
+
+	return found;
+}
+
+static void
+book_view_notify_status (EBookBackendLDAP *bl, EDataBookView *view, const gchar *status)
+{
+	if (!book_view_is_valid (bl, view))
+		return;
+	e_data_book_view_notify_status_message (view, status);
+}
+
 static void
 add_to_supported_fields (EBookBackendLDAP *bl, gchar **attrs, GHashTable *attr_hash)
 {
@@ -1063,14 +1085,12 @@ e_book_backend_ldap_reconnect (EBookBackendLDAP *bl, EDataBookView *book_view, g
 		GNOME_Evolution_Addressbook_CallStatus status;
 		gint ldap_error = LDAP_SUCCESS;
 
-		if (book_view)
-			book_view_notify_status (book_view, _("Reconnecting to LDAP server..."));
+		book_view_notify_status (bl, book_view, _("Reconnecting to LDAP server..."));
 
 		status = e_book_backend_ldap_connect (bl);
 
 		if (status != GNOME_Evolution_Addressbook_Success) {
-			if (book_view)
-				book_view_notify_status (book_view, "");
+			book_view_notify_status (bl, book_view, "");
 			if (enable_debug)
 				printf ("e_book_backend_ldap_reconnect ... failed (server down?)\n");
 			return FALSE;
@@ -1083,8 +1103,7 @@ e_book_backend_ldap_reconnect (EBookBackendLDAP *bl, EDataBookView *book_view, g
 							bl->priv->auth_passwd);
 			g_static_rec_mutex_unlock (&eds_ldap_handler_lock);
 		}
-		if (book_view)
-			book_view_notify_status (book_view, "");
+		book_view_notify_status (bl, book_view, "");
 
 		if (enable_debug) {
 			printf ("e_book_backend_ldap_reconnect ... returning %d\n", ldap_error);
@@ -1147,7 +1166,7 @@ ldap_op_finished (LDAPOp *op)
 	g_hash_table_remove (bl->priv->id_to_op, &op->id);
 
 	/* clear the status message too */
-	book_view_notify_status (find_book_view (bl), "");
+	book_view_notify_status (bl, find_book_view (bl), "");
 
 	/* should handle errors here */
 	g_static_rec_mutex_lock (&eds_ldap_handler_lock);
@@ -1708,7 +1727,7 @@ e_book_backend_ldap_create_contact (EBookBackend *backend,
 		ldap_mods = (LDAPMod**)mod_array->pdata;
 
 		do {
-			book_view_notify_status (book_view, _("Adding contact to LDAP server..."));
+			book_view_notify_status (bl, book_view, _("Adding contact to LDAP server..."));
 			g_static_rec_mutex_lock (&eds_ldap_handler_lock);
 			err = ldap_add_ext (bl->priv->ldap, create_op->dn, ldap_mods,
 					    NULL, NULL, &create_contact_msgid);
@@ -1842,7 +1861,7 @@ e_book_backend_ldap_remove_contacts (EBookBackend *backend,
 		remove_op->id = g_strdup (ids->data);
 
 		do {
-			book_view_notify_status (book_view, _("Removing contact from LDAP server..."));
+			book_view_notify_status (bl, book_view, _("Removing contact from LDAP server..."));
 
 			g_static_rec_mutex_lock (&eds_ldap_handler_lock);
 			ldap_error = ldap_delete_ext (bl->priv->ldap,
@@ -2279,7 +2298,7 @@ e_book_backend_ldap_modify_contact (EBookBackend *backend,
 		modify_op->id = e_contact_get_const (modify_op->contact, E_CONTACT_UID);
 
 		do {
-			book_view_notify_status (book_view, _("Modifying contact from LDAP server..."));
+			book_view_notify_status (bl, book_view, _("Modifying contact from LDAP server..."));
 
 			g_static_rec_mutex_lock (&eds_ldap_handler_lock);
 			ldap_error = ldap_search_ext (bl->priv->ldap, modify_op->id,
@@ -4254,7 +4273,7 @@ build_contact_from_entry (EBookBackendLDAP *bl,
 								while (e_book_backend_ldap_reconnect (bl, book_view, ldap_error));
 
 								if (ldap_error != LDAP_SUCCESS) {
-									book_view_notify_status (book_view,
+									book_view_notify_status (bl, book_view,
 												 ldap_err2string(ldap_error));
 									continue;
 								}
@@ -4382,7 +4401,7 @@ ldap_search_handler (LDAPOp *op, LDAPMessage *res)
 
 	if (!search_op->notified_receiving_results) {
 		search_op->notified_receiving_results = TRUE;
-		book_view_notify_status (op->view, _("Receiving LDAP search results..."));
+		book_view_notify_status (bl, op->view, _("Receiving LDAP search results..."));
 	}
 
 	msg_type = ldap_msgtype (res);
@@ -4521,7 +4540,7 @@ e_book_backend_ldap_search (EBookBackendLDAP *bl,
 				view_limit);
 
 			do {
-				book_view_notify_status (view, _("Searching..."));
+				book_view_notify_status (bl, view, _("Searching..."));
 
 				g_static_rec_mutex_lock (&eds_ldap_handler_lock);
 				ldap_err = ldap_search_ext (bl->priv->ldap, bl->priv->ldap_rootdn,
@@ -4538,11 +4557,11 @@ e_book_backend_ldap_search (EBookBackendLDAP *bl,
 			g_free (ldap_query);
 
 			if (ldap_err != LDAP_SUCCESS) {
-				book_view_notify_status (view, ldap_err2string(ldap_err));
+				book_view_notify_status (bl, view, ldap_err2string(ldap_err));
 				return;
 			}
 			else if (search_msgid == -1) {
-				book_view_notify_status (view,
+				book_view_notify_status (bl, view,
 							 _("Error performing search"));
 				return;
 			}
@@ -4687,7 +4706,7 @@ generate_cache_handler (LDAPOp *op, LDAPMessage *res)
 			if (book_view) {
 				status_msg = g_strdup_printf (_("Downloading contacts (%d)... "),
 								 contact_num);
-				e_data_book_view_notify_status_message (book_view, status_msg);
+				book_view_notify_status (bl, book_view, status_msg);
 				g_free (status_msg);
 			}
 			e_book_backend_cache_add_contact (bl->priv->cache, contact);
@@ -4899,9 +4918,7 @@ e_book_backend_ldap_authenticate_user (EBookBackend *backend,
 		 * we get a fresh ldap handle Fixes #67541 */
 
 		if (ldap_error == LDAP_SERVER_DOWN) {
-			EDataBookView *view = find_book_view (bl);
-
-			if (e_book_backend_ldap_reconnect (bl, view, ldap_error)) {
+			if (e_book_backend_ldap_reconnect (bl, find_book_view (bl), ldap_error)) {
 				ldap_error = LDAP_SUCCESS;
 			}
 



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]