aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--plugins/exchange-account-setup/ChangeLog13
-rw-r--r--plugins/exchange-account-setup/exchange-account-setup.c217
2 files changed, 217 insertions, 13 deletions
diff --git a/plugins/exchange-account-setup/ChangeLog b/plugins/exchange-account-setup/ChangeLog
index 486639fa13..073e007f56 100644
--- a/plugins/exchange-account-setup/ChangeLog
+++ b/plugins/exchange-account-setup/ChangeLog
@@ -1,3 +1,16 @@
+2005-02-27 Sushma Rai <rsushma@novell.com>
+
+ * exchange-account-setup.c (org_gnome_exchange_settings): Storing the
+ oof data enterted by user to a file, displaying the existing data on
+ this page.
+ (toggled_state): Signal hander for radiobutton, that sets the oof state.
+ (update_state): Signal handler that reads the oof message entered.
+ (org_gnome_exchange_commit): Stores the oof data and does cleanup.
+ (store_oof_info): Checks for the oof information file, writes the
+ oof state and message to the file.
+ (destroy_oof_data): Frees OOFData.
+
+
2005-02-26 Sushma Rai <rsushma@novell.com>
* exchange-account-setup.c (org_gnome_exchange_check_options):
diff --git a/plugins/exchange-account-setup/exchange-account-setup.c b/plugins/exchange-account-setup/exchange-account-setup.c
index e5b1f03a55..78f5eb3147 100644
--- a/plugins/exchange-account-setup/exchange-account-setup.c
+++ b/plugins/exchange-account-setup/exchange-account-setup.c
@@ -23,6 +23,8 @@
#endif
#include <string.h>
+#include <unistd.h>
+#include <sys/stat.h>
#include <glib/gi18n.h>
#include <glade/glade.h>
#include <gtk/gtk.h>
@@ -31,6 +33,7 @@
#include <camel/camel-provider.h>
#include <camel/camel-url.h>
#include <camel/camel-service.h>
+#include <libedataserver/e-xml-hash-utils.h>
#include "mail/em-account-editor.h"
#include "mail/em-config.h"
#include "e-util/e-account.h"
@@ -40,10 +43,13 @@ GtkWidget* org_gnome_exchange_settings(EPlugin *epl, EConfigHookItemFactoryData
GtkWidget *org_gnome_exchange_owa_url(EPlugin *epl, EConfigHookItemFactoryData *data);
gboolean org_gnome_exchange_check_options(EPlugin *epl, EConfigHookPageCheckData *data);
GtkWidget *org_gnome_exchange_auth_section (EPlugin *epl, EConfigHookItemFactoryData *data);
+void org_gnome_exchange_commit (EPlugin *epl, EConfigHookItemFactoryData *data);
/* NB: This should be given a better name, it is NOT a camel service, it is only a camel-exchange one */
typedef gboolean (CamelProviderValidateUserFunc) (CamelURL *camel_url, const char *url, gboolean *remember_password, CamelException *ex);
+#define OOF_INFO_FILE_NAME "oof_info.xml"
+
typedef struct {
CamelProviderValidateUserFunc *validate_user;
}CamelProviderValidate;
@@ -71,6 +77,40 @@ CamelServiceAuthType camel_exchange_password_authtype = {
};
+typedef struct {
+ gboolean state;
+ char *account_name, *message;
+ GtkWidget *text_view;
+}OOFData;
+
+OOFData *oof_data;
+
+static void
+update_state (GtkTextBuffer *buffer, gpointer data)
+{
+ if (gtk_text_buffer_get_modified (buffer)) {
+ GtkTextIter start, end;
+ if (oof_data->message)
+ g_free (oof_data->message);
+ gtk_text_buffer_get_bounds (buffer, &start, &end);
+ oof_data->message = gtk_text_buffer_get_text (buffer, &start,
+ &end, FALSE);
+ gtk_text_buffer_set_modified (buffer, FALSE);
+ }
+}
+
+static void
+toggled_state (GtkToggleButton *button, gpointer data)
+{
+ gboolean current_oof_state = gtk_toggle_button_get_active (button);
+
+ if (current_oof_state == oof_data->state)
+ return;
+ oof_data->state = current_oof_state;
+ gtk_widget_set_sensitive (oof_data->text_view, current_oof_state);
+}
+
+
/* only used in editor */
GtkWidget *
org_gnome_exchange_settings(EPlugin *epl, EConfigHookItemFactoryData *data)
@@ -86,7 +126,11 @@ org_gnome_exchange_settings(EPlugin *epl, EConfigHookItemFactoryData *data)
GtkWidget *oof_frame;
GtkWidget *scrolledwindow_oof;
GtkWidget *textview_oof;
- char *txt;
+ GtkTextBuffer *buffer;
+ GtkTextIter start, end;
+ char *txt, *oof_message, *oof_info_file, *base_dir;
+ GHashTable *oof_props;
+ xmlDoc *doc;
target_account = (EMConfigTargetAccount *)data->config->target;
source_url = e_account_get_string (target_account->account, E_ACCOUNT_SOURCE_URL);
@@ -103,7 +147,43 @@ org_gnome_exchange_settings(EPlugin *epl, EConfigHookItemFactoryData *data)
return data->old;
}
- /* FIXME: This out of office data never goes anywhere */
+ oof_data = g_new0 (OOFData, 1);
+
+ /* See if oof info found already */
+
+ oof_data->account_name = g_strdup_printf ("%s@%s", url->user, url->host);
+ base_dir = g_strdup_printf ("%s/.evolution/exchange/%s",
+ g_get_home_dir (), oof_data->account_name);
+
+ oof_info_file = g_build_filename (base_dir, OOF_INFO_FILE_NAME, NULL);
+ g_free(base_dir);
+
+ oof_data->state = FALSE;
+ oof_data->message = NULL;
+ oof_data->text_view = NULL;
+
+ if (g_file_test (oof_info_file, G_FILE_TEST_EXISTS)) {
+ doc = xmlParseFile (oof_info_file);
+ if (doc) {
+ char *status, *message;
+
+ oof_props = e_xml_to_hash (doc, E_XML_HASH_TYPE_PROPERTY);
+ xmlFreeDoc (doc);
+ status = g_hash_table_lookup (oof_props, "oof-state");
+ if (!strcmp (status, "oof")) {
+ oof_data->state = TRUE;
+ message = g_hash_table_lookup (oof_props, "oof-message");
+ if (message && *message)
+ oof_data->message = g_strdup (message);
+ else
+ oof_data->message = NULL;
+ }
+ g_hash_table_destroy (oof_props);
+ }
+ }
+ g_free (oof_info_file);
+
+ /* construct page */
oof_page = gtk_vbox_new (FALSE, 6);
gtk_container_set_border_width (GTK_CONTAINER (oof_page), 12);
@@ -136,8 +216,21 @@ org_gnome_exchange_settings(EPlugin *epl, EConfigHookItemFactoryData *data)
gtk_table_attach (GTK_TABLE (oof_table), label_status, 0, 1, 0, 1,
GTK_FILL, GTK_FILL, 0, 0);
- radiobutton_inoff = gtk_radio_button_new_with_label (NULL,
+ if (oof_data->state) {
+ radiobutton_oof = gtk_radio_button_new_with_label (NULL,
+ _("I am out of the office"));
+ radiobutton_inoff = gtk_radio_button_new_with_label_from_widget (
+ GTK_RADIO_BUTTON (radiobutton_oof),
+ _("I am in the office"));
+ }
+ else {
+ radiobutton_inoff = gtk_radio_button_new_with_label (NULL,
_("I am in the office"));
+ radiobutton_oof = gtk_radio_button_new_with_label_from_widget (
+ GTK_RADIO_BUTTON (radiobutton_inoff),
+ _("I am out of the office"));
+ }
+
gtk_table_attach (GTK_TABLE (oof_table), radiobutton_inoff, 1, 2, 0, 1,
GTK_FILL, GTK_FILL, 0, 0);
@@ -148,15 +241,11 @@ org_gnome_exchange_settings(EPlugin *epl, EConfigHookItemFactoryData *data)
gtk_label_set_use_markup (GTK_LABEL (label_empty), FALSE);
gtk_table_attach (GTK_TABLE (oof_table), label_empty, 0, 1, 1, 2,
GTK_FILL, GTK_FILL, 0, 0);
-
- radiobutton_oof = gtk_radio_button_new_with_label_from_widget (
- GTK_RADIO_BUTTON (radiobutton_inoff),
- _("I am out of the office"));
-
-
gtk_table_attach (GTK_TABLE (oof_table), radiobutton_oof, 1, 2, 1, 2,
GTK_FILL, GTK_FILL, 0, 0);
+ g_signal_connect (radiobutton_oof, "toggled", G_CALLBACK (toggled_state), NULL);
+
/* frame containg oof message text box */
vbox_oof = gtk_vbox_new (FALSE, 6);
@@ -186,13 +275,31 @@ org_gnome_exchange_settings(EPlugin *epl, EConfigHookItemFactoryData *data)
gtk_text_view_set_wrap_mode (GTK_TEXT_VIEW (textview_oof),
GTK_WRAP_WORD);
gtk_text_view_set_editable (GTK_TEXT_VIEW (textview_oof), TRUE);
+
+ buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (textview_oof));
+ gtk_text_buffer_get_bounds (buffer, &start, &end);
+ oof_message = gtk_text_buffer_get_text (buffer, &start, &end, FALSE);
+ if (oof_message && *oof_message) {
+ /* Will this ever happen? */
+ oof_data->message = oof_message;
+ }
+ if (oof_data->message) {
+ /* previuosly set message */
+ gtk_text_buffer_set_text (buffer, oof_data->message, -1);
+ gtk_text_view_set_buffer (GTK_TEXT_VIEW (textview_oof), buffer);
+
+ }
+ gtk_text_buffer_set_modified (buffer, FALSE);
+ if (!oof_data->state)
+ gtk_widget_set_sensitive (textview_oof, FALSE);
+ oof_data->text_view = textview_oof;
+ g_signal_connect (buffer, "changed", G_CALLBACK (update_state), NULL);
+
gtk_container_add (GTK_CONTAINER (scrolledwindow_oof), textview_oof);
gtk_widget_show_all (scrolledwindow_oof);
gtk_widget_show_all (oof_page);
-
gtk_notebook_insert_page (GTK_NOTEBOOK (data->parent), oof_page, gtk_label_new(_("Exchange Settings")), 4);
-
return oof_page;
}
@@ -266,8 +373,7 @@ owa_editor_entry_changed(GtkWidget *entry, EConfig *config)
if (owaurl) {
active = TRUE;
- /* i'm not sure why we need this, "ssl connection mode" is redundant
- since we have it in the owa-url protocol */
+ /* Reading the owa url and setting use_ssl paramemter */
if (!strcmp(owaurl->protocol, "https"))
ssl = "always";
camel_url_free(owaurl);
@@ -398,6 +504,90 @@ org_gnome_exchange_check_options(EPlugin *epl, EConfigHookPageCheckData *data)
return status;
}
+static void
+store_oof_info ()
+{
+ char *oof_storage_base_dir, *oof_storage_file, *status;
+ xmlDocPtr doc;
+ int result;
+ GHashTable *oof_props;
+
+ /* oof information is entered at editor need to be written to the
+ * server, dump it to the file */
+ oof_storage_base_dir = g_strdup_printf ("%s/.evolution/exchange/%s",
+ g_get_home_dir (), oof_data->account_name);
+
+ if (!g_file_test (oof_storage_base_dir, G_FILE_TEST_EXISTS)) {
+ if (mkdir (oof_storage_base_dir, 0755)) {
+ /* Failed to create file */
+ g_free (oof_storage_base_dir);
+ return;
+ }
+ }
+
+ oof_storage_file = g_build_filename (oof_storage_base_dir,
+ OOF_INFO_FILE_NAME, NULL);
+ if (g_file_test (oof_storage_file, G_FILE_TEST_EXISTS))
+ unlink (oof_storage_file);
+
+ if (oof_data->state)
+ status = g_strdup ("oof");
+ else
+ status = g_strdup ("in-office");
+
+ oof_props = g_hash_table_new (g_str_hash, g_str_equal);
+ g_hash_table_insert (oof_props, "oof-state", status);
+ g_hash_table_insert (oof_props, "sync-state", g_strdup("0"));
+ g_hash_table_insert (oof_props, "oof-message", oof_data->message);
+ doc = e_xml_from_hash (oof_props, E_XML_HASH_TYPE_PROPERTY, "oof-info");
+ result = xmlSaveFile (oof_storage_file, doc);
+ xmlFreeDoc (doc);
+ if (result < 0)
+ unlink (oof_storage_file);
+ g_hash_table_destroy (oof_props);
+ g_free (status);
+ g_free (oof_storage_file);
+ g_free (oof_storage_base_dir);
+}
+
+static void
+destroy_oof_data ()
+{
+ if (oof_data->account_name)
+ g_free (oof_data->account_name);
+ if (oof_data->message)
+ g_free (oof_data->message);
+ g_free (oof_data);
+}
+
+void
+org_gnome_exchange_commit (EPlugin *epl, EConfigHookItemFactoryData *data)
+{
+ EMConfigTargetAccount *target_account;
+ target_account = (EMConfigTargetAccount *)data->config->target;
+ const char *source_url;
+ CamelURL *url;
+
+ source_url = e_account_get_string (target_account->account, E_ACCOUNT_SOURCE_URL);
+ url = camel_url_new (source_url, NULL);
+ if (url == NULL
+ || strcmp (url->protocol, "exchange") != 0) {
+ if (url)
+ camel_url_free (url);
+
+ return;
+ }
+ if (data->old) {
+ camel_url_free(url);
+ return;
+ }
+
+ /* dump oof data so that can be set in exchange account */
+ store_oof_info ();
+ destroy_oof_data ();
+ return;
+}
+
static void
exchange_check_authtype (GtkWidget *w, EConfig *config)
{
@@ -437,6 +627,7 @@ exchange_authtype_changed (GtkComboBox *dropdown, EConfig *config)
camel_url_free(url);
}
+
GtkWidget *
org_gnome_exchange_auth_section (EPlugin *epl, EConfigHookItemFactoryData *data)
{