r17064: lsa_GetUserName needs to return the name for S-1-5-7 on an anonymous login.
[jerry/samba.git] / source / rpc_server / srv_lsa_nt.c
index c513d8489cb2632d2a68ad1e23bae7d13494c4e6..ea2bc0fa7b588cf77c13266d60f40c50617df3fb 100644 (file)
@@ -1545,14 +1545,26 @@ NTSTATUS _lsa_enum_accounts(pipes_struct *p, LSA_Q_ENUM_ACCOUNTS *q_u, LSA_R_ENU
 
 NTSTATUS _lsa_unk_get_connuser(pipes_struct *p, LSA_Q_UNK_GET_CONNUSER *q_u, LSA_R_UNK_GET_CONNUSER *r_u)
 {
-       fstring username, domname;
+       const char *username, *domname;
        user_struct *vuser = get_valid_user_struct(p->vuid);
   
        if (vuser == NULL)
                return NT_STATUS_CANT_ACCESS_DOMAIN_INFO;
-  
-       fstrcpy(username, vuser->user.smb_name);
-       fstrcpy(domname, vuser->user.domain);
+
+       if (vuser->guest) {
+               /*
+                * I'm 99% sure this is not the right place to do this,
+                * global_sid_Anonymous should probably be put into the token
+                * instead of the guest id -- vl
+                */
+               if (!lookup_sid(p->mem_ctx, &global_sid_Anonymous,
+                               &domname, &username, NULL)) {
+                       return NT_STATUS_NO_MEMORY;
+               }
+       } else {
+               username = vuser->user.smb_name;
+               domname = vuser->user.domain;
+       }
   
        r_u->ptr_user_name = 1;
        init_unistr2(&r_u->uni2_user_name, username, UNI_STR_TERMINATE);