[Pkg-shadow-commits] r1346 - in upstream/trunk: . src
nekral-guest at alioth.debian.org
nekral-guest at alioth.debian.org
Fri Nov 16 11:32:42 UTC 2007
Author: nekral-guest
Date: 2007-11-16 11:32:42 +0000 (Fri, 16 Nov 2007)
New Revision: 1346
Modified:
upstream/trunk/ChangeLog
upstream/trunk/NEWS
upstream/trunk/configure.in
upstream/trunk/src/login_nopam.c
Log:
Add support for systems with no innetgr(). On those systems, username
with an @ will be treated like any other username (i.e. lookup in the
local database for an user with an @). Thanks to Mike Frysinger for the
patch.
Modified: upstream/trunk/ChangeLog
===================================================================
--- upstream/trunk/ChangeLog 2007-11-16 10:50:38 UTC (rev 1345)
+++ upstream/trunk/ChangeLog 2007-11-16 11:32:42 UTC (rev 1346)
@@ -1,5 +1,14 @@
2007-11-16 Nicolas François <nicolas.francois at centraliens.net>
+ * configure.in: Check if the netdb.h header file and the innetgr
+ function exist.
+ * src/login_nopam.c, NEWS: Add support for systems with no
+ innetgr(). On those systems, username with an @ will be treated
+ like any other username (i.e. lookup in the local database for an
+ user with an @). Thanks to Mike Frysinger for the patch.
+
+2007-11-16 Nicolas François <nicolas.francois at centraliens.net>
+
* src/useradd.c: Indentation fix.
2007-11-14 Nicolas François <nicolas.francois at centraliens.net>
Modified: upstream/trunk/NEWS
===================================================================
--- upstream/trunk/NEWS 2007-11-16 10:50:38 UTC (rev 1345)
+++ upstream/trunk/NEWS 2007-11-16 11:32:42 UTC (rev 1346)
@@ -15,6 +15,10 @@
- newgrp.c: Declare the child and pid variable at the beginning of a block.
This fixes a compilation issue with gcc 2.95. The intent is the same as
Gentoo's patch shadow-4.0.12-gcc2.patch.
+- login_nopam: Add support for systems with no innetgr(). On those
+ systems, username with an @ will be treated like any other username
+ (i.e. lookup in the local database for an user with an @). Thanks to
+ Mike Frysinger for the patch.
shadow-4.0.18.1 -> shadow-4.0.18.2 28-10-2007
Modified: upstream/trunk/configure.in
===================================================================
--- upstream/trunk/configure.in 2007-11-16 10:50:38 UTC (rev 1345)
+++ upstream/trunk/configure.in 2007-11-16 11:32:42 UTC (rev 1346)
@@ -32,11 +32,11 @@
AC_CHECK_HEADERS(errno.h fcntl.h limits.h unistd.h sys/time.h utmp.h \
utmpx.h termios.h termio.h sgtty.h sys/ioctl.h syslog.h paths.h \
utime.h ulimit.h sys/resource.h gshadow.h shadow.h lastlog.h \
- locale.h rpc/key_prot.h)
+ locale.h rpc/key_prot.h netdb.h)
AC_CHECK_FUNCS(a64l fchmod fchown fsync getgroups gethostname getspnam \
gettimeofday getusershell getutent initgroups lchown lckpwdf lstat \
- memcpy memset setgroups sigaction strchr updwtmp updwtmpx)
+ memcpy memset setgroups sigaction strchr updwtmp updwtmpx innetgr)
AC_SYS_LARGEFILE
dnl Checks for typedefs, structures, and compiler characteristics.
Modified: upstream/trunk/src/login_nopam.c
===================================================================
--- upstream/trunk/src/login_nopam.c 2007-11-16 10:50:38 UTC (rev 1345)
+++ upstream/trunk/src/login_nopam.c 2007-11-16 11:32:42 UTC (rev 1346)
@@ -37,7 +37,9 @@
#include <stdio.h>
#include <syslog.h>
#include <ctype.h>
+#ifdef HAVE_NETDB_H
#include <netdb.h>
+#endif
#include <grp.h>
#ifdef PRIMARY_GROUP_MATCH
#include <pwd.h>
@@ -49,8 +51,6 @@
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h> /* for inet_ntoa() */
-extern struct group *getgrnam ();
-extern int innetgr ();
#if !defined(MAXHOSTNAMELEN) || (MAXHOSTNAMELEN < 64)
#undef MAXHOSTNAMELEN
@@ -178,6 +178,7 @@
return (name);
}
+#if HAVE_INNETGR
/* netgroup_match - match group against machine or user */
static int
netgroup_match (const char *group, const char *machine, const char *user)
@@ -193,6 +194,7 @@
return innetgr (group, machine, user, mydomain);
}
+#endif
/* user_match - match a username against one token */
static int user_match (const char *tok, const char *string)
@@ -214,8 +216,10 @@
*at = 0;
return (user_match (tok, string)
&& from_match (at + 1, myhostname ()));
+#if HAVE_INNETGR
} else if (tok[0] == '@') { /* netgroup */
return (netgroup_match (tok + 1, (char *) 0, string));
+#endif
} else if (string_match (tok, string)) { /* ALL or exact match */
return (YES);
} else if ((group = getgrnam (tok))) { /* try group membership */
@@ -271,9 +275,12 @@
* contain a "." character. If the token is a network number, return YES
* if it matches the head of the string.
*/
+#if HAVE_INNETGR
if (tok[0] == '@') { /* netgroup */
return (netgroup_match (tok + 1, string, (char *) 0));
- } else if (string_match (tok, string)) { /* ALL or exact match */
+ } else
+#endif
+ if (string_match (tok, string)) { /* ALL or exact match */
return (YES);
} else if (tok[0] == '.') { /* domain: match last fields */
if ((str_len = strlen (string)) > (tok_len = strlen (tok))
More information about the Pkg-shadow-commits
mailing list