diff options
Diffstat (limited to 'mail/mail-account-editor.c')
-rw-r--r-- | mail/mail-account-editor.c | 290 |
1 files changed, 290 insertions, 0 deletions
diff --git a/mail/mail-account-editor.c b/mail/mail-account-editor.c index bb2de76318..1146485758 100644 --- a/mail/mail-account-editor.c +++ b/mail/mail-account-editor.c @@ -21,4 +21,294 @@ */ #include "mail-account-editor.h" +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <camel/camel-url.h> + +static void mail_account_editor_class_init (MailAccountEditorClass *class); +static void mail_account_editor_init (MailAccountEditor *editor); +static void mail_account_editor_finalise (GtkObject *obj); + +static GnomeDialogClass *parent_class; + + +GtkType +mail_account_editor_get_type () +{ + static GtkType type = 0; + + if (!type) { + GtkTypeInfo type_info = { + "MailAccountEditor", + sizeof (MailAccountEditor), + sizeof (MailAccountEditorClass), + (GtkClassInitFunc) mail_account_editor_class_init, + (GtkObjectInitFunc) mail_account_editor_init, + (GtkArgSetFunc) NULL, + (GtkArgGetFunc) NULL + }; + + type = gtk_type_unique (gnome_dialog_get_type (), &type_info); + } + + return type; +} + +static void +mail_account_editor_class_init (MailAccountEditorClass *class) +{ + GtkObjectClass *object_class; + + object_class = (GtkObjectClass *) class; + parent_class = gtk_type_class (gnome_dialog_get_type ()); + + object_class->finalize = mail_account_editor_finalise; + /* override methods */ + +} + +static void +mail_account_editor_init (MailAccountEditor *o) +{ + ; +} + +static void +mail_account_editor_finalise (GtkObject *obj) +{ + MailAccountEditor *editor = (MailAccountEditor *) obj; + + gtk_object_unref (GTK_OBJECT (editor->gui)); + + ((GtkObjectClass *)(parent_class))->finalize (obj); +} + +static void +source_auth_type_changed (GtkWidget *widget, gpointer user_data) +{ + MailAccountEditor *editor = user_data; + CamelServiceAuthType *authtype; + gboolean sensitive; + + authtype = gtk_object_get_data (GTK_OBJECT (widget), "authtype"); + + gtk_object_set_data (GTK_OBJECT (editor), "source_authmech", authtype->authproto); + + if (authtype->need_password) + sensitive = TRUE; + else + sensitive = FALSE; + + gtk_widget_set_sensitive (GTK_WIDGET (editor->source_passwd), sensitive); + gtk_widget_set_sensitive (GTK_WIDGET (editor->save_passwd), sensitive); +} + +static void +source_auth_init (MailAccountEditor *editor, CamelURL *url) +{ + GtkWidget *menu, *item, *authmech = NULL; + CamelServiceAuthType *authtype; + GList *authtypes = NULL; + + menu = gtk_menu_new (); + gtk_option_menu_set_menu (editor->source_auth, menu); + + /* If we can't connect, don't let them continue. */ + if (!check_service (url, CAMEL_PROVIDER_STORE, &authtypes)) { + return; + } + + if (authtypes) { + GList *l; + + menu = gtk_menu_new (); + l = authtypes; + while (l) { + authtype = l->data; + + item = gtk_menu_item_new_with_label (authtype->name); + gtk_object_set_data (GTK_OBJECT (item), "authtype", authtype); + gtk_signal_connect (GTK_OBJECT (item), "activate", + GTK_SIGNAL_FUNC (source_auth_type_changed), + editor); + + gtk_menu_append (GTK_MENU (menu), item); + + if (!g_strcasecmp (authtype->authproto, url->authmech)) + authmech = item; + } + + if (authmech) + gtk_signal_emit_by_name (GTK_OBJECT (authmech), "activate", editor); + } +} + +static void +transport_type_changed (GtkWidget *widget, gpointer user_data) +{ + MailAccountEditor *editor = user_data; + CamelProvider *provider; + + provider = gtk_object_get_data (GTK_OBJECT (widget), "provider"); + editor->transport = provider; + + /* hostname */ + if (provider->url_flags & CAMEL_URL_ALLOW_HOST) + gtk_widget_set_sensitive (GTK_WIDGET (editor->transport_host), TRUE); + else + gtk_widget_set_sensitive (GTK_WIDGET (editor->transport_host), FALSE); + + /* auth */ + if (provider->url_flags & CAMEL_URL_ALLOW_AUTH) + gtk_widget_set_sensitive (GTK_WIDGET (editor->transport_auth_type), TRUE); + else + gtk_widget_set_sensitive (GTK_WIDGET (editor->transport_auth_type), FALSE); + + /* FIXME: regen the auth list */ +} + +static void +transport_type_init (MailAccountEditor *editor, CamelURL *url) +{ + GtkWidget *menu, *xport = NULL; + GList *providers, *l; + + menu = gtk_menu_new (); + providers = camel_session_list_providers (session, FALSE); + l = providers; + while (l) { + CamelProvider *provider = l->data; + + if (strcmp (provider->domain, "mail")) { + l = l->next; + continue; + } + + if (provider->object_types[CAMEL_PROVIDER_TRANSPORT]) { + GtkWidget *item; + + item = gtk_menu_item_new_with_label (provider->name); + gtk_object_set_data (GTK_OBJECT (item), "provider", provider); + gtk_signal_connect (GTK_OBJECT (item), "activate", + GTK_SIGNAL_FUNC (transport_type_changed), + editor); + + gtk_menu_append (GTK_MENU (menu), item); + + if (!g_strcasecmp (provider->protocol, url->protocol)) + xport = item; + } + + l = l->next; + } + + gtk_option_menu_set_menu (editor->transport_type, menu); + + if (xport) + gtk_signal_emit_by_name (GTK_OBJECT (xport), "activate", editor); +} + +static void +transport_auth_init (MailAccountEditor *editor, CamelURL *url) +{ + /* FIXME: look through the options and select the prefered authmech */ + ; +} + +static void +construct (MailAccountEditor *editor, const MailConfigAccount *account) +{ + GladeXML *gui; + GtkWidget *notebook, *entry; + CamelURL *url; + + gui = glade_xml_new (EVOLUTION_DATA_DIR "/mail-config-druid.glade", "mail-account-editor"); + editor->gui = gui; + + /* get our toplevel widget */ + notebook = glade_xml_get_widget (gui, "notebook"); + + /* reparent */ + gtk_widget_reparent (widget, GTK_WIDGET (editor)); + + /* give our dialog an OK button and title */ + gnome_dialog_construct (GNOME_DIALOG (editor), _("Evolution Account Editor"), + GNOME_STOCK_BUTTON_OK, GNOME_STOCK_BUTTON_APPLY, + GNOME_STOCK_BUTTON_CANCEL); + + /* General */ + editor->account_name = GTK_ENTRY (glade_xml_get_widget (gui, "txtAccountName")); + gtk_entry_set_text (editor->account_name, account->name); + editor->name = GTK_ENTRY (glade_xml_get_widget (gui, "txtName")); + gtk_entry_set_text (editor->name, account->id->name); + editor->email = GTK_ENTRY (glade_xml_get_widget (gui, "txtEMail")); + gtk_entry_set_text (editor->email, account->id->address); + editor->reply_to = GTK_ENTRY (glade_xml_get_widget (gui, "txtReplyTo")); + gtk_entry_set_text (editor->reply_to, account->id->reply_to); + editor->organization = GTK_ENTRY (glade_xml_get_widget (gui, "txtOrganization")); + gtk_entry_set_text (editor->organization, account->id->organization); + editor->signature = GNOME_FILE_ENTRY (glade_xml_get_widget (gui, "fileSignature")); + entry = gnome_file_entry_gtk_entry (editor->signature); + gtk_entry_set_text (GTK_ENTRY (entry), account->id->signature); + + /* Servers */ + url = camel_url_new (account->source->url, NULL); + editor->source_type = GTK_ENTRY (glade_xml_get_widget (gui, "txtSourceType")); + gtk_entry_set_text (editor->source_type, url->protocol); + editor->source_host = GTK_ENTRY (glade_xml_get_widget (gui, "txtSourceHost")); + gtk_entry_set_text (editor->source_host, url->host); + if (url->port) { + char port[10]; + + g_snprintf (port, 9, ":%d", port); + gtk_entry_append_text (editor->source_host, port); + } + editor->source_user = GTK_ENTRY (glade_xml_get_widget (gui, "txtSourceUser")); + gtk_entry_set_text (editor->source_user, url->user); + editor->source_passwd = GTK_ENTRY (glade_xml_get_widget (gui, "txtSourcePasswd")); + gtk_entry_set_text (editor->source_passwd, url->passwd); + editor->save_passwd = GTK_CHECK_BUTTON (glade_xml_get_widget (gui, "chkSavePasswd")); + gtk_check_button_set_active (GTK_TOGGLE_BUTTON (editor->save_passwd), account->source->save_passwd); + editor->source_auth = GTK_OPTION_MENU (glade_xml_get_widget (gui, "omenuSourceAuth")); + editor->source_ssl = GTK_CHECK_BUTTON (glade_xml_get_widget (gui, "chkSourceSSL")); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (editor->source_ssl), account->source->use_ssl); + editor->keep_on_server = GTK_CHECK_BUTTON (glade_xml_get_widget (gui, "chkKeepMailOnServer")); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (editor->keep_on_server), account->source->keep_on_server); + source_auth_init (editor, url); + camel_url_free (url); + + /* Transport */ + url = camel_url_new (account->transport->url, NULL); + editor->transport_type = GTK_OPTION_MENU (glade_xml_get_widget (gui, "omenuTransportType")); + gtk_entry_set_text (editor->transport_type, url->protocol); + editor->transport_host = GTK_ENTRY (glade_xml_get_widget (gui, "txtTransportHost")); + gtk_entry_set_text (editor->transport_host, url->host); + if (url->port) { + char port[10]; + + g_snprintf (port, 9, ":%d", port); + gtk_entry_append_text (editor->transport_host, port); + } + editor->transport_auth = GTK_OPTION_MENU (glade_xml_get_widget (gui, "omenuTransportAuth")); + transport_auth_init (editor); + editor->transport_ssl = GTK_CHECK_BUTTON (glade_xml_get_widget (gui, "chkTransportSSL")); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (editor->transport_ssl), account->transport->use_ssl); + transport_type_init (editor, url); + transport_auth_init (editor, url); + camel_url_free (url); + + editor->account = account; +} + +MailAccountEditor * +mail_account_editor_new (const MailConfigAccount *account) +{ + MailAccountsDialog *new; + + new = (MailAccountEditor *) gtk_type_new (mail_account_editor_get_type ()); + construct (new, account); + + return new; +} |