aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
Diffstat (limited to 'mail')
-rw-r--r--mail/ChangeLog8
-rw-r--r--mail/mail-sources.c771
2 files changed, 778 insertions, 1 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 4bba22d4b3..b2f2515736 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,9 +1,15 @@
+2000-03-14 Dan Winship <danw@helixcode.com>
+
+ * mail-sources.c: First cut at a mail source selection wizard.
+ Basically a rigged demo at this point. Doesn't use camel to get
+ its information, and is not yet complete or integrated with the
+ mail component. Did I mention that the code is ugly?
+
2000-03-13 bertrand <bertrand@helixcode.com>
* folder-browser-factory.c (folder_browser_set_shell):
for testing and demonstration purpose, immediately
register a fake service.
-
2000-03-12 bertrand <bertrand@helixcode.com>
diff --git a/mail/mail-sources.c b/mail/mail-sources.c
new file mode 100644
index 0000000000..3e5fbaed91
--- /dev/null
+++ b/mail/mail-sources.c
@@ -0,0 +1,771 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+/* mail-sources.c: Mail source selection wizard */
+
+/*
+ * Author :
+ * Dan Winship <danw@helixcode.com>
+ *
+ * Copyright 2000 Helix Code, Inc. (http://www.helixcode.com)
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or (at your option) any later version.
+ *
+ * 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+ * USA
+ */
+
+#include <sys/stat.h>
+
+#include <gnome.h>
+#include <gtkhtml/gtkhtml.h>
+
+/* XXX */
+#define default_mail_path "/var/mail"
+
+struct {
+ char *protocol, *name, *description, *authname[4], *authproto[4];
+ gboolean authpasswd[4];
+} providers[] = {
+ { "POP3", "Post Office Protocol, version 3",
+ "For connecting to POP3 servers. Some web mail providers and "
+ "proprietary email systems also provide POP3 interfaces.",
+ { "Password/APOP", "Kerberos 4" },
+ { NULL, "KERBEROS_V4" },
+ { TRUE, FALSE }
+ },
+ { "IMAP", "Internet Mail Access Protocol",
+ "For connecting to IMAP servers. Allows you to keep all of "
+ "your mail on the IMAP server so that you can access it from "
+ "anywhere.",
+ { "Password/CRAM-MD5", "S/Key", "Kerberos 4", "GSSAPI" },
+ { NULL, "SKEY", "KERBEROS_V4", "GSSAPI" },
+ { TRUE, TRUE, FALSE, FALSE },
+ }
+};
+#define nproviders 2
+
+struct msinfo {
+ GtkHTML *html;
+ GtkWidget *prev, *next;
+ int page;
+
+ /* Locally-delivered mail. */
+ gboolean get_local_mail, default_local_mail_path;
+ char *local_mail_path;
+ gboolean use_movemail;
+
+ /* Remotely-delivered mail. */
+ gboolean get_remote_mail;
+ int remote_provider;
+ char *remote_host, *remote_user, *remote_password;
+ int remote_auth;
+ gboolean remember_password;
+ gboolean copy_local;
+
+ /* Local store. */
+ gboolean store_local;
+ char *local_store_path;
+};
+
+static void display_intro (struct msinfo *msi);
+static int finish_intro (struct msinfo *msi, int direction);
+static void display_local (struct msinfo *msi);
+static int finish_local (struct msinfo *msi, int direction);
+static void display_remote (struct msinfo *msi);
+static int finish_remote (struct msinfo *msi, int direction);
+static void display_remconf (struct msinfo *msi);
+static int finish_remconf (struct msinfo *msi, int direction);
+
+static struct {
+ void (*display) (struct msinfo *msi);
+ int (*finish) (struct msinfo *msi, int direction);
+} pages[] = {
+ { display_intro, finish_intro },
+ { display_local, finish_local },
+#if 0
+ { display_movemail, finish_movemail },
+#endif
+ { display_remote, finish_remote },
+ { display_remconf, finish_remconf },
+ { NULL, NULL }
+};
+
+
+/* Wrappers around gtkhtml */
+
+static void
+write_html (GtkHTML *html, GtkHTMLStreamHandle handle, const char *text)
+{
+ gtk_html_write (html, handle, text, strlen (text));
+}
+
+static GtkHTMLStreamHandle
+start_html (GtkHTML *html)
+{
+ GtkHTMLStreamHandle handle;
+
+ handle = gtk_html_begin (html, "");
+ write_html (html, handle, "<body bgcolor=white>\n");
+ return handle;
+}
+
+void
+end_html (GtkHTML *html, GtkHTMLStreamHandle handle)
+{
+ write_html (html, handle, "</body>");
+ gtk_html_end (html, handle, GTK_HTML_STREAM_OK);
+}
+
+
+/* Button callbacks */
+
+static void
+prev_clicked (GtkButton *button, gpointer data)
+{
+ struct msinfo *msi = data;
+
+ if (msi->page == 3)
+ gtk_widget_set_sensitive (msi->next, TRUE);
+ msi->page = pages[msi->page].finish (data, -1);
+ pages[msi->page].display (data);
+ if (msi->page == 0)
+ gtk_widget_set_sensitive (msi->prev, FALSE);
+}
+
+static void
+next_clicked (GtkButton *button, gpointer data)
+{
+ struct msinfo *msi = data;
+
+ if (msi->page == 0)
+ gtk_widget_set_sensitive (msi->prev, TRUE);
+ msi->page = pages[msi->page].finish (data, 1);
+ pages[msi->page].display (data);
+ if (msi->page == 3)
+ gtk_widget_set_sensitive (msi->next, FALSE);
+}
+
+static void
+cancel_clicked (GtkButton *button, gpointer data)
+{
+ exit (1);
+}
+
+static void
+object_requested(GtkHTML *html, GtkHTMLEmbedded *eb)
+{
+ GtkWidget *w;
+
+ w = gtk_object_get_data (GTK_OBJECT(html), eb->classid);
+ gtk_container_add (GTK_CONTAINER(eb), w);
+ gtk_widget_show_all (GTK_WIDGET(eb));
+}
+
+
+
+int
+main (int argc, char **argv)
+{
+ struct msinfo *msi;
+ GtkWidget *window, *vbox, *frame, *scrolled, *hbbox;
+ GtkWidget *cancel;
+ int page;
+
+ gtk_init (&argc, &argv);
+ gdk_imlib_init ();
+ gdk_rgb_init ();
+ gtk_widget_set_default_colormap (gdk_rgb_get_cmap ());
+ gtk_widget_set_default_visual (gdk_rgb_get_visual ());
+
+ msi = g_new (struct msinfo, 1);
+
+ /* Build window */
+ window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ gtk_window_set_title (GTK_WINDOW (window),
+ "Mail Source Configuration");
+ gtk_window_set_default_size (GTK_WINDOW (window), 600, 400);
+
+ vbox = gtk_vbox_new (FALSE, 5);
+ gtk_container_set_border_width (GTK_CONTAINER (vbox), 8);
+ gtk_container_add (GTK_CONTAINER (window), vbox);
+
+ frame = gtk_frame_new (NULL);
+ gtk_box_pack_start (GTK_BOX (vbox), frame, TRUE, TRUE, 0);
+
+ scrolled = gtk_scrolled_window_new (NULL, NULL);
+ gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled),
+ GTK_POLICY_AUTOMATIC,
+ GTK_POLICY_ALWAYS);
+ gtk_container_add (GTK_CONTAINER (frame), scrolled);
+
+ msi->html = GTK_HTML (gtk_html_new());
+ gtk_html_set_editable (msi->html, FALSE);
+ gtk_container_add (GTK_CONTAINER (scrolled), GTK_WIDGET (msi->html));
+ gtk_signal_connect (GTK_OBJECT (msi->html), "object_requested",
+ GTK_SIGNAL_FUNC (object_requested), NULL);
+
+ hbbox= gtk_hbutton_box_new ();
+ gtk_button_box_set_layout (GTK_BUTTON_BOX (hbbox),
+ GTK_BUTTONBOX_END);
+ gtk_box_pack_end (GTK_BOX (vbox), hbbox, FALSE, FALSE, 0);
+
+ msi->prev = gnome_stock_button (GNOME_STOCK_BUTTON_PREV);
+ msi->next = gnome_stock_button (GNOME_STOCK_BUTTON_NEXT);
+ cancel = gnome_stock_button (GNOME_STOCK_BUTTON_CANCEL);
+
+ gtk_box_pack_start (GTK_BOX (hbbox), msi->prev, TRUE, FALSE, 0);
+ gtk_box_pack_end (GTK_BOX (hbbox), msi->next, TRUE, FALSE, 0);
+ gtk_box_pack_end (GTK_BOX (hbbox), cancel, TRUE, FALSE, 0);
+
+ GTK_WIDGET_SET_FLAGS (msi->prev, GTK_CAN_DEFAULT);
+ GTK_WIDGET_SET_FLAGS (msi->next, GTK_CAN_DEFAULT);
+ GTK_WIDGET_SET_FLAGS (cancel, GTK_CAN_DEFAULT);
+ gtk_widget_grab_default (msi->next);
+
+ gtk_signal_connect (GTK_OBJECT (msi->prev), "clicked",
+ prev_clicked, msi);
+ gtk_signal_connect (GTK_OBJECT (msi->next), "clicked",
+ next_clicked, msi);
+ gtk_signal_connect (GTK_OBJECT (cancel), "clicked",
+ cancel_clicked, NULL);
+
+ msi->page = 0;
+ msi->get_local_mail = msi->default_local_mail_path = -1;
+ msi->use_movemail = -1;
+ msi->get_remote_mail = msi->store_local = -1;
+ msi->remember_password = msi->copy_local = -1;
+ msi->local_mail_path = msi->local_store_path = NULL;
+ msi->remote_provider = msi->remote_auth = -1;
+ msi->remote_host = msi->remote_user = msi->remote_password = NULL;
+
+ display_intro (msi);
+
+ gtk_widget_show_all (window);
+ gtk_main ();
+ exit (0);
+}
+
+#define intro_text \
+ "<h1>Evolution Mail Source Wizard</h1>\n" \
+ "<p>Welcome to the Evolution Mail Source Wizard. This will " \
+ "help you blah blah blah blah blah.</p>"
+
+static void
+display_intro (struct msinfo *msi)
+{
+ GtkHTMLStreamHandle handle;
+
+ handle = start_html (msi->html);
+ write_html (msi->html, handle, intro_text);
+ end_html (msi->html, handle);
+}
+
+static int
+finish_intro (struct msinfo *msi, int direction)
+{
+ return msi->page + direction;
+}
+
+#define local_text_1 \
+ "<h1>Local mail source</h1>\n<hr>\n" \
+ "<p>First you need to tell Evolution whether or not you " \
+ "receive mail locally, and if so, where.</p>\n" \
+ "<p>Your default mail file on this system is <b>"
+
+#define local_text_2 \
+ "</b>.</p>\n"
+
+#define local_text_3_file \
+ "<p>That file exists, so you almost certainly want to use it " \
+ "as a mail source.</p>\n"
+
+#define local_text_3_dir \
+ "<p>That directory exists, but you currently have no mail " \
+ "there. If you aren't sure whether or not you receive mail " \
+ "on this machine, it's safest to leave it selected.</p>\n"
+
+#define local_text_3_none \
+ "<p>However, that directory does not exist.</p>\n"
+
+#define local_text_label_1 \
+ "Don't fetch local mail."
+
+#define local_text_label_2 \
+ "Fetch local mail from the default location."
+
+#define local_text_label_3 \
+ "Fetch local mail from an alternate location:"
+
+void
+display_local (struct msinfo *msi)
+{
+ GtkHTMLStreamHandle handle;
+ struct stat st;
+ char *default_user_mail_path;
+ GtkWidget *radio, *text;
+ GSList *group = NULL;
+
+ default_user_mail_path = g_strdup_printf ("%s/%s", default_mail_path,
+ getenv ("USER"));
+
+ handle = start_html (msi->html);
+ write_html (msi->html, handle, local_text_1);
+ write_html (msi->html, handle, default_user_mail_path);
+ write_html (msi->html, handle, local_text_2);
+
+ if (stat (default_mail_path, &st) == 0) {
+ if (stat (default_user_mail_path, &st) == 0)
+ write_html (msi->html, handle, local_text_3_file);
+ else
+ write_html (msi->html, handle, local_text_3_dir);
+ if (msi->get_local_mail == -1)
+ msi->get_local_mail = TRUE;
+ } else {
+ write_html (msi->html, handle, local_text_3_none);
+ if (msi->get_local_mail == -1)
+ msi->get_local_mail = FALSE;
+ }
+ g_free (default_user_mail_path);
+
+ radio = gtk_radio_button_new_with_label (group, local_text_label_1);
+ group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio));
+ if (!msi->get_local_mail)
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (radio), TRUE);
+ gtk_object_set_data (GTK_OBJECT (msi->html), "local:no", radio);
+ write_html (msi->html, handle,
+ "<object classid=\"local:no\"></object><br>\n");
+
+ radio = gtk_radio_button_new_with_label (group, local_text_label_2);
+ group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio));
+ if (msi->get_local_mail && msi->default_local_mail_path)
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (radio), TRUE);
+ gtk_object_set_data (GTK_OBJECT (msi->html), "local:default", radio);
+ write_html (msi->html, handle,
+ "<object classid=\"local:default\"></object><br>\n");
+
+ radio = gtk_radio_button_new_with_label (group, local_text_label_3);
+ text = gtk_entry_new ();
+ if (msi->get_local_mail && !msi->default_local_mail_path) {
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (radio), TRUE);
+ gtk_entry_set_text (GTK_ENTRY (text), msi->local_mail_path);
+ }
+ gtk_object_set_data (GTK_OBJECT (msi->html), "local:alt", radio);
+ gtk_object_set_data (GTK_OBJECT (msi->html), "local:text", text);
+ write_html (msi->html, handle,
+ "<object classid=\"local:alt\"></object> "
+ "<object classid=\"local:text\"></object>");
+
+ end_html (msi->html, handle);
+}
+
+static int
+finish_local (struct msinfo *msi, int direction)
+{
+ GtkWidget *radio, *text;
+
+ radio = gtk_object_get_data (GTK_OBJECT (msi->html), "local:no");
+ msi->get_local_mail =
+ !gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (radio));
+
+ g_free (msi->local_mail_path);
+ if (!msi->get_local_mail)
+ msi->local_mail_path = NULL;
+ else {
+ radio = gtk_object_get_data (GTK_OBJECT (msi->html),
+ "local:default");
+ msi->default_local_mail_path =
+ gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (radio));
+ if (msi->default_local_mail_path)
+ msi->local_mail_path = NULL;
+ else {
+ text = gtk_object_get_data (GTK_OBJECT (msi->html),
+ "local:text");
+ msi->local_mail_path =
+ g_strdup (gtk_entry_get_text (GTK_ENTRY (text)));
+ }
+ }
+
+ return msi->page + direction;
+}
+
+#define remote_text_1 \
+ "<h1>Remote mail source</h1>\n<hr>\n<p>Now you need to " \
+ "configure a remote mail source, if you have one.</p>\n" \
+ "<p>Evolution supports the following protocols for reading " \
+ "mail from remote servers:</p>"
+
+#define remote_text_2 \
+ "<p>To add a remote mail source, choose a protocol from " \
+ "the list below and click \"Next\".</p>"
+
+#define remote_text_3_must \
+ "<p>You have not configured a local mail source, so you " \
+ "must configure a remote one.</p>"
+
+#define remote_label_none \
+ "No remote mail source"
+
+void
+display_remote (struct msinfo *msi)
+{
+ GtkHTMLStreamHandle handle;
+ char *table, *item, *button, *nolabel;
+ GtkWidget *widget;
+ int i;
+ GSList *group = NULL;
+
+ handle = start_html (msi->html);
+ write_html (msi->html, handle, remote_text_1);
+
+ /* Write the table of available providers */
+ table = "<blockquote><table border=1>\n";
+ write_html (msi->html, handle, table);
+ for (i = 0; i < nproviders; i++) {
+ table = g_strdup_printf ("<tr><th width=\"15%%\" "
+ "rowspan=2 valign=top>%s</th>"
+ "<td>%s</td></tr>\n"
+ "<tr><td>%s</td>\n",
+ providers[i].protocol,
+ providers[i].name,
+ providers[i].description);
+ write_html (msi->html, handle, table);
+ g_free (table);
+ }
+ table = "</table></blockquote>\n";
+ write_html (msi->html, handle, table);
+
+ write_html (msi->html, handle, remote_text_2);
+ if (!msi->get_local_mail)
+ write_html (msi->html, handle, remote_text_3_must);
+
+ /* Write the list of configurable sources */
+ write_html (msi->html, handle, "<blockquote>");
+ if (msi->get_local_mail) {
+ widget = gtk_radio_button_new_with_label (NULL,
+ remote_label_none);
+ group = gtk_radio_button_group (GTK_RADIO_BUTTON (widget));
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remote:no",
+ widget);
+ write_html (msi->html, handle,
+ "\n<object classid=\"remote:no\"></object><br>");
+ }
+
+ for (i = 0; i < nproviders; i++) {
+ button = g_strdup_printf ("remote:%s", providers[i].protocol);
+ widget = gtk_radio_button_new_with_label (group, providers[i].protocol);
+ if (msi->remote_provider == i) {
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget),
+ TRUE);
+ }
+ group = gtk_radio_button_group (GTK_RADIO_BUTTON (widget));
+ gtk_object_set_data (GTK_OBJECT (msi->html), button, widget);
+ g_free (button);
+
+ button = g_strdup_printf ("\n<object classid=\"remote:%s\">"
+ "</object><br>",
+ providers[i].protocol);
+ write_html (msi->html, handle, button);
+ g_free (button);
+ }
+ write_html (msi->html, handle, "</blockquote>");
+
+ end_html (msi->html, handle);
+}
+
+static int
+finish_remote (struct msinfo *msi, int direction)
+{
+ GtkToggleButton *radio;
+ char *button;
+ int i;
+
+ radio = gtk_object_get_data (GTK_OBJECT (msi->html), "remote:no");
+ msi->get_remote_mail = !radio || !gtk_toggle_button_get_active (radio);
+ if (msi->get_remote_mail) {
+ for (i = 0; i < nproviders; i++) {
+ button = g_strdup_printf ("remote:%s",
+ providers[i].protocol);
+ radio = gtk_object_get_data (GTK_OBJECT (msi->html),
+ button);
+ if (gtk_toggle_button_get_active (radio))
+ break;
+ }
+
+ msi->remote_provider = i;
+ } else if (direction == 1)
+ direction = 2; /* Skip remconf page. */
+
+ return msi->page + direction;
+}
+
+#define remconf_text_title \
+ "<h1>Configure a remote mail source: %s</h1><hr>"
+
+#define remconf_text_host_label "Server name:"
+#define remconf_text_user_label "Account name:"
+#define remconf_text_path_label "Path to mail on server:"
+#define remconf_text_auth_label "Authentication method:"
+
+#define remconf_text_password \
+ "<p>If you would like to have Evolution remember the password " \
+ "for this account, enter it below. If you would rather be " \
+ "prompted for the password when Evolution needs it, choose " \
+ "one of the other options.</p>\n"
+
+#define remconf_text_password_remember "Remember my password"
+#define remconf_text_password_confirm "Enter password again for confirmation"
+#define remconf_text_password_once \
+ "Prompt me for the password once each Evolution session."
+#define remconf_text_password_forget \
+ "Prompt me for the password every time it is needed."
+
+static void
+resize_password (GtkWidget *html, GtkAllocation *alloc, gpointer data)
+{
+ GtkWidget *scrolled;
+
+ scrolled = gtk_object_get_data (GTK_OBJECT (html), "remconf:htmlwin");
+ gtk_widget_set_usize (scrolled, alloc->width - 20, 300);
+}
+
+static void
+frob_password (GtkMenuItem *menuitem, gpointer data)
+{
+ struct msinfo *msi = data;
+ GtkHTML *subhtml;
+ GtkHTMLStreamHandle handle;
+ GtkWidget *radio, *table, *text, *label;
+ GSList *group = NULL;
+ int id;
+
+ id = GPOINTER_TO_UINT (gtk_object_get_data (GTK_OBJECT (menuitem),
+ "id"));
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remconf:authproto",
+ GUINT_TO_POINTER (id));
+ subhtml = gtk_object_get_data (GTK_OBJECT (msi->html), "remconf:html");
+ handle = start_html (subhtml);
+ if (providers[msi->remote_provider].authpasswd[id]) {
+ write_html (subhtml, handle, remconf_text_password);
+
+ table = gtk_table_new (2, 2, FALSE);
+ radio = gtk_radio_button_new_with_label (NULL, remconf_text_password_remember);
+ group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio));
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:remember",
+ radio);
+ gtk_table_attach (GTK_TABLE (table), radio, 0, 1, 0, 1,
+ GTK_FILL, GTK_SHRINK, 0, 0);
+ text = gtk_entry_new ();
+ gtk_entry_set_visibility (GTK_ENTRY (text), FALSE);
+ if (msi->remote_password)
+ gtk_entry_set_text (GTK_ENTRY (text), msi->remote_password);
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:passwd1",
+ text);
+ gtk_table_attach (GTK_TABLE (table), text, 1, 2, 0, 1,
+ GTK_EXPAND, GTK_SHRINK, 0, 0);
+ label = gtk_label_new (remconf_text_password_confirm);
+ gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_RIGHT);
+ gtk_table_attach (GTK_TABLE (table), label, 0, 1, 1, 2,
+ GTK_SHRINK, GTK_SHRINK, 5, 0);
+ text = gtk_entry_new ();
+ gtk_entry_set_visibility (GTK_ENTRY (text), FALSE);
+ if (msi->remote_password)
+ gtk_entry_set_text (GTK_ENTRY (text), msi->remote_password);
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:passwd2",
+ text);
+ gtk_table_attach (GTK_TABLE (table), text, 1, 2, 1, 2,
+ GTK_EXPAND, GTK_SHRINK, 0, 0);
+
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:table", table);
+
+ write_html (subhtml, handle, "<object classid=\"sub:table\">"
+ "</object>\n");
+
+ radio = gtk_radio_button_new_with_label (group, remconf_text_password_once);
+ group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio));
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:once",
+ radio);
+ write_html (subhtml, handle, "<object classid=\"sub:once\">"
+ "</object>\n");
+
+ radio = gtk_radio_button_new_with_label (group, remconf_text_password_forget);
+ group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio));
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:forget",
+ radio);
+ write_html (subhtml, handle, "<object classid=\"sub:forget\">"
+ "</object>\n");
+ } else {
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:remember", NULL);
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:once", NULL);
+ gtk_object_set_data (GTK_OBJECT (subhtml), "sub:forget", NULL);
+ }
+ end_html (subhtml, handle);
+}
+
+void
+display_remconf (struct msinfo *msi)
+{
+ GtkHTMLStreamHandle handle;
+ char *text;
+ int prov = msi->remote_provider;
+ GtkWidget *widget, *menu, *menuitem, *mi1 = NULL;
+ GtkWidget *scrolled, *subhtml;
+
+ handle = start_html (msi->html);
+
+ text = g_strdup_printf (remconf_text_title, providers[prov].protocol);
+ write_html (msi->html, handle, text);
+ g_free (text);
+
+ write_html (msi->html, handle, "<table>\n");
+
+ if (1) {
+ write_html (msi->html, handle, "<tr><td>");
+ write_html (msi->html, handle, remconf_text_host_label);
+ widget = gtk_entry_new ();
+ if (msi->remote_host) {
+ gtk_entry_set_text (GTK_ENTRY (widget),
+ msi->remote_host);
+ }
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remconf:host",
+ widget);
+ write_html (msi->html, handle, "</td><td><object "
+ "classid=\"remconf:host\"></object></td></tr>");
+ }
+
+ if (1) {
+ write_html (msi->html, handle, "<tr><td>");
+ write_html (msi->html, handle, remconf_text_user_label);
+ widget = gtk_entry_new ();
+ if (msi->remote_user) {
+ gtk_entry_set_text (GTK_ENTRY (widget),
+ msi->remote_user);
+ }
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remconf:user",
+ widget);
+ write_html (msi->html, handle, "</td><td><object "
+ "classid=\"remconf:user\"></object></td></tr>");
+ }
+
+ if (0) {
+ write_html (msi->html, handle, "<tr><td>");
+ write_html (msi->html, handle, remconf_text_path_label);
+ widget = gtk_entry_new ();
+#if 0
+ if (msi->remote_path) {
+ gtk_entry_set_text (GTK_ENTRY (widget),
+ msi->remote_path);
+ }
+#endif
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remconf:path",
+ widget);
+ write_html (msi->html, handle, "</td><td><object "
+ "classid=\"remconf:path\"></object></td></tr>");
+ }
+
+ if (1) {
+ int i;
+
+ write_html (msi->html, handle, "<tr><td>");
+ write_html (msi->html, handle, remconf_text_auth_label);
+ menu = gtk_menu_new ();
+ for (i = 0; i < 4 && providers[prov].authname[i]; i++) {
+ menuitem = gtk_menu_item_new_with_label (providers[prov].authname[i]);
+ gtk_widget_show (menuitem);
+ gtk_signal_connect (GTK_OBJECT (menuitem), "activate",
+ GTK_SIGNAL_FUNC (frob_password),
+ msi);
+ gtk_object_set_data (GTK_OBJECT (menuitem), "id",
+ GUINT_TO_POINTER (i));
+ if (!mi1)
+ mi1 = menuitem;
+ gtk_menu_append (GTK_MENU (menu), menuitem);
+ }
+ widget = gtk_option_menu_new ();
+ gtk_option_menu_set_menu (GTK_OPTION_MENU (widget), menu);
+ gtk_option_menu_set_history (GTK_OPTION_MENU (widget),
+ msi->remote_auth ?
+ msi->remote_auth : 0);
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remconf:auth",
+ widget);
+ write_html (msi->html, handle, "</td><td><object "
+ "classid=\"remconf:auth\"></object></td></tr>");
+ }
+ write_html (msi->html, handle, "</table>\n");
+
+ subhtml = gtk_html_new ();
+ gtk_html_set_editable (GTK_HTML (subhtml), FALSE);
+ gtk_signal_connect (GTK_OBJECT (subhtml), "object_requested",
+ GTK_SIGNAL_FUNC (object_requested), NULL);
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remconf:html",
+ subhtml);
+ frob_password (GTK_MENU_ITEM (mi1), msi);
+ scrolled = gtk_scrolled_window_new (NULL, NULL);
+ gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled),
+ GTK_POLICY_NEVER, GTK_POLICY_NEVER);
+ gtk_container_add (GTK_CONTAINER (scrolled), subhtml);
+ gtk_object_set_data (GTK_OBJECT (msi->html), "remconf:htmlwin",
+ scrolled);
+ write_html (msi->html, handle, "<object classid=\"remconf:htmlwin\">"
+ "</object>\n");
+ write_html (msi->html, handle, "<p>foo</p>");
+
+ gtk_signal_connect (GTK_OBJECT (msi->html), "size-allocate",
+ GTK_SIGNAL_FUNC (resize_password), NULL);
+
+ end_html (msi->html, handle);
+}
+
+static int
+finish_remconf (struct msinfo *msi, int direction)
+{
+ GtkEntry *host, *user, *passwd1, *passwd2;
+ char *data;
+ GtkWidget *menu, *menuitem;
+ GtkObject *subhtml;
+ GtkToggleButton *radio;
+
+ gtk_signal_disconnect_by_func (GTK_OBJECT (msi->html),
+ GTK_SIGNAL_FUNC (resize_password),
+ NULL);
+
+ host = gtk_object_get_data (GTK_OBJECT (msi->html), "remconf:host");
+ data = gtk_entry_get_text (GTK_ENTRY (host));
+ if (data && *data)
+ msi->remote_host = g_strdup (data);
+
+ user = gtk_object_get_data (GTK_OBJECT (msi->html), "remconf:user");
+ data = gtk_entry_get_text (GTK_ENTRY (user));
+ if (data && *data)
+ msi->remote_user = g_strdup (data);
+
+ msi->remote_auth = GPOINTER_TO_UINT (gtk_object_get_data (GTK_OBJECT (msi->html), "remconf:authproto"));
+
+ subhtml = gtk_object_get_data (GTK_OBJECT (msi->html), "remconf:html");
+ radio = gtk_object_get_data (subhtml, "sub:remember");
+ if (radio && gtk_toggle_button_get_active (radio)) {
+ passwd1 = gtk_object_get_data (subhtml, "sub:passwd1");
+ passwd2 = gtk_object_get_data (subhtml, "sub:passwd2");
+
+ /* XXX compare */
+ data = gtk_entry_get_text (GTK_ENTRY (passwd1));
+ printf ("%s\n", data);
+ if (data && *data) {
+ msi->remote_password = g_strdup (data);
+ msi->remember_password = TRUE;
+ }
+ } else {
+ radio = gtk_object_get_data (subhtml, "sub:once");
+ msi->remember_password = gtk_toggle_button_get_active (radio);
+ }
+
+ return msi->page + direction;
+}