diff options
author | Christian Persch <chpe@cvs.gnome.org> | 2006-06-22 20:37:00 +0800 |
---|---|---|
committer | Christian Persch <chpe@src.gnome.org> | 2006-06-22 20:37:00 +0800 |
commit | 7444dff3902968066f45081c342fa8ebb8aaf1d0 (patch) | |
tree | f2dffcfdad23a35b0aa66322501fe737ed22e58d /lib | |
parent | c7c27d1728fd00d3ebfa49e4f0c8c75c5176e6b0 (diff) | |
download | gsoc2013-epiphany-7444dff3902968066f45081c342fa8ebb8aaf1d0.tar.gz gsoc2013-epiphany-7444dff3902968066f45081c342fa8ebb8aaf1d0.tar.zst gsoc2013-epiphany-7444dff3902968066f45081c342fa8ebb8aaf1d0.zip |
A lib/ephy-password-dialog.c: A lib/ephy-password-dialog.h:
2006-06-22 Christian Persch <chpe@cvs.gnome.org>
* embed/mozilla/GtkNSSClientAuthDialogs.cpp:
* embed/mozilla/GtkNSSDialogs.cpp:
* embed/mozilla/GtkNSSDialogs.h:
* embed/mozilla/GtkNSSKeyPairDialogs.cpp:
* embed/mozilla/MozRegisterComponents.cpp:
* lib/Makefile.am:
A lib/ephy-password-dialog.c:
A lib/ephy-password-dialog.h:
Implement nsITokenPasswordDialogs. Misc cleanups and mozilla string
simplification now that we depend on gecko 1.8.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Makefile.am | 3 | ||||
-rw-r--r-- | lib/ephy-password-dialog.c | 707 | ||||
-rw-r--r-- | lib/ephy-password-dialog.h | 102 |
3 files changed, 812 insertions, 0 deletions
diff --git a/lib/Makefile.am b/lib/Makefile.am index 439c356bb..e6d4bf638 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -19,6 +19,7 @@ NOINST_H_FILES = \ ephy-node-filter.h \ ephy-node-common.h \ ephy-object-helpers.h \ + ephy-password-dialog.h \ ephy-prefs.h \ ephy-shlib-loader.h \ ephy-signal-accumulator.h \ @@ -29,6 +30,7 @@ NOINST_H_FILES = \ TYPES_H_FILES = \ ephy-adblock.h \ ephy-node.h \ + ephy-password-dialog.h \ ephy-state.h INST_H_FILES = \ @@ -57,6 +59,7 @@ libephymisc_la_SOURCES = \ ephy-node-common.h \ ephy-node-db.c \ ephy-object-helpers.c \ + ephy-password-dialog.c \ ephy-prefs.h \ ephy-shlib-loader.c \ ephy-signal-accumulator.c \ diff --git a/lib/ephy-password-dialog.c b/lib/ephy-password-dialog.c new file mode 100644 index 000000000..165d7a3ff --- /dev/null +++ b/lib/ephy-password-dialog.c @@ -0,0 +1,707 @@ +/* + * Copyright (C) 2003 Crispin Flowerday <gnome@flowerday.cx> + * Copyright (C) 2005, 2006 Christian Persch + * + * 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. + * + * $Id$ + */ + +#ifndef DONT_HAVE_CONFIG_H +#include "config.h" +#endif + +#include <string.h> + +#include <glib/gi18n.h> +#include <gtk/gtk.h> + +#ifdef ENABLE_KEYRING +#include <gnome-keyring.h> +#endif + +#include "ephy-gui.h" +#include "ephy-lib-type-builtins.h" +#include "ephy-state.h" + +#include "ephy-password-dialog.h" + +enum +{ + CHECK_USER = 1 << 0, + CHECK_DOMAIN = 1 << 1, + CHECK_PWD = 1 << 2, + CHECK_PWD_MATCH = 1 << 3, + CHECK_PWD_QUALITY = 1 << 4, + CHECK_MASK = 0x1f +}; + +enum +{ + USERNAME_ENTRY, + DOMAIN_ENTRY, + PASSWORD_ENTRY, + NEW_PASSWORD_ENTRY, + CONFIRM_PASSWORD_ENTRY, + N_ENTRIES +}; + +#define EPHY_PASSWORD_DIALOG_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_PASSWORD_DIALOG, EphyPasswordDialogPrivate)) + +struct _EphyPasswordDialogPrivate +{ + GtkWidget *entry[N_ENTRIES]; + GtkWidget *quality_meter; + GtkWidget *remember_button[3]; + gdouble quality_minimum; +#if 0 + char *realm; + char *keyring; + + gpointer lookup_op; + + guint keyring_enabled : 1; +#endif + EphyPasswordDialogFlags flags; + guint checks : 5; +}; + +enum +{ + PROP_0, + PROP_FLAGS, + PROP_DOMAIN, + PROP_KEYRING, + PROP_KEYRING_ENABLED +}; + +G_DEFINE_TYPE (EphyPasswordDialog, ephy_password_dialog, GTK_TYPE_MESSAGE_DIALOG) + +/** + * Calculate the quality of a password. The algorithm used is taken + * directly from mozilla: + * mozilla/security/manager/pki/resources/content/password.js + */ +static gdouble +password_quality (const char *text) +{ + const char *p; + gsize length; + int uppercase = 0, symbols = 0, numbers = 0, strength; + gunichar uc; + + if (text == NULL) return 0.0; + + /* Get the length */ + length = g_utf8_strlen (text, -1); + + /* Count the number of number, symbols and uppercase chars */ + for (p = text; *p; p = g_utf8_find_next_char (p, NULL)) + { + uc = g_utf8_get_char (p); + + if (g_unichar_isdigit (uc)) + { + numbers++; + } + else if (g_unichar_isupper (uc)) + { + uppercase++; + } + else if (g_unichar_islower (uc)) + { + /* Not counted */ + } + else if (g_unichar_isgraph (uc)) + { + symbols++; + } + } + + if (length > 5) length = 5; + if (numbers > 3) numbers = 3; + if (symbols > 3) symbols = 3; + if (uppercase > 3) uppercase = 3; + + strength = (length * 10 - 20) + (numbers * 10) + (symbols * 15) + (uppercase * 10); + strength = CLAMP (strength, 0, 100); + + return ((gdouble) strength) / 100.0; +} + +static void +update_responses (EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv = dialog->priv; + + gtk_dialog_set_response_sensitive (GTK_DIALOG (dialog), + GTK_RESPONSE_ACCEPT, + priv->checks == 0); +} + +static void +entry_changed_cb (GtkWidget *entry, + EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv = dialog->priv; + guint flag = 0; + const char *text; + + if (entry == priv->entry[USERNAME_ENTRY]) + { + flag = CHECK_USER; + } + else if (entry == priv->entry[DOMAIN_ENTRY]) + { + flag = CHECK_DOMAIN; + } + else if (entry == priv->entry[PASSWORD_ENTRY]) + { + flag = CHECK_PWD; + } + + text = gtk_entry_get_text (GTK_ENTRY (entry)); + if (text != NULL && text[0] != '\0') + { + priv->checks &= ~flag; + } + else + { + priv->checks |= flag; + } + + update_responses (dialog); +} + +static void +password_entry_changed_cb (GtkWidget *entry, + EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv = dialog->priv; + const char *text1, *text2; + + text1 = gtk_entry_get_text (GTK_ENTRY (priv->entry[NEW_PASSWORD_ENTRY])); + text2 = gtk_entry_get_text (GTK_ENTRY (priv->entry[CONFIRM_PASSWORD_ENTRY])); + + if (text1 != NULL && text2 != NULL && strcmp (text1, text2) == 0) + { + priv->checks &= ~CHECK_PWD_MATCH; + } + else + { + priv->checks |= CHECK_PWD_MATCH; + } + + if ((priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_QUALITY_METER) && + (entry == priv->entry[NEW_PASSWORD_ENTRY])) + { + gdouble quality; + + quality = password_quality (text1); + + gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (priv->quality_meter), + quality); + + if (quality >= priv->quality_minimum) + { + priv->checks &= ~CHECK_PWD_QUALITY; + } + else + { + priv->checks |= CHECK_PWD_QUALITY; + } + } + + update_responses (dialog); +} + +/* Focuses the next entry */ +static void +entry_activate_cb (GtkWidget *entry, + EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv = dialog->priv; + int i; + + for (i = 0; i < N_ENTRIES; ++i) + if (entry == priv->entry[i]) break; + g_assert (i < N_ENTRIES); + + for ( ; i < N_ENTRIES; ++i) + if (priv->entry[i] != NULL && + GTK_WIDGET_IS_SENSITIVE (priv->entry[i])) break; + + if (i < N_ENTRIES) + gtk_widget_grab_focus (priv->entry[i]); + else + gtk_window_activate_default (GTK_WINDOW (dialog)); +} + +static void +ephy_password_dialog_init (EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv; + + priv = dialog->priv = EPHY_PASSWORD_DIALOG_GET_PRIVATE (dialog); + + priv->checks = 0; + priv->quality_minimum = 0.0; +} + +static void +add_row (GtkTable *table, + int row, + const char *text, + GtkWidget *widget) +{ + GtkWidget *label; + + label = gtk_label_new_with_mnemonic (text); + gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); + + gtk_table_attach (table, label, + 0, 1, row, row + 1, + GTK_FILL, GTK_FILL, 0, 0); + gtk_table_attach (table, widget, + 1, 2, row, row + 1, + GTK_FILL | GTK_EXPAND, GTK_FILL, 0, 0); + + gtk_label_set_mnemonic_widget (GTK_LABEL (label), widget); +} + +static GtkWidget * +new_entry (EphyPasswordDialog *dialog, + GtkTable *table, + int row, + const char *text, + gboolean editable, + gboolean password, + GCallback changed_cb) +{ + GtkWidget *entry; + + entry = gtk_entry_new (); + gtk_entry_set_visibility (GTK_ENTRY (entry), !password); + gtk_widget_set_sensitive (entry, editable); + g_signal_connect (entry, "changed", changed_cb, dialog); + g_signal_connect (entry, "activate", + G_CALLBACK (entry_activate_cb), dialog); + + add_row (table, row, text, entry); + + return entry; +} + +#if 0 +static void +update_capslock_warning (GtkWidget *widget, + gboolean show) +{ + //EphyPasswordDialog *dialog = EPHY_PASSWORD_DIALOG (dialog); + //EphyPasswordDialogPrivate *priv = dialog->priv; + + g_print ("CapsLock is now %s\n", show?"on": "off"); +} + +static gboolean +ephy_password_dialog_key_press (GtkWidget *widget, + GdkEventKey *event) +{ + /* The documentation says that LOCK_MASK may be either the + * Shift or the CapsLock key, but I've only ever seen this set + * with CapsLock on. So hopefully this code works ok :) + */ + /* Pressing CapsLock when it was off: state-bit 0 keyval GDK_Caps_Lock + * Pressing CapsLock when it was on: state-bit 1 keyval GDK_Caps_Lock + * Pressing any key while CapsLock on: state-bit 1 + */ + if ((event->state & GDK_LOCK_MASK && + event->keyval != GDK_Caps_Lock) || + event->keyval == GDK_Caps_Lock) + { + update_capslock_warning (widget, TRUE); + } + else if ((event->state & GDK_LOCK_MASK) == 0 || + ((event->state & GDK_LOCK_MASK) && + event->keyval == GDK_Caps_Lock)) + { + update_capslock_warning (widget, FALSE); + } + + return GTK_WIDGET_CLASS (ephy_password_dialog_parent_class)->key_press_event (widget, event); +} +#endif + +static GObject * +ephy_password_dialog_constructor (GType type, + guint n_construct_properties, + GObjectConstructParam *construct_params) + +{ + GObject *object; + GtkWindow *window; + GtkDialog *dialog; + GtkMessageDialog *message_dialog; + EphyPasswordDialog *password_dialog; + EphyPasswordDialogPrivate *priv; + GtkWidget *vbox; + GtkTable *table; + int row = 0; + + object = G_OBJECT_CLASS (ephy_password_dialog_parent_class)->constructor + (type, n_construct_properties, construct_params); + + priv = EPHY_PASSWORD_DIALOG (object)->priv; + window = GTK_WINDOW (object); + dialog = GTK_DIALOG (object); + message_dialog = GTK_MESSAGE_DIALOG (object); + password_dialog = EPHY_PASSWORD_DIALOG (object); + + gtk_window_set_resizable (window, FALSE); + gtk_box_set_spacing (GTK_BOX (dialog->vbox), 2); /* Message has 24, we want 12 = 2 + 2 * 5 */ + + // gtk_window_set_destroy_with_parent (GTK_WINDOW (dialog), TRUE); + gtk_window_set_icon_name (window, "web-browser"); + + gtk_image_set_from_icon_name (GTK_IMAGE (message_dialog->image), + GTK_STOCK_DIALOG_AUTHENTICATION, + GTK_ICON_SIZE_DIALOG); + + vbox = message_dialog->label->parent; + + // fixme resize later + table = GTK_TABLE (gtk_table_new (6, 2, FALSE)); + gtk_table_set_row_spacings (table, 6); + gtk_table_set_col_spacings (table, 12); + gtk_box_pack_start (GTK_BOX (vbox), GTK_WIDGET (table), FALSE, FALSE, 0); + + if (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_USERNAME) + { + priv->entry[USERNAME_ENTRY] = + new_entry (password_dialog, + table, + row++, + _("_Username:"), + priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_EDIT_USERNAME, + FALSE, + G_CALLBACK (entry_changed_cb)); + + priv->checks |= CHECK_USER; + } + + if (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_DOMAIN) + { + priv->entry[DOMAIN_ENTRY] = + new_entry (password_dialog, + table, + row++, + _("_Domain:"), + priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_EDIT_DOMAIN, + FALSE, + G_CALLBACK (entry_changed_cb)); + + priv->checks |= CHECK_DOMAIN; + } + + if (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_PASSWORD) + { + priv->entry[PASSWORD_ENTRY] = + new_entry (password_dialog, + table, + row++, + _("_Password:"), + TRUE, + TRUE, + G_CALLBACK (entry_changed_cb)); + + priv->checks |= CHECK_PWD; + } + + if (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_NEW_PASSWORD) + { + priv->entry[NEW_PASSWORD_ENTRY] = + new_entry (password_dialog, + table, + row++, + priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_PASSWORD ? + _("_New password:") : + _("_Password:"), + TRUE, + TRUE, + G_CALLBACK (password_entry_changed_cb)); + + priv->entry[CONFIRM_PASSWORD_ENTRY] = + new_entry (password_dialog, + table, + row++, + _("Con_firm password:"), + TRUE, + TRUE, + G_CALLBACK (password_entry_changed_cb)); + + priv->checks |= CHECK_PWD_MATCH; + } + + /* Password quality meter */ + /* TODO: We need a better password quality meter */ + if (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_NEW_PASSWORD && + priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_QUALITY_METER) + { + priv->quality_meter = gtk_progress_bar_new (); + gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (priv->quality_meter), 0.0); + + add_row (table, row++, _("Password quality:"), priv->quality_meter); + + priv->checks |= CHECK_PWD_QUALITY; + } + + /* Removed unused table rows */ + gtk_table_resize (table, row, 2); + + if (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_REMEMBER) + { + GSList *group = NULL; + GtkWidget *rbox; + + rbox = gtk_vbox_new (FALSE, 6); + gtk_box_pack_start (GTK_BOX (vbox), rbox, FALSE, FALSE, 0); + + priv->remember_button[0] = gtk_radio_button_new_with_mnemonic (group, _("Do not remember this password")); + gtk_box_pack_start (GTK_BOX (rbox), priv->remember_button[0], FALSE, FALSE, 0); + group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (priv->remember_button[0])); + + priv->remember_button[1] = gtk_radio_button_new_with_mnemonic (group, _("_Remember password for this session")); + gtk_box_pack_start (GTK_BOX (rbox), priv->remember_button[1], FALSE, FALSE, 0); + group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (priv->remember_button[1])); + + priv->remember_button[2] = gtk_radio_button_new_with_mnemonic (group, _("Save password in _keyring")); + gtk_box_pack_start (GTK_BOX (rbox), priv->remember_button[2], FALSE, FALSE, 0); + } + + gtk_dialog_add_button (dialog, GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL); + gtk_dialog_add_button (dialog, GTK_STOCK_OK, GTK_RESPONSE_ACCEPT); + gtk_dialog_set_default_response (dialog, GTK_RESPONSE_ACCEPT); + update_responses (password_dialog); + + gtk_widget_show_all (vbox); + + return object; +} + +static void +ephy_password_dialog_finalize (GObject *object) +{ +// EphyPasswordDialog *dialog = EPHY_PASSWORD_DIALOG (object); +// EphyPasswordDialogPrivate *priv = dialog->priv; + + G_OBJECT_CLASS (ephy_password_dialog_parent_class)->finalize (object); +} + +static void +ephy_password_dialog_get_property (GObject *object, + guint prop_id, + GValue *value, + GParamSpec *pspec) +{ + /* no readable properties */ + g_assert_not_reached (); +} + +static void +ephy_password_dialog_set_property (GObject *object, + guint prop_id, + const GValue *value, + GParamSpec *pspec) +{ + EphyPasswordDialogPrivate *priv = EPHY_PASSWORD_DIALOG (object)->priv; + + switch (prop_id) + { + case PROP_FLAGS: + priv->flags = g_value_get_flags (value); + break; +#if 0 + case PROP_DOMAIN: + priv->realm = g_value_dup_string (value); + break; + case PROP_KEYRING: + priv->keyring = g_value_dup_string (value); + break; + case PROP_KEYRING_ENABLED: + priv->keyring_enabeld = g_value_get_boolean (value) != FALSE; + break; +#endif + } +} + +static void +ephy_password_dialog_class_init (EphyPasswordDialogClass *klass) +{ + GObjectClass *object_class = G_OBJECT_CLASS (klass); +// GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass); +// GtkDialogClass *dialog_class = GTK_DIALOG_CLASS (klass); + + object_class->constructor = ephy_password_dialog_constructor; + object_class->finalize = ephy_password_dialog_finalize; + object_class->get_property = ephy_password_dialog_get_property; + object_class->set_property = ephy_password_dialog_set_property; + +// widget_class->key_press_event = ephy_password_dialog_key_press; + +// dialog_class->response = ephy_password_dialog_response; + + g_type_class_add_private (object_class, sizeof (EphyPasswordDialogPrivate)); + + g_object_class_install_property + (object_class, + PROP_FLAGS, + g_param_spec_flags ("flags", + "flags", + "flags", + EPHY_TYPE_PASSWORD_DIALOG_FLAGS, + EPHY_PASSWORD_DIALOG_FLAGS_DEFAULT, + G_PARAM_WRITABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | + G_PARAM_CONSTRUCT_ONLY)); +#if 0 + g_object_class_install_property (object_class, + PROP_DOMAIN, + g_param_spec_string ("realm", + "realm", + "realm", + NULL, + G_PARAM_WRITABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | + G_PARAM_CONSTRUCT_ONLY)); + + g_object_class_install_property (object_class, + PROP_KEYRING, + g_param_spec_string ("keyring", + "keyring", + "keyring", + NULL, + G_PARAM_WRITABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | + G_PARAM_CONSTRUCT_ONLY)); + + g_object_class_install_property (object_class, + PROP_KEYRING_ENABLED, + g_param_spec_boolean ("keyring-enabled", + "keyring-enabled", + "keyring-enabled", + TRUE, + G_PARAM_WRITABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | + G_PARAM_CONSTRUCT_ONLY)); +#endif +} + +GtkWidget * +ephy_password_dialog_new (GtkWidget *parent, + const char *title, + EphyPasswordDialogFlags flags) +{ + return g_object_new (EPHY_TYPE_PASSWORD_DIALOG, + "transient-for", parent, + "title", title, + "message-type", GTK_MESSAGE_OTHER, + "flags", flags, + (gpointer) NULL); +} + +void +ephy_password_dialog_set_remember (EphyPasswordDialog *dialog, + GnomePasswordDialogRemember remember) +{ + EphyPasswordDialogPrivate *priv; + + g_return_if_fail (EPHY_IS_PASSWORD_DIALOG (dialog)); + g_return_if_fail (remember < GNOME_PASSWORD_DIALOG_REMEMBER_NOTHING || + remember > GNOME_PASSWORD_DIALOG_REMEMBER_FOREVER); + + priv = dialog->priv; + g_return_if_fail (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_REMEMBER); + + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (priv->remember_button[remember]), TRUE); +} + +GnomePasswordDialogRemember +ephy_password_dialog_get_remember (EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv; + GnomePasswordDialogRemember remember = GNOME_PASSWORD_DIALOG_REMEMBER_NOTHING; + + g_return_val_if_fail (EPHY_IS_PASSWORD_DIALOG (dialog), remember); + + priv = dialog->priv; + g_return_val_if_fail (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_REMEMBER, remember); + + if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (priv->remember_button[0]))) + remember = GNOME_PASSWORD_DIALOG_REMEMBER_NOTHING; + else if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (priv->remember_button[1]))) + remember = GNOME_PASSWORD_DIALOG_REMEMBER_SESSION; + else if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (priv->remember_button[2]))) + remember = GNOME_PASSWORD_DIALOG_REMEMBER_FOREVER; + + return remember; +} + +const char * +ephy_password_dialog_get_username (EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv; + + g_return_val_if_fail (EPHY_IS_PASSWORD_DIALOG (dialog), NULL); + + priv = dialog->priv; + g_return_val_if_fail (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_USERNAME, NULL); + + return gtk_entry_get_text (GTK_ENTRY (priv->entry[USERNAME_ENTRY])); +} + +const char * +ephy_password_dialog_get_domain (EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv; + + g_return_val_if_fail (EPHY_IS_PASSWORD_DIALOG (dialog), NULL); + + priv = dialog->priv; + g_return_val_if_fail (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_DOMAIN, NULL); + + return gtk_entry_get_text (GTK_ENTRY (priv->entry[DOMAIN_ENTRY])); +} + +const char * +ephy_password_dialog_get_password (EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv; + + g_return_val_if_fail (EPHY_IS_PASSWORD_DIALOG (dialog), NULL); + + priv = dialog->priv; + g_return_val_if_fail (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_PASSWORD, NULL); + + return gtk_entry_get_text (GTK_ENTRY (priv->entry[PASSWORD_ENTRY])); +} + +const char * +ephy_password_dialog_get_new_password (EphyPasswordDialog *dialog) +{ + EphyPasswordDialogPrivate *priv; + + g_return_val_if_fail (EPHY_IS_PASSWORD_DIALOG (dialog), NULL); + + priv = dialog->priv; + g_return_val_if_fail (priv->flags & EPHY_PASSWORD_DIALOG_FLAGS_SHOW_NEW_PASSWORD, NULL); + + return gtk_entry_get_text (GTK_ENTRY (priv->entry[NEW_PASSWORD_ENTRY])); +} diff --git a/lib/ephy-password-dialog.h b/lib/ephy-password-dialog.h new file mode 100644 index 000000000..6da76f12b --- /dev/null +++ b/lib/ephy-password-dialog.h @@ -0,0 +1,102 @@ +/* + * Copyright (C) 2005 Christian Persch + * + * 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. + * + * $Id$ + */ + +#ifndef EPHY_PASSWORD_DIALOG_H +#define EPHY_PASSWORD_DIALOG_H + +#include <gtk/gtkmessagedialog.h> +#include <libgnomeui/gnome-password-dialog.h> + +G_BEGIN_DECLS + +#define EPHY_TYPE_PASSWORD_DIALOG (ephy_password_dialog_get_type ()) +#define EPHY_PASSWORD_DIALOG(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), EPHY_TYPE_PASSWORD_DIALOG, EphyPasswordDialog)) +#define EPHY_PASSWORD_DIALOG_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), EPHY_TYPE_PASSWORD_DIALOG, EphyPasswordDialogClass)) +#define EPHY_IS_PASSWORD_DIALOG(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), EPHY_TYPE_PASSWORD_DIALOG)) +#define EPHY_IS_PASSWORD_DIALOG_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), EPHY_TYPE_PASSWORD_DIALOG)) +#define EPHY_PASSWORD_DIALOG_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), EPHY_TYPE_PASSWORD_DIALOG, EphyPasswordDialogClass)) + +typedef struct _EphyPasswordDialog EphyPasswordDialog; +typedef struct _EphyPasswordDialogPrivate EphyPasswordDialogPrivate; +typedef struct _EphyPasswordDialogClass EphyPasswordDialogClass; + +struct _EphyPasswordDialog +{ + GtkMessageDialog parent_instance; + + /*< private >*/ + EphyPasswordDialogPrivate *priv; +}; + +struct _EphyPasswordDialogClass +{ + GtkMessageDialogClass parent_class; +}; + +typedef enum +{ + EPHY_PASSWORD_DIALOG_FLAGS_SHOW_USERNAME = 1 << 0, + EPHY_PASSWORD_DIALOG_FLAGS_EDIT_USERNAME = 1 << 1, + EPHY_PASSWORD_DIALOG_FLAGS_SHOW_DOMAIN = 1 << 2, + EPHY_PASSWORD_DIALOG_FLAGS_EDIT_DOMAIN = 1 << 3, + EPHY_PASSWORD_DIALOG_FLAGS_SHOW_PASSWORD = 1 << 4, + EPHY_PASSWORD_DIALOG_FLAGS_SHOW_NEW_PASSWORD = 1 << 5, + EPHY_PASSWORD_DIALOG_FLAGS_SHOW_QUALITY_METER = 1 << 6, + EPHY_PASSWORD_DIALOG_FLAGS_SHOW_REMEMBER = 1 << 7, +} EphyPasswordDialogFlags; + +#define EPHY_PASSWORD_DIALOG_FLAGS_DEFAULT 0 + +GType ephy_password_dialog_get_type (void); + +GtkWidget *ephy_password_dialog_new (GtkWidget *parent, + const char *title, + EphyPasswordDialogFlags flags); + +void ephy_password_dialog_set_remember (EphyPasswordDialog *dialog, + GnomePasswordDialogRemember remember); + +GnomePasswordDialogRemember ephy_password_dialog_get_remember (EphyPasswordDialog *dialog); + +void ephy_password_dialog_set_label (EphyPasswordDialog *dialog, + const char *markup); + +GtkWidget *ephy_password_dialog_get_username_entry (EphyPasswordDialog *dialog); + +const char *ephy_password_dialog_get_username (EphyPasswordDialog *dialog); + +void ephy_password_dialog_set_username (EphyPasswordDialog *dialog, + const char *text); + +const char *ephy_password_dialog_get_domain (EphyPasswordDialog *dialog); + +void ephy_password_dialog_set_domain (EphyPasswordDialog *dialog, + const char *text); + +const char *ephy_password_dialog_get_password (EphyPasswordDialog *dialog); + +void ephy_password_dialog_set_password (EphyPasswordDialog *dialog, + const char *text); + +const char *ephy_password_dialog_get_new_password (EphyPasswordDialog *dialog); + +G_END_DECLS + +#endif /* !EPHY_PASSWORD_DIALOG_H */ |