[evolution/account-mgmt: 25/33] Add 'book-config-webdav' module.



commit 0e38155d9bb9abfc6d0db8f84dd55750d31ede9d
Author: Matthew Barnes <mbarnes redhat com>
Date:   Thu Dec 23 09:00:21 2010 -0500

    Add 'book-config-webdav' module.
    
    Registers the "WebDAV" backend in EBookSourceConfig widgets.
    
    Replaces the 'webdav-account-setup' plugin.

 configure.ac                                       |    4 +-
 modules/Makefile.am                                |    1 +
 modules/book-config-webdav/Makefile.am             |   27 ++
 .../evolution-book-config-webdav.c                 |  233 +++++++++++++++
 plugins/webdav-account-setup/Makefile.am           |   30 --
 .../org-gnome-evolution-webdav.eplug.xml           |   22 --
 .../webdav-account-setup/webdav-contacts-source.c  |  311 --------------------
 7 files changed, 263 insertions(+), 365 deletions(-)
---
diff --git a/configure.ac b/configure.ac
index 6da3393..c9e5e85 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1403,7 +1403,7 @@ AC_ARG_ENABLE([plugins],
 	[enable_plugins="$enableval"],[enable_plugins=all])
 
 dnl Add any new plugins here
-plugins_base_always="calendar-file calendar-http itip-formatter default-source mark-all-read groupwise-features publish-calendar caldav imap-features google-account-setup webdav-account-setup"
+plugins_base_always="calendar-http itip-formatter default-source mark-all-read groupwise-features publish-calendar caldav imap-features google-account-setup"
 
 plugins_base="$plugins_base_always $SA_JUNK_PLUGIN $BF_JUNK_PLUGIN"
 dist_plugins_base="$plugins_base_always calendar-weather sa-junk-plugin bogo-junk-plugin"
@@ -1741,6 +1741,7 @@ modules/addressbook/Makefile
 modules/calendar/Makefile
 modules/mail/Makefile
 modules/book-config-local/Makefile
+modules/book-config-webdav/Makefile
 modules/composer-autosave/Makefile
 modules/connman/Makefile
 modules/mailto-handler/Makefile
@@ -1786,7 +1787,6 @@ plugins/save-calendar/Makefile
 plugins/templates/Makefile
 plugins/tnef-attachments/Makefile
 plugins/vcard-inline/Makefile
-plugins/webdav-account-setup/Makefile
 plugins/contacts-map/Makefile
 smclient/Makefile
 smime/Makefile
diff --git a/modules/Makefile.am b/modules/Makefile.am
index 9949d2d..ca97cdf 100644
--- a/modules/Makefile.am
+++ b/modules/Makefile.am
@@ -23,6 +23,7 @@ SUBDIRS = \
 	calendar \
 	mail \
 	book-config-local \
+	book-config-webdav \
 	composer-autosave \
 	mailto-handler \
 	offline-alert \
diff --git a/modules/book-config-webdav/Makefile.am b/modules/book-config-webdav/Makefile.am
new file mode 100644
index 0000000..aac4771
--- /dev/null
+++ b/modules/book-config-webdav/Makefile.am
@@ -0,0 +1,27 @@
+module_LTLIBRARIES = libevolution-module-book-config-webdav.la
+
+libevolution_module_book_config_webdav_la_CPPFLAGS =		\
+	$(AM_CPPFLAGS)						\
+	-I$(top_srcdir)						\
+	-I$(top_srcdir)/widgets					\
+	-DG_LOG_DOMAIN=\"evolution-book-config-webdav\"		\
+	$(EVOLUTION_ADDRESSBOOK_CFLAGS)				\
+	$(GNOME_PLATFORM_CFLAGS)
+
+libevolution_module_book_config_webdav_la_SOURCES =		\
+	evolution-book-config-webdav.c
+
+libevolution_module_book_config_webdav_la_LIBADD =		\
+	$(top_builddir)/e-util/libeutil.la			\
+	$(top_builddir)/widgets/misc/libemiscwidgets.la		\
+	$(top_builddir)/addressbook/printing/libecontactprint.la \
+	$(top_builddir)/addressbook/gui/merging/libeabbookmerging.la \
+	$(top_builddir)/addressbook/gui/widgets/libeabwidgets.la \
+	$(top_builddir)/addressbook/util/libeabutil.la		\
+	$(EVOLUTION_ADDRESSBOOK_LIBS)				\
+	$(GNOME_PLATFORM_LIBS)
+
+libevolution_module_book_config_webdav_la_LDFLAGS =		\
+	-module -avoid-version $(NO_UNDEFINED)
+
+-include $(top_srcdir)/git.mk
diff --git a/modules/book-config-webdav/evolution-book-config-webdav.c b/modules/book-config-webdav/evolution-book-config-webdav.c
new file mode 100644
index 0000000..47a29ce
--- /dev/null
+++ b/modules/book-config-webdav/evolution-book-config-webdav.c
@@ -0,0 +1,233 @@
+/*
+ * evolution-book-config-webdav.c
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) version 3.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+#include <config.h>
+#include <glib/gi18n-lib.h>
+#include <libedataserver/e-source-webdav.h>
+
+#include <e-util/e-extension.h>
+#include <misc/e-source-config-backend.h>
+#include <addressbook/gui/widgets/e-book-source-config.h>
+
+typedef ESourceConfigBackend EBookConfigWebdav;
+typedef ESourceConfigBackendClass EBookConfigWebdavClass;
+
+typedef struct _Context Context;
+
+struct _Context {
+	GtkWidget *url_entry;
+	GtkWidget *user_entry;
+	GtkWidget *avoid_ifmatch;
+};
+
+/* Module Entry Points */
+void e_module_load (GTypeModule *type_module);
+void e_module_unload (GTypeModule *type_module);
+
+/* Forward Declarations */
+GType e_book_config_webdav_get_type (void);
+
+G_DEFINE_DYNAMIC_TYPE (
+	EBookConfigWebdav,
+	e_book_config_webdav,
+	E_TYPE_SOURCE_CONFIG_BACKEND)
+
+static void
+book_config_webdav_context_free (Context *context)
+{
+	g_object_unref (context->url_entry);
+	g_object_unref (context->user_entry);
+	g_object_unref (context->avoid_ifmatch);
+
+	g_slice_free (Context, context);
+}
+
+static gboolean
+book_config_webdav_uri_to_text (GBinding *binding,
+                                const GValue *source_value,
+                                GValue *target_value,
+                                gpointer user_data)
+{
+	SoupURI *uri;
+	gchar *text;
+
+	uri = g_value_get_boxed (source_value);
+	soup_uri_set_user (uri, NULL);
+
+	text = soup_uri_to_string (uri, FALSE);
+	g_value_set_string (target_value, text);
+	g_free (text);
+
+	return TRUE;
+}
+
+static gboolean
+book_config_webdav_text_to_uri (GBinding *binding,
+                                const GValue *source_value,
+                                GValue *target_value,
+                                gpointer user_data)
+{
+	ESourceWebdav *extension = user_data;
+	SoupURI *uri;
+	const gchar *text;
+	gchar *user;
+
+	text = g_value_get_string (source_value);
+	uri = soup_uri_new (text);
+
+	if (uri == NULL)
+		return FALSE;
+
+	g_object_get (extension, "user", &user, NULL);
+	soup_uri_set_user (uri, user);
+	g_free (user);
+
+	g_value_set_boxed (target_value, uri);
+	soup_uri_free (uri);
+
+	return TRUE;
+}
+
+static void
+book_config_webdav_insert_widgets (ESourceConfigBackend *backend,
+                                   ESource *scratch_source)
+{
+	ESourceConfig *config;
+	ESourceExtension *extension;
+	GtkWidget *widget;
+	Context *context;
+	const gchar *extension_name;
+	const gchar *uid;
+
+	context = g_slice_new (Context);
+	uid = e_source_get_uid (scratch_source);
+	config = e_source_config_backend_get_config (backend);
+
+	g_object_set_data_full (
+		G_OBJECT (backend), uid, context,
+		(GDestroyNotify) book_config_webdav_context_free);
+
+	e_book_source_config_add_offline_toggle (
+		E_BOOK_SOURCE_CONFIG (config), scratch_source);
+
+	widget = gtk_entry_new ();
+	e_source_config_insert_widget (
+		config, scratch_source, _("URL:"), widget);
+	context->url_entry = g_object_ref (widget);
+	gtk_widget_show (widget);
+
+	e_source_config_add_secure_connection (config, scratch_source);
+
+	widget = gtk_entry_new ();
+	e_source_config_insert_widget (
+		config, scratch_source, _("User:"), widget);
+	context->user_entry = g_object_ref (widget);
+	gtk_widget_show (widget);
+
+	widget = gtk_check_button_new_with_label (
+		_("Avoid IfMatch (needed on Apache < 2.2.8)"));
+	e_source_config_insert_widget (
+		config, scratch_source, NULL, widget);
+	context->avoid_ifmatch = g_object_ref (widget);
+	gtk_widget_show (widget);
+
+	extension_name = E_SOURCE_EXTENSION_WEBDAV_BACKEND;
+	extension = e_source_get_extension (scratch_source, extension_name);
+
+	g_object_bind_property (
+		extension, "avoid-ifmatch",
+		context->avoid_ifmatch, "active",
+		G_BINDING_BIDIRECTIONAL |
+		G_BINDING_SYNC_CREATE);
+
+	g_object_bind_property_full (
+		extension, "soup-uri",
+		context->url_entry, "text",
+		G_BINDING_BIDIRECTIONAL |
+		G_BINDING_SYNC_CREATE,
+		book_config_webdav_uri_to_text,
+		book_config_webdav_text_to_uri,
+		extension, (GDestroyNotify) NULL);
+
+	g_object_bind_property (
+		extension, "user",
+		context->user_entry, "text",
+		G_BINDING_BIDIRECTIONAL |
+		G_BINDING_SYNC_CREATE);
+}
+
+static gboolean
+book_config_webdav_check_complete (ESourceConfigBackend *backend,
+                                   ESource *scratch_source)
+{
+	SoupURI *uri;
+	GtkEntry *entry;
+	Context *context;
+	const gchar *uri_string;
+	const gchar *uid;
+	gboolean complete;
+
+	uid = e_source_get_uid (scratch_source);
+	context = g_object_get_data (G_OBJECT (backend), uid);
+	g_return_val_if_fail (context != NULL, FALSE);
+
+	entry = GTK_ENTRY (context->url_entry);
+	uri_string = gtk_entry_get_text (entry);
+
+	uri = soup_uri_new (uri_string);
+	complete = SOUP_URI_VALID_FOR_HTTP (uri);
+
+	if (uri != NULL)
+		soup_uri_free (uri);
+
+	return complete;
+}
+
+static void
+e_book_config_webdav_class_init (ESourceConfigBackendClass *class)
+{
+	EExtensionClass *extension_class;
+
+	extension_class = E_EXTENSION_CLASS (class);
+	extension_class->extensible_type = E_TYPE_BOOK_SOURCE_CONFIG;
+
+	class->backend_name = "webdav";
+	class->insert_widgets = book_config_webdav_insert_widgets;
+	class->check_complete = book_config_webdav_check_complete;
+}
+
+static void
+e_book_config_webdav_class_finalize (ESourceConfigBackendClass *class)
+{
+}
+
+static void
+e_book_config_webdav_init (ESourceConfigBackend *backend)
+{
+}
+
+G_MODULE_EXPORT void
+e_module_load (GTypeModule *type_module)
+{
+	e_book_config_webdav_register_type (type_module);
+}
+
+G_MODULE_EXPORT void
+e_module_unload (GTypeModule *type_module)
+{
+}



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