|
|
ce426f |
commit 58b930ae216bfa98cd60212b954b07b9963d6d04
|
|
|
ce426f |
Author: Siddhesh Poyarekar <siddhesh@redhat.com>
|
|
|
ce426f |
Date: Wed Sep 10 21:51:50 2014 +0530
|
|
|
ce426f |
|
|
|
ce426f |
Return failure in getnetgrent only when all netgroups have been searched (#17363)
|
|
|
ce426f |
|
|
|
ce426f |
The netgroups lookup code fails when one of the groups in the search
|
|
|
ce426f |
tree is empty. In such a case it only returns the leaves of the tree
|
|
|
ce426f |
after the blank netgroup. This is because the line parser returns a
|
|
|
ce426f |
NOTFOUND status when the netgroup exists but is empty. The
|
|
|
ce426f |
__getnetgrent_internal implementation needs to be fixed to try
|
|
|
ce426f |
remaining groups if the current group is entry. This patch implements
|
|
|
ce426f |
this fix. Tested on x86_64.
|
|
|
ce426f |
|
|
|
ce426f |
[BZ #17363]
|
|
|
ce426f |
* inet/getnetgrent_r.c (__internal_getnetgrent_r): Try next
|
|
|
ce426f |
group if the current group is empty.
|
|
|
ce426f |
|
|
|
ce426f |
diff --git glibc-2.17-c758a686/inet/getnetgrent_r.c glibc-2.17-c758a686/inet/getnetgrent_r.c
|
|
|
ce426f |
index f6d064d..e101537 100644
|
|
|
ce426f |
--- glibc-2.17-c758a686/inet/getnetgrent_r.c
|
|
|
ce426f |
+++ glibc-2.17-c758a686/inet/getnetgrent_r.c
|
|
|
ce426f |
@@ -297,7 +297,10 @@ __internal_getnetgrent_r (char **hostp, char **userp, char **domainp,
|
|
|
ce426f |
{
|
|
|
ce426f |
status = DL_CALL_FCT (*fct, (datap, buffer, buflen, &errno));
|
|
|
ce426f |
|
|
|
ce426f |
- if (status == NSS_STATUS_RETURN)
|
|
|
ce426f |
+ if (status == NSS_STATUS_RETURN
|
|
|
ce426f |
+ /* The service returned a NOTFOUND, but there are more groups that we
|
|
|
ce426f |
+ need to resolve before we give up. */
|
|
|
ce426f |
+ || (status == NSS_STATUS_NOTFOUND && datap->needed_groups != NULL))
|
|
|
ce426f |
{
|
|
|
ce426f |
/* This was the last one for this group. Look at next group
|
|
|
ce426f |
if available. */
|