]> git.0d.be Git - empathy.git/commitdiff
Add the checkbox only if the reason is SelfSigned
authorCosimo Cecchi <cosimoc@gnome.org>
Fri, 13 Aug 2010 14:20:07 +0000 (16:20 +0200)
committerCosimo Cecchi <cosimoc@gnome.org>
Fri, 13 Aug 2010 14:22:25 +0000 (16:22 +0200)
Also, add a comment to explain why.

libempathy-gtk/empathy-tls-dialog.c

index 0fe0093b6b0755e000825a201ac192da9660f450..b61d5caccde56388d6f117c6d717f4d3a03b4bc3 100644 (file)
@@ -232,12 +232,21 @@ empathy_tls_dialog_constructed (GObject *object)
 
   content_area = gtk_dialog_get_content_area (dialog);
 
-  checkbox = gtk_check_button_new_with_label (_("Remember this choice"));
-  gtk_box_pack_end (GTK_BOX (content_area), checkbox, FALSE, FALSE, 0);
-  gtk_widget_show (checkbox);
+  /* FIXME: right now we do this only if the error is SelfSigned, as we can
+   * easily store the new CA cert in $XDG_CONFIG_DIR/telepathy/certs in that
+   * case. For the other errors, we probably need a smarter/more powerful
+   * certificate storage.
+   */
+  if (priv->reason == EMP_TLS_CERTIFICATE_REJECT_REASON_SELF_SIGNED)
+    {
+      checkbox = gtk_check_button_new_with_label (
+          _("Remember this choice for future connections"));
+      gtk_box_pack_end (GTK_BOX (content_area), checkbox, FALSE, FALSE, 0);
+      gtk_widget_show (checkbox);
 
-  g_signal_connect (checkbox, "toggled",
-      G_CALLBACK (checkbox_toggled_cb), self);
+      g_signal_connect (checkbox, "toggled",
+          G_CALLBACK (checkbox_toggled_cb), self);
+    }
 
   text = g_strdup_printf ("<b>%s</b>", _("Certificate Details"));
   expander = gtk_expander_new (text);