]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Report if no record is found by initgroups in nss_files.
authorUlrich Drepper <drepper@gmail.com>
Fri, 6 May 2011 16:54:12 +0000 (12:54 -0400)
committerUlrich Drepper <drepper@gmail.com>
Fri, 6 May 2011 16:54:12 +0000 (12:54 -0400)
ChangeLog
nss/nss_files/files-initgroups.c

index 18e5a48d8e16cf6cd64571f7d221183a29ebf954..83c0f9bdd2ec2ac3a9bbc477e9e91e19302a6b00 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2011-05-06  Ulrich Drepper  <drepper@gmail.com>
+
+       * nss/nss_files/files-initgroups.c (_nss_files_initgroups_dyn): Return
+       NSS_STATUS_NOTFOUND if no record was found.
+
 2011-05-05  Andreas Schwab  <schwab@redhat.com>
 
        * sunrpc/Makefile (headers): Add rpc/netdb.h.
index 4c7b9f8e6f4a5c5e07809c1327f2ea61f46131d8..113abf282155b6adfacca4e3b4bee6cfd7baee70 100644 (file)
@@ -43,6 +43,7 @@ _nss_files_initgroups_dyn (const char *user, gid_t group, long int *start,
   char *line = NULL;
   size_t linelen = 0;
   enum nss_status status = NSS_STATUS_SUCCESS;
+  bool any = false;
 
   size_t buflen = 1024;
   void *buffer = alloca (buflen);
@@ -118,6 +119,7 @@ _nss_files_initgroups_dyn (const char *user, gid_t group, long int *start,
 
              groups[*start] = grp.gr_gid;
              *start += 1;
+             any = true;
 
              break;
            }
@@ -131,5 +133,5 @@ _nss_files_initgroups_dyn (const char *user, gid_t group, long int *start,
 
   fclose (stream);
 
-  return status;
+  return status == NSS_STATUS_SUCCESS && !any ? NSS_STATUS_NOTFOUND : status;
 }