diff options
author | DJ Delorie <dj@redhat.com> | 2021-02-15 21:34:23 -0500 |
---|---|---|
committer | DJ Delorie <dj@redhat.com> | 2021-03-09 14:34:50 -0500 |
commit | 9b456c5da968ee832ea4b2b73a18a5bf6d2118a6 (patch) | |
tree | e0f9e838dd5862499207e16cf6e8b3d15d49d374 /nss/nsswitch.c | |
parent | 24eb3be5db5befefe4bcf0f438bf6629a9c3a608 (diff) | |
download | glibc-9b456c5da968ee832ea4b2b73a18a5bf6d2118a6.zip glibc-9b456c5da968ee832ea4b2b73a18a5bf6d2118a6.tar.gz glibc-9b456c5da968ee832ea4b2b73a18a5bf6d2118a6.tar.bz2 |
nss: fix nss_database_lookup2's alternate handling [BZ #27416]
__nss_database_lookup2's extra arguments were left unused in the
nsswitch reloading patch set; this broke compat (default config
ignored) and shadow files (secondary name ignored) which relies on
these fallbacks.
This patch adds in the previous behavior by correcting the
initialization of the database list to reflect the fallbacks. This
means that the nss_database_lookup2 interface no longer needs to be
passed the fallback info, so API and callers were adjusted.
Since all callers needed to be edited anyway, the calls were changed
from __nss_database_lookup2 to the faster __nss_database_get. This
was an intended optimization which was deferred during the initial
lookup changes to avoid touching so many files.
The test case verifies that compat targets work (passwd) and that the
default configuration works (group). Tested on x86-64.
Diffstat (limited to 'nss/nsswitch.c')
-rw-r--r-- | nss/nsswitch.c | 40 |
1 files changed, 0 insertions, 40 deletions
diff --git a/nss/nsswitch.c b/nss/nsswitch.c index 46f232d..6b7d4c7 100644 --- a/nss/nsswitch.c +++ b/nss/nsswitch.c @@ -51,53 +51,13 @@ #undef DEFINE_DATABASE -#undef DEFINE_DATABASE -#define DEFINE_DATABASE(name) #name, -static const char * database_names[] = { -#include "databases.def" - NULL -}; - #ifdef USE_NSCD /* Flags whether custom rules for database is set. */ bool __nss_database_custom[NSS_DBSIDX_max]; #endif - /*__libc_lock_define_initialized (static, lock)*/ -/* -1 == database not found - 0 == database entry pointer stored */ -int -__nss_database_lookup2 (const char *database, const char *alternate_name, - const char *defconfig, nss_action_list *ni) -{ - int database_id; - - for (database_id = 0; database_names[database_id]; database_id++) - if (strcmp (database_names[database_id], database) == 0) - break; - - if (database_names[database_id] == NULL) - return -1; - - /* If *NI is NULL, the database was not mentioned in nsswitch.conf. - If *NI is not NULL, but *NI->module is NULL, the database was in - nsswitch.conf but listed no actions. We test for the former. */ - if (__nss_database_get (database_id, ni) && *ni != NULL) - { - /* Success. */ - return 0; - } - else - { - /* Failure. */ - return -1; - } -} -libc_hidden_def (__nss_database_lookup2) - - /* -1 == not found 0 == function found 1 == finished */ |