aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk
diff options
context:
space:
mode:
Diffstat (limited to 'libempathy-gtk')
-rw-r--r--libempathy-gtk/empathy-chat.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/libempathy-gtk/empathy-chat.c b/libempathy-gtk/empathy-chat.c
index 455fb0e8e..eb7325339 100644
--- a/libempathy-gtk/empathy-chat.c
+++ b/libempathy-gtk/empathy-chat.c
@@ -2973,6 +2973,7 @@ typedef struct
GtkWidget *label;
GtkWidget *entry;
GtkWidget *spinner;
+ gchar *password;
} PasswordData;
static void
@@ -2994,12 +2995,18 @@ remember_password_infobar_response_cb (GtkWidget *info_bar,
gint response_id,
PasswordData *data)
{
+ EmpathyChatPriv *priv = GET_PRIV (data->self);
+
if (response_id == GTK_RESPONSE_OK) {
DEBUG ("Saving room password");
- /* TODO: implement this */
+ empathy_keyring_set_room_password_async (priv->account,
+ empathy_tp_chat_get_id (priv->tp_chat),
+ data->password,
+ NULL, NULL);
}
gtk_widget_destroy (info_bar);
+ g_free (data->password);
g_slice_free (PasswordData, data);
}
@@ -3014,6 +3021,9 @@ chat_prompt_to_save_password (EmpathyChat *self,
GtkWidget *alig;
GtkWidget *button;
+ /* save the password in case it needs to be saved */
+ data->password = g_strdup (gtk_entry_get_text (GTK_ENTRY (data->entry)));
+
/* Remove all previous widgets */
content_area = gtk_info_bar_get_content_area (GTK_INFO_BAR (data->info_bar));
gtk_container_forall (GTK_CONTAINER (content_area),