[gvfs] smb: Handle the anonymous flag when calling AskPassword
- From: Ross Lagerwall <rossl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gvfs] smb: Handle the anonymous flag when calling AskPassword
- Date: Wed, 21 Jan 2015 07:44:22 +0000 (UTC)
commit a0aec329939e198b6faea6b788df7278f6543436
Author: Ross Lagerwall <rosslagerwall gmail com>
Date: Thu Jan 1 09:29:08 2015 +0200
smb: Handle the anonymous flag when calling AskPassword
Previously, the smb backend would try logging in anonymously first if a
user is not specified making it difficult to mount a share as a specific
user from Nautilus. Instead, only try an anonymous login if the
anonymous flag is TRUE after calling AskPassword.
https://bugzilla.gnome.org/show_bug.cgi?id=742169
daemon/gvfsbackendsmb.c | 50 +++++++++++++++++++++++++++++++++-------------
1 files changed, 36 insertions(+), 14 deletions(-)
---
diff --git a/daemon/gvfsbackendsmb.c b/daemon/gvfsbackendsmb.c
index 74655a7..bdfb365 100644
--- a/daemon/gvfsbackendsmb.c
+++ b/daemon/gvfsbackendsmb.c
@@ -84,6 +84,7 @@ struct _GVfsBackendSmb
int mount_try;
gboolean mount_try_again;
gboolean mount_cancelled;
+ gboolean use_anonymous;
gboolean password_in_keyring;
GPasswordSave password_save;
@@ -176,7 +177,7 @@ auth_callback (SMBCCTX *context,
{
GVfsBackendSmb *backend;
char *ask_password, *ask_user, *ask_domain;
- gboolean handled, abort;
+ gboolean handled, abort, anonymous = FALSE;
backend = smbc_getOptionUserData (context);
@@ -213,9 +214,16 @@ auth_callback (SMBCCTX *context,
backend->user == NULL &&
backend->domain == NULL)
{
- /* Try again if kerberos login + anonymous fallback fails */
+ /* Try again if kerberos login fails */
backend->mount_try_again = TRUE;
- DEBUG ("auth_callback - anonymous pass\n");
+ DEBUG ("auth_callback - kerberos pass\n");
+ }
+ else if (backend->use_anonymous)
+ {
+ /* Try again if anonymous login fails */
+ backend->use_anonymous = FALSE;
+ backend->mount_try_again = TRUE;
+ DEBUG ("auth_callback - anonymous login pass\n");
}
else
{
@@ -254,6 +262,8 @@ auth_callback (SMBCCTX *context,
flags |= G_ASK_PASSWORD_NEED_DOMAIN;
if (backend->user == NULL)
flags |= G_ASK_PASSWORD_NEED_USERNAME;
+ if (backend->user == NULL && backend->domain == NULL)
+ flags |= G_ASK_PASSWORD_ANONYMOUS_SUPPORTED;
DEBUG ("auth_callback - asking for password...\n");
@@ -269,7 +279,7 @@ auth_callback (SMBCCTX *context,
&ask_password,
&ask_user,
&ask_domain,
- NULL,
+ &anonymous,
&(backend->password_save));
g_free (message);
if (!handled)
@@ -287,11 +297,19 @@ auth_callback (SMBCCTX *context,
/* Try again if this fails */
backend->mount_try_again = TRUE;
- strncpy (password_out, ask_password, pwmaxlen);
- if (ask_user && *ask_user)
- strncpy (username_out, ask_user, unmaxlen);
- if (ask_domain && *ask_domain)
- strncpy (domain_out, ask_domain, domainmaxlen);
+ if (anonymous)
+ {
+ backend->use_anonymous = TRUE;
+ backend->password_save = FALSE;
+ }
+ else
+ {
+ strncpy (password_out, ask_password, pwmaxlen);
+ if (ask_user && *ask_user)
+ strncpy (username_out, ask_user, unmaxlen);
+ if (ask_domain && *ask_domain)
+ strncpy (domain_out, ask_domain, domainmaxlen);
+ }
out:
g_free (ask_password);
@@ -551,8 +569,7 @@ do_mount (GVfsBackend *backend,
smbc_setOptionUseKerberos (smb_context, 1);
smbc_setOptionFallbackAfterKerberos (smb_context,
op_backend->user != NULL);
- smbc_setOptionNoAutoAnonymousLogin (smb_context,
- op_backend->user != NULL);
+ smbc_setOptionNoAutoAnonymousLogin (smb_context, TRUE);
#if 0
@@ -636,15 +653,20 @@ do_mount (GVfsBackend *backend,
}
/* The first round is Kerberos-only. Only if this fails do we enable
- * NTLMSSP fallback (turning off anonymous fallback, which we've
- * already tried and failed with).
+ * NTLMSSP fallback.
*/
if (op_backend->mount_try == 0)
{
DEBUG ("do_mount - after anon, enabling NTLMSSP fallback\n");
smbc_setOptionFallbackAfterKerberos (op_backend->smb_context, 1);
- smbc_setOptionNoAutoAnonymousLogin (op_backend->smb_context, 1);
}
+
+ /* If the AskPassword reply requested anonymous login, enable the
+ * anonymous fallback and try again.
+ */
+ smbc_setOptionNoAutoAnonymousLogin (op_backend->smb_context,
+ !op_backend->use_anonymous);
+
op_backend->mount_try ++;
}
while (op_backend->mount_try_again);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]