2007-10-07 11:44:02 +00:00
|
|
|
dnl Process this file with autoconf to produce a configure script.
|
2007-10-07 11:45:23 +00:00
|
|
|
AC_INIT
|
2008-04-02 21:55:27 +00:00
|
|
|
AM_INIT_AUTOMAKE(shadow, 4.1.1)
|
2007-10-07 11:45:23 +00:00
|
|
|
AC_CONFIG_HEADERS([config.h])
|
2007-10-07 11:44:02 +00:00
|
|
|
|
|
|
|
dnl Some hacks...
|
|
|
|
test "$prefix" = "NONE" && prefix="/usr"
|
|
|
|
test "$prefix" = "/usr" && exec_prefix=""
|
|
|
|
|
2007-10-07 11:46:07 +00:00
|
|
|
AC_GNU_SOURCE
|
|
|
|
|
2007-10-07 11:44:51 +00:00
|
|
|
AM_DISABLE_SHARED
|
|
|
|
AM_ENABLE_STATIC
|
|
|
|
|
2007-10-07 11:45:23 +00:00
|
|
|
AM_MAINTAINER_MODE
|
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
dnl Checks for programs.
|
|
|
|
AC_PROG_CC
|
|
|
|
AC_ISC_POSIX
|
|
|
|
AC_PROG_LN_S
|
|
|
|
AC_PROG_YACC
|
|
|
|
AM_C_PROTOTYPES
|
|
|
|
AM_PROG_LIBTOOL
|
|
|
|
|
|
|
|
dnl Checks for libraries.
|
|
|
|
|
|
|
|
dnl Checks for header files.
|
|
|
|
AC_HEADER_DIRENT
|
|
|
|
AC_HEADER_STDC
|
|
|
|
AC_HEADER_SYS_WAIT
|
2007-10-07 11:44:51 +00:00
|
|
|
|
2007-10-07 11:45:40 +00:00
|
|
|
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 \
|
2008-01-05 16:33:43 +00:00
|
|
|
utime.h ulimit.h sys/resource.h gshadow.h lastlog.h \
|
2007-11-16 11:32:42 +00:00
|
|
|
locale.h rpc/key_prot.h netdb.h)
|
2007-10-07 11:44:51 +00:00
|
|
|
|
2008-01-05 16:33:43 +00:00
|
|
|
dnl shadow now uses the libc's shadow implementation
|
|
|
|
AC_CHECK_HEADER([shadow.h],,[AC_MSG_ERROR([You need a libc with shadow.h])])
|
|
|
|
|
2007-11-16 12:36:21 +00:00
|
|
|
AC_CHECK_FUNCS(l64a fchmod fchown fsync getgroups gethostname getspnam \
|
2007-10-07 11:44:51 +00:00
|
|
|
gettimeofday getusershell getutent initgroups lchown lckpwdf lstat \
|
* lib/prototypes.h, configure.in, libmisc/Makefile.am,
libmisc/xgetXXbyYY.c, libmisc/xgetpwnam.c, libmisc/xgetpwuid.c,
libmisc/xgetgrnam.c, libmisc/xgetgrgid.c, libmisc/xgetspnam.c:
Added functions xgetpwnam(), xgetpwuid(), xgetgrnam(),
xgetgrgid(), and xgetspnam(). They allocate memory for the
returned structure and are more robust to successive calls. They
are implemented with the libc's getxxyyy_r() functions if
available.
* libmisc/limits.c, libmisc/entry.c, libmisc/chowntty.c,
libmisc/addgrps.c, libmisc/myname.c, libmisc/rlogin.c,
libmisc/pwdcheck.c, src/newgrp.c, src/login_nopam.c,
src/userdel.c, src/lastlog.c, src/grpck.c, src/gpasswd.c,
src/newusers.c, src/chpasswd.c, src/chfn.c, src/groupmems.c,
src/usermod.c, src/expiry.c, src/groupdel.c, src/chgpasswd.c,
src/su.c, src/useradd.c, src/groupmod.c, src/passwd.c, src/pwck.c,
src/groupadd.c, src/chage.c, src/login.c, src/suauth.c,
src/faillog.c, src/groups.c, src/chsh.c, src/id.c: Review all the
usage of one of the getpwnam(), getpwuid(), getgrnam(),
getgrgid(), and getspnam() functions. It was noticed on
http://bugs.debian.org/341230 that chfn and chsh use a passwd
structure after calling a pam function, which result in using
information from the passwd structure requested by pam, not the
original one. It is much easier to use the new xget... functions
to avoid these issues. I've checked which call to the original
get... functions could be left (reducing the scope of the
structure if possible), and I've left comments to ease future
reviews (e.g. /* local, no need for xgetpwnam */).
Note: the getpwent/getgrent calls should probably be checked also.
* src/groupdel.c, src/expiry.c: Fix typos in comments.
* src/groupmod.c: Re-indent.
* libmisc/Makefile.am, lib/groupmem.c, lib/groupio.c, lib/pwmem.c,
lib/pwio.c, lib/shadowmem.c, lib/shadowio.c: Move the __<xx>_dup
functions (used by the xget... functions) from the <xx>io.c files
to the new <xx>mem.c files. This avoid linking some utils against
the SELinux library.
2007-11-18 23:15:26 +00:00
|
|
|
memcpy memset setgroups sigaction strchr updwtmp updwtmpx innetgr \
|
|
|
|
getpwnam_r getpwuid_r getgrnam_r getgrgid_r getspnam_r)
|
2007-10-07 11:45:58 +00:00
|
|
|
AC_SYS_LARGEFILE
|
2007-10-07 11:44:02 +00:00
|
|
|
|
|
|
|
dnl Checks for typedefs, structures, and compiler characteristics.
|
|
|
|
AC_C_CONST
|
|
|
|
AC_TYPE_UID_T
|
|
|
|
AC_TYPE_OFF_T
|
|
|
|
AC_TYPE_PID_T
|
|
|
|
AC_TYPE_MODE_T
|
|
|
|
AC_HEADER_STAT
|
2007-10-07 11:45:23 +00:00
|
|
|
AC_CHECK_MEMBERS([struct stat.st_rdev])
|
2007-10-07 11:44:02 +00:00
|
|
|
AC_HEADER_TIME
|
|
|
|
AC_STRUCT_TM
|
|
|
|
|
|
|
|
if test "$ac_cv_header_utmp_h" = "yes"; then
|
|
|
|
AC_CACHE_CHECK(for ut_host in struct utmp,
|
2007-10-07 11:45:23 +00:00
|
|
|
ac_cv_struct_utmp_ut_host,
|
|
|
|
AC_COMPILE_IFELSE(
|
|
|
|
[AC_LANG_PROGRAM([#include <utmp.h>],
|
|
|
|
[struct utmp ut; char *cp = ut.ut_host;]
|
|
|
|
)],
|
|
|
|
[ac_cv_struct_utmp_ut_host=yes],
|
|
|
|
[ac_cv_struct_utmp_ut_host=no]
|
|
|
|
)
|
|
|
|
)
|
2007-10-07 11:44:02 +00:00
|
|
|
|
|
|
|
if test "$ac_cv_struct_utmp_ut_host" = "yes"; then
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE(UT_HOST, 1, [Define if you have ut_host in struct utmp.])
|
2007-10-07 11:44:02 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
AC_CACHE_CHECK(for ut_user in struct utmp,
|
2007-10-07 11:45:23 +00:00
|
|
|
ac_cv_struct_utmp_ut_user,
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <utmp.h>],
|
|
|
|
[struct utmp ut; char *cp = ut.ut_user;]
|
|
|
|
)],
|
|
|
|
[ac_cv_struct_utmp_ut_user=yes],
|
|
|
|
[ac_cv_struct_utmp_ut_user=no]
|
|
|
|
)
|
|
|
|
)
|
2007-10-07 11:44:02 +00:00
|
|
|
|
|
|
|
if test "$ac_cv_struct_utmp_ut_user" = "no"; then
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE(ut_user, ut_name,
|
|
|
|
[Define to ut_name if struct utmp has ut_name (not ut_user).])
|
2007-10-07 11:44:02 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$ac_cv_header_lastlog_h" = "yes"; then
|
|
|
|
AC_CACHE_CHECK(for ll_host in struct lastlog,
|
2007-10-07 11:45:23 +00:00
|
|
|
ac_cv_struct_lastlog_ll_host,
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <lastlog.h>],
|
|
|
|
[struct lastlog ll; char *cp = ll.ll_host;]
|
|
|
|
)],
|
|
|
|
[ac_cv_struct_lastlog_ll_host=yes],
|
|
|
|
[ac_cv_struct_lastlog_ll_host=no]
|
|
|
|
)
|
|
|
|
)
|
2007-10-07 11:44:02 +00:00
|
|
|
|
|
|
|
if test "$ac_cv_struct_lastlog_ll_host" = "yes"; then
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE(HAVE_LL_HOST, 1,
|
|
|
|
[Define if struct lastlog has ll_host])
|
2007-10-07 11:44:02 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl Checks for library functions.
|
|
|
|
AC_TYPE_GETGROUPS
|
|
|
|
AC_TYPE_SIGNAL
|
|
|
|
AC_FUNC_UTIME_NULL
|
|
|
|
AC_FUNC_STRFTIME
|
|
|
|
AC_REPLACE_FUNCS(mkdir putgrent putpwent putspent rename rmdir)
|
|
|
|
AC_REPLACE_FUNCS(sgetgrent sgetpwent sgetspent)
|
|
|
|
AC_REPLACE_FUNCS(snprintf strcasecmp strdup strerror strstr)
|
|
|
|
|
|
|
|
AC_CHECK_FUNC(setpgrp)
|
|
|
|
AC_FUNC_SETPGRP
|
|
|
|
|
|
|
|
if test "$ac_cv_header_shadow_h" = "yes"; then
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_CACHE_CHECK(for working shadow group support,
|
|
|
|
ac_cv_libc_shadowgrp,
|
|
|
|
AC_RUN_IFELSE([AC_LANG_SOURCE([
|
|
|
|
#include <shadow.h>
|
|
|
|
main()
|
|
|
|
{
|
|
|
|
struct sgrp *sg = sgetsgent("test:x::");
|
|
|
|
/* NYS libc on Red Hat 3.0.3 has broken shadow group support */
|
|
|
|
return !sg || !sg->sg_adm || !sg->sg_mem;
|
|
|
|
}]
|
|
|
|
)],
|
|
|
|
[ac_cv_libc_shadowgrp=yes],
|
|
|
|
[ac_cv_libc_shadowgrp=no],
|
|
|
|
[ac_cv_libc_shadowgrp=no]
|
|
|
|
)
|
2007-10-07 11:45:23 +00:00
|
|
|
)
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:46:34 +00:00
|
|
|
if test "$ac_cv_libc_shadowgrp" = "yes"; then
|
|
|
|
AC_DEFINE(HAVE_SHADOWGRP, 1, [Have working shadow group support in libc])
|
|
|
|
fi
|
2007-10-07 11:44:02 +00:00
|
|
|
fi
|
|
|
|
|
2007-10-07 11:45:40 +00:00
|
|
|
AC_CACHE_CHECK([location of shared mail directory], shadow_cv_maildir,
|
2007-10-07 11:45:49 +00:00
|
|
|
[for shadow_cv_maildir in /var/mail /var/spool/mail /usr/spool/mail /usr/mail none; do
|
|
|
|
if test -d $shadow_cv_maildir; then
|
2007-10-07 11:44:02 +00:00
|
|
|
break
|
|
|
|
fi
|
2007-10-07 11:45:40 +00:00
|
|
|
done])
|
2007-10-07 11:45:49 +00:00
|
|
|
if test $shadow_cv_maildir != none; then
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE_UNQUOTED(MAIL_SPOOL_DIR, "$shadow_cv_maildir",
|
|
|
|
[Location of system mail spool directory.])
|
2007-10-07 11:45:49 +00:00
|
|
|
fi
|
2007-10-07 11:45:40 +00:00
|
|
|
|
|
|
|
AC_CACHE_CHECK([location of user mail file], shadow_cv_mailfile,
|
2007-10-07 11:45:49 +00:00
|
|
|
[for shadow_cv_mailfile in Mailbox mailbox Mail mail .mail none; do
|
2007-10-07 11:45:40 +00:00
|
|
|
if test -f $HOME/$shadow_cv_mailfile; then
|
2007-10-07 11:44:02 +00:00
|
|
|
break
|
|
|
|
fi
|
2007-10-07 11:45:40 +00:00
|
|
|
done])
|
2007-10-07 11:45:49 +00:00
|
|
|
if test $shadow_cv_mailfile != none; then
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE_UNQUOTED(MAIL_SPOOL_FILE, "$shadow_cv_mailfile",
|
|
|
|
[Name of user's mail spool file if stored in user's home directory.])
|
2007-10-07 11:45:49 +00:00
|
|
|
fi
|
2007-10-07 11:45:40 +00:00
|
|
|
|
|
|
|
AC_CACHE_CHECK([location of utmp], shadow_cv_utmpdir,
|
2007-10-07 11:46:07 +00:00
|
|
|
[for shadow_cv_utmpdir in /var/run /var/adm /usr/adm /etc none; do
|
2007-10-07 11:45:40 +00:00
|
|
|
if test -f $shadow_cv_utmpdir/utmp; then
|
2007-10-07 11:44:02 +00:00
|
|
|
break
|
|
|
|
fi
|
2007-10-07 11:45:40 +00:00
|
|
|
done])
|
|
|
|
if test "$shadow_cv_utmpdir" = "none"; then
|
|
|
|
AC_MSG_WARN(utmp file not found)
|
|
|
|
fi
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE_UNQUOTED(_UTMP_FILE, "$shadow_cv_utmpdir/utmp",
|
|
|
|
[Path for utmp file.])
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:45:40 +00:00
|
|
|
AC_CACHE_CHECK([location of faillog/lastlog/wtmp], shadow_cv_logdir,
|
|
|
|
[for shadow_cv_logdir in /var/log /var/adm /usr/adm /etc; do
|
2007-10-07 11:47:11 +00:00
|
|
|
if test -d $shadow_cv_logdir; then
|
2007-10-07 11:44:02 +00:00
|
|
|
break
|
|
|
|
fi
|
2007-10-07 11:45:40 +00:00
|
|
|
done])
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE_UNQUOTED(_WTMP_FILE, "$shadow_cv_logdir/wtmp",
|
|
|
|
[Path for wtmp file.])
|
|
|
|
AC_DEFINE_UNQUOTED(LASTLOG_FILE, "$shadow_cv_logdir/lastlog",
|
|
|
|
[Path for lastlog file.])
|
|
|
|
AC_DEFINE_UNQUOTED(FAILLOG_FILE, "$shadow_cv_logdir/faillog",
|
|
|
|
[Path for faillog file.])
|
2007-10-07 11:45:40 +00:00
|
|
|
|
|
|
|
AC_CACHE_CHECK([location of the passwd program], shadow_cv_passwd_dir,
|
|
|
|
[if test -f /usr/bin/passwd; then
|
|
|
|
shadow_cv_passwd_dir=/usr/bin
|
2007-10-07 11:44:02 +00:00
|
|
|
else
|
2007-10-07 11:45:40 +00:00
|
|
|
shadow_cv_passwd_dir=/bin
|
|
|
|
fi])
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE_UNQUOTED(PASSWD_PROGRAM, "$shadow_cv_passwd_dir/passwd",
|
|
|
|
[Path to passwd program.])
|
2007-10-07 11:44:02 +00:00
|
|
|
|
|
|
|
dnl XXX - quick hack, should disappear before anyone notices :).
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE(USE_SYSLOG, 1, [Define to use syslog().])
|
|
|
|
AC_DEFINE(RLOGIN, 1, [Define if login should support the -r flag for rlogind.])
|
|
|
|
AC_DEFINE(RUSEROK, 0, [Define to the ruserok() "success" return value (0 or 1).])
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:46:43 +00:00
|
|
|
AC_ARG_ENABLE(shadowgrp,
|
2007-10-07 11:47:01 +00:00
|
|
|
[AC_HELP_STRING([--enable-shadowgrp], [enable shadow group support @<:@default=yes@:>@])],
|
2007-10-07 11:46:43 +00:00
|
|
|
[case "${enableval}" in
|
|
|
|
yes) enable_shadowgrp="yes" ;;
|
|
|
|
no) enable_shadowgrp="no" ;;
|
|
|
|
*) AC_MSG_ERROR(bad value ${enableval} for --enable-shadowgrp) ;;
|
|
|
|
esac],
|
2007-10-07 11:46:52 +00:00
|
|
|
[enable_shadowgrp="yes"]
|
2007-10-07 11:46:43 +00:00
|
|
|
)
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:47:01 +00:00
|
|
|
AC_ARG_ENABLE(man,
|
|
|
|
[AC_HELP_STRING([--enable-man],
|
|
|
|
[regenerate roff man pages from Docbook @<:@default=no@:>@])],
|
|
|
|
[enable_man=yes],
|
|
|
|
[enable_man=no]
|
|
|
|
)
|
|
|
|
|
|
|
|
AC_ARG_WITH(audit,
|
|
|
|
[AC_HELP_STRING([--with-audit], [use auditing support @<:@default=yes if found@:>@])],
|
2008-04-16 20:09:03 +00:00
|
|
|
[with_audit=$withval], [with_audit=maybe])
|
2007-10-07 11:47:01 +00:00
|
|
|
AC_ARG_WITH(libpam,
|
|
|
|
[AC_HELP_STRING([--with-libpam], [use libpam for PAM support @<:@default=yes if found@:>@])],
|
2008-04-16 21:18:20 +00:00
|
|
|
[with_libpam=$withval], [with_libpam=maybe])
|
2007-10-07 11:47:01 +00:00
|
|
|
AC_ARG_WITH(selinux,
|
2008-04-16 20:16:43 +00:00
|
|
|
[AC_HELP_STRING([--with-selinux], [use SELinux support @<:@default=yes if found@:>@])],
|
2008-04-16 21:18:20 +00:00
|
|
|
[with_selinux=$withval], [with_selinux=maybe])
|
2007-10-07 11:47:01 +00:00
|
|
|
AC_ARG_WITH(skey,
|
|
|
|
[AC_HELP_STRING([--with-skey], [use S/Key support @<:@default=no@:>@])],
|
|
|
|
[with_skey=$withval], [with_skey=no])
|
|
|
|
AC_ARG_WITH(libcrack,
|
|
|
|
[AC_HELP_STRING([--with-libcrack], [use libcrack @<:@default=yes if found and if PAM not enabled@:>@])],
|
|
|
|
[with_libcrack=$withval], [with_libcrack=no])
|
* configure.in: New configure option: --with-sha-crypt enabled by
default. Keeping the feature enabled is safe. Disabling it permits
to disable the references to the SHA256 and SHA512 password
encryption algorithms from the usage help and manuals (in addition
to the support for these algorithms in the code).
* libmisc/obscure.c, libmisc/salt.c, src/newusers.c,
src/chpasswd.c, src/chgpasswd.c, src/passwd.c: ENCRYPT_METHOD is
always supported in login.defs. Remove the ENCRYPTMETHOD_SELECT
preprocessor condition.
* libmisc/obscure.c, libmisc/salt.c, src/newusers.c,
src/chpasswd.c, src/chgpasswd.c, src/passwd.c: Disable SHA256 and
SHA512 if USE_SHA_CRYPT is not defined (this corresponds to a
subset of the ENCRYPTMETHOD_SELECT sections).
2007-11-24 13:08:08 +00:00
|
|
|
AC_ARG_WITH(sha-crypt,
|
|
|
|
[AC_HELP_STRING([--with-sha-crypt], [allow the SHA256 and SHA512 password encryption algorithms @<:@default=yes@:>@])],
|
|
|
|
[with_sha_crypt=$withval], [with_sha_crypt=yes])
|
|
|
|
|
|
|
|
AM_CONDITIONAL(USE_SHA_CRYPT, test "x$with_sha_crypt" = "xyes")
|
|
|
|
if test "$with_sha_crypt" = "yes"; then
|
|
|
|
AC_DEFINE(USE_SHA_CRYPT, 1, [Define to allow the SHA256 and SHA512 password encryption algorithms])
|
|
|
|
fi
|
2007-10-07 11:44:02 +00:00
|
|
|
|
|
|
|
dnl Check for some functions in libc first, only if not found check for
|
|
|
|
dnl other libraries. This should prevent linking libnsl if not really
|
|
|
|
dnl needed (Linux glibc, Irix), but still link it if needed (Solaris).
|
|
|
|
|
2007-10-07 11:45:40 +00:00
|
|
|
AC_SEARCH_LIBS(inet_ntoa, inet)
|
|
|
|
AC_SEARCH_LIBS(socket, socket)
|
|
|
|
AC_SEARCH_LIBS(gethostbyname, nsl)
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:46:34 +00:00
|
|
|
if test "$enable_shadowgrp" = "yes"; then
|
|
|
|
AC_DEFINE(SHADOWGRP, 1, [Define to support the shadow group file.])
|
2007-10-07 11:44:02 +00:00
|
|
|
fi
|
2007-11-22 21:36:38 +00:00
|
|
|
AM_CONDITIONAL(SHADOWGRP, test "x$enable_shadowgrp" = "xyes")
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:47:01 +00:00
|
|
|
if test "$enable_man" = "yes"; then
|
|
|
|
dnl
|
|
|
|
dnl Check for xsltproc
|
|
|
|
dnl
|
|
|
|
AC_PATH_PROG([XSLTPROC], [xsltproc])
|
|
|
|
if test -z "$XSLTPROC"; then
|
|
|
|
enable_man=no
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl check for DocBook DTD and stylesheets in the local catalog.
|
|
|
|
JH_CHECK_XML_CATALOG([-//OASIS//DTD DocBook XML V4.1.2//EN],
|
|
|
|
[DocBook XML DTD V4.1.2], [], enable_man=no)
|
2007-10-07 11:47:45 +00:00
|
|
|
JH_CHECK_XML_CATALOG([http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl],
|
2007-10-07 11:47:33 +00:00
|
|
|
[DocBook XSL Stylesheets >= 1.70.1], [], enable_man=no)
|
2007-10-07 11:47:01 +00:00
|
|
|
fi
|
|
|
|
AM_CONDITIONAL(ENABLE_REGENERATE_MAN, test x$enable_man != xno)
|
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
AC_SUBST(LIBCRYPT)
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_CHECK_LIB(crypt, crypt, [LIBCRYPT=-lcrypt],
|
|
|
|
[AC_MSG_ERROR([crypt() not found])])
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:47:01 +00:00
|
|
|
AC_SUBST(LIBAUDIT)
|
2008-04-16 20:09:03 +00:00
|
|
|
if test "$with_audit" != "no"; then
|
2007-10-07 11:47:01 +00:00
|
|
|
AC_CHECK_HEADER(libaudit.h, [audit_header="yes"], [audit_header="no"])
|
2008-04-16 20:09:03 +00:00
|
|
|
if test "$audit_header$with_audit" = "noyes" ; then
|
|
|
|
AC_MSG_ERROR([libaudit.h is missing])
|
|
|
|
elif test "$audit_header" = "yes"; then
|
2007-10-07 11:47:11 +00:00
|
|
|
AC_CHECK_LIB(audit, audit_log_acct_message,
|
2008-04-16 20:09:03 +00:00
|
|
|
[audit_lib="yes"], [audit_lib="no"])
|
|
|
|
if test "$audit_lib$with_audit" = "noyes" ; then
|
|
|
|
AC_MSG_ERROR([libaudit not found])
|
|
|
|
elif test "$audit_lib" = "no" ; then
|
|
|
|
with_audit="no"
|
|
|
|
else
|
|
|
|
AC_DEFINE(WITH_AUDIT, 1,
|
|
|
|
[Define if you want to enable Audit messages])
|
|
|
|
LIBAUDIT="-laudit"
|
|
|
|
with_audit="yes"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
with_audit="no"
|
2007-10-07 11:47:01 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
AC_SUBST(LIBCRACK)
|
2007-10-07 11:46:34 +00:00
|
|
|
if test "$with_libcrack" = "yes"; then
|
2007-10-07 11:44:02 +00:00
|
|
|
echo "checking cracklib flavour, don't be surprised by the results"
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_CHECK_LIB(crack, FascistCheck,
|
|
|
|
[LIBCRACK=-lcrack AC_DEFINE(HAVE_LIBCRACK, 1, [Defined if you have libcrack.])])
|
|
|
|
AC_CHECK_LIB(crack, FascistHistory,
|
|
|
|
AC_DEFINE(HAVE_LIBCRACK_HIST, 1, [Defined if you have the ts&szs cracklib.]))
|
|
|
|
AC_CHECK_LIB(crack, FascistHistoryPw,
|
|
|
|
AC_DEFINE(HAVE_LIBCRACK_PW, 1, [Defined if it includes *Pw functions.]))
|
2007-10-07 11:44:02 +00:00
|
|
|
fi
|
|
|
|
|
2008-04-16 21:18:20 +00:00
|
|
|
AC_SUBST(LIBSELINUX)
|
|
|
|
if test "$with_selinux" != "no"; then
|
|
|
|
AC_CHECK_HEADERS(selinux/selinux.h, [selinux_header="yes"], [selinux_header="no"])
|
|
|
|
if test "$selinux_header$with_selinux" = "noyes" ; then
|
|
|
|
AC_MSG_ERROR([selinux/selinux.h is missing])
|
|
|
|
elif test "$selinux_header" = "yes" ; then
|
|
|
|
AC_CHECK_LIB(selinux, is_selinux_enabled,
|
|
|
|
[selinux_lib="yes"], [selinux_lib="no"])
|
|
|
|
if test "$selinux_lib$with_selinux" = "noyes" ; then
|
|
|
|
AC_MSG_ERROR([libselinux not found])
|
|
|
|
elif test "$selinux_lib" = "no" ; then
|
|
|
|
with_selinux="no"
|
|
|
|
else
|
|
|
|
AC_DEFINE(WITH_SELINUX, 1,
|
|
|
|
[Build shadow with SELinux support])
|
|
|
|
LIBSELINUX="-lselinux"
|
2008-04-16 21:24:14 +00:00
|
|
|
with_selinux="yes"
|
2008-04-16 21:18:20 +00:00
|
|
|
fi
|
|
|
|
else
|
|
|
|
with_selinux="no"
|
|
|
|
fi
|
2007-10-07 11:45:40 +00:00
|
|
|
fi
|
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
AC_SUBST(LIBPAM)
|
2008-04-16 21:18:20 +00:00
|
|
|
if test "$with_libpam" != "no"; then
|
2007-10-07 11:44:51 +00:00
|
|
|
AC_CHECK_LIB(pam, pam_start,
|
2008-04-16 21:18:20 +00:00
|
|
|
[pam_lib="yes"], [pam_lib="no"])
|
|
|
|
if test "$pam_lib$with_libpam" = "noyes" ; then
|
|
|
|
AC_MSG_ERROR(libpam not found)
|
|
|
|
fi
|
|
|
|
|
|
|
|
AC_CHECK_LIB(pam_misc, main,
|
|
|
|
[pam_misc_lib="yes"], [pam_misc_lib="no"])
|
|
|
|
if test "$pam_misc_lib$with_libpam" = "noyes" ; then
|
|
|
|
AC_MSG_ERROR(libpam_misc not found)
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$pam_lib$pam_misc_lib" = "yesyes" ; then
|
|
|
|
with_libpam="yes"
|
|
|
|
else
|
|
|
|
with_libpam="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
dnl Now with_libpam is either yes or no
|
|
|
|
if test "$with_libpam" = "yes"; then
|
|
|
|
AC_DEFINE(USE_PAM, 1, [Define to support Pluggable Authentication Modules])
|
|
|
|
AM_CONDITIONAL(USE_PAM, [true])
|
|
|
|
LIBPAM="-lpam -lpam_misc"
|
2007-10-07 11:44:51 +00:00
|
|
|
AC_MSG_CHECKING(use login and su access checking if PAM not used)
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
else
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_DEFINE(SU_ACCESS, 1, [Define to support /etc/suauth su access control.])
|
2007-10-07 11:47:33 +00:00
|
|
|
AM_CONDITIONAL(USE_PAM, [false])
|
2008-04-16 21:18:20 +00:00
|
|
|
AC_MSG_CHECKING(use login and su access checking if PAM not used)
|
|
|
|
AC_MSG_RESULT(yes)
|
2007-10-07 11:44:02 +00:00
|
|
|
fi
|
|
|
|
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_SUBST(LIBSKEY)
|
|
|
|
AC_SUBST(LIBMD)
|
2007-10-07 11:47:01 +00:00
|
|
|
if test "$with_skey" = "yes"; then
|
2007-10-07 11:46:34 +00:00
|
|
|
AC_CHECK_LIB(md, MD5Init, [LIBMD=-lmd])
|
|
|
|
AC_CHECK_LIB(skey, skeychallenge, [LIBSKEY=-lskey],
|
|
|
|
[AC_MSG_ERROR([liskey missing. You can download S/Key source code from http://rsync1.it.gentoo.org/gentoo/distfiles/skey-1.1.5.tar.bz2])])
|
|
|
|
AC_DEFINE(SKEY, 1, [Define to support S/Key logins.])
|
2007-10-07 11:47:22 +00:00
|
|
|
AC_TRY_COMPILE([
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <skey.h>
|
|
|
|
],[
|
|
|
|
skeychallenge((void*)0, (void*)0, (void*)0, 0);
|
|
|
|
],[AC_DEFINE(SKEY_BSD_STYLE, 1, [Define to support newer BSD S/Key API])])
|
2007-10-07 11:46:34 +00:00
|
|
|
fi
|
|
|
|
|
2007-10-27 23:22:11 +00:00
|
|
|
AM_GNU_GETTEXT_VERSION(0.16)
|
2007-10-07 11:46:52 +00:00
|
|
|
AM_GNU_GETTEXT([external], [need-ngettext])
|
2007-10-07 11:47:22 +00:00
|
|
|
AM_CONDITIONAL(USE_NLS, test "x$USE_NLS" = "xyes")
|
2007-10-07 11:44:02 +00:00
|
|
|
|
2007-10-07 11:45:23 +00:00
|
|
|
AC_CONFIG_FILES([
|
2007-10-07 11:44:51 +00:00
|
|
|
Makefile
|
|
|
|
po/Makefile.in
|
|
|
|
doc/Makefile
|
|
|
|
man/Makefile
|
* configure.in, man/po/Makefile.in.in, man/po/Makevars,
man/po/POTFILES.in, man/Makefile.am: Generate the PO files for the
manpages in the man/po directory (instead of man/<lang>). Use a
Makefile.in.in based on gettext's one. This ensure that the PO are
generated before being used in the <lang> directories.
* man/generate_mans.mak, man/generate_translations.mak,
man/Makefile.am: New makefile for the generation of manpages from
XML (generate_mans.mak). This avoid duplicate chunks in
generate_translations.mak and Makefile.am
* man/de/de.po, man/fr/fr.po, man/it/it.po, man/pl/pl.po,
man/ru/ru.po, man/sv/sv.po: Moved to...
* man/po/de.po, man/po/fr.po, man/po/it.po, man/po/pl.po,
man/po/ru.po, man/po/sv.po: ... here.
2007-11-25 21:02:32 +00:00
|
|
|
man/po/Makefile.in
|
2007-10-07 11:45:14 +00:00
|
|
|
man/cs/Makefile
|
|
|
|
man/de/Makefile
|
2007-10-07 11:45:23 +00:00
|
|
|
man/es/Makefile
|
2007-10-07 11:47:11 +00:00
|
|
|
man/fi/Makefile
|
2007-10-07 11:45:14 +00:00
|
|
|
man/fr/Makefile
|
2007-10-07 11:44:59 +00:00
|
|
|
man/hu/Makefile
|
2007-10-07 11:45:14 +00:00
|
|
|
man/id/Makefile
|
|
|
|
man/it/Makefile
|
2007-10-07 11:44:51 +00:00
|
|
|
man/ja/Makefile
|
2007-10-07 11:45:14 +00:00
|
|
|
man/ko/Makefile
|
2007-10-07 11:44:51 +00:00
|
|
|
man/pl/Makefile
|
|
|
|
man/pt_BR/Makefile
|
2007-10-07 11:45:23 +00:00
|
|
|
man/ru/Makefile
|
2007-10-07 11:47:57 +00:00
|
|
|
man/sv/Makefile
|
2007-10-07 11:47:11 +00:00
|
|
|
man/tr/Makefile
|
2007-10-07 11:45:23 +00:00
|
|
|
man/zh_CN/Makefile
|
|
|
|
man/zh_TW/Makefile
|
2007-10-07 11:44:51 +00:00
|
|
|
libmisc/Makefile
|
|
|
|
lib/Makefile
|
|
|
|
src/Makefile
|
|
|
|
contrib/Makefile
|
|
|
|
etc/Makefile
|
|
|
|
etc/pam.d/Makefile
|
2007-10-07 11:45:23 +00:00
|
|
|
shadow.spec
|
|
|
|
])
|
|
|
|
AC_OUTPUT
|
2007-10-07 11:47:01 +00:00
|
|
|
|
|
|
|
echo
|
2007-10-07 11:48:07 +00:00
|
|
|
echo "shadow will be compiled with the following features:"
|
2007-10-07 11:47:01 +00:00
|
|
|
echo
|
|
|
|
echo " auditing support: $with_audit"
|
|
|
|
echo " CrackLib support: $with_libcrack"
|
|
|
|
echo " PAM support: $with_libpam"
|
|
|
|
echo " SELinux support: $with_selinux"
|
|
|
|
echo " shadow group support: $enable_shadowgrp"
|
|
|
|
echo " S/Key support: $with_skey"
|
* configure.in: New configure option: --with-sha-crypt enabled by
default. Keeping the feature enabled is safe. Disabling it permits
to disable the references to the SHA256 and SHA512 password
encryption algorithms from the usage help and manuals (in addition
to the support for these algorithms in the code).
* libmisc/obscure.c, libmisc/salt.c, src/newusers.c,
src/chpasswd.c, src/chgpasswd.c, src/passwd.c: ENCRYPT_METHOD is
always supported in login.defs. Remove the ENCRYPTMETHOD_SELECT
preprocessor condition.
* libmisc/obscure.c, libmisc/salt.c, src/newusers.c,
src/chpasswd.c, src/chgpasswd.c, src/passwd.c: Disable SHA256 and
SHA512 if USE_SHA_CRYPT is not defined (this corresponds to a
subset of the ENCRYPTMETHOD_SELECT sections).
2007-11-24 13:08:08 +00:00
|
|
|
echo " SHA passwords encryption: $with_sha_crypt"
|
2007-10-07 11:47:01 +00:00
|
|
|
echo
|