aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy/empathy-server-sasl-handler.c
diff options
context:
space:
mode:
authorDanielle Madeley <danielle.madeley@collabora.co.uk>2011-03-03 10:35:45 +0800
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2011-03-03 17:23:15 +0800
commit855095a0e0c5c50f0713caf11afad2329428827b (patch)
tree6c5d5af19686f82279967a685676ba0f1ea64811 /libempathy/empathy-server-sasl-handler.c
parent2d652e402b4ed7fa1ca01805288018e4fc867d53 (diff)
downloadgsoc2013-empathy-855095a0e0c5c50f0713caf11afad2329428827b.tar
gsoc2013-empathy-855095a0e0c5c50f0713caf11afad2329428827b.tar.gz
gsoc2013-empathy-855095a0e0c5c50f0713caf11afad2329428827b.tar.bz2
gsoc2013-empathy-855095a0e0c5c50f0713caf11afad2329428827b.tar.lz
gsoc2013-empathy-855095a0e0c5c50f0713caf11afad2329428827b.tar.xz
gsoc2013-empathy-855095a0e0c5c50f0713caf11afad2329428827b.tar.zst
gsoc2013-empathy-855095a0e0c5c50f0713caf11afad2329428827b.zip
Only show the "Remember password" tickybox if we can do that
Diffstat (limited to 'libempathy/empathy-server-sasl-handler.c')
-rw-r--r--libempathy/empathy-server-sasl-handler.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/libempathy/empathy-server-sasl-handler.c b/libempathy/empathy-server-sasl-handler.c
index b0909e220..d6c81a862 100644
--- a/libempathy/empathy-server-sasl-handler.c
+++ b/libempathy/empathy-server-sasl-handler.c
@@ -498,3 +498,40 @@ empathy_server_sasl_handler_has_password (EmpathyServerSASLHandler *handler)
return (priv->password != NULL);
}
+
+/**
+ * empathy_server_sasl_handler_can_save_response_somewhere:
+ * @self:
+ *
+ * Returns: %TRUE if the response can be saved somewhere, either the keyring
+ * or via Ch.I.CredentialsStorage
+ */
+gboolean
+empathy_server_sasl_handler_can_save_response_somewhere (
+ EmpathyServerSASLHandler *self)
+{
+ EmpathyServerSASLHandlerPriv *priv;
+ gboolean may_save_response, may_save_response_valid;
+ gboolean has_storage_iface;
+
+ g_return_val_if_fail (EMPATHY_IS_SERVER_SASL_HANDLER (self), FALSE);
+
+ priv = self->priv;
+
+ /* determine if we are permitted to save the password locally */
+ may_save_response = tp_asv_get_boolean (
+ tp_channel_borrow_immutable_properties (priv->channel),
+ TP_PROP_CHANNEL_INTERFACE_SASL_AUTHENTICATION_MAY_SAVE_RESPONSE,
+ &may_save_response_valid);
+
+ if (!may_save_response_valid)
+ {
+ DEBUG ("MaySaveResponse unknown, assuming TRUE");
+ may_save_response = TRUE;
+ }
+
+ has_storage_iface = tp_proxy_has_interface_by_id (priv->channel,
+ EMP_IFACE_QUARK_CHANNEL_INTERFACE_CREDENTIALS_STORAGE);
+
+ return may_save_response || has_storage_iface;
+}