summaryrefslogtreecommitdiff
path: root/nscd
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2004-09-03 03:39:45 +0000
committerUlrich Drepper <drepper@redhat.com>2004-09-03 03:39:45 +0000
commit3c82c131d9d101248892d2b4579297bab3a31a4d (patch)
treeaf4b671fca54fa0772b7d02d25b738761d19f2de /nscd
parent91b52f4838fffe071bfbf489d4d9c62f32702287 (diff)
(nscd_run): Check early for invalid request types.
Diffstat (limited to 'nscd')
-rw-r--r--nscd/connections.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/nscd/connections.c b/nscd/connections.c
index c3100816df..53e258b498 100644
--- a/nscd/connections.c
+++ b/nscd/connections.c
@@ -786,6 +786,10 @@ nscd_run (void *p)
continue;
}
+ /* Check whether this is a valid request type. */
+ if (req.type < GETPWBYNAME || req.type >= LASTREQ)
+ goto close_and_out;
+
/* Some systems have no SO_PEERCRED implementation. They don't
care about security so we don't as well. */
#ifdef SO_PEERCRED
@@ -798,8 +802,7 @@ nscd_run (void *p)
{
dbg_log (_("error getting callers id: %s"),
strerror_r (errno, buf, sizeof (buf)));
- close (fd);
- continue;
+ goto close_and_out;
}
if (req.type < GETPWBYNAME || req.type > LASTDBREQ
@@ -825,8 +828,6 @@ nscd_run (void *p)
{
if (debug_level > 0)
dbg_log (_("key length in request too long: %d"), req.key_len);
- close (fd);
- continue;
}
else
{
@@ -859,11 +860,12 @@ handle_request: request received (Version = %d)"), req.version);
/* Phew, we got all the data, now process it. */
handle_request (fd, &req, keybuf, uid);
-
- /* We are done. */
- close (fd);
}
+ close_and_out:
+ /* We are done. */
+ close (fd);
+
/* Just determine whether any data is present. We do this to
measure whether clients are queued up. */
try_get: