further idmapd update
[nfs-utils.git] / configure.in
1 dnl Process this file with autoconf to produce a configure script.
2 dnl
3 AC_INIT(rules.mk)
4 AC_PREFIX_DEFAULT(/usr)
5
6 # The nfs-utils version
7 VERSION="1.0.6"
8 AC_SUBST(VERSION)
9
10 dnl *************************************************************
11 dnl * Define the set of applicable options
12 dnl *************************************************************
13 AC_ARG_WITH(release,
14         [  --with-release=XXX      set release to XXX [1]],
15         RELEASE=$withval,
16         RELEASE=1)
17         AC_SUBST(RELEASE)
18 AC_ARG_WITH(statedir,
19         [  --with-statedir=/foo    use state dir /foo [/var/lib/nfs]],
20         statedir=$withval,
21         statedir=/var/lib/nfs)
22         AC_SUBST(statedir)
23 AC_ARG_WITH(statduser,
24         [  --with-statduser=rpcuser user for statd to run under [rpcuser or nobody]],
25         statduser=$withval,
26         if grep -s '^rpcuser:' /etc/passwd > /dev/null; then
27                 statduser=rpcuser
28         else
29                 statduser=nobody
30         fi)
31         AC_SUBST(statduser)
32 AC_ARG_ENABLE(nfsv3,
33         [  --enable-nfsv3          enable support for NFSv3],
34         enable_nfsv3=$enableval,
35         enable_nfsv3=yes)
36         if test "$enable_nfsv3" = yes; then
37                 AC_DEFINE(NFS3_SUPPORTED)
38         else
39                 enable_nfsv3=
40         fi
41         AC_SUBST(enable_nfsv3)
42 AC_ARG_ENABLE(nfsv4,
43         [  --enable-nfsv4          enable support for NFSv4],
44         enable_nfsv4=$enableval,
45         enable_nfsv4=yes)
46         if test "$enable_nfsv4" = yes; then
47                 AC_DEFINE(NFS4_SUPPORTED)
48                 IDMAPD=idmapd
49         else
50                 enable_nfsv4=
51                 IDMAPD=
52         fi
53         AC_SUBST(IDMAPD)
54         AC_SUBST(enable_nfsv4)
55 AC_ARG_ENABLE(gss,
56         [  --enable-gss           enable support for rpcsec_gss],
57         enable_gss=$enableval,
58         enable_gss=yes)
59         if test "$enable_gss" = yes; then
60                 AC_DEFINE(GSS_SUPPORTED)
61                 GSSD=gssd
62                 SVCGSSD=svcgssd
63         else
64                 enable_gss=
65                 GSSD=
66                 SVCGSSD=
67         fi
68         AC_SUBST(GSSD)
69         AC_SUBST(SVCGSSD)
70         AC_SUBST(enable_gss)
71 AC_ARG_ENABLE(kprefix,
72         [  --enable-kprefix       install progs as rpc.knfsd etc],
73         test "$enableval" = "yes" && kprefix=k,
74         kprefix=)
75         AC_SUBST(kprefix)
76 AC_ARG_ENABLE(secure-statd,
77         [  --enable-secure-statd  Only lockd can use statd (security)],
78         test "$enableval" = "yes" && secure_statd=yes,
79         secure_statd=no)
80         if test "$secure_statd" = yes; then
81                 AC_DEFINE(RESTRICTED_STATD)
82         fi
83         AC_SUBST(secure_statd)
84 AC_ARG_ENABLE(rquotad,
85         [  --enable-rquotad          enable rquotad],
86         enable_rquotad=$enableval,
87         enable_rquotad=yes)
88         if test "$enable_rquotad" = yes; then
89                 RQUOTAD=rquotad
90         else
91                 RQUOTAD=
92         fi
93         AC_SUBST(RQUOTAD)
94 dnl AC_ARG_ENABLE(frob, enable frobnicator,,                enable_frob=test)
95 AC_CONFIG_HEADER(support/include/config.h)
96
97 AC_PROG_CC
98 AC_PROG_CPP
99 AC_PROG_INSTALL
100
101 test "${CC_FOR_BUILD+set}" = set || CC_FOR_BUILD="$CC"
102 AC_SUBST(CC_FOR_BUILD)
103
104 AC_CHECK_TOOL(RANLIB, ranlib, :)
105 AC_CHECK_TOOL(AR, ar)
106 AC_CHECK_TOOL(LD, ld)
107
108 AC_STDC_HEADERS
109 AC_GNULIBC
110 dnl AC_LN_SF
111 dnl AC_BSD_SIGNALS
112
113 dnl *************************************************************
114 dnl * Check for required librarues
115 dnl *************************************************************
116 AC_CHECK_LIB(socket, main, [LIBSOCKET="-lnsl"])
117 AC_CHECK_LIB(nsl, main, [LIBNSL="-lnsl"])
118 AC_CHECK_LIB(crypt, crypt, [LIBCRYPT="-lcrypt"])
119 if test "$enable_nfsv4" = yes; then
120     AC_CHECK_LIB(event, event_dispatch)
121     AC_CHECK_LIB(nfsidmap, nfs4_uid_to_name)
122     AC_CHECK_HEADERS(event.h)
123     AC_CHECK_HEADERS(nfsidmap.h)
124 fi
125 if test "$knfsd_cv_glibc2" = no; then
126     AC_CHECK_LIB(bsd, daemon, [LIBBSD="-lbsd"])
127 fi
128 AC_SUBST(LIBSOCKET)
129 AC_SUBST(LIBNSL)
130 AC_SUBST(LIBCRYPT)
131 AC_SUBST(LIBBSD)
132
133 AC_TCP_WRAPPER
134 AC_SUBST(LIBWRAP)
135
136 if test "$enable_gss" = yes; then
137   dnl Checks for Kerberos
138   dnl NOTE: while we intend to do generic gss-api, currently we
139   dnl have a requirement to get an initial Kerberos machine
140   dnl credential.  Thus, the requirement for Kerberos.
141   dnl The Kerberos gssapi library will be dynamically loaded?
142   AC_MSG_CHECKING(for Kerberos v5)
143   AC_ARG_WITH(krb5,
144   [  --with-krb5=DIR         use Kerberos v5 installation in DIR],
145   [ case "$withval" in
146     yes|no)
147        krb5_with=""
148        ;;
149     *)
150        krb5_with="$withval"
151        ;;
152     esac ]
153   )
154
155   for dir in $krb5_with /usr/kerberos /usr/local /usr/local/krb5 /usr/krb5 \
156              /usr/heimdal /usr/local/heimdal /usr/athena /usr ; do
157     dnl This ugly hack brought on by the split installation of
158     dnl MIT Kerberos on Fedora Core 1
159     K5CONFIG=""
160     if test -f $dir/bin/krb5-config; then
161       K5CONFIG=$dir/bin/krb5-config
162     elif test -f "/usr/kerberos/bin/krb5-config"; then
163       K5CONFIG="/usr/kerberos/bin/krb5-config"
164     fi
165     if test "$K5CONFIG" != ""; then
166       if test -f $dir/include/gssapi/gssapi_krb5.h -a \
167               \( -f $dir/lib/libgssapi_krb5.a -o \
168             -f $dir/lib/libgssapi_krb5.so \) ; then
169          AC_DEFINE(HAVE_KRB5)
170          KRBDIR="$dir"
171          K5VERS=`$K5CONFIG --version | awk '{split($4,v,"."); print v[[1]]v[[2]]v[[3]] }'`
172          AC_DEFINE_UNQUOTED(KRB5_VERSION,$K5VERS)
173          KRBLIB=`$K5CONFIG --libs gssapi`
174          if test $K5VERS -le 131; then
175            AC_DEFINE(USE_PRIVATE_KRB5_FUNCTIONS)
176          fi
177          AC_CHECK_LIB(gssapi_krb5, gss_krb5_export_lucid_sec_context,
178            AC_DEFINE(HAVE_LUCID_CONTEXT_SUPPORT),,$KRBLIB)
179          AC_CHECK_LIB(gssapi_krb5, gss_krb5_set_allowable_enctypes,
180            AC_DEFINE(HAVE_SET_ALLOWABLE_ENCTYPES),,$KRBLIB)
181          AC_CHECK_LIB(gssapi_krb5, gss_krb5_ccache_name,
182            AC_DEFINE(HAVE_GSS_KRB5_CCACHE_NAME),,$KRBLIB)
183          break
184       dnl The following ugly hack brought on by the split installation
185       dnl of Heimdal Kerberos on SuSe
186       elif test \( -f $dir/include/heim_err.h -o\
187                  -f $dir/include/heimdal/heim_err.h \) -a \
188                 -f $dir/lib/libroken.a; then
189          AC_DEFINE(HAVE_HEIMDAL)
190          KRBDIR="$dir"
191          K5VERS=`$K5CONFIG --version | head -1 | awk '{split($2,v,"."); print v[[1]]v[[2]]v[[3]] }'`
192          AC_DEFINE_UNQUOTED(KRB5_VERSION,$K5VERS)
193          KRBLIB=`$K5CONFIG --libs gssapi`
194          AC_CHECK_LIB(gssapi, gss_krb5_export_lucid_sec_context,
195            AC_DEFINE(HAVE_LUCID_CONTEXT_SUPPORT),,$KRBLIB)
196          AC_CHECK_LIB(gssapi, gss_krb5_set_allowable_enctypes,
197            AC_DEFINE(HAVE_SET_ALLOWABLE_ENCTYPES),,$KRBLIB)
198          AC_CHECK_LIB(gssapi, gss_krb5_ccache_name,
199            AC_DEFINE(HAVE_GSS_KRB5_CCACHE_NAME),,$KRBLIB)
200         break
201       fi
202       CFLAGS=$CFLAGS `K5CONFIG --cflags`
203     fi
204   done
205   dnl We didn't find a usable Kerberos environment
206   if test "x$KRBDIR" = "x"; then
207     if test "x$krb5_with" = "x"; then
208       AC_MSG_ERROR(Kerberos v5 with GSS support not found)
209     else
210       AC_MSG_ERROR(Kerberos v5 with GSS support not found at $krb5_with)
211     fi
212   fi
213   AC_MSG_RESULT($KRBDIR)
214   dnl If they specified a directory and it didn't work, give them a warning
215   if test "x$krb5_with" != "x" -a "$krb5_with" != "$KRBDIR"; then
216     AC_MSG_WARN(Using $KRBDIR instead of requested value of $krb5_with for Kerberos!)
217   fi
218
219   AC_SUBST([KRBDIR])
220   AC_SUBST([KRBLIB])
221   AC_SUBST([K5VERS])
222 fi
223
224 dnl *************************************************************
225 dnl Check for headers
226 dnl *************************************************************
227 dnl AC_HAVE_HEADERS(string.h)
228
229 dnl *************************************************************
230 dnl Check for functions
231 dnl *************************************************************
232 AC_HAVE_FUNCS(innetgr)
233
234 dnl *************************************************************
235 dnl Export some path names to config.h
236 dnl *************************************************************
237 AC_DEFINE_UNQUOTED(NFS_STATEDIR, "$statedir")
238
239 AC_SUBST(LDFLAGS)
240 AC_SUBST(CXXFLAGS)
241 AC_SUBST(CFLAGS)
242 AC_OUTPUT(config.mk utils/Makefile)