* 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? svn path=/trunk/; revision=2117
772 lines
24 KiB
C
772 lines
24 KiB
C
/* -*- 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;
|
|
}
|